<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在日常生活中,我們經常會存取一些朋友們的醜照,在這個專案中,我們以萌萌噠的熊貓頭作為背景,然後試著在背景圖上加入朋友們的照片。
效果如下圖所示:
import cv2 import numpy as mp import matplotlib.pyplot as plt from PIL import Image, ImageDraw, ImageFont
這個專案主要是通過 opencv
完成,但如果要在表情包下面寫中文的話,PIL(pillow)
庫是必不可少的。
這裡寫一個繪圖函數,方便繪圖操作。
def plt_show(img): imageRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) plt.imshow(imageRGB)plt.show
image = cv2.imread('SXC.jpg', 0) # 匯入灰度圖即可 plt_show(image)
因為我們發現前景照片的尺寸比背景尺寸還要大,這顯然是不合適的,所以要先對其進行等比例(0.3)縮放。
image_resize = cv2.resize(image, None, fx=0.3, fy=0.3, interpolation = cv2.INTER_CUBIC) plt_show(image_resize)
在這裡,我們將畫素值大於 80 的區域設定為 255;小於 80 的區域設定成 0。
ret, image_binary = cv2.threshold(image_resize, 80, 255, cv2.THRESH_BINARY) plt_show(image_binary)
image_roi = image_binary[74: 185, 0: 150] plt_show(image_roi)
因為我們的背景圖片(熊貓頭)是正的,而前景圖片有些向右傾斜,所以要先對其進行旋轉操作(大概逆時針旋轉 15 度即可)。
rows, cols = image_roi.shape M = cv2.getRotationMatrix2D(((cols-1)/2.0, (rows-1)/2.0), 15, 1) # (旋轉中心,逆時針旋轉角度,各個方向同等擴大比例) image_rotate = cv2.warpAffine(image_roi, M, (140, 130)) # (140, 130) 是指旋轉後的畫布大小 plt_show(image_rotate)
在這裡我們使用cv2.fillPoly
函數對不需要的區域用白色進行填充。
h, w = image_rotate.shape image_rotate_copy = image_rotate.copypts1 = np.array([[0, 20], [64, 0], [0, 0]], np.int32) pts2 = np.array([[0, 18], [0, h], [80, h]], np.int32) pts3 = np.array([[0, 100], [0, h], [w, h], [w, 100]], np.int32) pts4 = np.array([[111, 0], [w, 0], [w, 30]], np.int32) pts5 = np.array([[124, 0], [115, h], [w, h]], np.int32) pts6 = np.array([[120, 40], [95, 100], [120, 100]], np.int32) foreground = cv2.fillPoly(image_rotate_copy, [pts1], (255, 255, 255)) # (圖片,填充區域,填充顏色) foreground = cv2.fillPoly(image_rotate_copy, [pts2], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts3], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts4], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts5], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts6], (255, 255, 255)) plt_show(foreground)
foreground_roi = foreground[0: 93, 0: 125] plt_show(foreground_roi) foreground_roi_resize = cv2.resize(foreground_roi, None, fx=2.5, fy=2.5, interpolation = cv2.INTER_CUBIC) plt_show(foreground_roi_resize)
background = cv2.imread('back.jpg', 0) plt_show(background)
h_f, w_f = foreground.shape h_b, w_b = background.shapeleft = (w_b - w_f)//2 # 前景圖片在背景圖片中的左邊的橫座標 right = left + w_f # 前景圖片在背景圖片中的右邊的橫座標 top = 100 # 前景圖片在背景圖片中的上邊的縱座標 bottom = top + h_f # 前景圖片在背景圖片中的下邊的縱座標 emoji = background emoji[top: bottom, left: right] = foreground plt_show(emoji)
如果只是要新增英文文字,用 opencv 就可以解決:
emoji_copy = emoji.copy # (圖片,文字,位置,字型,文字大小,文字顏色,文字粗細) cv2.putText(emoji_copy, "FXXK!!", (210, 500), cv2.FONT_HERSHEY_SIMPLEX, 1.2, (0, 0, 0), 5) plt_show(emoji_copy)
如果要新增中文文字,我們需要藉助 PIL 庫來實現。
PilImg = Image.fromarray(emoji) # cv2 轉 PIL draw = ImageDraw.Draw(PilImg) # 建立畫筆 ttfront = ImageFont.truetype('simhei.ttf', 34) # 設定字型 draw.text((210, 450),"你瞅啥!!",fill=0, font=ttfront) # (位置,文字,文字顏色,字型) emoji_text = cv2.cvtColor(np.array(PilImg),cv2.COLOR_RGB2BGR) # PIL 轉回 cv2 plt_show(emoji_text)
cv2.imwrite('./emoji.png', np.array(emoji_text))
import cv2 import numpy as mpimport matplotlib.pyplot as pltfrom PIL import Image, ImageDraw, ImageFontdef plt_show(img):imageRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)plt.imshow(imageRGB)plt.showimage = cv2.imread('SXC.jpg', 0) # 匯入前景圖片 image_resize = cv2.resize(image, None, fx=0.3, fy=0.3, interpolation = cv2.INTER_CUBIC) # 縮放 ret, image_binary = cv2.threshold(image_resize, 80, 255, cv2.THRESH_BINARY) # 圖片二值化 image_roi = image_binary[74: 185, 0: 150] # 感興趣區域 rows, cols = image_roi.shape# 旋轉M = cv2.getRotationMatrix2D(((cols-1)/2.0, (rows-1)/2.0), 15, 1) image_rotate = cv2.warpAffine(image_roi, M, (140, 130)) # 填充不需要的區域h, w = image_rotate.shapeimage_rotate_copy = image_rotate.copypts1 = np.array([[0, 20], [64, 0], [0, 0]], np.int32) pts2 = np.array([[0, 18], [0, h], [80, h]], np.int32) pts3 = np.array([[0, 100], [0, h], [w, h], [w, 100]], np.int32) pts4 = np.array([[111, 0], [w, 0], [w, 30]], np.int32) pts5 = np.array([[124, 0], [115, h], [w, h]], np.int32) pts6 = np.array([[120, 40], [95, 100], [120, 100]], np.int32) foreground = cv2.fillPoly(image_rotate_copy, [pts1], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts2], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts3], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts4], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts5], (255, 255, 255)) foreground = cv2.fillPoly(image_rotate_copy, [pts6], (255, 255, 255)) foreground_roi = foreground[0: 93, 0: 125] foreground_roi_resize = cv2.resize(foreground_roi, None, fx=2.5, fy=2.5, interpolation = cv2.INTER_CUBIC) background = cv2.imread('back.jpg', 0) # 匯入背景圖片 # 拼接兩張圖片h_f, w_f = foreground_roi_resize.shapeh_b, w_b = background.shapeleft = (w_b - w_f)//2 right = left + w_ftop = 80 bottom = top + h_femoji = backgroundemoji[top: bottom, left: right] = foreground_roi_resizePilImg = Image.fromarray(emoji) # cv2 轉 PILdraw = ImageDraw.Draw(PilImg) # 建立畫筆ttfront = ImageFont.truetype('simhei.ttf', 34) # 設定字型 draw.text((210, 450),"你瞅啥!!",fill=0, font=ttfront) # (位置,文字,文字顏色,字型) emoji_text = cv2.cvtColor(np.array(PilImg),cv2.COLOR_RGB2BGR) # PIL 轉回 cv2cv2.imwrite('./emoji.png', np.array(emoji_text)) # 儲存表情包
到此這篇關於利用 Python 把小夥伴變成表情包的文章就介紹到這了,更多相關用 Python 製作表情包內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45