第三方库的原生相册相机操作。第三方的react-native-image-crop-picker的功能更为完整易用(可多选、压缩、裁剪等)。

https://github.com/ivpusic/react-native-image-crop-picker //GitHub地址

这里说一下配置说明:

npm i react-native-image-crop-picker --save //安装依赖

react-native link react-native-image-crop-picker //链接原生库

ios配置权限: 注意:这里权限的值随便写,必须要写。

Xcode打开info.plist.在最下面一行点击+号(表示新增一行)或者鼠标在空白处右击Add Row.结果都是一样的新增一行.

在上一步骤的新的一行中选择Privacy-photo Library....增加访问相册的权限

注意:这里值随便写,必须要写。

重复以上步骤增加相机和麦克风的权限

权限配置后安装cocoaPods:教程在我的开源中国:https://my.oschina.net/u/3112095/blog/1553404

安装后cd进去我的RN项目,进入ios文件。执行pod init生成一个podFile文件

cd ios

pod init

打开podfile文件把TVOS等没用的删除。增加以下

platform :ios,'8.0'//这里创建的时候是什么就是什么,不用改

target 'your_project_name' do

pod 'RSKImageCropper' //主要要这句

pod 'QBImagePickerController' //主要还有这句

end

最后执行:

pod install

执行后关闭xcode。以后xcode运行项目不能打开.xcodeproj文件,运行项目的话要打开.xcworksspace的文件。否则报错找不到

Android配置:

注意:保证使用了Gradle 2.2.x以上。

app build.gradle 中添加useSupportLibrary

android {

...

defaultConfig {

...

vectorDrawables.useSupportLibrary = true

...

}

[可选] 如果使用照相机在你的项目中,AndroidManifest.xml添加

//相机权限

//写入权限

使用

导入library

import ImagePicker from 'react-native-image-crop-picker';

从图库中选择:

①调用单图选择器与裁剪

ImagePicker.openPicker({

width: 300,height: 400,cropping: true

}).then(image => {

console.log(image);

}).catch(e => {

console.log(e);

});

②选择多个图片的选择器

ImagePicker.openPicker({

multiple: true

}).then(images => {

console.log(images);

}).catch(e => {

console.log(e);

});

从照相中选择:

ImagePicker.openCamera({

width: 300,cropping: true

}).then(image => {

console.log(image);

}).catch(e => {

console.log(e);

});

裁剪图片:

ImagePicker.openCropper({

path: 'my-file-path.jpg',width: 300,height: 400

}).then(image => {

console.log(image);

}).catch(e => {

console.log(e);

});

选择清理:

模块创建临时文件图像将在未来的某个时间自动清理。 如果要强制清理,可以使用clean清理所有临时文件图像,或者使用cleanSingle(path)清除单个临时文件。

ImagePicker.clean().then(() => {

console.log('removed all tmp images from tmp directory');

}).catch(e => {

alert(e);

});

请求对象:

Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐