这次让我们一个用 Python 做一个小工具:将动态 GIF 图片倒序播放!
GIF(Graphics Interchange Format) 是一种可以用来呈现动画效果的图片格式,原理就是保存很多帧(Frame)静态图像,然后连续呈现。很多简短的视频也会被转换成动态 GIF 呈现,压缩画质和去除声音之后可以有效地减小文件大小。网络上不计其数的搞笑动图,几乎承载了网友大半的欢乐,但是也有人发现,将正常的动画倒序播放往往可以获得更搞笑的效果,Reddit 上甚至有一个专门的节点:/r/reversegif。
要做到这一点其实很简单,只要从原始图片中提取中间每一帧静态图像,然后将顺序颠倒之后重新生成一张 GIF 图片即可。Python 中专门用于处理图像的库是 PIL,在 PIL 基础上由 Alex Clark 等人开发了一个更友好的版本:Pillow。于是首先来安装(或升级)Pillow:
pip install --upgrade pillow -i http://pypi.douban.com/simple python -c "import PIL; print(PIL.VERSION, '\t', PIL.PILLOW_VERSION)" // 1.1.7 3.4.2 利用 Pillow 可以先读取图片文件并判断该图片是否为动态图片及其帧数: from PIL import Imagewith Image.open('ani.gif') as im: print(im.is_animated, im.n_frames)
新版本的 Pillow 提供了更多写入 GIF 的功能:
im.save(out, save_all=True, append_images=[im1, im2, ...])
通过设定 save_all=True 参数和 append_images 可以一次性将多帧图像同时存入 GIF 图片,于是我们可以这样来生成倒序播放的图片:
from PIL import Image, ImageSequence with Image.open('ani.gif') as im: if im.is_animated: frames = [f.copy() for f in ImageSequence.Iterator(im)] frames.reverse() # 内置列表倒序方法 # 将倒序后的所有帧图像保存下来 frames[0].save('out.gif', save_all=True, append_images=frames[1:])
再来看一个比较明显的效果:
为了满足微信2M 图片大小限制,倒序图片经过了采样压缩处理
如果想要达到鬼畜一些的效果,还可以对所有帧随机打乱顺序:
import random # frames.reverse() random.shuffle(frames)
效果如下:
以上所述是小编给大家介绍的用Python将动态GIF图片倒放播放的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍Python实现GIF图倒放,包括了Python实现GIF图倒放的使用技巧和注意事项,需要的朋友参考一下 前言 GIF图现在已经融入了我们的日常网络生活,微信群、QQ群、朋友圈......一言不合就斗图,你怕了吗?不用担心,只要学会了Python之GIF倒放技能,你就是“斗图王”。 咱们直接开始本文的内容! PIL(Python Image Library) 它是python的第三方
问题内容: 我想使用python3和tkinter创建一个虚拟的宠物风格游戏。到目前为止,我已经有了主窗口并开始放入标签,但是我遇到的问题是播放动画gif。我在这里搜索并找到了一些答案,但是他们不断抛出错误。我发现使用PhotoImage的结果具有gif的索引位置,并在一定范围内继续。 当我在终端中使用“ pyhton3 main.py”运行此命令时,出现以下错误: _tkinter.TclErr
本文向大家介绍Unity3D实现播放gif图功能,包括了Unity3D实现播放gif图功能的使用技巧和注意事项,需要的朋友参考一下 Unity是不识别Gif格式图的,需要我们使用c#将gif里多帧图转化为Texture2D格式。需要使用System.Drawing.dll.此dll在unity安装目录下就可以找到。由于unity没有gif格式的文件,所以我们无法在面板指定,需要动态加载。所以将gi
我看到这个问题问了很多,但我还没有看到一个非常普遍的方法。我正在使用JavaFX在JavaEclipse Oxygen中开发一个桌面应用程序,我有一个加载器,我想在任何时候通过超文本传输协议加载图像。当用户单击不同的行时,图像必须通过超文本传输协议加载。所以我把我的加载器放在图像的顶部,我只是使用;来显示或隐藏它。fxml中的加载器ImageView在GridPane中看起来像这样。 设置加载器映
主要目标是想让儿童可以以最好的体验来看动画片。 1、支持记录每一部动画片的当前播放位置,方便下次打开的时候可以接着看。 2、可以增加片头、片尾的时间点,不用每次都播放重复内容。 3、播放、暂停、上一集、下一集、快照、全屏等。
本文向大家介绍js手动播放图片实现图片轮播效果,包括了js手动播放图片实现图片轮播效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js图片轮播具体实现代码,供大家参考,具体内容如下 一、html代码部分(et.thtml): 二、css代码部分(styleet,css): 三、js代码部分(et.js): 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教