From 1e600a0d36a074ce1e3d4c55a0f6461f5be16018 Mon Sep 17 00:00:00 2001 From: Olivier Paroz Date: Tue, 2 Sep 2014 22:53:41 +0200 Subject: [PATCH 1/3] Adding support for tiff files --- lib/private/preview.php | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/private/preview.php b/lib/private/preview.php index cc15ab84fe..086d9c0272 100755 --- a/lib/private/preview.php +++ b/lib/private/preview.php @@ -24,6 +24,7 @@ require_once 'preview/svg.php'; require_once 'preview/txt.php'; require_once 'preview/unknown.php'; require_once 'preview/office.php'; +require_once 'preview/tiff.php'; class Preview { //the thumbnail folder From b559b21dc37228062ba8c3cccd842771d17132ce Mon Sep 17 00:00:00 2001 From: Olivier Paroz Date: Tue, 2 Sep 2014 22:56:39 +0200 Subject: [PATCH 2/3] Converts TIFF files to PNG --- lib/private/preview/tiff.php | 48 ++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 lib/private/preview/tiff.php diff --git a/lib/private/preview/tiff.php b/lib/private/preview/tiff.php new file mode 100644 index 0000000000..52b53b00d1 --- /dev/null +++ b/lib/private/preview/tiff.php @@ -0,0 +1,48 @@ +queryFormats('TIFF')) === 1) { + + class TIFF extends Provider { + + public function getMimeType() { + return '/image\/tiff/'; + } + + public function getThumbnail($path, $maxX, $maxY, $scalingup, $fileview) { + $tmpPath = $fileview->toTmpFile($path); + + //create imagick object from TIFF + try{ + $tiff = new Imagick($tmpPath . '[0]'); + $tiff->setImageFormat('png'); + } catch (\Exception $e) { + \OC_Log::write('core', $e->getmessage(), \OC_Log::ERROR); + return false; + } + + unlink($tmpPath); + + //new image object + $image = new \OC_Image($tiff); + //check if image object is valid + return $image->valid() ? $image : false; + } + + } + + \OC\Preview::registerProvider('OC\Preview\TIFF'); + } +} From 3bf155e138511da0c548ea4e40dcab5173be5238 Mon Sep 17 00:00:00 2001 From: Olivier Paroz Date: Wed, 3 Sep 2014 12:32:59 +0200 Subject: [PATCH 3/3] This is not a PDF, there are no pages --- lib/private/preview/tiff.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/private/preview/tiff.php b/lib/private/preview/tiff.php index 52b53b00d1..c435ec7135 100644 --- a/lib/private/preview/tiff.php +++ b/lib/private/preview/tiff.php @@ -26,7 +26,7 @@ if (extension_loaded('imagick')) { //create imagick object from TIFF try{ - $tiff = new Imagick($tmpPath . '[0]'); + $tiff = new Imagick($tmpPath); $tiff->setImageFormat('png'); } catch (\Exception $e) { \OC_Log::write('core', $e->getmessage(), \OC_Log::ERROR);