I metadati dei frame vengono introdotti in Android 11 come membro della struttura dati BufferDesc. Questo nuovo campo è dichiarato come vec<uint8_t>
per accogliere un formato dati definito dal cliente ed è opaco per il gestore 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>
rappresenta array di dimensioni dinamiche con i dati archiviati in un buffer separato. Tali istanze sono rappresentate con un'istanza di vec<T>
nella struct , il che significa che l'implementazione del driver HAL della fotocamera EVS possiede questi metadati e dovrebbe ripulirli correttamente. Esistono due modi per compilare i metadati:
- Ridimensionare il contenitore e inserire i dati utilizzando
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
- Utilizza
setToExternal()
per fare in modovec<T>
punti alla struttura dati personalizzata.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...
I metadati dei frame vengono introdotti in Android 11 come membro della struttura dati BufferDesc. Questo nuovo campo è dichiarato come vec<uint8_t>
per accogliere un formato dati definito dal cliente ed è opaco per il gestore 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>
rappresenta array di dimensioni dinamiche con i dati archiviati in un buffer separato. Tali istanze sono rappresentate con un'istanza di vec<T>
nella struct , il che significa che l'implementazione del driver HAL della fotocamera EVS possiede questi metadati e dovrebbe ripulirli correttamente. Esistono due modi per compilare i metadati:
- Ridimensionare il contenitore e inserire i dati utilizzando
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
- Utilizza
setToExternal()
per fare in modovec<T>
punti alla struttura dati personalizzata.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...