一、前言
用python画素描画的方式有很多种,
常见的有通过opencv、pil来进行转换
这里给大家分享通过pil实现图片转素描风格绘画的方式。
对人像的转换出来看就一般,对风景的转化看着还行。
大佬可优化一下算法。
二、效果
1.风景
原图: 转换后:
2.人像
原图: 转换后:
3.物品
原图: 转换后:
三、环境要求
1.python3+ 2.numpy
四、源码分享
from PIL import Image
import numpy as np
import tkinter.filedialog
root = tkinter.Tk().withdraw()
filename = tkinter.filedialog.askopenfilename()
try:
depth = 30
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
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('转换失败!')
五、源码分享
可直接运行版下载地址:
已经打包成exe文件了,Windows环境下可直接点击运行
下载地址:https://download.csdn.net/download/momoda118/20719184
六、往期文章回顾
python小爬虫-28行代码实现图形化在线翻译!
python-85行代码完成贪吃蛇和关卡升级:是男人就坚持到第10关!
|