2020-02-20 06:19:14 +08:00
[![GitHub license ](https://img.shields.io/github/license/mintware-de/flutter_barcode_reader.svg )](https://github.com/mintware-de/flutter_barcode_reader/blob/master/LICENSE)
[![GitHub stars ](https://img.shields.io/github/stars/mintware-de/flutter_barcode_reader )](https://github.com/mintware-de/flutter_barcode_reader/stargazers)
[![Pub ](https://img.shields.io/pub/v/barcode_scan.svg )](https://pub.dartlang.org/packages/barcode_scan)
[![GitHub forks ](https://img.shields.io/github/forks/mintware-de/flutter_barcode_reader )](https://github.com/mintware-de/flutter_barcode_reader/network)
2017-10-30 01:05:11 +08:00
# Barcode Scanner
2017-10-30 04:09:37 +08:00
A flutter plugin for scanning 2D barcodes and QR codes.
This provides a simple wrapper for two commonly used iOS and Android libraries:
iOS: https://github.com/mikebuss/MTBBarcodeScanner
2017-10-30 06:31:33 +08:00
2017-10-30 04:09:37 +08:00
Android: https://github.com/dm77/barcodescanner
2017-10-30 01:05:11 +08:00
### Features
- [x] Scan 2D barcodes
- [x] Scan QR codes
- [x] Control the flash while scanning
2018-01-12 18:57:19 +08:00
- [x] Permission handling
2017-10-30 01:05:11 +08:00
## Getting Started
2017-11-12 06:38:21 +08:00
### Android
2017-10-30 01:05:11 +08:00
For Android, you must do the following before you can use the plugin:
* Add the camera permission to your AndroidManifest.xml
`<uses-permission android:name="android.permission.CAMERA" />`
2018-04-14 00:56:46 +08:00
* This plugin is written in Kotlin. Therefore, you need to add Kotlin support to your project. See [installing the Kotlin plugin ](https://kotlinlang.org/docs/tutorials/kotlin-android.html#installing-the-kotlin-plugin ).
Edit your project-level build.gradle file to look like this:
2020-02-20 06:19:14 +08:00
```groovy
buildscript {
ext.kotlin_version = '1.3.61'
// ...
dependencies {
// ...
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
}
}
// ...
```
2018-04-14 00:56:46 +08:00
Edit your app-level build.gradle file to look like this:
2020-02-20 06:19:14 +08:00
```groovy
apply plugin: 'kotlin-android'
// ...
dependencies {
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
// ...
}
```
2018-04-14 00:56:46 +08:00
Now you can depend on the barcode_scan plugin in your pubspec.yaml file:
2020-02-20 06:19:14 +08:00
```yaml
dependencies:
# ...
barcode_scan: any
```
2018-04-14 00:56:46 +08:00
Click "Packages get" in Android Studio or run `flutter packages get` in your project folder.
2017-10-30 01:05:11 +08:00
### iOS
To use on iOS, you must add the the camera usage description to your Info.plist
2020-02-20 06:19:14 +08:00
```xml
< dict >
<!-- ... -->
2017-10-30 01:05:11 +08:00
< key > NSCameraUsageDescription< / key >
2017-11-12 06:38:21 +08:00
< string > Camera permission is required for barcode scanning.< / string >
2020-02-20 06:19:14 +08:00
<!-- ... -->
< / dict >
2020-02-20 08:01:32 +08:00
```
## Common problems
### Android "Could not find org.jetbrains.kotlin:kotlin-stdlib-jre..."
Change `org.jetbrains.kotlin:kotlin-stdlib-jre` to `org.jetbrains.kotlin:kotlin-stdlib-jdk`
([StackOverflow](https://stackoverflow.com/a/53358817))