From 42fa47e8f780e50392ca2b2289f58d2f6b840c86 Mon Sep 17 00:00:00 2001 From: Zach Prezkuta Date: Mon, 18 Jun 2012 20:53:46 -0600 Subject: [PATCH 1/2] rotate uploaded images if an EXIF rotation is present --- include/Photo.php | 62 ++++++++++++++++++++++++++++++++++++++++++++++- mod/photos.php | 1 + 2 files changed, 62 insertions(+), 1 deletion(-) diff --git a/include/Photo.php b/include/Photo.php index aa6f5f113c..66dec06118 100644 --- a/include/Photo.php +++ b/include/Photo.php @@ -121,7 +121,67 @@ class Photo { $this->image = imagerotate($this->image,$degrees,0); $this->width = imagesx($this->image); $this->height = imagesy($this->image); - } + } + + public function flip($horiz = true, $vert = false) { + $w = imagesx($this->image); + $h = imagesy($this->image); + $flipped = imagecreate($w, $h); + if($horiz) { + for ($x = 0; $x < $w; $x++) { + imagecopy($flipped, $this->image, $x, 0, $w - $x - 1, 0, 1, $h); + } + } + if($vert) { + for ($y = 0; $y < $h; $y++) { + imagecopy($flipped, $this->image, 0, $y, 0, $h - $y - 1, $w, 1); + } + } + $this->image = $flipped; + } + + public function orient($filename) { + // based off comment on http://php.net/manual/en/function.imagerotate.php + + $exif = exif_read_data($filename); + $ort = $exif['Orientation']; + + switch($ort) + { + case 1: // nothing + break; + + case 2: // horizontal flip + $this->flip(); + break; + + case 3: // 180 rotate left + $this->rotate(180); + break; + + case 4: // vertical flip + $this->flip(false, true); + break; + + case 5: // vertical flip + 90 rotate right + $this->flip(false, true); + $this->rotate(-90); + break; + + case 6: // 90 rotate right + $this->rotate(-90); + break; + + case 7: // horizontal flip + 90 rotate right + $this->flip(); + $this->rotate(-90); + break; + + case 8: // 90 rotate left + $this->rotate(90); + break; + } + } diff --git a/mod/photos.php b/mod/photos.php index a6552994e5..4fa8aca082 100644 --- a/mod/photos.php +++ b/mod/photos.php @@ -718,6 +718,7 @@ function photos_post(&$a) { killme(); } + $ph->orient($src); @unlink($src); $width = $ph->getWidth(); From 7cd516e34f95945b7f15f42cfe7318dfd907c8d8 Mon Sep 17 00:00:00 2001 From: Zach Prezkuta Date: Mon, 18 Jun 2012 21:06:54 -0600 Subject: [PATCH 2/2] fix some whitespace issues --- include/Photo.php | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/include/Photo.php b/include/Photo.php index 66dec06118..54db9278e4 100644 --- a/include/Photo.php +++ b/include/Photo.php @@ -124,20 +124,20 @@ class Photo { } public function flip($horiz = true, $vert = false) { - $w = imagesx($this->image); - $h = imagesy($this->image); - $flipped = imagecreate($w, $h); + $w = imagesx($this->image); + $h = imagesy($this->image); + $flipped = imagecreate($w, $h); if($horiz) { - for ($x = 0; $x < $w; $x++) { - imagecopy($flipped, $this->image, $x, 0, $w - $x - 1, 0, 1, $h); - } - } - if($vert) { - for ($y = 0; $y < $h; $y++) { - imagecopy($flipped, $this->image, 0, $y, 0, $h - $y - 1, $w, 1); - } - } - $this->image = $flipped; + for ($x = 0; $x < $w; $x++) { + imagecopy($flipped, $this->image, $x, 0, $w - $x - 1, 0, 1, $h); + } + } + if($vert) { + for ($y = 0; $y < $h; $y++) { + imagecopy($flipped, $this->image, 0, $y, 0, $h - $y - 1, $w, 1); + } + } + $this->image = $flipped; } public function orient($filename) {