android native 相册,React Native手动实现调用原生相机相册(Android端)

前言

最近一直在学习RN的相关开发,想做一部分调用原生的实现,来练练手,于是就有了下面这个demo,由于本人是Android开发,所以只实现了Android端的效果.

Demo

主要实现

这种调用原生的操作,主要涉及到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继承ReactPackag

你可能感兴趣的:(android,native,相册)