qrcode_flutter 1.0.10 qrcode_flutter: ^1.0.10 copied to clipboard
Flutter plugin for scanning QR codes.You can customize your page by using PlatformView.Scanning Picture from path (photo album).
import 'package:flutter/material.dart';
import 'package:qrcode_flutter/qrcode_flutter.dart';
import 'package:image_picker/image_picker.dart';
void main() => runApp(OnePage());
class OnePage extends StatefulWidget {
@override
_OnePageState createState() => _OnePageState();
}
class _OnePageState extends State<OnePage> {
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text("qrcode_flutter"),
),
body: Builder(builder:(context)=>RaisedButton(
child:Text("navigate to qrcode page"),
onPressed: () {
Navigator.of(context)
.push(MaterialPageRoute(builder: (_) => MyApp()));
},
),),)
);
}
}
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> with TickerProviderStateMixin {
QRCaptureController _controller = QRCaptureController();
bool _isTorchOn = false;
String _captureText = '';
@override
void initState() {
super.initState();
_controller.onCapture((data) {
print('$data');
setState(() {
_captureText = data;
});
});
}
@override
void dispose() {
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('scan'),
actions: <Widget>[
FlatButton(
onPressed: () async {
PickedFile image =
await ImagePicker().getImage(source: ImageSource.gallery);
var qrCodeResult =
await QRCaptureController.getQrCodeByImagePath(image.path);
setState(() {
_captureText = qrCodeResult.join('\n');
});
},
child: Text('photoAlbum', style: TextStyle(color: Colors.white)),
),
],
),
body: Stack(
alignment: Alignment.center,
children: <Widget>[
Container(
width: 300,
height: 300,
child: QRCaptureView(
controller: _controller,
),
),
SafeArea(
child: Align(
alignment: Alignment.bottomCenter,
child: _buildToolBar(),
),
),
Container(
child: Text('$_captureText'),
)
],
),
);
}
Widget _buildToolBar() {
return Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
FlatButton(
onPressed: () {
_controller.pause();
},
child: Text('pause'),
),
FlatButton(
onPressed: () {
if (_isTorchOn) {
_controller.torchMode = CaptureTorchMode.off;
} else {
_controller.torchMode = CaptureTorchMode.on;
}
_isTorchOn = !_isTorchOn;
},
child: Text('torch'),
),
FlatButton(
onPressed: () {
_controller.resume();
},
child: Text('resume'),
),
],
);
}
}