Kể từ Android 10 (API cấp 29) trở lên, có các phương thức trong MediaCodecInfo
cho biết thêm thông tin về bộ mã hoá và giải mã:
isSoftwareOnly()
- Trả về true nếu bộ mã hoá và giải mã chỉ chạy trong phần mềm. Các bộ mã hoá và giải mã phần mềm không đảm bảo về hiệu suất kết xuất.
isHardwareAccelerated()
- Trả về true nếu bộ mã hoá và giải mã được tăng tốc bằng phần cứng.
isVendor()
- Trả về 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 do nền tảng Android cung cấp.
isAlias()
MediaCodecList
có thể chứa các mục bổ sung cho cùng một bộ mã hoá và giải mã cơ bản bằng cách sử dụng tên bộ mã hoá và giải mã thay thế (bí danh). 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à bí danh 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 thông qua một bí danh.
Điểm hiệu suất
Điểm hiệu suất thể hiện khả năng của bộ mã hoá và giải mã trong việc kết xuất video ở 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 Ultra High Definition (3840x2160 pixel) được kết xuất ở tốc độ 60 khung hình/giây.
Phương thức MediaCodecInfo.VideoCapabilities.getSupportedPerformancePoints()
sẽ trả về một 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 phủ 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 điểm hiệu suất được cung cấp cho tất cả bộ mã hoá và giải mã tăng tốc phần cứng. Danh sách này có thể trống nếu bộ mã hoá và giải mã 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 của 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()
trả về giá trị rỗng.