我在 SO 上发现了许多类似问题的实例,但遗憾的是没有答案符合我的要求。
我有不同的纵向和横向布局,并且我正在使用后堆栈,这既阻止我setRetainState()
使用配置更改例程,又会欺骗我使用配置更改例程。
我在 TextViews 中向用户显示某些信息,这些信息不会保存在默认处理程序中。仅使用活动编写我的应用程序时,以下内容运行良好:
TextView vstup;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.whatever);
vstup = (TextView)findViewById(R.id.whatever);
/* (...) */
}
@Override
public void onSaveInstanceState(Bundle state) {
super.onSaveInstanceState(state);
state.putCharSequence(App.VSTUP, vstup.getText());
}
@Override
public void onRestoreInstanceState(Bundle state) {
super.onRestoreInstanceState(state);
vstup.setText(state.getCharSequence(App.VSTUP));
}
使用Fragment
s,这仅适用于非常特定的情况。具体来说,最糟糕的是替换片段,将其放入后堆栈,然后在显示新片段时旋转屏幕。据我了解,旧片段在被替换时不会收到调用,但会以onSaveInstanceState()
某种方式与Activity
View
TextView
NullPointerException
另外,我发现使用 s 保留对 my 的引用TextViews
并不是一个好主意Fragment
,即使使用Activity
's 也可以。在这种情况下,实际上保存了状态,但是如果我在隐藏片段时onSaveInstanceState()
旋转屏幕两次onCreateView()
,问题会再次出现,因为它不会在新实例中被调用。
我想将状态保存onDestroyView()
到某个Bundle
-type 类成员元素中(实际上是更多数据,而不仅仅是一个TextView
)并将其保存在其中onSaveInstanceState()
,但还有其他缺点。首先,如果当前显示片段,调用这两个函数的顺序是相反的,所以我需要考虑两种不同的情况。必须有一个更清洁和正确的解决方案!