Android - 使用CursorAdapter将日期设置为RelevantDate

时间:2013-08-24 06:25:18

标签: android android-sqlite android-cursoradapter

让我举一个我想要实现的要求的例子。 (对不起,如果这是一个愚蠢的问题,但我的大脑现在有点油炸,我自己正在研究这个问题)

我有一个CursorAdapter(在后端有/ SQLite),我用于ListView来显示内容。我正在显示的列表项中的一个字段是项目添加到Listview的日期。所以...

CASE:

如果今天是2013年12月31日,我刚创建了一个列表项,我希望它显示“今天”。 2014年1月1日,我希望将日期更改为“昨天”。最后,在2014年1月2日,我希望将日期更改为“ 12/31/2013 ”。

满足这些要求的简单或最优雅的方法是什么?我不想经常检查我的整个列表视图的日期,并对CPU有意义。关于保存日期的最佳做法的任何想法也将非常感谢!

谢谢!

1 个答案:

答案 0 :(得分:0)

我认为我已经开始工作......我在listview所在的活动中使用此方法,并在onCreate,onStart和onResume上调用它。

 public void setRelevantDate() {
    SimpleDateFormat year = new SimpleDateFormat("MM/dd/yyyy", Locale.US); 
    Date date = new Date();
    String current_date = year.format(date);
    String db_day_after_creation_date;



  //check dates created, sub "today" or "yesterday"
    for(SoundData s: app.unsent_recordings){
        Log.e("soundData date flag",String.valueOf(s.isAfter_Day_two()));
        Log.e("soundData date buffer",s.getDate_buffer());
        Log.e("soundData date created",s.getDate_created());

        if (!s.isAfter_Day_two()){ //if we are two days after the creation then we can skip all the checks for this item because
                                    // it has already been set back to the initial MM/dd/yyyy date format
        String sql_date = s.getDate_buffer();
        String db_date = sql_date.substring(0,10);
        String db_time = sql_date.substring(11);

        //find the day after creation date
        SimpleDateFormat sdf = new SimpleDateFormat("MM/dd/yyyy", Locale.US);
        Calendar c = Calendar.getInstance();
        try {
            c.setTime(sdf.parse(db_date));
        } catch (ParseException e) {
            e.printStackTrace();
        }
        c.add(Calendar.DATE, 1);
        db_day_after_creation_date = sdf.format(c.getTime());


        if (db_date.equals(current_date)){
                   s.setDate_created("Today, "+db_time);
                   app.update_Recording_DateCreated(s.getId(),"Today, "+db_time, s.getDate_buffer(), String.valueOf(s.isAfter_Day_two()));  //dateCreated = today, TIME
        }
        else if(current_date.equals(db_day_after_creation_date)){                       // basically if the current date is equal to the day after the db_created date
                   s.setDate_created("Yesterday, "+db_time);
                                                                //we can say that it was created yesterday
                   app.update_Recording_DateCreated(s.getId(),"Yesterday, "+db_time, s.getDate_buffer(), String.valueOf(s.isAfter_Day_two()));  

        }
        else{
                s.setDate_created(sql_date);
                                                        //Otherwise use normal date
                app.update_Recording_DateCreated(s.getId(),sql_date,s.getDate_buffer(), String.valueOf(s.isAfter_Day_two()));   //dateCreated = dateBuffer

        }

            app.mCursor = app.db.getCursor();
            app.rec_adapter.changeCursor(app.mCursor);
            app.rec_adapter.notifyDataSetChanged();                                             //Update cursor, notifyDataSetChanged()
        }