pub package

A fast barcode scanner using MLKit (and CameraX) on Android and AVFoundation on iOS. This package leaves the UI up to the user, but rather gives an access to a camera preview.

Note: This plugin is still under development, and some APIs might not be available yet. If you have any issues, ideas or recommendendations, don't hesitate to create an issue or pull request on github. I am using this plugin in production myself and will actively develop and maintain it going forward.

This plugin required iOS 10.0 and Android sdk version 21 or higher.


Add the following line to your pubspec.yaml:

fast_barcode_scanner: ^1.1.0


Add the NSCameraUsageDescription key to your ios/Runner/Info.plist, like so:

<string>This app requires access to your phone’s camera solely for scanning barcodes</string>


Change the minimum Android sdk version to 21 (or higher) in your android/app/build.gradle file.

minSdkVersion 21


The barcode scanner consists of two main classes CameraController and BarcodeCamera. A full example looks like this:

import 'package:fast_barcode_scanner/fast_barcode_scanner.dart';

class MyScannerScreen extends StatelessWidget {
    Widget build(BuildContext context) {
        return Scaffold(
            appBar: AppBar(title: Text('Barcode Scanner')),
            body: BarcodeCamera(
                types: const [
                resolution: Resolution.hd720,
                framerate: Framerate.fps30,
                mode: DetectionMode.pauseVideo,
                onScan: (code) => print(code),
                children: [
                    MaterialPreviewOverlay(animateDetection: false),
                      child: ElevatedButton(
                        onPressed: () =>
                        child: Text('Resume'),

As you can see, there are two overlays in the childrens list. These two are included in the package. MaterialPreviewOverlay mimics the official material barcode scanning example. BlurPreviewOverlay blurs the screen when a barcode is detected and unblurs it on resuming. These are normal widget, which are shown above the camera preview. Look at their source code to find out, how to react to events from the barcode scanner.


The CameraController-singleton manages the camera. It handles all the low level stuff like communicating with native code. It is implemented as a singleton to guarantee that there is always one and the same controller managing the camera. You can access the controller via the CameraController.instance attribute. These are the accessible methods:

initializeInitialized the scanner with the provided config
pauseDetectorActively pauses the scanner
resumeDetectorResumes the scanner from the paused state
toggleTorchtoggles the torch on and off
disposeStops and resets the camera on platform level

You do not have to call initialize yourself, if you use the BarcodeCamera widget.


CameraController.instance.state contains the current state of the scanner. You can use it to build your own overlay. The following information can be accessed:

isInitializedIndicated whether the camera is currently initialized
previewConfigA PreviewConfiguration that is currently used
eventNotifierA event notifier to react to init or detecting codes
torchStateThe current state of the torch (on/off)
hasErrorIndicates whether error is null or not
errorAccess the error produced last


The BarcodeCamera is a widget showing a preview of the camera feed. It calls the CameraController in the background for initialization and configuration of the barcode camera.

An overview of all possible configurations (either passed to BarcodeCamera or CameraController.initialize):

typesSee code types to scan (see BarcodeType)
modeWhether to pause the camera on detection
resolutionThe resolution of the camera feed
framerateThe framerate of the camera feed
positionChoose between back and front camera (iOS)
onScanThe callback when a barcode is scanned
childrenWidgets to display on top of the preview