我的应用程序中有一个奇怪的行为有关方向更改。
正常行为:
当我打开我的应用时,我的家庭活动开始了。当我进入下一个活动(画廊)时,它会正常启动(从右到左滑动动画)。
当我使用后退键返回时,当前活动(图库)已完成(从左到右的滑动动画)。
奇怪的行为:
所以它就像风景和肖像模式被视为两种不同的活动。
我不使用android:configChanges="orientation|keyboardHidden|screenSize"
,因此方向更改应遵循正常的Android活动生命周期并销毁活动的“旧”纵向(或横向)版本。
我的活动继承自FragmentActivity
。
我正在使用onSaveInstanceState
传递一个parceable(不包含对该活动的任何引用),我正在使用onRetainCustomNonConfigurationInstance
(read here)来传递多个AsyncTask
s 。但是这些任务中的所有引用(如果它们都有)在onRetainCustomNonConfigurationInstance
中被销毁并在getLastCustomNonConfigurationInstance
之后恢复(使用新创建的活动)。
任何可能导致此行为的想法?
修改
清单文件中的活动声明:
<activity android:name=".activities.smartphone.HomeSmartphone" android:label="@string/app_name"></activity>
HomeSmartphone扩展首页
Home扩展了MyFragmentActivity
MyFragmentActivity扩展了android.support.v4.app.FragmentActivity
在MyFragmentActivity中,我只是通过调用跟踪类的一些静态方法,在onCreate,onRestart,onStart,onSaveInstanceState,onPause,onResume,onStop,onDestroy上执行一些日志记录/跟踪操作,这些方法只保存对应用程序上下文的引用。不是活动背景。
Home是一个抽象类,由HomeSmartphone和HomeTablet扩展。这两个类只在不同的布局中进行一些特殊的加载/刷新/初始化。
最多的任务是在抽象的Home类中完成的。
public HomeRetainedObjects retained = new HomeRetainedObjects();
public boolean adIsShown = false;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.home);
Log.i("DEBUG", "onCreate(Home)");
if (savedInstanceState != null) {
this.adIsShown = savedInstanceState.getBoolean("adIsShown");
}
// write/update values in shared preferences
this.initPreferences();
// recover retained objects (mostly AsyncTasks)
this.recoverRetained();
// show content / refresh content
this.init();
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putBoolean("adIsShown", this.adIsShown);
Log.i("DEBUG", "onSaveInstanceState(Home)");
}
public void recoverRetained() {
Object retained = this.getLastCustomNonConfigurationInstance();
if (retained instanceof HomeRetainedObjects) {
this.retained = (HomeRetainedObjects) retained;
if (this.retained.loadMessageTask != null) {
this.retained.loadMessageTask.restoreContext(this);
}
}
}
@Override
public Object onRetainCustomNonConfigurationInstance() {
if (this.retained.loadMessageTask != null) {
this.retained.loadMessageTask.destroyContext();
}
return this.retained;
}
我希望这有帮助吗?!
答案 0 :(得分:0)
我遇到了类似的问题,看来问题的原因是覆盖onRetainCustomNonConfigurationInstance()
。
我查看了保留状态对象,发现它持有对Context
的引用。我把它包裹在一个WeakReference
中,恢复了正常的行为,没有奇怪的双重实例徘徊。
也许您的保留状态也包含对Context
的引用?