栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

详解Flutter扫码识别二维码内容

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

详解Flutter扫码识别二维码内容

前面一篇写了生成二维码图片,这篇来写使用相机扫描识别二维码

识别二维码需要用到插件barcode_scan

首先在pubspec.yaml文件中添加以下依赖,添加依赖后在pubspec.yaml运行flutter packages get或 使用IDE更新软件包。

dependencies:
 ...
 barcode_scan: ^1.0.0

Android配置

在使用它之前需要先配置 androidappsrcmainAndroidManifest.xml

在该文件中添加添加app获取相机权限及BarcodeScanner activity




如下图所示

编辑项目级build.gradle文件

buildscript {
  ext.kotlin_version = '1.2.31'
  ...
  dependencies {
    ...
    classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
  }
}
...

如图所示

以及编辑应用级build.gradle文件

apply plugin: 'kotlin-android'
...
dependencies {
  implementation "org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
  ...
}

如图所示

注意 apply plugin: 'kotlin-android' 需要放在 apply plugin: 'com.android.application' 之后

IOS配置

在 Info.plist 中添加一下内容

NSCameraUsageDescription
Camera permission is required for barcode scanning.

扫码实现

完成以上步骤之后在需要触发扫码的页面引用barcode_scan

import 'package:barcode_scan/barcode_scan.dart';

然后写上一个调用扫码的方法

// 扫描二维码
Future scan() async {
 try {
  // 此处为扫码结果,barcode为二维码的内容
  String barcode = await BarcodeScanner.scan();
  print('扫码结果: '+barcode);
 } on PlatformException catch (e) {
  if (e.code == BarcodeScanner.CameraAccessDenied) {
   // 未授予APP相机权限
   print('未授予APP相机权限');
  } else {
   // 扫码错误
   print('扫码错误: $e');
  }
 } on FormatException{
  // 进入扫码页面后未扫码就返回
  print('进入扫码页面后未扫码就返回');
 } catch (e) {
  // 扫码错误
  print('扫码错误: $e');
 }
}

在使用时触发scan()方法即可,效果如下

默认的右上角打开闪光灯的文字为英文,如果需要修改可以到Flutter目录下修改以下相应文件

Andriod文件

flutter.pub-cachehostedpub.flutter-io.cnbarcode_scan-1.0.0androidsrcmainkotlincomapptreesoftwarebarcodescanBarcodeScannerActivity.kt
flutter.pub-cachehostedpub.flutter-io.cnbarcode_scan-1.0.0androidsrcmainkotlincomapptreesoftwarebarcodescanBarcodeScannerActivity.kt

如图

IOS文件

flutter.pub-cachehostedpub.flutter-io.cnbarcode_scan-1.0.0iosClassesBarcodeScannerViewController.m

如图

注:该插件也可以用来扫描条形码

到此这篇关于Flutter扫码识别二维码内容的文章就介绍到这了,更多相关Flutter扫码二维码内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/153725.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号