图像的手绘效果是在图像灰度化的基础上叠加立体效果和明暗效果实现的。其中立体效果通过添加虚拟深度值实现,而明暗变化则通过调整像素梯度值实现。
程序的源代码如下:
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')
输出结果如下:
输入彩色图片:
输出手绘风图片: