fuchsia.camera2

已新增:7

專家

經理

定義位置: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
1

建立影格時發生錯誤。與這則通知對應的資料緩衝區中不會顯示任何資料。

2

資料緩衝區中沒有可用的空間,導致影格遭到捨棄。

資料表

DeviceInfo

定義於 fuchsia.camera2/manager.fidl

裝置相關資訊。

序數欄位類型說明
vendor_id uint16

來自實體裝置列舉的資訊:

vendor_name string[255]
product_id uint16
product_name string[255]
type DeviceType

裝置類型相關資訊:

FrameMetadata

定義位置:fuchsia.camera2/stream.fidl

序數欄位類型說明
timestamp int64
image_format_index uint32

|image_format_index| 會將索引參照至串流支援的可用格式向量。

capture_timestamp int64

在用來建構這個影格的緩衝區從 ISP 收到時,系統單聲道時鐘的值。

StreamConstraints

定義於 fuchsia.camera2/manager.fidl

要求串流時,系統會將這些限制條件傳送給相機管理員。相機管理員將會使用這些限制來比對適當的串流。

序數欄位類型說明
properties StreamProperties

這個表格用於說明串流的屬性。您指定的所有屬性都會視為相符串流的要求。

format_index uint32

如已指定,系統就會使用這個索引建立串流,做為初始格式索引。 如未指定,系統會使用第一個串流格式。

StreamProperties

定義位置:fuchsia.camera2/stream.fidl

序數欄位類型說明
stream_type CameraStreamType

這些可能是上述一或多個串流類型

節拍

CameraStreamType 嚴格

類型:uint32

定義於 fuchsia.camera2/stream.fidl

相機堆疊提供的各種串流類型。

名稱說明
1

機器學習要求 FR(Full Resolution) 串流,以及安全性用途的 DS(向下擴充解析度) 串流,提供固定解析度的

2

這是安全性視訊串流,可在執行階段支援多種解析度。

4
8

機器學習要求 DS 串流以提供固定解析度的視訊會議

16

這是可用於執行階段的多個解析度的視訊會議串流。

32

視野更廣的串流。

場景

名稱類型說明
MAX_IMAGE_FORMATS 256 uint64

每個串流的圖片格式數量上限。