forked from theonemule/gphoto-webui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCameraRaw.php
161 lines (143 loc) · 5.05 KB
/
CameraRaw.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
<?php
/**
* A class that can fetch preview images from camera raw files.
*
* In order to use this class you'll need a few php mods and
* some other software installed on your server.
*
* - imagemagick (Manage images)
* - ufraw (Reading and converting raw files)
* - exiv2 (Extracting previews from raw files)
*
*/
class CameraRaw {
/**
* @var array an array containing popular raw file format extensions
*/
private static $rawExtensions = array('.ari','.arw','.bay','.crw','.cr2','.cap','.dcs','.dcr','.dng','.drf','.eip','.erf','.fff','.iiq','.k25','.kdc','.mdc','.mef','.mos','.mrw','.nef','.nrw','.obm','.orf','.pef','.ptx','.pxn','.r3d','.raf','.raw','.rwl','.rw2','.rwz','.sr2','.srf','.srw', '.x3f');
private static $imgExtensions = array('.jpg', '.jpeg');
/**
* Checks if a file exists based on the filepath.
*
* @param string $filePath the path to the file
* @return bool returns true if the file exists
*/
private static function checkFile($filePath) {
if(file_exists($filePath)) {
return true;
}
return false;
}
/**
* Checks if a file is a raw file based on file extension.
*
* @param string $filePath the path to the file
* @return bool returns true if the file is a raw type
*/
public static function isImageFile($filePath) {
$fileExtension = '.' . pathinfo($filePath, PATHINFO_EXTENSION);
if(in_array(strToLower($fileExtension), self::$rawExtensions)) {
return true;
} else if(in_array(strToLower($fileExtension), self::$imgExtensions)) {
return true;
}
return false;
}
/**
* Checks if a file is a raw file based on file extension.
*
* @param string $filePath the path to the file
* @return bool returns true if the file is a raw type
*/
public static function isRawFile($filePath) {
$fileExtension = '.' . pathinfo($filePath, PATHINFO_EXTENSION);
if(in_array(strToLower($fileExtension), self::$rawExtensions)) {
return true;
}
return false;
}
/**
* Fetches all preview types that are embedded in an image.
*
* @param string $filePath the path to the file
* @return array all the detected previews.
*/
public static function embeddedPreviews($filePath) {
if(!self::checkFile($filePath)) {
throw new \InvalidArgumentException('Incorrect filepath given');
}
$previews = array();
exec('exiv2 -pp "'.$filePath.'"', $previews);
return $previews;
}
/**
* Generates a new jpg image with new sizes from an already existing file.
* (This will also work on raw files, but it will be exceptionally
* slower than extracting the preview).
*
* @param string $sourceFilePath the path to the original file
* @param string $targetFilePath the path to the target file
* @param int $width the max width
* @param int $height the max height of the image
* @param int $quality the quality of the new image (0-100)
*
* @throws \InvalidArgumentException
*
* @return void.
*/
public static function generateImageJPG($sourceFilePath, $targetFilePath, $width = -1, $height = -1, $quality = 60) {
if(!self::checkFile($sourceFilePath)) {
throw new \InvalidArgumentException('Incorrect filepath given');
}
$im = new \Gmagick($sourceFilePath);
$im->setImageFormat('jpg');
$im->setCompressionQuality($quality);
$im->stripImage();
if ($width > -1 || $height > -1)
$im->thumbnailImage($width, $height, true);
$im->writeImage($targetFilePath);
$im->clear();
$im->destroy();
}
/**
* Extracts a preview image from an image and saves the
* image to the designated path.
*
* @param string $sourceFilePath the path to the original file
* @param string $targetFilePath the path to the new file
* @param int $previewNumber which preview (defaults to the highest preview)
*
* @throws \InvalidArgumentException
* @throws \Exception
*
* @return void.
*/
public static function extractPreview($sourceFilePath, $targetFilePath, $previewNumber = null) {
// check that the source file exists.
if(!self::checkFile($sourceFilePath)) {
throw new \InvalidArgumentException('Incorrect source filepath given '.$sourceFilePath);
}
// fetch the all the preview images (and verify that there indeed exit previews)
$numberOfPreviews = self::embeddedPreviews($sourceFilePath);
if(count($numberOfPreviews) == 0) {
throw new \Exception('No embedded previews detected');
}
// default to the last preview
if(is_null($previewNumber)) {
$previewNumber = count($numberOfPreviews);
}
$previewNumber = intval($previewNumber);
$filename = pathinfo($sourceFilePath, PATHINFO_FILENAME);
$return = array();
// generate the preview with exiv2, save it to the temp directory
exec('exiv2 -ep'.$previewNumber.' -l '.sys_get_temp_dir(). ' "' . $sourceFilePath . '"', $return);
$previewFilePath = sys_get_temp_dir() . DIRECTORY_SEPARATOR . $filename . '-preview' . $previewNumber . '.jpg';
// check that the preview got saved correctly
if(!self::checkFile($previewFilePath)) {
throw new \Exception('No preview file.');
}
// copy the preview to the target path and remove the original one in temp
copy($previewFilePath, $targetFilePath);
unlink($previewFilePath);
}
}