LEADTOOLS Barcode (Leadtools.Barcode assembly)
LEAD Technologies, Inc

MicroPDF417BarcodeData Class

Example 







Members 
Contains the data for a single MicroPDF417 barcode. .NET support Silverlight support
Object Model
MicroPDF417BarcodeData Class
Syntax
[TypeConverterAttribute()]
[SerializableAttribute()]
public class MicroPDF417BarcodeData : BarcodeData, System.ICloneable  
'Declaration
 
<TypeConverterAttribute()>
<SerializableAttribute()>
Public Class MicroPDF417BarcodeData 
   Inherits BarcodeData
   Implements System.ICloneable 
'Usage
 
Dim instance As MicroPDF417BarcodeData
public sealed class MicroPDF417BarcodeData : System.ICloneable  
ObjectiveC Syntax
Java Syntax
function Leadtools.Barcode.MicroPDF417BarcodeData()
[TypeConverterAttribute()]
[SerializableAttribute()]
public ref class MicroPDF417BarcodeData : public BarcodeData, System.ICloneable  
Remarks

The MicroPDF417BarcodeData class derives from the base BarcodeData to add specific data that can be read or written when using MicroPDF417 barcodes.

Reading Barcodes

When the BarcodeReader object detects and reads a MicroPDF417 (BarcodeSymbology.MicroPDF417), the BarcodeReader.ReadBarcode and BarcodeReader.ReadBarcodes methods will return the MicroPDF417BarcodeData object for each barcode casted down to the base BarcodeData class.

You can can perform standard .NET casting to get the object as MicroPDF417BarcodeData and then examine the extra data properties associated with it.

In addition to all the data members returned as usual in the base BarcodeData object, this class adds the following members:

In addition to the members above, other MicroPDF417 read options not related to the barcode data can be set using the MicroPDF417BarcodeReadOptions class.

Writing Barcodes

The BarcodeWriter class contains the WriteBarcode method that is used to write a barcode to an image. This method accepts the data parameter as the base BarcodeData object. To write a MicroPDF417 barcode, create an instance of MicroPDF417BarcodeData and fill the required parameters then pass this object as the data parameter to WriteBarcode.

In addition to all the data members that must be set as usual in the base BarcodeData object, you must also specify the following members:

In addition to the members above, other MicroPDF417 write options not related to the barcode data can be set using the MicroPDF417BarcodeWriteOptions class.

Use the static (or Shared in Visual Basic) BarcodeData.CreateDefaultBarcodeData method to create a new instance of MicroPDF417BarcodeData that contains default parameters ready for writing to an image:

[Visual Basic]

    
             Dim microPDF417Data As MicroPDF417BarcodeData = DirectCast(BarcodeData.CreateDefaultBarcodeData(BarcodeSymbology.MicroPDF417), MicroPDF417BarcodeData)
             

  

[C#]

    
             MicroPDF417BarcodeData microPDF417Data = BarcodeData.CreateDefaultBarcodeData(BarcodeSymbology.MicroPDF417) as MicroPDF417BarcodeData;
             

  

Example
Copy CodeCopy Code  
Public Sub MicroPDF417Barcode_Example()
      Dim imageFileName As String = Path.Combine(LEAD_VARS.ImagesDir, "MyMicroPDF417Barcodes.tif")

      Dim engine As New BarcodeEngine()

      ' Create the image to write the barcodes to
      Dim resolution As Integer = 300
      Using image As RasterImage = RasterImage.Create(CType(8.5 * resolution, Integer), CType(11.0 * resolution, Integer), 1, resolution, RasterColor.FromKnownColor(RasterKnownColor.White))
         ' Write two MicroPDF417 barcodes
         WriteBarcode(engine.Writer, image, "DATA1", MicroPDF417BarcodeSymbolSize.Smallest, True)
         WriteBarcode(engine.Writer, image, "DATA2", MicroPDF417BarcodeSymbolSize.Size44X4, False)

         ' Save the image
         Using codecs As New RasterCodecs()
            codecs.Save(image, imageFileName, RasterImageFormat.CcittGroup4, 1)
         End Using
      End Using

      ' Now read the barcodes again
      Using codecs As New RasterCodecs()
         Using image As RasterImage = codecs.Load(imageFileName)
            ReadBarcodes(engine.Reader, image)
         End Using
      End Using
   End Sub

   Private Sub WriteBarcode(ByVal writer As BarcodeWriter, ByVal image As RasterImage, ByVal value As String, ByVal symbolSize As MicroPDF417BarcodeSymbolSize, ByVal topLeft As Boolean)
      ' Create the barcode data
      Dim barcode As New MicroPDF417BarcodeData()
      barcode.Value = value
      barcode.DataCode = 0

      ' We will use the alignment to position the barcodes, so use all of the image
      barcode.Bounds = New LogicalRectangle(0, 0, image.ImageWidth, image.ImageHeight, LogicalUnit.Pixel)

      ' Set the write options
      Dim options As New MicroPDF417BarcodeWriteOptions()

      If topLeft Then
         options.HorizontalAlignment = BarcodeAlignment.Near
         options.VerticalAlignment = BarcodeAlignment.Near
      Else
         options.HorizontalAlignment = BarcodeAlignment.Far
         options.VerticalAlignment = BarcodeAlignment.Far
      End If

      options.UseMode128Emulation = False
      options.IsLinked = False
      options.EnableGroupMode = False
      options.XModule = 30
      options.XModuleAspectRatio = 3
      options.LimitByRowsAndColumns = True
      options.SymbolSize = symbolSize

      ' Write it
      Console.WriteLine("Writing barcode with symbol size: {0} and Data: {1}", symbolSize, value)
      writer.WriteBarcode(image, barcode, options)
   End Sub

   Private Sub ReadBarcodes(ByVal reader As BarcodeReader, ByVal image As RasterImage)
      ' Setup read options
      Dim options As New MicroPDF417BarcodeReadOptions()
      options.SearchDirection = BarcodeSearchDirection.Horizontal
      options.EnableDoublePass = False
      options.ReadMode = MicroPDF417BarcodeReadMode.Mode0
      options.ReadOptionalMacroFileNameField = False
      options.ReadOptionalMacroSegmentCountField = False
      options.ReadOptionalMacroTimestampField = False
      options.ReadOptionalMacroSenderField = False
      options.ReadOptionalMacroAddresseeField = False
      options.ReadOptionalMacroFileSizeField = False
      options.ReadOptionalMacroChecksumField = False
      options.ReadOptionalMacro79AndAZField = False

      Console.WriteLine("Reading Barcodes")
      Dim barcodes() As BarcodeData = reader.ReadBarcodes(image, LogicalRectangle.Empty, 0, New BarcodeSymbology() {BarcodeSymbology.MicroPDF417}, New BarcodeReadOptions() {options})
      Console.WriteLine("{0} barcodes found:", barcodes.Length)
      For Each barcode As MicroPDF417BarcodeData In barcodes
         Console.WriteLine(" At {0} and data: {1}", barcode.Bounds, barcode.Value)
      Next
   End Sub

Public NotInheritable Class LEAD_VARS
   Public Const ImagesDir As String = "C:\Users\Public\Documents\LEADTOOLS Images"
End Class
public void MicroPDF417Barcode_Example()
   {
      string imageFileName = Path.Combine(LEAD_VARS.ImagesDir, "MyMicroPDF417Barcodes.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 two MicroPDF417 barcodes
         WriteBarcode(engine.Writer, image, "DATA1", MicroPDF417BarcodeSymbolSize.Smallest, true);
         WriteBarcode(engine.Writer, image, "DATA2", MicroPDF417BarcodeSymbolSize.Size44X4, false);

         // 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))
         {
            ReadBarcodes(engine.Reader, image);
         }
      }
   }

   private void WriteBarcode(BarcodeWriter writer, RasterImage image, string value, MicroPDF417BarcodeSymbolSize symbolSize, bool topLeft)
   {
      // Create the barcode data
      MicroPDF417BarcodeData barcode = new MicroPDF417BarcodeData();
      barcode.Value = value;
      barcode.DataCode = 0;

      // We will use the alignment to position the barcodes, so use all of the image
      barcode.Bounds = new LogicalRectangle(0, 0, image.ImageWidth, image.ImageHeight, LogicalUnit.Pixel);

      // Set the write options
      MicroPDF417BarcodeWriteOptions options = new MicroPDF417BarcodeWriteOptions();

      if(topLeft)
      {
         options.HorizontalAlignment = BarcodeAlignment.Near;
         options.VerticalAlignment = BarcodeAlignment.Near;
      }
      else
      {
         options.HorizontalAlignment = BarcodeAlignment.Far;
         options.VerticalAlignment = BarcodeAlignment.Far;
      }

      options.UseMode128Emulation = false;
      options.IsLinked = false;
      options.EnableGroupMode = false;
      options.XModule = 30;
      options.XModuleAspectRatio = 3;
      options.LimitByRowsAndColumns = true;
      options.SymbolSize = symbolSize;

      // Write it
      Console.WriteLine("Writing barcode with symbol size: {0} and Data: {1}", symbolSize, value);
      writer.WriteBarcode(image, barcode, options);
   }

   private void ReadBarcodes(BarcodeReader reader, RasterImage image)
   {
      // Setup read options
      MicroPDF417BarcodeReadOptions options = new MicroPDF417BarcodeReadOptions();
      options.SearchDirection = BarcodeSearchDirection.Horizontal;
      options.EnableDoublePass = false;
      options.ReadMode = MicroPDF417BarcodeReadMode.Mode0;
      options.ReadOptionalMacroFileNameField = false;
      options.ReadOptionalMacroSegmentCountField = false;
      options.ReadOptionalMacroTimestampField = false;
      options.ReadOptionalMacroSenderField = false;
      options.ReadOptionalMacroAddresseeField = false;
      options.ReadOptionalMacroFileSizeField = false;
      options.ReadOptionalMacroChecksumField = false;
      options.ReadOptionalMacro79AndAZField = false;

      Console.WriteLine("Reading Barcodes");
      BarcodeData[] barcodes = reader.ReadBarcodes(image, LogicalRectangle.Empty, 0, new BarcodeSymbology[] { BarcodeSymbology.MicroPDF417 }, new BarcodeReadOptions[] { options });
      Console.WriteLine("{0} barcodes found:", barcodes.Length);
      foreach(MicroPDF417BarcodeData barcode in barcodes)
      {
         Console.WriteLine(" At {0} and data: {1}", barcode.Bounds, barcode.Value);
      }
   }

static class LEAD_VARS
{
   public const string ImagesDir = @"C:\Users\Public\Documents\LEADTOOLS Images";
}
[TestMethod]
public async Task MicroPDF417Barcode_Example()
{
   string imageFileName = @"MyMicroPDF417Barcodes.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, RasterColorHelper.FromKnownColor(RasterKnownColor.White)))
   {
      // Write two MicroPDF417 barcodes
      WriteBarcode(engine.Writer, image, "DATA1", MicroPDF417BarcodeSymbolSize.Smallest, true);
      WriteBarcode(engine.Writer, image, "DATA2", MicroPDF417BarcodeSymbolSize.Size44X4, false);

      // Save the image
      using(RasterCodecs codecs = new RasterCodecs())
      {
         StorageFile saveFile = await Tools.AppLocalFolder.CreateFileAsync(imageFileName);
         await codecs.SaveAsync(image, LeadStreamFactory.Create(saveFile), RasterImageFormat.CcittGroup4, 1);
      }
   }

   // Now read the barcodes again
   using(RasterCodecs codecs = new RasterCodecs())
   {
      StorageFile loadFile = await Tools.AppInstallFolder.GetFileAsync(imageFileName);
      using(RasterImage image = await codecs.LoadAsync(LeadStreamFactory.Create(loadFile)))
      {
         ReadBarcodes(engine.Reader, image);
      }
   }
}

private void WriteBarcode(BarcodeWriter writer, RasterImage image, string value, MicroPDF417BarcodeSymbolSize symbolSize, bool topLeft)
{
   // Create the barcode data
   BarcodeData barcode = new BarcodeData();
   barcode.Value = value;
   barcode.MicroPDF417DataCode = 0;

   // We will use the alignment to position the barcodes, so use all of the image
   barcode.Bounds = LeadRectHelper.Create(0, 0, image.ImageWidth, image.ImageHeight);

   // Set the write options
   MicroPDF417BarcodeWriteOptions options = new MicroPDF417BarcodeWriteOptions();

   if(topLeft)
   {
      options.HorizontalAlignment = BarcodeAlignment.Near;
      options.VerticalAlignment = BarcodeAlignment.Near;
   }
   else
   {
      options.HorizontalAlignment = BarcodeAlignment.Far;
      options.VerticalAlignment = BarcodeAlignment.Far;
   }

   options.UseMode128Emulation = false;
   options.IsLinked = false;
   options.EnableGroupMode = false;
   options.XModule = 30;
   options.XModuleAspectRatio = 3;
   options.LimitByRowsAndColumns = true;
   options.SymbolSize = symbolSize;

   // Write it
   Debug.WriteLine("Writing barcode with symbol size: {0} and Data: {1}", symbolSize, value);
   writer.WriteBarcode(image, barcode, options);
}

private void ReadBarcodes(BarcodeReader reader, RasterImage image)
{
   // Setup read options
   MicroPDF417BarcodeReadOptions options = new MicroPDF417BarcodeReadOptions();
   options.SearchDirection = BarcodeSearchDirection.Horizontal;
   options.EnableDoublePass = false;
   options.ReadMode = MicroPDF417BarcodeReadMode.Mode0;
   options.ReadOptionalMacroFileNameField = false;
   options.ReadOptionalMacroSegmentCountField = false;
   options.ReadOptionalMacroTimestampField = false;
   options.ReadOptionalMacroSenderField = false;
   options.ReadOptionalMacroAddresseeField = false;
   options.ReadOptionalMacroFileSizeField = false;
   options.ReadOptionalMacroChecksumField = false;
   options.ReadOptionalMacro79AndAZField = false;

   Debug.WriteLine("Reading Barcodes");
   BarcodeData[] barcodes = reader.ReadBarcodes(image, LeadRectHelper.Empty, 0, new BarcodeSymbology[] { BarcodeSymbology.MicroPDF417 }, new IBarcodeReadOptions[] { options });
   if (barcodes == null)
   {
      Debug.WriteLine("No barcodes found");
      return;
   }

   Debug.WriteLine("{0} barcodes found:", barcodes.Length);
   foreach(BarcodeData barcode in barcodes)
   {
      Debug.WriteLine(" At {0} and data: {1}", barcode.Bounds, barcode.Value);
   }
}
public void MicroPDF417Barcode_Example(RasterImage image, Stream outStream)
{
   BarcodeEngine engine = new BarcodeEngine();
   // Create the image to write the barcodes to
   RasterCodecs codecs = new RasterCodecs();

   // Write two MicroPDF417 barcodes
   WriteBarcode(engine.Writer, image, "DATA1", MicroPDF417BarcodeSymbolSize.Smallest, true);
   WriteBarcode(engine.Writer, image, "DATA2", MicroPDF417BarcodeSymbolSize.Size44X4, false);

   // Save the image
   codecs.Save(image, outStream, RasterImageFormat.CcittGroup4, 1);

   // Now read the barcodes again
   ReadBarcodes(engine.Reader, image);
}

private void WriteBarcode(BarcodeWriter writer, RasterImage image, string value, MicroPDF417BarcodeSymbolSize symbolSize, bool topLeft)
{
   // Create the barcode data
   MicroPDF417BarcodeData barcode = new MicroPDF417BarcodeData();
   barcode.Value = value;
   barcode.DataCode = 0;

   // We will use the alignment to position the barcodes, so use all of the image
   barcode.Bounds = new LogicalRectangle(0, 0, image.ImageWidth, image.ImageHeight, LogicalUnit.Pixel);

   // Set the write options
   MicroPDF417BarcodeWriteOptions options = new MicroPDF417BarcodeWriteOptions();

   if(topLeft)
   {
      options.HorizontalAlignment = BarcodeAlignment.Near;
      options.VerticalAlignment = BarcodeAlignment.Near;
   }
   else
   {
      options.HorizontalAlignment = BarcodeAlignment.Far;
      options.VerticalAlignment = BarcodeAlignment.Far;
   }

   options.UseMode128Emulation = false;
   options.IsLinked = false;
   options.EnableGroupMode = false;
   options.XModule = 30;
   options.XModuleAspectRatio = 3;
   options.LimitByRowsAndColumns = true;
   options.SymbolSize = symbolSize;

   // Write it
   Console.WriteLine("Writing barcode with symbol size: {0} and Data: {1}", symbolSize, value);
   writer.WriteBarcode(image, barcode, options);
}

private void ReadBarcodes(BarcodeReader reader, RasterImage image)
{
   // Setup read options
   MicroPDF417BarcodeReadOptions options = new MicroPDF417BarcodeReadOptions();
   options.SearchDirection = BarcodeSearchDirection.Horizontal;
   options.EnableDoublePass = false;
   options.ReadMode = MicroPDF417BarcodeReadMode.Mode0;
   options.ReadOptionalMacroFileNameField = false;
   options.ReadOptionalMacroSegmentCountField = false;
   options.ReadOptionalMacroTimestampField = false;
   options.ReadOptionalMacroSenderField = false;
   options.ReadOptionalMacroAddresseeField = false;
   options.ReadOptionalMacroFileSizeField = false;
   options.ReadOptionalMacroChecksumField = false;
   options.ReadOptionalMacro79AndAZField = false;

   Console.WriteLine("Reading Barcodes");
   BarcodeData[] barcodes = reader.ReadBarcodes(image, LogicalRectangle.Empty, 0, new BarcodeSymbology[] { BarcodeSymbology.MicroPDF417 }, new BarcodeReadOptions[] { options });
   Console.WriteLine("{0} barcodes found:", barcodes.Length);
   foreach(MicroPDF417BarcodeData barcode in barcodes)
   {
      Console.WriteLine(" At {0} and data: {1}", barcode.Bounds, barcode.Value);
   }
}
Public Sub MicroPDF417Barcode_Example(ByVal image As RasterImage, ByVal outStream As Stream)
  Dim engine As BarcodeEngine = New BarcodeEngine()
  ' Create the image to write the barcodes to
  Dim codecs As RasterCodecs = New RasterCodecs()

  ' Write two MicroPDF417 barcodes
  WriteBarcode(engine.Writer, image, "DATA1", MicroPDF417BarcodeSymbolSize.Smallest, True)
  WriteBarcode(engine.Writer, image, "DATA2", MicroPDF417BarcodeSymbolSize.Size44X4, False)

  ' Save the image
  codecs.Save(image, outStream, RasterImageFormat.CcittGroup4, 1)

  ' Now read the barcodes again
  ReadBarcodes(engine.Reader, image)
End Sub

Private Sub WriteBarcode(ByVal writer As BarcodeWriter, ByVal image As RasterImage, ByVal value As String, ByVal symbolSize As MicroPDF417BarcodeSymbolSize, ByVal topLeft As Boolean)
  ' Create the barcode data
  Dim barcode As MicroPDF417BarcodeData = New MicroPDF417BarcodeData()
  barcode.Value = value
  barcode.DataCode = 0

  ' We will use the alignment to position the barcodes, so use all of the image
  barcode.Bounds = New LogicalRectangle(0, 0, image.ImageWidth, image.ImageHeight, LogicalUnit.Pixel)

  ' Set the write options
  Dim options As MicroPDF417BarcodeWriteOptions = New MicroPDF417BarcodeWriteOptions()

  If topLeft Then
    options.HorizontalAlignment = BarcodeAlignment.Near
    options.VerticalAlignment = BarcodeAlignment.Near
  Else
    options.HorizontalAlignment = BarcodeAlignment.Far
    options.VerticalAlignment = BarcodeAlignment.Far
  End If

  options.UseMode128Emulation = False
  options.IsLinked = False
  options.EnableGroupMode = False
  options.XModule = 30
  options.XModuleAspectRatio = 3
  options.LimitByRowsAndColumns = True
  options.SymbolSize = symbolSize

  ' Write it
  Console.WriteLine("Writing barcode with symbol size: {0} and Data: {1}", symbolSize, value)
  writer.WriteBarcode(image, barcode, options)
End Sub

Private Sub ReadBarcodes(ByVal reader As BarcodeReader, ByVal image As RasterImage)
  ' Setup read options
  Dim options As MicroPDF417BarcodeReadOptions = New MicroPDF417BarcodeReadOptions()
  options.SearchDirection = BarcodeSearchDirection.Horizontal
  options.EnableDoublePass = False
  options.ReadMode = MicroPDF417BarcodeReadMode.Mode0
  options.ReadOptionalMacroFileNameField = False
  options.ReadOptionalMacroSegmentCountField = False
  options.ReadOptionalMacroTimestampField = False
  options.ReadOptionalMacroSenderField = False
  options.ReadOptionalMacroAddresseeField = False
  options.ReadOptionalMacroFileSizeField = False
  options.ReadOptionalMacroChecksumField = False
  options.ReadOptionalMacro79AndAZField = False

  Console.WriteLine("Reading Barcodes")
  Dim barcodes As BarcodeData() = reader.ReadBarcodes(image, LogicalRectangle.Empty, 0, New BarcodeSymbology() { BarcodeSymbology.MicroPDF417 }, New BarcodeReadOptions() { options })
  Console.WriteLine("{0} barcodes found:", barcodes.Length)
  For Each barcode As MicroPDF417BarcodeData In barcodes
    Console.WriteLine(" At {0} and data: {1}", barcode.Bounds, barcode.Value)
  Next barcode
End Sub
Requirements

Target Platforms: Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

See Also

Reference

MicroPDF417BarcodeData Members
Leadtools.Barcode Namespace
BarcodeData Class
BarcodeReader Class
BarcodeWriter Class
BarcodeSymbology Enumeration
BarcodeEngine Class
DatamatrixBarcodeData Class
PDF417BarcodeData Class
QRBarcodeData Class
MicroPDF417BarcodeReadOptions Class
MicroPDF417BarcodeWriteOptions Class
BarcodeReader.ReadBarcode
BarcodeReader.ReadBarcodes
BarcodeWriter.WriteBarcode
Programming with LEADTOOLS Barcode
Supported Barcode Symbologies
Unlocking Barcode Support
Reading Barcodes Tutorial
Writing Barcodes Tutorial
MicroPDF417 Barcodes In LEADTOOLS
Writing Barcodes - Bounds and XModule

 

 


Products | Support | Contact Us | Copyright Notices

© 2006-2012 All Rights Reserved. LEAD Technologies, Inc.

Leadtools.Barcode requires a Barcode Module license and unlock key. For more information, refer to: LEADTOOLS Toolkit Features