首先,如果是用simpleCursorAdapter填充ListView的数据时,必须注意SQLite的主键命名,由于simpleCursorAdapter的方法只识别_id,所以,当你用到SQLite的simpleCursorAdapter时,必须把数据表的主键命名为_id。否则就会出现java.lang.IllegalArgumentException: column '_id' does not exist错误。
(1)言归正传,当我们点击ListView时,会调用ListView的点击事件,那么点击的这个item的对应的数据库的_id的值,我们可以通过以下代码获取
- //添加点击
- listView.setOnItemClickListener(new OnItemClickListener() {
- public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) {
- //setTitle("点击第"+arg2+"个项目");
- String mytitle = null;
- String mycontent = null;
- switch(arg0.getId())
- {
- case R.id.ListView01:
- ListView templist = (ListView)arg0;
- View mView = templist.getChildAt(arg2);
- mytextview = (TextView) mView.findViewById(R.id.ItemTitle);
- mytitle = mytextview.getText().toString();
- mysqlhelper.db = mysqlhelper.mOpenHelper.getReadableDatabase();
- Cursor cur=mysqlhelper.db.rawQuery("select Content from Table_1 where Title = ?",new String[]{mytitle});
- int count=cur.getCount();
- cur.moveToFirst();
- mycontent=cur.getString(0);
- cur.close();
- mysqlhelper.db.close();
- Intent intent = new Intent(view_Activity.this, modify_Activity.class);
- intent.putExtra("Title",mytitle);
- intent.putExtra("Content",mycontent);
- startActivityForResult(intent, SUBACTIVITY2);
- break;
- }
- }
- });
- //添加长按点击
- listView.setOnCreateContextMenuListener(new OnCreateContextMenuListener() {
- public void onCreateContextMenu(ContextMenu menu, View v,ContextMenuInfo menuInfo) {
- menu.setHeaderTitle("确定删除?");
- menu.add(0, 0, 0, "OK");
- menu.add(0, 1, 0, "Cancel");
- }
- });
(2)另外,我们可能还会用到长按菜单(上下文菜单),当我们在ListView上长按时,想获得长按的这个ListView的item的_id的值,参考下面这段代码
- //长按菜单响应函数
- @Override
- public boolean onContextItemSelected(MenuItem item) {
- // TODO Auto-generated method stub
- ContextMenuInfo menuInfo = (ContextMenuInfo) item.getMenuInfo();
- AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo)item.getMenuInfo();
- int id = (int)info.id;//这里的info.id对应的就是数据库中_id的值
- switch(item.getItemId())
- {
- case 0:
- ListView templist = listView;
- View mView = templist.getChildAt(id);
- mytextview = (TextView) mView.findViewById(R.id.ItemTitle);
- String title1 = mytextview.getText().toString();
- //setTitle("点击了长按菜单里面的第"+title1+"个项目");
- mysqlhelper.DeleteItem(title1); //删除这条记录
- break;
- case 1:
- break;
- }
- return super.onContextItemSelected(item);
- }
menu.add方法的参数:
第一个int类型的group ID参数,代表的是组概念,你可以将几个菜单项归为一组,以便更好的以组的方式管理你的菜单按钮。
第二个int类型的item ID参数,代表的是项目编号。这个参数非常重要,一个item ID对应一个menu中的选项。在后面使用菜单的时候,就靠这个item ID来判断你使用的是哪个选项。
第三个int类型的order ID参数,代表的是菜单项的显示顺序。默认是0,表示菜单的显示顺序就是按照add的显示顺序来显示。
第四个String类型的title参数,表示选项中显示的文字。