瀏覽代碼

Finish SplashActivity if it's opened over NavigationActivity

On some devices, when returning to the app from background, some launchers
open the SplashActivity over the NavigationActivity. In this case, simply finish the SplashActivity
and return the the preview NavigationActivity.
Guy Carmeli 7 年之前
父節點
當前提交
0c389b5dac

+ 5
- 0
android/app/src/main/java/com/reactnativenavigation/controllers/SplashActivity.java 查看文件

11
 
11
 
12
 import com.reactnativenavigation.NavigationApplication;
12
 import com.reactnativenavigation.NavigationApplication;
13
 import com.reactnativenavigation.react.ReactDevPermission;
13
 import com.reactnativenavigation.react.ReactDevPermission;
14
+import com.reactnativenavigation.utils.CompatUtils;
14
 
15
 
15
 public abstract class SplashActivity extends AppCompatActivity {
16
 public abstract class SplashActivity extends AppCompatActivity {
16
     public static boolean isResumed = false;
17
     public static boolean isResumed = false;
39
         isResumed = true;
40
         isResumed = true;
40
 
41
 
41
         if (NavigationApplication.instance.getReactGateway().hasStartedCreatingContext()) {
42
         if (NavigationApplication.instance.getReactGateway().hasStartedCreatingContext()) {
43
+            if (CompatUtils.isSplashOpenedOverNavigationActivity(this, getIntent())) {
44
+                finish();
45
+                return;
46
+            }
42
             NavigationApplication.instance.getEventEmitter().sendAppLaunchedEvent();
47
             NavigationApplication.instance.getEventEmitter().sendAppLaunchedEvent();
43
             if (NavigationApplication.instance.clearHostOnActivityDestroy()) {
48
             if (NavigationApplication.instance.clearHostOnActivityDestroy()) {
44
                 overridePendingTransition(0, 0);
49
                 overridePendingTransition(0, 0);

+ 13
- 0
android/app/src/main/java/com/reactnativenavigation/utils/CompatUtils.java 查看文件

1
+package com.reactnativenavigation.utils;
2
+
3
+import android.app.Activity;
4
+import android.content.Intent;
5
+
6
+public class CompatUtils {
7
+    public static boolean isSplashOpenedOverNavigationActivity(final Activity act, final Intent intent) {
8
+        return intent != null && intent.getAction() != null
9
+               && intent.getAction().equals(Intent.ACTION_MAIN)
10
+               && !act.isTaskRoot()
11
+               && intent.hasCategory(Intent.CATEGORY_LAUNCHER);
12
+    }
13
+}