Package org.lwjgl.vulkan
Class VkCopyBufferToImageInfo2
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkCopyBufferToImageInfo2>
org.lwjgl.vulkan.VkCopyBufferToImageInfo2
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkCopyBufferToImageInfo2KHR
public class VkCopyBufferToImageInfo2
extends org.lwjgl.system.Struct<VkCopyBufferToImageInfo2>
implements org.lwjgl.system.NativeResource
Structure specifying parameters of a buffer to image copy command.
Valid Usage
- The image region specified by each element of
pRegionsthat does not containVkCopyCommandTransformInfoQCOMin itspNextchain must be contained within the specifiedimageSubresourceofdstImage - If the image region specified by each element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, the rotated destination region must be contained withindstImage - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thendstImagemust have a 1x1x1 texel block extent - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thendstImagemust be of typeIMAGE_TYPE_2D - If any element of
pRegionscontainsVkCopyCommandTransformInfoQCOMin itspNextchain, thendstImagemust not have a multi-planar format
srcBuffermust 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 srcBuffermust have been created withBUFFER_USAGE_TRANSFER_SRC_BITusage flag- The format features of
dstImagemust containFORMAT_FEATURE_TRANSFER_DST_BIT - If
srcBufferis non-sparse then it must be bound completely and contiguously to a singleVkDeviceMemoryobject dstImagemust have been created withIMAGE_USAGE_TRANSFER_DST_BITusage flagdstImageLayoutmust specify the layout of the image subresources ofdstImagespecified inpRegionsat the time this command is executed on aVkDevicedstImageLayoutmust beIMAGE_LAYOUT_SHARED_PRESENT_KHR,IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL, orIMAGE_LAYOUT_GENERAL- If
VK_EXT_depth_range_unrestrictedis not enabled, for each element ofpRegionswhoseimageSubresourcecontains a depth aspect, the data insrcBuffermust be in the range[0,1]
- If
dstImageis 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 inVkImageCreateInfowhendstImagewas created - If
imageSubresource.layerCountis notREMAINING_ARRAY_LAYERS,of each element ofimageSubresource.baseArrayLayer+imageSubresource.layerCountpRegionsmust be less than or equal to thearrayLayersspecified inVkImageCreateInfowhendstImagewas created dstImagemust not have been created withflagscontainingIMAGE_CREATE_SUBSAMPLED_BIT_EXT
dstImagemust have a sample count equal toSAMPLE_COUNT_1_BIT
- If
dstImageis 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)imageSubresourceofdstImage - If
dstImageis 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - For each element of
pRegions,imageOffset.zmust be a multiple of the texel block extent depth of theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - 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 theVkFormatofdstImage - For each element of
pRegions,imageSubresource.aspectMaskmust specify aspects present indstImage - If
dstImagehas a multi-planar image format, then for each element ofpRegions,imageSubresource.aspectMaskmust be a single valid multi-planar aspect mask bit - If
dstImageis 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 theVkFormatofdstImage - For each element of
pRegions,bufferImageHeightmust be a multiple of the texel block extent height of theVkFormatofdstImage - For each element of
pRegions,bufferRowLengthdivided by the texel block extent width and then multiplied by the texel block size ofdstImagemust be less than or equal to231-1
- If
dstImagedoes 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
dstImagehas 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
dstImagehas 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 specifiedimageSubresourceofdstImage - 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 specifiedimageSubresourceofdstImage
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_COPY_BUFFER_TO_IMAGE_INFO_2pNextmust beNULLsrcBuffermust be a validVkBufferhandledstImagemust be a validVkImagehandledstImageLayoutmust be a validVkImageLayoutvaluepRegionsmust be a valid pointer to an array ofregionCountvalidVkBufferImageCopy2structuresregionCountmust be greater than 0- Both of
dstImage, andsrcBuffermust have been created, allocated, or retrieved from the sameVkDevice
See Also
VkBufferImageCopy2, CmdCopyBufferToImage2, CmdCopyBufferToImage2KHR
Layout
struct VkCopyBufferToImageInfo2 {
VkStructureType sType();
void const * pNext();
VkBuffer srcBuffer();
VkImage dstImage();
VkImageLayout dstImageLayout();
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 member offsets.static final intThe struct size in bytes.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
ConstructorsConstructorDescriptionVkCopyBufferToImageInfo2(ByteBuffer container) Creates aVkCopyBufferToImageInfo2instance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionstatic VkCopyBufferToImageInfo2calloc()Returns a newVkCopyBufferToImageInfo2instance allocated withmemCalloc.calloc(int capacity) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkCopyBufferToImageInfo2calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2instance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkCopyBufferToImageInfo2create()Returns a newVkCopyBufferToImageInfo2instance allocated withBufferUtils.create(int capacity) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withBufferUtils.static VkCopyBufferToImageInfo2create(long address) Returns a newVkCopyBufferToImageInfo2instance for the specified memory address.create(long address, int capacity) Create aVkCopyBufferToImageInfo2.Bufferinstance at the specified memory.static @Nullable VkCopyBufferToImageInfo2createSafe(long address) static @Nullable VkCopyBufferToImageInfo2.BuffercreateSafe(long address, int capacity) longdstImage()the destination image.dstImage(long value) Sets the specified value to thedstImage()field.intthe layout of the destination image subresources for the copy.dstImageLayout(int value) Sets the specified value to thedstImageLayout()field.static VkCopyBufferToImageInfo2malloc()Returns a newVkCopyBufferToImageInfo2instance allocated withmemAlloc.malloc(int capacity) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated on the specifiedMemoryStack.static VkCopyBufferToImageInfo2malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2instance allocated on the specifiedMemoryStack.static longndstImage(long struct) Unsafe version ofdstImage().static voidndstImage(long struct, long value) Unsafe version ofdstImage.static intndstImageLayout(long struct) Unsafe version ofdstImageLayout().static voidndstImageLayout(long struct, int value) Unsafe version ofdstImageLayout.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 longnsrcBuffer(long struct) Unsafe version ofsrcBuffer().static voidnsrcBuffer(long struct, long value) Unsafe version ofsrcBuffer.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 srcBuffer, long dstImage, int dstImageLayout, VkBufferImageCopy2.Buffer pRegions) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()longthe source buffer.srcBuffer(long value) Sets the specified value to thesrcBuffer()field.intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_COPY_BUFFER_TO_IMAGE_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. -
SRCBUFFER
public static final int SRCBUFFERThe struct member offsets. -
DSTIMAGE
public static final int DSTIMAGEThe struct member offsets. -
DSTIMAGELAYOUT
public static final int DSTIMAGELAYOUTThe struct member offsets. -
REGIONCOUNT
public static final int REGIONCOUNTThe struct member offsets. -
PREGIONS
public static final int PREGIONSThe struct member offsets.
-
-
Constructor Details
-
VkCopyBufferToImageInfo2
Creates aVkCopyBufferToImageInfo2instance 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<VkCopyBufferToImageInfo2>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
srcBuffer
public long srcBuffer()the source buffer. -
dstImage
public long dstImage()the destination image. -
dstImageLayout
public int dstImageLayout()the layout of the destination image subresources for the copy. -
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_BUFFER_TO_IMAGE_INFO_2value to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
srcBuffer
Sets the specified value to thesrcBuffer()field. -
dstImage
Sets the specified value to thedstImage()field. -
dstImageLayout
Sets the specified value to thedstImageLayout()field. -
pRegions
Sets the address of the specifiedVkBufferImageCopy2.Bufferto thepRegions()field. -
set
public VkCopyBufferToImageInfo2 set(int sType, long pNext, long srcBuffer, long dstImage, int dstImageLayout, 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 newVkCopyBufferToImageInfo2instance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkCopyBufferToImageInfo2instance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkCopyBufferToImageInfo2instance allocated withBufferUtils. -
create
Returns a newVkCopyBufferToImageInfo2instance for the specified memory address. -
createSafe
-
malloc
Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkCopyBufferToImageInfo2.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
malloc
Returns a newVkCopyBufferToImageInfo2instance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkCopyBufferToImageInfo2instance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkCopyBufferToImageInfo2.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkCopyBufferToImageInfo2.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkCopyBufferToImageInfo2.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(). -
nsrcBuffer
public static long nsrcBuffer(long struct) Unsafe version ofsrcBuffer(). -
ndstImage
public static long ndstImage(long struct) Unsafe version ofdstImage(). -
ndstImageLayout
public static int ndstImageLayout(long struct) Unsafe version ofdstImageLayout(). -
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. -
nsrcBuffer
public static void nsrcBuffer(long struct, long value) Unsafe version ofsrcBuffer. -
ndstImage
public static void ndstImage(long struct, long value) Unsafe version ofdstImage. -
ndstImageLayout
public static void ndstImageLayout(long struct, int value) Unsafe version ofdstImageLayout. -
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
-