我的应用程序显示注册活动的第一次用户运行应用程序,看起来像:

ActivitySplashScreen(欢迎加入游戏,注册账号吗?) ActivitySplashScreenSignUp(很好,填写这个信息) ActivityGameMain(游戏主界面)

因此,当用户单击每个屏幕上的按钮时,这些活动以相同的顺序相互启动。

当用户从活动#2到#3时,是否有可能将#1和#2从历史堆栈中完全擦除?我希望这样,如果用户处于#3,并点击返回按钮,他们只会回到主屏幕,而不是回到启动画面。

我想我可以完成任务。开始第三项任务,但想看看是否有更简单的方法,

谢谢


当前回答

在API 11之前工作的一种方法是首先启动ActivityGameMain,然后在该活动的onCreate中启动ActivitySplashScreen活动。ActivityGameMain不会在你太早调用startActivity时出现。

然后你可以在启动ActivityGameMain时通过在Intent上设置这些标志来清除堆栈:

intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);

您还必须将此添加到ActivitySplashScreen:

@Override
public void onBackPressed() {
    moveTaskToBack(true);
}

按回那个活动不会回到你的ActivityGameMain。

我假设你不希望启动画面回到任何一个,为了实现这一点,我建议将它设置为noHistory在你的AndroidManifest.xml。然后将goBackPressed代码放在ActivitySplashScreenSignUp类中。

然而,我发现了一些方法来打破这个。从通知中启动另一个应用程序,同时ActivitySplashScreenSignUp显示,并且不重置回溯历史。

唯一真正解决这个问题的方法是在API 11中:

intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);

其他回答

从历史记录中删除一个活动是通过在你不想要的活动之前设置标志来完成的

A - C > B - > - > D

假设A,B,C和D是4个活动,如果你想清除B和C 设置标志

intent.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);

在活动A和B中

这是代码位

Intent intent = new Intent(this,Activity_B.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);
startActivity(intent);

在API 11之前工作的一种方法是首先启动ActivityGameMain,然后在该活动的onCreate中启动ActivitySplashScreen活动。ActivityGameMain不会在你太早调用startActivity时出现。

然后你可以在启动ActivityGameMain时通过在Intent上设置这些标志来清除堆栈:

intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);

您还必须将此添加到ActivitySplashScreen:

@Override
public void onBackPressed() {
    moveTaskToBack(true);
}

按回那个活动不会回到你的ActivityGameMain。

我假设你不希望启动画面回到任何一个,为了实现这一点,我建议将它设置为noHistory在你的AndroidManifest.xml。然后将goBackPressed代码放在ActivitySplashScreenSignUp类中。

然而,我发现了一些方法来打破这个。从通知中启动另一个应用程序,同时ActivitySplashScreenSignUp显示,并且不重置回溯历史。

唯一真正解决这个问题的方法是在API 11中:

intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);

居然没有人提到这个优雅的解决方案,真是不可思议。这应该是公认的答案。

SplashActivity -> AuthActivity -> DashActivity

if (!sessionManager.isLoggedIn()) {
    Intent intent = new Intent(context, AuthActivity.class);
    intent.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);
    context.startActivity(intent);
    finish();
} else {
   Intent intent = new Intent(context, DashActivity.class);
   context.startActivity(intent);
    finish();
}

这里的关键是使用intent.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);为中介活动。一旦中间的链接断开,DashActivity将位于堆栈的第一个和最后一个。

android:noHistory="true"是一个糟糕的解决方案,因为它会在依赖Activity作为回调时引起问题,例如onActivityResult。这是推荐的解决方案,应该被接受。

在清单中,您可以添加:

android:noHistory="true"

<activity
android:name=".ActivityName"
android:noHistory="true" />

你也可以打电话

finish()

在调用startActivity(..)

这可能不是理想的方法。如果有人有更好的办法,我会很期待去实施。以下是我如何使用11版本前的sdk完成这一特定任务。

在每节课上,你都想在时间清楚的时候离开,你需要这样做:

    ... interesting code stuff ...
    Intent i = new Intent(MyActivityThatNeedsToGo.this, NextActivity.class);
    startActivityForResult(i, 0);
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (resultCode == R.string.unwind_stack_result_id) {
        this.setResult(R.string.unwind_stack_result_id);
        this.finish();
    }
}

然后,当你想要初始化它时,需要从堆栈中设置弹出链的函数需要调用this:

NextActivity.this.setResult(R.string.unwind_stack_result_id);
NextActivity.this.finish();

那么活动就不在堆栈上了! 请记住,你可以启动一个活动,然后开始清理它的背后,执行并不遵循一个单一的(ui)线程。