react-native下载图片到本地相册

需求

点击右上角下载icon,可以将当前图片下载并保存到本地相册。
在这里插入图片描述
下载的图片:

在这里插入图片描述

流程

下载图片的本质其实是,

固定需要下载的页面内容和样式 ===》将其放在当前页面不可见区域 ===》点击下载按钮 ===》穿一个ref给native,会自动拉起手机系统下载到本地相册

todo:native如何下载的话需要进一步再看一下

分析一下需要下载图片的样式:
在这里插入图片描述

  • 头部logo,可选可不选
  • 底部二维码和文案,固定的展示
  • 中间部分是外部传进来的card部分

所以我们可以设置需要的props如下,

interface SnapshotProps {
  backgroundImage: number;
  cardNode: React.ReactNode;
  bottomOpacity?: number; // 底部bottom透明度
  isShowHeader?: boolean; // 是否需要头部logo,例如首页应该为false
  viewRef: React.MutableRefObject<null>;
}

代码

import React, { memo } from 'react';
import { Image, ImageBackground, StyleSheet, Text, View } from 'react-native';
import Shopeepay from '../../assets/Shopeepay';
import QRCode from '../../assets/qrcode.png';

interface SnapshotProps {
  backgroundImage: number;
  cardNode: React.ReactNode;
  bottomOpacity?: number; // 底部bottom透明度
  isShowHeader?: boolean; // 是否需要头部logo,例如首页应该为false
  viewRef: React.MutableRefObject<null>;
}

const getColorWithOpacity = (rgb: string, opacity: number): string =>
  rgb.replace(')', `, ${opacity})`).replace('rgb', 'rgba');

const Snapshot = ({
  backgroundImage,
  bottomOpacity = 1,
  cardNode,
  isShowHeader = true,
  viewRef,
}: SnapshotProps) => {
  return (
    <ImageBackground
      style={styles.bgContainer}
      source={backgroundImage}
      ref={viewRef} // viewRef关键点
    >
      {isShowHeader && (
        <View style={styles.headerView}>
          <View style={styles.shopeepaySvg}>
            <Shopeepay />
          </View>
        </View>
      )}
      <View style={styles.cardView}>{cardNode}</View> // 外部传进来的中间内容部分
      <View
        style={[
          styles.bottomView,
          { // 背景透明度,如果设置Opacity属性的话,其所有子元素也会是透明或不透明状态
            backgroundColor: getColorWithOpacity(
              'rgb(233,78,43)',
              bottomOpacity
            ),
          },
        ]}
      >
        <View style={styles.leftView}>
          <Text style={styles.title}>Scan to enter ShopeePay</Text>
          <Text style={styles.subTitle}>Shopee.com/wrapup</Text>
        </View>
        <View style={styles.rightView}>
          <Image style={styles.qrcodeImage} source={QRCode} />
        </View>
      </View>
    </ImageBackground>
  );
};

export default memo(Snapshot);

const styles = StyleSheet.create({
  bgContainer: {
    width: WINDOW_WIDTH,
    height: WINDOW_HEIGHT,
  },
  headerView: {
    justifyContent: 'center',
    alignItems: 'center',
    width: WINDOW_WIDTH,
    height: 100,
  },
  shopeepaySvg: {
    position: 'absolute',
    top: 50,
  },
  cardView: {
    flex: 1,
  },
  bottomView: {
    flexDirection: 'row',
    alignItems: 'center',
    justifyContent: 'space-between',
    paddingHorizontal: 16,
    height: 110,
  },
  leftView: {
    marginLeft: 18,
  },
  title: {
    fontSize: 16,
    fontWeight: '500',
    color: Colors.white,
  },
  subTitle: {
    fontSize: 14,
    marginTop: 4,
    color: Colors.white,
  },
  rightView: {
    flex: 1,
    marginRight: 18,
    alignItems: 'flex-end',
  },
  qrcodeImage: {
    width: 80,
    height: 80,
  },
});

使用:

const onDownloadPress = async () => {
  // ...
  const resultFile = await captureViewToImage(viewRef); // 生成一个字符串,
  if (resultFile) {
    setImgUri(resultFile);
    try {
      await storeImageToDevice(rootTag, resultFile);
    } catch (err) {
      // ...
    }
  }
};

<Snapshot
  viewRef={viewRef} // 关键点
  backgroundImage={WrapUpBg}
  cardNode={carouselData[carouselIndex]}
/>
要使用 `react-native-svg` 和 `react-native-svg-transformer` 加载本地 SVG 图像,你可以按照以下步骤进行操作: 1. 首先,确保你已经在项目中安装了 `react-native-svg` 和 `react-native-svg-transformer` 依赖。你可以通过运行以下命令来安装它们: ``` npm install react-native-svg react-native-svg-transformer ``` 2. 在项目的根目录下创建一个名为 `metro.config.js` 的文件(如果已存在,请跳过此步骤)。 3. 在 `metro.config.js` 文件中添加以下内容: ```javascript module.exports = { transformer: { assetPlugins: ['react-native-svg-transformer'], }, }; ``` 4. 接下来,在你的组件中,使用 `react-native-svg` 中的 `<SvgUri>` 组件来加载本地 SVG 图像。首先,确保你的 SVG 图像位于项目的 `assets` 文件夹中。 ```javascript import React from 'react'; import { View } from 'react-native'; import SvgUri from 'react-native-svg-uri'; const MyComponent = () => { return ( <View> <SvgUri width={200} height={200} source={require('./assets/myImage.svg')} /> </View> ); }; export default MyComponent; ``` 在上面的示例中,我们使用 `require` 方法加载位于 `assets` 文件夹中的 `myImage.svg` 图像,并将其作为 `source` 属性传递给 `<SvgUri>` 组件。你可以根据自己的需要调整宽度和高度。 5. 确保你在重新启动 Metro Bundler 之前完成了以上步骤。你可以通过运行以下命令重新启动 Metro Bundler: ``` npx react-native start --reset-cache ``` 这样,你就可以使用 `react-native-svg` 和 `react-native-svg-transformer` 成功加载和显示本地 SVG 图像了。 希望对你有所帮助!如有任何疑问,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值