Filename extension | |
---|---|
Developed by | JEIDA, now JEITA, CIPA |
Initial release | 1995[3] |
Latest release | |
Extended from | TIFF, JPEG, WAV |
Extended to | DCF |
Exchangeable image file format (officially Exif, according to JEIDA/JEITA/CIPA specifications) [5] is a standard that specifies formats for images, sound, and ancillary tags used by digital cameras (including smartphones), scanners and other systems handling image and sound files recorded by digital cameras. The specification uses the following existing encoding formats with the addition of specific metadata tags: JPEG lossy coding for compressed image files, TIFF Rev. 6.0 ( RGB or YCbCr) for uncompressed image files, and RIFF WAV for audio files (linear PCM or ITU-T G.711 μ-law PCM for uncompressed audio data, and IMA- ADPCM for compressed audio data). [6] It does not support JPEG 2000 or GIF encoded images.
This standard consists of the Exif image file specification and the Exif audio file specification.
Exif is supported by almost all camera manufacturers.
The metadata tags defined in the Exif standard cover a broad spectrum:
This section needs expansion with: changes. You can help by
adding to it. (August 2020) |
The Japan Electronic Industries Development Association (JEIDA) produced the initial definition of Exif. Version 2.1 of the specification is dated 12 June 1998.[ citation needed] JEITA established Exif version 2.2 (a.k.a. "Exif Print"), dated 20 February 2002 and released in April 2002. [7] Version 2.21 (with Adobe RGB support) is dated 11 July 2003, but was released in September 2003 following the release of DCF 2.0. Version 2.3 was released on 26 April 2010, and revised to 2.31 in July 2013 and revised to 2.32 on 17 May 2019, was jointly formulated by JEITA and CIPA. The latest version, 3.0, was released in May 2023, and brings, among other things, support for UTF-8 to allow text data in non-ASCII encoding. [4]
Version | Release Date | Changes |
---|---|---|
1.0 | October 1995 | Removed dependencies to io package |
1.1 | May 1997 | |
2.0 | November 1997 | License change to MIT license |
2.1 | December 1998 | |
2.2 | April 2002 | Added HEIC support |
2.21 | September 2003 | Addition of "Exif Print" |
2.21 (unified version) | September 2009 | |
2.3 | April 2010 | |
2.3 (revised) | December 2012 | |
2.31 | July 2016 | |
2.32 | May 2019 | |
3.0 | May 2023 | UTF-8 data type |
The Exif tag structure is borrowed from TIFF files. On several image specific properties, there is a large overlap between the tags defined in the TIFF, Exif, TIFF/EP, and DCF standards. For descriptive metadata, there is an overlap between Exif, IPTC Information Interchange Model and XMP info, which also can be embedded in a JPEG file. The Metadata Working Group has guidelines on mapping tags between these standards. [8]
When Exif is employed for JPEG files, the Exif data are stored in one of JPEG's defined utility Application Segments, the APP1 (segment marker 0xFFE1), which in effect holds an entire TIFF file within. When Exif is employed in TIFF files (also when used as "an embedded TIFF file" mentioned earlier), the TIFF Private Tag 0x8769 defines a sub-Image File Directory (IFD) that holds the Exif specified TIFF Tags. In addition, Exif also defines a Global Positioning System sub-IFD using the TIFF Private Tag 0x8825, holding location information, and an "Interoperability IFD" specified within the Exif sub-IFD, using the Exif tag 0xA005.
Formats specified in Exif standard are defined as folder structures that are based on Exif-JPEG and recording formats for memory. When these formats are used as Exif/DCF files together with the DCF specification (for better interoperability among devices of different types), their scope shall cover devices, recording media, and application software that handle them.
The Exif format has standard tags for location information. As of 2014 [update], many cameras and mobile phones have a built-in GPS receiver that stores the location information in the Exif header when a picture is taken. Some other cameras have a separate GPS receiver that fits into the flash connector or hot shoe. Recorded GPS data can also be added to any digital photograph on a computer, either by correlating the time stamps of the photographs with a GPS record from a hand-held GPS receiver or manually by using a map or mapping software. Some cameras can be paired with cellphones to provide the geolocation. The process of adding geographic information to a photograph is known as geotagging. Photo-sharing communities like Panoramio, locr or Flickr equally allow their users to upload geocoded pictures or to add geolocation information online.
Exif data are embedded within the image file itself. While many recent image manipulation programs recognize and preserve Exif data when writing to a modified image, this is not the case for most older programs. Many image gallery programs also recognise Exif data and optionally display it alongside the images.
Software libraries, such as libexif [9] for C and Adobe XMP Toolkit [10] or Exiv2 [11] for C++, Metadata Extractor [12] for Java, PIL/Pillow for Python, LEADTOOLS or ExifTool [13] for Perl, parse Exif data from files and read/write Exif tag values.
The Exif format has a number of drawbacks, mostly relating to its use of legacy file structures.
Since the Exif tag contains metadata about the photo, it can pose a privacy problem. For example, a photo taken with a GPS-enabled camera can reveal the exact location and time it was taken, and the unique ID number of the device - this is all done by default - often without the user's knowledge. Many users may be unaware that their photos are tagged by default in this manner, or that specialist software may be required to remove the Exif tag before publishing. For example, a whistleblower, journalist or political dissident relying on the protection of anonymity to allow them to report malfeasance by a corporate entity, criminal, or government may therefore find their safety compromised by this default data collection.
In December 2012, anti-virus businessman John McAfee was arrested in Guatemala while fleeing from alleged persecution [22] in neighboring Belize. Vice magazine had published an exclusive interview on their website with McAfee "on the run" [23] that included a photo of McAfee with a Vice reporter taken with a phone that had geotagged the image. [24] The photo's metadata included GPS coordinates locating McAfee in Guatemala, and he was captured two days later. [25] McAfee later claimed to have edited the Exif data from his phone to provide a false location. [26]
According to documents leaked by Edward Snowden, the NSA is targeting Exif information under the XKeyscore program. [27]
The privacy problem of Exif data can be avoided by removing the Exif data using a metadata removal tool. [28]
Metadata Working Group was formed by a consortium of companies in 2006 (according to their web page) or 2007 (as stated in their own press release). Version 2.0 of the specification was released in November 2010, [8] giving recommendations concerning the use of Exif, IPTC and XMP metadata in images.
Extensible Metadata Platform (XMP) is an ISO standard, originally created by Adobe Systems Inc., for the creation, processing and interchange of standardized and custom metadata for digital documents and data sets. IPTC was developed in the early 1990s by the International Press Telecommunications Council (IPTC) to expedite the international exchange of news among newspapers and news agencies.
Not all devices use every available metadata field in the Exif standard.
The following table shows Exif metadata for a photo made with a typical digital camera. Authorship and copyright information is generally not provided in the camera's output, so it must be filled in during later stages of processing. Some programs, such as Canon's Digital Photo Professional, allow the name of the owner to be added to the camera itself.
Tag | Value |
---|---|
Manufacturer | CASIO |
Model | QV-4000 |
Orientation (rotation) | top-left [8 possible values [29]] |
Software | Ver1.01 |
Date and time | 2003:08:11 16:45:32 |
YCbCr positioning | centered |
Compression | JPEG compression |
X resolution | 72.00 |
Y resolution | 72.00 |
Resolution unit | Inch |
Exposure time | 1/659 s |
F-number | f/4.0 |
Exposure program | Normal program |
Exif version | Exif version 2.1 |
Date and time (original) | 2003:08:11 16:45:32 |
Date and time (digitized) | 2003:08:11 16:45:32 |
Components configuration | Y Cb Cr – |
Compressed bits per pixel | 4.01 |
Exposure bias | 0.0 |
Max. aperture value | 2.00 |
Metering mode | Pattern |
Flash | Flash did not fire |
Focal length | 20.1 mm |
MakerNote | 432 bytes unknown data |
FlashPix version | FlashPix version 1.0 |
Color space | sRGB |
Pixel X dimension | 2240 |
Pixel Y dimension | 1680 |
File source | DSC |
Interoperability index | R98 |
Interoperability version | (null) |
In addition to the basic date and time tags (DateTime
, DateTimeOriginal
, and DateTimeDigitized
), there are three corresponding "subsecond" tags: SubsecTime
, SubsecTimeOriginal
, and SubsecTimeDigitized
. The SubsecTime
tag is defined in version 2.3 as "a tag used to record fractions of seconds for the DateTime tag;"
[6] the SubsecTimeOriginal
and SubsecTimeDigitized
fields are defined similarly. The subsecond tags are of variable length, meaning manufacturers may choose the number of ASCII-encoded decimal digits to place in these tags. For DateTime = 2000:01:01 00:00:00
, the actual time with various subsecond values would be:
SubsecTime = 2
: 2000:01:01 00:00:00.2
SubsecTime = 23
: 2000:01:01 00:00:00.23
SubsecTime = 234
: 2000:01:01 00:00:00.234
SubsecTime = 2345
: 2000:01:01 00:00:00.2345
The standard does not specify which particular event during the "taking" of a picture the time tags should describe. The standard is, in fact, ambiguous. The DateTimeOriginal
tag is defined as "The date and time when the original image data was generated." For an exposure—say, 30 seconds—longer than the granularity of the timestamp (one second for the DateTimeOriginal
tag), the tag's time could correspond to the beginning of the exposure, the end of the exposure, or some other time. This confusion is exacerbated for the subsecond tags, where the granularity (down to 1/10000th of a second in the examples in the standard) is shorter than many common exposure durations.
As noted above, tags to specify the previously-missing timezone information were added in Exif version 2.31. These are "OffsetTime", "OffsetTimeOriginal" and "OffsetTimeDigitized". They are formatted as seven ASCII characters (including the null terminator) denoting the hours and minutes of the offset, like +01:00
or -01:00
. The offset is "from UTC (the time difference from Universal Coordinated Time including daylight saving time) of the time of"
[6] the matching tag.
The Exif specification also includes a description of FPXR (FlashPix-ready) information, which may be stored in APP2 of JPEG images using a structure similar to that of a FlashPix file. [30] These FlashPix extensions allow meta-information to be preserved when converting between FPXR JPEG images and FlashPix images. FPXR information may be found in images from some models of digital cameras by Kodak and Hewlett-Packard. [31] Below is an example of the FPXR information found in a JPEG image from a Kodak EasyShare V570 digital camera:
Tag | Value |
---|---|
Code page | 1200 |
Used extension numbers | 1 |
Extension name | Screen nail |
Extension class ID | 10000230-6FC0-11D0-BD01-00609719A180 |
Extension persistence | Invalidated by modification |
Extension create date | 2003:03:29 17:47:50 |
Extension modify date | 2003:03:29 17:47:50 |
Creating application | Picoss |
Extension description | Presized image for LCD |
Storage-stream pathname | /.Screen Nail_bd0100609719a180 |
Screen nail | (124,498 bytes of data containing 640×480 JPEG preview image) |
The Exif specification describes the RIFF file format used for WAV audio files and defines a number of tags for storing meta-information such as artist, copyright, creation date, and more in these files. [32] The following table gives an example of Exif information found in a WAV file written by the Pentax Optio WP digital camera:
Tag | Value |
---|---|
Encoding | Microsoft PCM |
Number of channels | 1 |
Sampling rate | 7872 |
Avg. bytes per second | 7872 |
Bits per sample | 8 |
Date created | 2005:08:08 |
Exif version | 0220 |
Related image file | IMGP1149.JPG |
Time created | 16:23:35 |
Make | PENTAX Corporation |
Model | PENTAX Optio WP |
MakerNote | (2064 bytes of data) |
The "MakerNote" tag contains image information normally in a proprietary binary format. Some of these manufacturer-specific formats have been decoded:
The proprietary formats used by many manufacturers break if the MakerNote tag data is moved (i.e. by inserting or editing a tag that precedes it). The reason to edit to the Exif data could be as simple as to add copyright information, an Exif comment, etc. There are two solutions for this problem:
Microsoft has implemented the last solution in Windows 10: In the Windows explorer you can change the Exif data of an image file by the properties window. Here the tab sheet "Details" contains some Exif data like title, subject, comments etc. and these Exif data can also be changed and stored. When the image file is saved the tag "OffsetSchema" (tag ID = 0xea1d) is added and this tag contains a signed 32 bit number. With this number the original index of "MakerNote" can be restored:
Original index of "MakerNote" = Current index of "MakerNote" - Value of tag "OffsetSchema"
But the tag "OffsetSchema" was defined by Microsoft and it is not part of the official Exif standard.
In some cases, camera vendors also store important information only in proprietary makernote fields, instead of using available Exif standard tags. An example for this is Nikon's ISO speed settings tag. [38]
{{
cite web}}
: CS1 maint: bot: original URL status unknown (
link)