600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 【学习笔记】python实现图像的手绘效果

【学习笔记】python实现图像的手绘效果

时间:2020-11-10 15:53:13

相关推荐

【学习笔记】python实现图像的手绘效果

图像的手绘效果是在图像灰度化的基础上叠加立体效果和明暗效果实现的。其中立体效果通过添加虚拟深度值实现,而明暗变化则通过调整像素梯度值实现。

程序的源代码如下:

from PIL import Imageimport numpy as npa = np.asarray(Image.open('C:/Users/86185/Desktop/1.jpg').convert('L')).astype('float')depth = 10. # (0-100)grad = np.gradient(a) #取图像灰度的梯度值grad_x, grad_y = grad#分别取横纵图像梯度值grad_x = grad_x*depth/100.grad_y = grad_y*depth/100.A = np.sqrt(grad_x**2 + grad_y**2 + 1.)uni_x = grad_x/Auni_y = grad_y/Auni_z = 1./Avec_el = np.pi/2.2 # 光源的俯视角度,弧度值vec_az = np.pi/4.# 光源的方位角度,弧度值dx = np.cos(vec_el)*np.cos(vec_az) #光源对x 轴的影响dy = np.cos(vec_el)*np.sin(vec_az) #光源对y 轴的影响dz = np.sin(vec_el) #光源对z 轴的影响b = 255*(dx*uni_x + dy*uni_y + dz*uni_z)#光源归一化b = b.clip(0,255)im = Image.fromarray(b.astype('uint8')) #重构图像im.save('C:/Users/86185/Desktop/2.jpg')

输出结果如下:

输入彩色图片:

输出手绘风图片:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。