Test in production without watermarks.
Works wherever you need it to.
Get 30 days of fully functional product.
Have it up and running in minutes.
Full access to our support engineering team during your product trial
Barcodes provide a clear and machine-readable way to present data. Initially, barcodes consisted of parallel lines with varying widths and spacing, serving as a representation of data. These traditional linear or one-dimensional (1D) barcodes could be scanned by specialized optical devices called barcode readers. However, the evolution of barcodes led to the invention of two-dimensional (2D) barcodes, also known as matrix codes. Unlike traditional barcodes, 2D barcodes utilize patterns such as rectangles, dots, and hexagons instead of bars. To read these 2D barcodes, specific optical scanner setups are available, or alternative methods involve using a digital camera connected to a computer running decoding software. Moreover, mobile devices like smartphones can leverage their integrated cameras and dedicated applications to function as a 2D barcode scanner.
Zebra Crossing, often known as ZXing, is an open-source, multi-format 1D/2D barcode image processing toolkit that was developed in Java and has ports for other languages. The core image decoding library, Java-specific client code, and the Android client Barcode Scanner are only a few of the modules that make up ZXing. Numerous more independent open-source projects are built upon it.
Open Visual Studio, choose "new project" from the file menu, then "console application". In this article, we are choosing the C# console app.
Enter the project name and the file path in the appropriate text box. Next, click the Create button to choose the required .NET Framework.
If you selected a console application, the project will now create its structure and open the program.cs file, allowing you to enter the program's code and build or execute it.
Enter the following command into the NuGet Package Manager Console to install the ZXing library:
Install-Package ZXing.Net.Bindings.Windows.Compatibility
Alternatively, you can get the package using the NuGet package manager tool. Like the illustration below. Try installing the first result you choose.
We can create a barcode using the following sample code. ZXing allows us to create more than 10 types of barcode formats.
using ZXing.Windows.Compatibility;
var options = new QrCodeEncodingOptions
{
Width = 250,
Height = 250,
};
var writer = new BarcodeWriter();
writer.Format = BarcodeFormat.QR_CODE;
writer.Options = options;
// Encode the string into a QR code bitmap image
System.Drawing.Bitmap _bitmap = writer.Write("Hello world");
// Save the bitmap as a PNG file
_bitmap.Save("Demo1.png");
using ZXing.Windows.Compatibility;
var options = new QrCodeEncodingOptions
{
Width = 250,
Height = 250,
};
var writer = new BarcodeWriter();
writer.Format = BarcodeFormat.QR_CODE;
writer.Options = options;
// Encode the string into a QR code bitmap image
System.Drawing.Bitmap _bitmap = writer.Write("Hello world");
// Save the bitmap as a PNG file
_bitmap.Save("Demo1.png");
Imports ZXing.Windows.Compatibility
Private options = New QrCodeEncodingOptions With {
.Width = 250,
.Height = 250
}
Private writer = New BarcodeWriter()
writer.Format = BarcodeFormat.QR_CODE
writer.Options = options
' Encode the string into a QR code bitmap image
Dim _bitmap As System.Drawing.Bitmap = writer.Write("Hello world")
' Save the bitmap as a PNG file
_bitmap.Save("Demo1.png")
The code above sets the height and width for the QrCodeEncodingOptions
. Then it creates an instance of BarcodeWriter
. For the BarcodeWriter
, we set the barcode format as QR code. We assign the previously created QR code options to the writer. The Write
method in the BarcodeWriter
encodes the given string into a barcode and returns it as a bitmap image. The image is saved using the Save
method of the bitmap. Below is the result from the code.
The next code sample demonstrates decoding a barcode using ZXing.
using ZXing.Windows.Compatibility;
// Load the barcode image into a bitmap
var barcodeBitmap = (System.Drawing.Bitmap)System.Drawing.Bitmap.FromFile("demo.png");
// Create a BarcodeReader object
var reader = new BarcodeReader();
// Decode the bitmap into a result
var result = reader.Decode(barcodeBitmap);
if (result != null)
{
// Output the decoded text to the console
Console.WriteLine(result.Text);
Console.ReadKey();
}
using ZXing.Windows.Compatibility;
// Load the barcode image into a bitmap
var barcodeBitmap = (System.Drawing.Bitmap)System.Drawing.Bitmap.FromFile("demo.png");
// Create a BarcodeReader object
var reader = new BarcodeReader();
// Decode the bitmap into a result
var result = reader.Decode(barcodeBitmap);
if (result != null)
{
// Output the decoded text to the console
Console.WriteLine(result.Text);
Console.ReadKey();
}
Imports ZXing.Windows.Compatibility
' Load the barcode image into a bitmap
Private barcodeBitmap = CType(System.Drawing.Bitmap.FromFile("demo.png"), System.Drawing.Bitmap)
' Create a BarcodeReader object
Private reader = New BarcodeReader()
' Decode the bitmap into a result
Private result = reader.Decode(barcodeBitmap)
If result IsNot Nothing Then
' Output the decoded text to the console
Console.WriteLine(result.Text)
Console.ReadKey()
End If
In the code above, we first load the image into a bitmap and then create a BarcodeReader
object. The Decode
function allows us to pass the bitmap as a parameter, which can return results in multiple formats. We use the Text
property to get the text encoded in the barcode.
With the help of this barcode library, reading and creating barcodes is straightforward. A dynamic barcode is easy to make with IronBarcode's Library. With just a few lines of code, this simple library can generate a barcode, which helps us to encode barcode images. IronBarcode enables us to generate barcodes in languages like C# and VB.NET.
To utilize the IronBarcode library in the solution, you must download the required package. To do this, use the following command in the NuGet Package Manager Console:
Install-Package BarCode
As an alternative, you can use the NuGet Package Manager, which will show all the search results, to seek and download the "Barcode" package. Then you can select the essential package to download into the program from them.
With just a few lines of code, we can quickly make barcode images using the IronBarcode library. Additionally, it enables us to save the created barcode as a separate picture file. Here is some sample C# code for creating a barcode label with a Console program.
using IronBarCode;
// Create a QR code with a medium error correction level
QRCodeWriter.CreateQrCode("Your text here", 500, QRCodeWriter.QrErrorCorrectionLevel.Medium).SaveAsPng("demo.png");
using IronBarCode;
// Create a QR code with a medium error correction level
QRCodeWriter.CreateQrCode("Your text here", 500, QRCodeWriter.QrErrorCorrectionLevel.Medium).SaveAsPng("demo.png");
Imports IronBarCode
' Create a QR code with a medium error correction level
QRCodeWriter.CreateQrCode("Your text here", 500, QRCodeWriter.QrErrorCorrectionLevel.Medium).SaveAsPng("demo.png")
This code produces a 500 by 500 pixel graphic using a medium level of error correction, and then saves it to a file location using the SaveAsPng
method.
The next code example reads the text encoded in the QR code that we created in the previous example.
using IronBarCode;
// Load the QR code image into a bitmap
var barcodeBitmap = (System.Drawing.Bitmap)System.Drawing.Bitmap.FromFile("demo.png");
// Read the barcode image
var reader = IronBarCode.BarcodeReader.Read(barcodeBitmap);
// Output the decoded value to the console
Console.WriteLine(reader.Values[0]);
Console.ReadKey();
using IronBarCode;
// Load the QR code image into a bitmap
var barcodeBitmap = (System.Drawing.Bitmap)System.Drawing.Bitmap.FromFile("demo.png");
// Read the barcode image
var reader = IronBarCode.BarcodeReader.Read(barcodeBitmap);
// Output the decoded value to the console
Console.WriteLine(reader.Values[0]);
Console.ReadKey();
Imports IronBarCode
' Load the QR code image into a bitmap
Private barcodeBitmap = CType(System.Drawing.Bitmap.FromFile("demo.png"), System.Drawing.Bitmap)
' Read the barcode image
Private reader = IronBarCode.BarcodeReader.Read(barcodeBitmap)
' Output the decoded value to the console
Console.WriteLine(reader.Values(0))
Console.ReadKey()
We first load the image into a bitmap, and then read the image using the Read
method on the BarcodeReader
class. We use the Values
property on the BarcodeResults
object returned from the Read
method to get the content that was read from the QR code.
To know more about ZXing and how it compares with IronBarcode, read this next blog post.
Our Reading Barcodes tutorial also provides more information about how to use IronBarcode to read barcodes and QR codes. For more code tutorials on IronBarcode.
ZXing barcode scanner can create high-quality barcodes, but it is outdated and supports few barcode formats. It also has limited documentation and product support.
On the other hand, IronBarcode is very efficient and flexible, and is able to work on many operating systems. IronBarcode can change the color, size, spacing, and lettering used in barcodes. It also supports Crystal Reports.
Developers can use IronBarcode for free. Users can purchase a license to access additional features and receive a full year of support and product updates.
ZXing, also known as Zebra Crossing, is an open-source, multi-format 1D/2D barcode image processing toolkit developed in Java with ports for other languages. It includes modules like the core image decoding library, Java-specific client code, and the Android client Barcode Scanner.
To install ZXing for .NET development, you can use the NuGet Package Manager Console with the command: Install-Package ZXing.Net.Bindings.Windows.Compatibility. Alternatively, you can use the NuGet package manager tool to search and install the package.
IronBarcode can read and write most barcode image formats and QR standards, correct rotation, noise, distortion, and skewing in scans and real-time video frames, and utilize multiple cores and threads for batch-processing. It can also find multiple barcodes in single- and multipage documents.
IronBarcode supports a wider range of barcode formats compared to ZXing. While ZXing is effective for creating high-quality barcodes, it is limited in format support, documentation, and product support. IronBarcode offers more flexibility and efficiency across different operating systems.
Yes, ZXing has an Android client Barcode Scanner module, and its core library can be integrated with mobile applications to leverage the device's camera for barcode scanning.
IronBarcode supports languages like C# and VB.NET for generating and reading barcode images.
To create a QR code with IronBarcode, you can use the QRCodeWriter class in C# to generate a QR code image and save it as a PNG file. You can specify the size and error correction level in the QRCodeWriter.CreateQrCode method.
To start using IronBarcode, you need to download the necessary package via the NuGet Package Manager Console using the command: Install-Package IronBarcode. Alternatively, you can search for the package in the NuGet Package Manager and download it.
Developers can use IronBarcode for free. However, purchasing a license provides access to additional features and includes a full year of support and product updates.
Yes, IronBarcode can process real-time video frames, correcting rotation, noise, distortion, and skewing to improve reading accuracy and speed during barcode scanning.