用Python获取可能是全网最全的杰尼龟表情包(第三弹)

根据前几篇文章,我们已经得到了大量包含杰尼龟的图片,接下来我们就对这些图片来做一些简单的处理,添加与图片相符的文字或是生成gif动图。

file

文字添加

迅哥曾经说过,没有文字的表情包是没有灵魂的。因此今天我们就用Python在图片上添加文字,先随便拿一张杰尼龟的图片。

file

这里我们采用PIL库来给图片的指定位置添加指定的文字,truetype函数来设置字体类型以及大小,text函数来添加指定颜色的文字。

def add_font(text):
    font=ImageFont.truetype('simhei.ttf', 70)
    img=Image.open('a.jpg')
    draw=ImageDraw.Draw(img)
    draw.text((200,400),text,font=font,fill='white')
    img.save('add_font.jpg')

file

这些图片配上相符的文字后,有一种画龙点睛的错觉。你可能会想,一张一张加文字,和用P图有什么区别。恰巧,去年就有一篇专门研究给表情包添加相应文字的论文,用OCR提取表情包中的文字,采用对抗生成网络训练这些去掉文字的表情包,这个网络便能够在你输入新表情包的时候能给给出与该表情相符的文字,论文传送门放在最底部。

file

动图制作

之前我们是从剪切的图片中获取杰尼龟的图片,是大粒度的分类,现在我们需要来做一个小粒度的分类,即按照图片的相似性,把相似的图片分为一组,从而制作成为动图(这些相似的图片本就是视频之中的连续图片)。

我们可以采用平均哈希的做法来计算图片的相似度,具体可以参考你朋友圈发的假图被我发现了!这篇文章,通过比对图片的指纹来判断相似程度,另外我们还可以采用CV2的模板匹配算法来筛选相似图片。

这样便可以完成小粒度的筛选,我们可以将这些相似图片通过PIL库来生成gif动图。

def make_gif():
    gif_images=[]
    img_paths=os.listdir('gif')
    img_paths=[os.sep.join(['gif',i]) for i in img_paths]
    for path in img_paths:
        gif_images.append(imageio.imread(path))
    imageio.mimsave("a.gif",gif_images,fps=4)

至此,用Python获取可能是全网最全的杰尼龟表情包全系列完结撒花!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值