public class CodecsVectorLoadOptions
@interface LTCodecsVectorLoadOptions : NSObject
public class CodecsVectorLoadOptions
public ref class CodecsVectorLoadOptions
class CodecsVectorLoadOptions:
LEADTOOLS provides support for loading a vector image as a raster image. Vector formats such as DXF, DWG and SVG can be converted to a raster image through a process called rasterization.
Rasterization is the process of converting a vector image to a raster image. To determine whether a certain file on disk (or in a .NET stream) contains a vector image file rather than a regular raster image, call the RasterCodecs.GetInformation or RasterCodecs.GetInformationAsync method and check the CodecsVectorImageInfo.IsVectorFile property. Here is a code snippet:
CodecsImageInfo imageInfo = rasterCodecsInstance.GetInformation(fileName, true);
if(imageInfo.Vector.IsVectorFile)
{
// A vector image file (DXF, DWG, SVG, etc)
Console.WriteLine("Vector file");
// Your code specific to working with a vector image goes here
}
To rasterize a vector image file, set the properties of the CodecsVectorLoadOptions to the desired values, and then call the RasterCodecs.Load or RasterCodecs.LoadAsync methods.
A vector image file format usually does not have a physical size. The user can specify a viewport (physical size up to which the drawing can be rendered) ViewWidth and ViewHeight. How the drawing is to be rendered inside this viewport depends on the current viewport mode set with ViewMode. Default viewport size is 640x480 pixels.
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing.Core;
using Leadtools.Pdf;
public void CodecsVectorLoadOptionsExample()
{
RasterCodecs codecs = new RasterCodecs();
string srcFileName = Path.Combine(LEAD_VARS.ImagesDir, "random.dxf");
//Check if it is a vector file
CodecsImageInfo info = codecs.GetInformation(srcFileName, false);
Debug.WriteLine($"Is {srcFileName} a vector file? : {info.Vector.IsVectorFile}");
Debug.WriteLine($"Units: {info.Vector.Unit}");
//Parallelogram data
CodecsVectorImageInfo codecsVectorImageInfo = info.Vector;
Debug.WriteLine($"Parallelogram Max X: {codecsVectorImageInfo.ParallelogramMaxX}");
Debug.WriteLine($"Parallelogram Max Y: {codecsVectorImageInfo.ParallelogramMaxY}");
Debug.WriteLine($"Parallelogram Max Z: {codecsVectorImageInfo.ParallelogramMaxZ}");
Debug.WriteLine($"Parallelogram Min X: {codecsVectorImageInfo.ParallelogramMinX}");
Debug.WriteLine($"Parallelogram Min Y: {codecsVectorImageInfo.ParallelogramMinY}");
Debug.WriteLine($"Parallelogram Min Z: {codecsVectorImageInfo.ParallelogramMinZ}");
// Set the vector load options
// CodecsVectorOptions & CodecsVectorLoadOptions reference
codecs.Options.Vector.Load.BackgroundColor = new RasterColor(255, 255, 255);
codecs.Options.Vector.Load.BitsPerPixel = 24;
codecs.Options.Vector.Load.ForceBackgroundColor = true;
codecs.Options.Vector.Load.ViewWidth = 800;
codecs.Options.Vector.Load.ViewHeight = 800;
codecs.Options.Vector.Load.ViewMode = CodecsVectorViewMode.UseBest;
// Load the image
RasterImage image = codecs.Load(srcFileName);
// do something with the image here
// Clean up
image.Dispose();
codecs.Dispose();
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";
}
import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.nio.file.Paths;
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.imageprocessing.core.MinMaxBitsCommand;
public void codecsVectorLoadOptionsExample() {
final String LEAD_VARS_IMAGES_DIR = "C:\\LEADTOOLS23\\Resources\\Images";
RasterCodecs codecs = new RasterCodecs();
String srcFileName = combine(LEAD_VARS_IMAGES_DIR, "random.dxf");
String outputFileName = combine(LEAD_VARS_IMAGES_DIR, "Result.jpg");
// Check if it is a vector file
CodecsImageInfo info = codecs.getInformation(srcFileName, false);
System.out.println("Is {srcFileName} a vector file? : {info.Vector.IsVectorFile}");
System.out.println("Units: {info.Vector.Unit}");
// Parallelogram data
CodecsVectorImageInfo codecsVectorImageInfo = info.getVector();
System.out.println("Parallelogram Max X: " + codecsVectorImageInfo.getParallelogramMaxX());
System.out.println("Parallelogram Max Y: " + codecsVectorImageInfo.getParallelogramMaxY());
System.out.println("Parallelogram Max Z: " + codecsVectorImageInfo.getParallelogramMaxZ());
System.out.println("Parallelogram Min X: " + codecsVectorImageInfo.getParallelogramMinX());
System.out.println("Parallelogram Min Y: " + codecsVectorImageInfo.getParallelogramMinY());
System.out.println("Parallelogram Min Z: " + codecsVectorImageInfo.getParallelogramMinZ());
// Set the vector load options
// CodecsVectorOptions & CodecsVectorLoadOptions reference
codecs.getOptions().getVector().getLoad().setBackgroundColor(new RasterColor(255, 255, 255));
codecs.getOptions().getVector().getLoad().setBitsPerPixel(24);
codecs.getOptions().getVector().getLoad().setForceBackgroundColor(true);
codecs.getOptions().getVector().getLoad().setViewWidth(800);
codecs.getOptions().getVector().getLoad().setViewHeight(800);
codecs.getOptions().getVector().getLoad().setViewMode(CodecsVectorViewMode.UseBest);
// Load the image
RasterImage image = codecs.load(srcFileName);
codecs.save(image, outputFileName, RasterImageFormat.JPEG, 0);
// do something with the image here
assertTrue("File saved to " + outputFileName, (new File(outputFileName)).exists());
System.out.printf("File successfully saved to %s%n", outputFileName);
// Clean up
image.dispose();
codecs.dispose();
}
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