Metadane ramek zostały wprowadzone w systemie Android 11 jako element struktury danych BufferDesc. To nowe pole jest zadeklarowane jako vec<uint8_t>
, aby dostosować się do formatu danych zdefiniowanego przez klienta i jest niewidoczne dla menedżera EVS.
struct BufferDesc { /** * HIDL counterpart of AHardwareBuffer_Desc. Please see * hardware/interfaces/graphics/common/1.2/types.hal for more details. */ HardwareBuffer buffer; ... /** * Time that this buffer is being filled. */ int64_t timestamp; /** * Frame metadata field. This is opaque to EVS manager. */ vec<uint8_t> metadata; };
HIDL vec<T>
reprezentuje tablice o dynamicznym rozmiarze z danymi przechowywanymi w oddzielnym buforze. Takie przypadki są reprezentowane przez instancję vec<T>
w strukturze , co oznacza, że implementacja sterownika HAL kamery EVS jest właścicielem tych metadanych i powinna je poprawnie wyczyścić. Istnieją dwa sposoby wypełniania metadanych:
- Zmień rozmiar kontenera i wypełnij dane, używając
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
- Użyj
setToExternal()
, abyvec<T>
wskazywał na niestandardową strukturę danych.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...
Metadane ramek zostały wprowadzone w systemie Android 11 jako element struktury danych BufferDesc. To nowe pole jest zadeklarowane jako vec<uint8_t>
, aby dostosować się do formatu danych zdefiniowanego przez klienta i jest niewidoczne dla menedżera EVS.
struct BufferDesc { /** * HIDL counterpart of AHardwareBuffer_Desc. Please see * hardware/interfaces/graphics/common/1.2/types.hal for more details. */ HardwareBuffer buffer; ... /** * Time that this buffer is being filled. */ int64_t timestamp; /** * Frame metadata field. This is opaque to EVS manager. */ vec<uint8_t> metadata; };
HIDL vec<T>
reprezentuje tablice o dynamicznym rozmiarze z danymi przechowywanymi w oddzielnym buforze. Takie przypadki są reprezentowane przez instancję vec<T>
w strukturze , co oznacza, że implementacja sterownika HAL kamery EVS jest właścicielem tych metadanych i powinna je poprawnie wyczyścić. Istnieją dwa sposoby wypełniania metadanych:
- Zmień rozmiar kontenera i wypełnij dane, używając
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
- Użyj
setToExternal()
, abyvec<T>
wskazywał na niestandardową strukturę danych.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...