我的应用程序中有一个特殊的导航,我想知道如何正确设置它。
活动 H 是我的应用程序的主屏幕。从这个活动中,我们可以启动活动 A、B、C 和 D。从活动 A 我们可以启动 A',然后启动 A'',从活动 B 我们可以启动 B',启动 B'',等等。
问题是,从任何活动,我们可以转到活动 H、A、B、C 或 D。但是,当用户启动 A->A'->A''->C,然后返回 A ,他必须被重定向到A''。此外,仍然在这个例子中,如果用户按回 A'',他必须被重定向到 A' 而不是 C。如果他再次按回,他必须被重定向到 A,并且再次返回应该将他重定向到H(主屏幕)活动,而不是 C !
最后,当用户从 H 按下返回时,并且仅在此时,应用程序(以及所有任务,如果选择的解决方案是创建单独的任务)应该关闭。
其他例子:H -> A -> B -> H -> back -> end of application
我怎样才能做到这一点?我曾想过使用这样的任务:
<!-- A-->
<activity
android:name=".A"
android:excludeFromRecents="true"
android:taskAffinity=".A"
android:label="@string/my_A_label">
</activity>
<activity
android:name=".A'"
android:taskAffinity=".A"
android:label="@string/my_A'_label">
</activity>
<activity
android:name=".A''"
android:taskAffinity=".A"
android:label="@string/my_A''_label">
</activity>
<!-- B-->
<activity
android:name=".B"
android:excludeFromRecents="true"
android:taskAffinity=".B"
android:label="@string/my_B_label">
</activity>
<activity
android:name=".B'"
android:taskAffinity=".B"
android:label="@string/my_B'_label">
</activity>
<activity
android:name=".B''"
android:taskAffinity=".B"
android:label="@string/my_B''_label">
</activity>
...
如您所见,我为每个主页创建了任务:A、B、C、D。我不知道这是否是一件好事,因为例如,通过任务,用户可以看到所有这些活动用“最后一个任务”选项长按他的主页按钮,我不想有这种行为。为此,活动 A、B、C、D(每个任务的根屏幕)具有属性 android:excludeFromRecents="true"。但是现在,另一个问题:当用户单击他的主页按钮并返回我的应用程序时,他返回主屏幕,而不是最后启动的活动......
此外,我的第二个例子没有得到尊重。
你有解决所有这些问题的想法吗?
PS:请不要告诉我改变我的导航系统:-)
编辑:这里有一个流程图,代表需要的后备箱。这种行为似乎很正常。我的情况有什么不同没有出现在这个图表上。实际上,仅表示后退按钮。每个上下文 - 由不同的颜色表示 - 可以切换到另一个上下文,而不会覆盖此处描述的 back comportment。
EDIT2:感谢 David Wasser 的建议,我已经实现了两个完全符合我所描述的行为的类,而不使用 android 任务。也感谢 JoxTraex 的帮助 :-) 这是我所做的:我的活动 A、B、C、D 扩展了 RootActivity,除 H 之外的其他活动扩展了 CustomNavigationActivity。
根活动:
import android.content.Intent;
public abstract class RootActivity extends CustomNavigationActivity{
@Override
public void onBackPressed(){
Intent intent = new Intent(this, HomeScreen.class);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(intent);
}
}
自定义导航活动:
import android.content.Intent;
public abstract class CustomNavigationActivity extends Activity{
private int actualRequestCode;
private int menuRequestCode = -1;
@Override
protected void onResume(){
if (getIntent().hasExtra("childLaunched")){
Intent intent = new Intent(this, (Class<?>) getIntent().getExtras().get("childLaunched"));
intent.addFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT);
startActivity(intent);
}
super.onResume();
}
@Override
public void startActivity (Intent intent) {
this.startActivityForResult(intent, 0);
}
@Override
public void startActivityForResult(Intent intent, int requestCode){
Class<?> targetClass = null;
this.actualRequestCode = requestCode;
if (this.actualRequestCode == this.menuRequestCode){
this.menuRequestCode -= 1;
}
try {
if (intent.getComponent() != null){
targetClass = Class.forName(intent.getComponent().getClassName());
}
}
catch (ClassNotFoundException e) {
e.printStackTrace();
}
if (targetClass == null){
super.startActivityForResult(intent, this.actualRequestCode);
}
else if (!targetClass.equals(Menu.class)){
getIntent().putExtra("childLaunched", targetClass);
super.startActivityForResult(intent, this.actualRequestCode);
}
else{
super.startActivityForResult(intent, this.menuRequestCode);
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data){
if (requestCode == this.actualRequestCode){
getIntent().removeExtra("childLaunched");
}
}
}