---
title: "Scan and read 1D (linear) barcodes in C# .NET | Nutrient .NET SDK"
canonical_url: "https://www.nutrient.io/guides/dotnet/barcodes/read-scan/1d-linear/"
md_url: "https://www.nutrient.io/guides/dotnet/barcodes/read-scan/1d-linear.md"
last_updated: "2026-05-21T17:12:02.199Z"
description: "Discover how to scan 1D barcodes efficiently with our step-by-step guide, featuring practical tips and methods for seamless barcode scanning."
---

# Scan and read 1D (linear) barcodes in C#

## Reading a 1D barcode from an image

In addition to the general barcode scanning workflow below, you can use this focused 1D-specific snippet:

```csharp

using GdPicture14;

LicenseManager licence = new LicenseManager();
licence.RegisterKEY("");

using GdPictureImaging imaging = new GdPictureImaging();
int imageId = imaging.CreateGdPictureImageFromFile(@"input_barcode_1d.png");
imaging.Barcode1DReaderDoScan(imageId);
int barcodesCount = imaging.Barcode1DReaderGetBarcodeCount();
if (barcodesCount > 0)
{
    string barcodeValue = imaging.Barcode1DReaderGetBarcodeValue(1);
}

```

## Scanning a barcode from an image

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

- [Scan and read Aztec Code in C# .NET](/guides/dotnet/barcodes/read-scan/aztec-code.md)
- [Scan and read Micro QR codes in C#](/guides/dotnet/barcodes/read-scan/microqr.md)
- [C# barcode reader and scanner library](/guides/dotnet/barcodes/read-scan.md)
- [Scan, read, and generate Data Matrix barcodes in C#](/guides/dotnet/barcodes/read-scan/datamatrix.md)
- [Scan and read MaxiCode in C# .NET](/guides/dotnet/barcodes/read-scan/maxicode.md)
- [Scan and read PDF417 barcodes in C#](/guides/dotnet/barcodes/read-scan/pdf417.md)
- [Scan and read QR codes in C#](/guides/dotnet/barcodes/read-scan/qr.md)

