[ImageMagick] Remove unnecessary code

ImageMagickPlugin:
- Remove animated thumbnail setting, we'll be able to use FFmpeg for performance
- Remove onFillImageFileMetadata and onCreateFileImageThumbnailSource(), these
  are handled just fine by ImageFile
- Bump minor version number

README:
- Update
This commit is contained in:
tenma 2020-08-13 18:31:43 +01:00
parent b65c200922
commit 8a2c1658a8
2 changed files with 8 additions and 79 deletions

View File

@ -29,48 +29,16 @@
if (!defined('GNUSOCIAL')) { exit(1); } if (!defined('GNUSOCIAL')) { exit(1); }
/*
* Dependencies:
* php5-imagick
*
* Provides:
* Animated GIF resize support
*
* Comments:
* Animated GIF resize requires setting $config['thumbnail']['animated'] = true;
*
* Bugs:
* Not even ImageMagick is very good at resizing animated GIFs.
* We are not infinitely fast, so resizing animated GIFs is _not_ recommended.
*/
class ImageMagickPlugin extends Plugin class ImageMagickPlugin extends Plugin
{ {
const PLUGIN_VERSION = '2.0.0'; const PLUGIN_VERSION = '2.1.0';
public $preview_imageformat = 'PNG'; // Image format strings: http://www.imagemagick.org/script/formats.php#supported
public $rasterize_vectors = false; // Whether we want to turn SVG into PNG etc.
/**
* @param ImageFile $file An ImageFile object we're getting metadata for
* @param array $info The response from getimagesize()
*/
public function onFillImageFileMetadata(ImageFile $imagefile) {
if (is_null($imagefile->animated) && $imagefile->mimetype === 'image/gif') {
$magick = new Imagick($imagefile->filepath);
$magick = $magick->coalesceImages();
$imagefile->animated = $magick->getNumberImages()>1;
}
return true;
}
public function onStartResizeImageFile(ImageFile $imagefile, $outpath, array $box) public function onStartResizeImageFile(ImageFile $imagefile, $outpath, array $box)
{ {
switch ($imagefile->mimetype) { switch ($imagefile->mimetype) {
case 'image/gif': case 'image/gif':
// If GIF, then only for animated gifs! (and only if we really want to resize the animation!) // If GIF, then only for animated gifs
if ($imagefile->animated && common_config('thumbnail', 'animated')) { if ($imagefile->animated) {
return $this->resizeImageFileAnimatedGif($imagefile, $outpath, $box); return $this->resizeImageFileAnimatedGif($imagefile, $outpath, $box);
} }
break; break;
@ -91,7 +59,6 @@ class ImageMagickPlugin extends Plugin
$magick = $magick->deconstructImages(); $magick = $magick->deconstructImages();
// $magick->writeImages($outpath, true); did not work, had to use filehandle // $magick->writeImages($outpath, true); did not work, had to use filehandle
// There's been bugs for writeImages in php5-imagick before, probably now too
$fh = fopen($outpath, 'w+'); $fh = fopen($outpath, 'w+');
$success = $magick->writeImagesFile($fh); $success = $magick->writeImagesFile($fh);
fclose($fh); fclose($fh);
@ -100,40 +67,6 @@ class ImageMagickPlugin extends Plugin
return !$success; return !$success;
} }
public function onCreateFileImageThumbnailSource(File $file, &$imgPath, $media=null)
{
switch ($file->mimetype) {
case 'image/svg+xml':
if (!$this->rasterize_vectors) {
// ImageMagick seems to be hard to trick into scaling vector graphics...
return true;
}
break;
default:
// If we don't know the format, let's try not to mess with anything.
return true;
}
$imgPath = tempnam(sys_get_temp_dir(), 'socialthumb-');
if (!$this->createImagePreview($file, $imgPath)) {
common_debug('Could not create ImageMagick preview of File id=='.$file->id);
@unlink($imgPath);
$imgPath = null;
return true;
}
return false;
}
protected function createImagePreview(File $file, $outpath)
{
$magick = new Imagick($file->getPath());
$magick->setImageFormat($this->preview_imageformat);
$magick->writeImage($outpath);
$magick->destroy();
return getimagesize($outpath); // Verify that we wrote an understandable image.
}
public function onPluginVersion(array &$versions): bool public function onPluginVersion(array &$versions): bool
{ {
$versions[] = array('name' => 'ImageMagick', $versions[] = array('name' => 'ImageMagick',

View File

@ -1,21 +1,17 @@
The ImageMagick plugin handles more kinds of image formats for thumbnails, The ImageMagick plugin handles more kinds of image formats for thumbnails,
thanks to ImageMagick. thanks to ImageMagick.
Note: This plugin depends on php5-imagick Note: This plugin depends on php-imagick
Installation Installation
============ ============
add "addPlugin('ImageMagick');" add "addPlugin('ImageMagick');"
to the bottom of your config.php to the bottom of your config.php
Settings Notes
======== ========
animated: Whether to resize animated GIFs.
Note: We are not infinitely fast, so resizing animated GIFs is _not_ recommended. - This plugin depends on php-imagick.
Example
=======
$config['thumbnail']['animated'] = true;
addPlugin('ImageMagick');
- Imagick is not very good at resizing animated GIFs.
Consider using the FFmpeg plugin for a faster alternative.