Tài liệu này liệt kê tất cả các bài kiểm tra có sẵn để đánh giá lớp trừu tượng phần cứng máy ảnh Android (HAL). Nó dành cho các nhà sản xuất thiết bị gốc (OEM) và các nhà cung cấp bộ xử lý ứng dụng (AP) để họ có thể đảm bảo triển khai đúng cách HAL của máy ảnh với các khuyết tật tối thiểu. Mặc dù đây là sự bổ sung tự nguyện cho Bộ kiểm tra khả năng tương thích Android (CTS), nó làm tăng đáng kể phạm vi kiểm tra máy ảnh và chắc chắn sẽ xác định được các lỗi tiềm ẩn.
Bằng cách vượt qua các bài kiểm tra này, OEM sẽ xác nhận xem họ đã tích hợp đúng giao diện lớp trừu tượng phần cứng máy ảnh Android (HAL) 3 hay chưa. Khi tuân theo tất cả các mục trong danh sách kiểm tra, việc triển khai thiết bị có thể được coi là đầy đủ đối với giao diện HAL của Máy ảnh Android. Điều này sẽ cho phép thiết bị hỗ trợ đúng cách gói android.hardware.camera2
mà các ứng dụng máy ảnh xây dựng.
Đặc điểm kỹ thuật máy ảnh HAL3
Thông số kỹ thuật Android Camera HAL3 là nguồn thông tin có thẩm quyền về những gì thiết bị phải đáp ứng; trang này cung cấp một bản tóm tắt của tất cả các bài kiểm tra có thể được sử dụng như một danh sách kiểm tra. Những người triển khai Camera HAL (ví dụ: nhà cung cấp AP) nên xem qua từng dòng đặc điểm kỹ thuật của Camera HAL3 và đảm bảo thiết bị của họ tuân theo quy định đó.
Đặc điểm kỹ thuật HAL hiện tại được xác định trong các tệp này trong Bộ phát triển nền tảng Android 5.0 trở lên (PDK):
- Giao diện và thông số kỹ thuật của camera HAL 3.x :
hardware/libhardware/include/hardware/camera3.h
,hardware/libhardware/include/hardware/camera_common.h
- Thông số siêu dữ liệu của Camera HAL 3.x :
system/media/camera/docs/docs.html
- Giao diện và thông số định dạng pixel HAL :
system/core/libsystem/include/system/graphics.h
Các loại kiểm tra camera
Dưới đây là các loại kiểm tra chính có sẵn cho máy ảnh Android mới nhất cùng với tham chiếu đến các hướng dẫn liên quan bên dưới:
- Bộ thử nghiệm của nhà cung cấp (VTS) : Các thử nghiệm kiểm tra trực tiếp giao diện HAL của máy ảnh
- Bộ kiểm tra khả năng tương thích (CTS) : Các bài kiểm tra Android tiêu chuẩn, tự động để đảm bảo tính tương thích của thiết bị - xem phần giới thiệu CTS và Tổng quan về Liên đoàn Thương mại
- Bộ kiểm tra hình ảnh (ITS) : Chạy thử nghiệm theo cách thủ công để đảm bảo tính chính xác của hình ảnh - xem tệp
README
cấp cao nhất và thử nghiệm cụ thể vàtutorial.py
để biết hướng dẫn thiết lập - Kiểm tra thủ công TestingCam : Chạy từ nguồn trong
pdk/apps/TestingCamera/
- Kiểm tra thủ côngCam2.1 kiểm tra : Chạy từ nguồn trong
pdk/apps/TestingCamera2/
Tất cả các loại kiểm tra này được mô tả chi tiết bên dưới. Các bài kiểm tra này được trình bày theo thứ tự thời gian mà OEM dự kiến sẽ thực hiện chúng.
Ví dụ: nếu một thiết bị không đạt các bài kiểm tra gốc, nó chắc chắn sẽ thất bại trong các bài kiểm tra Bộ kiểm tra tương thích (CTS) tiếp theo. Và nếu một thiết bị bị lỗi CTS, sẽ có rất ít tác dụng trong việc chuyển sang Bộ kiểm tra hình ảnh (ITS). Chúng tôi khuyên bạn nên giải quyết các lỗi trong từng loại thử nghiệm trước khi tiếp tục tập hợp các thử nghiệm tiếp theo.
Các bài kiểm tra Bộ kiểm tra nhà cung cấp (VTS)
Bộ kiểm tra nhà cung cấp Android (VTS) là bộ kiểm tra hoạt động ở cấp giao diện HIDL. Để biết thêm thông tin về cách sử dụng VTS, hãy xem Bộ thử nghiệm của nhà cung cấp .
Các bài kiểm tra Bộ kiểm tra khả năng tương thích (CTS)
Bộ kiểm tra tính tương thích với máy ảnh Android (CTS) tập trung vào khả năng tương thích của thiết bị. Để biết thông tin về cách thiết lập môi trường thử nghiệm, hãy xem Thiết lập CTS .
Đường dẫn bắt đầu cho các bài kiểm tra CTS máy ảnh là: platform/cts
.
Khi chạy CTS camera cho các thiết bị hỗ trợ camera ngoài (chẳng hạn như webcam USB), bạn phải cắm thiết bị khi chạy CTS nếu không các bài kiểm tra sẽ tự động thất bại. Ví dụ về camera bên ngoài bao gồm: Logitech HD Pro Webcam C920 và Microsoft LifeCam HD-3000 .
Xem phần giới thiệu CTS và các trang con của nó để biết hướng dẫn chung về cách chạy CTS.
Kiểm tra CTS cho API android.hardware.Camera
Tìm các bài kiểm tra camera này trong cts/tests/tests/
:
-
hardware/src/android/hardware/cts/CameraTest.java
-
hardware/src/android/hardware/cts/CameraGLTest.java
-
hardware/src/android/hardware/cts/Camera_SizeTest.java
-
permission/src/android/permission/cts/CameraPermissionTest.java
Kiểm tra CTS cho API android.hardware.camera2
Tìm các bài kiểm tra camera này trong cts/tests/tests/
:
-
hardware/src/android/hardware/camera2/cts/*
-
permission/src/android/permission/cts/Camera2PermissionTest.java
Kiểm tra camera của CTS Verifier
Tìm các bài kiểm tra camera này trong: cts/apps/CtsVerifier/src/com/android/cts/verifier/camera/*
Các bài kiểm tra Bộ kiểm tra hình ảnh (ITS)
Các bài kiểm tra Camera Image Image Test Suite (ITS) tập trung vào độ chính xác của hình ảnh. Để thực hiện các bài kiểm tra, hãy chạy các tập lệnh Python trên máy trạm có thiết bị Android được kết nối qua USB.
Cơ sở hạ tầng ITS của Máy ảnh và các bài kiểm tra nằm trong thư mục cts/apps/CameraITS
. Mỗi thử nghiệm nằm trong một thư mục con tests/scene #
.
extract root/out/host/linux-x86/cts-verfier/android-cts-verifier.zip
cd android-cts-verifier
adb install -r -g CtsVerifier.apk
cd CameraITS
source build/envsetup.sh
Để biết thêm thông tin về cách thiết lập và chạy thử nghiệm, hãy xem tệp PDF CameraITS
trong cts/apps/CameraITS
. Xem tutorial.py
trong thư mục con của tests
để biết hướng dẫn về cách sử dụng các tập lệnh.
Các bài kiểm tra ITS yêu cầu môi trường Linux. Để biết chi tiết về các phiên bản Python cụ thể được yêu cầu để chạy các bài kiểm tra ITS, hãy xem tệp PDF CameraITS
cho bản phát hành hoặc ghi chú phát hành Android 12 cho Android 12.
Thiết lập khuyến nghị cho các cảnh tĩnh được mô tả trong ITS-in-a-box của Camera . Thiết lập được đề xuất cho cảnh sensor_fusion được mô tả trong Hướng dẫn Bắt đầu Nhanh Sensor Fusion Box .
Để chạy ITS theo cách thủ công, hãy chuẩn bị một môi trường vật lý đơn giản với mục tiêu cụ thể, có thể tái sử dụng như bức tường trắng, thẻ xám và đèn bàn. Gắn thiết bị Android lên giá ba chân và chạy các tập lệnh để kiểm tra các chức năng của máy ảnh. Hầu hết các bài kiểm tra đều đạt hoặc không đạt nhưng một số bài kiểm tra cung cấp các chỉ số.
Các kịch bản này kiểm tra các kịch bản không được kiểm tra trong CTS và là một thành phần quan trọng của kế hoạch kiểm tra HAL 3.2.
Các bài kiểm tra ITS đạt hoặc không đạt. Tất cả các bài kiểm tra bắt buộc trong mỗi thư mục cảnh phải vượt qua. Các thử nghiệm không bắt buộc có thể không thành công và vẫn được tính là vượt qua trong CtsVerifier
.
Để biết mô tả cảnh và thử nghiệm, hãy xem Kiểm tra ITS của Máy ảnh .
Kiểm tra Khung phương tiện
Vượt qua tất cả các bài kiểm tra phương tiện liên quan đến máy ảnh trong MediaFrameworkTest. Xin lưu ý, các bài kiểm tra này yêu cầu cài đặt mediaframeworktest.apk trên thiết bị Android. Bạn sẽ cần make mediaframeworktest
và sau đó sử dụng adb để cài đặt .apk kết quả. Các lệnh ví dụ được bao gồm bên dưới.
Con đường bắt đầu cho các bài kiểm tra khung phương tiện liên quan đến Máy ảnh là: platform/frameworks/base
Tìm mã nguồn cho các bài kiểm tra tại đây: frameworks/base/media/tests/MediaFrameworkTest
Để thiết lập các thử nghiệm này:
make mediaframeworktest
adb install out/target/product/name/data/app/mediaframeworktest.apk
Trong đó biến name đại diện cho thư mục chứa sản phẩm của nhà cung cấp.
Tìm tất cả các bài kiểm tra trong thư mục sau hoặc các thư mục con của nó:
frameworks/base/media/tests/MediaFrameworkTest/src/com/android/mediaframeworktest
Mỗi thư mục con đại diện cho một lớp kiểm tra:
-
functional/
-
integration/
-
performance/
-
power/
-
stress/
-
unit/
Chạy thử nghiệm Khung phương tiện
Để xem tất cả các bài kiểm tra có sẵn ::
adb shell pm list instrumentation
Điều này sẽ mang lại kết quả tương tự như:
instrumentation:com.android.mediaframeworktest/.MediaFrameworkIntegrationTestRunner (target=com.android.mediaframeworktest) instrumentation:com.android.mediaframeworktest/.MediaRecorderStressTestRunner (target=com.android.mediaframeworktest) instrumentation:com.android.mediaframeworktest/.MediaFrameworkPerfTestRunner (target=com.android.mediaframeworktest) instrumentation:com.android.mediaframeworktest/.MediaFrameworkPowerTestRunner (target=com.android.mediaframeworktest)
Xác định và trích xuất thành phần (giữa instrumentation:
và (target=com.android.mediaframeworktest)
từ mỗi dòng thử nghiệm. Thành phần bao gồm tên gói đích ( com.android.mediaframeworktest
) và tên người chạy thử nghiệm ( MediaFramework TestRunner
MediaFramework TestRunner
).
Ví dụ:
com.android.mediaframeworktest/.MediaFrameworkIntegrationTestRunner com.android.mediaframeworktest/.MediaRecorderStressTestRunner com.android.mediaframeworktest/.MediaFrameworkPerfTestRunner com.android.mediaframeworktest/.MediaFrameworkPowerTestRunner
Sau đó, bạn có thể chuyển từng thành phần đến adb shell am instrument
như sau:
adb shell am instrument -w component.name
Trong đó component.name
bằng giá trị trích xuất ở trên. Ví dụ:
adb shell am instrument -w com.android.mediaframeworktest/.MediaFrameworkIntegrationTestRunner
Xin lưu ý, trong khi đường dẫn lớp là gói Java + tên lớp, gói thiết bị đo đạc không nhất thiết phải giống với gói Java. Đảm bảo rằng bạn sử dụng gói AndroidManifest.xml khi nối tên thành phần, không phải gói Java chứa lớp chạy thử nghiệm.
Để chạy một lớp kiểm tra, hãy vượt qua lớp -e
adb shell am instrument -e class com.android.mediaframeworktest.integration.CameraBinderTest -w com.android.mediaframeworktest/.MediaFrameworkIntegrationTestRunner
Để chỉ chạy một phương thức duy nhất trong một lớp thử nghiệm, hãy thêm dấu thăng (#) và tên phương thức (trong trường hợp này testConnectPro
) vào tên lớp, như sau:
adb shell am instrument -e class 'com.android.mediaframeworktest.integration.CameraBinderTest#testConnectPro' -w com.android.mediaframeworktest/.MediaFrameworkIntegrationTestRunner
Kiểm tra chức năng cài đặt phương tiện
Đây là một ví dụ về chạy thử nghiệm chức năng. Thử nghiệm này xác minh chức năng cơ bản của các kết hợp cài đặt máy ảnh khác nhau. (ví dụ: Flash, độ phơi sáng, WB, cảnh, kích thước hình ảnh và thẻ địa lý)
Chạy lệnh kiểm tra:
adb shell am instrument -w -r -e delay_msec 15 -e log true -e class com.android.mediaframeworktest.functional.camera.CameraPairwiseTest com.android.mediaframeworktest/com.android.mediaframeworktest.CameraStressTestRunner
Kiểm tra tích hợp phương tiện
Đây là một ví dụ về chạy thử nghiệm tích hợp, trong trường hợp này là mediaframeworktest / integration / CameraBinderTest.java và mediaframeworktest / CameraS StressTestRunner.java:
adb shell am instrument -e class \ 'com.android.mediaframeworktest.integration.CameraBinderTest' -w \ 'com.android.mediaframeworktest/.CameraStressTestRunner'
Nếu thành công, điều này dẫn đến kết quả đầu ra giống như sau:
----- com.android.mediaframeworktest.integration.CameraBinderTest:........... Test results for CameraStressTestRunner=........... Time: 3.328 OK (11 tests) -----
Kiểm tra hiệu suất phương tiện
Kiểm tra bộ nhớ xem trước này sẽ mở và phát hành bản xem trước của máy ảnh trong 200 lần. Trong mỗi 20 lần lặp, ảnh chụp nhanh của máy chủ trung gian ps sẽ được ghi lại và nó sẽ so sánh việc sử dụng bộ nhớ khác nhau sau 200 lần lặp. Kiểm tra sẽ không thành công nếu chênh lệch lớn hơn 150kM.
Chạy lệnh kiểm tra:
adb shell am instrument -w -r -e class com.android.mediaframeworktest.performance.MediaPlayerPerformance#testCameraPreviewMemoryUsage com.android.mediaframeworktest/.MediaFrameworkPerfTestRunner
Đầu ra chi tiết hơn có thể được tìm thấy trong: /sdcard/mediaMemOutput.txt
Kiểm tra đơn vị phương tiện
Các lệnh để chạy các bài kiểm tra đơn vị đều tương tự nhau. Ví dụ: đối với CameraMetadataTest.java, lệnh sẽ là:
adb shell am instrument -e class 'com.android.mediaframeworktest.unit.CameraMetadataTest' -w 'com.android.mediaframeworktest/.CameraStressTestRunner'
Kiểm tra căng thẳng phương tiện
Bài kiểm tra này nhằm tăng cường khả năng chụp ảnh và quay video của máy ảnh.
Chạy lệnh kiểm tra:
adb shell am instrument -w com.google.android.camera.tests/com.android.camera.stress.CameraStressTestRunner
Tất cả các bài kiểm tra sẽ vượt qua.
Kiểm tra thử nghiệm thủ công
Ứng dụng TestingCam phải được chạy theo cách thủ công với các bước kiểm tra sau được thực hiện. Nguồn cho TestingCam ở đây: pdk/apps/TestingCamera/
Lấy nét vô cực với độ nghiêng máy ảnh
Khởi động TestingCam, bật xem trước và đảm bảo rằng chế độ lấy nét tự động được đặt thành vô cực. Sử dụng nút Chụp ảnh , chụp ảnh các đối tượng ở xa (cách ít nhất 10m) với máy ảnh hướng theo chiều ngang, hướng lên trên (gần với chiều dọc) và hướng xuống (gần với chiều dọc); ví dụ về ảnh chụp từ trên cao có thể là những chiếc lá / cành cây cao từ bên dưới và ví dụ về ảnh chụp từ dưới lên có thể là đường phố khi nhìn từ mái của một tòa nhà. Trong mọi trường hợp, chủ thể ở xa phải sắc nét và được lấy nét. Lưu và xem ảnh chụp trong chế độ xem thư viện để bạn có thể phóng to và kiểm tra độ sắc nét dễ dàng hơn.
Lưu ý rằng để một máy ảnh có bộ truyền động VCM vượt qua bài kiểm tra này, nó sẽ yêu cầu hệ thống điều khiển AF vòng kín hoặc nó sẽ cần một số loại hiệu chỉnh SW dựa trên việc sử dụng dữ liệu gia tốc kế để xác định hướng máy ảnh. Cũng sẽ cần hiệu chuẩn nhà máy đáng tin cậy đối với vị trí vô cực của ống kính.
Kiểm tra thủ côngCam2 kiểm tra
Ứng dụng TestingCam2 phải được chạy theo cách thủ công, với các bước kiểm tra sau được thực hiện. Nguồn cho TestingCam2 ở đây: pdk/apps/TestingCamera2/
Chụp ảnh JPEG
Bắt đầu TestingCam2 và nhấn nút JPEG . Hình ảnh xuất hiện ở bên phải của hình ảnh trong khung ngắm phải giống với khung ngắm, kể cả có cùng hướng.