[Flutter] 二维码生成和扫描功能实现

二维码生成和扫描功能实现

二维码生成

添加依赖

 #二维码生成
  qr_flutter: ^4.0.0

完整代码

import 'package:flutter/material.dart';
import 'package:qr_flutter/qr_flutter.dart';
class QRGeneratePage extends StatefulWidget {
    QRGeneratePage({Key? key}) : super(key: key);

    @override
    State<QRGeneratePage> createState() => _QRGeneratePageState();
}
class _QRGeneratePageState extends State<QRGeneratePage> {
    String id = "2016115150";
    @override
    Widget build(BuildContext context) {
        return Scaffold(
            appBar: AppBar(
                title: Text('二维码生成'),
            ),
            body: QrImage(
                data: id,//扫描得到的内容
                version: QrVersions.auto,
                size: 200,
            ),
        );
    }
}

扫描功能

配置 AndroidManifest.xml文件
//与application同级
<uses-permission android:name="android.permission.CAMERA" /> <!--相机-->

添加依赖

#扫描
barcode_scan2: ^4.2.0

完整代码

import 'package:flutter/material.dart';
import 'package:barcode_scan2/barcode_scan2.dart';
class BarcodeScanPage extends StatefulWidget {
    BarcodeScanPage({Key? key}) : super(key: key);

    @override
    State<BarcodeScanPage> createState() => _BarcodeScanPageState();
}

class _BarcodeScanPageState extends State<BarcodeScanPage> {
    //现在的时间
    var _currentTime = DateTime.now().hour;
    //控制闪光灯
    bool? flashLigh = true;

    _doBarcodeScan() async {
        //ScanOptions设置闪光灯和前后摄像头
        var options = ScanOptions(
            autoEnableFlash: flashLigh!,
            strings: {'cancel': '取消', 'flash_on': '闪光灯开/关', 'flash_off': '闪光灯开/关'});
        //返回扫描的参数
        var result = await BarcodeScanner.scan(options: options);
        //扫描返回值的类型
        print(result.type);
        //返回参数
        print(result.rawContent);
        //格式
        print(result.format);
    }

    @override
    void initState() {
        super.initState();
        //如果早上7至晚上19点,闪光灯默认关闭
        if (_currentTime >= 7 && _currentTime <= 19) {
            setState(() {
                flashLigh = false;
            });
        }
    }
    @override
    void dispose() {
        super.dispose();
        _doBarcodeScan().cancel();//销毁
    }
    @override
    Widget build(BuildContext context) {
        return Scaffold(
            appBar: AppBar(
                title: Text('扫描页面'),
            ),
            body: Center(
                child: Column(
                    mainAxisAlignment: MainAxisAlignment.center,
                    children: [
                        ElevatedButton(onPressed: _doBarcodeScan, child: Text('开始扫描')),
                    ],
                ),
            ));
    }
}

扩展

二维码生成和扫描可以结合实现很多功能,比如微信扫码添加联系人,二维码付款等等。

都是利用扫描得到的数据进行处理,有空实现一下扫码添加联系人,再更新此文。

上一篇:秋招在线测评,性格和岗位是如何匹配的?


下一篇:Flutter 关于计步(一)