public BarcodeReturnCheckDigit ReturnCheckDigit { get; set; }
@property (nonatomic, assign) LTBarcodeReturnCheckDigit returnCheckDigit;
public BarcodeReturnCheckDigit getReturnCheckDigit()
public void setReturnCheckDigit(BarcodeReturnCheckDigit value)
public:
property BarcodeReturnCheckDigit ReturnCheckDigit {
BarcodeReturnCheckDigit get();
void set ( BarcodeReturnCheckDigit );
}
ReturnCheckDigit # get and set (GS1DatabarStackedBarcodeReadOptions)
Value indicating whether the error check digit is returned as part of the barcode data. The default value is Default.
If you set the value of ReturnCheckDigit to Yes, then this digit is returned as part of barcode data (can be retrieved with BarcodeData.GetData or BarcodeData.Value). Then parse the data and extract the error check digit from the rest of the data based on the barcode symbology standard.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.Barcode;
using Leadtools.ImageProcessing;
public void GS1DatabarStackedBarcode_Example()
{
string imageFileName = Path.Combine(LEAD_VARS.ImagesDir, "MyGS1DatabarStackedBarcodes.tif");
BarcodeEngine engine = new BarcodeEngine();
// Create the image to write the barcodes to
int resolution = 300;
using (RasterImage image = RasterImage.Create((int)(8.5 * resolution), (int)(11.0 * resolution), 1, resolution, RasterColor.FromKnownColor(RasterKnownColor.White)))
{
// Write a few GS1 Databar Stacked barcodes
WriteBarcode(engine.Writer, image, BarcodeSymbology.GS1DatabarStacked, "1234567890123", new LeadRect(10, 100, 400, 400));
WriteBarcode(engine.Writer, image, BarcodeSymbology.GS1DatabarExpandedStacked, "(01)00012345678905(10)ABC123", new LeadRect(10, 900, 400, 400));
// Save the image
using (RasterCodecs codecs = new RasterCodecs())
{
codecs.Save(image, imageFileName, RasterImageFormat.CcittGroup4, 1);
}
}
// Now read the barcodes again
using (RasterCodecs codecs = new RasterCodecs())
{
using (RasterImage image = codecs.Load(imageFileName))
{
// Read the GS1 Databar Stacked barcode
ReadBarcodes(engine.Reader, image, BarcodeSymbology.GS1DatabarStacked);
// Read the GS1 Databar Expanded Stacked barcode
ReadBarcodes(engine.Reader, image, BarcodeSymbology.GS1DatabarExpandedStacked);
}
}
}
private void WriteBarcode(BarcodeWriter writer, RasterImage image, BarcodeSymbology symbology, string value, LeadRect bounds)
{
// Create the barcode data
BarcodeData barcode = new BarcodeData(symbology, value);
barcode.Bounds = bounds;
// Set the write options
GS1DatabarStackedBarcodeWriteOptions options = new GS1DatabarStackedBarcodeWriteOptions();
options.UseXModule = false;
options.XModule = 30;
options.SetLinkageBit = false;
options.UseStackedOmniDirectionalFormat = false;
options.ExpandedStackedRowsCount = 2;
// Write it
Console.WriteLine("Writing {0} barcode with data: {1}", symbology, value);
writer.WriteBarcode(image, barcode, options);
}
private void ReadBarcodes(BarcodeReader reader, RasterImage image, BarcodeSymbology symbology)
{
// Setup read options
GS1DatabarStackedBarcodeReadOptions options = new GS1DatabarStackedBarcodeReadOptions();
options.SearchDirection = BarcodeSearchDirection.Horizontal;
options.EnableFastMode = true;
options.Granularity = 9;
options.ReturnCheckDigit = BarcodeReturnCheckDigit.Default;
Console.WriteLine("Reading {0} barcodes", symbology);
BarcodeData barcode = reader.ReadBarcode(image, LeadRect.Empty, symbology, options);
if (barcode != null)
{
Console.WriteLine(" At {0}, data: {1}", barcode.Bounds, barcode.Value);
}
else
{
Console.WriteLine(" Not found");
}
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document