
org.lwjgl.assimp.AIMaterialProperty Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lwjgl-assimp Show documentation
Show all versions of lwjgl-assimp Show documentation
A portable Open Source library to import various well-known 3D model formats in a uniform manner.
/*
* Copyright LWJGL. All rights reserved.
* License terms: https://www.lwjgl.org/license
* MACHINE GENERATED FILE, DO NOT EDIT
*/
package org.lwjgl.assimp;
import javax.annotation.*;
import java.nio.*;
import org.lwjgl.system.*;
import static org.lwjgl.system.MemoryUtil.*;
/**
* Data structure for a single material property.
*
* As a user, you'll probably never need to deal with this data structure. Just use the provided {@code aiGetMaterialXXX()} family of functions to query
* material properties easily. Processing them manually is faster, but it is not the recommended way. It isn't worth the effort.
*
* Material property names follow a simple scheme:
*
*
* $<name>
* ?<name>
* A public property, there must be corresponding AI_MATKEY_XXX define
* 2nd: Public, but ignored by the aiProcess_RemoveRedundantMaterials
* post-processing step.
* ~<name>
* A temporary property for internal use.
*
* Member documentation
*
*
* - {@code mKey} – Specifies the name of the property (key). Keys are generally case insensitive.
* - {@code mSemantic} – Textures: Specifies their exact usage semantic. For non-texture properties, this member is always 0 (or, better-said, {@link Assimp#aiTextureType_NONE TextureType_NONE}).
* - {@code mIndex} – Textures: Specifies the index of the texture. For non-texture properties, this member is always 0.
* - {@code mDataLength} – Size of the buffer {@code mData} is pointing to, in bytes. This value may not be 0.
* - {@code mType} –
* Type information for the property. Defines the data layout inside the data buffer. This is used by the library internally to perform debug checks and
* to utilize proper type conversions. (It's probably a hacky solution, but it works.)
* - {@code mData} – Binary buffer to hold the property's value. The size of the buffer is always mDataLength.
*
*
* Layout
*
*
* struct aiMaterialProperty {
* {@link AIString struct aiString} mKey;
* unsigned int mSemantic;
* unsigned int mIndex;
* unsigned int mDataLength;
* aiPropertyTypeInfo mType;
* char * mData;
* }
*/
@NativeType("struct aiMaterialProperty")
public class AIMaterialProperty extends Struct {
/** The struct size in bytes. */
public static final int SIZEOF;
/** The struct alignment in bytes. */
public static final int ALIGNOF;
/** The struct member offsets. */
public static final int
MKEY,
MSEMANTIC,
MINDEX,
MDATALENGTH,
MTYPE,
MDATA;
static {
Layout layout = __struct(
__member(AIString.SIZEOF, AIString.ALIGNOF),
__member(4),
__member(4),
__member(4),
__member(4),
__member(POINTER_SIZE)
);
SIZEOF = layout.getSize();
ALIGNOF = layout.getAlignment();
MKEY = layout.offsetof(0);
MSEMANTIC = layout.offsetof(1);
MINDEX = layout.offsetof(2);
MDATALENGTH = layout.offsetof(3);
MTYPE = layout.offsetof(4);
MDATA = layout.offsetof(5);
}
/**
* Creates a {@link AIMaterialProperty} instance at the current position of the specified {@link ByteBuffer} container. Changes to the buffer's content will be
* visible to the struct instance and vice versa.
*
* The created instance holds a strong reference to the container object.
*/
public AIMaterialProperty(ByteBuffer container) {
super(memAddress(container), __checkContainer(container, SIZEOF));
}
@Override
public int sizeof() { return SIZEOF; }
/** Returns a {@link AIString} view of the {@code mKey} field. */
@NativeType("struct aiString")
public AIString mKey() { return nmKey(address()); }
/** Passes the {@code mKey} field to the specified {@link java.util.function.Consumer Consumer}. */
public AIMaterialProperty mKey(java.util.function.Consumer consumer) { consumer.accept(mKey()); return this; }
/** Returns the value of the {@code mSemantic} field. */
@NativeType("unsigned int")
public int mSemantic() { return nmSemantic(address()); }
/** Returns the value of the {@code mIndex} field. */
@NativeType("unsigned int")
public int mIndex() { return nmIndex(address()); }
/** Returns the value of the {@code mDataLength} field. */
@NativeType("unsigned int")
public int mDataLength() { return nmDataLength(address()); }
/** Returns the value of the {@code mType} field. */
@NativeType("aiPropertyTypeInfo")
public int mType() { return nmType(address()); }
/** Returns a {@link ByteBuffer} view of the data pointed to by the {@code mData} field. */
@NativeType("char *")
public ByteBuffer mData() { return nmData(address()); }
// -----------------------------------
/** Returns a new {@link AIMaterialProperty} instance for the specified memory address. */
public static AIMaterialProperty create(long address) {
return wrap(AIMaterialProperty.class, address);
}
/** Like {@link #create(long) create}, but returns {@code null} if {@code address} is {@code NULL}. */
@Nullable
public static AIMaterialProperty createSafe(long address) {
return address == NULL ? null : wrap(AIMaterialProperty.class, address);
}
/**
* Create a {@link AIMaterialProperty.Buffer} instance at the specified memory.
*
* @param address the memory address
* @param capacity the buffer capacity
*/
public static AIMaterialProperty.Buffer create(long address, int capacity) {
return wrap(Buffer.class, address, capacity);
}
/** Like {@link #create(long, int) create}, but returns {@code null} if {@code address} is {@code NULL}. */
@Nullable
public static AIMaterialProperty.Buffer createSafe(long address, int capacity) {
return address == NULL ? null : wrap(Buffer.class, address, capacity);
}
// -----------------------------------
/** Unsafe version of {@link #mKey}. */
public static AIString nmKey(long struct) { return AIString.create(struct + AIMaterialProperty.MKEY); }
/** Unsafe version of {@link #mSemantic}. */
public static int nmSemantic(long struct) { return UNSAFE.getInt(null, struct + AIMaterialProperty.MSEMANTIC); }
/** Unsafe version of {@link #mIndex}. */
public static int nmIndex(long struct) { return UNSAFE.getInt(null, struct + AIMaterialProperty.MINDEX); }
/** Unsafe version of {@link #mDataLength}. */
public static int nmDataLength(long struct) { return UNSAFE.getInt(null, struct + AIMaterialProperty.MDATALENGTH); }
/** Unsafe version of {@link #mType}. */
public static int nmType(long struct) { return UNSAFE.getInt(null, struct + AIMaterialProperty.MTYPE); }
/** Unsafe version of {@link #mData() mData}. */
public static ByteBuffer nmData(long struct) { return memByteBuffer(memGetAddress(struct + AIMaterialProperty.MDATA), nmDataLength(struct)); }
// -----------------------------------
/** An array of {@link AIMaterialProperty} structs. */
public static class Buffer extends StructBuffer {
private static final AIMaterialProperty ELEMENT_FACTORY = AIMaterialProperty.create(-1L);
/**
* Creates a new {@link AIMaterialProperty.Buffer} instance backed by the specified container.
*
* Changes to the container's content will be visible to the struct buffer instance and vice versa. The two buffers' position, limit, and mark values
* will be independent. The new buffer's position will be zero, its capacity and its limit will be the number of bytes remaining in this buffer divided
* by {@link AIMaterialProperty#SIZEOF}, and its mark will be undefined.
*
* The created buffer instance holds a strong reference to the container object.
*/
public Buffer(ByteBuffer container) {
super(container, container.remaining() / SIZEOF);
}
public Buffer(long address, int cap) {
super(address, null, -1, 0, cap, cap);
}
Buffer(long address, @Nullable ByteBuffer container, int mark, int pos, int lim, int cap) {
super(address, container, mark, pos, lim, cap);
}
@Override
protected Buffer self() {
return this;
}
@Override
protected AIMaterialProperty getElementFactory() {
return ELEMENT_FACTORY;
}
/** Returns a {@link AIString} view of the {@code mKey} field. */
@NativeType("struct aiString")
public AIString mKey() { return AIMaterialProperty.nmKey(address()); }
/** Passes the {@code mKey} field to the specified {@link java.util.function.Consumer Consumer}. */
public AIMaterialProperty.Buffer mKey(java.util.function.Consumer consumer) { consumer.accept(mKey()); return this; }
/** Returns the value of the {@code mSemantic} field. */
@NativeType("unsigned int")
public int mSemantic() { return AIMaterialProperty.nmSemantic(address()); }
/** Returns the value of the {@code mIndex} field. */
@NativeType("unsigned int")
public int mIndex() { return AIMaterialProperty.nmIndex(address()); }
/** Returns the value of the {@code mDataLength} field. */
@NativeType("unsigned int")
public int mDataLength() { return AIMaterialProperty.nmDataLength(address()); }
/** Returns the value of the {@code mType} field. */
@NativeType("aiPropertyTypeInfo")
public int mType() { return AIMaterialProperty.nmType(address()); }
/** Returns a {@link ByteBuffer} view of the data pointed to by the {@code mData} field. */
@NativeType("char *")
public ByteBuffer mData() { return AIMaterialProperty.nmData(address()); }
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy