React Native App启动页制作 安卓端
- 作者:Bougie
- 创建于:2018-03-29
- 更新于:2023-03-09
react native 启动页制作,隐藏启动白屏,打打广告 这篇文章是根据开源项目react-native-splash-screen (opens new window)来写的。在使用 react-native-link 命令安装该包后不知是何原因导致 app 无法运行了。issue 也有很多用户说安装该包后项目出错。其实制作 app 启动页很简单,大可不必引用该包。下面开始正文。
app 启动页第一是为了宣传,第二是为了防止在 app 初始化期间屏幕白屏。所以 app 启动页不能干扰 mainActivity 的加载。app 启动页一般方法就是在 mainActivity 上创建一个全屏的 dialog,页面加载完成后关闭该 dialog。下面介绍在 react-native 中加入 app 启动页的方法。
# Native 端
# 创建 dialog 全屏样式
在 styles.xml 中添加:
<style name="Dialog_Fullscreen">
<item name="android:windowFullscreen">true</item>
<item name="android:windowNoTitle">true</item>
</style>
# 创建布局文件
创建一个 dialog 内部的布局文件,命名为 activity_launch.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/launch_screen">
</LinearLayout>
其中 launch_screen 为启动页图片,必须为 png 格式,位于 drawable 目录下。
# 创建类 SplashScreen:
public class SplashScreen {
private static Dialog mSplashDialog;
// 显示启动页
public static void show(final Activity activity) {
mSplashDialog = new Dialog(activity,R.style.Dialog_Fullscreen); // 设置dialog全屏
mSplashDialog.setContentView(R.layout.activity_launch); // 设置dialog内容
mSplashDialog.setCancelable(false);
mSplashDialog.show();
}
// 关闭启动页
public static void hide(Activity activity) {
mSplashDialog.dismiss();
mSplashDialog = null;
}
}
# 显示启动屏
在 mainActivity 创建时显示启动页,在 MainActivity.java 中添加:
@Override
protected void onCreate(Bundle savedInstanceState) {
SplashScreen.show(this);
super.onCreate(savedInstanceState);
}
对于 rn 项目,当 HomePage 执行到 componentDidMount 生命周期的时候,首屏渲染完毕,关闭启动页,故需要把类 SplashScreen 中的 hide 方法传递到 js 端。
# 添加 js 方法
创建 ModuleHideSplash 类继承 ReactContextBaseJavaModule:
public class ModuleHideSplash extends ReactContextBaseJavaModule {
private Context context;
public ModuleHideSplash(ReactApplicationContext reactContext) {
super(reactContext);
context = reactContext;
}
@Override
public String getName() {
return "SplashScreen";
}
@ReactMethod
public void show() {
SplashScreen.show(getCurrentActivity());
}
@ReactMethod
public void hide() {
SplashScreen.hide(getCurrentActivity());
}
}
# 添加 module
创建 myPackge 并添加 ModuleHideSplash 实例:
public class MyPackage implements ReactPackage {
@Override
public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
return Collections.emptyList();
}
@Override
public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
List<NativeModule> modules = new ArrayList<>();
modules.add(new ModuleHideSplash(reactContext));
return modules;
}
}
# 添加 package
最后在 MainApplication.java 中注册 package:
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
new MyPackage()
);
}
# js 端
在 js 端关闭启动页:
import {NativeModules} from "react-native";
componentDidMount() {
NativeModules.SplashScreen.hide();
}
原文链接:http://bougieblog.cn/article/55 大功告成! 壁纸送给大家