Online Image Vectorizer
If you need to vectorize images, use our free online tool! Image Vectorizer supports JPEG, JPG, PJP, PJPEG, PNG, BMP, ICO, GIF, TIFF, WEBP, XBM and other bitmap formats. It offers various options for preprocessing bitmaps before saving them to SVG format. Convert your images into scalable and clear vector art just now!
PNG Image Vectorization
Image vectorization is the process of converting bitmap images into vector graphics – Bezier curves, splines, and lines. You may want to vectorize bitmaps for a number of reasons – scaling, small file size, animation support, etc., or you just want to experiment with images and get some fun vectorizing effects. Either way, bitmap vectorization is a good experience if you’re interested in photography, painting, design, art, and web development.
Aspose.SVG for .NET API offers a high-speed C# library that you can use for different SVG parsing tasks. The ImageVectorization Namespace includes classes and interfaces for implementing the image vectorization process. In this article, we’ll look at how to convert Image to vector graphics in C# or using an online Image Vectorizer.
How to use Image Vectorizer?
- First, load the raster image from a local file system in JPEG, JPG, PJP, PJPEG, WEBP, PNG, BMP, ICO, GIF, TIFF, XBM or other bitmap format. You will see three windows - Source Image, Quantized Image and Vectorized Image - with the preview of initial, color-quantized and vectorized images.
- Image Vectorizer converts PNG to vector with default settings and you can download vectorized PNG as an SVG file. But for getting a better result, you can handle the quantization and vectorization processes with two settings sidebars. Click “Quantize” button to apply quantization settings, click “Vectorize” button to apply vectorization settings and convert PNG to SVG.
- Click the “Download” button to get the resultant.
Image Vectorizer converts raster bitmap images into vector artwork constructed from outlines. The vectorization algorithm includes the next steps: color quantization, contour tracing, trace smoothing, trace simplification, and building SVG path elements from the traces. Apply custom settings to get the best PNG vectorization result.
Quantization Options
Color quantization is a process of selecting the limited number of colors to use in an image. It is applied when the color information of an image is to be reduced. Color quantization is a very complex process involving a number of factors. This can be implemented using different algorithms. Each of the algorithms determines which colors from the larger set of colors remain in the new image and how the discarded colors are mapped to the remaining ones.
- colors - desired palette size;
- method - histogram methods that implement various color quantization algorithms;
- minHueCols - is a parameter that works with color gradients;
- scale - or scaling factor - configurable for finer or coarser sampling of colors;
- grayscale - you can convert the image to grayscale by clicking the checkbox.
Vectorization Options
- threshold - is responsible for setting the number of pixels to mark the contour;
- severity - affects contours’ smoothing and determines the extent of the region considered by query point the Nearest Neighbor approach;
- line-width - affects lines’ width for marking the contours;
- stencil - turns an ordinary image or photo into an outline image that can be used as a stencil for graffiti-like effects;
- trace paths - you can view the points in a curve that are responsible for building path segments.
Vector graphics are the best for creating logos, icons, page layouts, maps, graphs, line arts, illustrations, technical drawings and more. It is not the most suitable format for continuous-tone images with blends of color or editing photographs. However, vectorizing photos can result in impressive artistic effects that can be interesting and useful.
How to vectorize PNG in C#
Aspose.SVG for the .NET API provides classes and methods that allow you to implement the image vectorization process and work with various pre-processing options for images before saving them in vector format. Processing involves controlling the following vectorization options: TraceSimplifier, TraceSmoother, PathBuilder, etc.
Convert PNG to SVG in C#
// Initialize an instance of the ImageVectorizer class
var vectorizer = new ImageVectorizer
{
//optionally set configuration
Configuration =
{
//optionally set path builder
PathBuilder = new BezierPathBuilder {
//optionally set trace smoother
TraceSmoother = new ImageTraceSmoother(1),
ErrorThreshold = 30,
MaxIterations = 30
},
ColorsLimit = 25,
LineWidth = 1
}
};
// Vectorize PNG from the specified file
using var document = vectorizer.Vectorize(InputFolder + "image.png");
// Save vectorized PNG as SVG file
document.Save(OutputFolder + "image.svg");
Steps to Convert PNG to SVG in C#
To vectorize PNG image with Aspose.SVG, you should follow a few steps:
- Initialize an instance of the
ImageVectorizer
class. Use one of ImageVectorizer() constructors and specify configuration properties.
- TraceSmoother property sets the trace smoother. It is used to smooth out fragments of contours.
- TraceSimplifier property sets the trace simplified. As a result, the trace curve will be built composed of line segments with fewer (or bigger) points.
- PathBuilder property sets the SVG path segments builder and affects how sharply the curve bends at the control points.
- Vectorize PNG from the specified file. The Vectorize() method takes the path to the image file and returns an SVGDocument.
- Save the vectorized PNG to SVG. Use the Save() method and pass to it the output path.
In the documentation chapter Vectorization – Basic Overview , you will find image vectorization info, a description of the image vectorization process and vectorization options, learn how to vectorize raster images such as PNG, JPG, BMP, TIFF, GIF, ICO into an SVG document. You will consider a few C# examples that demonstrate the ImageVectorization functionalities and the effect of configuration properties on the vectorization result.
FAQ
Aspose.SVG allows you to convert PNG to SVG in any way – online or programmatically. For example, you can vectorize PNG in real-time using Online Image Vectorizer that converts your images quickly and with high quality. On other hand, you can use Aspose.SVG to vectorize PNG programmatically.
The process of image conversion from raster to vector is called image vectorization. It is a complex computational process that converts a bitmap image made up of pixels into a vector image made up of lines, curves, and other geometric shapes.
Vector images are essential for any professional who works with drawings, graphics, or sketches. Many designers, printers, architects, and artists often choose to work with sketches or drawings as vector images. And they have good reasons! Unlike bitmap graphics, vector arts are resizable and scalable without losing any quality, and they will still display just as clearly. Also, vectorization can be used to update or recover images.
Vector images are what you need to produce banners, logos, maps, signs, embroideries, engravings, graphs, blueprints, etc.
The vectorization process uses color image quantization – a technique that reduces the number of different colors used in an image, intending that the new image should be as visually similar as possible to the original one. Then, the Vectorizer replaces all the same colored spots or pixels with geometric shapes or curves using a set of contour tracing algorithms. The final step is to convert the tracing points to SVG path lines and Bezier curves and add them to the SVG document.
What is PNG File Format?
PNG (Portable Network Graphics) refers to a type of raster image file format that uses lossless compression. This file format was created as a replacement for Graphics Interchange Format (GIF) and has no copyright limitations. However, the PNG file format does not support animations. PNG file format supports lossless image compression that makes it popular among its users. With the passage of time, PNG has evolved into one of the most used image file formats. Almost all Operating Systems have support for opening PNG files. For example, Microsoft Windows viewer has the capability to open PNG files as the OS has by default the support available as part of the installation.
What is SVG File Format?
SVG files are Scalable Vector Graphics Files that use XML-based text format to describe an image’s appearance. In an SVG file, images are described as geometric primitives: lines, curves, shapes, text, etc. Vector objects are built and stored as a set of commands, numbers, formulas, and not in a pixel grid, as in bitmap images. The word Scalable refers to the fact that SVG can be scaled to different sizes without losing any quality. A text-based description of such files makes them independent of resolution. It is one of the most used formats for website building and print graphics to achieve scalability. SVG files can be viewed/opened in almost all modern browsers including Chrome, Internet Explorer, Firefox, and Safari.
Get Started with Aspose.SVG for .NET API
If you are interested in developing scalable vector graphics and their application, install our flexible, high-speed Aspose.SVG for .NET API with a powerful set of interfaces for C# and other .NET programming languages.Install from command line as
nuget install Aspose.SVG
or via Package Manager Console of Visual Studio with Install-Package Aspose.SVG
.
Alternatively, get the offline MSI installer or DLLs in a ZIP file from
downloads.
Aspose.SVG for .NET API is a standalone library and does not depend on any software for SVG document processing.For more details about C# library installation and system requirements, please refer to Aspose.SVG Documentation.