All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lwjgl.nanovg.NanoSVG Maven / Gradle / Ivy

Go to download

A small antialiased vector graphics rendering library for OpenGL. Also includes NanoSVG, a simple SVG parser.

There is a newer version: 3.3.5
Show newest version
/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.nanovg;

import org.jspecify.annotations.*;

import java.nio.*;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;
import static org.lwjgl.system.MemoryStack.*;
import static org.lwjgl.system.MemoryUtil.*;

/**
 * NanoSVG is a simple stupid single-header-file SVG parse. The output of the parser is a list of cubic bezier shapes.
 * 
 * 

The library suits well for anything from rendering scalable icons in your editor application to prototyping a game.

* *

NanoSVG supports a wide range of SVG features, but something may be missing, feel free to create a pull request!

* *

The shapes in the SVG images are transformed by the viewBox and converted to specified units. That is, you should get the same looking data as your * designed in your favorite app.

* *

NanoSVG can return the paths in few different units. For example if you want to render an image, you may choose to get the paths in pixels, or if you * are feeding the data into a CNC-cutter, you may want to use millimeters.

* *

The units passed to NanoSVG should be one of: 'px', 'pt', 'pc' 'mm', 'cm', or 'in'. DPI (dots-per-inch) controls how the unit conversion is done.

* *

If you don't know or care about the units stuff, "px" and 96 should get you going.

*/ public class NanoSVG { static { LibNanoVG.initialize(); } /** * NSVGpaintType * *
Enum values:
* *
    *
  • {@link #NSVG_PAINT_UNDEF PAINT_UNDEF}
  • *
  • {@link #NSVG_PAINT_NONE PAINT_NONE}
  • *
  • {@link #NSVG_PAINT_COLOR PAINT_COLOR}
  • *
  • {@link #NSVG_PAINT_LINEAR_GRADIENT PAINT_LINEAR_GRADIENT}
  • *
  • {@link #NSVG_PAINT_RADIAL_GRADIENT PAINT_RADIAL_GRADIENT}
  • *
*/ public static final int NSVG_PAINT_UNDEF = -1, NSVG_PAINT_NONE = 0, NSVG_PAINT_COLOR = 1, NSVG_PAINT_LINEAR_GRADIENT = 2, NSVG_PAINT_RADIAL_GRADIENT = 3; /** * NSVGspreadType * *
Enum values:
* *
    *
  • {@link #NSVG_SPREAD_PAD SPREAD_PAD}
  • *
  • {@link #NSVG_SPREAD_REFLECT SPREAD_REFLECT}
  • *
  • {@link #NSVG_SPREAD_REPEAT SPREAD_REPEAT}
  • *
*/ public static final int NSVG_SPREAD_PAD = 0, NSVG_SPREAD_REFLECT = 1, NSVG_SPREAD_REPEAT = 2; /** * NSVGlineJoin * *
Enum values:
* *
    *
  • {@link #NSVG_JOIN_MITER JOIN_MITER}
  • *
  • {@link #NSVG_JOIN_ROUND JOIN_ROUND}
  • *
  • {@link #NSVG_JOIN_BEVEL JOIN_BEVEL}
  • *
*/ public static final int NSVG_JOIN_MITER = 0, NSVG_JOIN_ROUND = 1, NSVG_JOIN_BEVEL = 2; /** * NSVGlineCap * *
Enum values:
* *
    *
  • {@link #NSVG_CAP_BUTT CAP_BUTT}
  • *
  • {@link #NSVG_CAP_ROUND CAP_ROUND}
  • *
  • {@link #NSVG_CAP_SQUARE CAP_SQUARE}
  • *
*/ public static final int NSVG_CAP_BUTT = 0, NSVG_CAP_ROUND = 1, NSVG_CAP_SQUARE = 2; /** * NSVGfillRule * *
Enum values:
* *
    *
  • {@link #NSVG_FILLRULE_NONZERO FILLRULE_NONZERO}
  • *
  • {@link #NSVG_FILLRULE_EVENODD FILLRULE_EVENODD}
  • *
*/ public static final int NSVG_FILLRULE_NONZERO = 0, NSVG_FILLRULE_EVENODD = 1; /** NSVGflags */ public static final int NSVG_FLAGS_VISIBLE = 0x01; protected NanoSVG() { throw new UnsupportedOperationException(); } // --- [ nsvgParseFromFile ] --- /** Unsafe version of: {@link #nsvgParseFromFile ParseFromFile} */ public static native long nnsvgParseFromFile(long filename, long units, float dpi); /** Parses SVG file from a file, returns SVG image as paths. */ @NativeType("NSVGimage *") public static @Nullable NSVGImage nsvgParseFromFile(@NativeType("char const *") ByteBuffer filename, @NativeType("char const *") ByteBuffer units, float dpi) { if (CHECKS) { checkNT1(filename); checkNT1(units); } long __result = nnsvgParseFromFile(memAddress(filename), memAddress(units), dpi); return NSVGImage.createSafe(__result); } /** Parses SVG file from a file, returns SVG image as paths. */ @NativeType("NSVGimage *") public static @Nullable NSVGImage nsvgParseFromFile(@NativeType("char const *") CharSequence filename, @NativeType("char const *") CharSequence units, float dpi) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nASCII(filename, true); long filenameEncoded = stack.getPointerAddress(); stack.nASCII(units, true); long unitsEncoded = stack.getPointerAddress(); long __result = nnsvgParseFromFile(filenameEncoded, unitsEncoded, dpi); return NSVGImage.createSafe(__result); } finally { stack.setPointer(stackPointer); } } // --- [ nsvgParse ] --- /** Unsafe version of: {@link #nsvgParse Parse} */ public static native long nnsvgParse(long input, long units, float dpi); /** * Parses SVG file from a null terminated string, returns SVG image as paths. * *

Important note: changes the string.

*/ @NativeType("NSVGimage *") public static @Nullable NSVGImage nsvgParse(@NativeType("char *") ByteBuffer input, @NativeType("char const *") ByteBuffer units, float dpi) { if (CHECKS) { checkNT1(input); checkNT1(units); } long __result = nnsvgParse(memAddress(input), memAddress(units), dpi); return NSVGImage.createSafe(__result); } /** * Parses SVG file from a null terminated string, returns SVG image as paths. * *

Important note: changes the string.

*/ @NativeType("NSVGimage *") public static @Nullable NSVGImage nsvgParse(@NativeType("char *") CharSequence input, @NativeType("char const *") CharSequence units, float dpi) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nASCII(input, true); long inputEncoded = stack.getPointerAddress(); stack.nASCII(units, true); long unitsEncoded = stack.getPointerAddress(); long __result = nnsvgParse(inputEncoded, unitsEncoded, dpi); return NSVGImage.createSafe(__result); } finally { stack.setPointer(stackPointer); } } // --- [ nsvgDuplicatePath ] --- /** Unsafe version of: {@link #nsvgDuplicatePath DuplicatePath} */ public static native long nnsvgDuplicatePath(long p); /** Duplicates a path. */ @NativeType("NSVGpath *") public static @Nullable NSVGPath nsvgDuplicatePath(@NativeType("NSVGpath *") NSVGPath p) { long __result = nnsvgDuplicatePath(p.address()); return NSVGPath.createSafe(__result); } // --- [ nsvgDelete ] --- /** Unsafe version of: {@link #nsvgDelete Delete} */ public static native void nnsvgDelete(long image); /** Deletes an image. */ public static void nsvgDelete(@NativeType("NSVGimage *") NSVGImage image) { nnsvgDelete(image.address()); } // --- [ nsvgCreateRasterizer ] --- /** Allocates rasterizer context. */ @NativeType("NSVGrasterizer *") public static native long nsvgCreateRasterizer(); // --- [ nsvgRasterize ] --- /** Unsafe version of: {@link #nsvgRasterize Rasterize} */ public static native void nnsvgRasterize(long r, long image, float tx, float ty, float scale, long dst, int w, int h, int stride); /** * Rasterizes SVG image, returns RGBA image (non-premultiplied alpha). * * @param r pointer to rasterizer context * @param image pointer to image to rasterize * @param tx image x offset (applied after scaling) * @param ty image y offset (applied after scaling) * @param scale image scale * @param dst pointer to destination image data, 4 bytes per pixel (RGBA) * @param w width of the image to render * @param h height of the image to render * @param stride number of bytes per scaleline in the destination buffer */ public static void nsvgRasterize(@NativeType("NSVGrasterizer *") long r, @NativeType("NSVGimage *") NSVGImage image, float tx, float ty, float scale, @NativeType("unsigned char *") ByteBuffer dst, int w, int h, int stride) { if (CHECKS) { check(r); check(dst, h * stride); } nnsvgRasterize(r, image.address(), tx, ty, scale, memAddress(dst), w, h, stride); } // --- [ nsvgDeleteRasterizer ] --- /** Unsafe version of: {@link #nsvgDeleteRasterizer DeleteRasterizer} */ public static native void nnsvgDeleteRasterizer(long rasterizer); /** * Deletes rasterizer context. * * @param rasterizer the rasterizer context to delete */ public static void nsvgDeleteRasterizer(@NativeType("NSVGrasterizer *") long rasterizer) { if (CHECKS) { check(rasterizer); } nnsvgDeleteRasterizer(rasterizer); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy