日付の比較に問題があります。TextView からの日付があります (通常は SQLite テキスト フィールドに格納されます)。TextView の rowduedate には、「2012/10/01 15:16」という値の日付が含まれています。以下に貼り付けたコードをコメントアウトすると、正常に動作し、R.id.rowduedate が表示されます。だから空じゃない。ただし、LogCat で次のエラーが発生します。
11-01 15:16:55.445: E/AndroidRuntime(783): FATAL EXCEPTION: main
11-01 15:16:55.445: E/AndroidRuntime(783): java.lang.NumberFormatException: Invalid long: ""
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.invalidLong(Long.java:125)
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.parseLong(Long.java:346)
11-01 15:16:55.445: E/AndroidRuntime(783): at java.lang.Long.parseLong(Long.java:319)
11-01 15:16:55.445: E/AndroidRuntime(783): at com.android.demo.notepad3.Notepadv3$1.setViewValue(Notepadv3.java:100)
これはコードです:
TextView dueDate = (TextView) view.findViewById(R.id.rowduedate);
String due = (String) dueDate.getText().toString();
if(due!=null){
Long longDue = Long.parseLong(due);
String now = new Date().toString();
Long longNow = Long.parseLong(now);
if(longDue <= longNow){
dueDate.setTextColor(Color.RED);
}
}