这里的时候,打了两次电话是一个简单的Android应用我创建证明我的问题:安卓onCreateOptionsMenu恢复状态
public class OptionMenuTest extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d("test", "create activity");
setContentView(R.layout.options_layout);
if(getFragmentManager().findFragmentByTag("frag") == null) {
getFragmentManager().beginTransaction().add(R.id.option_fragment_container, new OptionMenuFragment(), "frag").commit();
}
}
@Override
protected void onSaveInstanceState(Bundle outState) {
Log.d("test", "saving Activity state");
super.onSaveInstanceState(outState);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
Log.d("test", "create Activity options menu");
menu.add("activity");
return true;
}
}
片段:
public class OptionMenuFragment extends Fragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.d("test", "create fragment");
setHasOptionsMenu(true);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
TextView tv = new TextView(getActivity());
tv.setText("Hello world");
Log.d("test", "create fragment view");
return tv;
}
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
menu.add("fragment");
Log.d("test", "create fragment options menu");
}
}
布局只是转储片段导入的LinearLayout :
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/option_fragment_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
</LinearLayout>
很简单吧?当我运行它,我得到以下输出预期:
06-12 15:42:51.415: D/test(957): create activity
06-12 15:42:51.446: D/test(957): create fragment
06-12 15:42:51.446: D/test(957): create fragment view
06-12 15:42:51.446: D/test(957): create Activity options menu
06-12 15:42:51.446: D/test(957): create fragment options menu
现在,当我旋转手机,我得到一些奇怪的行为:
06-12 15:43:11.251: D/test(957): saving Activity state
06-12 15:43:11.290: D/test(957): create fragment
06-12 15:43:11.290: D/test(957): create activity
06-12 15:43:11.306: D/test(957): create fragment view
06-12 15:43:11.306: D/test(957): create Activity options menu
06-12 15:43:11.306: D/test(957): create fragment options menu
06-12 15:43:11.306: D/test(957): create Activity options menu
06-12 15:43:11.306: D/test(957): create fragment options menu
为什么活动onCreateOptionMenu和片段onCreateOptionsMenu叫了两声?如果我删除片段中的选项菜单,我得到1调用活动onCreateOptionsMenu预期:
06-12 15:50:03.610: D/test(1076): create fragment
06-12 15:50:03.610: D/test(1076): create fragment view
06-12 15:50:03.813: D/test(1076): create Activity options menu
06-12 15:50:08.392: D/test(1076): saving Activity state // <-- rotate happens here
06-12 15:50:08.446: D/test(1076): create fragment
06-12 15:50:08.446: D/test(1076): create activity
06-12 15:50:08.462: D/test(1076): create fragment view
06-12 15:50:08.470: D/test(1076): create Activity options menu
我不明白这一点,并没有其他人似乎也遇到了这个问题。真正的问题是我的SearchView无法在配置更改(电话旋转)时恢复它的状态,因为onCreateOptionMenu被调用两次。第一次它似乎有它的状态,但第二次它被清除并重置。我无法弄清楚我做错了什么。
在此先感谢。
我觉得你最好的拍摄是获得源代码的保持,并通过它与调试步骤。可能是Android中的一个错误。 –
我在这个问题上还没有取得任何进展。我已经介绍了代码,但不熟悉幕后的片段/活动生命周期,以了解正在发生的事情或可能出现的问题。现在我已经有了一个解决方法,这很“黑客”,但我正在继续前进。如果有人想出答案,请告诉我。谢谢! – Dave
我有完全相同的问题。 'onCreateOptionMenu'和'onPrepareOptionsMenu'被调用两次,第二次重置菜单状态。还没有找到解决方案:( –