Формат обмена файлами JPEG - Википедия - JPEG File Interchange Format

В Формат обмена файлами JPEG (JFIF) является формат файла изображения стандарт. Он определяет дополнительные спецификации для формат контейнера который содержит данные изображения, закодированные с JPEG алгоритм. Базовые спецификации для формата контейнера JPEG определены в Приложении B стандарта JPEG, известном как Формат обмена JPEG (JIF). JFIF строится поверх JIF для устранения некоторых ограничений JIF, включая ненужную сложность, регистрацию образцов компонентов, разрешение, соотношение сторон и цветовое пространство. Поскольку JFIF является дополнительным стандартом, итоговый формат файла может называться «JPEG / JFIF».

JFIF - это взаимно несовместимые с новым Сменный формат файла изображения (Exif).

Цель

JFIF определяет ряд деталей, которые не указаны в стандарте JPEG Часть 1 (ISO /IEC 10918-1, ITU-T Рекомендация T.81.)[1]

Регистрация образца компонента

JPEG позволяет использовать несколько компонентов (например, Y, Cb и Cr ), чтобы иметь разное разрешение, но он не определяет, как эти разные массивы выборок должны быть выровнены. Стандарт JFIF требует размещения образцов "межстраничный "- означает, что декодер может обрабатывать каждый массив компонентов как массив прямоугольных пикселей равного размера, выбранных в их центрах, причем каждый массив имеет те же внешние границы, что и изображение. Это удобно для пользователей компьютеров, но не используется для выравнивания в MPEG-2 и большинство видеоприложений.

Разрешение и соотношение сторон

Стандарт JPEG не включает никаких методов кодирования разрешения или соотношения сторон изображения. JFIF предоставляет информацию о разрешении или соотношении сторон с использованием расширения сегмента приложения до JPEG. Он использует сегмент приложения № 0 с заголовком сегмента, состоящим из строка с завершающим нулем написание "JFIF" в ASCII за которым следует байт, равный 0, и указывает, что это должен быть первый сегмент в файле, что упрощает распознавание файла JFIF. Exif изображения, записанные цифровыми камерами, обычно не включают этот сегмент, но обычно соответствуют во всех других отношениях стандарту JFIF.

Цветовое пространство

Стандарт JPEG, используемый для кодирования сжатия в файлах JFIF, не определяет, какой цветовая кодировка должен использоваться для изображений. JFIF определяет цветовая модель для использования: либо Y для оттенков серого, либо YCbCr происходит от Основные цвета RGB как определено в CCIR 601 (теперь известна как Рек. ITU-R BT.601), за исключением другого масштабирования "полного диапазона" компонентов Y, Cb и Cr. В отличие от «студийного диапазона», определенного в CCIR 601, в котором черный представлен как Y = 16, а белый - как Y = 235, а значения вне этого диапазона доступны для обработки сигнала «запас» и «пространство для ног», JFIF использует все 256 уровней. 8-битного представления, так что Y = 0 для черного и Y = 255 для максимального белого. Основные цвета RGB, определенные в JFIF через CCIR 601, также несколько отличаются от того, что стало обычной практикой в ​​новых приложениях (например, они немного отличаются от основных цветов, определенных в sRGB ). Более того, CCIR 601 (до 2007 г.) не давал точного определения основных цветов RGB; вместо этого он опирался на основную практику телеиндустрии.

Интерпретацию цвета изображения JFIF можно улучшить путем встраивания ICC профиль, метаданные цветового пространства или sRGB тег и с помощью приложения, которое интерпретирует эту информацию.

Структура формата файла

Файл JFIF состоит из последовательности маркеров или сегментов маркеров (подробности см. JPEG, синтаксис и структура ). Маркеры определены в части 1 JPEG Стандарт.[1] Каждый маркер состоит из двух байтов: FF байт, за которым следует байт, не равный 00 или же FF и определяет тип маркера. Некоторые маркеры стоят отдельно, но большинство указывают на начало сегмента маркера, который содержит байты данных, согласно следующему шаблону:

FF хх s1 s2 [байты данных]

Байты s1 и s2 взяты вместе, чтобы представить 16-битное целое число с прямым порядком байтов, определяющее длину следующих «байтов данных» плюс 2 байта, используемых для представления длины. Другими словами, s1 и s2 укажите количество следующих байты данных в качестве .

Согласно части 1 стандарта JPEG, приложения могут использовать сегменты маркера APP и определять значение данных для конкретного приложения. В стандарте JFIF определены следующие сегменты маркера APP:

  • Сегмент маркера JFIF APP0 (сокращенно сегмент JFIF) (обязательно)
  • Сегмент маркера APP0 расширения JFIF (для краткости сегмент JFXX) (необязательно)

Они описаны ниже.

Стандарт JFIF требует, чтобы сегмент маркера JFIF APP0 следовал сразу за маркером SOI. Если используется сегмент маркера APP0 расширения JFIF, он должен сразу следовать за сегментом маркера JFIF APP0.[2] Итак, файл JFIF будет иметь следующую структуру:

Файловая структура JFIF
СегментКодОписание
ТАК ЧТО ЯFF D8Начало изображения
JFIF-APP0FF E0 s1 s2 4А 46 49 46 00 ...Смотри ниже
JFXX-APP0FF E0 s1 s2 4A 46 58 58 00 ...необязательно, см. ниже
… Дополнительные сегменты маркера
(например, SOF, DHT, COM)
SOSFF DAНачало сканирования
сжатые данные изображения
EOIFF D9Конец изображения

Сегмент маркера JFIF APP0

В обязательном сегменте маркера JFIF APP0 указываются параметры изображения. При желании можно встроить несжатый эскиз.

Сегмент маркера JFIF APP0
ПолеРазмер (байты)Описание
Маркер APP02FF E0
Длина2Длина сегмента без маркера APP0
Идентификатор54A 46 49 46 00 = "JFIF" в ASCII, заканчивается нулевым байтом
Версия JFIF2Первый байт для основной версии, второй байт для дополнительной версии (01 02 для 1.02)
Единицы плотности1Единицы для следующих полей плотности пикселей
X плотность2Плотность пикселей по горизонтали. Не должно быть нулевым
Yплотность2Плотность пикселей по вертикали. Не должно быть нулевым
Xthumbnail1Количество пикселей по горизонтали следующей встроенной миниатюры RGB. Может быть нулевым
Ythumbnail1Количество пикселей по вертикали следующей встроенной миниатюры RGB. Может быть нулевым
Данные эскиза3 × пНесжатые 24-битные данные эскизов растра RGB (8 бит на канал цвета) в порядке R0, G0, B0, ... Rn-1, Gn-1, Bn-1; с п = Xthumbnail × Ythumbnail

Сегмент маркера APP0 расширения JFIF

Сразу после сегмента маркера JFIF APP0 может быть сегмент маркера APP0 расширения JFIF. Этот сегмент может присутствовать только для JFIF версии 1.02 и выше. Это позволяет встроить миниатюру в 3 различных формата.

Сегмент маркера APP0 расширения JFIF
ПолеРазмер (байты)Описание
Маркер APP02FF E0
Длина2Длина сегмента без маркера APP0
Идентификатор54A 46 58 58 00 = "JFXX" в ASCII, заканчивается нулевым байтом
Формат миниатюр1Указывает, какой формат данных используется для следующего встроенного эскиза:
  • 10 : Формат JPEG
  • 11 : 1 байт на пиксель в формате палитры
  • 13 : 3 байта на пиксель в формате RGB
Данные эскизаПеременнаяЗависит от формата миниатюр, см. Ниже

Данные эскиза зависят от формата эскиза следующим образом:

Миниатюра сохранена с использованием кодировки JPEG
ПолеРазмер (байты)Описание
ТАК ЧТО Я2FF D8
ПеременнаяДолжен быть в формате JIF с использованием YCbCr или просто Y и не должен содержать сегментов JFIF или JFXX.
EOI2FF D9
Миниатюра хранится с использованием одного байта на пиксель
ПолеРазмер (байты)Описание
Xthumbnail1Количество пикселей по горизонтали следующего встроенного эскиза. Не должно быть нулевым
Ythumbnail1Количество пикселей по вертикали следующего встроенного эскиза. Не должно быть нулевым
Палитра эскизов768256 записей палитры, каждая из которых содержит 24-битное значение цвета RGB
Данные эскизапОдин байт на пиксель, содержащий индекс цвета в палитре,

с п = Xthumbnail × Ythumbnail

Миниатюра хранится с использованием трех байтов на пиксель
ПолеРазмер (байты)Описание
Xthumbnail1Количество пикселей по горизонтали следующего встроенного эскиза. Не должно быть нулевым
Ythumbnail1Количество пикселей по вертикали следующего встроенного эскиза. Не должно быть нулевым
Данные эскиза3 × пНесжатые 24-битные данные эскизов растра RGB (8 бит на канал цвета) в порядке R0, G0, B0, ... Rn-1, Gn-1, Bn-1; с п = Xthumbnail × Ythumbnail

Совместимость

Новее Сменный формат файла изображения (Exif) сравним с JFIF, но эти два стандарта несовместимы. Это связано с тем, что оба стандарта определяют, что их конкретный сегмент приложения (APP0 для JFIF, APP1 для Exif) должен сразу следовать за маркером SOI. На практике многие программы и цифровые камеры создают файлы, содержащие оба сегмента приложения. Это не повлияет на декодирование изображения для большинства декодеров, но плохо спроектированные парсеры JFIF или Exif могут не распознавать файл должным образом.

JFIF совместим с Adobe Фотошоп расширения "Блок информационных ресурсов" JPEG и Модель обмена информацией IPTC метаданные, поскольку JFIF не препятствует работе других сегментов приложения, а расширения Photoshop не обязательно должны быть первыми в файле. Однако Photoshop обычно сохраняет буферы CMYK как четырехкомпонентные «Adobe JPEG», которые не соответствуют JFIF. Поскольку эти файлы не находятся в цветовом пространстве YCbCr, они обычно не декодируются веб-браузерами и другим программным обеспечением Интернета.

История

Разработкой документа JFIF руководил Эрик Гамильтон из Микросистемы C-Cube, и соглашение о первой версии было заключено в конце 1991 года на встрече, проведенной в C-Cube, с участием около 40 представителей различных компьютерных, телекоммуникационных и графических компаний. Вскоре после этого была опубликована небольшая ревизия - JFIF 1.01.[3] В течение почти 20 лет последней доступной версией была v1.02, опубликованная 1 сентября 1992 года.[2]

В 1996 г. RFC 2046 указано, что формат изображения, используемый для передачи изображений JPEG через Интернет, должен быть JFIF. В Тип MIME "изображение / JPEG" должно быть закодировано как JFIF. Однако на практике практически все интернет-программы могут декодировать любые базовые данные. JIF изображение, которое использует компоненты Y или YCbCr, независимо от того, совместимо ли оно с JFIF или нет.

Со временем C-Cube был реструктурирован (и в конечном итоге превратился в Гармонический, LSI Logic, Магнум Полупроводник, Avago Technologies, Broadcom, и GigOptix, GigPeak и т. д.), и потерял интерес к документу, и у спецификации не было официального издателя, пока она не была принята Ecma International и ITU-T / ISO / IEC Объединенная группа экспертов в области фотографии примерно в 2009 году, чтобы не потерять его для истории и предоставить возможность формально цитировать его в стандартных публикациях и улучшить его редакционное качество. Он был опубликован ECMA в 2009 году как Технический отчет № 98, чтобы избежать потери исторических данных.[3]и формально стандартизирован ITU-T в 2011 году в качестве рекомендации T.871[4]и ISO / IEC в 2013 году как ISO / IEC 10918-5,[5] Новые публикации включали редакционные улучшения, но без существенных технических изменений.

Смотрите также

Рекомендации

  1. ^ а б «Рекомендация МСЭ-T T.81: Информационные технологии - Цифровое сжатие и кодирование неподвижных изображений с непрерывным тоном - Требования и руководящие принципы» (PDF). ITU-T (ранее CCITT). 18 февраля 1992 г.. Получено 15 июн 2015.
  2. ^ а б Гамильтон, Эрик (12 сентября 1992 г.). «Формат обмена файлами JPEG, версия 1.02» (pdf, 0,02 МБ). Получено 15 июн 2015.
  3. ^ а б «Формат обмена файлами JPEG (JFIF)». ecma-international.org. 2009. Получено 15 июн 2015.
  4. ^ «Рекомендация ITU-T T.871: Информационные технологии - Цифровое сжатие и кодирование неподвижных изображений с непрерывным тоном: формат обмена файлами JPEG (JFIF)» (PDF). ITU-T. 14 мая 2011. Получено 15 июн 2015.
  5. ^ «ISO / IEC 10918-5: 2013: Информационные технологии. Цифровое сжатие и кодирование неподвижных изображений с непрерывным тоном: формат обмена файлами JPEG (JFIF)». ISO / Международная электротехническая комиссия. 1 мая 2013 г.. Получено 15 июн 2015.

дальнейшее чтение

Книги

  • Миано, Джон М., «Форматы файлов сжатых изображений»; 1999, Эддисон-Уэсли ISBN  978-0-201-60443-6
  • Пеннебейкер, Уильям Б. и Джоан Л. Митчелл: Стандарт сжатия данных неподвижных изображений JPEG; 3-е издание, 1993 г., Springer ISBN  978-0-442-01272-4

Стандарты