动画gif调整大小与sorl-thumbnail

时间:2011-01-17 09:53:50

标签: django gif sorl-thumbnail

是否有可能使用sorl调整GIF动画效果?

4 个答案:

答案 0 :(得分:6)

哇,这是我永远不会想到的功能请求! sorl.thumbnail现在可以配置引擎,并附带PIL和pgmagick。我认为有一些方法可以使imagemagick调整动画GIF动画,所以也许pgmagick可以做到这一点,但我没有对此进行过测试,并且它不太可能按原样使用已发布的引擎。

答案 1 :(得分:3)

我有工作解决方案(使用sorl-thumbnail 11.12.1b测试)。需要魔杖后端:

#sorl_extensions.py
from sorl.thumbnail.base import (
    ThumbnailBackend, EXTENSIONS,
    default_settings as thumbnail_default_settings
)


EXTENSIONS.update({'GIF': 'gif'})


class GifThumbnailBackend(ThumbnailBackend):
    def _get_format(self, file_):
        file_extension = self.file_extension(file_)

        if file_extension == '.jpg' or file_extension == '.jpeg':
            return 'JPEG'
        elif file_extension == '.png':
            return 'PNG'
        elif file_extension == '.gif':
            return 'GIF'
        else:
            from django.conf import settings

            return getattr(settings, 'THUMBNAIL_FORMAT', thumbnail_default_settings.THUMBNAIL_FORMAT)

#settings.py
THUMBNAIL_ENGINE = 'sorl.thumbnail.engines.wand_engine.Engine'
THUMBNAIL_BACKEND = 'tools.sorl_extensions.GifThumbnailBackend'
THUMBNAIL_PRESERVE_FORMAT = True

答案 2 :(得分:2)

我设法使用gif制作了sorl。

  1. 你需要使用图像magick或图形magick后端(PIL不支持gif调整大小而没有一些黑客攻击)。你也可以尝试pgmagick,但我不知道它是否会起作用。
  2. 将这些放在代码中的某处:

    from sorl.thumbnail import base
    base.EXTENSIONS.update({'GIF': 'gif'})
    
  3. 您可以查看sorl-thumnail来源以了解其工作原理

    UPD:未经测试。只有在确定自己在做什么时才使用此功能。

答案 3 :(得分:0)

我将分享我的例子:

# -*- coding: utf-8 -*-
import os
from sorl.thumbnail import get_thumbnail

def get_file_extension(obj):
    filename, file_extension = os.path.splitext(obj)
    return file_extension

def get_thumbnail_size(obj, size):
    img_format = 'JPEG'
    if get_file_extension(obj.url) == '.png':
        img_format = 'PNG'
    if get_file_extension(obj.url) == '.gif':
        from sorl.thumbnail import base
        base.EXTENSIONS.update({'GIF': 'gif'})
        img_format = 'GIF'
    return get_thumbnail(obj, size, quality=90, format=img_format).url