Python幫你微信頭像任意添加裝飾,別再@微信官方了!
@微信官方
昨天朋友圈刷爆了@微信官方的梗,從起初的為頭像添加國旗,到最后的各種Book思議的需求…而我呢?@了辣么辣么多的奧特曼,結(jié)果還是加班到12點多…最后想想,人還是得靠自己吧,@我自己吧…
昨天最近每晚加班回家都凌晨了,昨晚因為太累沒更新,今天再不更新感覺有點太對不起大家,所以想想今天就學(xué)著@微信官方,用Python給我們的微信頭像添加國旗吧!
說說上篇文章
上篇文章如何把圖片變得炫酷多彩,Python教你這樣實現(xiàn)!,其實也是講關(guān)于圖片拼接的內(nèi)容,只是有些朋友私下微信和我說,分塊加載的方式不夠好看,看著像是因為網(wǎng)速不好而一點點顯示的效果。其實,文章只是給大家提供一個思路,你可以根據(jù)自己的算法去優(yōu)化圖片內(nèi)容的加載方式,比如這樣隨即加載的模式:
當(dāng)然你還可以轉(zhuǎn)圈等等…
很多朋友問,Python應(yīng)該怎么學(xué)習(xí)才上手快。其實學(xué)編程不管什么語言都是如出一轍的方式,多練習(xí)勤動手!當(dāng)你不知道該寫什么的時候,自己給自己找一點練習(xí)的idea,相信你的python會學(xué)的更快且更有趣…
頭像添加國旗
今天微信添加國旗的活動,最終我也不知道@微信官方到底有沒有用,上班一天忙著填坑,沒什么時間玩手機(jī)。到時看朋友發(fā)有的鏈接可以給微信加頭像,但晚上發(fā)現(xiàn)鏈接失效了。想想既然上篇文章做了關(guān)于圖片剪裁粘貼的文章,為何不用Python給自己的頭像添加一個國旗呢?
- 圖片堆疊
python默認(rèn)創(chuàng)建的圖片都是矩形的,這樣直接把矩形圖片加到微信的頭像上,實在太丑了!就比如搜到的一篇文章:
通過Python給頭像加國旗,10多行代碼搞定,就別@官方了
這種添加沒毛病,但不覺得有點丑么…該怎么做才能美化呢?先來看看效果圖:
大家覺得以上兩種圖片,哪個梗好看呢?哈哈…
- 特效分析
看似兩張圖差別不太,其實技術(shù)處理上,相差還是很多的。
首先,我們準(zhǔn)備一張用來添加的圖標(biāo),就像這樣:
程序支持你添加任意的圖標(biāo)來繪圖,只需要更換icon.png的名字即可,比如我換成東京食尸鬼的金木,是不是很炫酷:
其次,最外層不起眼的一圈留白,為了達(dá)到這個效果,我們需要先創(chuàng)建一個白色的背景畫布,然后將我們的頭像居中粘貼上去。
之后,是如何生成一個圓形的圖片,大家知道默認(rèn)創(chuàng)建的圖片都是矩形的,我們需要通過RGBA的透明度,將多余的邊角進(jìn)行透明處理。
最終代碼如下:
- # -*- coding: utf-8 -*-
- # @Author : 王翔
- # @WeChat : King_Uranus
- # @公眾號 : 清風(fēng)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) # 圓心橫坐標(biāo)
- r3 = int(size // 2)
- for i in range(size):
- for j in range(size):
- lx = abs(i - r) # 到圓心距離的橫坐標(biāo)
- ly = abs(j - r) # 到圓心距離的縱坐標(biāo)
- l = (pow(lx, 2) + pow(ly, 2)) ** 0.5 # 三角函數(shù) 半徑
- if l < r3:
- 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="請?zhí)顚懰柚谱鞯膱D片全路徑")
- args = parser.parse_args()
- run()
程序打包
這么好玩的功能,我們當(dāng)然需要打包后方便傳遞給朋友們使用嘍…頭像圖片通過-p 傳輸至程序,想要替換的裝飾秩序保證文件名為icon.png即可。是不是很方便?還不去下載嗎?公眾號輸入關(guān)鍵字:頭像 即可獲取exe文件及代碼….
