@微信官方
昨天朋友圈刷爆了@微信官方的梗,從起初的為頭像添加國旗,到最後的各種Book思議的需求…而我呢?@了辣麼辣麼多的奧特曼,結果還是加班到12點多…最後想想,人還是得靠自己吧,@我自己吧…
昨天最近每晚加班回家都淩晨了,昨晚因為太累沒更新,今天再不更新感覺有點太對不起大家,是以想想今天就學着@微信官方,用Python給我們的微信頭像添加國旗吧!
說說上篇文章
上篇文章如何把圖檔變得炫酷多彩,Python教你這樣實作!,其實也是講關于圖檔拼接的内容,隻是有些朋友私下微信和我說,分塊加載的方式不夠好看,看着像是因為網速不好而一點點顯示的效果。其實,文章隻是給大家提供一個思路,你可以根據自己的算法去優化圖檔内容的加載方式,比如這樣随即加載的模式:
當然你還可以轉圈等等…
很多朋友問,Python應該怎麼學習才上手快。其實學程式設計不管什麼語言都是如出一轍的方式,多練習勤動手!當你不知道該寫什麼的時候,自己給自己找一點練習的idea,相信你的python會學的更快且更有趣…
頭像添加國旗
今天微信添加國旗的活動,最終我也不知道@微信官方到底有沒有用,上班一天忙着填坑,沒什麼時間玩手機。到時看朋友發有的連結可以給微信加頭像,但晚上發現連結失效了。想想既然上篇文章做了關于圖檔剪裁粘貼的文章,為何不用Python給自己的頭像添加一個國旗呢?圖檔堆疊
python預設建立的圖檔都是矩形的,這樣直接把矩形圖檔加到微信的頭像上,實在太醜了!就比如搜到的一篇文章:
通過Python給頭像加國旗,10多行代碼搞定,就别@官方了
這種添加沒毛病,但不覺得有點醜麼…該怎麼做才能美化呢?先來看看效果圖:
大家覺得以上兩種圖檔,哪個梗好看呢?哈哈…特效分析
看似兩張圖差别不太,其實技術處理上,相差還是很多的。
首先,我們準備一張用來添加的圖示,就像這樣:
程式支援你添加任意的圖示來繪圖,隻需要更換icon.png的名字即可,比如我換成東京食屍鬼的金木,是不是很炫酷:
其次,最外層不起眼的一圈留白,為了達到這個效果,我們需要先建立一個白色的背景畫布,然後将我們的頭像居中粘貼上去。
之後,是如何生成一個圓形的圖檔,大家知道預設建立的圖檔都是矩形的,我們需要通過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檔案及代碼….