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

本文介绍了如何在React Native项目中手动实现调用Android原生相机和相册的功能。通过创建ReactContextBaseJavaModule和ReactPackage,在Application中注册模块,并在Android Activity中处理相机和相册的操作逻辑,同时处理权限问题。RN与原生交互的三种方式也进行了简单提及。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

最近一直在学习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继承ReactPackage这个CameraMoudle需要通过这个类在Application中注册才能使用:

public class CameraPackage implements ReactPackage {
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值