React-Native react-native-image-
组件的Github地址 https://github.com/react-community/react-native-image-picker
使用方式:
1) 添加依赖库
npm install react-native-image-picker@latest --save
react-native link react-native-image-crop-picker
配置ios/安卓
适配iOS
iOS添加比较简单:
1)首先找到plist文件,添加相册和相机的权限。
data:image/s3,"s3://crabby-images/f1ecc/f1ecc961a1cbdbd447060b214ce9304c84a89342" alt=""
<!-- 相册 -->
<key>NSPhotoLibraryUsageDescription</key>
<string>App需要您的同意,才能访问相册</string>
<key>NSCameraUsageDescription</key>
<string>App需要您的同意,才能访问相机</string>
<key>NSMicrophoneUsageDescription</key>
<string>App需要您的同意,才能访问麦克风</string>
适配安卓:
1)添加权限在/android/app/src/main/AndroidManifest.xml文件中添加、
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
data:image/s3,"s3://crabby-images/b65fd/b65fdf1a5ccfcdeb657401fb749edc901e8349ed" alt=""
2)android/settings.gradle文件中
include ':react-native-image-picker'
project(':react-native-image-picker').projectDir = new File(settingsDir, '../node_modules/react-native-image-picker/android')
data:image/s3,"s3://crabby-images/f0fc8/f0fc8b69b66ffe126867095cf5ec971a85d8d277" alt=""
3)android/app/build.gradle文件的dependencies中
compile project(':react-native-image-picker')
data:image/s3,"s3://crabby-images/b88a1/b88a1fcb530d69c48f75543c36be003114de9103" alt=""
4)/android/app/src/main/java/com/newredsj/MainApplication.java文件中
import com.imagepicker.ImagePickerPackage;
newImagePickerPackage()
data:image/s3,"s3://crabby-images/d1410/d1410de3a8eff4afb16d53172f8c601a102a72f5" alt=""
人生啊,处处是坑啊,以为就好啦。报错疯狂报错。。。
1) 需要引入头文件。
data:image/s3,"s3://crabby-images/fc2c7/fc2c7c5dcd0bce7566144a44b3c8e97774de672a" alt=""
2)一看iOS 确实好了,也可以用了,再一看安卓。我的天。
data:image/s3,"s3://crabby-images/1db98/1db987bc0f35203c7b08613723b7595be5a2f91d" alt=""
飘红一片。解决办法
先link一下 react-native link react-native-image-crop-picker
然后切记切记不要 直接reload安卓。
从新运行安卓react-native run-android 。
这时你就会发现你搞定了。 人生啊处处是坑,rn就是不断的填坑找坑。
data:image/s3,"s3://crabby-images/463c4/463c409edcfb21cde2271f990030a4a8c176b4ae" alt=""
data:image/s3,"s3://crabby-images/93ac1/93ac1ae60fa324446df7c028e14bc50eb6fb7d72" alt=""
代码:
data:image/s3,"s3://crabby-images/9f628/9f62850601104f292b87482696989fa8ae1ac374" alt=""
data:image/s3,"s3://crabby-images/0954d/0954dc74c6ca9fb14b356aa207ed980ac8cd8f05" alt=""