​ 一、前言

七夕要到了——这款素描送给女朋友叭!!!!

一个很nice的源码。用的IU的照片!

用python画素描画的方式有很多种,

常见的有通过opencv、pil来进行转换

这里给大家分享通过pil实现图片转素描风格绘画的方式。

二、效果

1.iu素描前后效果 yyds!!

你最爱的女神七夕素描礼物一键解锁!![附源码]_文件对话框你最爱的女神七夕素描礼物一键解锁!![附源码]_文件对话框_02

2.同事的女朋友.素描前后效果。

你最爱的女神七夕素描礼物一键解锁!![附源码]_python_03你最爱的女神七夕素描礼物一键解锁!![附源码]_文件对话框_02

你最爱的女神七夕素描礼物一键解锁!![附源码]_灰度_05你最爱的女神七夕素描礼物一键解锁!![附源码]_项目代码_06

三、环境要求

1.python3+
2.numpy
3.pillow

四、源码分享

 

 

 

from PIL import Image
import numpy as np
import tkinter.filedialog
root = tkinter.Tk().withdraw()
filename = tkinter.filedialog.askopenfilename()  # 打开选择文件对话框
try:
    depth = 30  # 0-100,越高,颜色越深
    picture_grad = np.gradient(np.asarray(Image.open(filename).convert('L')).astype('int'))  # 取图像灰度的梯度值
    grad_x, grad_y = picture_grad[0] * depth / 100., picture_grad[1] * depth / 100.  # 将获取的维度梯度值进行深度处理
    base = np.sqrt(grad_x ** 2 + grad_y ** 2 + 1.)  # 降噪基
    _x, _y, _z = grad_x / base, grad_y / base, 1. / base
    sce_z, sce_x = np.pi / 2.1, np.pi / 3  # 光源的俯视角度值和方位角度值
    # 光源对x,y,z 轴的影响
    dx, dy, dz = np.cos(sce_z) * np.cos(sce_x), np.cos(sce_z) * np.sin(sce_x), np.sin(sce_z)
    Normalized = 255 * (dx * _x + dy * _y + dz * _z).clip(0, 255)  # 光源归一化
    im = Image.fromarray(Normalized.astype('uint8'))  # 重构图像
    im.save('转换后的素描图.jpg')  # 保存转换后的图片
    im.show()  # 展示转换后的图片
except Exception:
    print('转换失败!')