0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

20行Python代碼給微信頭像戴帽子

電子工程師 ? 來源:lq ? 2019-01-18 10:41 ? 次閱讀

朋友圈里@微信官方要求戴圣誕帽的活動曾經(jīng)火爆一時,有些會玩的小伙伴都悄咪咪地用美圖秀秀一類的 app 給自己頭像 p 一頂,然后可高興地表示“哎呀好神奇hhhh”,呆萌的小伙伴當然就一直等啊等... ...作為一名堅信“用技術解決需求”的萌新,在一個無聊的周末嘗試用python來搞一波事情。

主要思路

準備兩張圖:一張頭像,一張帽子。先用人臉識別定位頭像中的人臉,給出人臉像素坐標;再根據(jù)這個坐標確定帽子放置的坐標;最后將兩張圖片拼接后輸出。(需要注意的是,帽子是不規(guī)則圖像,除了主體外背景應該是透明的,因此必須是四通道png格式)。gakki 醬親自演示如下:

示意圖

問題展開

1. 人臉識別怎么搞定?(重新造輪子?不存在的,這輩子都不可能造輪子的)。Github上一個開源的python人臉識別庫face_recognition雙手奉

https://github.com/ageitgey/face_recognition#face-recognition

據(jù)說識別率99.38%(頂瓜瓜?。。?。通過安裝這個庫就可以調用人臉檢測器。

2. 確定了帽子的放置位置,怎么拼接圖層?這個屬于基本的圖像操作,python提供了PIL(Python Image Lib)這么一個庫來進行圖像處理,具體操作請看后面的代碼。

庫的安裝

我的環(huán)境是Ubuntu 16.04+Python2.7.12。使用Window,Mac OS和Python3的同學也可以參考,都是類似的。face_recognition這個庫比較事兒,安裝前需要依次安裝boost(boost_python),cmake,dlib這幾個依賴和庫,中間出現(xiàn)任何問題都可以通過Google解決(懶得寫 -.. -)。安裝完所有的依賴后,使用命令:

1pipinstallface_recognition2pipinstallpillow#PIL庫

完成后就可以在你的python腳本里import face_recognition和PIL了。

代碼分析

Talk is cheap, show me the code。直接上代碼:

1fromPILimportImage 2importface_recognition 3img_path=raw_input("imagepath:") 4image=face_recognition.load_image_file(img_path) 5face_locations=face_recognition.face_locations(image) 6print("Found{}face(s)inthisphotograph.".format(len(face_locations)))

第1、2行導入PIL庫中的Image模塊和face_recognition庫。第3行,等待用戶輸入頭像圖片的路徑。第4行,把路徑所指的圖像數(shù)據(jù)讀入image中。第5行,調用face_locations處理image中的圖像數(shù)據(jù),對圖片中的人臉進行識別定位,定位后的得到的像素坐標數(shù)據(jù)放在face_locations里。第6行在shell里輸出圖片里識別到的人臉的個數(shù)。

7human_img=Image.open(img_path) 8human_img=human_img.convert("RGBA") 9hat_img=Image.open("./hat.png")10hat_img=hat_img.convert("RGBA")

第7、8行,把路徑所指的圖像數(shù)據(jù)讀入human_img中,并轉換為四通道RGBA模式。9、10行讀入帽子圖像并做相同處理。

11forface_locationinface_locations:12top,right,bottom,left=face_location13top-=1014print("AfaceislocatedatpixellocationTop:{},Left:{},Bottom:{},Right:{}".format(top,left,bottom,right))15head_h=bottom-top#hightofhead16head_l=right-left#lengthofhead17hat_img=hat_img.resize((head_l,head_h))#convertsizeofhat18hat_region=hat_img19human_region=(left,top-head_h,right,top)20human_img.paste(hat_region,human_region,mask=hat_img)21human_img.show()

如果一張圖里有多張人臉,face_recognition.face_locations(image)會返回每張人臉的位置信息,存放在一個list里。因此第11行是遍歷face_locations里的每張人臉的數(shù)據(jù)。第12行解包一個人臉像素坐標數(shù)據(jù),得到top,right,bottom,left分別為示意圖中的y1,x2,y2,x1。第13行,為啥y1要減10個像素?

因為人臉識別得到的y1最多到你額頭的位置,所以再把這個坐標往上提一提帽子才戴得更自然。第14行輸出坐標數(shù)據(jù)方便調試。第15、16行計算人臉的高度和寬度。第17行使用resize()根據(jù)人臉的大小調整帽子的大小,因為圖像中的人臉有大有小,調整后看起來更和諧。第18行,將帽子圖像作為頂部圖層圖像。第19行,確定底部圖層(頭像圖片)被覆蓋的區(qū)域(就是帽子放置區(qū)域)。

第20行,把頂部圖層與底部圖層拼接(不太明白的看下圖)。然后一個循環(huán)結束,亦即完成圖片中一個人的戴帽操作,接著進行下個人的戴帽,直到所有人都戴上了帽子。最后21行,完成輸出~

更新

更多人臉:

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 人臉識別
    +關注

    關注

    76

    文章

    3998

    瀏覽量

    81359
  • python
    +關注

    關注

    53

    文章

    4753

    瀏覽量

    84081
  • GitHub
    +關注

    關注

    3

    文章

    461

    瀏覽量

    16236

原文標題:20行Python代碼給微信頭像戴帽子

文章出處:【微信號:rgznai100,微信公眾號:rgznai100】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    分享50條經(jīng)典的Python代碼

    今天浩道跟大家分享python學習過程中非常經(jīng)典的50條一代碼,讓大家體驗它簡潔而功能強大的特點。同時大家分享號主收集到的所有關于python
    發(fā)表于 08-16 15:00 ?879次閱讀

    labview中用python節(jié)點實現(xiàn)登錄獲取好友列表,登錄怎么掃碼?

    `python節(jié)點對于單次輸入挺好用的,最近學習怎么實現(xiàn)python登錄獲取好友列表等信息,在pythonIDE測試通過,但labview的py
    發(fā)表于 06-19 12:00

    如何用Python頭像添加國旗?

    Python頭像添加國旗的方法
    發(fā)表于 11-11 08:02

    代碼分享

    代碼
    發(fā)表于 12-30 06:01

    怎樣去使用Python頭像戴圣誕帽?

    怎樣去使用Python頭像戴圣誕帽?都有哪些步驟流程需要去操作?
    發(fā)表于 06-17 06:41

    如何實現(xiàn)計算機視覺的目標檢測10Python代碼幫你實現(xiàn)

    只需10Python代碼,我們就能實現(xiàn)計算機視覺中目標檢測。 沒錯,用這寥寥10代碼,就能實現(xiàn)目前AI產品中應用廣泛的目標檢測技術。
    的頭像 發(fā)表于 02-03 11:35 ?2977次閱讀

    如何使用50Python代碼實現(xiàn)AI的動作平衡

    本文將為大家展示如何通過 Numpy 庫和 50 Python 代碼,使用標準的 OpenAI Gym平臺創(chuàng)建智能體 (agent),就教會機器處理推車桿問題 (cart pole problem) ,保持平衡。
    的頭像 發(fā)表于 06-16 10:40 ?3044次閱讀

    盤點10個一強大的、有趣的Python代碼

    Python是一門非常簡潔而優(yōu)美的編程語言,在其他編程語言中需要繁瑣的代碼邏輯才能完成的事情,往往在Python中一就可以解決。
    的頭像 發(fā)表于 10-08 14:33 ?8657次閱讀

    使用Python讀文件的源代碼免費下載

    本文檔的主要內容詳細介紹的是使用Python讀文件的源代碼免費下載。
    發(fā)表于 10-22 17:57 ?12次下載
    使用<b class='flag-5'>Python</b>按<b class='flag-5'>行</b>讀文件的源<b class='flag-5'>代碼</b>免費下載

    Python代碼的性能分析的命令合集

    。注意,在本教程中,我建議使用 Anaconda。1.分析一代碼要檢查一 python 代碼的執(zhí)行時間,請使用**%timeit**。下
    發(fā)表于 11-25 10:43 ?10次下載

    第一代碼曝光:一切的開始

    ,廣州,一群年輕人在小黑屋里敲下了一行行代碼。 這是后臺第一天提交的代碼。 從此,人們的溝通方式變了。 如今,
    的頭像 發(fā)表于 12-03 09:40 ?4034次閱讀

    智能可穿戴帽子開源分享

    電子發(fā)燒友網(wǎng)站提供《智能可穿戴帽子開源分享.zip》資料免費下載
    發(fā)表于 11-15 11:26 ?0次下載
    智能可穿<b class='flag-5'>戴帽子</b>開源分享

    如何使用Python直接給推送消息

    ?Python可以實現(xiàn)QQ郵箱、企業(yè)、等等軟件推送消息,今天咱們實現(xiàn)一下
    的頭像 發(fā)表于 01-17 11:22 ?1866次閱讀

    20個解決日常問題的Python代碼片段!

    在本文中,將分享20Python 代碼片段,以幫助你應對日常編程挑戰(zhàn)。你可能已經(jīng)知道其中一些片段,但有些其他片段對你來說可能是新的。趕緊使用這些有用的 Python
    的頭像 發(fā)表于 03-13 09:40 ?910次閱讀

    20個非常有用的Python單行代碼

    有用的 Python 單行代碼片段,只需一代碼即可解決特定編碼問題!
    的頭像 發(fā)表于 03-14 17:45 ?800次閱讀