The following example demonstrates how to use Bytescout BarCode SDK and its Barcode class with Crystal Reports to insert barcodes into an automatically generated report based on a database SQL query.

Run Visual Studio 2005

Create new Crystal Reports Application by using the menu: File | New | Project..

Select Crystal Reports Application project type and enter the project name as CrystalReportsWithBarcode and then click OK to create new Crystal Reports Application:

New Project wizard

Crystal Reports Gallery window will appear, select Standard Expert type and click OK

New report

Then the Wizard will ask to choose the data source for the report. You can use your own data source or use the data source provided with this sample (products.mdb) as shown on the screenshot below.

New connection

Products.mdb database

If you use products.mdb then

Choose Products table to import data from


And click OK button

In next screen you will be suggested to choose fields from the table to use in the report. Choose Products.ProductName and Products.ProductDescription field


and finally click Finish button

Now report designer window will appear. Move automatically generated elements if needed:

Default layout

For example you can re-arrange elements like this:

Rearranged layout

Now we need to create a dataset to bind the data from the query and the barcode generation component

To show SQL Query used for the data query please right-click in the report designer and use Database -> Show SQL Query.. command from the menu:

Show SQL Quert

The designer will show the SQL Query:

SELECT `Products`.`ProductName`, `Products`.`ProductDescription FROM `Products` `Products`

SQL Quert

Now we will create the dataset which will bind data from the query and barcode generation component. Copy BarcodeDataSet.xsd (provided with this example) into the project folder and open this file in the editor (in Notepad or Visual Studio editor):

Notepad editing XSD

We need to bind virtual data set and data we have already added to the report. If we want to bind data using ProductName string field then we should add the following child element :

<xs:element name=”ProductName” type=”xs:string” minOccurs=”0″ />



element inside BarcodeDataSet.xsd file

So BarcodeDataSet.xsd will look like this:

Add line

<?xml version=”1.0″ standalone=”yes”?>

<xs:schema id=”NewDataSet” xmlns=”” xmlns:xs=”” xmlns:msdata=”urn:schemas-microsoft-com:xml-msdata”>

<xs:element name=”NewDataSet” msdata:IsDataSet=”true” msdata:UseCurrentLocale=”true”>


<xs:choice minOccurs=”0″ maxOccurs=”unbounded”>

<xs:element name=”Table”>



<xs:element name=”ProductName” type=”xs:string” minOccurs=”0″ />








Now we need to add virtual dataset (BarcodeDataSet.xsd) into our project.

In Solution Explorer right-click on the project and select Add -> Existing Item:

Add dataset into project

Then select BarcodeDataSet.xsd file and click Add

Select file

Visual Studio will add BarcodeDataSet.xsd into the project and you’ll see BarcodeDataSet.xsd in the Solution Explorer in the project:

Solution Explorer

Switch to Field Explorer in Visual Studio, right click and click Database Expert command to call Database Expert:

Database Expert

Project Data, ADO.NET DataSets, CrystalReportWithBarcode.NewDataSet Table.

On the left side (In Available Data Source) select Project Data -> ADO.NET DataSets -> CrystalReportWithBarcode.NewDataSet and select Table element

Then click > button to add this Table into our project:

Adding dataset

Adding dataset

Click OK

Database Export will show Links window:

Link dialog

We don’t need to change anything as data is already linked (as you see can see the arrow links ProductName to the table) and we need to click OK

The Database warning will appear

Warning message

Click OK to ignore warning

Now we need to place a placeholder for the barcode image. Switch to Field Explorer and expand Database Fields and then select Table element

Drag element

Then drag-n-drop BarcodeImage element into the report designer:

Drag element

Drop the element into the report. Change the size and the position of the BarcodeImage element:

Dragging completed

Resize the object to the desired size:

Right-click on the BarcodeImage and select Format Object command:

Format Object command

Format Editor dialog will appear.

Rename Object Name into BarcodeImagePlacholder and make sure Can Grow checkbox is Unchecked

Ranaming project

Click OK to close the dialog

Now we should add the reference to Bytescout.BarCode.dll to the project

In Solution Explorer right click on the References element of the CrystalReportsWithBarcode project and select Add Reference.. command

Add reference to Bytescout BarCode

Now we should add the code to generate barcode image by generating barcode images using Bytescout BarCode SDK.

This code will be called on report load event and will provide the generated barcode image as the byte array

Select Form1 and switch to Design mode for the form. Then select crystalReportViewer1 object in the list of available objects on the form in Properties panel:

Report viewer properties

Switch to Events tab for the crystalReportViewer1 object and double-click on Load:

Switch to Events tab

This double-click will automatically create crystalReportViewer1_Load(object sender, EventArgs e) function and will automatically switch to Form1.cs source into automatically generated method: code:

New method added automatically

Now copy and paste the code to into crystalReportViewer1_Load function

Visual C# sample code:

private void crystalReportViewer1_Load(object sender, EventArgs e)
// create (duplicate) connection for report fields
// we use OleDbConnection to the sample Access database
// you should create your connection yourselves

OleDbConnection aConnection = new OleDbConnection(“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C: /CrystalReportsWithBarcode/products.mdb”);

// use SQL query you previously remembered
OleDbDataAdapter dataAdapter = new OleDbDataAdapter(“SELECT `Products`.`ProductName`, `Products`.`ProductDescription` FROM `Products` `Products`”, aConnection);

// fill dataset
DataSet ds = new DataSet();

// add virtual field that will be used for generated barcode data
ds.Tables[0].Columns.Add(new DataColumn(“BarcodeImage”, typeof(byte[])));

// don’t forget to close the connection

// create barcode object
Barcode bc = new Barcode(SymbologyType.Code128);
bc.DrawCaption = false;
bc.NarrowBarWidth = 1;
bc.WideToNarrowRatio = 2;

foreach (DataRow dr in ds.Tables[0].Rows)
// set barcode object’s Value property to a value of a field
// you want to be used for barcode creation
// we use 5 first symbols of product name
bc.Value = (dr[“ProductName”] as string).Substring(0, 5);

// retrieve generated image bytes
byte[] barcodeBytes = bc.GetImageBytesPNG();

// fill virtual field with generated image bytes
dr[“BarcodeImage”] = barcodeBytes;

// attach data source to virtual table

Now run the application and you’ll see the report with barcode images in the report:

Run application with the report

Solution to “Database Login” dialog appearing and asking to enter login and passsword:

1) Click “Explore Folder” and find “BinDebug” folder and open Products.mdb file
2) Copy Products.mdb into C: drive
3) Then open CrystalReportsWithBarcode.sln solution in Visual Studio 2005
4) In the Solution Explorer find and double-click CrystalReport1.rpt file
This will show report design mode.
5) Right-click anyway on the report and select Database -> Verify Database.. in the menu
6) Database Source dialog will appear. Click “Browse…” button and locate c:Products.mdb file
7) Click Finish button. Visual Studio will display “The database is up to date” message
8) Finally, run the project by click Run button on the toolbar in Visual Studio or F5 button

Windows Vista note: you may need to copy into c:UsersYourUserNameDesktop instead of c: folder on step (2)