图像尺寸一定要与头部坐标尺寸相对应
def do_mosaic(self, x, y, w, h, neighbor=5):
"""
马赛克的实现原理是把图像上某个像素点一定范围邻域
内的所有点用邻域内左上像素点的颜色代替,这样可以模糊细节,
但是可以保留大体的轮廓。
:param frame: opencv frame
:param int x : 马赛克框左顶点x
:param int y: 马赛克框左顶点y
:param int w: 马赛克框宽
:param int h: 马赛克框高
:param int neighbor: 马赛克每一块的宽(小色块大小)
"""
frame = self.img # opencv读取到的图片(原色)
fh, fw = frame.shape[0], frame.shape[1] # 图片的高,宽
if (y + h > fh) or (x + w > fw):
return
for i in range(0, h - neighbor, neighbor): # 关键点0 减去neightbour 防止溢出
for j in range(0, w - neighbor, neighbor):
rect = [j + x, i + y, neighbor, neighbor]
color = frame[i + y][j + x].tolist() # 关键点1 tolist
left_up = (rect[0], rect[1])
right_down = (rect[0] + neighbor - 1, rect[1] + neighbor - 1) # 关键点2 减去一个像素
cv2.rectangle(frame, left_up, right_down, color, -1)
return frame
本文介绍了一种在图像上应用马赛克效果的方法。通过将指定区域内的像素用邻域内左上角像素颜色替代,达到模糊细节同时保持轮廓的效果。文章提供了具体的实现代码及关键步骤说明。
7325

被折叠的 条评论
为什么被折叠?



