小编给大家分享一下Python+PIL如何实现支付宝AR红包,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
思路比较简单:
1、对图片进行锐化处理;
2、设(r_h, g_h, b_h)为支付宝遮罩黑条的RGB值,以此为中心,查找半径为Diff_radius的范围内所有的色值;
3、对每一行符合步骤2的像素点个数进行计数,若该数值超过某个临界值(如:图片宽度的一半),将其所在行替换为上一行非遮罩数据;
4、对处理后的图片高斯滤镜。
以下是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!")
对于不同的图片,可能需要修改3、4、5行的参数。
目前测试过几组照片,发现给出的线索图片越复杂,这种方法处理后能被识别的成功率越高,尤其是对人脸,简单的处理后基本都可以识别。
识别成功的:
识别失败的:
以上是“Python+PIL如何实现支付宝AR红包”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。