Python编程利用Numpy和PIL库将图片转化为手绘

作者:Dragon少年 时间:2021-09-02 07:28:55 

主要采用的技术点

Python + Numpy + PIL

在正文代码开始前,大家先看看最初原图和转换手绘风图片前后对比。

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,库,图转手绘
0
投稿

猜你喜欢

  • Python中super().__init__()测试以及理解

    2023-08-25 02:22:04
  • ASP.NET在IIS一些问题经验总结

    2007-08-07 15:42:00
  • 浅析Golang中的内存逃逸

    2024-05-05 09:28:21
  • getAllResponseHeaders获取网页的http头信息代码

    2010-03-31 14:31:00
  • Python+OpenCV人脸检测原理及示例详解

    2021-07-31 19:31:51
  • 初学者学习Python好还是Java好

    2021-03-16 21:48:32
  • python flask框架快速入门

    2021-10-16 22:02:26
  • python 实现批量xls文件转csv文件的方法

    2023-08-29 10:25:26
  • Dreamweaver滑动菜单的制作[图]

    2007-11-08 12:43:00
  • django 解决model中类写不到数据库中,数据库无此字段的问题

    2024-01-24 17:52:07
  • WEB设计经验-来自Microsoft

    2008-05-15 07:30:00
  • Python机器学习应用之支持向量机的分类预测篇

    2023-08-29 20:42:55
  • python环境中的概念conda中与环境相关指令操作

    2021-01-09 19:40:55
  • TensorFLow 数学运算的示例代码

    2023-12-13 21:30:16
  • python中multiprosessing模块的Pool类中的apply函数和apply_async函数的区别

    2023-03-21 20:23:37
  • MySQL中or、in、union与索引优化详析

    2024-01-18 08:21:55
  • SQL中笛卡尔积的实际应用

    2024-01-27 14:18:21
  • 交互设计实用指南系列(12)—避免出错

    2010-04-12 13:02:00
  • Python中使用不同编码读写txt文件详解

    2023-06-29 20:35:27
  • 详解 python logging日志模块

    2021-05-07 19:59:01
  • asp之家 网络编程 m.aspxhome.com