昨夜刷b站的时候,看到了一条评论,形式如下图,于是心血来潮写了个python脚本,可以根据文字来生成这种由emoji拼接成的“文字”。
代码的思路极其简单,这种形式的“文字”可以理解为一张黑白图片,图中的白色使用一种emoji表情代替,黑色使用另一种emoji代替。那么想要生成这种“文字”,则我们只需要两步即可,第一步是根据输入文字得到一张图,第二步则是遍历这张图片,当前像素的颜色为黑色时我们输出表情,为白色时输出b表情。在网上简单搜索了一下,PIL中的ImageDraw类型含有text方法用于生产文字图片,本脚本即采用该方法实现。
脚本代码如下,各种注意事项均已在代码注释中写明。
# coding=utf-8 from PIL import Image, ImageFont, ImageDraw import numpy as np def getTextImage(text, fontFilePath = None, fontSzie = 10): #此处踩坑,truetype方法必须传入字体文件路径,传入None会报错 font = ImageFont.truetype(fontFilePath, fontSzie, encoding='unic') #此处踩坑,在生成图片的文字为多行文字时,getsize方法返回的宽高会交换,具体什么原因未知,但是这么写就是对的 height,width = font.getsize(text) #此处踩坑,getsize方法返回的高度在有些情况下可能不够长 因此将高度拓展为原来的1.2倍 height = int(height * 1.2) #生成一张黑白纹理 img = Image.new("1", (width, height)) draw = ImageDraw.Draw(img) #textsize方法同样可以得到要生成的文字的大小 该大小更为准确 那么为啥不用这个大小直接生成图片呢 存疑 w,h = draw.textsize(text, font) #渲染文字, 第一个参数是offset,此处传入的值是为了让渲染的文字居于图片的中心 draw.text(((width - w) / 2 ,(height - h) /2 ), text, font = font, fill='red', align='center') # img.show() return img def getEmojiTextFromPureText(text): #在输入的文字中插入换行符,以得到竖排文字 mutilLineText = '' lens = len(text) for i in range(lens): mutilLineText += text[i] if i != lens - 1: mutilLineText += '\n' #此处踩坑 在mac上有些字体生成汉字是会乱码,经本人尝试,simsun.ttc字体和Hiragino Sans GB.ttc字体均可生成中文图片,其余的不知道哪种字体可行 img = getTextImage(mutilLineText, '/Users/xiaoyi/Downloads/simsun.ttc', fontSzie= 11) #将PIL的Image转为np的array 遍历图片输出即可 array = np.array(img) height,width = array.shape for j in range(height): for i in range(width): if array[j][i] : print('', end = '') #传入end参数,用于指定不换行 else: print('', end = '') print('') getEmojiTextFromPureText('全世界无产者联合起来')
使用该脚本生成“文字”效果如下:
该脚本中有几个遗留的小问题:
1.因为在手机微信中发送消息时会将过长的消息自动换行,所以脚本中将fontSize指定为11,但是这样生成出来的文字分辨率很低,面对一些复杂的问题时,最终得到的结果会难以辨识。
2.因为将长度扩展了1.2倍,所以生成出来的结果中在上下两侧会冗余一些无用的emoji表情。
3.本脚本并未将结果输出至文本中,仅在控制台打印 使用或有不便。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理