0

这是一个在 StackOverflow 上流传了一段时间的问题,在您将此问题标记为重复之前,我知道此链接。但是,这个问题很模糊,没有代码,而且似乎没有得到完全的回答。

那么关于我的问题:

我有一个ListFragment(MainListFragment),它onLongItemClick打开了一个Contextual Action Bar. 此上下文操作栏中的菜单项之一可以删除ListView长按的项目。

在实现的类中ActionMode.Callback,我可以删除长按的项目,但我需要在ListView删除后刷新自身,这样用户就不必切换片段来查看删除的效果。

在这里你可以看到我onLongItemClickListener的内部MainListFragment

this.getListView().setOnItemLongClickListener(new OnItemLongClickListener(){

        @Override
        public boolean onItemLongClick(AdapterView<?> adapter, View view,
                int pos, long id) {
            // TODO Auto-generated method stub
            Log.d("My Debug Bitches", "made it to the listener");
            MainListContextualMenu menu = new MainListContextualMenu();
            //view.startActionMode(menu);
            ActionMode mode = getActivity().startActionMode(menu);
            Object[] tags = new Object[2];
            tags[0] = view.getRootView().getContext();
            tags[1] = pos;
            mode.setTag(tags);
            //view.setSelected(true);
            return true;
        }

    });

这是我的 ActionMode.Callback 实现类:

public class MainListContextualMenu implements ActionMode.Callback{

@Override
public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
    // TODO Auto-generated method stub

    switch(item.getItemId()){
    case R.id.main_list_contextual_menu_delete:

        //MainActivity activity = (MainActivity) mode.getCustomView().getContext();
        //activity.getLists().remove(mode.getTag());

        Object[] tags = (Object[]) mode.getTag();
        MainActivity activity = (MainActivity) tags[0];
        int index = (Integer) tags[1];
        //Log.d("My Debug Bitches","" +index);
        //Log.d("My Debug Bitches", "size before " + activity.getLists().size());
        activity.getLists().remove(index);
        //Log.d("My Debug Bitches", "size after " + activity.getLists().size());
        break;
    case R.id.main_list_contextual_menu_edit:
        break;
    }


    return false;
}

@Override
public boolean onCreateActionMode(ActionMode mode, Menu menu) {
    // TODO Auto-generated method stub
    MenuInflater inflater = mode.getMenuInflater();
    inflater.inflate(R.menu.main_list_contextual_menu, menu);
    Log.d("My Debug Bitches", "menu inflated");
    return true;
}

@Override
public void onDestroyActionMode(ActionMode mode) {
    // TODO Auto-generated method stub
    Object[] tags = (Object[]) mode.getTag();
    MainActivity activity = (MainActivity) tags[0];
    ListView view = (ListView) activity.getCurrentFocus();
}

@Override
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
    // TODO Auto-generated method stub
    return false;
}

}

我已经尝试invalidateViews()在我的onDestroyActionMode()方法中使用无济于事,并且我看到其他人推荐notifyDataSetChange().

但是,我不确定如何在 ActionMode.Callback 中使用这些解决方案。如果您查看我的onLongClick()方法,我mode.setTag()会同时传递被单击的 ListView 项的MainActivity和。position这是好形式吗?

我只是希望能够ListView从方法MainListFragment中刷新ActionMode.Callback.onDestroyActionMode()

以前有没有人让这个工作,如果有,他/她有什么建议吗?

4

1 回答 1

1

我根据您的实现建议这个答案,可能有更好的方法,首先创建一个方法,该方法getAdapter() 将返回您adapter用于您的listview.

ArrayAdapter adapter;

public ArrayAdapter getAdapter()
    {
        // TODO Auto-generated method stub
        return adapter;
    }

现在像这样改变你的代码,添加这个 activity.getAdapter().notifyDataSetChanged();

case R.id.main_list_contextual_menu_delete:

        //MainActivity activity = (MainActivity) mode.getCustomView().getContext();
        //activity.getLists().remove(mode.getTag());

        Object[] tags = (Object[]) mode.getTag();
        MainActivity activity = (MainActivity) tags[0];
        int index = (Integer) tags[1];
        //Log.d("My Debug Bitches","" +index);
        //Log.d("My Debug Bitches", "size before " + activity.getLists().size());
        activity.getLists().remove(index);
        activity.getAdapter().notifyDataSetChanged();
        //Log.d("My Debug Bitches", "size after " + activity.getLists().size());
        break;

希望它会有所帮助。

于 2014-02-10T07:39:17.153 回答