精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

好機會,我用Python給女同事頭像戴上口罩!

開發(fā) 后端 開發(fā)工具
突如其來的新型冠狀病毒讓全國人民春節(jié)過的誠惶誠恐,出門必須帶口罩已經(jīng)達成共識。

突如其來的新型冠狀病毒讓全國人民春節(jié)過的誠惶誠恐,出門必須帶口罩已經(jīng)達成共識。

[[315795]] 

圖片來自 Pexels

疫情防控期間,我們大家要做的就是遵從政府號令:“少出門,戴口罩、勤洗手......”,乖乖宅家就是為抗擊疫情做貢獻。

看到一些朋友叫設(shè)計同學(xué)幫忙給自己的頭像戴上口罩,作為技術(shù)人,心想一定還有更多人有這樣的訴求,不如開發(fā)一個簡單的程序來實現(xiàn)這個需求,也算是幫助設(shè)計小姐姐減少工作量。

于是我花了些時間,寫了一個叫做 face-mask[1] 的命令行工具,能夠輕松的給圖片中的人像戴上口罩,而且口罩的方向和大小都是適應(yīng)人臉的哦~

使用

①安裝 face-mask

  1. pip install face-mask 

確保 Python 版本在 3.6 及以上。

②使用 face-mask

直接指定圖片路徑即可為圖片中的人像戴上口罩,并會生成一個新的圖片(額外有 -with-mask 后綴):

  1. face-mask /path/to/face/picture 

通過指定 --show 選項,還可以使用默認圖片查看器打開新生成的圖片:

  1. face-mask /path/to/face/picture --show 

③效果

給一個人戴上口罩,效果如下圖:

給多個人戴上口罩,效果如下圖:

給動漫人物戴上口罩:

實現(xiàn)

思路

要想實現(xiàn)上面的效果,我們應(yīng)該怎么做?不妨這么想:

  • 首先是識別出人的鼻子(nose_bridge)和臉輪廓(chin)。
  • 通過臉輪廓確定出臉左點(chin_left_point)、臉底點(chin_bottom_point)和臉右點(chin_right_point)。
  • 由鼻子和臉底點確定口罩大小的高度、中心線。
  • 將口罩左右平均分為兩個部分,調(diào)整左口罩大小,寬度為臉左點到中心線的距離;調(diào)整右口罩大小,寬度為臉右點到中心線的距離;合并左右口罩為新口罩。
  • 旋轉(zhuǎn)新口罩,角度為中心線相對于 y 軸的旋轉(zhuǎn)角。
  • 將新口罩放在原圖適當(dāng)位置。

關(guān)于人臉識別,可以使用 face_recognition[2] 庫進行識別。關(guān)于圖像處理,可以使用 Pillow[3] 庫進行處理。

代碼

有了思路之后,實現(xiàn)就是件相對輕松的事情。不過對庫的熟悉和圖片的變換計算可能要花些時間。

詳細的代碼請參考如下鏈接,這里僅說明下最核心的步驟:

https://github.com/Prodesire/face-mask

人臉識別:

  1. import face_recognition 
  2.  
  3. face_image_np = face_recognition.load_image_file('/path/to/face/picture'
  4. face_landmarks = face_recognition.face_landmarks(face_image_np) 

借助 face_recognition 庫可以輕松的識別出人像,最終得到的 face_landmarks 是一個列表,里面的每個 face_landmark 都表示一個人像數(shù)據(jù)。

face_landmark 是一個字典,其中的鍵表示人像特征,值表示該特征的點的列表。比如:

  • 鍵 nose_bridge 表示鼻梁
  • 鍵 chin 表示臉頰

我們需要根據(jù)每個 face_landmark,給對應(yīng)的頭像戴上口罩。

獲得鼻子和臉頰的特征點:

  1. import numpy as np 
  2.  
  3. nose_bridge = face_landmark['nose_bridge'
  4. nose_point = nose_bridge[len(nose_bridge) * 1 // 4] 
  5. nose_v = np.array(nose_point) 
  6.  
  7. chin = face_landmark['chin'
  8. chin_len = len(chin) 
  9. chin_bottom_point = chin[chin_len // 2] 
  10. chin_bottom_v = np.array(chin_bottom_point) 
  11. chin_left_point = chin[chin_len // 8] 
  12. chin_right_point = chin[chin_len * 7 // 8] 

通過上述代碼,我們獲得了:

  • 表示上鼻梁的一個點:nose_point
  • 表示臉左點:chin_left_point
  • 表示臉右點:chin_right_point
  • 表示臉底點:chin_bottom_point

拆分、縮放和合并口罩:

  1. from PIL import Image 
  2.  
  3. _face_img = Image.fromarray(face_image_np) 
  4. _mask_img = Image.open('/path/to/mask/picture'
  5.  
  6. # split mask and resize 
  7. width = _mask_img.width 
  8. height = _mask_img.height 
  9. width_ratio = 1.2 
  10. new_height = int(np.linalg.norm(nose_v - chin_bottom_v)) 
  11.  
  12. left 
  13. mask_left_img = _mask_img.crop((0, 0, width // 2, height)) 
  14. mask_left_width = get_distance_from_point_to_line(chin_left_point, nose_point, chin_bottom_point) 
  15. mask_left_width = int(mask_left_width * width_ratio) 
  16. mask_left_img = mask_left_img.resize((mask_left_width, new_height)) 
  17.  
  18. right 
  19. mask_right_img = _mask_img.crop((width // 2, 0, width, height)) 
  20. mask_right_width = get_distance_from_point_to_line(chin_right_point, nose_point, chin_bottom_point) 
  21. mask_right_width = int(mask_right_width * width_ratio) 
  22. mask_right_img = mask_right_img.resize((mask_right_width, new_height)) 
  23.  
  24. # merge mask 
  25. size = (mask_left_img.width + mask_right_img.width, new_height) 
  26. mask_img = Image.new('RGBA'size
  27. mask_img.paste(mask_left_img, (0, 0), mask_left_img) 
  28. mask_img.paste(mask_right_img, (mask_left_img.width, 0), mask_right_img) 

上述代碼主要做了如下內(nèi)容:

  • 將口罩左右平均分為兩個部分。
  • 調(diào)整左口罩大小,寬度為臉左點到中心線的距離*寬度系數(shù) 1.2。
  • 調(diào)整右口罩大小,寬度為臉右點到中心線的距離*寬度系數(shù) 1.2。
  • 合并左右口罩為新口罩。

get_distance_from_point_to_line 用來獲取一個點到一條線的距離,具體實現(xiàn)可看源代碼。

width_ratio 是寬度系數(shù),用來適當(dāng)擴大口罩。原因我們是根據(jù)臉頰的寬度計算口罩的寬度,但口罩是待在耳朵上的,真實寬度應(yīng)該要更寬。

旋轉(zhuǎn)口罩、并放到原圖適當(dāng)位置:

  1. # rotate mask 
  2. angle = np.arctan2(chin_bottom_point[1] - nose_point[1], chin_bottom_point[0] - nose_point[0]) 
  3. rotated_mask_img = mask_img.rotate(angle, expand=True
  4.  
  5. # calculate mask location 
  6. center_x = (nose_point[0] + chin_bottom_point[0]) // 2 
  7. center_y = (nose_point[1] + chin_bottom_point[1]) // 2 
  8.  
  9. offset = mask_img.width // 2 - mask_left_img.width 
  10. radian = angle * np.pi / 180 
  11. box_x = center_x + int(offset * np.cos(radian)) - rotated_mask_img.width // 2 
  12. box_y = center_y + int(offset * np.sin(radian)) - rotated_mask_img.height // 2 
  13.  
  14. add mask 
  15. _face_img.paste(mask_img, (box_x, box_y), mask_img) 

上述代碼主要做了如下內(nèi)容:

  • 旋轉(zhuǎn)新口罩,角度為中心線相對于 y 軸的旋轉(zhuǎn)角。
  • 計算口罩應(yīng)該放置的坐標。
  • 將新口罩放在原圖的計算出的坐標下。

最后就是將新圖片保存到本地路徑,代碼不再展示。

總結(jié)

我們借助 face_recognition 庫可以輕松的識別出人像,然后根據(jù)臉頰的寬度和鼻梁位置計算出口罩的大小、方向和位置,并最終生成出戴上口罩的圖片。

整個過程并不復(fù)雜,但在坐標計算上要格外小心,如此,我們便打造了一個短小精悍的“自動戴上口罩”程序!

 

責(zé)任編輯:武曉燕 來源: Prodesire
相關(guān)推薦

2020-02-13 14:32:36

解決Maven沖突問題

2020-11-27 19:08:51

AI 數(shù)據(jù)人工智能

2020-08-24 07:52:40

代理Java動態(tài)

2021-02-20 10:56:30

人工智能人臉識別

2017-12-26 09:10:43

Python微信圣誕帽

2021-03-17 14:15:24

人臉識別人工智能AI

2020-10-31 09:06:37

C語言編程語言

2017-12-27 15:27:36

大數(shù)據(jù)數(shù)據(jù)建模數(shù)據(jù)支撐

2009-04-03 15:17:43

LinuxWindows 7機會

2009-04-04 09:36:11

Windows 7微軟操作系統(tǒng)

2020-02-13 12:50:07

人臉識別口罩護目鏡

2021-08-09 14:47:44

微信表情移動應(yīng)用

2021-07-05 09:52:05

大數(shù)據(jù)大數(shù)據(jù)“殺熟”數(shù)據(jù)監(jiān)管

2021-08-06 21:16:08

人臉識別AI人工智能

2020-03-10 17:34:57

天貓精靈

2010-03-06 08:48:23

2022-03-23 08:01:04

Python語言代碼

2010-02-24 16:47:22

戴爾員工性騷擾

2021-04-07 22:22:10

人工智能數(shù)據(jù)軟件
點贊
收藏

51CTO技術(shù)棧公眾號

香蕉加勒比综合久久| 欧美日韩国产在线一区| 色狠狠av一区二区三区| 亚洲v国产v在线观看| 国产又黄又粗又长| 极品av少妇一区二区| 亚洲丝袜在线视频| 一二三级黄色片| aa国产成人| 国产精品无人区| 成人动漫视频在线观看免费| 六月丁香婷婷综合| 天天综合久久| 亚洲女人天堂成人av在线| 五月婷婷之综合激情| 深夜国产在线播放| 国产偷国产偷亚洲高清人白洁 | 日本黄色片免费观看| 国内精品国产成人国产三级粉色| 在线精品视频一区二区三四| 成人免费不卡视频| 亚洲第一男人天堂| 日韩一区二区三区久久| 第一福利在线视频| 国产精品久久免费看| 精品国产一区二区三区麻豆免费观看完整版 | 亚洲av无码乱码国产精品久久 | 亚洲国产色一区| 色涩成人影视在线播放| www.天堂在线| 老司机精品视频在线| 555www成人网| 免费在线观看黄色av| 成人影院天天5g天天爽无毒影院| 亚洲成人精品av| 亚洲成人手机在线观看| 影音成人av| 天天综合色天天综合色h| 国产一二三四区在线观看| 成人av毛片| 牛牛影视久久网| 国产乱子伦精品无码码专区| 精品久久久久久久久久岛国gif| 51精品视频| 亚洲欧洲日产国码二区| 日韩欧美国产二区| 深夜视频在线免费| 中文字幕亚洲欧美在线| 中国一区二区三区| 久久精品蜜桃| 久久免费看少妇高潮| 极品尤物一区二区三区| 国产77777| 国产69精品久久777的优势| 国产这里只有精品| 一区二区精品在线| 日韩一级在线播放| 成人性生交大片免费看中文| 99久久无色码| 亚洲国产www| 国产+成+人+亚洲欧洲自线| 99精彩视频| 成人免费视频国产免费麻豆| 丁香六月综合激情| 一本一道波多野毛片中文在线| 国产日韩欧美一区二区三区在线观看| 欧美精品在线第一页| 国产喷水在线观看| 欧美疯狂party性派对| 日韩在线视频二区| 小泽玛利亚一区| 欧美激情综合| 欧美激情视频网| 国产一级视频在线观看| av不卡在线看| 日韩欧美国产亚洲| 都市激情亚洲欧美| 精品奇米国产一区二区三区| 国产人妖在线观看| 九九热hot精品视频在线播放| 亚洲国产精彩中文乱码av在线播放| 亚洲av无码一区东京热久久| 久久精品国产亚洲5555| 亚洲美女av网站| x88av在线| 亚洲精品中文字幕乱码| 久久久视频精品| 亚洲成熟少妇视频在线观看| 另类小说一区二区三区| 99九九视频| 成人国产一区二区| 亚洲人成网站在线播放2019| 成人h小游戏| 自拍偷拍欧美精品| 97碰在线视频| www.av成人| 欧美1区3d| 国产91对白在线播放| 天天天天天天天干| 豆国产96在线|亚洲| 成人日批视频| 国产日韩精品久久久| 亚洲制服中文| 国产资源第一页| 最新中文字幕免费| 国产成人免费网站| 欧美精品一区二区三区在线看午夜 | 成人在线播放av| 五月激情婷婷综合| 国模无码大尺度一区二区三区| 日韩av在线资源| 欧美激情视频二区| 精品91久久久久| 亚洲精品久久久久久久久久| 丝瓜av网站精品一区二区 | 日韩女同强女同hd| 免费看欧美女人艹b| 高清不卡一区二区三区| 欧美精品一卡两卡| 国产成人三级在线播放| 丁香激情综合国产| 青青草久久网络| 青春草免费在线视频| 欧美视频一区二区三区在线观看| youjizz.com日本| 欧美丰满老妇| 国产精品6699| 天天av综合网| 亚洲制服丝袜av| 一本一道久久a久久综合蜜桃| 亚洲自拍电影| 午夜精品99久久免费| 精品欧美一区二区精品少妇| 国产精品三级视频| 免费大片在线观看| 天堂久久av| 久久综合伊人77777| 伊人网av在线| 久久久.com| 欧美亚洲国产成人| 国产96在线亚洲| 欧美黑人国产人伦爽爽爽| 国产精品一区二区免费视频| 国产精品久久久久一区二区三区共 | 成年人视频在线免费| 色88888久久久久久影院| 久久久久久亚洲精品| 不卡视频免费在线观看| 亚洲免费成人av| 少妇愉情理伦片bd| 亚洲一区二区三区无吗| 国产日韩欧美黄色| 一区二区三区视频在线观看视频| 色8久久精品久久久久久蜜| 97超碰在线资源| 日韩精品一二三| 亚洲国产精品毛片| 9.1麻豆精品| 美女999久久久精品视频| 欧美黑人一区二区三区| 99视频免费看| 亚洲**毛片| 中文字幕一区免费在线观看| 中文字幕一区二区三区四区在线视频| 久久不见久久见国语| 国产精品久久久久久网站| av一本在线| 欧美一区永久视频免费观看| 澳门黄色一级片| 成人性生交大合| 欧美黄色免费影院| 欧美丝袜激情| 亚洲一区二区在线| 超免费在线视频| 亚洲精品久久久久久久久| 色av性av丰满av| **欧美大码日韩| 日本性生活一级片| 老牛国产精品一区的观看方式| 日韩欧美在线一区二区| 国色天香久久精品国产一区| 欧美不卡一区二区三区| 国产+高潮+白浆+无码| 亚洲麻豆一区| 日韩av电影在线观看| 日本丰满少妇裸体自慰| 在线成人欧美| 欧美亚洲另类久久综合| 亚洲ww精品| 午夜精品久久久久久久久久久久久 | 野花国产精品入口| 久久99精品久久久久子伦| 黄色亚洲网站| 久久精视频免费在线久久完整在线看| 成人h动漫精品一区二区无码| 狠狠操狠狠色综合网| 精品一区二区三区蜜桃在线| 青春草在线免费视频| 亚洲国产精品va| 一区二区视频网站| 亚洲高清视频的网址| 中字幕一区二区三区乱码| 国产老女人精品毛片久久| heyzo国产| 亚洲第一天堂| 欧美精品vⅰdeose4hd| 色99中文字幕| 中文字幕在线观看91| 久久av在线| 69精品丰满人妻无码视频a片| 国产精品自拍区| 国产传媒一区| 91成人小视频| 国产91久久婷婷一区二区| 影音先锋中文在线视频| 一个人www欧美| 污污网站在线免费观看| 91精品在线免费观看| 欧美成人一区二区三区四区| 亚洲五月六月丁香激情| 亚洲 欧美 变态 另类 综合| 国产无人区一区二区三区| 久久久午夜精品福利内容| 加勒比av一区二区| 亚洲xxxx2d动漫1| 亚洲欧美清纯在线制服| 久久www视频| 99久久夜色精品国产亚洲1000部 | 少妇一区二区三区| 亚洲综合第一页| 亚洲图片小说区| 国产精品一区电影| 欧美日韩五码| 欧洲成人免费视频| 91九色国产在线播放| 欧美精品一区二区三区国产精品| 四虎久久免费| 在线精品国产欧美| 成人好色电影| 最近2019年好看中文字幕视频| 欧美性孕妇孕交| 亚洲精品视频在线观看视频| 四虎成人免费在线| 亚洲国产天堂久久综合网| 人妻夜夜爽天天爽| 精品99999| 天堂91在线| 亚洲精品一区二区网址| 免费在线观看污视频| 亚洲男人天堂网站| 欧美日韩在线中文字幕| 亚洲老板91色精品久久| 免费在线性爱视频| 国产亚洲成av人片在线观看桃| 黄色软件在线| 色婷婷综合久久久久| 黄色网在线免费观看| 久久综合免费视频| 在线观看a级片| 久久久中精品2020中文| mm视频在线视频| 欧美中文字幕视频| 国产99在线| 日韩av免费一区| 日韩免费小视频| 国产噜噜噜噜久久久久久久久| 久久久国产精品无码| 韩日欧美一区二区三区| 激情久久综合网| 理论在线观看| 欧洲亚洲国产日韩| 中文字幕在线观看第二页| 成人综合国产精品| 福利视频在线播放| 最近中文字幕日韩精品 | 成人看片网页| 国产一区视频在线| 国产精品亚洲一区二区在线观看| 亚洲综合在线小说| 粉嫩久久久久久久极品| 精品伦精品一区二区三区视频| 亚洲精品456| 一区二区视频在线播放| 激情综合视频| 国产免费人做人爱午夜视频| 久久电影网电视剧免费观看| 亚洲性图第一页| 国产亚洲精品精华液| 国产免费一区二区三区四区| 亚洲国产综合色| 亚洲大尺度在线观看| 欧美一区二区人人喊爽| 国精产品乱码一区一区三区四区| 亚洲视频网站在线观看| 国内精品不卡| 青草成人免费视频| 欧美片网站免费| 日韩高清av| 精品999网站| 亚洲天堂2018av| 99久精品国产| 天天看天天摸天天操| 91成人午夜| 亚洲国产免费看| 亚洲 国产 日韩 综合一区| 一区二区蜜桃| 成年人视频网站免费观看| 国内精品久久久久影院薰衣草 | 国产在线视频二区| 色悠悠久久综合| 亚洲国产精品欧美久久 | 成人免费视屏| 国产精品第2页| 久久久久久毛片免费看 | 欧美一区二区视频在线观看2020| 天堂在线中文| 久久频这里精品99香蕉| 999色成人| 色综合666| 国产精品腿扒开做爽爽爽挤奶网站| 免费国偷自产拍精品视频| 国产片一区二区三区| 日本少妇激情舌吻| 欧美一区二区日韩一区二区| 欧美性猛交xxx乱大交3蜜桃| 日韩av大片免费看| 色婷婷精品视频| 妞干网在线视频观看| 成人综合激情网| 国产精品电影观看| 激情av综合| 伊人再见免费在线观看高清版 | 性欧美69xoxoxoxo| 亚洲福利精品视频| 久久久精品tv| 一级片免费在线播放| 国产视频在线一区二区| 男女在线视频| av资源一区二区| 欧美日韩一区二区国产| 亚洲成人av免费观看| 亚洲欧美偷拍另类a∨色屁股| 亚洲天堂一二三| 色偷偷偷综合中文字幕;dd| 韩国三级一区| 日韩成人av网站| 麻豆成人久久精品二区三区红 | 色婷婷综合网| 爱情岛论坛亚洲首页入口章节| 欧美国产精品v| 欧美成人精品网站| 中文字幕久久久| 日韩一区二区三区四区五区| 中文字幕一区二区三区有限公司 | 欧美少妇bbb| 亚洲毛片aa| 亚洲国产精品一区| 亚洲精品乱码久久久久久蜜桃图片| 一区二区成人在线| 成人午夜视频一区二区播放| 国语自产精品视频在免费| 亚洲中文字幕在线一区| 亚洲欧美国产精品| 国产精品久久久久av电视剧| 亚洲春色在线| 国产一区欧美一区| 九九热这里有精品视频| 亚洲国产精品国自产拍av秋霞| 波多野结衣视频一区二区| www.四虎在线| 后进极品白嫩翘臀在线播放| 国产精品国产精品国产专区蜜臀ah| 水蜜桃一区二区| 激情综合色丁香一区二区| 久久久久久久久毛片| 精品国产凹凸成av人导航| 爱搞国产精品| 午夜精品区一区二区三 | 日本www高清视频| 国产精品久久久久aaaa樱花 | 一区二区三区在线播放欧美| 日本午夜免费一区二区| 18禁裸男晨勃露j毛免费观看| 久久久久久久久免费| 国产伦精品一区二区三区视频痴汉 | av网站大全在线| 久久国产精品一区二区三区| 麻豆视频一区二区| 国产精品变态另类虐交| 在线观看日韩av| 草草视频在线一区二区| 日韩一级片播放| 亚洲一区二区美女| 国产精品免费播放| 国产精品久久久一区二区三区| 日本中文字幕一区二区有限公司| 久久机热这里只有精品| 中文字幕精品一区二区精品| 精品少妇3p| 乳色吐息在线观看|