ListView获取选中和长按菜单对应的item的_id值

前端之家收集整理的这篇文章主要介绍了ListView获取选中和长按菜单对应的item的_id值前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先,如果是用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上长按时,想获得长按的这个ListViewitem_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参数,表示选项中显示文字

猜你在找的Sqlite相关文章