public CodecsExtensionList ReadExtensions(
string fileName,
int pageNumber
)
Public Overloads Function ReadExtensions( _
ByVal fileName As String, _
ByVal pageNumber As Integer _
) As CodecsExtensionList
- (nullable LTCodecsExtensionList *)readExtensionsFromFile:(NSString *)file
pageNumber:(NSInteger)pageNumber
error:(NSError **)error
public:
CodecsExtensionList^ ReadExtensions(
String^ fileName,
int pageNumber
)
fileName
The input file name.
pageNumber
1-based index of the page within the file that contains the extension.
An CodecsExtensionList object that contains the extensions found in this file.
Please note that not all Exif files have extensions.
Currently, this method works only with Exif files. Exif files can contain extra data stored as "FlashPix extensions". This method can be used to access this extra data. LEADTOOLS refers to this extra data as "extensions".
You must dispose the CodecsExtensionList returned from this method when you are done using it.
This example will show detailed information on the streams present in the Exif file.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing;
using Leadtools.ImageProcessing.Color;
using Leadtools.Svg;
void ExtensionsExample(string exifFileName)
{
RasterCodecs codecs = new RasterCodecs();
string stampFileName = Path.Combine(LEAD_VARS.ImagesDir, "Extension.bmp");
string audioFileNameTemplate = Path.Combine(LEAD_VARS.ImagesDir, "Extension{0}.wav");
// Read the extensions from the file
Console.WriteLine("Reading the extensions from the exif file");
CodecsExtensionList extensionList = codecs.ReadExtensions(exifFileName, 1);
if (extensionList != null)
{
if ((extensionList.Flags & CodecsExtensionListFlags.Stamp) == CodecsExtensionListFlags.Stamp)
{
Console.WriteLine("Stamp extension: Found, saving to {0}", stampFileName);
RasterImage stampImage = extensionList.CreateStamp();
codecs.Save(stampImage, stampFileName, RasterImageFormat.Bmp, 24);
stampImage.Dispose();
}
else
Console.WriteLine("Stamp extension: Not found");
if ((extensionList.Flags & CodecsExtensionListFlags.Audio) == CodecsExtensionListFlags.Audio)
{
Console.WriteLine("Audio extension: Found, saving ...");
RasterNativeBuffer audioData;
int streamIndex = 0;
do
{
audioData = extensionList.GetAudioData(streamIndex);
if (audioData.Data != IntPtr.Zero)
{
string audioFileName = string.Format(audioFileNameTemplate, streamIndex);
Console.WriteLine("To {0}", audioFileName);
using (FileStream fs = File.Create(audioFileName))
{
byte[] data = new byte[audioData.Length];
Marshal.Copy(audioData.Data, data, 0, (int)audioData.Length);
fs.Write(data, 0, (int)audioData.Length);
}
streamIndex++;
}
}
while (audioData.Data != IntPtr.Zero);
Console.WriteLine("{0} total audio streams found", streamIndex);
}
else
Console.WriteLine("Audio extension: Not found");
CodecsExtension[] extensions = extensionList.GetExtensions();
Console.WriteLine("Total number of extensions found in the file: {0}", extensions.Length);
for (int i = 0; i < extensions.Length; i++)
{
CodecsExtension extension = extensions[i];
Console.WriteLine(" {0}. Name: {1}, Clsid: {2}, UCDefault: {3}, DatLength: {4}",
i, extension.Name, extension.Clsid, extension.UCDefault, extension.DataLength);
}
extensionList.Dispose();
}
else
Console.WriteLine("No extensions were found in the file");
codecs.Dispose();
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS21\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