In this tutorial, you will learn how to use the ZXing.Net.Maui.Controls library to integrate a barcode scanner into your Android app using .NET MAUI.
Prerequisites
Before you begin developing a .NET MAUI application, you have to ensure your development environment is configured correctly.
First, you have to install the .NET SDK on your machine. We recommend installing .NET 8.0. You can check all the available versions by accessing the official .NET website.
You will create the application using Visual Studio. If you don’t have Visual Studio on your computer, access the Microsoft portal and download the Visual Studio Community version, which is free for individuals.
⚠️ A note for Mac users: Microsoft has ended support for Visual Studio on Mac. We’ve covered several other options in our blog post about Visual Studio alternatives.
During the installation, select the following workloads:
- ASP.NET and web development
- Mobile development with .NET
- Universal Windows Platform (UWP) development
Create a project
To create a new project, launch Visual Studio and follow these steps:
- Click on Create a new project.
- Search for .NET MAUI App using the search bar. Choose the .NET MAUI App template and click Next.
Visual Studio will generate the new project. If a Windows Security Alert regarding the firewall pops up, click Allow access to proceed.
Configure your MAUI app to scan barcodes
After creating the project, it’s time to add the ZXing.Net.Maui library to your project and configure it to add barcode scanning capabilities to your .NET MAUI app.
Step 1: Install ZXing.Net.Maui.Controls
Begin by installing the ZXing.Net.Maui.Controls NuGet package into your project. To add the package, run the following command:
dotnet add package ZXing.Net.Maui.Controls --version 0.4.0
This package provides the necessary components to integrate barcode scanning functionality seamlessly into your app.
Step 2: Initialize the ZXing.Net.Maui plugin
Next, you need to initialize the ZXing.Net.Maui plugin within the MauiProgram.cs file. This will enable the barcode scanning feature across the application. First, add the following to the top of the file:
using ZXing.Net.Maui;
After that, within the Create
method, add the UseBarcodeReader()
method to integrate the ZXing plugin into the app’s configuration:
public static MauiApp Create()
{
var builder = MauiApp.CreateBuilder();
builder
.UseMauiApp<App>()
.UseBarcodeReader(); // This line initializes the barcode reader plugin
return builder.Build();
}
Step 3: Provide camera access permissions
To scan barcodes, your app needs permission to access the device’s camera. You’ll need to add the appropriate permissions to the app’s metadata, depending on the platform you’re using. For Android, add the following permission to your AndroidManifest.xml
file:
<uses-permission android:name="android.permission.CAMERA" />
If you’re using iOS, include the following entry in your info.plist
file:
<key>NSCameraUsageDescription</key>
<string>This app uses the camera to scan barcodes.</string>
When adding permission for an iOS app, Ensure you enter a clear and valid reason for your app to access the camera. This message will be displayed to users when the app requests permission.
Step 4: Add the barcode reader
To start reading barcodes, you need to add the barcode reader control to your MainPage.xaml
. This is done by including the appropriate XML namespace and adding the CameraBarcodeReaderView
control. Your MainPage.xaml
should look like this:
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MauiApp.MainPage"
xmlns:zxing="clr-namespace:ZXing.Net.Maui.Controls;assembly=ZXing.Net.MAUI.Controls">
<zxing:CameraBarcodeReaderView
x:Name="cameraBarcodeReaderView"
IsDetecting="True"
BarcodesDetected="BarcodesDetected" />
</ContentPage>
The CameraBarcodeReaderView
component provides live barcode detection through the camera. In addition, setting IsDetecting
to True
ensures that barcode detection starts as soon as the app runs.
Step 5: Configure the barcode reader options
After setting up the UI, you have to configure the barcode reader’s behavior in MainPage.xaml.cs. In this step, you’ll specify which barcode formats your app should recognize and whether it should handle multiple barcodes simultaneously.
To define the barcode reader, use the x:Name
from the code snippet in step 4 for the zxing:CameraBarcodeReaderView
view. If you used the code example, that’s x:Name = cameraBarcodeReaderView
. To specify the options, use the BarcodeReaderOptions
class. The following code block presents a configuration example where the scanner is configured to detect EAN-13 barcodes, which are standard in many retail environments. The AutoRotate
option ensures that barcodes are detected regardless of orientation, while Multiple
allows for scanning more than one barcode at a time.
public MainPage()
{
InitializeComponent();
cameraBarcodeReaderView.Options = new ZXing.Net.Maui.BarcodeReaderOptions
{
Formats = ZXing.Net.Maui.BarcodeFormat.Ean13, // Set to recognize EAN-13 barcodes
AutoRotate = true, // Automatically rotate the image to detect barcodes from different angles
Multiple = true // Allow the detection of multiple barcodes at once
};
}
Step 6: Handle barcode detection events
As the last step, you need to handle the event triggered when a barcode is detected. To add this event handler, use the BarcodesDetected
method in your MainPage.xaml.cs
file.
For this tutorial, we’ll set the code to listen for barcode detection events and, upon detecting a barcode, display a message in a pop-up alert. The message will inform the barcode was detected and will also display the barcode. The pop-up will also contain a button, which the user can press to close the alert. The following code block presents a configuration example.
protected void BarcodesDetected(object sender, ZXing.Net.Maui.BarcodeDetectionEventArgs e)
{
var first = e.Results?.FirstOrDefault();
if (first is null) {
return;
}
Dispatcher.DispatchAsync(async () =>
{
await DisplayAlert("Barcode Detected", first.Value, "OK");
});
}
In the above example, the Dispatcher.DispatchAsync
method ensures that the UI is updated on the main thread, which is necessary for displaying alerts.
Since steps 5 and 6 change the MainPage.xaml.cs
file, the following code block presents the complete code for the MainPage.xaml.cs
to ensure your app is configured correctly.
namespace MauiApp
{
public partial class MainPage : ContentPage
{
public MainPage()
{
InitializeComponent();
cameraBarcodeReaderView.Options = new ZXing.Net.Maui.BarcodeReaderOptions
{
Formats = ZXing.Net.Maui.BarcodeFormat.Ean13, // Set to recognize EAN-13 barcodes
AutoRotate = true, // Automatically rotate the image to detect barcodes from different angles
Multiple = true // Allow the detection of multiple barcodes at once
};
}
protected void BarcodesDetected(object sender, ZXing.Net.Maui.BarcodeDetectionEventArgs e)
{
var first = e.Results?.FirstOrDefault();
if (first is null) {
return;
}
Dispatcher.DispatchAsync(async () =>
{
await DisplayAlert("Barcode Detected", first.Value, "OK");
});
}
}
}
Test the app
To test your finished app, you can connect your Android phone to your computer and enable Developer Options or use Virtual Devices (see Run on mobile device in the .NET MAUI docs to learn more).
⚠️ Not all Android devices work properly with Visual Studio when testing apps. We recommend trying the emulator if you face issues connecting your Android device.
Disadvantages of using the ZXing barcode scanner library
ZXing provides decent performance for basic barcode scanning tasks but sometimes struggles with more challenging scenarios. Its most notable drawbacks as a barcode scanning solution include:
- Scanning accuracy and speed: ZXing struggles with scanning poorly lit or damaged barcodes. It often exhibits low recognition rates for smaller barcodes and can fail to decode them altogether.
- Compatibility issues: ZXing may not perform reliably across all devices, particularly newer models. This has led to frustration among developers who require consistent performance across different platforms.
- Lack of active development: As an open-source project, ZXing has seen limited updates and maintenance in recent years. This stagnation can lead to unresolved bugs and compatibility issues, making it less reliable for commercial applications.
- Integration complexity: Integrating ZXing into your app can be cumbersome, especially for developers who may not be familiar with its architecture. This can lead to longer development times and increased chances of bugs during implementation.
We developed the Scanbot Barcode Scanner SDK as a commercial solution to help enterprises overcome these hurdles presented by free barcode scanning software. Our goal was to have a developer-friendly solution available for a wide range of platforms that consistently delivers high-quality results – even in challenging circumstances.
Integrating the SDK into your MAUI app only takes a few minutes. Don’t believe us? Then give it a try yourself by heading over to our step-by-step tutorial! Or take a look at our MAUI example app for an implementation similar to this ZXing one.
Should you have any questions, feel free to reach out to us on Slack or MS Teams or send us an email via sdksupport@scanbot.io