source: extensions/exif_view/main.inc.php @ 7071

Last change on this file since 7071 was 6989, checked in by plg, 14 years ago

bug 1862 fixed: no date format on creation date

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Author Date Id Revision
File size: 11.0 KB
Line 
1<?php /*
2Plugin Name: Exif View
3Version: auto
4Description: Converts EXIF values to human readable localized values. Corresponds to EXIF specification 2.2, details in http://www.exif.org. Easily extensible.
5Plugin URI: http://piwigo.org/ext/extension_view.php?eid=155
6Author: Martin Javorek
7Author URI: mailto:maple@seznam.cz&subject=PWG%20EXIF%20View
8*/
9
10/*
11-------------------------------------------------------------------------------
12Change log:
13
140.2, 23th August 2007
15- exposurue bias fix, date time original formatting
16
170.1, 1st August 2007
18- initial version
19
20
21-------------------------------------------------------------------------------
22
23Extend your configuration in /include/config.local.inc.php file - example:
24
25$conf['show_exif_fields'] = array(
26  'Make',
27  'Model',
28  'ExifVersion',
29  'Software',
30  'DateTimeOriginal',
31  'FNumber',
32  'ExposureBiasValue',
33  'FILE;FileSize',
34  'ExposureTime',
35  'Flash',
36  'ISOSpeedRatings',
37  'FocalLength',
38  'FocalLengthIn35mmFilm',
39  'WhiteBalance',
40  'ExposureMode',
41  'MeteringMode',
42  'ExposureProgram',
43  'LightSource',
44  'Contrast',
45  'Saturation',
46  'Sharpness',
47  );
48
49*/
50
51add_event_handler('format_exif_data', 'exif_translation' );
52
53/**
54 * Date and time format.
55 * @see http://cz2.php.net/manual/en/function.date.php
56 */
57define('DATE_TIME_FORMAT', 'H:i:s j.n.Y');
58
59/**
60 * Truncates number.
61 *
62 * @param num number
63 * @param digits number of digits, default 0
64 */
65function truncate($num, $digits = 0) {
66    $shift = pow(10 , $digits);
67    return ((floor($num * $shift)) / $shift);
68}
69
70/**
71 * Format date.
72 *
73 * @param date given EXIF date
74 */
75function formatDate($date) {
76        $dateTime = explode(' ', $date);
77        $d = explode(':', $dateTime[0]);
78        $t = explode(':', $dateTime[1]);
79        // beware of american date format for mktime, it accepts date in M/D/Y ;-)
80        return date(DATE_TIME_FORMAT, mktime($t[0], $t[1], $t[2], $d[1], $d[2], $d[0]));
81}
82
83/**
84 * EXIF translation.
85 *
86 * @param $key EXIF key name
87 * @param $value EXIF key value
88 * @return translated value depending on key meaning and choosed language
89 */
90function exif_key_translation($key, $value) {
91   // EXIF
92        if (!(strpos($key, 'ExifVersion') === FALSE)) {
93      return $value[1].'.'.$value[2];
94   }
95   
96   // Date Time Original
97   if (!(strpos($key, 'DateTimeOriginal') === FALSE)) {
98     // to fix bug:1862 the easiest way without releasing a new version of
99     // Piwigo itself, it's better to bypass the date format function
100     //
101     // return formatDate($value);
102     return $value;
103   }
104
105   // exposure time
106         if (!(strpos($key, 'ExposureTime') === FALSE)) {
107      $tokens = explode('/', $value);
108      while ($tokens[0] % 10 == 0) {
109         $tokens[0] = $tokens[0] / 10;
110         $tokens[1] = $tokens[1] / 10;
111      }
112      if ($tokens[1] == 1) {
113         return $tokens[0].' s';
114      } else {
115         return $tokens[0].'/'.$tokens[1].' s';
116      }
117   }
118
119   // aperture
120         if (!(strpos($key, 'FNumber') === FALSE)) {
121      $tokens = explode('/', $value);
122      return $tokens[0]/$tokens[1];
123   }
124
125   // flash
126   if (!(strpos($key, 'Flash') === FALSE)) {
127      // 1st bit is fired/did not fired
128      if (($value & 1) > 0) {
129         $retValue = l10n('yes');
130      } else {
131         $retValue = l10n('no');
132      }
133      // 2nd+3rd bits are return light mode
134      $returnLight = $value & (3 << 1);
135      switch ($returnLight) {
136        case 2 << 1: $retValue .= ', '.l10n('exif_value_flash_return_light_not_detected');break;
137        case 3 << 1: $retValue .= ', '.l10n('exif_value_flash_return_light_detected');break;
138      }
139      // 4th+5th bits are mode
140      $mode = $value & (3 << 3);
141      switch ($mode) {
142        case 0: $retValue .= ', '.l10n('exif_value_flash_mode').': '.l10n('exif_value_flash_mode_unknown');break;
143        case 1 << 3: $retValue .= ', '.l10n('exif_value_flash_mode').': '.l10n('exif_value_flash_mode_compulsory');break;
144        case 2 << 3: $retValue .= ', '.l10n('exif_value_flash_mode').': '.l10n('exif_value_flash_mode_supress');break;
145        case 3 << 3: $retValue .= ', '.l10n('exif_value_flash_mode').': '.l10n('exif_value_flash_mode_auto');break;
146      }
147                        // 6th bit is red eye function
148      if (($value & (1 << 6)) > 0) {
149         $retValue .= ', '.l10n('exif_value_red_eye');
150      }
151      return $retValue;
152   }
153
154   // exposure bias
155   if (!(strpos($key, 'ExposureBiasValue') === FALSE)) {
156      $tokens = explode('/', $value);
157      $newValue = $tokens[0] / $tokens[1];
158      // max EV range +-
159      $maxEV = 5;
160      // default value
161      $retValue = $newValue;
162      $absValue = truncate(abs($newValue), 2);
163      $found = FALSE;
164      // find through 1/3
165      for ($i = 1; $i <= $maxEV * 3 ; $i++) {
166         $ev = floor($i * 1/3.0 * 100) / 100;
167         if ($ev == $absValue) {
168            if ($i > 3) {
169               $retValue = (truncate($i / 3)).' '.($i % 3).'/3';
170            } else {
171               $retValue = $i.'/3';
172            }
173            $found = TRUE;
174            break;
175         }
176      }
177      // find through 1/2
178      if (!$found) {
179         for ($i = 1; $i <= $maxEV * 2 ; $i++) {
180            $ev = floor($i * 1/2.0 * 100) / 100;
181            if ($ev == $absValue) {
182               if ($i > 2) {
183                  $retValue = ($i / 2).' '.($i % 2).'/2';
184               } else {
185                  $retValue = $i.'/2';
186               }
187               $found = TRUE;
188               break;
189            }
190         }
191      }
192      // signs
193      if (($newValue < 0) && $found) {
194         $retValue = '- '.$retValue;
195      }
196      if ($newValue > 0) {
197         $retValue = '+ '.$retValue;
198      }
199      return $retValue.' EV';
200   }
201
202   // focal length 35mm
203   if (!(strpos($key, 'FocalLengthIn35mmFilm') === FALSE)) {
204      return $value.' mm';
205   }
206
207   // focal length
208   if (!(strpos($key, 'FocalLength') === FALSE)) {
209      $tokens = explode('/', $value);
210      return ($tokens[0]/$tokens[1]).' mm';
211   }
212
213   // digital zoom
214   if (!(strpos($key, 'DigitalZoomRatio') === FALSE)) {
215      $tokens = explode('/', $value);
216      return ($tokens[0]/$tokens[1]);
217   }
218
219   // white balance
220   if (!(strpos($key, 'WhiteBalance') === FALSE)) {
221      switch ($value) {
222         case 0: return l10n('exif_value_white_balance_auto');
223         case 1: return l10n('exif_value_white_balance_manual');
224         default: return '';
225      }
226   }
227
228   // exposure mode
229   if (!(strpos($key, 'ExposureMode') === FALSE)) {
230      switch ($value) {
231         case 0: return l10n('exif_value_exposure_mode_auto');
232         case 1: return l10n('exif_value_exposure_mode_manual');
233         case 2: return l10n('exif_value_exposure_mode_auto_bracket');
234         default: return '';
235      }
236   }
237
238   // exposure metering mode
239   if (!(strpos($key, 'MeteringMode') === FALSE)) {
240      switch ($value) {
241         case 0: return l10n('exif_value_metering_mode_unknown');
242         case 1: return l10n('exif_value_metering_mode_average');
243         case 2: return l10n('exif_value_metering_mode_CenterWeightedAVG');
244         case 3: return l10n('exif_value_metering_mode_spot');
245         case 4: return l10n('exif_value_metering_mode_multispot');
246         case 5: return l10n('exif_value_metering_mode_pattern');
247         case 6: return l10n('exif_value_metering_mode_partial');
248         default: return '';
249      }
250   }
251
252   // exposure program
253   if (!(strpos($key, 'ExposureProgram') === FALSE)) {
254      switch ($value) {
255         case 0: return l10n('exif_value_exposure_program_not_defined');
256         case 1: return l10n('exif_value_exposure_program_manual');
257         case 2: return l10n('exif_value_exposure_program_normal');
258         case 3: return l10n('exif_value_exposure_program_aperture');
259         case 4: return l10n('exif_value_exposure_program_shutter');
260         case 5: return l10n('exif_value_exposure_program_creative');
261         case 6: return l10n('exif_value_exposure_program_action');
262         case 7: return l10n('exif_value_exposure_program_portrait');
263         case 8: return l10n('exif_value_exposure_program_landscape');
264         default: return '';
265      }
266   }
267   
268   // light source
269   if (!(strpos($key, 'LightSource') === FALSE)) {
270      switch ($value) {
271         case 0: return l10n('exif_value_light_source_unknown');
272         case 1: return l10n('exif_value_light_source_daylight');
273         case 2: return l10n('exif_value_light_source_fluorescent');
274         case 3: return l10n('exif_value_light_source_tungsten');
275         case 4: return l10n('exif_value_light_source_flash');
276         case 9: return l10n('exif_value_light_source_fine_weather');
277         case 10: return l10n('exif_value_light_source_cloudy_weather');
278         case 11: return l10n('exif_value_light_source_shade');
279         case 12: return l10n('exif_value_light_source_daylight_fluorescent_d');
280         case 13: return l10n('exif_value_light_source_daywhite_fluorescent_n');
281         case 14: return l10n('exif_value_light_source_coolwhite_fluorescent_w');
282         case 15: return l10n('exif_value_light_source_white_fluorescent');
283         case 17: return l10n('exif_value_light_source_standard_light_a');
284         case 18: return l10n('exif_value_light_source_standard_light_b');
285         case 19: return l10n('exif_value_light_source_standard_light_c');
286         case 20: return l10n('exif_value_light_source_D55');
287         case 21: return l10n('exif_value_light_source_D65');
288         case 22: return l10n('exif_value_light_source_D75');
289         case 23: return l10n('exif_value_light_source_D50');
290         case 24: return l10n('exif_value_light_source_iso_studio_tungsten');
291         case 255: return l10n('exif_value_light_source_other');
292         default: return '';
293      }
294   }
295
296   // contrast
297   if (!(strpos($key, 'Contrast') === FALSE)) {
298      switch ($value) {
299         case 0: return l10n('exif_value_contrast_normal');
300         case 1: return l10n('exif_value_contrast_soft');
301         case 2: return l10n('exif_value_contrast_hard');
302         default: return '';
303      }
304   }
305
306   // sharpness
307   if (!(strpos($key, 'Sharpness') === FALSE)) {
308      switch ($value) {
309         case 0: return l10n('exif_value_sharpness_normal');
310         case 1: return l10n('exif_value_sharpness_soft');
311         case 2: return l10n('exif_value_sharpness_hard');
312         default: return '';
313      }
314   }
315
316   // saturation
317   if (!(strpos($key, 'Saturation') === FALSE)) {
318      switch ($value) {
319         case 0: return l10n('exif_value_saturation_normal');
320         case 1: return l10n('exif_value_saturation_low');
321         case 2: return l10n('exif_value_saturation_hard');
322         default: return '';
323      }
324   }
325
326   // return value unchanged
327   return $value;
328}
329define('exif_DIR' , basename(dirname(__FILE__)));
330define('exif_PATH' , PHPWG_PLUGINS_PATH . exif_DIR . '/');
331        /**
332         * Loads plugin language file.
333         */
334  function loadLang() {
335    global $lang;
336    load_language('lang.exif', exif_PATH);
337  }
338
339/**
340 * EXIF translation.
341 *
342 * @param $key EXIF key name
343 * @param $value EXIF key value
344 * @return translated value dependend on key meaning and choosed language
345 */
346function exif_translation($exif) {
347         // translate all exif fields
348         if (is_array($exif)) {
349         loadLang();
350           foreach ($exif as $key => $value) {
351                         $exif[$key] = exif_key_translation($key, $value);
352           }
353         }
354   return $exif;
355}
356
357?>
Note: See TracBrowser for help on using the repository browser.