Class VkVideoEncodeCapabilitiesKHR
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
Description
Implementations must include support for at least VIDEO_ENCODE_FEEDBACK_BITSTREAM_BUFFER_OFFSET_BIT_KHR and VIDEO_ENCODE_FEEDBACK_BITSTREAM_BYTES_WRITTEN_BIT_KHR in supportedEncodeFeedbackFlags.
encodeInputPictureGranularity provides information about the way encode input picture data is used as input to video encode operations. In particular, some implementations may not be able to limit the set of texels used to encode the output video bitstream to the image subregion specified in the VkVideoPictureResourceInfoKHR structure corresponding to the encode input picture (i.e. to the resolution of the image data to encode specified in its codedExtent member).
Note
For example, the application requests the coded extent to be 1920x1080, but the implementation is only able to source the encode input picture data at the granularity of the codec-specific coding block size which is 16x16 pixels (or as otherwise indicated in encodeInputPictureGranularity). In this example, the content is horizontally aligned with the coding block size, but not vertically aligned with it. Thus encoding of the last row of coding blocks will be impacted by the contents of the input image at texel rows 1080 to 1087 (the latter being the next row which is vertically aligned with the coding block size, assuming a zero-based texel row index).
If codedExtent rounded up to the next integer multiple of encodeInputPictureGranularity is greater than the extent of the image subresource specified for the encode input picture, then the texel values corresponding to texel coordinates outside of the bounds of the image subresource may be undefined. However, implementations should use well-defined default values for such texels in order to maximize the encoding efficiency for the last coding block row/column, and/or to ensure consistent encoding results across repeated encoding of the same input content. Nonetheless, the values used for such texels must not have an effect on whether the video encode operation produces a compliant bitstream, and must not have any other effects on the encoded picture data beyond what may otherwise result from using these texel values as input to any compression algorithm, as defined in the used video compression standard.
Note
While not required, it is generally a good practice for applications to make sure that the image subresource used for the encode input picture has an extent that is an integer multiple of the codec-specific coding block size (or at least encodeInputPictureGranularity) and that this padding area is filled with known values in order to improve encoding efficiency, portability, and reproducibility.
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_VIDEO_ENCODE_CAPABILITIES_KHR
See Also
Layout
struct VkVideoEncodeCapabilitiesKHR {
VkStructureType sType();
void * pNext();
VkVideoEncodeCapabilityFlagsKHR flags();
VkVideoEncodeRateControlModeFlagsKHR rateControlModes();
uint32_t maxRateControlLayers();
uint64_t maxBitrate();
uint32_t maxQualityLevels();
VkExtent2D encodeInputPictureGranularity();
VkVideoEncodeFeedbackFlagsKHR supportedEncodeFeedbackFlags();
}-
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 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
ConstructorsConstructorDescriptionVkVideoEncodeCapabilitiesKHR(ByteBuffer container) Creates aVkVideoEncodeCapabilitiesKHRinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionstatic VkVideoEncodeCapabilitiesKHRcalloc()Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkVideoEncodeCapabilitiesKHRcalloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.static VkVideoEncodeCapabilitiesKHRcreate()Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated withBufferUtils.create(int capacity) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withBufferUtils.static VkVideoEncodeCapabilitiesKHRcreate(long address) Returns a newVkVideoEncodeCapabilitiesKHRinstance for the specified memory address.create(long address, int capacity) Create aVkVideoEncodeCapabilitiesKHR.Bufferinstance at the specified memory.static @Nullable VkVideoEncodeCapabilitiesKHRcreateSafe(long address) static @Nullable VkVideoEncodeCapabilitiesKHR.BuffercreateSafe(long address, int capacity) indicates the granularity at which encode input picture data is encoded and may indicate a texel granularity up to the size of the largest supported codec-specific coding block.intflags()a bitmask ofVkVideoEncodeCapabilityFlagBitsKHRdescribing supported encoding features.static VkVideoEncodeCapabilitiesKHRmalloc()Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated on the specifiedMemoryStack.static VkVideoEncodeCapabilitiesKHRmalloc(org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated on the specifiedMemoryStack.longindicates the maximum supported bitrate.intindicates the number of discrete video encode quality levels supported.intindicates the maximum number of rate control layers supported.static VkExtent2DnencodeInputPictureGranularity(long struct) Unsafe version ofencodeInputPictureGranularity().static intnflags(long struct) Unsafe version offlags().static longnmaxBitrate(long struct) Unsafe version ofmaxBitrate().static intnmaxQualityLevels(long struct) Unsafe version ofmaxQualityLevels().static intnmaxRateControlLayers(long struct) Unsafe version ofmaxRateControlLayers().static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnrateControlModes(long struct) Unsafe version ofrateControlModes().static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.static intnsupportedEncodeFeedbackFlags(long struct) Unsafe version ofsupportedEncodeFeedbackFlags().longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.inta bitmask ofVkVideoEncodeRateControlModeFlagBitsKHRindicating supported rate control modes.set(int sType, long pNext) 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_VIDEO_ENCODE_CAPABILITIES_KHRvalue to thesType()field.inta bitmask ofVkVideoEncodeFeedbackFlagBitsKHRvalues specifying the supported flags for video encode feedback queries.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. -
FLAGS
public static final int FLAGSThe struct member offsets. -
RATECONTROLMODES
public static final int RATECONTROLMODESThe struct member offsets. -
MAXRATECONTROLLAYERS
public static final int MAXRATECONTROLLAYERSThe struct member offsets. -
MAXBITRATE
public static final int MAXBITRATEThe struct member offsets. -
MAXQUALITYLEVELS
public static final int MAXQUALITYLEVELSThe struct member offsets. -
ENCODEINPUTPICTUREGRANULARITY
public static final int ENCODEINPUTPICTUREGRANULARITYThe struct member offsets. -
SUPPORTEDENCODEFEEDBACKFLAGS
public static final int SUPPORTEDENCODEFEEDBACKFLAGSThe struct member offsets.
-
-
Constructor Details
-
VkVideoEncodeCapabilitiesKHR
Creates aVkVideoEncodeCapabilitiesKHRinstance 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<VkVideoEncodeCapabilitiesKHR>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
flags
public int flags()a bitmask ofVkVideoEncodeCapabilityFlagBitsKHRdescribing supported encoding features. -
rateControlModes
public int rateControlModes()a bitmask ofVkVideoEncodeRateControlModeFlagBitsKHRindicating supported rate control modes. -
maxRateControlLayers
public int maxRateControlLayers()indicates the maximum number of rate control layers supported. -
maxBitrate
public long maxBitrate()indicates the maximum supported bitrate. -
maxQualityLevels
public int maxQualityLevels()indicates the number of discrete video encode quality levels supported. Implementations must support at least one quality level. -
encodeInputPictureGranularity
indicates the granularity at which encode input picture data is encoded and may indicate a texel granularity up to the size of the largest supported codec-specific coding block. This capability does not impose any valid usage constraints on the application, however, depending on the contents of the encode input picture, it may have effects on the encoded bitstream, as described in more detail below. -
supportedEncodeFeedbackFlags
public int supportedEncodeFeedbackFlags()a bitmask ofVkVideoEncodeFeedbackFlagBitsKHRvalues specifying the supported flags for video encode feedback queries. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_VIDEO_ENCODE_CAPABILITIES_KHRvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
set
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 newVkVideoEncodeCapabilitiesKHRinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated withBufferUtils. -
create
Returns a newVkVideoEncodeCapabilitiesKHRinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkVideoEncodeCapabilitiesKHR.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
-
malloc
Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkVideoEncodeCapabilitiesKHRinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkVideoEncodeCapabilitiesKHR.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHR.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkVideoEncodeCapabilitiesKHR.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkVideoEncodeCapabilitiesKHR.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(). -
nflags
public static int nflags(long struct) Unsafe version offlags(). -
nrateControlModes
public static int nrateControlModes(long struct) Unsafe version ofrateControlModes(). -
nmaxRateControlLayers
public static int nmaxRateControlLayers(long struct) Unsafe version ofmaxRateControlLayers(). -
nmaxBitrate
public static long nmaxBitrate(long struct) Unsafe version ofmaxBitrate(). -
nmaxQualityLevels
public static int nmaxQualityLevels(long struct) Unsafe version ofmaxQualityLevels(). -
nencodeInputPictureGranularity
Unsafe version ofencodeInputPictureGranularity(). -
nsupportedEncodeFeedbackFlags
public static int nsupportedEncodeFeedbackFlags(long struct) Unsafe version ofsupportedEncodeFeedbackFlags(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext.
-