RN实现调用相册权限

本文介绍了在React Native (RN) 中如何实现调用Android相册权限并保存图片到本地的过程。首先在AndroidMainifest.xml配置权限,然后面对需求,通过react-native-fs下载网络图片,并使用react-native-community/cameraroll组件在Android中保存图片到相册,解决CameraRoll.saveToCameraRoll()在Android上的问题。
摘要由CSDN通过智能技术生成

1.写在前面

在android中实现调用相机的权限的前提是APP请求到调用相机的权限,这个权限在android/app/src/main/AndriodMainifest.xml中进行配置
在这里插入图片描述

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name ="android.permission.READ_EXTERNAL_STORAGE" />

2.简叙需求

获得权限以后,接着要说一下这次的需求,我原本是想做一个很简单的页面,就是一个联系客服的二维码,然后可以点击查看大图,长按图片可以保存到本地相册。由于才疏学浅,以为很简单的事情,实行过程却很艰难。

3.具体实施

在保存图片这个功能上,安卓和苹果有着很大不同,IOS可以在RN中使用自带的CameraRoll,而Android 使用这个方法则会报错误:open failed:ENOENT(No such file or diectory),这是因为Android的CameraRoll.saveToCameraRoll()方法只能保存下载到本地的图片或者视频,而且RN自带的CameraRoll已经不再更新,现在需要使用的是react-native-community/cameraroll,而将网络上下载的图片缓存到本地的组件是react-native-fs,所以现在需要分别安装这两个组件下面是安装两个组件的教程:
3.1安装react-native-fs
第一步:

npm install react-native-fs --save

第二步:

react-native link react-native-fs

这里react-native-fs组件就已经安装好了。
3.2安装react-native-community/cameraroll
第一步:

npm install @react-native-community/cameraroll --save

第二步:

react-native link @react-native-community/cameraroll && npx pod-install

3.3实现代码

import React from 'react';
import {
   
  Dimensions,
  Image,
  Modal,
  ScrollView,
  StyleSheet,
  TouchableOpacity,
  View,
  Text,
  ActivityIndicator,
  Platform
} from 'react-native';
import ImageViewer from 'react-native-image-zoom-viewer';
import CameraRoll from '@react-native-community/cameraroll'


const {
   width, height} = Dimensions.get(
如果你想在 React Native调用原生方法,可以使用 React Native 提供的 Native Modules。 首先,在原生代码中创建一个方法,然后将其导出到 React Native 中。例如在 iOS 项目中,可以在 `AppDelegate.m` 文件中添加以下方法: ``` #import <React/RCTBridge.h> #import <React/RCTBridgeModule.h> @interface MyModule : NSObject <RCTBridgeModule> @end @implementation MyModule RCT_EXPORT_MODULE(); RCT_EXPORT_METHOD(myMethod:(NSString *)myArgument callback:(RCTResponseSenderBlock)callback) { // 在这里实现你的方法逻辑 NSString *myResponse = @"这是我的响应"; callback(@[[NSNull null], myResponse]); } @end ``` 在上面的代码中,我们定义了一个名为 `myMethod` 的方法,并将其导出到 React Native 中。此方法接受一个字符串参数 `myArgument` 和一个回调函数 `callback`,并在回调函数中返回一个响应字符串。 接下来,在 React Native调用这个方法。可以使用 `NativeModules` 模块来访问原生方法。例如: ``` import { NativeModules } from 'react-native'; const { MyModule } = NativeModules; MyModule.myMethod('这是我的参数', (error, response) => { if (error) { console.error(error); } else { console.log(response); } }); ``` 在上面的代码中,我们使用 `NativeModules` 访问原生模块 `MyModule`,并调用其中的 `myMethod` 方法。此方法接受一个字符串参数和一个回调函数,该回调函数在方法完成后被调用,并传递错误对象和响应字符串作为参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值