HEIF-визуализация

Устройства под управлением Android 10 поддерживают формат сжатых изображений HEIC, специальную марку высокоэффективного кодирования видео (HEVC) высокоэффективного формата файлов изображений (HEIF), как указано в ISO/IEC 23008-12 . Изображения в кодировке HEIC обеспечивают лучшее качество изображения при меньшем размере файлов по сравнению с файлами JPEG.

Изображения HEIC генерируются платформой камеры, запрашивающей несжатое изображение из HAL камеры и отправляющей его в медиа-подсистему для кодирования кодером HEIC или HEVC.

Требования

Для поддержки формата изображения HEIC на вашем устройстве должен быть аппаратный кодировщик, поддерживающий MIMETYPE_IMAGE_ANDROID_HEIC или MIMETYPE_VIDEO_HEVC с режимом постоянного качества .

Выполнение

Чтобы поддерживать формат изображения HEIC на вашем устройстве, внедрите кодек HEIC/HEVC и обеспечьте поддержку необходимых конфигураций потока, которыми являются потоки IMPLEMENTATION_DEFINED / YUV и потоки сегментов приложений JPEG.

СМИ

Реализуйте кодек HEIC/HEVC в режиме постоянного качества (CQ) для соответствующего оборудования следующим образом:

  • Кодек типа HEVC использует либо формат IMPLEMENTATION_DEFINED с использованием GRALLOC_USAGE_HW_VIDEO_ENCODER , либо формат HAL_PIXEL_FORMAT_YCBCR_420_888 в зависимости от размера изображения.
  • Кодек типа HEIC использует формат IMPLEMENTATION_DEFINED с использованием GRALLOC_USAGE_HW_IMAGE_ENCODER .

Камера

В статических метаданных установите ANDROID_HEIC_INFO_SUPPORTED значение true, а ANDROID_HEIC_INFO_MAX_JPEG_APP_SEGMENTS_COUNT значение между [1, 16] , указывающее количество сегментов приложения JPEG.

Для каждой обязательной комбинации потоков ваша камера должна поддерживать замену потока JPEG на поток HEIC того же размера.

Для выходного потока HEIC в общедоступном API служба камеры создает два внутренних потока HAL:

  • Поток BLOB с флагом использования JPEG_APPS_SEGMENT для хранения сегментов приложения, включая сегменты EXIF ​​и эскизов.
  • Поток IMPLEMENTATION_DEFINED или YCBCR_420_888 — размер потока HEIC в зависимости от целевого кодека и размера потока HEIC.

На основе ANDROID_HEIC_INFO_MAX_JPEG_APP_SEGMENTS_COUNT платформа камеры выделяет буферы, достаточно большие, чтобы HAL камеры мог заполнить сегменты приложения JPEG. Сегмент APP1 является обязательным, однако сегменты, следующие за сегментом APP1 ( APP2 и выше), являются необязательными. Платформа камеры переопределяет теги EXIF ​​в сегменте APP1 , которые могут быть получены из метаданных результата захвата или связаны с основным битовым потоком изображения, и отправляет их в MediaMuxer .

Поскольку медиакодер встраивает ориентацию в метаданные выходных изображений, чтобы обеспечить согласованную ориентацию между основным изображением и миниатюрой, HAL камеры не должен поворачивать миниатюру изображения на основе android.jpeg.orientation. Платформа записывает ориентацию в метаданные EXIF ​​и контейнер HEIC.

Теги статических, управляющих и динамических метаданных, относящиеся к формату JPEG, также применимы к формату HEIC. Например, теги метаданных android.jpeg.orientation и android.jpeg.quality в запросе захвата используются для управления ориентацией и качеством изображений HEIC.

Чтобы использовать формат HEIC в приложении, используйте общедоступный API HEIC .

Для получения дополнительной информации см. следующие источники.

Камера ХАЛ

Пространство данных графического буфера

Использование пространства графического буфера

Валидация

Чтобы убедиться, что ваша реализация поддерживает изображения HEIC, используйте тестовое приложение TestingCamera2 и запустите следующие тесты CTS и VTS камеры.

Тесты камеры CTS

Тесты камеры VTS