<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          教你用 Python 將微信頭像秒變成表情包

          共 9004字,需瀏覽 19分鐘

           ·

          2021-03-03 12:20

          在日常生活中,我們經常會存取一些朋友們的丑照,在這個項目中,我們以萌萌噠的熊貓頭作為背景,然后試著在背景圖上加入朋友們的照片。效果如下圖所示:

          二、實現步驟

          1. 導入朋友的照片(前景照片);

          2. 處理前景照片(縮放、旋轉,填充);

          3. 導入熊貓頭照片(背景照片);

          4. 將前景和背景拼接起來形成表情包;

          5. 在表情包下面添加文字。

          三、Python 實現

          1、導入需要的庫

          import cv2
          import numpy as mp
          import matplotlib.pyplot as plt
          from PIL import Image, ImageDraw, ImageFont

          這個項目主要是通過 opencv 完成,但如果要在表情包下面寫中文的話,PIL(pillow)庫是必不可少的。

          2、繪圖函數

          這里寫一個繪圖函數,方便繪圖操作。

          def plt_show(img):
              imageRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
              plt.imshow(imageRGB)
              plt.show()

          3、導入前景照片

          image = cv2.imread('SXC.jpg', 0)  # 導入灰度圖即可
          plt_show(image)

          4、等比例縮放前景照片

          因為我們發(fā)現前景照片的尺寸比背景尺寸還要大,這顯然是不合適的,所以要先對其進行等比例(0.3)縮放。

          image_resize = cv2.resize(image, None, fx=0.3, fy=0.3, interpolation = cv2.INTER_CUBIC)
          plt_show(image_resize)

          5、對前景照片進行二值化處理

          在這里,我們將像素值大于 80 的區(qū)域設置為 255;小于 80 的區(qū)域設置成 0。

          ret, image_binary = cv2.threshold(image_resize, 80, 255, cv2.THRESH_BINARY)
          plt_show(image_binary)

          6、提取出感興趣區(qū)域

          image_roi = image_binary[74: 185, 0: 150]
          plt_show(image_roi)

          7、旋轉圖片

          因為我們的背景圖片(熊貓頭)是正的,而前景圖片有些向右傾斜,所以要先對其進行旋轉操作(大概逆時針旋轉 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)

          8、將一些不需要的黑色區(qū)域刪除掉

          在這里我們使用 cv2.fillPoly 函數對不需要的區(qū)域用白色進行填充。

          h, w = image_rotate.shape

          image_rotate_copy = image_rotate.copy()
          pts1 = 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))  # (圖片,填充區(qū)域,填充顏色)
          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)

          9、再次提取感興趣區(qū)域并縮放

          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)

          10、導入背景圖片

          background = cv2.imread('back.jpg', 0)
          plt_show(background)

          11、組合兩張圖片成表情包

          h_f, w_f = foreground.shape
          h_b, w_b = background.shape

          left = (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)

          12、在表情包下面添加文本

          12.1 添加英文文本

          如果只是要添加英文文本,用 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)

          12.2 添加中文文本

          如果要添加中文文本,我們需要借助 PIL 庫來實現。

          PilImg = Image.fromarray(emoji)  # cv2 轉 PIL
          draw = ImageDraw.Draw(PilImg)  # 創(chuàng)建畫筆
          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)

          13、保存表情包

          cv2.imwrite('./emoji.png', np.array(emoji_text))

          四、完整代碼

          import cv2
          import numpy as mp
          import matplotlib.pyplot as plt
          from PIL import Image, ImageDraw, ImageFont

          def plt_show(img):
              imageRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
              plt.imshow(imageRGB)
              plt.show()

          image = 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]  # 感興趣區(qū)域

          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))
          # 填充不需要的區(qū)域
          h, w = image_rotate.shape
          image_rotate_copy = image_rotate.copy()
          pts1 = 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.shape
          h_b, w_b = background.shape
          left = (w_b - w_f)//2
          right = left + w_f
          top = 80
          bottom = top + h_f
          emoji = background
          emoji[top: bottom, left: right] = foreground_roi_resize

          PilImg = Image.fromarray(emoji)  # cv2 轉 PIL
          draw = ImageDraw.Draw(PilImg)  # 創(chuàng)建畫筆
          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

          cv2.imwrite('./emoji.png', np.array(emoji_text))  # 保存表情包

          原文鏈接:https://urlify.cn/2aQfya



          留言送書

          本周贈書:《Python 量化金融編程
          內容簡介:
          1.基礎:初識量化交易,掌握 Python 編程語言的基本用法
          2.進階:結合量化金融實例,進階掌握數據分析庫和量化交易庫的基本用法
          3.實戰(zhàn):結合當下熱點,引入機器學習與深度學習在量化交易場景下的應用,實戰(zhàn)搭建屬于自己的量化交易工具庫

          PS:中獎名單將在交流群公布,可以掃描下方二維碼,備注【交流群】,加入技術交流群!



          ??分享、點贊、在看,給個三連擊唄!
          瀏覽 75
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  男女操逼高清视频 | 久久黄色免费视频 | 豆花视频国产原创 | 无码_免费在线视频网站入口_第1页 | 翔田千里无码视频 |