Package org.lwjgl.ovr
Class OVRLayerEyeMatrix
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<OVRLayerEyeMatrix>
org.lwjgl.ovr.OVRLayerEyeMatrix
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
public class OVRLayerEyeMatrix
extends org.lwjgl.system.Struct<OVRLayerEyeMatrix>
implements org.lwjgl.system.NativeResource
Describes a layer that specifies a monoscopic or stereoscopic view.
This uses a direct 3x4 matrix to map from view space to the UV coordinates. It is essentially the same thing as OVRLayerEyeFov but using a much
lower level. This is mainly to provide compatibility with specific apps. Unless the application really requires this flexibility, it is usually
better to use ovrLayerEyeFov.
Three options exist with respect to mono/stereo texture usage:
ColorTexture[0]andColorTexture[1]contain the left and right stereo renderings, respectively.Viewport[0]andViewport[1]refer toColorTexture[0]andColorTexture[1], respectively.ColorTexture[0]contains both the left and right renderings,ColorTexture[1]isNULL, andViewport[0]andViewport[1]refer to sub-rects withColorTexture[0].ColorTexture[0]contains a single monoscopic rendering, andViewport[0]andViewport[1]both refer to that rendering.
Layout
struct ovrLayerEyeMatrix {
ovrLayerHeader Header();
ovrTextureSwapChain ColorTexture()[ovrEye_Count];
ovrRecti Viewport()[ovrEye_Count];
ovrPosef RenderPose()[ovrEye_Count];
ovrMatrix4f Matrix()[ovrEye_Count];
double SensorSampleTime();
}-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from class org.lwjgl.system.Struct
org.lwjgl.system.Struct.StructValidationNested classes/interfaces inherited from interface org.lwjgl.system.Pointer
org.lwjgl.system.Pointer.Default -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe struct alignment in bytes.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.Fields inherited from interface org.lwjgl.system.Pointer
BITS32, BITS64, CLONG_SHIFT, CLONG_SIZE, POINTER_SHIFT, POINTER_SIZE -
Constructor Summary
ConstructorsConstructorDescriptionOVRLayerEyeMatrix(ByteBuffer container) Creates aOVRLayerEyeMatrixinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionstatic OVRLayerEyeMatrixcalloc()Returns a newOVRLayerEyeMatrixinstance allocated withmemCalloc.static OVRLayerEyeMatrix.Buffercalloc(int capacity) Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withmemCalloc.static OVRLayerEyeMatrix.Buffercalloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newOVRLayerEyeMatrix.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static OVRLayerEyeMatrixcalloc(org.lwjgl.system.MemoryStack stack) Returns a newOVRLayerEyeMatrixinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static OVRLayerEyeMatrixDeprecated.static OVRLayerEyeMatrix.BuffercallocStack(int capacity) Deprecated.static OVRLayerEyeMatrix.BuffercallocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.static OVRLayerEyeMatrixcallocStack(org.lwjgl.system.MemoryStack stack) Deprecated.org.lwjgl.PointerBufferovrTextureSwapChainsfor the left and right eye respectively.longColorTexture(int index) ovrTextureSwapChainsfor the left and right eye respectively.ColorTexture(int index, long value) Sets the specified value at the specified index of theColorTexture()field.ColorTexture(org.lwjgl.PointerBuffer value) Copies the specifiedPointerBufferto theColorTexture()field.static OVRLayerEyeMatrixcreate()Returns a newOVRLayerEyeMatrixinstance allocated withBufferUtils.static OVRLayerEyeMatrix.Buffercreate(int capacity) Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withBufferUtils.static OVRLayerEyeMatrixcreate(long address) Returns a newOVRLayerEyeMatrixinstance for the specified memory address.static OVRLayerEyeMatrix.Buffercreate(long address, int capacity) Create aOVRLayerEyeMatrix.Bufferinstance at the specified memory.static @Nullable OVRLayerEyeMatrixcreateSafe(long address) static @Nullable OVRLayerEyeMatrix.BuffercreateSafe(long address, int capacity) Header()Header.Typemust beLayerType_EyeMatrixHeader(Consumer<OVRLayerHeader> consumer) Header(OVRLayerHeader value) Copies the specifiedOVRLayerHeaderto theHeader()field.static OVRLayerEyeMatrixmalloc()Returns a newOVRLayerEyeMatrixinstance allocated withmemAlloc.static OVRLayerEyeMatrix.Buffermalloc(int capacity) Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withmemAlloc.static OVRLayerEyeMatrix.Buffermalloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newOVRLayerEyeMatrix.Bufferinstance allocated on the specifiedMemoryStack.static OVRLayerEyeMatrixmalloc(org.lwjgl.system.MemoryStack stack) Returns a newOVRLayerEyeMatrixinstance allocated on the specifiedMemoryStack.static OVRLayerEyeMatrixDeprecated.static OVRLayerEyeMatrix.BuffermallocStack(int capacity) Deprecated.static OVRLayerEyeMatrix.BuffermallocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.static OVRLayerEyeMatrixmallocStack(org.lwjgl.system.MemoryStack stack) Deprecated.Matrix()specifies the mapping from a view-space vector to a UV coordinate on the textures given above.Matrix(int index) specifies the mapping from a view-space vector to a UV coordinate on the textures given above.Matrix(int index, Consumer<OVRMatrix4f> consumer) Matrix(int index, OVRMatrix4f value) Copies the specifiedOVRMatrix4fat the specified index of theMatrix()field.Matrix(Consumer<OVRMatrix4f.Buffer> consumer) Matrix(OVRMatrix4f.Buffer value) Copies the specifiedOVRMatrix4f.Bufferto theMatrix()field.static org.lwjgl.PointerBuffernColorTexture(long struct) Unsafe version ofColorTexture().static longnColorTexture(long struct, int index) Unsafe version ofColorTexture.static voidnColorTexture(long struct, int index, long value) Unsafe version ofColorTexture.static voidnColorTexture(long struct, org.lwjgl.PointerBuffer value) Unsafe version ofColorTexture.static OVRLayerHeadernHeader(long struct) Unsafe version ofHeader().static voidnHeader(long struct, OVRLayerHeader value) Unsafe version ofHeader.static OVRMatrix4f.BuffernMatrix(long struct) Unsafe version ofMatrix().static OVRMatrix4fnMatrix(long struct, int index) Unsafe version ofMatrix.static voidnMatrix(long struct, int index, OVRMatrix4f value) Unsafe version ofMatrix.static voidnMatrix(long struct, OVRMatrix4f.Buffer value) Unsafe version ofMatrix.static OVRPosef.BuffernRenderPose(long struct) Unsafe version ofRenderPose().static OVRPosefnRenderPose(long struct, int index) Unsafe version ofRenderPose.static voidnRenderPose(long struct, int index, OVRPosef value) Unsafe version ofRenderPose.static voidnRenderPose(long struct, OVRPosef.Buffer value) Unsafe version ofRenderPose.static doublenSensorSampleTime(long struct) Unsafe version ofSensorSampleTime().static voidnSensorSampleTime(long struct, double value) Unsafe version ofSensorSampleTime.static OVRRecti.BuffernViewport(long struct) Unsafe version ofViewport().static OVRRectinViewport(long struct, int index) Unsafe version ofViewport.static voidUnsafe version ofViewport.static voidnViewport(long struct, OVRRecti.Buffer value) Unsafe version ofViewport.specifies the position and orientation of each eye view, with the position specified in meters.RenderPose(int index) specifies the position and orientation of each eye view, with the position specified in meters.RenderPose(int index, Consumer<OVRPosef> consumer) RenderPose(int index, OVRPosef value) Copies the specifiedOVRPosefat the specified index of theRenderPose()field.RenderPose(Consumer<OVRPosef.Buffer> consumer) Passes theRenderPose()field to the specifiedConsumer.RenderPose(OVRPosef.Buffer value) Copies the specifiedOVRPosef.Bufferto theRenderPose()field.doublespecifies the timestamp when the sourceovrPosef(used in calculatingRenderPose) was sampled from the SDK.SensorSampleTime(double value) Sets the specified value to theSensorSampleTime()field.set(OVRLayerEyeMatrix src) Copies the specified struct data to this struct.set(OVRLayerHeader Header, org.lwjgl.PointerBuffer ColorTexture, OVRRecti.Buffer Viewport, OVRPosef.Buffer RenderPose, OVRMatrix4f.Buffer Matrix, double SensorSampleTime) Initializes this struct with the specified values.intsizeof()static voidvalidate(long struct) Validates pointer members that should not beNULL.Viewport()specifies theColorTexturesub-rect UV coordinates.Viewport(int index) specifies theColorTexturesub-rect UV coordinates.Copies the specifiedOVRRectiat the specified index of theViewport()field.Viewport(Consumer<OVRRecti.Buffer> consumer) Passes theViewport()field to the specifiedConsumer.Viewport(OVRRecti.Buffer value) Copies the specifiedOVRRecti.Bufferto theViewport()field.Methods inherited from class org.lwjgl.system.Struct
clear, free, isNull, validate, validateMethods inherited from class org.lwjgl.system.Pointer.Default
address, equals, hashCode, toStringMethods inherited from interface org.lwjgl.system.NativeResource
close, free
-
Field Details
-
SIZEOF
public static final int SIZEOFThe struct size in bytes. -
ALIGNOF
public static final int ALIGNOFThe struct alignment in bytes. -
HEADER
public static final int HEADERThe struct member offsets. -
COLORTEXTURE
public static final int COLORTEXTUREThe struct member offsets. -
VIEWPORT
public static final int VIEWPORTThe struct member offsets. -
RENDERPOSE
public static final int RENDERPOSEThe struct member offsets. -
MATRIX
public static final int MATRIXThe struct member offsets. -
SENSORSAMPLETIME
public static final int SENSORSAMPLETIMEThe struct member offsets.
-
-
Constructor Details
-
OVRLayerEyeMatrix
Creates aOVRLayerEyeMatrixinstance at the current position of the specifiedByteBuffercontainer. 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.
-
-
Method Details
-
sizeof
public int sizeof()- Specified by:
sizeofin classorg.lwjgl.system.Struct<OVRLayerEyeMatrix>
-
Header
Header.Typemust beLayerType_EyeMatrix -
ColorTexture
public org.lwjgl.PointerBuffer ColorTexture()ovrTextureSwapChainsfor the left and right eye respectively. The second one of which can beNULLfor cases described above. -
ColorTexture
public long ColorTexture(int index) ovrTextureSwapChainsfor the left and right eye respectively. The second one of which can beNULLfor cases described above. -
Viewport
specifies theColorTexturesub-rect UV coordinates. BothViewport[0]andViewport[1]must be valid. -
Viewport
specifies theColorTexturesub-rect UV coordinates. BothViewport[0]andViewport[1]must be valid. -
RenderPose
specifies the position and orientation of each eye view, with the position specified in meters.RenderPosewill typically be the value returned from_CalcEyePoses, but can be different in special cases if a different head pose is used for rendering. -
RenderPose
specifies the position and orientation of each eye view, with the position specified in meters.RenderPosewill typically be the value returned from_CalcEyePoses, but can be different in special cases if a different head pose is used for rendering. -
Matrix
specifies the mapping from a view-space vector to a UV coordinate on the textures given above.P = (x,y,z,1)*Matrix TexU = P.x/P.z TexV = P.y/P.z -
Matrix
specifies the mapping from a view-space vector to a UV coordinate on the textures given above.P = (x,y,z,1)*Matrix TexU = P.x/P.z TexV = P.y/P.z -
SensorSampleTime
public double SensorSampleTime()specifies the timestamp when the sourceovrPosef(used in calculatingRenderPose) was sampled from the SDK. Typically retrieved by callingGetTimeInSecondsaround the instant the application callsGetTrackingStateThe main purpose for this is to accurately track app tracking latency. -
Header
Copies the specifiedOVRLayerHeaderto theHeader()field. -
Header
-
ColorTexture
Copies the specifiedPointerBufferto theColorTexture()field. -
ColorTexture
Sets the specified value at the specified index of theColorTexture()field. -
Viewport
Copies the specifiedOVRRecti.Bufferto theViewport()field. -
Viewport
Copies the specifiedOVRRectiat the specified index of theViewport()field. -
Viewport
Passes theViewport()field to the specifiedConsumer. -
Viewport
-
RenderPose
Copies the specifiedOVRPosef.Bufferto theRenderPose()field. -
RenderPose
Copies the specifiedOVRPosefat the specified index of theRenderPose()field. -
RenderPose
Passes theRenderPose()field to the specifiedConsumer. -
RenderPose
-
Matrix
Copies the specifiedOVRMatrix4f.Bufferto theMatrix()field. -
Matrix
Copies the specifiedOVRMatrix4fat the specified index of theMatrix()field. -
Matrix
-
Matrix
-
SensorSampleTime
Sets the specified value to theSensorSampleTime()field. -
set
public OVRLayerEyeMatrix set(OVRLayerHeader Header, org.lwjgl.PointerBuffer ColorTexture, OVRRecti.Buffer Viewport, OVRPosef.Buffer RenderPose, OVRMatrix4f.Buffer Matrix, double SensorSampleTime) Initializes this struct with the specified values. -
set
Copies the specified struct data to this struct.- Parameters:
src- the source struct- Returns:
- this struct
-
malloc
Returns a newOVRLayerEyeMatrixinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newOVRLayerEyeMatrixinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newOVRLayerEyeMatrixinstance allocated withBufferUtils. -
create
Returns a newOVRLayerEyeMatrixinstance for the specified memory address. -
createSafe
-
malloc
Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newOVRLayerEyeMatrix.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aOVRLayerEyeMatrix.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
mallocStack
Deprecated.Deprecated for removal in 3.4.0. Usemalloc(MemoryStack)instead. -
callocStack
Deprecated.Deprecated for removal in 3.4.0. Usecalloc(MemoryStack)instead. -
mallocStack
Deprecated.Deprecated for removal in 3.4.0. Usemalloc(MemoryStack)instead. -
callocStack
Deprecated.Deprecated for removal in 3.4.0. Usecalloc(MemoryStack)instead. -
mallocStack
Deprecated.Deprecated for removal in 3.4.0. Usemalloc(int, MemoryStack)instead. -
callocStack
Deprecated.Deprecated for removal in 3.4.0. Usecalloc(int, MemoryStack)instead. -
mallocStack
@Deprecated public static OVRLayerEyeMatrix.Buffer mallocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usemalloc(int, MemoryStack)instead. -
callocStack
@Deprecated public static OVRLayerEyeMatrix.Buffer callocStack(int capacity, org.lwjgl.system.MemoryStack stack) Deprecated.Deprecated for removal in 3.4.0. Usecalloc(int, MemoryStack)instead. -
malloc
Returns a newOVRLayerEyeMatrixinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newOVRLayerEyeMatrixinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
Returns a newOVRLayerEyeMatrix.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
Returns a newOVRLayerEyeMatrix.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nHeader
Unsafe version ofHeader(). -
nColorTexture
public static org.lwjgl.PointerBuffer nColorTexture(long struct) Unsafe version ofColorTexture(). -
nColorTexture
public static long nColorTexture(long struct, int index) Unsafe version ofColorTexture. -
nViewport
Unsafe version ofViewport(). -
nViewport
Unsafe version ofViewport. -
nRenderPose
Unsafe version ofRenderPose(). -
nRenderPose
Unsafe version ofRenderPose. -
nMatrix
Unsafe version ofMatrix(). -
nMatrix
Unsafe version ofMatrix. -
nSensorSampleTime
public static double nSensorSampleTime(long struct) Unsafe version ofSensorSampleTime(). -
nHeader
Unsafe version ofHeader. -
nColorTexture
public static void nColorTexture(long struct, org.lwjgl.PointerBuffer value) Unsafe version ofColorTexture. -
nColorTexture
public static void nColorTexture(long struct, int index, long value) Unsafe version ofColorTexture. -
nViewport
Unsafe version ofViewport. -
nViewport
Unsafe version ofViewport. -
nRenderPose
Unsafe version ofRenderPose. -
nRenderPose
Unsafe version ofRenderPose. -
nMatrix
Unsafe version ofMatrix. -
nMatrix
Unsafe version ofMatrix. -
nSensorSampleTime
public static void nSensorSampleTime(long struct, double value) Unsafe version ofSensorSampleTime. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-