Package org.lwjgl.vulkan
Class VkCopyImageToBufferInfo2
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkCopyImageToBufferInfo2>
org.lwjgl.vulkan.VkCopyImageToBufferInfo2
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkCopyImageToBufferInfo2KHR
public class VkCopyImageToBufferInfo2
extends org.lwjgl.system.Struct<VkCopyImageToBufferInfo2>
implements org.lwjgl.system.NativeResource
Structure specifying parameters of an image to buffer copy command.
Valid Usage
- The image region specified by each element of
pRegionsthat does not containVkCopyCommandTransformInfoQCOMin itspNextchain must be contained within the specifiedimageSubresourceofsrcImage - If the image region specified by each element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, the rotated source region must be contained withinsrcImage - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thensrcImagemust have a 1x1x1 texel block extent - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thensrcImagemust be of typeIMAGE_TYPE_2D - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thensrcImagemust not have a multi-planar format
dstBuffermust be large enough to contain all buffer locations that are accessed according to Buffer and Image Addressing, for each element ofpRegions- The union of all source regions, and the union of all destination regions, specified by the elements of
pRegions, must not overlap in memory srcImagemust have been created withIMAGE_USAGE_TRANSFER_SRC_BITusage flag- The format features of
srcImagemust containFORMAT_FEATURE_TRANSFER_SRC_BIT dstBuffermust have been created withBUFFER_USAGE_TRANSFER_DST_BITusage flag- If
dstBufferis non-sparse then it must be bound completely and contiguously to a singleVkDeviceMemoryobject srcImageLayoutmust specify the layout of the image subresources ofsrcImagespecified inpRegionsat the time this command is executed on aVkDevicesrcImageLayoutmust beIMAGE_LAYOUT_SHARED_PRESENT_KHR,IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL, orIMAGE_LAYOUT_GENERAL
- If
srcImageis non-sparse then the image or the specified disjoint plane must be bound completely and contiguously to a singleVkDeviceMemoryobject - The
imageSubresource.mipLevelmember of each element ofpRegionsmust be less than themipLevelsspecified inVkImageCreateInfowhensrcImagewas created - If
imageSubresource.layerCountis notREMAINING_ARRAY_LAYERS,of each element ofimageSubresource.baseArrayLayer+imageSubresource.layerCountpRegionsmust be less than or equal to thearrayLayersspecified inVkImageCreateInfowhensrcImagewas created srcImagemust not have been created withflagscontainingIMAGE_CREATE_SUBSAMPLED_BIT_EXT
srcImagemust have a sample count equal toSAMPLE_COUNT_1_BIT
- If
srcImageis of typeIMAGE_TYPE_1D, then for each element ofpRegions,imageOffset.ymust be 0 andimageExtent.heightmust be 1 - For each element of
pRegions,imageOffset.zand(must both be greater than or equal to 0 and less than or equal to the depth of the specifiedimageExtent.depth+imageOffset.z)imageSubresourceofsrcImage - If
srcImageis of typeIMAGE_TYPE_1DorIMAGE_TYPE_2D, then for each element ofpRegions,imageOffset.zmust be 0 andimageExtent.depthmust be 1 - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_IDENTITY_BIT_KHRorSURFACE_TRANSFORM_ROTATE_270_BIT_KHR,imageOffset.xmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_180_BIT_KHRorSURFACE_TRANSFORM_ROTATE_90_BIT_KHR, andimageOffset.xdoes not equal the width of the subresource specified byimageSubresource,imageOffset.xmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_IDENTITY_BIT_KHRorSURFACE_TRANSFORM_ROTATE_90_BIT_KHR,imageOffset.ymust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_270_BIT_KHRorSURFACE_TRANSFORM_ROTATE_180_BIT_KHR, andimageOffset.ydoes not equal the height of the subresource specified byimageSubresource,imageOffset.ymust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions,imageOffset.zmust be a multiple of the texel block extent depth of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_IDENTITY_BIT_KHR, the sum ofimageOffset.xandextent.widthdoes not equal the width of the subresource specified byimageSubresource,extent.widthmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_90_BIT_KHR, the difference ofimageOffset.xandextent.heightmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_180_BIT_KHR, the difference ofimageOffset.xandextent.widthmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_270_BIT_KHR, the sum ofimageOffset.xandextent.heightdoes not equal the width of the subresource specified byimageSubresource,extent.heightmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_IDENTITY_BIT_KHR, and the sum ofimageOffset.yandextent.heightdoes not equal the height of the subresource specified byimageSubresource,extent.heightmust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_90_BIT_KHR, the sum ofimageOffset.yandextent.widthdoes not equal the height of the subresource specified byimageSubresource,extent.widthmust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_180_BIT_KHR, the difference ofimageOffset.yandextent.heightmust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions, ifVkCopyCommandTransformInfoQCOM::transformis equal toSURFACE_TRANSFORM_ROTATE_270_BIT_KHR, the difference ofimageOffset.yandextent.widthmust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions, if the sum ofimageOffset.zandextent.depthdoes not equal the depth of the subresource specified bysrcSubresource,extent.depthmust be a multiple of the texel block extent depth of theVkFormatofsrcImage - For each element of
pRegions,imageSubresource.aspectMaskmust specify aspects present insrcImage - If
srcImagehas a multi-planar image format, then for each element ofpRegions,imageSubresource.aspectMaskmust be a single valid multi-planar aspect mask bit - If
srcImageis of typeIMAGE_TYPE_3D, for each element ofpRegions,imageSubresource.baseArrayLayermust be 0 andimageSubresource.layerCountmust be 1
- For each element of
pRegions,bufferRowLengthmust be a multiple of the texel block extent width of theVkFormatofsrcImage - For each element of
pRegions,bufferImageHeightmust be a multiple of the texel block extent height of theVkFormatofsrcImage - For each element of
pRegions,bufferRowLengthdivided by the texel block extent width and then multiplied by the texel block size ofsrcImagemust be less than or equal to231-1
- If
srcImagedoes not have either a depth/stencil format or a multi-planar format, then for each element ofpRegions,bufferOffsetmust be a multiple of the texel block size - If
srcImagehas a multi-planar format, then for each element ofpRegions,bufferOffsetmust be a multiple of the element size of the compatible format for the format and theaspectMaskof theimageSubresourceas defined in Compatible formats of planes of multi-planar formats - If
srcImagehas a depth/stencil format, thebufferOffsetmember of any element ofpRegionsmust be a multiple of 4 - For each element of
pRegionsnot containingVkCopyCommandTransformInfoQCOMin itspNextchain,imageOffset.xand(imageExtent.width + imageOffset.x)must both be greater than or equal to 0 and less than or equal to the width of the specifiedimageSubresourceofsrcImage - For each element of
pRegionsnot containingVkCopyCommandTransformInfoQCOMin itspNextchain,imageOffset.yand(imageExtent.height + imageOffset.y)must both be greater than or equal to 0 and less than or equal to the height of the specifiedimageSubresourceofsrcImage
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_COPY_IMAGE_TO_BUFFER_INFO_2pNextmust beNULLsrcImagemust be a validVkImagehandlesrcImageLayoutmust be a validVkImageLayoutvaluedstBuffermust be a validVkBufferhandlepRegionsmust be a valid pointer to an array ofregionCountvalidVkBufferImageCopy2structuresregionCountmust be greater than 0- Both of
dstBuffer, andsrcImagemust have been created, allocated, or retrieved from the sameVkDevice
See Also
VkBufferImageCopy2, CmdCopyImageToBuffer2, CmdCopyImageToBuffer2KHR
Layout
struct VkCopyImageToBufferInfo2 {
VkStructureType sType();
void const * pNext();
VkImage srcImage();
VkImageLayout srcImageLayout();
VkBuffer dstBuffer();
uint32_t regionCount();
VkBufferImageCopy2 const * pRegions();
}-
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 size in bytes.static final intThe struct member offsets.static final intThe struct member offsets.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
ConstructorsConstructorDescriptionVkCopyImageToBufferInfo2(ByteBuffer container) Creates aVkCopyImageToBufferInfo2instance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionstatic VkCopyImageToBufferInfo2calloc()Returns a newVkCopyImageToBufferInfo2instance allocated withmemCalloc.calloc(int capacity) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkCopyImageToBufferInfo2calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2instance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkCopyImageToBufferInfo2create()Returns a newVkCopyImageToBufferInfo2instance allocated withBufferUtils.create(int capacity) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withBufferUtils.static VkCopyImageToBufferInfo2create(long address) Returns a newVkCopyImageToBufferInfo2instance for the specified memory address.create(long address, int capacity) Create aVkCopyImageToBufferInfo2.Bufferinstance at the specified memory.static @Nullable VkCopyImageToBufferInfo2createSafe(long address) static @Nullable VkCopyImageToBufferInfo2.BuffercreateSafe(long address, int capacity) longthe destination buffer.dstBuffer(long value) Sets the specified value to thedstBuffer()field.static VkCopyImageToBufferInfo2malloc()Returns a newVkCopyImageToBufferInfo2instance allocated withmemAlloc.malloc(int capacity) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated on the specifiedMemoryStack.static VkCopyImageToBufferInfo2malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2instance allocated on the specifiedMemoryStack.static longndstBuffer(long struct) Unsafe version ofdstBuffer().static voidndstBuffer(long struct, long value) Unsafe version ofdstBuffer.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static VkBufferImageCopy2.BuffernpRegions(long struct) Unsafe version ofpRegions().static voidnpRegions(long struct, VkBufferImageCopy2.Buffer value) Unsafe version ofpRegions.static intnregionCount(long struct) Unsafe version ofregionCount().static voidnregionCount(long struct, int value) Sets the specified value to theregionCountfield of the specifiedstruct.static longnsrcImage(long struct) Unsafe version ofsrcImage().static voidnsrcImage(long struct, long value) Unsafe version ofsrcImage.static intnsrcImageLayout(long struct) Unsafe version ofsrcImageLayout().static voidnsrcImageLayout(long struct, int value) Unsafe version ofsrcImageLayout.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.pRegions()a pointer to an array ofVkBufferImageCopy2structures specifying the regions to copy.Sets the address of the specifiedVkBufferImageCopy2.Bufferto thepRegions()field.intthe number of regions to copy.set(int sType, long pNext, long srcImage, int srcImageLayout, long dstBuffer, VkBufferImageCopy2.Buffer pRegions) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()longsrcImage()the source image.srcImage(long value) Sets the specified value to thesrcImage()field.intthe layout of the source image subresources for the copy.srcImageLayout(int value) Sets the specified value to thesrcImageLayout()field.intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_COPY_IMAGE_TO_BUFFER_INFO_2value to thesType()field.static voidvalidate(long struct) Validates pointer members that should not beNULL.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. -
SRCIMAGE
public static final int SRCIMAGEThe struct member offsets. -
SRCIMAGELAYOUT
public static final int SRCIMAGELAYOUTThe struct member offsets. -
DSTBUFFER
public static final int DSTBUFFERThe struct member offsets. -
REGIONCOUNT
public static final int REGIONCOUNTThe struct member offsets. -
PREGIONS
public static final int PREGIONSThe struct member offsets.
-
-
Constructor Details
-
VkCopyImageToBufferInfo2
Creates aVkCopyImageToBufferInfo2instance 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<VkCopyImageToBufferInfo2>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
srcImage
public long srcImage()the source image. -
srcImageLayout
public int srcImageLayout()the layout of the source image subresources for the copy. -
dstBuffer
public long dstBuffer()the destination buffer. -
regionCount
public int regionCount()the number of regions to copy. -
pRegions
a pointer to an array ofVkBufferImageCopy2structures specifying the regions to copy. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_COPY_IMAGE_TO_BUFFER_INFO_2value to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
srcImage
Sets the specified value to thesrcImage()field. -
srcImageLayout
Sets the specified value to thesrcImageLayout()field. -
dstBuffer
Sets the specified value to thedstBuffer()field. -
pRegions
Sets the address of the specifiedVkBufferImageCopy2.Bufferto thepRegions()field. -
set
public VkCopyImageToBufferInfo2 set(int sType, long pNext, long srcImage, int srcImageLayout, long dstBuffer, VkBufferImageCopy2.Buffer pRegions) 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 newVkCopyImageToBufferInfo2instance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkCopyImageToBufferInfo2instance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkCopyImageToBufferInfo2instance allocated withBufferUtils. -
create
Returns a newVkCopyImageToBufferInfo2instance for the specified memory address. -
createSafe
-
malloc
Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkCopyImageToBufferInfo2.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
malloc
Returns a newVkCopyImageToBufferInfo2instance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkCopyImageToBufferInfo2instance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkCopyImageToBufferInfo2.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkCopyImageToBufferInfo2.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyImageToBufferInfo2.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(). -
nsrcImage
public static long nsrcImage(long struct) Unsafe version ofsrcImage(). -
nsrcImageLayout
public static int nsrcImageLayout(long struct) Unsafe version ofsrcImageLayout(). -
ndstBuffer
public static long ndstBuffer(long struct) Unsafe version ofdstBuffer(). -
nregionCount
public static int nregionCount(long struct) Unsafe version ofregionCount(). -
npRegions
Unsafe version ofpRegions(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
nsrcImage
public static void nsrcImage(long struct, long value) Unsafe version ofsrcImage. -
nsrcImageLayout
public static void nsrcImageLayout(long struct, int value) Unsafe version ofsrcImageLayout. -
ndstBuffer
public static void ndstBuffer(long struct, long value) Unsafe version ofdstBuffer. -
nregionCount
public static void nregionCount(long struct, int value) Sets the specified value to theregionCountfield of the specifiedstruct. -
npRegions
Unsafe version ofpRegions. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-