Bộ mã hoá và giải mã nội dung nghe nhìn

Kể từ Android 10 (API cấp 29) trở lên, có các phương thức trong MediaCodecInfo để tiết lộ thêm thông tin về một bộ mã hoá và giải mã:

isSoftwareOnly()
Trả về giá trị true nếu bộ mã hoá và giải mã chỉ chạy trong phần mềm. Codec phần mềm không đảm bảo về hiệu suất kết xuất.
isHardwareAccelerated()
Trả về giá trị true nếu bộ mã hoá và giải mã được tăng tốc bằng phần cứng.
isVendor()
Trả về giá trị true nếu bộ mã hoá và giải mã do nhà cung cấp thiết bị cung cấp hoặc trả về false nếu nền tảng Android cung cấp.
isAlias()
MediaCodecList có thể chứa các mục nhập bổ sung cho cùng một bộ mã hoá và giải mã cơ bản bằng cách sử dụng một tên/các bộ mã hoá và giải mã thay thế (alias/es). Phương thức này trả về giá trị true nếu bộ mã hoá và giải mã trong mục này là đại diện của một bộ mã hoá và giải mã khác.

Ngoài ra, MediaCodec.getCanonicalName() trả về tên bộ mã hoá và giải mã cơ bản cho các bộ mã hoá và giải mã được tạo qua một bí danh.

Điểm thành tích

Điểm hiệu suất thể hiện khả năng kết xuất video của bộ mã hoá và giải mã ở một chiều cao, chiều rộng và tốc độ khung hình cụ thể. Ví dụ: điểm hiệu suất UHD_60 đại diện cho video Độ phân giải siêu cao (3840 x 2160 pixel) được kết xuất với tốc độ 60 khung hình/giây.

Phương thức MediaCodecInfo.VideoCapabilities.getSupportedPerformancePoints() sẽ trả về danh sách các mục PerformancePoint mà bộ mã hoá và giải mã có thể kết xuất hoặc thu thập.

Bạn có thể kiểm tra xem một PerformancePoint nhất định có bao gồm một PerformancePoint khác hay không bằng cách gọi PerformancePoint.covers(PerformancePoint). Ví dụ: UHD_60.covers(UHD_50) trả về giá trị true.

Danh sách các điểm hiệu suất được cung cấp cho tất cả các bộ mã hoá và giải mã được tăng tốc phần cứng. Đây có thể là một danh sách trống nếu bộ mã hoá và giải mã này không đáp ứng được điểm hiệu suất tiêu chuẩn thấp nhất.

Xin lưu ý rằng các thiết bị đã được nâng cấp lên Android 10 (API cấp 29) trở lên mà không cập nhật hình ảnh nhà cung cấp sẽ không có dữ liệu điểm hiệu suất, vì dữ liệu này đến từ HAL của nhà cung cấp. Trong trường hợp này, getSupportedPerformancePoints() sẽ trả về giá trị rỗng.