React Native 截屏组件

来源:互联网 发布:步进电机闭环控制算法 编辑:程序博客网 时间:2024/06/04 18:38

本文原创首发于公众号:ReactNative开发圈,转载需注明出处。

React Native 截屏组件:react-native-view-shot,可以截取当前屏幕或者按照当前页面的组件来选择截取,如当前页面有一个图片组件,一个View组件,可以选择截取图片组件或者View组件。支持iOS和安卓。

安装方法

  1. npm install react-native-view-shot

  2. react-native link react-native-view-shot

使用示例

captureScreen() 截屏方法

截取当前屏幕,跟系统自带的截图一致,只会截取当前屏幕显示的页面内容。如果是ScrollView,那么未显示的部分是不会被截取的。

  1. import { captureScreen } from "react-native-view-shot";

  2. captureScreen({

  3.  format: "jpg",

  4.  quality: 0.8

  5. })

  6. .then(

  7.  uri => console.log("Image saved to", uri),

  8.  error => console.error("Oops, snapshot failed", error)

  9. );

captureRef(view, options) 根据组件reference名称来截取

  1. import { captureRef } from "react-native-view-shot";

  2. render() {

  3.     return (

  4.     <ScrollView ref="full">

  5.          <View ref="form1”>

  6.           </View>

  7.                  <View ref="form2”>

  8.           </View>

  9.    </ScrollView>

  10. );

  11. }

  12. snapshot = refname => () =>

  13. captureRef(refname, {

  14.  format: "jpg",

  15.  quality: 0.8,

  16.  result: "tmpfile",

  17.  snapshotContentContainer: true

  18. })

  19. .then(

  20.  uri => console.log("Image saved to", uri),

  21.  error => console.error("Oops, snapshot failed", error)

  22. );

指定需要截取的组件的ref名称,然后将该ref名称传递给snapshot方法来截取指定组件的内容。如需要截取ScrollView,只需要将”full”传递给snapshot方法即可。captureRef方法和captureScreen方法都可以设置options,options的说明如下:width / height:可以指定最后生成图片的宽度和高度。format:指定生成图片的格式png or jpg or webm (Android). 默认是png。quality:图片的质量0.0 - 1.0 (default)。result:最后生成的类型,可以是tmpfile、base64、data-uri。snapshotContentContainer:如果设置为True的话,会动态计算组件的高度。如果是ScrollView组件,就会截取整个ScrollView的实际高度。

支持的组件

示例源码

https://github.com/forrest23/ReactNativeComponents

组件地址

https://github.com/gre/react-native-view-shot

微信不让跳转外链,可以点击查看原文来查看外链GitHub内容。

转载http://mp.weixin.qq.com/s/rGJORsP2JmW8kNAgYU_wow