首先,如果是用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,"OK"); menu.add(0,1,"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的显示顺序来显示。