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
Crystal Reports is a powerful reporting tool that allows developers to create feature-rich reports for their applications. When it comes to including barcodes in Crystal Reports using C#, it adds a new dimension to data representation, making it easier to manage and track information. In this article, we'll explore the steps to integrate barcodes into Crystal Reports using C#.
Before diving into the implementation, it's essential to select a barcode library that supports Crystal Reports and C#. One popular choice is the IronBarcode for .NET.
IronBarcode is a versatile .NET library that simplifies barcode generation and reading. With IronBarcode, you can effortlessly create various barcodes, including Code 128 and QR codes, by specifying the value to encode. It also supports resizing and customization. On the reading side, IronBarcode can extract barcode data from images or PDFs, making it ideal for inventory management and document tracking. Its user-friendly API ensures quick integration into your projects, and cross-platform support allows seamless development across different .NET versions. Whether you’re a seasoned developer or a beginner, IronBarcode empowers you to work with barcodes efficiently.
Open Visual Studio for creating an ASP.NET Crystal Reports Web Site. I am using Visual Studio 2022. You may use any, but make sure Crystal reports for Visual Studio for that particular version is installed.
Select Project Name, Location & Target Framework. Click on the Create Button. A new Project will be created as shown below.
Before we begin, we need to have a Database. Let's create a new database and a sample table.
The following script will create a new database.
CREATE DATABASE ProductDB;
USE [ProductDB]
GO
/****** Object: Table [dbo].[Products] Script Date: 3/10/2024 2:57:18 PM******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Products](
[Product_ID] [int] NULL,
[Product_Name] [varchar](100) NULL,
[Product_Price] [decimal](18, 0) NULL,
[Product_Barcode] [image] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
Let's insert data into this table. We'll create a barcode and save it in the Product table. Therefore, we need to insert data using C# code and install the IronBarcode Library in our project to use its features to create barcodes.
To install the IronBarcode library using the NuGet Package Manager Console, follow these steps:
Open the NuGet Package Manager Console. You can find it by going to View -> Other Windows -> Package Manager Console.
In the Package Manager Console, use the following command to install the IronBarcode library:
Install-Package BarCode
Press Enter to execute the command.
Alternatively, you can install IronBarcode library using the Manage NuGet Packages for Solution:
Wait for the NuGet Package Manager to download and install the IronBarcode library and its dependencies. Once the installation is complete, you'll see a confirmation message in the Package Manager Console.
Now, the IronBarcode library is installed in your project, and you can start using its features for barcode generation and reading.
We'll generate barcode images and store them in the database using ADO.NET. The following code demonstrates the example of generating a barcode in C#.
using System;
using System.Data.SqlClient;
using IronBarCode;
class Program
{
static void Main(string[] args)
{
// Create a barcode from a string value using Code128 format.
var myBarcode = BarcodeWriter.CreateBarcode("77446252", BarcodeWriterEncoding.Code128);
// Add the barcode value text below the barcode image.
myBarcode.AddBarcodeValueTextBelowBarcode();
// Resize the barcode image.
myBarcode.ResizeTo(600, 300);
// SQL connection to the SQL Server database.
using (SqlConnection cn = new SqlConnection("Data Source=localhost\\SQLEXPRESS;Initial Catalog=ProductDB;User ID=sa;Password=123456;Integrated Security=SSPI;"))
{
// SQL command to insert the barcode into the Products table.
SqlCommand cmd = new SqlCommand($"INSERT INTO dbo.Products VALUES (77446252, 'Pine Apple Small', '100', @Barcode)", cn);
// Add parameter for the barcode binary data.
cmd.Parameters.AddWithValue("@Barcode", myBarcode.BinaryStream);
// Open the connection, execute the query, close the connection.
cn.Open();
cmd.ExecuteNonQuery();
cn.Close();
}
}
}
using System;
using System.Data.SqlClient;
using IronBarCode;
class Program
{
static void Main(string[] args)
{
// Create a barcode from a string value using Code128 format.
var myBarcode = BarcodeWriter.CreateBarcode("77446252", BarcodeWriterEncoding.Code128);
// Add the barcode value text below the barcode image.
myBarcode.AddBarcodeValueTextBelowBarcode();
// Resize the barcode image.
myBarcode.ResizeTo(600, 300);
// SQL connection to the SQL Server database.
using (SqlConnection cn = new SqlConnection("Data Source=localhost\\SQLEXPRESS;Initial Catalog=ProductDB;User ID=sa;Password=123456;Integrated Security=SSPI;"))
{
// SQL command to insert the barcode into the Products table.
SqlCommand cmd = new SqlCommand($"INSERT INTO dbo.Products VALUES (77446252, 'Pine Apple Small', '100', @Barcode)", cn);
// Add parameter for the barcode binary data.
cmd.Parameters.AddWithValue("@Barcode", myBarcode.BinaryStream);
// Open the connection, execute the query, close the connection.
cn.Open();
cmd.ExecuteNonQuery();
cn.Close();
}
}
}
Imports System
Imports System.Data.SqlClient
Imports IronBarCode
Friend Class Program
Shared Sub Main(ByVal args() As String)
' Create a barcode from a string value using Code128 format.
Dim myBarcode = BarcodeWriter.CreateBarcode("77446252", BarcodeWriterEncoding.Code128)
' Add the barcode value text below the barcode image.
myBarcode.AddBarcodeValueTextBelowBarcode()
' Resize the barcode image.
myBarcode.ResizeTo(600, 300)
' SQL connection to the SQL Server database.
Using cn As New SqlConnection("Data Source=localhost\SQLEXPRESS;Initial Catalog=ProductDB;User ID=sa;Password=123456;Integrated Security=SSPI;")
' SQL command to insert the barcode into the Products table.
Dim cmd As New SqlCommand($"INSERT INTO dbo.Products VALUES (77446252, 'Pine Apple Small', '100', @Barcode)", cn)
' Add parameter for the barcode binary data.
cmd.Parameters.AddWithValue("@Barcode", myBarcode.BinaryStream)
' Open the connection, execute the query, close the connection.
cn.Open()
cmd.ExecuteNonQuery()
cn.Close()
End Using
End Sub
End Class
var myBarcode = BarcodeWriter.CreateBarcode("77446252", BarcodeWriterEncoding.Code128);
BarcodeWriter
class's CreateBarcode()
method. The barcode is generated from the data represented by the string "77446252" using the Code 128 encoding format. The myBarcode
variable now holds the generated barcode.AddBarcodeValueTextBelowBarcode()
ResizeTo(600, 300)
SaveAs()
method to save barcode images in the file system.The following barcode will be generated from the above code:
SqlConnection cn = new SqlConnection("Data Source=localhost\\SQLEXPRESS;Initial Catalog=ProductDB;User ID=sa;Password=123456;Integrated Security=SSPI;");
localhost\\SQLEXPRESS
), the initial catalog (database name: ProductDB
), and the authentication credentials (user ID sa
and password 123456
).SqlCommand cmd = new SqlCommand($"INSERT INTO dbo.Products VALUES (77446252, 'Pine Apple Small', '100', '{myBarcode.BinaryStream}' )", cn);
SqlCommand
object. This command represents an SQL query to insert data into the Products table.77446252
, 'Pine Apple Small'
, '100'
, and the binary stream of the generated barcode (myBarcode.BinaryStream
).Now, design the report layout, add database connections, and arrange the necessary fields. If you're new to this, follow the following steps.
Open Field Explorer => Database Field => Database Expert.
Expand Create a new Connection => OLE DB(ADO) => Make New Connection.
Select Microsoft OLE DB Data Source for SQL Server and click Next.
Provide the Server Name, Login Credential, and Database Name as shown below.
Select the table you want to add. In this case, select the Products table.
We have set up a Database Connection. Now, let's set up the Report layout.
Now, I have added a Text Box with the text "Barcode in Crystal report C#". I added a text box, and drag & drop the Product ID, Product Name, Product Price Field, and Product Barcode from the database fields and placed them inside the box as shown below.
See the Crystal Report Preview in Crystal Report Viewer.
Build and run the project. The output is as follows:
I have not downloaded the sample dataset package, ensuring I had the correct data file, and proceeded to create a Crystal Report in C# for comprehensive data visualization.
In this way, we can create a barcode in the Crystal Reports Application without downloading the Barcode Font. Similarly, we can also add a QR Code as per your requirement.
In conclusion, integrating barcodes into Crystal Reports using C# is a powerful way to enhance data representation and management. Choosing a reliable barcode library like IronBarcode streamlines the process, offering versatility and ease of use. IronBarcode, with its support for various barcode types, resizing, and customization features, proves to be a valuable asset in barcode generation and reading tasks. The step-by-step guide provided here ensures a seamless implementation process, from selecting the library to designing the Crystal Report layout.
Moreover, IronBarcode offers developers the opportunity to unlock additional functionalities and support to enhance their barcode integration experience. This flexibility makes IronBarcode a compelling choice for developers, whether they are working on small-scale projects or enterprise-level applications.
Crystal Reports is a powerful reporting tool that allows developers to create feature-rich reports for their applications, enhancing data representation and management.
To add a barcode to Crystal Reports using C#, you need to install a barcode library, generate a barcode image, save it to a database, design the Crystal Report layout, and include the barcode image field in your report.
IronBarcode is a recommended library for use with Crystal Reports and C#. It supports barcode generation and reading, and offers features like resizing and customization.
You can install IronBarcode library via the NuGet Package Manager Console by using the command 'Install-Package Barcode'. Alternatively, use the Manage NuGet Packages for Solution to search and install IronBarcode.
Using IronBarcode, generate a barcode image, add the value text below the barcode, resize it, and use ADO.NET to insert the barcode into a database table.
The SQL command used is an INSERT statement, like 'INSERT INTO dbo.Products VALUES (77446252, 'ProductName', 'Price', @Barcode)', where @Barcode is the barcode image binary data.
IronBarcode simplifies barcode generation and reading, supports various barcode formats, resizing, customization, and offers a user-friendly API for quick integration into projects.
Use the Field Explorer to navigate to Database Field, then Database Expert, expand Create a new Connection, select OLE DB(ADO), and set up your connection with server details.
Yes, IronBarcode supports the creation of various barcode types, including QR codes, providing versatile solutions for different requirements.
IronBarcode offers versatility, ease of use, support for multiple barcode types, cross-platform compatibility, and a user-friendly API, making it ideal for both small and enterprise-level applications.