ListActivity:在将数据放入行之前从SQLite更改数据

时间:2009-12-11 12:19:23

标签: android listactivity

这是我的ListActivity:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.my_list);

    mDbHelper = new MyDbAdapter(this);
    mDbHelper.open();
    fillData();

    registerForContextMenu(getListView());
}

private void fillData() {
    // Get all of the rows from the database and create the item list
    Cursor c = mDbHelper.fetchAllTransactions();
    startManagingCursor(c);

    // Create an array to specify the fields we want to display in the list
    String[] from = new String[]{MyDbAdapter.KEY_DATE, MyDbAdapter.KEY_NAME};

    // and an array of the fields we want to bind those fields to
    int[] to = new int[]{R.id.row_date, R.id.row_name};

    // Now create a simple cursor adapter and set it to display
    setListAdapter(new SimpleCursorAdapter(this, R.layout.my_list_row, c, from, to));
}

这是我的行布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content">
    <TextView android:id="@+id/row_date" android:layout_width="wrap_content" android:layout_height="fill_parent" />
    <TextView android:id="@+id/row_name" android:layout_width="wrap_content" android:layout_height="fill_parent" />
</LinearLayout>

日期实际上存储为SQLLite数据库中的int,因此它显示为整数。

有没有人知道从int创建日期的方法,因此它不会显示为1216544611(或其他),而是显示为"12/11/2009 11:32"

2 个答案:

答案 0 :(得分:2)

我怀疑您需要编写自己的CursorAdapter,将int格式化为日期字符串。诀窍是在列表项显示之前实现bindView()格式化:

private final class MyCursorAdapter extends CursorAdapter {
    MyCursorAdapter(Context context, Cursor c) {
        super(context, c);
    }

    @Override public void bindView(View view, Context context, Cursor cursor) {             

        // Format the date string
        TextView dateView = (TextView) view.findViewById(R.id.row_date);
        long millis = cursor.getLong(cursor.getColumnIndex(MyDbAdapter.KEY_DATE));
        dateView.setText(DateFormat.getDateInstance().format(new Date(milis)));

        // Do the rest of your view formatting
        ...
    }

    @Override View public newView(Context context, Cursor cursor, ViewGroup parent) {        
        View view = getLayoutInflater().inflate(R.layout.my_list_row, null);
        bindView(view, context, cursor);
        return view;        
    }
}

并将其连接到Activity中的onCreate()

setListAdapter(new MyCursorAdapter(this, c));

答案 1 :(得分:1)

对于像我这样想知道getLayoutInflater()下CursorAdapter未实现或继承的内容的人,试试这个:

(LayoutInflater) context.getSystemService( Context.LAYOUT_INFLATER_SERVICE );