react-native-app-splash
v1.0.2
Published
React Native splash screen library: programmatically show/hide for Android & iOS.
Downloads
14
Maintainers
Readme
react-native-app-splash
React Native app splash library: programmatically show/hide for Android & iOS.
Content
Installation
First Step(Download):
$ npm install --save react-native-app-splash
$ yarn add react-native-app-splash
Manual Installation(If Needed)
Android:
- In your
android/settings.gradle
file, make the following additions:
include ':react-native-app-splash'
project(':react-native-app-splash').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-app-splash/android')
- In your android/app/build.gradle file, add the
:react-native-app-splash
project as a compile-time dependency:
...
dependencies {
...
implementation project(':react-native-app-splash')
}
iOS:
cd ios
run pod install
Second Step(Plugin Configuration):
Android:
Update the MainActivity.java
to use react-native-app-splash
via the following changes:
java:
import android.os.Bundle; // here
import com.appsplash.AppSplash; // here
public class MainActivity extends ReactActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
AppSplash.show(this); // here
super.onCreate(null) // to fix Fragment constructor caused an exception
}
// ...other code
}
kotlin:
import android.os.Bundle; // here
import com.appsplash.AppSplash; // here
class MainActivity : ReactActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
AppSplash.show(this)
super.onCreate(null) // to fix Fragment constructor caused an exception
}
// ...other code
}
iOS:
Update AppDelegate.m
with the following additions:
obj-c:
#import "AppDelegate.h"
#import <React/RCTBundleURLProvider.h>
#import "AppSplash.h" // here
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// ...other code
[super application:application didFinishLaunchingWithOptions:launchOptions];
[AppSplash show]; // here
return YES;
}
@end
// ...other code
Getting started
Android:
Create a file called app_splash.xml
in app/src/main/res/layout
(create the layout
-folder if it doesn't exist). The contents of the file should be the following:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/_dialog_parent"
android:layout_width="match_parent"
android:background="@android:color/white"
android:layout_height="match_parent">
<ImageView
android:id="@+id/_dialog_imageview"
android:layout_width="match_parent"
android:src="@drawable/app_splash"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:layout_height="match_parent"
tools:ignore="ContentDescription" />
</RelativeLayout>
Customize your launch screen by creating a app_splash.png
-file and placing it in an appropriate drawable
-folder. Android automatically scales drawable, so you do not necessarily need to provide images for all phone densities.
You can create app splashs in the following folders:
drawable-ldpi
drawable-mdpi
drawable-hdpi
drawable-xhdpi
drawable-xxhdpi
drawable-xxxhdpi
Optional steps:
If you want the app splash to be full screen, Change your show
method.
java/kotlin:
AppSplash.show(this, true)
iOS
Customize your app splash via LaunchScreen.storyboard
or LaunchScreen.xib
。
Usage
Use like so:
import AppSplash from 'react-native-app-splash';
const App = () => {
React.useEffect(() => {
// do the needed action while app splash is shown
// After having done action hide the app splash
AppSplash?.hide()
}, [])
}
export default App;
API
| Method | Type | Optional | Description | | ------------------------------------------------------- | -------- | -------- | -------------------------------- | | show() | function | false | Open App Splash (Native Method ) | | show(final Activity activity, final boolean fullScreen) | function | false | Open App Splash (Native Method ) | | hide() | function | false | Close App Splash |