Class VkRenderingInputAttachmentIndexInfo
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkRenderingInputAttachmentIndexInfoKHR
Description
This structure allows applications to remap attachments to different input attachment indices.
Each element of pColorAttachmentInputIndices set to a value of ATTACHMENT_UNUSED indicates that the corresponding attachment will not be used as an input attachment in this pipeline. Any other value in each of those elements will map the corresponding attachment to a InputAttachmentIndex value defined in shader code.
If pColorAttachmentInputIndices is NULL, it is equivalent to setting each element to its index within the array.
If pDepthInputAttachmentIndex or pStencilInputAttachmentIndex are set to NULL, they map to input attachments without a InputAttachmentIndex decoration. If they point to a value of ATTACHMENT_UNUSED, it indicates that the corresponding attachment will not be used as an input attachment in this pipeline. If they point to any other value it maps the corresponding attachment to a InputAttachmentIndex value defined in shader code.
This structure can be included in the pNext chain of a VkGraphicsPipelineCreateInfo structure to set this state for a pipeline. If this structure is not included in the pNext chain of VkGraphicsPipelineCreateInfo, it is equivalent to specifying this structure with the following properties:
colorAttachmentCountset toVkPipelineRenderingCreateInfo::colorAttachmentCount.pColorAttachmentInputIndicesset toNULL.pDepthInputAttachmentIndexset toNULL.pStencilInputAttachmentIndexset toNULL.
This structure can be included in the pNext chain of a VkCommandBufferInheritanceInfo structure to specify inherited state from the primary command buffer. If this structure is not included in the pNext chain of VkCommandBufferInheritanceInfo, it is equivalent to specifying this structure with the following properties:
colorAttachmentCountset toVkCommandBufferInheritanceRenderingInfo::colorAttachmentCount.pColorAttachmentInputIndicesset toNULL.pDepthInputAttachmentIndexset toNULL.pStencilInputAttachmentIndexset toNULL.
Valid Usage
- If the
dynamicRenderingLocalReadfeature is not enabled, andpColorAttachmentInputIndicesis notNULL, each element must beATTACHMENT_UNUSED - If the
dynamicRenderingLocalReadfeature is not enabled,pDepthInputAttachmentIndexmust be a valid pointer to a value ofATTACHMENT_UNUSED - If the
dynamicRenderingLocalReadfeature is not enabled,pStencilInputAttachmentIndexmust be a valid pointer to a value ofATTACHMENT_UNUSED - Elements of
pColorAttachmentInputIndicesthat are notATTACHMENT_UNUSEDmust each be unique - Elements of
pColorAttachmentInputIndicesthat are notATTACHMENT_UNUSEDmust not take the same value as the content ofpDepthInputAttachmentIndex - Elements of
pColorAttachmentInputIndicesthat are notATTACHMENT_UNUSEDmust not take the same value as the content ofpStencilInputAttachmentIndex colorAttachmentCountmust be less than or equal tomaxColorAttachments
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_RENDERING_INPUT_ATTACHMENT_INDEX_INFO- If
colorAttachmentCountis not 0, andpColorAttachmentInputIndicesis notNULL,pColorAttachmentInputIndicesmust be a valid pointer to an array ofcolorAttachmentCountuint32_tvalues - If
pDepthInputAttachmentIndexis notNULL,pDepthInputAttachmentIndexmust be a valid pointer to a validuint32_tvalue - If
pStencilInputAttachmentIndexis notNULL,pStencilInputAttachmentIndexmust be a valid pointer to a validuint32_tvalue
See Also
CmdSetRenderingInputAttachmentIndices, CmdSetRenderingInputAttachmentIndicesKHR
Layout
struct VkRenderingInputAttachmentIndexInfo {
VkStructureType sType();
void const * pNext();
uint32_t colorAttachmentCount();
uint32_t const * pColorAttachmentInputIndices();
uint32_t const * pDepthInputAttachmentIndex(int);
uint32_t const * pStencilInputAttachmentIndex(int);
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkRenderingInputAttachmentIndexInfostructs.Nested 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
ConstructorsConstructorDescriptionVkRenderingInputAttachmentIndexInfo(ByteBuffer container) Creates aVkRenderingInputAttachmentIndexInfoinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.intthe number of elements inpColorAttachmentInputIndices.colorAttachmentCount(int value) Sets the specified value to thecolorAttachmentCount()field.create()Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated withBufferUtils.create(int capacity) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkRenderingInputAttachmentIndexInfoinstance for the specified memory address.create(long address, int capacity) Create aVkRenderingInputAttachmentIndexInfo.Bufferinstance at the specified memory.static @Nullable VkRenderingInputAttachmentIndexInfocreateSafe(long address) static @Nullable VkRenderingInputAttachmentIndexInfo.BuffercreateSafe(long address, int capacity) malloc()Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated on the specifiedMemoryStack.static intncolorAttachmentCount(long struct) Unsafe version ofcolorAttachmentCount().static voidncolorAttachmentCount(long struct, int value) Sets the specified value to thecolorAttachmentCountfield of the specifiedstruct.static @Nullable IntBuffernpColorAttachmentInputIndices(long struct) Unsafe version ofpColorAttachmentInputIndices.static voidnpColorAttachmentInputIndices(long struct, @Nullable IntBuffer value) Unsafe version ofpColorAttachmentInputIndices.static @Nullable IntBuffernpDepthInputAttachmentIndex(long struct, int capacity) Unsafe version ofpDepthInputAttachmentIndex.static voidnpDepthInputAttachmentIndex(long struct, @Nullable IntBuffer value) Unsafe version ofpDepthInputAttachmentIndex.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static @Nullable IntBuffernpStencilInputAttachmentIndex(long struct, int capacity) Unsafe version ofpStencilInputAttachmentIndex.static voidnpStencilInputAttachmentIndex(long struct, @Nullable IntBuffer value) Unsafe version ofpStencilInputAttachmentIndex.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.@Nullable IntBuffera pointer to an array ofcolorAttachmentCountuint32_tvalues defining indices for color attachments to be used as input attachments.pColorAttachmentInputIndices(@Nullable IntBuffer value) Sets the address of the specifiedIntBufferto thepColorAttachmentInputIndices()field.@Nullable IntBufferpDepthInputAttachmentIndex(int capacity) pDepthInputAttachmentIndex(@Nullable IntBuffer value) Sets the address of the specifiedIntBufferto thepDepthInputAttachmentIndex(int)field.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.@Nullable IntBufferpStencilInputAttachmentIndex(int capacity) pStencilInputAttachmentIndex(@Nullable IntBuffer value) Sets the address of the specifiedIntBufferto thepStencilInputAttachmentIndex(int)field.set(int sType, long pNext, int colorAttachmentCount, @Nullable IntBuffer pColorAttachmentInputIndices, @Nullable IntBuffer pDepthInputAttachmentIndex, @Nullable IntBuffer pStencilInputAttachmentIndex) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_RENDERING_INPUT_ATTACHMENT_INDEX_INFOvalue to thesType()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. -
STYPE
public static final int STYPEThe struct member offsets. -
PNEXT
public static final int PNEXTThe struct member offsets. -
COLORATTACHMENTCOUNT
public static final int COLORATTACHMENTCOUNTThe struct member offsets. -
PCOLORATTACHMENTINPUTINDICES
public static final int PCOLORATTACHMENTINPUTINDICESThe struct member offsets. -
PDEPTHINPUTATTACHMENTINDEX
public static final int PDEPTHINPUTATTACHMENTINDEXThe struct member offsets. -
PSTENCILINPUTATTACHMENTINDEX
public static final int PSTENCILINPUTATTACHMENTINDEXThe struct member offsets.
-
-
Constructor Details
-
VkRenderingInputAttachmentIndexInfo
Creates aVkRenderingInputAttachmentIndexInfoinstance 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<VkRenderingInputAttachmentIndexInfo>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
colorAttachmentCount
public int colorAttachmentCount()the number of elements inpColorAttachmentInputIndices. -
pColorAttachmentInputIndices
a pointer to an array ofcolorAttachmentCountuint32_tvalues defining indices for color attachments to be used as input attachments. -
pDepthInputAttachmentIndex
- Parameters:
capacity- the number of elements in the returned buffer- Returns:
- either
NULL, or a pointer to auint32_tvalue defining the index for the depth attachment to be used as an input attachment.
-
pStencilInputAttachmentIndex
- Parameters:
capacity- the number of elements in the returned buffer- Returns:
- either
NULL, or a pointer to auint32_tvalue defining the index for the stencil attachment to be used as an input attachment.
-
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_RENDERING_INPUT_ATTACHMENT_INDEX_INFOvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
colorAttachmentCount
Sets the specified value to thecolorAttachmentCount()field. -
pColorAttachmentInputIndices
Sets the address of the specifiedIntBufferto thepColorAttachmentInputIndices()field. -
pDepthInputAttachmentIndex
Sets the address of the specifiedIntBufferto thepDepthInputAttachmentIndex(int)field. -
pStencilInputAttachmentIndex
Sets the address of the specifiedIntBufferto thepStencilInputAttachmentIndex(int)field. -
set
public VkRenderingInputAttachmentIndexInfo set(int sType, long pNext, int colorAttachmentCount, @Nullable IntBuffer pColorAttachmentInputIndices, @Nullable IntBuffer pDepthInputAttachmentIndex, @Nullable IntBuffer pStencilInputAttachmentIndex) 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 newVkRenderingInputAttachmentIndexInfoinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated withBufferUtils. -
create
Returns a newVkRenderingInputAttachmentIndexInfoinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkRenderingInputAttachmentIndexInfo.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkRenderingInputAttachmentIndexInfo.Buffer createSafe(long address, int capacity) -
malloc
Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkRenderingInputAttachmentIndexInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkRenderingInputAttachmentIndexInfo.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkRenderingInputAttachmentIndexInfo.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkRenderingInputAttachmentIndexInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nsType
public static int nsType(long struct) Unsafe version ofsType(). -
npNext
public static long npNext(long struct) Unsafe version ofpNext(). -
ncolorAttachmentCount
public static int ncolorAttachmentCount(long struct) Unsafe version ofcolorAttachmentCount(). -
npColorAttachmentInputIndices
Unsafe version ofpColorAttachmentInputIndices. -
npDepthInputAttachmentIndex
Unsafe version ofpDepthInputAttachmentIndex. -
npStencilInputAttachmentIndex
Unsafe version ofpStencilInputAttachmentIndex. -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
ncolorAttachmentCount
public static void ncolorAttachmentCount(long struct, int value) Sets the specified value to thecolorAttachmentCountfield of the specifiedstruct. -
npColorAttachmentInputIndices
Unsafe version ofpColorAttachmentInputIndices. -
npDepthInputAttachmentIndex
Unsafe version ofpDepthInputAttachmentIndex. -
npStencilInputAttachmentIndex
Unsafe version ofpStencilInputAttachmentIndex.
-