public SeekOrigin Origin { get; }
public LeadSeekOrigin getOrigin()
public:
property SeekOrigin Origin {
SeekOrigin get();
}
Origin # get (CodecsRedirectSeekEventArgs)
A SeekOrigin value indicating the reference point used to obtain the new position.
If Offset is negative, the new position is required to precede the position specified by Origin by the number of bytes specified by Offset. If Offset is zero (0), the new position is required to be the position specified by Origin. If Offset is positive, the new position is required to follow the position specified by Origin by the number of bytes specified by Offset.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing;
using Leadtools.ImageProcessing.Color;
using Leadtools.Svg;
// Redirect Read event example
FileStream myStream;
// Redirect Open event example
private void Codecs_Open(object sender, CodecsRedirectOpenEventArgs e)
{
myStream = new FileStream(e.FileName, e.Mode);
Console.WriteLine("Access: {0}, Share: {1}", e.Access, e.Share);
e.Success = true;
}
// Redirect Seek event example
private void Codecs_Seek(object sender, CodecsRedirectSeekEventArgs e)
{
myStream.Seek(e.Offset, e.Origin);
e.Offset = myStream.Position;
}
// Redirect Read event example
private void Codecs_Read(object sender, CodecsRedirectReadEventArgs e)
{
byte[] byteBuffer = new byte[e.Count];
myStream.Read(byteBuffer, 0, e.Count);
Marshal.Copy(byteBuffer, 0, e.Buffer, e.Count);
e.Read = e.Count;
Debug.WriteLine("The number of bytes that read request should copy to the buffer is : {0}", e.Count);
Debug.WriteLine("The actual number of bytes that this read request has copied to Buffer is : {0}", e.Read);
}
// Redirect Write event example
private void Codecs_Write(object sender, CodecsRedirectWriteEventArgs e)
{
byte[] byteBuffer = new byte[e.Count];
Marshal.Copy(e.Buffer, byteBuffer, 0, e.Count);
myStream.Write(byteBuffer, 0, e.Count);
e.Written = e.Count;
Debug.WriteLine("The number of bytes that write request should copy from the buffer is : {0}", e.Count);
Debug.WriteLine("The actual number of bytes that this write request has copied from Buffer is : {0}", e.Written);
}
// Redirect Close event example
private void Codecs_Close(object sender, CodecsRedirectCloseEventArgs e)
{
myStream.Close();
}
public void StartRedirectingExample()
{
RasterCodecs codecs = new RasterCodecs();
codecs.RedirectOpen += new EventHandler<CodecsRedirectOpenEventArgs>(Codecs_Open);
codecs.RedirectSeek += new EventHandler<CodecsRedirectSeekEventArgs>(Codecs_Seek);
codecs.RedirectRead += new EventHandler<CodecsRedirectReadEventArgs>(Codecs_Read);
codecs.RedirectWrite += new EventHandler<CodecsRedirectWriteEventArgs>(Codecs_Write);
codecs.RedirectClose += new EventHandler<CodecsRedirectCloseEventArgs>(Codecs_Close);
string srcFilename = Path.Combine(LEAD_VARS.ImagesDir, "test_image1.cmp");
codecs.StartRedirecting();
RasterImage image = codecs.Load(srcFilename);
myStream.Close();
codecs.Save(image, Path.Combine(LEAD_VARS.ImagesDir, "Image1_redirect.jpg"), RasterImageFormat.Jpeg, image.BitsPerPixel);
codecs.StopRedirecting();
// Clean up
myStream.Dispose();
image.Dispose();
codecs.Dispose();
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS22\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