RN实现摄像头扫码功能

第三方包为

react-native-vision-camera

自行安装

js 复制代码
yarn add react-native-vision-camera

安卓和ios权限配置

安卓配置 android/app/src/AndroidManifest.xml 加入以下代码

js 复制代码
<uses-permission android:name="android.permission.CAMERA" />

ios配置 ios/项目名/Info.plist 加入以下代码

js 复制代码
// 获取相机权限
<key>NSCameraUsageDescription</key>
<string>$(PRODUCT_NAME) needs access to your Camera.</string>

RN代码如下

js 复制代码
import React, {useEffect, useState} from 'react';
import {View, Text, Platform, Button} from 'react-native';
import {
  Camera,
  useCodeScanner,
  useCameraPermission,
  useCameraDevice,
} from 'react-native-vision-camera';

export default function App() {
  const [checked, setChecked] = useState(false); // 获取权限,当有了权限再打开摄像头
  const device = useCameraDevice('back'); // 控制扫码为后置摄像头
  const {hasPermission, requestPermission} = useCameraPermission(); // 获取/申请权限(第一次需要申请,后续不用)
  useEffect(() => {
    requestPermission(); // 进入页面申请权限
    setChecked(hasPermission); // 获取权限结果
  }, []);

  const codeScanner = useCodeScanner({ // 后置扫码主要组件
    codeTypes: ['qr', 'ean-13'],
    onCodeScanned: codes => {
      console.log('codes', codes);
      console.log(`Scanned ${codes.length} codes!`);
    },
  });

  return (
    <View>
      <Button
        title="获取权限"
        onPress={() => {
          setChecked(hasPermission); // 点击按钮获取权限(因为第一次安装软件,获取完权限后页面不会立即显示,需要点一下按钮,后续不用)
        }}></Button>
      {device && checked ? (
        <Camera
          style={{width: 200, height: 400}}
          device={device}
          isActive={true}
          codeScanner={codeScanner}
        />
      ) : (
        <Text>未获取权限</Text>
      )}
    </View>
  );
}

扫描到的结果

相关推荐
kyriewen6 小时前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
IT_陈寒7 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
DigitalOcean9 小时前
Laravel 开发者已在 DigitalOcean 上开通超过 10 万台服务器
前端·laravel
星始流年9 小时前
从 Tool 到 Skill——基于 LangChain 的服务端Skill实现
前端·langchain·agent
李惟9 小时前
开源本地通信库,纯客户端 RPC,像聊天一样通信
前端
YAwu119 小时前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js
GuWenyue9 小时前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
OpenTiny社区9 小时前
🎨 看完 GenUI SDK 源码我悟了!
前端·vue.js·github
叁两9 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
何时梦醒9 小时前
深入理解递归与快速排序 —— 从基础入门到手写实现
前端·javascript