diff options
author | Clark Tomlinson <fallen013@gmail.com> | 2014-09-03 09:14:35 -0400 |
---|---|---|
committer | Clark Tomlinson <fallen013@gmail.com> | 2014-09-03 09:14:35 -0400 |
commit | d64cacec438e379a39fd2e791020f417b3737d9b (patch) | |
tree | e5d23218b3faaa1934dae080b5b22027baec8dd5 | |
parent | 0400f7845c46dabc2c87913a8a047c11e39b3323 (diff) | |
parent | 3bf155e138511da0c548ea4e40dcab5173be5238 (diff) | |
download | nextcloud-server-d64cacec438e379a39fd2e791020f417b3737d9b.tar.gz nextcloud-server-d64cacec438e379a39fd2e791020f417b3737d9b.zip |
Merge pull request #10826 from oparoz/master
Adding TIFF support to the files app
-rwxr-xr-x | lib/private/preview.php | 1 | ||||
-rw-r--r-- | lib/private/preview/tiff.php | 48 |
2 files changed, 49 insertions, 0 deletions
diff --git a/lib/private/preview.php b/lib/private/preview.php index cc15ab84fe7..086d9c0272a 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 diff --git a/lib/private/preview/tiff.php b/lib/private/preview/tiff.php new file mode 100644 index 00000000000..c435ec71352 --- /dev/null +++ b/lib/private/preview/tiff.php @@ -0,0 +1,48 @@ +<?php +/** + * Copyright (c) 2013-2014 Georg Ehrke georg@ownCloud.com + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ +namespace OC\Preview; + +use Imagick; + +if (extension_loaded('imagick')) { + + $checkImagick = new Imagick(); + + if(count($checkImagick->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); + $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'); + } +} |