教你如何几行python代码实现图片转手绘

这里是运行效果

在这里插入图片描述在这里插入图片描述

先展示一下完整代码,后面在进行分析
# -*- coding: utf-8 -*-
from PIL import Image
import numpy as np

im = Image.open('really.jpg').convert('L')#really.jpg是这里将用于转换的原图
a = np.asarray(im).astype('float')  # 将图像以灰度图的方式打开并将数据转为float存入np中.

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.)  # 构造x和y轴梯度的三维归一化单位坐标系
uni_x = grad_x / A
uni_y = grad_y / A
uni_z = 1. / A

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)  # 光源归一化,(梯度和光源相互作用,将梯度转化为灰度)
b = b.clip(0, 255)

im2 = Image.fromarray(b.astype('uint8'))          # 重构图像

im2.save('lk.jpg')#保存得到的手绘图片
im2.show()#展示

1.上面的代码要想运行,首先你得安装两个库numpy(一个科学计算库),还有一个PIL(python的图像处理库)

直接终端输入:

pip install numpy
pip install Pillow
2.使用Image.open()方法将图片读入,随后使用numpy将其存在一个二维数组中(二维数组存储的是灰度图)
im = Image.open('really.jpg').convert('L')
a = np.asarray(im).astype('float') 
3.取梯度值,建立坐标系
depth = 10.                        
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
vec_el = np.pi / 2.2                 
vec_az = np.pi / 4.                   
dx = np.cos(vec_el) * np.cos(vec_az) 
dy = np.cos(vec_el) * np.sin(vec_az)  
dz = np.sin(vec_el) 
4.通过建好的坐标系,光源归一化
b = 255 * (dx * uni_x + dy * uni_y + dz * uni_z)  # 光源归一化,(梯度和光源相互作用,将梯度转化为灰度)
b = b.clip(0, 255)
5图像重构
im2 = Image.fromarray(b.astype('uint8'))  
6.得到的手绘图像的展示与存储
im2.save('lk.jpg')#保存得到的手绘图片
im2.show()#展示
  • 9
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是lk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值