專家
經理
定義位置:fuchsia.camera2/manager.fidl
AcknowledgeDeviceEvent
必須在上述任一事件發生後呼叫 AcknowledgeDeviceEvent,之後才會傳送其他事件。
要求
<EMPTY>
ConnectToStream
連線到相機串流:
device_id
是指 OnDeviceAvailable 所宣傳的特定 device_id。
constraints
針對要求的串流含有一組限制。相機管理員會嘗試尋找符合限制條件的串流。如果有多個串流相符,系統會連結其中一個相符的串流。token
是指用於透過串流通訊協定傳送圖片的 Sysmem 緩衝區分配。相機管理員會套用與圖片格式相關的 BufferCollectionContraints,因此用戶端不需要套用任何 ImageFormatConstraint。系統會假設同步處理作業已在 token
上呼叫,然後才將其傳遞至 ConnectToStream。由於 constraints
可能無法指定特定格式,因此回應中會顯示串流圖片的初始格式。除非 stream
已關閉,否則提供回應後,系統會將連線視為成功。
要求
名稱 | 類型 |
---|---|
device_id |
int32
|
constraints |
StreamConstraints
|
token |
fuchsia.sysmem/BufferCollectionToken
|
stream |
server_end<Stream>
|
回應
名稱 | 類型 |
---|---|
format |
fuchsia.sysmem/ImageFormat_2
|
OnDeviceAvailable
有相機可供使用時通知用戶端。當用戶端首次連線至這個通訊協定時,系統會傳送其中幾個事件。device_id
是用來識別相機。在相機的整個生命週期中,device_id 不應變更。當相機管理員通知用戶端目前已知的所有裝置時,last_known_camera
會設為 true。description
會說明相機的屬性。
回應
名稱 | 類型 |
---|---|
device_id |
int32
|
description |
DeviceInfo
|
last_known_camera |
bool
|
OnDeviceMuteChanged
在攝影機設為靜音或取消靜音時通知用戶端。device_id
是指先前 OnDeviceAvailable 呼叫說明中的 device_id。
回應
名稱 | 類型 |
---|---|
device_id |
int32
|
currently_muted |
bool
|
OnDeviceUnavailable
在相機無法使用時通知用戶端。
回應
名稱 | 類型 |
---|---|
device_id |
int32
|
MuteControl
定義位置:fuchsia.camera2/manager.fidl
靜音
關閉攝影機。這與停止或關閉串流無關。在呼叫取消靜音之前,靜音相機不會產生更多圖片。您仍然可以從靜音的攝影機連線至串流,但除非攝影機取消靜音,否則不會產生畫面。device_id
是指先前的 OnDeviceAvailable 呼叫中的 device_id。
要求
名稱 | 類型 |
---|---|
device_id |
int32
|
回應
名稱 | 類型 |
---|---|
status |
zx/Status
|
取消靜音
要求
名稱 | 類型 |
---|---|
device_id |
int32
|
回應
名稱 | 類型 |
---|---|
status |
zx/Status
|
湖水綠
定義位置:fuchsia.camera2/stream.fidl
AcknowledgeFrameError
提供流量控制以接收影格錯誤。請參閱 OnFrameAvailable 註解。
要求
<EMPTY>
GetBuffers
將權杖傳回至緩衝區,用來在串流中輸出影格。符記為 dispensable
,表示無須開啟 sysmem 也能完成分配作業。這也表示,傳回權杖的所有 SetConstraints 呼叫都不會與 StreamConfig
中的限制衝突,否則嘗試等待權杖上的緩衝區失敗。
要求
<EMPTY>
回應
名稱 | 類型 |
---|---|
token |
fuchsia.sysmem/BufferCollectionToken
|
GetImageFormats
取得這個串流支援的圖片格式。
要求
<EMPTY>
回應
名稱 | 類型 |
---|---|
image_formats |
vector<fuchsia.sysmem/ImageFormat_2>[256]
|
OnFrameAvailable
在有可用於處理的影格或發生錯誤時,驅動程式庫將訊息傳送至用戶端。收到這則訊息後,用戶端會將該影格視為已鎖定。用戶端必須呼叫 ReleaseFrame 來釋放非錯誤影格的讀取鎖定,否則取用端最終會用盡緩衝區。如果影格發生錯誤,用戶端必須先呼叫 AcknowledgeFrameError,再透過錯誤影格呼叫另一個 OnFrameAvailable。
回應
名稱 | 類型 |
---|---|
frame |
FrameAvailableInfo
|
ReleaseFrame
解鎖指定影格,允許驅動程式庫重複使用記憶體。
要求
名稱 | 類型 |
---|---|
buffer_id |
uint32
|
SetImageFormat
變更訊息串的圖片格式。當用戶端想在串流期間動態變更串流解析度時,就會呼叫此方法。
要求
名稱 | 類型 |
---|---|
image_format_index |
uint32
|
回應
名稱 | 類型 |
---|---|
s |
zx/Status
|
SetRegionOfInterest
資料作業 用戶端會使用這個欄位來提供選擇意願區域的輸入內容。輸入內容是新定界框的 x 和 y 座標。如果串流不支援智慧取景,則會傳回錯誤。
要求
名稱 | 類型 |
---|---|
x_min |
float32
|
y_min |
float32
|
x_max |
float32
|
y_max |
float32
|
回應
名稱 | 類型 |
---|---|
s |
zx/Status
|
開始
控制項作業會啟動影格串流。
要求
<EMPTY>
停止
停止串流影格。
要求
<EMPTY>
結構
FrameAvailableInfo
定義於 fuchsia.camera2/stream.fidl
在有可用於處理的影格或發生錯誤時,驅動程式庫將訊息傳送至用戶端。
欄位 | 類型 | 說明 | 預設 |
---|---|---|---|
frame_status |
FrameStatus
|
如果發生錯誤,則為非零。 |
無預設 |
buffer_id |
uint32
|
緩衝區集合中的緩衝區索引。 |
無預設 |
metadata |
FrameMetadata
|
無預設 |
FrameRate
定義位置:fuchsia.camera2/stream.fidl
欄位 | 類型 | 說明 | 預設 |
---|---|---|---|
frames_per_sec_numerator |
uint32
|
畫面更新率是 frame_per_sec_numerator / frame_per_sec_denominator。 |
無預設 |
frames_per_sec_denominator |
uint32
|
無預設 |
表情符號
DeviceType 嚴格
類型:uint32
定義位置:fuchsia.camera2/manager.fidl
名稱 | 值 | 說明 |
---|---|---|
內建 |
1 |
|
虛擬 |
2 |
FrameStatus strict
類型:uint32
定義於 fuchsia.camera2/stream.fidl
影格已發出訊號時要設定的狀態。
名稱 | 值 | 說明 |
---|---|---|
確定 |
0 |
|
ERROR_FRAME |
1 |
建立影格時發生錯誤。與這則通知對應的資料緩衝區中不會顯示任何資料。 |
ERROR_BUFFER_FULL |
2 |
資料緩衝區中沒有可用的空間,導致影格遭到捨棄。 |
資料表
DeviceInfo
定義於 fuchsia.camera2/manager.fidl
裝置相關資訊。
序數 | 欄位 | 類型 | 說明 |
---|---|---|---|
1 |
vendor_id |
uint16
|
來自實體裝置列舉的資訊: |
2 |
vendor_name |
string[255]
|
|
3 |
product_id |
uint16
|
|
4 |
product_name |
string[255]
|
|
5 |
type |
DeviceType
|
裝置類型相關資訊: |
FrameMetadata
定義位置:fuchsia.camera2/stream.fidl
序數 | 欄位 | 類型 | 說明 |
---|---|---|---|
1 |
timestamp |
int64
|
|
2 |
image_format_index |
uint32
|
|image_format_index| 會將索引參照至串流支援的可用格式向量。 |
3 |
capture_timestamp |
int64
|
在用來建構這個影格的緩衝區從 ISP 收到時,系統單聲道時鐘的值。 |
StreamConstraints
定義於 fuchsia.camera2/manager.fidl
要求串流時,系統會將這些限制條件傳送給相機管理員。相機管理員將會使用這些限制來比對適當的串流。
序數 | 欄位 | 類型 | 說明 |
---|---|---|---|
1 |
properties |
StreamProperties
|
這個表格用於說明串流的屬性。您指定的所有屬性都會視為相符串流的要求。 |
2 |
format_index |
uint32
|
如已指定,系統就會使用這個索引建立串流,做為初始格式索引。 如未指定,系統會使用第一個串流格式。 |
StreamProperties
定義位置:fuchsia.camera2/stream.fidl
序數 | 欄位 | 類型 | 說明 |
---|---|---|---|
1 |
stream_type |
CameraStreamType
|
這些可能是上述一或多個串流類型 |
節拍
CameraStreamType 嚴格
類型:uint32
定義於 fuchsia.camera2/stream.fidl
相機堆疊提供的各種串流類型。
名稱 | 值 | 說明 |
---|---|---|
MACHINE_LEARNING |
1 | 機器學習要求 FR(Full Resolution) 串流,以及安全性用途的 DS(向下擴充解析度) 串流,提供固定解析度的 |
監控 |
2 | 這是安全性視訊串流,可在執行階段支援多種解析度。 |
FULL_RESOLUTION |
4 | |
DOWNSCALED_RESOLUTION |
8 | 機器學習要求 DS 串流以提供固定解析度的視訊會議 |
VIDEO_CONFERENCE |
16 | 這是可用於執行階段的多個解析度的視訊會議串流。 |
EXTENDED_FOV |
32 | 視野更廣的串流。 |
場景
名稱 | 值 | 類型 | 說明 |
---|---|---|---|
MAX_IMAGE_FORMATS |
256
|
uint64 |
每個串流的圖片格式數量上限。 |