React Native App启动页制作 安卓端

React-Native App启动页制作(安卓端)

react native 启动页制作,隐藏启动白屏,打打广告 这篇文章是根据开源项目react-native-splash-screen (opens new window)来写的。在使用 react-native-link 命令安装该包后不知是何原因导致 app 无法运行了。issue 也有很多用户说安装该包后项目出错。其实制作 app 启动页很简单,大可不必引用该包。下面开始正文。

splash_screen.gif
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 大功告成! 壁纸送给大家 launch_screen.png