Android - Format Timestamp in ListView with Cursor Adapter

前端 未结 3 545
迷失自我
迷失自我 2021-01-05 04:57

I am using a SimpleCursorAdapter to populate an Android ListView, and was wondering how I should go about getting all of the timestamps I get from a database, each in \"DATE

3条回答
  •  执念已碎
    2021-01-05 05:49

    You're going to have to create a custom CursorAdapter to be able to format your timestamps.

    public class MyAdapter extends CursorAdapter {
        private final LayoutInflater mInflater;
    
        public MyAdapter(Context context, Cursor cursor) {
            super(context, cursor, false);
            mInflater = LayoutInflater.from(context);
        }
    
        @Override
        public View newView(Context context, Cursor cursor, ViewGroup parent) {
             return mInflater.inflate(R.layout.program_date, parent, false);
        }
    
        @Override
        public void bindView(View view, Context context, Cursor cursor) {
            long time = cursor.getLong(cursor.getColumnIndex("DATE_DATE")) * 1000L;
    
            Calendar cal = Calendar.getInstance();
            cal.setTimeInMillis(time);
    
            String format = "M/dd h:mm a";
            SimpleDateFormat sdf = new SimpleDateFormat(format);
            String dateString = sdf.format(cal.getTime());
    
            ((TextView) view.findViewById(R.id.text1)).setText(dateString);
        }
    }
    

    The list to change the String format to your liking is here.

    You'd then use this adapter with

    Cursor programDateCursor = mDbAdapter.loadProgramDates();
    startManagingCursor(programDateCursor);
    
    setListAdapter(new MyAdapter(this, programDateCursor));
    

提交回复
热议问题