react native基于expo上传图片组件expo-image-picker的使用

app中,需要新增一个用户上传图片功能,由于app项目基于expo搭建的,所以直接使用expo中的组件。

第一步:下载expo-image-picker

yarn add expo-image-picker

第二步:在对应的文件中导入

import * as ImagePicker from 'expo-image-picker';

第三步:上传方法(我这里用伪代码描述)

import React, { useState, useEffect } from 'react';
import { View, Button, Image } from 'react-native';
import * as ImagePicker from 'expo-image-picker';

export default function App() {
  const [selectedImage, setSelectedImage] = useState(null);

  const openImagePicker = async () => {
    let result = await ImagePicker.launchImageLibraryAsync({
        allowsEditing: true, // 图片是否可编辑
        quality: 0,
        mediaTypes:ImagePicker.MediaTypeOptions.Images, //打开相册
    });

    if (!result.cancelled) {
        console.log(result,'result');
        setSelectedImage(result.uri);
        //在这里进行与后端对接操作,一般来说这里需要组装一下数据传给后端。
        //打印的数据如下图
    }else{
        console.log('已取消上传')
    }
  };

  return (
    <View>
      <Button title="上传图片" onPress={openImagePicker} />
    </View>
  );
}

上传图片成功后的回调结果

 拿到assets后,组装成你想要的数据,返给后端拿到图片id再接着实现后面的功能。

这里注意IOS和安卓下的区别,IOS正常打开相册,安卓打开的是文件管理器。

React Native 中,保存图片需要获取写入权限。您可以使用 React Native 的 PermissionsAndroid API 来请求用户的许可。 以下是一些示例代码,可以在保存图片之前请求权限: ```javascript import { PermissionsAndroid, Platform } from 'react-native'; import RNFetchBlob from 'rn-fetch-blob'; async function requestStoragePermission() { try { const granted = await PermissionsAndroid.request( PermissionsAndroid.PERMISSIONS.WRITE_EXTERNAL_STORAGE, { title: 'Storage Permission', message: 'App needs access to your storage to save photos', }, ); if (granted === PermissionsAndroid.RESULTS.GRANTED) { console.log('Storage permission granted'); } else { console.log('Storage permission denied'); } } catch (err) { console.warn(err); } } async function saveImage(imageUri) { if (Platform.OS === 'android') { await requestStoragePermission(); } const { config, fs } = RNFetchBlob; const date = new Date(); const imagePath = `${fs.dirs.DCIMDir}/photo_${date.getTime()}.png`; await config({ fileCache: true, addAndroidDownloads: { useDownloadManager: true, notification: true, path: imagePath, }, }).fetch('GET', imageUri); console.log('Image saved to', imagePath); } ``` 这里使用了 RNFetchBlob 模块来下载和保存图片。在 Android 平台上,我们先请求存储权限,然后使用 `addAndroidDownloads` 配置项将图片保存到设备上。 请注意,如果您正在使用 Expo,您需要使用 `expo-permissions` 模块来请求权限。您可以使用以下代码示例: ```javascript import { Platform } from 'react-native'; import * as ImagePicker from 'expo-image-picker'; import * as Permissions from 'expo-permissions'; import RNFetchBlob from 'rn-fetch-blob'; async function requestStoragePermission() { const { status } = await Permissions.askAsync(Permissions.CAMERA_ROLL); if (status === 'granted') { console.log('Storage permission granted'); } else { console.log('Storage permission denied'); } } async function saveImage(imageUri) { if (Platform.OS === 'android') { await requestStoragePermission(); } const { config, fs } = RNFetchBlob; const date = new Date(); const imagePath = `${fs.dirs.DCIMDir}/photo_${date.getTime()}.png`; await config({ fileCache: true, addAndroidDownloads: { useDownloadManager: true, notification: true, path: imagePath, }, }).fetch('GET', imageUri); console.log('Image saved to', imagePath); } ``` 请注意,这里使用Expo 的 `Permissions` 模块来请求存储权限,而不是使用 `PermissionsAndroid`。此外,Expo 也提供了自己的 `ImagePicker` 模块,可以用来选择图片,而不需要使用第三方组件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值