在onCreate android之前调用onCreateOptionsMenu

时间:2013-02-07 05:53:36

标签: android actionbarsherlock android-listfragment android-optionsmenu

我是Android的初学者,我正在开发小型Android应用程序。在我的应用程序中,我正在使用Sherlock库。我的应用程序包含一个主要活动和两个片段。在我的列表片段结构看起来像

public class MyCards extends SherlockListFragment
        {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setHasOptionsMenu(true);
        Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside fragment on create");

    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside on activity created");
    }

    private void displayCards(int type) {

        Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside display cards");

    }

    @Override
    public void onResume() {
        super.onResume();

    }

    @Override
    public void onPause() {
        super.onPause();

    }

    @Override
    public void onDestroy() {
        super.onDestroy();
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {

        View view = inflater.inflate(R.layout.mycards, container, false);

        View view1 = inflater.inflate(R.layout.empty_card, container, false);
        return view;

    }

    /*@Override
    public void onPrepareOptionsMenu(Menu menu) {
    super.onPrepareOptionsMenu(menu);

    optionsMenu = menu;
    }*/

    public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
        inflater.inflate(R.menu.menu_type2, menu);

        Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside on create option menu");
        Spinner spinner = (Spinner) menu.findItem(R.id.cardType)
                .getActionView();

        SpinnerAdapter adapter = ArrayAdapter.createFromResource(getSherlockActivity().getSupportActionBar().getThemedContext(), R.array.card_action_list,android.R.layout.simple_spinner_dropdown_item);
        spinner.setAdapter(adapter); // set the adapter

        spinner.setOnItemSelectedListener(new OnItemSelectedListener() {

            @Override
            public void onItemSelected(AdapterView<?> parent, View view,
                    int pos, long id) {
                displayCards(pos);
                Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside on option selected");
            }

            @Override
            public void onNothingSelected(AdapterView<?> arg0) {
                displayCards(0);
                Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside on no option selection");
            }

        });


    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        Log.i("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", "inside option select listener");

    }

}

现在我的问题是当我第一次将一个片段切换到另一个片段时 它提供以下日志输出

01-04 00:54:06.997: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(2575): inside on create option menu
01-04 00:54:06.997: W/KeyCharacterMap(2575): No keyboard for id -1
01-04 00:54:06.997: W/KeyCharacterMap(2575): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
01-04 00:54:07.020: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(2575): inside fragment on create
01-04 00:54:07.036: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(2575): inside on activity created

这意味着在onfragment create和on activity create之前调用的create选项。它还给出了两个警告。这项工作没有任何错误。但我无法显示我的列表视图

现在,当我再次切换到相同的片段(第二次)时,它会提供以下日志输出

02-07 10:05:10.983: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(15844): inside on create option menu
02-07 10:05:11.023: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(15844): inside fragment on create
02-07 10:05:11.043: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(15844): inside on activity created
02-07 10:05:11.113: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(15844): inside display cards
02-07 10:05:11.133: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(15844): inside on option selected

这次它没有发出任何警告并正常工作。还显示我的列表视图。 但这是第一次不能正常工作.. 另一点是,当我在更高版本的android上运行它时工作正常。但如果我在2.3.3的较低版本的android上运行它我会显示这样的行为.. 我读到了这个ListFragment onPrepareOptionsMenu called before onCreate. Why and How to Fix / Bypass?但是我无法解决这个问题。

如果我在setHasOptionsMenu(true)内定义onActivityCreated,则会提供以下输出

01-04 03:32:38.622: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(8157): inside fragment on create
01-04 03:32:38.653: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(8157): inside on activity created
01-04 03:32:38.692: I/!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(8157): inside on create option menu
01-04 03:32:38.700: W/KeyCharacterMap(8157): No keyboard for id -1
01-04 03:32:38.700: W/KeyCharacterMap(8157): Using default keymap: /system/usr/keychars/qwerty.kcm.bin

我还尝试为我的片段设置setHasOptionsMenu,其中实际片段事务发生如下所示。

@Override
        public void onTabSelected(Tab tab, FragmentTransaction ft) {
            MyCards mc = new MyCards();
            mc.setHasOptionsMenu(true);
            ft = mActivity.getSupportFragmentManager().beginTransaction();

                mFragment = Fragment.instantiate(mActivity, mClass.getName(),
                        mArgs);

                ft.add(android.R.id.content, mFragment, mTag);
                ft.commit();
            }

仍然存在同样的问题。

我的代码或其他一些问题? 那么如何解决这个问题呢。 需要帮忙... 谢谢......

2 个答案:

答案 0 :(得分:28)

setHasOptionsMenu(true);方法中写onActivityCreated(Bundle savedInstanceState)

答案 1 :(得分:1)

我不知道它为什么会这样,但是这样做: 在向其中添加片段时,在Activity中设置选项setHasOptionsMenu(true)

例如:

//Activity class
YourListFragment f = new YourListFragment();

f.setHasOptionsMenu(true); //here

getSupportFragmentManager().beginTransaction()
.add(R.id.your_list_fragment_container, f).commit();

并删除片段代码中的设置。它对我有用。