def motion_blur(img, degree=10, angle=20):
image = img.copy()
# 这里生成任意角度的运动模糊kernel的矩阵, degree越大,模糊程度越高
M = cv2.getRotationMatrix2D((degree / 2, degree / 2), angle, 1)
motion_blur_kernel = np.diag(np.ones(degree))
motion_blur_kernel = cv2.warpAffine(motion_blur_kernel, M, (degree, degree))
motion_blur_kernel = motion_blur_kernel / degree
blurred = cv2.filter2D(image, -1, motion_blur_kernel)
# convert to uint8
cv2.normalize(blurred, blurred, 0, 255, cv2.NORM_MINMAX)
blurred = np.array(blurred, dtype=np.uint8)
return blurred
if __name__ == '__main__':
img = cv2.imread(r'1.jpg')
blurred = motion_blur(img)
cv2.imwrite(r'2.jpg', blurred)
OpenCV图像运动模糊
原创
©著作权归作者所有:来自51CTO博客作者小殊小殊的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:pytorch 计算网络参数个数
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
运动模糊图像,模糊图像,锐化图像
%用函数创建一个制定的滤波器模版,其语法格式为:%H=fspecial(type);%H=fspecial(type,parameters);
image Image matlab Matlab MATLAB