Python编程利用Numpy和PIL库将图片转化为手绘
作者:Dragon少年 时间:2021-09-02 07:28:55
主要采用的技术点
Python + Numpy + PIL
在正文代码开始前,大家先看看最初原图和转换手绘风图片前后对比。
当然了,我先查了手绘的三个基本特点:
图片可单通道灰度图
边缘线条较重可当成黑色,相同或相近像素值趋向白色
光源效果下,灰度变化类似于人类视觉的远近
下面开始介绍,手绘照实现步骤:
读取图片,转化为数组
因为要对图像的像素计算,可以先把图片先转化为数组。代码如下:
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.
计算 x,y,z 轴梯度值,归一化
照片对边缘区域更侧重,计算梯度是定位图片边缘部分最有效方式,用灰度变化来模拟图片远近效果,depth 表示预设深度,z 轴默认梯度为 1。
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 / A
uni_y = grad_y / A
uni_z = 1. / A
加入光源效果
根据光源不同的入射角度,对x,y,z 各轴上的梯度值有不同程度的影响,添加一个模拟光源,放置在斜上方,与 x , y 分别形成两个夹角,最后用正弦余弦函数计算出新的像素值。
vec_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) # 光源归一化,8 255
b = b.clip(0, 255)# 对像素值低于0,高于255部分做截断处理
导出图片,并保存
im.save("man_shouhui.jpg")
用 Python将一张图片转化为手绘风格,就这么轻松搞定了!
来源:https://blog.csdn.net/hhladminhhl/article/details/117338511
标签:Numpy,PIL,库,图转手绘
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
用 Python 定义 Schema 并生成 Parquet 文件详情
2021-09-24 14:14:18
Anaconda的安装及其环境变量的配置详解
2022-08-31 19:21:11
![](https://img.aspxhome.com/file/2023/4/82924_0s.jpg)
python tkinter库的Text记录点击路经和删除记录详情
2021-04-15 03:41:13
Python ChineseCalendar包主要类和方法详解
2021-10-12 10:40:40
Python单元测试模块doctest的具体使用
2021-02-26 16:50:12
一个简单的python程序实例(通讯录)
2023-05-16 06:49:11
CSS文字排版终极指南
2010-01-19 10:30:00
python config文件的读写操作示例
2022-04-05 07:42:11
php for 循环语句使用方法详细说明
2023-11-17 21:43:21
python实现邮箱发送信息
2023-02-25 15:11:51
Python3.x检查内存可用大小的两种实现
2022-03-24 07:17:03
Python实现进程同步和通信的方法
2023-08-30 04:21:45
Python3 列表list合并的4种方法
2021-03-28 13:29:43
python实现一次性封装多条sql语句(begin end)
2022-09-27 13:20:34
Python ConfigParser模块的使用示例
2023-12-02 03:35:15
PyTorch中permute的基本用法示例
2022-04-22 01:14:01
让MYSQL彻底支持中文
2008-12-24 16:23:00
Python高级应用实例对比:高效计算大文件中的最长行的长度
2021-11-26 05:36:35
[翻译]标记语言和样式手册 Chapter 7 锚点
2008-01-28 14:01:00
![](https://img.aspxhome.com/file/UploadPic/20081/28/2008128141614907s.jpg)
小谈MySQL字符集
2009-02-13 13:30:00