Google berkomitmen untuk mendorong terwujudnya keadilan ras bagi komunitas Kulit Hitam. Lihat caranya.

Kamera HAL

Lapisan abstraksi perangkat keras kamera (HAL) Android menghubungkan API kerangka kerja kamera tingkat yang lebih tinggi di android.hardware.camera2 ke driver dan perangkat keras kamera yang mendasari Anda. Dimulai dengan Android 13, pengembangan antarmuka kamera HAL menggunakan AIDL . Android 8.0 memperkenalkan Treble , mengalihkan Camera HAL API ke antarmuka stabil yang ditentukan oleh bahasa deskripsi antarmuka HAL (HIDL). Jika sebelumnya Anda telah mengembangkan modul dan driver kamera HAL untuk Android 7.0 dan yang lebih rendah, waspadai perubahan signifikan pada saluran kamera.

Kamera AIDL HAL

Untuk perangkat yang menjalankan Android 13 atau lebih tinggi, kerangka kerja kamera menyertakan dukungan untuk HAL kamera AIDL. Kerangka kamera juga mendukung HAL kamera HIDL, namun fitur kamera yang ditambahkan di Android 13 atau lebih tinggi hanya tersedia melalui antarmuka HAL kamera AIDL. Untuk menerapkan fitur tersebut pada perangkat yang ditingkatkan ke Android 13 atau lebih tinggi, produsen perangkat harus memigrasikan proses HAL mereka dari menggunakan antarmuka kamera HIDL ke antarmuka kamera AIDL.

Untuk mempelajari tentang keuntungan AIDL, lihat AIDL untuk HAL .

Menerapkan kamera AIDL HAL

Untuk implementasi referensi HAL kamera AIDL, lihat hardware/google/camera/common/hal/aidl_service/ .

Spesifikasi HAL kamera AIDL ada di lokasi berikut:

Untuk perangkat yang bermigrasi ke AIDL, produsen perangkat mungkin perlu memodifikasi kebijakan Android SELinux (sepolicy) dan file RC bergantung pada struktur kode.

Validasi kamera AIDL HAL

Untuk menguji implementasi HAL kamera AIDL Anda, pastikan perangkat lulus semua tes CTS dan VTS. Android 13 memperkenalkan pengujian AIDL VTS, VtsAidlHalCameraProvider_TargetTest.cpp .

Fitur kamera HAL3

Tujuan dari desain ulang Android Camera API adalah untuk secara substansial meningkatkan kemampuan aplikasi untuk mengontrol subsistem kamera pada perangkat Android sambil mengatur ulang API agar lebih efisien dan dapat dipelihara. Kontrol tambahan mempermudah pembuatan aplikasi kamera berkualitas tinggi di perangkat Android yang dapat beroperasi dengan andal di beberapa produk sambil tetap menggunakan algoritme khusus perangkat bila memungkinkan untuk memaksimalkan kualitas dan kinerja.

Versi 3 dari subsistem kamera menyusun mode operasi menjadi satu tampilan terpadu, yang dapat digunakan untuk mengimplementasikan mode sebelumnya dan beberapa mode lainnya, seperti mode burst. Ini menghasilkan kontrol pengguna yang lebih baik untuk fokus dan eksposur dan lebih banyak pasca-pemrosesan, seperti pengurangan noise, kontras, dan penajaman. Selanjutnya, tampilan yang disederhanakan ini memudahkan pengembang aplikasi untuk menggunakan berbagai fungsi kamera.

API memodelkan subsistem kamera sebagai saluran yang mengubah permintaan masuk untuk pengambilan bingkai menjadi bingkai, dengan basis 1:1. Permintaan merangkum semua informasi konfigurasi tentang penangkapan dan pemrosesan bingkai. Ini termasuk resolusi dan format piksel; sensor manual, lensa dan kontrol lampu kilat; 3A mode operasi; RAW-> kontrol pemrosesan YUV; generasi statistik; dan seterusnya.

Secara sederhana, kerangka kerja aplikasi meminta bingkai dari subsistem kamera, dan subsistem kamera mengembalikan hasil ke aliran keluaran. Selain itu, metadata yang berisi informasi seperti ruang warna dan bayangan lensa dihasilkan untuk setiap rangkaian hasil. Anda dapat menganggap kamera versi 3 sebagai saluran ke aliran satu arah kamera versi 1. Ini mengubah setiap permintaan pengambilan menjadi satu gambar yang ditangkap oleh sensor, yang diproses menjadi:

  • Objek hasil dengan metadata tentang penangkapan.
  • Satu hingga N buffer data gambar, masing-masing ke permukaan tujuannya sendiri.

Himpunan permukaan keluaran yang mungkin telah dikonfigurasikan sebelumnya:

  • Setiap permukaan adalah tujuan untuk aliran buffer gambar dengan resolusi tetap.
  • Hanya sejumlah kecil permukaan yang dapat dikonfigurasi sebagai output sekaligus (~3).

Permintaan berisi semua pengaturan pengambilan yang diinginkan dan daftar permukaan keluaran untuk memasukkan buffer gambar ke dalam permintaan ini (dari total set yang dikonfigurasi). Permintaan bisa satu kali (dengan capture() ), atau dapat diulang tanpa batas waktu (dengan setRepeatingRequest() ). Tangkapan memiliki prioritas di atas permintaan berulang.

Model data kamera

Gambar 1. Model operasi inti kamera

Gambaran umum kamera HAL1

Versi 1 dari subsistem kamera dirancang sebagai kotak hitam dengan kontrol tingkat tinggi dan tiga mode operasi berikut:

  • Pratinjau
  • Rekaman video
  • Masih Menangkap

Setiap mode memiliki kemampuan yang sedikit berbeda dan tumpang tindih. Hal ini mempersulit penerapan fitur baru seperti mode burst, yang berada di antara dua mode operasi.

Diagram blok kamera

Gambar 2. Komponen kamera

Android 7.0 terus mendukung kamera HAL1 karena banyak perangkat masih mengandalkannya. Selain itu, layanan kamera Android mendukung penerapan kedua HAL (1 dan 3), yang berguna bila Anda ingin mendukung kamera depan yang kurang mampu dengan kamera HAL1 dan kamera belakang yang lebih canggih dengan kamera HAL3.

Ada modul HAL kamera tunggal (dengan nomor versinya sendiri ), yang mencantumkan beberapa perangkat kamera independen yang masing-masing memiliki nomor versinya sendiri. Modul kamera 2 atau yang lebih baru diperlukan untuk mendukung perangkat 2 atau yang lebih baru, dan modul kamera tersebut dapat memiliki campuran versi perangkat kamera (inilah yang kami maksud ketika kami mengatakan Android mendukung penerapan kedua HAL).