From 56d4b8312bc85253e975da524d9a3c72d7df5418 Mon Sep 17 00:00:00 2001 From: jcesarmobile Date: Thu, 27 Oct 2022 23:38:30 +0200 Subject: [PATCH] fix: only do fadeout animation if FadeSplashScreen is true (#1506) --- .../apache/cordova/SplashScreenPlugin.java | 42 ++++++++++--------- 1 file changed, 22 insertions(+), 20 deletions(-) diff --git a/framework/src/org/apache/cordova/SplashScreenPlugin.java b/framework/src/org/apache/cordova/SplashScreenPlugin.java index 91bcdc70..425b13f9 100644 --- a/framework/src/org/apache/cordova/SplashScreenPlugin.java +++ b/framework/src/org/apache/cordova/SplashScreenPlugin.java @@ -137,27 +137,29 @@ public class SplashScreenPlugin extends CordovaPlugin { // If auto hide is disabled (false), the hiding of the splash screen must be determined & // triggered by the front-end code with the `navigator.splashscreen.hide()` method. - // Setup the fade - splashScreen.setOnExitAnimationListener(new SplashScreen.OnExitAnimationListener() { - @Override - public void onSplashScreenExit(@NonNull SplashScreenViewProvider splashScreenViewProvider) { - View splashScreenView = splashScreenViewProvider.getView(); + if (isFadeEnabled) { + // Setup the fade + splashScreen.setOnExitAnimationListener(new SplashScreen.OnExitAnimationListener() { + @Override + public void onSplashScreenExit(@NonNull SplashScreenViewProvider splashScreenViewProvider) { + View splashScreenView = splashScreenViewProvider.getView(); - splashScreenView - .animate() - .alpha(0.0f) - .setDuration(isFadeEnabled ? fadeDuration : 0) - .setStartDelay(isFadeEnabled ? 0 : fadeDuration) - .setInterpolator(new AccelerateInterpolator()) - .setListener(new AnimatorListenerAdapter() { - @Override - public void onAnimationEnd(Animator animation) { - super.onAnimationEnd(animation); - splashScreenViewProvider.remove(); - } - }).start(); - } - }); + splashScreenView + .animate() + .alpha(0.0f) + .setDuration(fadeDuration) + .setStartDelay(0) + .setInterpolator(new AccelerateInterpolator()) + .setListener(new AnimatorListenerAdapter() { + @Override + public void onAnimationEnd(Animator animation) { + super.onAnimationEnd(animation); + splashScreenViewProvider.remove(); + } + }).start(); + } + }); + } } private void attemptCloseOnPageFinished() {