广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python编程利用Numpy和PIL库将图片转化为手绘
  • 514
分享到

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

2024-04-02 19:04:59 514人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录主要采用的技术点读取图片,转化为数组计算 x,y,z 轴梯度值,归一化加入光源效果导出图片,并保存主要采用的技术点 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将一张图片转化为手绘风格,就这么轻松搞定了!

以上就是Python编程利用Numpy和PIL库将一张图片转化为手绘风格的详细内容,更多关于python编程Numpy和PIL库的资料请关注编程网其它相关文章!

--结束END--

本文标题: Python编程利用Numpy和PIL库将图片转化为手绘

本文链接: https://www.lsjlt.com/news/136802.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python编程利用Numpy和PIL库将图片转化为手绘
    目录主要采用的技术点读取图片,转化为数组计算 x,y,z 轴梯度值,归一化加入光源效果导出图片,并保存主要采用的技术点 Python + Numpy + PIL 在正文代码开始前,大...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作