Çerçeve meta verileri, Android 11'de BufferDesc veri yapısının bir üyesi olarak tanıtıldı. Bu yeni alan, müşteri tanımlı bir veri formatına uyum sağlamak için vec<uint8_t>
olarak bildirilir ve EVS yöneticisi için opaktır.
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>
verileri ayrı bir arabellekte depolanan dinamik olarak boyutlandırılmış dizileri temsil eder. Bu tür örnekler struct dosyasında vec<T>
örneğiyle temsil edilir; bu, EVS Kamera HAL sürücüsü uygulamasının bu meta verilere sahip olduğu ve onu uygun şekilde temizlemesi gerektiği anlamına gelir. Meta verileri doldurmanın iki yolu vardır:
- Container'ı yeniden boyutlandırın ve
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
kullanarak verileri doldurun -
vec<T>
özel veri yapınıza işaret etmesini sağlamak içinsetToExternal()
öğesini kullanın.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...
Çerçeve meta verileri, Android 11'de BufferDesc veri yapısının bir üyesi olarak tanıtıldı. Bu yeni alan, müşteri tanımlı bir veri formatına uyum sağlamak için vec<uint8_t>
olarak bildirilir ve EVS yöneticisi için opaktır.
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>
verileri ayrı bir arabellekte depolanan dinamik olarak boyutlandırılmış dizileri temsil eder. Bu tür örnekler struct dosyasında vec<T>
örneğiyle temsil edilir; bu, EVS Kamera HAL sürücüsü uygulamasının bu meta verilere sahip olduğu ve onu uygun şekilde temizlemesi gerektiği anlamına gelir. Meta verileri doldurmanın iki yolu vardır:
- Container'ı yeniden boyutlandırın ve
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
kullanarak verileri doldurun -
vec<T>
özel veri yapınıza işaret etmesini sağlamak içinsetToExternal()
öğesini kullanın.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...