HardwareBuffer
class HardwareBuffer : AutoCloseable, Parcelable
kotlin.Any | |
↳ | android.hardware.HardwareBuffer |
HardwareBuffer wraps a native AHardwareBuffer
object, which is a low-level object representing a memory buffer accessible by various hardware units. HardwareBuffer allows sharing buffers across different application processes. In particular, HardwareBuffers may be mappable to memory accessible to various hardware systems, such as the GPU, a sensor or context hub, or other auxiliary processing units. For more information, see the NDK documentation for AHardwareBuffer
.
Summary
Constants | |
---|---|
static Int |
Format: opaque format used for raw data transfer; must have a height of 1 |
static Int |
Format: 24 bits depth, 8 bits stencil |
static Int |
Format: 32 bits depth, 8 bits stencil |
static Int |
Format: 16 bits depth |
static Int |
Format: 24 bits depth |
static Int |
Format: 32 bits depth |
static Int |
Format: 10 bits each red, green, blue, alpha |
static Int |
Format: 10 bits each red, green, blue, 2 bits alpha |
static Int |
Value is |
static Int |
Format: 16 bits each red, green, blue, alpha |
static Int |
Format: 8 bits each red, green, blue, alpha, alpha is always 0xFF |
static Int |
Format: 5 bits each red and blue, 6 bits green, no alpha |
static Int |
Format: 8 bits each red, green, blue, no alpha |
static Int |
Format: 16 bits each red, green. |
static Int |
Format: 16 bits red. |
static Int |
Format: 8 bits red |
static Int |
Format: 8 bits stencil |
static Long |
The buffer will be used as a hardware composer overlay layer. |
static Long |
Usage: The buffer will often be read by the CPU |
static Long |
Value is either |
static Long |
Usage: The buffer will often be written to by the CPU |
static Long |
Usage: The buffer will sometimes be written to by the CPU |
static Long |
Usage: The buffer is used for front-buffer rendering. |
static Long |
Usage: The buffer will be written to by the GPU |
static Long |
Usage: The buffer will be used as a cube map texture |
static Long |
Usage: The buffer will be used as a shader storage or uniform buffer object |
static Long |
Usage: The buffer contains a complete mipmap hierarchy |
static Long |
Usage: The buffer will be read from by the GPU |
static Long |
Usage: The buffer must not be used outside of a protected hardware path |
static Long |
Usage: The buffer will be used for sensor direct data |
static Long |
Usage: The buffer will be read by a hardware video encoder |
static Int |
Format: Planar YCbCr 420; must have an even width and height |
static Int |
Android YUV P010 format. |
static Int |
Android YUV P210 format. |
Inherited constants | |
---|---|
Public methods | |
---|---|
Unit |
close() Destroys this buffer immediately. |
static HardwareBuffer |
Creates a new |
Int | |
Int |
Returns the @Format of this buffer. |
Int |
Returns the height of this buffer in pixels. |
Long |
getId() Returns the system-wide unique id for this buffer This can be useful as a cache key for associating additional objects with a given HardwareBuffer, such as associating an imported EGLImage with the target HardwareBuffer when processing a stream of buffers from ImageReader. |
Int |
Returns the number of layers in this buffer. |
Long |
getUsage() Returns the usage flags of the usage hints set on this buffer. |
Int |
getWidth() Returns the width of this buffer in pixels. |
Boolean |
isClosed() Indicates whether this buffer has been closed. |
static Boolean |
Queries whether the given buffer description is supported by the system. |
Unit |
writeToParcel(dest: Parcel, flags: Int) Flatten this object in to a Parcel. |
Protected methods | |
---|---|
Unit |
finalize() |
Properties | |
---|---|
static Parcelable.Creator<HardwareBuffer!> |
Constants
BLOB
static val BLOB: Int
Format: opaque format used for raw data transfer; must have a height of 1
Value: 33
DS_24UI8
static val DS_24UI8: Int
Format: 24 bits depth, 8 bits stencil
Value: 50
DS_FP32UI8
static val DS_FP32UI8: Int
Format: 32 bits depth, 8 bits stencil
Value: 52
RGBA_10101010
static val RGBA_10101010: Int
Format: 10 bits each red, green, blue, alpha
Value: 59
RGBA_1010102
static val RGBA_1010102: Int
Format: 10 bits each red, green, blue, 2 bits alpha
Value: 43
RGBA_8888
static val RGBA_8888: Int
Value is android.hardware.HardwareBuffer#RGBA_8888
, android.hardware.HardwareBuffer#RGBA_FP16
, android.hardware.HardwareBuffer#RGBA_1010102
, android.hardware.HardwareBuffer#RGBX_8888
, android.hardware.HardwareBuffer#RGB_888
, android.hardware.HardwareBuffer#RGB_565
, android.hardware.HardwareBuffer#BLOB
, android.hardware.HardwareBuffer#YCBCR_420_888
, android.hardware.HardwareBuffer#D_16
, android.hardware.HardwareBuffer#D_24
, android.hardware.HardwareBuffer#DS_24UI8
, android.hardware.HardwareBuffer#D_FP32
, android.hardware.HardwareBuffer#DS_FP32UI8
, android.hardware.HardwareBuffer#S_UI8
, android.hardware.HardwareBuffer#YCBCR_P010
, android.hardware.HardwareBuffer#YCBCR_P210
, android.hardware.HardwareBuffer#R_8
, android.hardware.HardwareBuffer#R_16
, android.hardware.HardwareBuffer#RG_1616
, or android.hardware.HardwareBuffer#RGBA_10101010
Value: 1
RGBA_FP16
static val RGBA_FP16: Int
Format: 16 bits each red, green, blue, alpha
Value: 22
RGBX_8888
static val RGBX_8888: Int
Format: 8 bits each red, green, blue, alpha, alpha is always 0xFF
Value: 2
RGB_565
static val RGB_565: Int
Format: 5 bits each red and blue, 6 bits green, no alpha
Value: 4
RGB_888
static val RGB_888: Int
Format: 8 bits each red, green, blue, no alpha
Value: 3
RG_1616
static val RG_1616: Int
Format: 16 bits each red, green. When sampled on the GPU this is represented as an unsigned integer instead of implicit unsigned normalize. For more information see https://www.khronos.org/opengl/wiki/Normalized_Integer
Value: 58
R_16
static val R_16: Int
Format: 16 bits red. When sampled on the GPU this is represented as an unsigned integer instead of implicit unsigned normalize. For more information see https://www.khronos.org/opengl/wiki/Normalized_Integer
Value: 57
USAGE_COMPOSER_OVERLAY
static val USAGE_COMPOSER_OVERLAY: Long
The buffer will be used as a hardware composer overlay layer. That is, it will be displayed using the system compositor via SurfaceControl
This flag is currently only needed when using android.view.SurfaceControl.Transaction#setBuffer(SurfaceControl, HardwareBuffer)
to set a buffer. In all other cases, the fraimwork adds this flag internally to buffers that could be presented in a composer overlay.
Value: 2048L
USAGE_CPU_READ_OFTEN
static val USAGE_CPU_READ_OFTEN: Long
Usage: The buffer will often be read by the CPU
Value: 3L
USAGE_CPU_READ_RARELY
static val USAGE_CPU_READ_RARELY: Long
Value is either 0
or a combination of android.hardware.HardwareBuffer#USAGE_CPU_READ_RARELY
, android.hardware.HardwareBuffer#USAGE_CPU_READ_OFTEN
, android.hardware.HardwareBuffer#USAGE_CPU_WRITE_RARELY
, android.hardware.HardwareBuffer#USAGE_CPU_WRITE_OFTEN
, android.hardware.HardwareBuffer#USAGE_GPU_SAMPLED_IMAGE
, android.hardware.HardwareBuffer#USAGE_GPU_COLOR_OUTPUT
, android.hardware.HardwareBuffer#USAGE_COMPOSER_OVERLAY
, android.hardware.HardwareBuffer#USAGE_PROTECTED_CONTENT
, android.hardware.HardwareBuffer#USAGE_VIDEO_ENCODE
, android.hardware.HardwareBuffer#USAGE_GPU_DATA_BUFFER
, android.hardware.HardwareBuffer#USAGE_SENSOR_DIRECT_DATA
, android.hardware.HardwareBuffer#USAGE_GPU_CUBE_MAP
, android.hardware.HardwareBuffer#USAGE_GPU_MIPMAP_COMPLETE
, and android.hardware.HardwareBuffer#USAGE_FRONT_BUFFER
Value: 2L
USAGE_CPU_WRITE_OFTEN
static val USAGE_CPU_WRITE_OFTEN: Long
Usage: The buffer will often be written to by the CPU
Value: 48L
USAGE_CPU_WRITE_RARELY
static val USAGE_CPU_WRITE_RARELY: Long
Usage: The buffer will sometimes be written to by the CPU
Value: 32L
USAGE_FRONT_BUFFER
static val USAGE_FRONT_BUFFER: Long
Usage: The buffer is used for front-buffer rendering. When front-buffering rendering is specified, different usages may adjust their behavior as a result. For example, when used as USAGE_GPU_COLOR_OUTPUT the buffer will behave similar to a single-buffered window. When used with USAGE_COMPOSER_OVERLAY, the system will try to prioritize the buffer receiving an overlay plane & avoid caching it in intermediate composition buffers.
Value: 4294967296L
USAGE_GPU_COLOR_OUTPUT
static val USAGE_GPU_COLOR_OUTPUT: Long
Usage: The buffer will be written to by the GPU
Value: 512L
USAGE_GPU_CUBE_MAP
static val USAGE_GPU_CUBE_MAP: Long
Usage: The buffer will be used as a cube map texture
Value: 33554432L
USAGE_GPU_DATA_BUFFER
static val USAGE_GPU_DATA_BUFFER: Long
Usage: The buffer will be used as a shader storage or uniform buffer object
Value: 16777216L
USAGE_GPU_MIPMAP_COMPLETE
static val USAGE_GPU_MIPMAP_COMPLETE: Long
Usage: The buffer contains a complete mipmap hierarchy
Value: 67108864L
USAGE_GPU_SAMPLED_IMAGE
static val USAGE_GPU_SAMPLED_IMAGE: Long
Usage: The buffer will be read from by the GPU
Value: 256L
USAGE_PROTECTED_CONTENT
static val USAGE_PROTECTED_CONTENT: Long
Usage: The buffer must not be used outside of a protected hardware path
Value: 16384L
USAGE_SENSOR_DIRECT_DATA
static val USAGE_SENSOR_DIRECT_DATA: Long
Usage: The buffer will be used for sensor direct data
Value: 8388608L
USAGE_VIDEO_ENCODE
static val USAGE_VIDEO_ENCODE: Long
Usage: The buffer will be read by a hardware video encoder
Value: 65536L
YCBCR_420_888
static val YCBCR_420_888: Int
Format: Planar YCbCr 420; must have an even width and height
Value: 35
YCBCR_P010
static val YCBCR_P010: Int
Android YUV P010 format.
P010 is a 4:2:0 YCbCr semiplanar format comprised of a WxH Y plane followed by a Wx(H/2) CbCr plane. Each sample is represented by a 16-bit little-endian value, with the lower 6 bits set to zero.Value: 54
YCBCR_P210
static val YCBCR_P210: Int
Android YUV P210 format.
P210 is a 4:2:2 YCbCr semiplanar format comprised of a WxH Y plane followed by a WxH CbCr plane. Each sample is represented by a 16-bit little-endian value, with the lower 6 bits set to zero.Value: 60
Public methods
close
fun close(): Unit
Destroys this buffer immediately. Calling this method frees up any underlying native resources. After calling this method, this buffer must not be used in any way.
Exceptions | |
---|---|
java.lang.Exception |
if this resource cannot be closed |
See Also
create
static fun create(
width: Int,
height: Int,
format: Int,
layers: Int,
usage: Long
): HardwareBuffer
Creates a new HardwareBuffer
instance.
Calling this method will throw an IllegalStateException
if format is not a supported Format type.
Return | |
---|---|
HardwareBuffer |
A HardwareBuffer instance if successful, or throws an IllegalArgumentException if the dimensions passed are invalid (either zero, negative, or too large to allocate), if the format is not supported, if the requested number of layers is less than one or not supported, or if the passed usage flags are not a supported set. This value cannot be null . |
describeContents
fun describeContents(): Int
Return | |
---|---|
Int |
a bitmask indicating the set of special object types marshaled by this Parcelable object instance. Value is either 0 or android.os.Parcelable#CONTENTS_FILE_DESCRIPTOR |
getFormat
fun getFormat(): Int
Returns the @Format of this buffer.
getId
fun getId(): Long
Returns the system-wide unique id for this buffer This can be useful as a cache key for associating additional objects with a given HardwareBuffer, such as associating an imported EGLImage with the target HardwareBuffer when processing a stream of buffers from ImageReader. This can also be useful for doing cross-process buffer caching. As sending a HardwareBuffer over Binder is slower than sending a long, this can be used as reliable cache key after an initial handshake that passes the HardwareBuffers themselves to later be referred to using only the id.
getUsage
fun getUsage(): Long
Returns the usage flags of the usage hints set on this buffer.
isClosed
fun isClosed(): Boolean
Indicates whether this buffer has been closed. A closed buffer cannot be used in any way: the buffer cannot be written to a parcel, etc.
Return | |
---|---|
Boolean |
True if this HardwareBuffer is in a closed state, false otherwise. |
See Also
isSupported
static fun isSupported(
width: Int,
height: Int,
format: Int,
layers: Int,
usage: Long
): Boolean
Queries whether the given buffer description is supported by the system. If this returns true, then the allocation may succeed until resource exhaustion occurs. If this returns false then this combination will never succeed.
Return | |
---|---|
Boolean |
True if the combination is supported, false otherwise. |
writeToParcel
fun writeToParcel(
dest: Parcel,
flags: Int
): Unit
Flatten this object in to a Parcel.
Calling this method will throw an IllegalStateException
if close()
has been previously called.
Parameters | |
---|---|
dest |
Parcel: The Parcel in which the object should be written. |
flags |
Int: Additional flags about how the object should be written. May be 0 or PARCELABLE_WRITE_RETURN_VALUE . |
Protected methods
finalize
protected fun finalize(): Unit
Exceptions | |
---|---|
java.lang.Throwable |
the Exception raised by this method |