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

org.lwjgl.util.tinyexr.TinyEXR Maven / Gradle / Ivy

/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.util.tinyexr;

import java.nio.*;

import org.lwjgl.*;

import org.lwjgl.system.*;

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

/**
 * Native bindings to the Tiny OpenEXR image library.
 * 
 * 

tinyexr is a small, single header-only library to load and save OpenEXR(.exr) images.

*/ public class TinyEXR { static { LibTinyEXR.initialize(); } /** Error codes. */ public static final int TINYEXR_SUCCESS = 0, TINYEXR_ERROR_INVALID_MAGIC_NUMBER = -1, TINYEXR_ERROR_INVALID_EXR_VERSION = -2, TINYEXR_ERROR_INVALID_ARGUMENT = -3, TINYEXR_ERROR_INVALID_DATA = -4, TINYEXR_ERROR_INVALID_FILE = -5, TINYEXR_ERROR_INVALID_PARAMETER = -6, TINYEXR_ERROR_CANT_OPEN_FILE = -7, TINYEXR_ERROR_UNSUPPORTED_FORMAT = -8, TINYEXR_ERROR_INVALID_HEADER = -9, TINYEXR_ERROR_UNSUPPORTED_FEATURE = -10, TINYEXR_ERROR_CANT_WRITE_FILE = -11, TINYEXR_ERROR_SERIALIZATION_FAILED = -12, TINYEXR_ERROR_LAYER_NOT_FOUND = -13, TINYEXR_ERROR_DATA_TOO_LARGE = -14; /** Pixel types. */ public static final int TINYEXR_PIXELTYPE_UINT = 0, TINYEXR_PIXELTYPE_HALF = 1, TINYEXR_PIXELTYPE_FLOAT = 2; public static final int TINYEXR_MAX_HEADER_ATTRIBUTES = 1024, TINYEXR_MAX_CUSTOM_ATTRIBUTES = 128; /** Compression types. */ public static final int TINYEXR_COMPRESSIONTYPE_NONE = 0, TINYEXR_COMPRESSIONTYPE_RLE = 1, TINYEXR_COMPRESSIONTYPE_ZIPS = 2, TINYEXR_COMPRESSIONTYPE_ZIP = 3, TINYEXR_COMPRESSIONTYPE_PIZ = 4, TINYEXR_COMPRESSIONTYPE_ZFP = 128; /** ZFP compression types. */ public static final int TINYEXR_ZFP_COMPRESSIONTYPE_RATE = 0, TINYEXR_ZFP_COMPRESSIONTYPE_PRECISION = 1, TINYEXR_ZFP_COMPRESSIONTYPE_ACCURACY = 2; /** Tile level types. */ public static final int TINYEXR_TILE_ONE_LEVEL = 0, TINYEXR_TILE_MIPMAP_LEVELS = 1, TINYEXR_TILE_RIPMAP_LEVELS = 2; /** Tile rounding types. */ public static final int TINYEXR_TILE_ROUND_DOWN = 0, TINYEXR_TILE_ROUND_UP = 1; protected TinyEXR() { throw new UnsupportedOperationException(); } // --- [ LoadEXRWithLayer ] --- /** Unsafe version of: {@link #LoadEXRWithLayer} */ public static native int nLoadEXRWithLayer(long out_rgba, long width, long height, long filename, long layer_name, long err); /** * Loads single-frame OpenEXR image by specifying layer name. * *

Assume EXR image contains A(single channel alpha) or RGB(A) channels. Application must free image data as returned by {@code out_rgba}. Result image * format is: float x RGBA x width x height.

* * @return negative value and may set error string in {@code err} when there's an error. When the specified layer name is not found in the EXR file, the function * will return {@link #TINYEXR_ERROR_LAYER_NOT_FOUND ERROR_LAYER_NOT_FOUND}. */ public static int LoadEXRWithLayer(@NativeType("float **") PointerBuffer out_rgba, @NativeType("int *") IntBuffer width, @NativeType("int *") IntBuffer height, @NativeType("char const *") ByteBuffer filename, @NativeType("char const *") ByteBuffer layer_name, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(out_rgba, 1); check(width, 1); check(height, 1); checkNT1(filename); checkNT1(layer_name); check(err, 1); } return nLoadEXRWithLayer(memAddress(out_rgba), memAddress(width), memAddress(height), memAddress(filename), memAddress(layer_name), memAddress(err)); } /** * Loads single-frame OpenEXR image by specifying layer name. * *

Assume EXR image contains A(single channel alpha) or RGB(A) channels. Application must free image data as returned by {@code out_rgba}. Result image * format is: float x RGBA x width x height.

* * @return negative value and may set error string in {@code err} when there's an error. When the specified layer name is not found in the EXR file, the function * will return {@link #TINYEXR_ERROR_LAYER_NOT_FOUND ERROR_LAYER_NOT_FOUND}. */ public static int LoadEXRWithLayer(@NativeType("float **") PointerBuffer out_rgba, @NativeType("int *") IntBuffer width, @NativeType("int *") IntBuffer height, @NativeType("char const *") CharSequence filename, @NativeType("char const *") CharSequence layer_name, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(out_rgba, 1); check(width, 1); check(height, 1); check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); stack.nUTF8(layer_name, true); long layer_nameEncoded = stack.getPointerAddress(); return nLoadEXRWithLayer(memAddress(out_rgba), memAddress(width), memAddress(height), filenameEncoded, layer_nameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ EXRLayers ] --- /** Unsafe version of: {@link #EXRLayers} */ public static native int nEXRLayers(long filename, long layer_names, long num_layers, long err); /** * Get layer infos from EXR file. * * @param layer_names list of layer names. Application must free memory after using this. * @param num_layers the number of layers * @param err Error string(will be filled when the function returns error code). Free it using FreeEXRErrorMessage after using this value. * * @return {@link #TINYEXR_SUCCESS SUCCESS} upon success. */ public static int EXRLayers(@NativeType("char const *") ByteBuffer filename, @NativeType("char const ***") PointerBuffer layer_names, @NativeType("int *") IntBuffer num_layers, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { checkNT1(filename); check(layer_names, 1); check(num_layers, 1); check(err, 1); } return nEXRLayers(memAddress(filename), memAddress(layer_names), memAddress(num_layers), memAddress(err)); } /** * Get layer infos from EXR file. * * @param layer_names list of layer names. Application must free memory after using this. * @param num_layers the number of layers * @param err Error string(will be filled when the function returns error code). Free it using FreeEXRErrorMessage after using this value. * * @return {@link #TINYEXR_SUCCESS SUCCESS} upon success. */ public static int EXRLayers(@NativeType("char const *") CharSequence filename, @NativeType("char const ***") PointerBuffer layer_names, @NativeType("int *") IntBuffer num_layers, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(layer_names, 1); check(num_layers, 1); check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nEXRLayers(filenameEncoded, memAddress(layer_names), memAddress(num_layers), memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ IsEXRFromMemory ] --- /** Unsafe version of: {@link #IsEXRFromMemory} */ public static native int nIsEXRFromMemory(long memory, long size); /** * Checks if given data is a EXR image (by just looking up a header section). * *

Simple wrapper API for {@link #ParseEXRHeaderFromMemory}.

* * @return {@link #TINYEXR_SUCCESS SUCCESS} for EXR image, {@link #TINYEXR_ERROR_INVALID_HEADER ERROR_INVALID_HEADER} for others */ public static int IsEXRFromMemory(@NativeType("unsigned char const *") ByteBuffer memory) { return nIsEXRFromMemory(memAddress(memory), memory.remaining()); } // --- [ EXRNumLevels ] --- /** Unsafe version of: {@link #EXRNumLevels} */ public static native int nEXRNumLevels(long exr_image); /** Returns the number of resolution levels of the image (including the base). */ public static int EXRNumLevels(@NativeType("EXRImage const *") EXRImage exr_image) { if (CHECKS) { EXRImage.validate(exr_image.address()); } return nEXRNumLevels(exr_image.address()); } // --- [ InitEXRHeader ] --- /** Unsafe version of: {@link #InitEXRHeader} */ public static native void nInitEXRHeader(long exr_header); /** Initialize {@link EXRHeader} struct. */ public static void InitEXRHeader(@NativeType("EXRHeader *") EXRHeader exr_header) { nInitEXRHeader(exr_header.address()); } // --- [ EXRSetNameAttr ] --- /** Unsafe version of: {@link #EXRSetNameAttr} */ public static native void nEXRSetNameAttr(long exr_header, long name); /** Sets name attribute of {@link EXRHeader} struct (it makes a copy). */ public static void EXRSetNameAttr(@NativeType("EXRHeader *") EXRHeader exr_header, @NativeType("char const *") ByteBuffer name) { if (CHECKS) { checkNT1(name); } nEXRSetNameAttr(exr_header.address(), memAddress(name)); } /** Sets name attribute of {@link EXRHeader} struct (it makes a copy). */ public static void EXRSetNameAttr(@NativeType("EXRHeader *") EXRHeader exr_header, @NativeType("char const *") CharSequence name) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(name, true); long nameEncoded = stack.getPointerAddress(); nEXRSetNameAttr(exr_header.address(), nameEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ InitEXRImage ] --- /** Unsafe version of: {@link #InitEXRImage} */ public static native void nInitEXRImage(long exr_image); /** Initialize {@link EXRImage} struct. */ public static void InitEXRImage(@NativeType("EXRImage *") EXRImage exr_image) { nInitEXRImage(exr_image.address()); } // --- [ FreeEXRHeader ] --- /** Unsafe version of: {@link #FreeEXRHeader} */ public static native int nFreeEXRHeader(long exr_header); /** Frees internal data of {@link EXRHeader} struct */ public static int FreeEXRHeader(@NativeType("EXRHeader *") EXRHeader exr_header) { return nFreeEXRHeader(exr_header.address()); } // --- [ FreeEXRImage ] --- /** Unsafe version of: {@link #FreeEXRImage} */ public static native int nFreeEXRImage(long exr_image); /** Frees internal data of {@link EXRImage} struct */ public static int FreeEXRImage(@NativeType("EXRImage *") EXRImage exr_image) { return nFreeEXRImage(exr_image.address()); } // --- [ FreeEXRErrorMessage ] --- /** Unsafe version of: {@link #FreeEXRErrorMessage} */ public static native void nFreeEXRErrorMessage(long msg); /** Frees error message */ public static void FreeEXRErrorMessage(@NativeType("char const *") ByteBuffer msg) { nFreeEXRErrorMessage(memAddress(msg)); } // --- [ ParseEXRVersionFromFile ] --- /** Unsafe version of: {@link #ParseEXRVersionFromFile} */ public static native int nParseEXRVersionFromFile(long version, long filename); /** Parse EXR version header of a file. */ public static int ParseEXRVersionFromFile(@NativeType("EXRVersion *") EXRVersion version, @NativeType("char const *") ByteBuffer filename) { if (CHECKS) { checkNT1(filename); } return nParseEXRVersionFromFile(version.address(), memAddress(filename)); } /** Parse EXR version header of a file. */ public static int ParseEXRVersionFromFile(@NativeType("EXRVersion *") EXRVersion version, @NativeType("char const *") CharSequence filename) { MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nParseEXRVersionFromFile(version.address(), filenameEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ ParseEXRVersionFromMemory ] --- /** Unsafe version of: {@link #ParseEXRVersionFromMemory} */ public static native int nParseEXRVersionFromMemory(long version, long memory, long size); /** Parse EXR version header from memory-mapped EXR data. */ public static int ParseEXRVersionFromMemory(@NativeType("EXRVersion *") EXRVersion version, @NativeType("unsigned char const *") ByteBuffer memory) { return nParseEXRVersionFromMemory(version.address(), memAddress(memory), memory.remaining()); } // --- [ ParseEXRHeaderFromFile ] --- /** Unsafe version of: {@link #ParseEXRHeaderFromFile} */ public static native int nParseEXRHeaderFromFile(long header, long version, long filename, long err); /** * Parse single-part OpenEXR header from a file and initialize {@link EXRHeader}. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRHeaderFromFile(@NativeType("EXRHeader *") EXRHeader header, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { checkNT1(filename); check(err, 1); } return nParseEXRHeaderFromFile(header.address(), version.address(), memAddress(filename), memAddress(err)); } /** * Parse single-part OpenEXR header from a file and initialize {@link EXRHeader}. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRHeaderFromFile(@NativeType("EXRHeader *") EXRHeader header, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nParseEXRHeaderFromFile(header.address(), version.address(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ ParseEXRHeaderFromMemory ] --- /** Unsafe version of: {@link #ParseEXRHeaderFromMemory} */ public static native int nParseEXRHeaderFromMemory(long header, long version, long memory, long size, long err); /** * Parse single-part OpenEXR header from a memory and initialize {@link EXRHeader}. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRHeaderFromMemory(@NativeType("EXRHeader *") EXRHeader header, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("unsigned char const *") ByteBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); } return nParseEXRHeaderFromMemory(header.address(), version.address(), memAddress(memory), memory.remaining(), memAddress(err)); } // --- [ ParseEXRMultipartHeaderFromFile ] --- /** Unsafe version of: {@link #ParseEXRMultipartHeaderFromFile} */ public static native int nParseEXRMultipartHeaderFromFile(long headers, long num_headers, long version, long filename, long err); /** * Parse multi-part OpenEXR headers from a file and initialize {@link EXRHeader}* array. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRMultipartHeaderFromFile(@NativeType("EXRHeader ***") PointerBuffer headers, @NativeType("int *") IntBuffer num_headers, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, 1); check(num_headers, 1); checkNT1(filename); check(err, 1); } return nParseEXRMultipartHeaderFromFile(memAddress(headers), memAddress(num_headers), version.address(), memAddress(filename), memAddress(err)); } /** * Parse multi-part OpenEXR headers from a file and initialize {@link EXRHeader}* array. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRMultipartHeaderFromFile(@NativeType("EXRHeader ***") PointerBuffer headers, @NativeType("int *") IntBuffer num_headers, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, 1); check(num_headers, 1); check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nParseEXRMultipartHeaderFromFile(memAddress(headers), memAddress(num_headers), version.address(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ ParseEXRMultipartHeaderFromMemory ] --- /** Unsafe version of: {@link #ParseEXRMultipartHeaderFromMemory} */ public static native int nParseEXRMultipartHeaderFromMemory(long headers, long num_headers, long version, long memory, long size, long err); /** * Parse multi-part OpenEXR headers from a memory and initialize {@link EXRHeader}* array. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int ParseEXRMultipartHeaderFromMemory(@NativeType("EXRHeader ***") PointerBuffer headers, @NativeType("int *") IntBuffer num_headers, @NativeType("EXRVersion const *") EXRVersion version, @NativeType("unsigned char const *") ByteBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, 1); check(num_headers, 1); check(err, 1); } return nParseEXRMultipartHeaderFromMemory(memAddress(headers), memAddress(num_headers), version.address(), memAddress(memory), memory.remaining(), memAddress(err)); } // --- [ LoadEXRImageFromFile ] --- /** Unsafe version of: {@link #LoadEXRImageFromFile} */ public static native int nLoadEXRImageFromFile(long image, long header, long filename, long err); /** * Loads single-part OpenEXR image from a file. * *

Application must setup {@link #ParseEXRHeaderFromFile} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRImageFromFile(@NativeType("EXRImage *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader header, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { checkNT1(filename); check(err, 1); EXRHeader.validate(header.address()); } return nLoadEXRImageFromFile(image.address(), header.address(), memAddress(filename), memAddress(err)); } /** * Loads single-part OpenEXR image from a file. * *

Application must setup {@link #ParseEXRHeaderFromFile} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRImageFromFile(@NativeType("EXRImage *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader header, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); EXRHeader.validate(header.address()); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nLoadEXRImageFromFile(image.address(), header.address(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ LoadEXRImageFromMemory ] --- /** Unsafe version of: {@link #LoadEXRImageFromMemory} */ public static native int nLoadEXRImageFromMemory(long image, long header, long memory, long size, long err); /** * Loads single-part OpenEXR image from a memory. * *

Application must setup {@link EXRHeader} with {@link #ParseEXRHeaderFromMemory} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRImageFromMemory(@NativeType("EXRImage *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader header, @NativeType("unsigned char const *") ByteBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); EXRHeader.validate(header.address()); } return nLoadEXRImageFromMemory(image.address(), header.address(), memAddress(memory), memory.remaining(), memAddress(err)); } // --- [ LoadEXRMultipartImageFromFile ] --- /** Unsafe version of: {@link #LoadEXRMultipartImageFromFile} */ public static native int nLoadEXRMultipartImageFromFile(long images, long headers, int num_parts, long filename, long err); /** * Loads multi-part OpenEXR image from a file. * *

Application must setup {@link #ParseEXRMultipartHeaderFromFile} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRMultipartImageFromFile(@NativeType("EXRImage *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer headers, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, images.remaining()); checkNT1(filename); check(err, 1); } return nLoadEXRMultipartImageFromFile(images.address(), memAddress(headers), images.remaining(), memAddress(filename), memAddress(err)); } /** * Loads multi-part OpenEXR image from a file. * *

Application must setup {@link #ParseEXRMultipartHeaderFromFile} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRMultipartImageFromFile(@NativeType("EXRImage *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer headers, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, images.remaining()); check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nLoadEXRMultipartImageFromFile(images.address(), memAddress(headers), images.remaining(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ LoadEXRMultipartImageFromMemory ] --- /** Unsafe version of: {@link #LoadEXRMultipartImageFromMemory} */ public static native int nLoadEXRMultipartImageFromMemory(long images, long headers, int num_parts, long memory, long size, long err); /** * Loads multi-part OpenEXR image from a memory. * *

Application must setup {@link EXRHeader}* array with {@link #ParseEXRMultipartHeaderFromMemory} before calling this function.

* *

Application can free EXRImage using {@link #FreeEXRImage}. When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadEXRMultipartImageFromMemory(@NativeType("EXRImage *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer headers, @NativeType("unsigned char const *") ByteBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(headers, images.remaining()); check(err, 1); } return nLoadEXRMultipartImageFromMemory(images.address(), memAddress(headers), images.remaining(), memAddress(memory), memory.remaining(), memAddress(err)); } // --- [ SaveEXRImageToFile ] --- /** Unsafe version of: {@link #SaveEXRImageToFile} */ public static native int nSaveEXRImageToFile(long image, long exr_header, long filename, long err); /** * Saves multi-channel, single-frame OpenEXR image to a file. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int SaveEXRImageToFile(@NativeType("EXRImage const *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader exr_header, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { checkNT1(filename); check(err, 1); EXRImage.validate(image.address()); EXRHeader.validate(exr_header.address()); } return nSaveEXRImageToFile(image.address(), exr_header.address(), memAddress(filename), memAddress(err)); } /** * Saves multi-channel, single-frame OpenEXR image to a file. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int SaveEXRImageToFile(@NativeType("EXRImage const *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader exr_header, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); EXRImage.validate(image.address()); EXRHeader.validate(exr_header.address()); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nSaveEXRImageToFile(image.address(), exr_header.address(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ SaveEXRImageToMemory ] --- /** Unsafe version of: {@link #SaveEXRImageToMemory} */ public static native long nSaveEXRImageToMemory(long image, long exr_header, long memory, long err); /** * Saves multi-channel, single-frame OpenEXR image to a memory. * *

Image is compressed using {@code EXRImage.compression} value.

* *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return the number of bytes if success or zero and may set error string in {@code err} when there's an error */ @NativeType("size_t") public static long SaveEXRImageToMemory(@NativeType("EXRImage const *") EXRImage image, @NativeType("EXRHeader const *") EXRHeader exr_header, @NativeType("unsigned char **") PointerBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(memory, 1); check(err, 1); EXRImage.validate(image.address()); EXRHeader.validate(exr_header.address()); } return nSaveEXRImageToMemory(image.address(), exr_header.address(), memAddress(memory), memAddress(err)); } // --- [ SaveEXRMultipartImageToFile ] --- /** Unsafe version of: {@link #SaveEXRMultipartImageToFile} */ public static native int nSaveEXRMultipartImageToFile(long images, long exr_headers, int num_parts, long filename, long err); /** * Saves multi-channel, multi-frame OpenEXR image to a file. * *

Image is compressed using {@code EXRImage.compression} value. File global attributes (eg. {@code display_window}) must be set in the first header.

* * @return negative value and may set error string in {@code err} when there's an error. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int SaveEXRMultipartImageToFile(@NativeType("EXRImage const *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer exr_headers, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(exr_headers, images.remaining()); checkNT1(filename); check(err, 1); Struct.validate(images.address(), images.remaining(), EXRImage.SIZEOF, EXRImage::validate); } return nSaveEXRMultipartImageToFile(images.address(), memAddress(exr_headers), images.remaining(), memAddress(filename), memAddress(err)); } /** * Saves multi-channel, multi-frame OpenEXR image to a file. * *

Image is compressed using {@code EXRImage.compression} value. File global attributes (eg. {@code display_window}) must be set in the first header.

* * @return negative value and may set error string in {@code err} when there's an error. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ public static int SaveEXRMultipartImageToFile(@NativeType("EXRImage const *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer exr_headers, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(exr_headers, images.remaining()); check(err, 1); Struct.validate(images.address(), images.remaining(), EXRImage.SIZEOF, EXRImage::validate); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nSaveEXRMultipartImageToFile(images.address(), memAddress(exr_headers), images.remaining(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } // --- [ SaveEXRMultipartImageToMemory ] --- /** Unsafe version of: {@link #SaveEXRMultipartImageToMemory} */ public static native long nSaveEXRMultipartImageToMemory(long images, long exr_headers, int num_parts, long memory, long err); /** * Saves multi-channel, multi-frame OpenEXR image to a memory. * *

Image is compressed using {@code EXRImage.compression} value. File global attributes (eg. {@code display_window}) must be set in the first header.

* * @return the number of bytes if success. Return zero and will set error string in {@code err} when there's an error. * *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

*/ @NativeType("size_t") public static long SaveEXRMultipartImageToMemory(@NativeType("EXRImage const *") EXRImage.Buffer images, @NativeType("EXRHeader const **") PointerBuffer exr_headers, @NativeType("unsigned char **") PointerBuffer memory, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(exr_headers, images.remaining()); check(memory, 1); check(err, 1); Struct.validate(images.address(), images.remaining(), EXRImage.SIZEOF, EXRImage::validate); } return nSaveEXRMultipartImageToMemory(images.address(), memAddress(exr_headers), images.remaining(), memAddress(memory), memAddress(err)); } // --- [ LoadDeepEXR ] --- /** Unsafe version of: {@link #LoadDeepEXR} */ public static native int nLoadDeepEXR(long out_image, long filename, long err); /** * Loads single-frame OpenEXR deep image. * *

Application must free memory of variables in {@code DeepImage(image, offset_table)}.

* *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadDeepEXR(@NativeType("DeepImage *") DeepImage out_image, @NativeType("char const *") ByteBuffer filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { checkNT1(filename); check(err, 1); } return nLoadDeepEXR(out_image.address(), memAddress(filename), memAddress(err)); } /** * Loads single-frame OpenEXR deep image. * *

Application must free memory of variables in {@code DeepImage(image, offset_table)}.

* *

When there was an error message, Application must free {@code err} with {@link #FreeEXRErrorMessage}.

* * @return negative value and may set error string in {@code err} when there's an error */ public static int LoadDeepEXR(@NativeType("DeepImage *") DeepImage out_image, @NativeType("char const *") CharSequence filename, @NativeType("char const **") PointerBuffer err) { if (CHECKS) { check(err, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8(filename, true); long filenameEncoded = stack.getPointerAddress(); return nLoadDeepEXR(out_image.address(), filenameEncoded, memAddress(err)); } finally { stack.setPointer(stackPointer); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy