0x01 解决思路
如何裁剪一张图片的可视区域?解决这个问题的方法有很多种,本文采用的方法很简单:想象有四条线从图片四周向内推进,如果碰到不是白色的内容,那么就停止推进。最终这四条线内部的区域就是该图片的可视区域。
测试环境:Ubuntu 18.04 + Python3.6 + Pillow-5.3.0 + NumPy-1.15.2
0x02 实现(Pillow)
def visible_box_pil(img, white=240, ratio=0.99):
"""
获取图像的可视区域
:param img: PIL.Image.Image,目标图像
:param white: 白色像素灰度阀值
:param ratio: 白色像素比例阀值
:return: 可视区域,4元素元组
"""
gray = img.convert('L')
first_col, first_row = 0, 0
last_col, last_row = width, height = img.size
# 从上往下,按行推进
for y in range(height):
pixel_count = 0
for x in range(width):
if gray.getpixel((x, y)) > white:
pixel_count += 1
if pixel_count / width < ratio:
first_row = y
break
# 从下往上,按行推进
for y in reversed(range(height)):
pixel_count = 0