This is an Android library loosely based on the ZXing Android Barcode Scanner application for embedding in Android applications. This is not affiliated with the official ZXing project.
Generally it is recommended to scan a barcode via intents. There are however some cases in which it is not feasible:
- You need to customise the barcode scanning logic.
- You need to customise the UI.
- The users cannot install the Barcode Scanner application.
In these cases, this library may be more suitable.
Where version 2 was essentially just a stripped-down version of the Barcode Scanner application, version 3 is a rewrite of a large part of the codebase, making it more versatile and customizable.
With the rewrite, many APIs for UI customization were removed. Instead, it is now recommended to create a custom Activity using the lower-level components directly (see Customization for details).
Other notable changes:
- The camera is now loaded in a background thread, making the activity start faster.
- The camera preview and decoding now function correctly in any orientation.
From version 3 this is a single library, supporting Gingerbread and later versions of Android (API level 9+). If you need support for earlier Android versions, use version 2.
Add the following to your build.gradle file:
repositories {
jcenter()
}
dependencies {
compile 'com.journeyapps:zxing-android-embedded:3.0.0@aar'
compile 'com.google.zxing:core:3.2.0'
}
Maven is not supported currently, but it is possible that the aar can be used. Pull requests are welcome.
Launch the intent with the default options:
new IntentIntegrator(this).initiateScan(); // `this` is the current Activity
Use from a Fragment:
IntentIntegrator.forFragment(this).initiateScan(); // `this` is the current Fragment
// If you're using the support library, use IntentIntegrator.forSupportFragment(this) instead.
Customize options:
IntentIntegrator integrator = new IntentIntegrator(this);
integrator.setDesiredBarcodeFormats(IntentIntegrator.ONE_D_CODE_TYPES);
integrator.setPrompt("Scan a barcode");
integrator.setCameraId(0); // Use a specific camera of the device
integrator.initiateScan();
See IntentIntegrator for more options.
To change the orientation, create a new Activity extending CaptureActivity, and specify the
orientation in your AndroidManifest.xml
.
Sample:
public class CaptureActivityAnyOrientation extends CaptureActivity {
}
<activity android:name=".CaptureActivityAnyOrientation"
android:screenOrientation="fullSensor"
android:stateNotNeeded="true"
android:theme="@style/zxing_CaptureTheme"
android:windowSoftInputMode="stateAlwaysHidden">
</activity>
IntentIntegrator integrator = new IntentIntegrator(this);
integrator.setCaptureActivity(CaptureActivityAnyOrientation.class);
integrator.setOrientationLocked(false);
integrator.initiateScan();
The previous API for integrator.setOrientation()
was removed. It caused the Activity to be created
in landscape orientation, then destroyed and re-created in the requested orientation, which creates
a bad user experience. The only way around this is to specify the orientation in the manifest.
For more control over the UI or scanning behaviour, some components may be used directly:
- BarcodeView: Handles displaying the preview and decoding of the barcodes.
- CompoundBarcodeView: Combines BarcodeView with a viewfinder for feedback, as well as some status / prompt text.
- CaptureManager: Manages the InactivityTimer, BeepManager, orientation lock, and returning of the barcode result.
These components can be used from any Activity.
Samples:
- ContinuousCaptureActivity: continuously scan and display results (instead of a once-off scan).
- ToolbarCaptureActivity: Same as the normal CaptureActivity, but with a Lollipop Toolbar.
./gradlew assemble
To deploy the artifacts the your local Maven repository:
./gradlew publishToMavenLocal
You can then use your local version by specifying in your build.gradle
file:
repositories {
mavenLocal()
}
Journey - Build enterprise mobile apps for iOS and Android. Work in the cloud, code in JavaScript and forget about back-end development.