2012-10-17 31 views
3

所以我现在的问题是,现在我很长时间点击ListView中的一个项目,它会弹出一个上下文操作栏。传入onItemLongClick的id是我想在ActionItemClicked()方法的mActionModeCallback中使用的变量。这似乎是一个相当普遍的过程,因为如果用户正在编辑项目列表,那么当用户单击“编辑”或“删除”操作时,您会希望以某种方式访问​​数据库中该行的标识。将ListView项目的id传递给ActionMode.Callback对象

listView.setOnItemLongClickListener(new OnItemLongClickListener() { 
    public boolean onItemLongClick(AdapterView<?> p, View view, int pos, long id) { 

     //The id of the row in the database 
     long variableThatIWantToPassToCallback = id; 
     mActionMode = getActivity().startActionMode(mActionModeCallback); 
     view.setSelected(true); 
     return true; 
    } 
}); 

private ActionMode.Callback mActionModeCallback = new ActionMode.Callback() { 

    public boolean onCreateActionMode(ActionMode mode, Menu menu) {} 

    public boolean onPrepareActionMode(ActionMode mode, Menu menu) {} 

    public boolean onActionItemClicked(ActionMode mode, MenuItem item) { 
     //I would like access to the id of the clicked item here, NOT item.getItemId() 
    } 

    public void onDestroyActionMode(ActionMode mode) {} 
}; 
+0

你不能在'ActionMode.Callback'中访问'ListView'的适配器吗?从那里你可以得到检查的项目(方便地由你存储),或者如果你使用SDK行布局,你可以使用对ListView的引用并使用getCheckedItemsIds。 – Luksprog

回答

8

正确的方式做,这是调用mActionMode.setTag("1")onItemCheckedStateChanged然后从onActionItemClicked函数调用mode.getTag();

1

通过扩展接口ActionMode.Callback

private interface ActionCallback extends ActionMode.Callback { 
     public void setClickedView(View view); 
} 

private ActionCallback mActionModeCallback = new ActionCallback() { 

     public View mClickedView; 

     public void setClickedView(View view) { 
      mClickedView = view; 
     } 

     // Called when the action mode is created; startActionMode() was called 
     @Override 
     public boolean onCreateActionMode(ActionMode mode, Menu menu) { 
      // Inflate a menu resource providing context menu items 
      MenuInflater inflater = mode.getMenuInflater(); 
      inflater.inflate(R.menu.context_menu, menu); 
      return true; 
     } 

     // Called each time the action mode is shown. Always called after onCreateActionMode, but 
     // may be called multiple times if the mode is invalidated. 
     @Override 
     public boolean onPrepareActionMode(ActionMode mode, Menu menu) { 
      return false; // Return false if nothing is done 
     } 

     // Called when the user selects a contextual menu item 
     @Override 
     public boolean onActionItemClicked(ActionMode mode, MenuItem item) { 
      switch (item.getItemId()) { 
       case R.id.menu_delete: 
        Log.v(TAG, "#onActionItemClicked ready to delete the item with id: " + mClickedView.getTag()); 
        mode.finish();  // Action picked, so close the CAB 
        return true; 
       default: 
        return false; 
      } // end switch 
     } 

     // Called when the user exits the action mode 
     @Override 
     public void onDestroyActionMode(ActionMode mode) { 
      mActionMode = null; 
     } 
}; 

对于一个视图中创建您自己的回调其中附有OnLongClickListener,用这种方式覆盖onLongClick回调。

     @Override 
       // Called when the user long-clicks on someView 
       public boolean onLongClick(View view) { 
        // proceed only when actionmode is not null 
        // otherwise overlapping action modes will be 
        // displayed 
        if(mActionMode != null) { 
         return false; 
        } 

        mActionModeCallback.setClickedView(view); 
        // Start the CAB using the ActionMode.Callback defined above 
        mActionMode = startActionMode(mActionModeCallback); 
        view.setSelected(true); 
        return true; 
       } 
+0

为什么在'onDestroyActionMode'中设置'mode = null'? – Muddz