---
title: "C# .NET barcode recognition for 1D and 2D barcodes | Nutrient .NET SDK"
canonical_url: "https://www.nutrient.io/guides/dotnet/ocr/usage/barcode-recognition/"
md_url: "https://www.nutrient.io/guides/dotnet/ocr/usage/barcode-recognition.md"
last_updated: "2026-05-21T17:12:02.207Z"
description: "Learn how to scan 1D barcodes effectively with our step-by-step guide, featuring essential methods and tips for accurate barcode scanning."
---

# C# barcode recognition

Nutrient.NET SDK (formerly GdPicture.NET) enables you to recognize one-dimensional (1D or linear) and two-dimensional (2D) barcodes.

Nutrient.NET SDK supports all 1D barcode formats and the following 2D barcode formats:

- Aztec Code

- Data Matrix

- MaxiCode

- Micro QR

- PDF417

- QR

To recognize 1D barcodes and then write their values to the console, follow these steps:

1. Create a `GdPictureImaging` object.

2. Select the image by passing its path to the `CreateGdPictureImageFromFile` method of the `GdPictureImaging` object.

3. Scan the barcodes by passing the image as the parameter of the `Barcode1DReaderDoScan` method.

4. Determine the number of scanned barcodes and loop through them.

5. Save the value of each barcode.

6. Write the values to the console.

7. Release unnecessary resources.

The example below scans 1D barcodes and then writes their values to the console:

### C#

```csharp

using GdPictureImaging gdpictureImaging = new GdPictureImaging();
// Select the image to process.
int imageID = gdpictureImaging.CreateGdPictureImageFromFile(@"C:\temp\source.png");
// Scan the barcodes.
gdpictureImaging.Barcode1DReaderDoScan(imageID);
// Determine the number of scanned barcodes.
int barcodeCount = gdpictureImaging.Barcode1DReaderGetBarcodeCount();
string content = "";
if (barcodeCount > 0)
{
    content = "Number of barcodes scanned: " + barcodeCount.ToString();
    // Save the value of each barcode.
    for (int i = 1; i <= barcodeCount; i++)
    {
        content += $"\nBarcode Number: {i} Value: {gdpictureImaging.Barcode1DReaderGetBarcodeValue(i)}";
    }
}
// Write the values to the console.
Console.WriteLine(content);
// Release unnecessary resources.
gdpictureImaging.Barcode1DReaderClear();
gdpictureImaging.ReleaseGdPictureImage(imageID);

```

### VB.NET

```vb

Using gdpictureImaging As GdPictureImaging = New GdPictureImaging()
    ' Select the image to process.
    Dim imageID As Integer = gdpictureImaging.CreateGdPictureImageFromFile("C:\temp\source.png")
    ' Scan the barcodes.
    gdpictureImaging.Barcode1DReaderDoScan(imageID)
    ' Determine the number of scanned barcodes.
    Dim barcodeCount As Integer = gdpictureImaging.Barcode1DReaderGetBarcodeCount()
    Dim content = ""
    If barcodeCount > 0 Then
        content = "Number of barcodes scanned: " & barcodeCount.ToString()
        ' Save the value of each barcode.
        For i = 1 To barcodeCount
            content = content & vbLf & "Barcode Number: " & i.ToString() & "    Value: " & gdpictureImaging.Barcode1DReaderGetBarcodeValue(i).ToString()
        Next
    End If
    ' Write the values to the console.
    Console.WriteLine(content);
    ' Release unnecessary resources.
    gdpictureImaging.Barcode1DReaderClear()
    gdpictureImaging.ReleaseGdPictureImage(imageID)
End Using

```

#### Used methods and properties

- [`Barcode1DReaderClear`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~Barcode1DReaderClear.html)

- [`Barcode1DReaderDoScan`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~Barcode1DReaderDoScan.html)

- [`Barcode1DReaderGetBarcodeCount`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~Barcode1DReaderGetBarcodeCount.html)

- [`Barcode1DReaderGetBarcodeValue`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~Barcode1DReaderGetBarcodeValue.html)

- [`CreateGdPictureImageFromFile`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~CreateGdPictureImageFromFile.html)

- [`ReleaseGdPictureImage`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~ReleaseGdPictureImage.html)

#### Related topics

- [Load a file](/guides/dotnet/load-a-file.md)

- [Save a file](/guides/dotnet/save-a-file.md)

 and  methods.

## Additional options

To determine which types of 1D barcode to scan, use an overload of the [`Barcode1DReaderDoScan`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.GdPictureImaging~Barcode1DReaderDoScan.html) method that accepts members of the [`Barcode1DReaderType`](/api/gdpicture/GdPicture.NET.14.API~GdPicture14.Barcode1DReaderType.html) enumeration as its parameter. As a result, GdPicture.NET only scans the types of 1D barcode that you specify.

## Additional options

To determine the version of a 1D barcode, pass the index of the barcode to the  method.

---

## Related pages

- [C# OCR scanning to searchable PDFs](/guides/dotnet/ocr/usage/ocr-scan.md)
- [OCR PDF in C#](/guides/dotnet/ocr/usage/pdf-to-searchable-pdf.md)
- [Convert images into searchable PDF/A files in C#](/guides/dotnet/ocr/usage/pdfa-archiving.md)
- [C# OCR image to text](/guides/dotnet/ocr/usage/image-to-searchable-pdf.md)

