Python+PIL實(shí)現(xiàn)支付寶AR紅包
本文實(shí)例為大家分享了Python+PIL處理支付寶AR紅包的具體代碼,供大家參考,具體內(nèi)容如下
思路比較簡(jiǎn)單:
1、對(duì)圖片進(jìn)行銳化處理;
2、設(shè)(r_h, g_h, b_h)為支付寶遮罩黑條的RGB值,以此為中心,查找半徑為Diff_radius的范圍內(nèi)所有的色值;
3、對(duì)每一行符合步驟2的像素點(diǎn)個(gè)數(shù)進(jìn)行計(jì)數(shù),若該數(shù)值超過(guò)某個(gè)臨界值(如:圖片寬度的一半),將其所在行替換為上一行非遮罩?jǐn)?shù)據(jù);
4、對(duì)處理后的圖片高斯濾鏡。
以下是python代碼:
from PIL import Image,ImageFilter Diff_radius = 500 diff_min = 1 r_h, g_h, b_h = 43, 55, 66 image = Image.open('test.png') image_width = image.size[0] image_height = image.size[1] rgb_im = image.convert('RGB') img_sharpen = image.filter(ImageFilter.SHARPEN) img_new = Image.new('RGBA', image.size, (255,255,255,255)) img_copy = img_sharpen.crop((0,0,image_width,image_height)) img_new.paste(img_copy, (0,0,image_width,image_height)) y_tmp = 0 for y in range(image_height): y_is_black = 0 current_line_flag_acc = 0 for x in range(image_width): r, g, b = rgb_im.getpixel((x, y)) if ((r_h-r)**2 + (g_h-g)**2 + (b_h-b)**2) < Diff_radius : current_line_flag_acc = current_line_flag_acc + 1 if (x == image_width - 1) and (current_line_flag_acc > diff_min) : y_is_black = 1 img1 = img_new.crop((0,y_tmp-2,image_width,y_tmp-1)) img_new.paste(img1, (0,y,image_width,y+1)) # print('y_tmp:%d -> y:%d'%(y_tmp,y)) elif (x == image_width - 1) and not y_is_black: y_tmp = y # img_save = img_new.filter(ImageFilter.GaussianBlur(radius=1.5)) img_new.save('test_1.png') print("done!")
對(duì)于不同的圖片,可能需要修改3、4、5行的參數(shù)。
目前測(cè)試過(guò)幾組照片,發(fā)現(xiàn)給出的線索圖片越復(fù)雜,這種方法處理后能被識(shí)別的成功率越高,尤其是對(duì)人臉,簡(jiǎn)單的處理后基本都可以識(shí)別。
識(shí)別成功的:
識(shí)別失敗的:
以上內(nèi)容僅用作學(xué)習(xí),起到拋磚引玉的作用,請(qǐng)不要用作其他用途。我只是個(gè)python和PIL的初學(xué)者。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
pycharm 使用心得(六)進(jìn)行簡(jiǎn)單的數(shù)據(jù)庫(kù)管理
功能簡(jiǎn)介:pycharm自帶了一個(gè)簡(jiǎn)單的數(shù)據(jù)庫(kù)插件,可以比較方便的進(jìn)行簡(jiǎn)單的數(shù)據(jù)庫(kù)操作。2014-06-06python實(shí)現(xiàn)獲取客戶機(jī)上指定文件并傳輸?shù)椒?wù)器的方法
這篇文章主要介紹了python實(shí)現(xiàn)獲取客戶機(jī)上指定文件并傳輸?shù)椒?wù)器的方法,涉及Python實(shí)現(xiàn)C/S架構(gòu)程序與socket程序的使用技巧,需要的朋友可以參考下2015-03-03Python+OpenCV實(shí)現(xiàn)閾值分割的方法詳解
閾值分割法是一種基于區(qū)域的圖像分割技術(shù),原理是把圖像像素點(diǎn)分為若干類。本文將利用Python+OpenCV實(shí)現(xiàn)閾值分割,感興趣的可以了解一下2022-05-05Python 給下載文件顯示進(jìn)度條和下載時(shí)間的實(shí)現(xiàn)
這篇文章主要介紹了Python 給下載文件顯示進(jìn)度條和下載時(shí)間的代碼,本文通過(guò)實(shí)例代碼截圖相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04使用keras根據(jù)層名稱來(lái)初始化網(wǎng)絡(luò)
這篇文章主要介紹了使用keras根據(jù)層名稱來(lái)初始化網(wǎng)絡(luò),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05Python+OpenCV六種實(shí)時(shí)圖像處理詳細(xì)講解
OpenCV常用的圖像處理為閾值二值化、邊緣檢測(cè)、輪廓檢測(cè)、高斯濾波、色彩轉(zhuǎn)換、調(diào)節(jié)對(duì)比度。本文主要介紹了利用Python和OpenCV對(duì)實(shí)時(shí)圖像進(jìn)行上述六種操作的詳細(xì)講解,感興趣的可以了解一下。2021-11-11python翻譯軟件實(shí)現(xiàn)代碼(使用google api完成)
這篇文章主要介紹了python結(jié)合google api完成的翻譯軟件實(shí)現(xiàn)代碼,大家參考使用2013-11-11