המטא-נתונים של הפריים נוספים ל-Android 11 כחברים בנתוני BufferDesc
שלנו. השדה החדש הזה מוצהר כ-vec<uint8_t>
כדי להתאים
פורמט נתונים בהגדרת הלקוח והוא אטום למנהל הרכב החשמלי (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>
מייצג מערכים בגודל דינמי עם הנתונים
מאוחסנים במאגר נתונים זמני נפרד. מופעים כאלה מיוצגים באמצעות מופע
vec<T>
במבנה,
כלומר, הטמעת מנהל התקן של מצלמת EVS עם HAL היא הבעלים של המטא-נתונים האלה, והם צריכים לנקות
להגדיר אותו כמו שצריך. יש שתי דרכים למלא מטא-נתונים:
- שינוי הגודל של המאגר ומילוי הנתונים באמצעות
operator[]
struct BufferDesc desc = {}; ... desc.metadata.resize(10); for (auto i = 0; i < 10; ++i) { desc.metadata[i] = frameInfo[i]; } ...
- משתמשים בפונקציה
setToExternal()
כדי להפנות נקודה אחת (vec<T>
) למבנה הנתונים המותאם אישית.struct BufferDesc desc = {}; struct FrameMetadata metadata = { ... }; // this is in vendor-defined format.
desc.metadata.setToExternal(&metadata, sizeof(metadata)); ...