自 2025 年 3 月 27 日起,我們建議您使用 android-latest-release
而非 aosp-main
建構及貢獻 AOSP。詳情請參閱「Android 開放原始碼計畫變更」。
透過集合功能整理內容
你可以依據偏好儲存及分類內容。
camera_device_ops 結構參考資料
#include <
camera.h
>
|
int(*
|
set_preview_window
)(struct
camera_device
*, struct
preview_stream_ops
*window)
|
|
void(*
|
set_callbacks
)(struct
camera_device
*,
camera_notify_callback
notify_cb,
camera_data_callback
data_cb,
camera_data_timestamp_callback
data_cb_timestamp,
camera_request_memory
get_memory, void *user)
|
|
void(*
|
enable_msg_type
)(struct
camera_device
*, int32_t msg_type)
|
|
void(*
|
disable_msg_type
)(struct
camera_device
*, int32_t msg_type)
|
|
int(*
|
msg_type_enabled
)(struct
camera_device
*, int32_t msg_type)
|
|
int(*
|
start_preview
)(struct
camera_device
*)
|
|
void(*
|
stop_preview
)(struct
camera_device
*)
|
|
int(*
|
preview_enabled
)(struct
camera_device
*)
|
|
int(*
|
store_meta_data_in_buffers
)(struct
camera_device
*, int enable)
|
|
int(*
|
start_recording
)(struct
camera_device
*)
|
|
void(*
|
stop_recording
)(struct
camera_device
*)
|
|
int(*
|
recording_enabled
)(struct
camera_device
*)
|
|
void(*
|
release_recording_frame
)(struct
camera_device
*, const void *opaque)
|
|
int(*
|
auto_focus
)(struct
camera_device
*)
|
|
int(*
|
cancel_auto_focus
)(struct
camera_device
*)
|
|
int(*
|
take_picture
)(struct
camera_device
*)
|
|
int(*
|
cancel_picture
)(struct
camera_device
*)
|
|
int(*
|
set_parameters
)(struct
camera_device
*, const char *parms)
|
|
char *(*
|
get_parameters
)(struct
camera_device
*)
|
|
void(*
|
put_parameters
)(struct
camera_device
*, char *)
|
|
int(*
|
send_command
)(struct
camera_device
*, int32_t cmd, int32_t arg1, int32_t arg2)
|
|
void(*
|
release
)(struct
camera_device
*)
|
|
int(*
|
dump
)(struct
camera_device
*, int fd)
|
|
開始自動對焦,在對焦完成時,系統會使用 CAMERA_MSG_FOCUS 呼叫通知回呼例行程序。如果需要其他自動對焦,系統會再次呼叫 autoFocus()。
定義位於檔案
camera.h
的
227
行。
取消自動對焦功能。如果自動對焦功能仍在進行,此函式會取消該功能。無論是否正在進行自動對焦,這個函式都會將對焦位置設回預設值。如果相機不支援自動對焦,則不會執行此操作。
定義位於檔案
camera.h
的
235
行。
取消使用 takePicture 啟動的拍照作業。在未拍攝相片時呼叫此方法會導致無操作。
定義位於檔案
camera.h
的
246
行。
void(* disable_msg_type)(struct
camera_device
*, int32_t msg_type)
|
停用單一或多則訊息。
收到對 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 的呼叫後,相機 HAL 不應依賴其用戶端呼叫 releaseRecordingFrame(),以便在 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 呼叫前後釋放相機 HAL 傳送的錄影影格。呼叫 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 後,攝影機 HAL 用戶端不得修改/存取任何錄影影格。
定義位於檔案
camera.h
的
132
行。
void(* enable_msg_type)(struct
camera_device
*, int32_t msg_type)
|
以下三個函式都會使用 msg_type,這是在 include/ui/Camera.h 中定義的訊息位元遮罩,可啟用訊息或一組訊息。
定義位於檔案
camera.h
的
120
行。
擷取相機參數。如果 put_parameters 不為空值,則攝影機 HAL 傳回的緩衝區必須透過 put_parameters 傳回。
定義位於檔案
camera.h
的
258
行。
int(* msg_type_enabled)(struct
camera_device
*, int32_t msg_type)
|
查詢訊息或一組訊息是否已啟用。請注意,這項運算會以 AND 運算方式運作,如果查詢的任何訊息都關閉,這項運算會傳回 false。
定義位於檔案
camera.h
的
139
行。
當我們呼叫 get_parameters 時,相機 HAL 會使用自己的記憶體傳遞參數。如果 put_parameters 不是 NULL,請使用這個函式將記憶體傳回至相機 HAL。如果 put_parameters 為空值,您必須使用 free() 釋放記憶體。
定義位於檔案
camera.h
的
265
行。
釋出此物件擁有的硬體資源。請注意,這並
不是在析構函式中執行。
定義位於檔案
camera.h
的
277
行。
void(* release_recording_frame)(struct
camera_device
*, const void *opaque)
|
釋放先前由 CAMERA_MSG_VIDEO_FRAME 傳回的記錄影格。
在相機 HAL 接收 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 的呼叫之前,相機 HAL 用戶端必須釋放相機 HAL 傳送的錄影影格。接收到呼叫 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 後,相機 HAL 就負責管理錄影影格生命週期。
定義位於檔案
camera.h
的
219
行。
int(* send_command)(struct
camera_device
*, int32_t cmd, int32_t arg1, int32_t arg2)
|
設定攝影機參數。如果任何參數無效或不受支援,這個函式會傳回 BAD_VALUE。
定義位於檔案
camera.h
的
252
行。
開始錄製模式。當可使用記錄影像時,系統會傳送 CAMERA_MSG_VIDEO_FRAME 訊息,並附上對應的影格。在用戶端呼叫 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 之前,每個記錄影格都必須由相機 HAL 用戶端透過 releaseRecordingFrame() 釋出。在用戶端呼叫 disableMsgType(CAMERA_MSG_VIDEO_FRAME) 後,攝影機 HAL 就負責管理錄影影格生命週期,用戶端不得修改/存取任何錄影影格。
定義位於檔案
camera.h
的
198
行。
int(* store_meta_data_in_buffers)(struct
camera_device
*, int enable)
|
要求相機 HAL 在錄影期間透過 CAMERA_MSG_VIDEO_FRAME 傳送的視訊緩衝區中儲存中繼資料或實際 YUV 資料。如果未呼叫,預設相機 HAL 行為會在影片緩衝區中儲存實際的 YUV 資料。
為了確保有效,請先呼叫這個方法,再呼叫 startRecording()。
如果中繼資料儲存在影片緩衝區中,則影片緩衝區的接收端必須解讀內容,並利用緩衝區中的中繼資料找出實際影格資料。這項操作的執行方式不在本方法的討論範圍內。
部分相機 HAL 可能不支援在影片緩衝區中儲存中繼資料,但所有相機 HAL 都應支援在影片緩衝區中儲存實際的 YUV 資料。如果相機 HAL 在收到要求時不支援在影片緩衝區中儲存中繼資料,就必須傳回 INVALID_OPERATION。在影片大小很大的情況下,未壓縮的框架資料量可能會非常大,因此讓相機 HAL 直接將中繼資料,而非實際的框架資料傳遞給影片編碼器,是非常實用的做法。
-
參數
-
啟用 |
如果設為 true,則會指示相機 HAL 將中繼資料儲存在視訊緩衝區中;如果設為 false,則會指示相機 HAL 將實際的 YUV 資料儲存在視訊緩衝區中。 |
-
退貨
-
OK 表示成功。
定義位於檔案
camera.h
的
186
行。
這個結構體的說明文件是由下列檔案產生:
-
hardware/libhardware/include/hardware/
camera.h
這個頁面中的內容和程式碼範例均受《內容授權》中的授權所規範。Java 與 OpenJDK 是 Oracle 和/或其關係企業的商標或註冊商標。
上次更新時間:2025-03-26 (世界標準時間)。
[[["容易理解","easyToUnderstand","thumb-up"],["確實解決了我的問題","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["缺少我需要的資訊","missingTheInformationINeed","thumb-down"],["過於複雜/步驟過多","tooComplicatedTooManySteps","thumb-down"],["過時","outOfDate","thumb-down"],["翻譯問題","translationIssue","thumb-down"],["示例/程式碼問題","samplesCodeIssue","thumb-down"],["其他","otherDown","thumb-down"]],["上次更新時間:2025-03-26 (世界標準時間)。"],[],[]]