天天看點

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

@微信官方

昨天朋友圈刷爆了@微信官方的梗,從起初的為頭像添加國旗,到最後的各種Book思議的需求…而我呢?@了辣麼辣麼多的奧特曼,結果還是加班到12點多…最後想想,人還是得靠自己吧,@我自己吧…

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

昨天最近每晚加班回家都淩晨了,昨晚因為太累沒更新,今天再不更新感覺有點太對不起大家,是以想想今天就學着@微信官方,用Python給我們的微信頭像添加國旗吧!

說說上篇文章

上篇文章如何把圖檔變得炫酷多彩,Python教你這樣實作!,其實也是講關于圖檔拼接的内容,隻是有些朋友私下微信和我說,分塊加載的方式不夠好看,看着像是因為網速不好而一點點顯示的效果。其實,文章隻是給大家提供一個思路,你可以根據自己的算法去優化圖檔内容的加載方式,比如這樣随即加載的模式:

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

當然你還可以轉圈等等…

很多朋友問,Python應該怎麼學習才上手快。其實學程式設計不管什麼語言都是如出一轍的方式,多練習勤動手!當你不知道該寫什麼的時候,自己給自己找一點練習的idea,相信你的python會學的更快且更有趣…

頭像添加國旗

今天微信添加國旗的活動,最終我也不知道@微信官方到底有沒有用,上班一天忙着填坑,沒什麼時間玩手機。到時看朋友發有的連結可以給微信加頭像,但晚上發現連結失效了。想想既然上篇文章做了關于圖檔剪裁粘貼的文章,為何不用Python給自己的頭像添加一個國旗呢?圖檔堆疊

python預設建立的圖檔都是矩形的,這樣直接把矩形圖檔加到微信的頭像上,實在太醜了!就比如搜到的一篇文章:

通過Python給頭像加國旗,10多行代碼搞定,就别@官方了

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

這種添加沒毛病,但不覺得有點醜麼…該怎麼做才能美化呢?先來看看效果圖:

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

大家覺得以上兩種圖檔,哪個梗好看呢?哈哈…特效分析

看似兩張圖差别不太,其實技術處理上,相差還是很多的。

首先,我們準備一張用來添加的圖示,就像這樣:

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

程式支援你添加任意的圖示來繪圖,隻需要更換icon.png的名字即可,比如我換成東京食屍鬼的金木,是不是很炫酷:

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!

其次,最外層不起眼的一圈留白,為了達到這個效果,我們需要先建立一個白色的背景畫布,然後将我們的頭像居中粘貼上去。

之後,是如何生成一個圓形的圖檔,大家知道預設建立的圖檔都是矩形的,我們需要通過RGBA的透明度,将多餘的邊角進行透明處理。

最終代碼如下:# -*- coding: utf-8 -*-

# @Author   : 王翔

# @WeChat   : King_Uranus

# @公衆号    : 清風Python

# @Date     : 2019/9/23 23:08

# @Software : PyCharm

# @version  :Python 3.7.3

# @File     : NationalFlag.py

import os

import argparse

from PIL import Image

BasePath = os.path.dirname(os.path.realpath(__file__))

class NationalFlag:

def __init__(self):

self.border = 30

self.user_picture_size=None

self.picture, self.picture_size = self.sharpe_image(args.picture.replace('\', '/'), 'user_picture')

self.icon, self.icon_size = self.sharpe_image(os.path.join(BasePath, 'icon.png'))

def sharpe_image(self, picture_path, img_type=None):

image = Image.open(picture_path).convert("RGBA")

size = min(image.size)

if not img_type:

size = 240

image = image.resize((size, size), Image.ANTIALIAS)

reset_picture = self.blank_image(size, img_type)

if not img_type:

pimage = image.load()  # 像素的通路對象

preset_picture = reset_picture.load()

r = float(size / 2)  # 圓心橫坐标

r3 = int(size // 2)

for i in range(size):

for j in range(size):

lx = abs(i - r)  # 到圓心距離的橫坐标

ly = abs(j - r)  # 到圓心距離的縱坐标

l = (pow(lx, 2) + pow(ly, 2)) ** 0.5  # 三角函數 半徑

if l 

preset_picture[i - (r - r3), j - (r - r3)] = pimage[i, j]

else:

reset_picture.paste(image, (self.border, self.border))

return reset_picture, size

def blank_image(self, size, img_type=None):

if img_type:

new_size = size + self.border * 2

color_type = (255, 255, 255)

return Image.new('RGBA', (new_size, new_size), color_type)

else:

color_type = (255, 255, 255, 0)

return Image.new('RGBA', (size, size), color_type)

def final_paste(self):

r, g, b, a = self.icon.split()

locate = self.picture_size+ self.border//2 -self.icon_size

self.picture.paste(self.icon, (locate, locate), mask=a)

self.picture.save('result.png')

def run():

main = NationalFlag()

main.final_paste()

if __name__ == '__main__':

parser = argparse.ArgumentParser()

parser.add_argument("-p", "--picture", required=True,

help="請填寫所需制作的圖檔全路徑")

args = parser.parse_args()

run()

程式打包

這麼好玩的功能,我們當然需要打包後友善傳遞給朋友們使用喽…頭像圖檔通過-p 傳輸至程式,想要替換的裝飾秩序保證檔案名為icon.png即可。是不是很友善?還不去下載下傳嗎?公衆号輸入關鍵字:頭像 即可擷取exe檔案及代碼….

python微信圖示制作_Python幫你微信頭像任意添加裝飾,别再@微信官方了!