方向改变后的第二个活动实例

时间:2012-03-05 20:56:23

标签: android android-activity orientation-changes

我的应用程序中有一个奇怪的行为有关方向更改。

正常行为:
当我打开我的应用时,我的家庭活动开始了。当我进入下一个活动(画廊)时,它会正常启动(从右到左滑动动画)。 当我使用后退键返回时,当前活动(图库)已完成(从左到右的滑动动画)。

奇怪的行为:

  • 当我以纵向模式启动应用程序并将方向更改为横向时。然后就像家庭活动的第二个例子。因为然后在横向模式下按后退按钮不会像没有取消更改那样关闭应用程序(主页活动是我的应用程序中的第一个活动)但rahter从左到右制作滑动动画(如开始新活动)并再次显示家庭活动(但我认为另一个实例)。再次按后退按钮可关闭应用程序。
  • 当我在横向模式下启动应用程序并将目标更改为纵向模式时,请按后退按钮从右到左生成幻灯片动画(如关闭活动)并再次显示主页活动。
  • 当我启动应用程序并进行两个方向更改纵向 - 横向 - 纵向时,后退按钮会关闭应用程序。

所以它就像风景和肖像模式被视为两种不同的活动。

我不使用android:configChanges="orientation|keyboardHidden|screenSize",因此方向更改应遵循正常的Android活动生命周期并销毁活动的“旧”纵向(或横向)版本。
我的活动继承自FragmentActivity。 我正在使用onSaveInstanceState传递一个parceable(不包含对该活动的任何引用),我正在使用onRetainCustomNonConfigurationInstanceread 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;
    }

我希望这有帮助吗?!

1 个答案:

答案 0 :(得分:0)

我遇到了类似的问题,看来问题的原因是覆盖onRetainCustomNonConfigurationInstance()

我查看了保留状态对象,发现它持有对Context的引用。我把它包裹在一个WeakReference中,恢复了正常的行为,没有奇怪的双重实例徘徊。

也许您的保留状态也包含对Context的引用?