public event EventHandler<CodecsLoadInformationEventArgs> LoadInformation synchronized public void addLoadInformationListener(CodecsLoadInformationListener listener)synchronized public void removeLoadInformationListener(CodecsLoadInformationListener listener)
public:event EventHandler<CodecsLoadInformationEventArgs^>^ LoadInformation
def LoadInformation(sender,e): # sender: RasterCodecs e: CodecsLoadInformationEventArgs The event handler receives an argument of type CodecsLoadInformationEventArgs containing data related to this event. The following CodecsLoadInformationEventArgs properties provide information specific to this event.
| Property | Description |
|---|---|
| BitsPerPixel | Gets or sets the bits per pixel of the image data in the file. |
| Format | Gets the image file format. |
| Height | Gets or sets the image height in pixels. |
| LeastSignificantBitFirst | Gets or sets a value specifying whether the image data was saved with least significant bit first or last. |
| MotorolaOrder | Gets or sets a value that determines whether image data is in Motorola byte order. |
| Offset | Gets or sets the position of the first byte of image data. |
| Order | Gets or sets the byte order for the load process. |
| Pad4 | Gets or sets a value indicating whether the image data was saved padded to 4-byte boundary. |
| PhotoInterpolation | Gets or sets the photometric interpolation for the load process. |
| PlanarConfiguration | Gets or sets the planar configuration. |
| Reverse | Gets or sets a value that determines whether each line is reversed (mirrored). |
| Signed | Gets or sets a value that determines whether the image data is signed. |
| Stream | Gets the stream used by the load process. |
| StripSize | Gets or sets the size of the data strip before it is decompressed. |
| ViewPerspective | Gets or sets the view perspective for the load process. |
| WhiteOnBlack | Gets or sets a value that determines if the image is black-on-white or white on black. |
| Width | Gets or sets the image width in pixels. |
| XResolution | Gets or sets the horizontal resolution for rendering the image, specified in dots per inch. |
| YResolution | Gets or sets the vertical resolution for rendering the image, specified in dots per inch. |
The LoadInformation event will occur when LEADTOOLS cannot recognize the image file format during a call to GetInformation or GetInformationAsync. This event can be used for loading raw FAX data (CCITT Group 3 or Group 4), raw run-length-encoded data (4-bit or 8-bit), raw Bitfield compressed data, raw PackBits compressed data or raw uncompressed data.
To load a raw fax file, you must subscribe to this event first. When the toolkit fails to recognize the image file format, it will fire this event. If you know the size of the fax image, then set the values in the CodecsLoadInformationEventArgs.Width and CodecsLoadInformationEventArgs.Height properties of the CodecsLoadInformationEventArgs passed as the event data. To automatically detect the width and height of the fax file, set CodecsLoadInformationEventArgs.Width and CodecsLoadInformationEventArgs.Height to -1.
To load raw uncompressed data, you must subscribe to this event first. When the toolkit fails to recognize the image file format, it will fire this event. Set the CodecsLoadInformationEventArgs.Format property to RasterImageFormat.Raw. Valid values must also be set for the following properties:
If each line of RAW data is padded so that the number of bytes is a multiple of 4 (as is the case with raw Windows BMP data), set CodecsLoadInformationEventArgs.Pad4 to true. Include an orientation in the CodecsLoadInformationEventArgs.ViewPerspective to load with the proper orientation. For example, raw Windows BMP data is stored with a RasterViewPerspective.BottomLeft orientation. If the orientation is unknown, then set it to RasterViewPerspective.BottomLeft. If the raw data is 8 bits per pixel or less, then the image is palettized and a palette must be generated. If this is the case, pass in a valid palette with 1 << bits/pixel (2 ^ BitsPerPixel) number of entries to the CodecsLoadInformationEventArgs.SetPalette method.
Set the correct color order in the CodecsLoadInformationEventArgs.Order property. For example, if the order of the data is BGR, then set this value to RasterByteOrder.Bgr.
For more information, refer to CodecsLoadInformationEventArgs.
This example demonstrates saving and loading raw/headerless image files.
using Leadtools;using Leadtools.Codecs;using Leadtools.ImageProcessing;using Leadtools.ImageProcessing.Color;using Leadtools.Svg;private struct RawData{public int Width; // Width of imagepublic int Height; // Height of imagepublic int BitsPerPixel; // Bits per pixel of image--if palettized, a gray palette is generatedpublic RasterViewPerspective ViewPerspective; // View perspective of raw data (TopLeft, BottomLeft, etc)public RasterByteOrder Order; // Rgb or Bgrpublic int XResolution; // Horizontal resolution in DPIpublic int YResolution; // Vertical resolution in DPIpublic int Offset; // Offset into file where raw data beginspublic bool Padding; // true if each line of data is padded to four bytespublic bool ReverseBits; // true if the bits of each byte are reversed}private RawData myRawData;private void codecs_LoadInformation(object sender, CodecsLoadInformationEventArgs e){// Set the informatione.Format = RasterImageFormat.Raw;e.Width = myRawData.Width;e.Height = myRawData.Height;e.BitsPerPixel = myRawData.BitsPerPixel;e.XResolution = myRawData.XResolution;e.YResolution = myRawData.YResolution;e.Offset = myRawData.Offset;e.MotorolaOrder = false;e.PhotoInterpolation = CodecsPhotoInterpolation.WhiteIsZero;e.PlanarConfiguration = CodecsPlanarConfiguration.PlanarFormat; // This value is used only if Format is RasterImageFormat.RawPackBitse.Reverse = true;e.StripSize = 10;e.WhiteOnBlack = false;e.GetPalette();Debug.WriteLine($"Stream: {e.Stream.ToString()}");if (myRawData.Padding)e.Pad4 = true;e.Order = myRawData.Order;if (myRawData.ReverseBits)e.LeastSignificantBitFirst = true;e.ViewPerspective = myRawData.ViewPerspective;// If image is palettized create a grayscale paletteif (e.BitsPerPixel <= 8){int colors = 1 << e.BitsPerPixel;RasterColor[] palette = new RasterColor[colors];for (int i = 0; i < palette.Length; i++){byte val = (byte)((i * 255) / (colors - 1));palette[i] = new RasterColor(val, val, val);}e.SetColorMask(palette);e.SetPalette(palette);}}public void LoadInformationExample(){// First, load a JPEG or CMP filestring srcFilename = Path.Combine(LEAD_VARS.ImagesDir, "IMAGE2.CMP");string rawFileName = Path.Combine(LEAD_VARS.ImagesDir, "Image1.raw");RasterCodecs codecs = new RasterCodecs();RasterImage image = codecs.Load(srcFilename);// Save this image as RAW data// Set RAW optionscodecs.Options.Raw.Save.Pad4 = true;codecs.Options.Raw.Save.ReverseBits = true;codecs.Options.Save.OptimizedPalette = true;codecs.Save(image, rawFileName, RasterImageFormat.Raw, 0);// Save information about this image so we can use it to load the RAW filemyRawData = new RawData();myRawData.Width = image.Width;myRawData.Height = image.Height;myRawData.BitsPerPixel = image.BitsPerPixel;myRawData.ViewPerspective = image.ViewPerspective;myRawData.Order = image.Order;myRawData.XResolution = image.XResolution;myRawData.YResolution = image.YResolution;myRawData.Offset = 0;myRawData.Padding = true;myRawData.ReverseBits = true;// We dont need the image anymoreimage.Dispose();// Now load this RAW image back// First subscribe to the LoadInformation event so we can set the image informationcodecs.LoadInformation += new EventHandler<CodecsLoadInformationEventArgs>(codecs_LoadInformation);// Load the imageimage = codecs.Load(rawFileName);// Unsubscribe from the eventcodecs.LoadInformation -= new EventHandler<CodecsLoadInformationEventArgs>(codecs_LoadInformation);// save it as bmp for testingcodecs.Save(image, Path.Combine(LEAD_VARS.ImagesDir, "Image1_raw.bmp"), RasterImageFormat.Bmp, 0);// Clean upimage.Dispose();codecs.Dispose();}static class LEAD_VARS{public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";}
import java.io.*;import java.net.*;import java.nio.file.Paths;import java.util.*;import java.time.Instant;import java.time.Duration;import org.junit.*;import org.junit.runner.JUnitCore;import org.junit.runner.Result;import org.junit.runner.notification.Failure;import static org.junit.Assert.*;import leadtools.*;import leadtools.codecs.*;import leadtools.codecs.RasterCodecs.FeedCallbackThunk;import leadtools.drawing.internal.*;import leadtools.imageprocessing.*;import leadtools.imageprocessing.color.ChangeIntensityCommand;import leadtools.svg.*;private class RawData {public int Width; // Width of imagepublic int Height; // Height of imagepublic int BitsPerPixel; // Bits per pixel of image--if palettized, a gray palette is generatedpublic RasterViewPerspective ViewPerspective; // View perspective of raw data (TopLeft, BottomLeft, etc)public RasterByteOrder Order; // Rgb or Bgrpublic int XResolution; // Horizontal resolution in DPIpublic int YResolution; // Vertical resolution in DPIpublic int Offset; // Offset into file where raw data beginspublic boolean Padding; // true if each line of data is padded to four bytespublic boolean ReverseBits; // true if the bits of each byte are reversed}private RawData myRawData;CodecsLoadInformationListener codecsLoadInformation = new CodecsLoadInformationListener() {@Overridepublic void onLoadInformation(CodecsLoadInformationEvent e) {// Set the informatione.setFormat(RasterImageFormat.RAW);e.setWidth(myRawData.Width);e.setHeight(myRawData.Height);e.setBitsPerPixel(myRawData.BitsPerPixel);e.setXResolution(myRawData.XResolution);e.setYResolution(myRawData.YResolution);e.setOffset(myRawData.Offset);e.setMotorolaOrder(false);e.setPhotoInterpolation(CodecsPhotoInterpolation.WHITE_IS_ZERO);e.setPlanarConfiguration(CodecsPlanarConfiguration.PLANAR_FORMAT); // This value is used only if Format is// RasterImageFormat.RawPackBitse.setReverse(true);e.setStripSize(10);e.setWhiteOnBlack(false);e.getPalette();System.out.println("Stream: " + e.getStream().toString());if (myRawData.Padding)e.setPad4(true);e.setOrder(myRawData.Order);if (myRawData.ReverseBits)e.setLeastSignificantBitFirst(true);e.setViewPerspective(myRawData.ViewPerspective);// If image is palettized create a grayscale paletteif (e.getBitsPerPixel() <= 8) {int colors = 1 << e.getBitsPerPixel();RasterColor[] palette = new RasterColor[colors];int[] mask = new int[colors];for (int i = 0; i < palette.length; i++) {byte val = (byte) ((i * 255) / (colors - 1));palette[i] = new RasterColor(val, val, val);mask[i] = val;}e.setColorMask(mask);e.setPalette(palette);}}};public void loadInformationExample() {final String LEAD_VARS_IMAGES_DIR = "C:\\LEADTOOLS23\\Resources\\Images";// First, load a JPEG or CMP fileString srcFileName = combine(LEAD_VARS_IMAGES_DIR, "Image2.cmp");String rawFileName = combine(LEAD_VARS_IMAGES_DIR, "Image1.raw");RasterCodecs codecs = new RasterCodecs();RasterImage image = codecs.load(srcFileName);// Set RAW optionscodecs.getOptions().getRaw().getSave().setPad4(true);codecs.getOptions().getRaw().getSave().setReverseBits(true);codecs.getOptions().getSave().setOptimizedPalette(true);// Save this image as RAW datacodecs.save(image, rawFileName, RasterImageFormat.RAW, 0);assertTrue("File unsuccessfully saved", (new File(rawFileName)).exists());System.out.println("File successfully saved to: " + rawFileName);// Save information about this image so we can use it to load the RAW filemyRawData = new RawData();myRawData.Width = image.getWidth();myRawData.Height = image.getHeight();myRawData.BitsPerPixel = image.getBitsPerPixel();myRawData.ViewPerspective = image.getViewPerspective();myRawData.Order = image.getOrder();myRawData.XResolution = image.getXResolution();myRawData.YResolution = image.getYResolution();myRawData.Offset = 0;myRawData.Padding = true;myRawData.ReverseBits = true;// We dont need the image anymoreimage.dispose();// Now load this RAW image back// First subscribe to the LoadInformation event so we can set the image// informationcodecs.addLoadInformationListener(codecsLoadInformation2);// Load the imageILeadStream rawFileStream = LeadStreamFactory.create(rawFileName);image = codecs.load(rawFileStream);// Unsubscribe from the eventcodecs.removeLoadInformationListener(codecsLoadInformation2);// save it as bmp for testingcodecs.save(image, combine(LEAD_VARS_IMAGES_DIR, "Image1_raw.bmp"), RasterImageFormat.BMP, 0);assertTrue("RasterImage unsuccessfully saved to" + combine(LEAD_VARS_IMAGES_DIR, "Image1_raw.bmp"),(new File(combine(LEAD_VARS_IMAGES_DIR, "Image1_raw.bmp"))).exists());System.out.println("RasterImage saved to" + combine(LEAD_VARS_IMAGES_DIR, "Image1_raw.bmp"));// Clean upimage.dispose();codecs.dispose();}CodecsLoadInformationListener codecsLoadInformation2 = new CodecsLoadInformationListener() {@Overridepublic void onLoadInformation(CodecsLoadInformationEvent e) {// Set the informatione.setFormat(RasterImageFormat.RAW);e.setWidth(myRawData.Width);e.setHeight(myRawData.Height);e.setBitsPerPixel(myRawData.BitsPerPixel);e.setXResolution(myRawData.XResolution);e.setYResolution(myRawData.YResolution);e.setOffset(myRawData.Offset);e.setMotorolaOrder(false);e.setPhotoInterpolation(CodecsPhotoInterpolation.WHITE_IS_ZERO);e.setPlanarConfiguration(CodecsPlanarConfiguration.PLANAR_FORMAT); // This value is used only if Format is// RasterImageFormat.RawPackBitse.setReverse(true);e.setStripSize(10);e.setWhiteOnBlack(false);e.getPalette();System.out.println("Stream: " + e.getStream());if (myRawData.Padding)e.setPad4(true);e.setOrder(myRawData.Order);if (myRawData.ReverseBits)e.setLeastSignificantBitFirst(true);e.setViewPerspective(myRawData.ViewPerspective);// If image is palettized create a grayscale paletteif (e.getBitsPerPixel() <= 8) {int colors = 1 << e.getBitsPerPixel();RasterColor[] palette = new RasterColor[colors];int[] mask = new int[colors];for (int i = 0; i < palette.length; i++) {byte val = (byte) ((i * 255) / (colors - 1));palette[i] = new RasterColor(val, val, val);mask[i] = val;}e.setColorMask(mask);e.setPalette(palette);}}};
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
