前言
最近一直在学习RN的相关开发,想做一部分调用原生的实现,来练练手,于是就有了下面这个demo,由于本人是Android开发,所以只实现了Android端的效果.
主要实现
这种调用原生的操作,主要涉及到RN于原生交互和通信,官方给出的交互方式就是通过在Application中注册的模式实现交互.
首先我们需要先创建一个RN项目 CameraPage.js ,并把它设为启动页:页面比较简单,就是两个按钮拍照,照片一个Image标签用来展示原生的图片.开始新建与原生交互的类, CameraMoudle 继承自ReactContextBaseJavaModule类:
public class CameraMoudle extends ReactContextBaseJavaModule {
private ReactApplicationContext reactContext;
public CameraMoudle(ReactApplicationContext reactContext) {
super(reactContext);
this.reactContext =reactContext;
}
@Override
public String getName() {
return "CameraMoudle";
}
//打开登录设置界面,用于给RN调用
@ReactMethod
public void openNative(int tag) {
Intent intent = new Intent();
CameraAct.reactContext=reactContext;
CameraAct.tag=tag;
intent.setClass(reactContext, CameraAct.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
reactContext.startActivity(intent);
}
}
这个getName()方法中返回的就是RN端调用的引用名,相当于webview中addJavascriptInterface(JsInterface,JsName)中的JsName,下面的openNative方法是我们自定义的Rn端调用原生的方法.注意:这里面的reactContext是静态赋值.接下来创建CameraPackage.java继承ReactPackage这个CameraMoudle需要通过这个类在Application中注册才能使用:
public class CameraPackage implements ReactPackage {