Python——图像手绘效果
1、图像的RGB色彩模式
PIL
PIL, Python Image Library
PIL库是一个具有强大图像处理能力的第三方库
在命令行下的安装方法: pip install pillow
from PIL import Image
Image是PIL库中代表一个图像的类(对象)
- from PIL import Image
- import numpy as np
- im=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg"))
- print(im.shape,im.dtype)
可以看出图像是一个三维数组,800行,1200列,每一个点分别是RGB三个值。
2、图像的变换
(1)
- b=[255,255,255]-im
- a=Image.fromarray(b.astype('uint8'))%生成新的图像三维数组
- a.save(r"C:\Users\Administrator\Desktop\timg_2.jpg")
(2)
模式L”为灰色图像,它的每个像素用8个bit表示,0表示黑,255表示白,其他数字表示不同的灰度。在PIL中,从模式“RGB”转换为“L”模式是按照下面的公式转换的:
L = R * 299/1000 + G * 587/1000+ B * 114/1000
下面我们将图像转换为“L”图像。
- a=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg"))
- b=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L'))
- c=Image.fromarray(b.astype('uint8'))
- c.save(r"C:\Users\Administrator\Desktop\timg_5.jpg")
RGB三个数变为了一个数。
(3)
- a=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L'))%变为灰度值图片
- a
- Out[12]:
- array([[104, 104, 104, ..., 145, 145, 145],
- [104, 104, 104, ..., 145, 145, 145],
- [104, 104, 104, ..., 145, 145, 145],
- ...,
- [ 70, 78, 79, ..., 73, 65, 78],
- [ 72, 79, 78, ..., 76, 49, 83],
- [ 73, 71, 69, ..., 118, 76, 97]], dtype=uint8)
- b=255-a
- b
- Out[14]:
- array([[151, 151, 151, ..., 110, 110, 110],
- [151, 151, 151, ..., 110, 110, 110],
- [151, 151, 151, ..., 110, 110, 110],
- ...,
- [185, 177, 176, ..., 182, 190, 177],
- [183, 176, 177, ..., 179, 206, 172],
- [182, 184, 186, ..., 137, 179, 158]], dtype=uint8)
- im=Image.fromarray(b.astype('uint8'))
- im.save(r"C:\Users\Administrator\Desktop\timg_3.jpg")
(4)
- d=255*(a/255)**2 %平方变换
- im=Image.fromarray(d.astype('uint8'))
- im.save(r"C:\Users\Administrator\Desktop\timg_4.jpg")
(5)
- d=(100/255)*a+150%区间变换
- im=Image.fromarray(d.astype('uint8'))
- im.save(r"C:\Users\Administrator\Desktop\timg_4.jpg")
2、图像手绘效果分析
手绘效果的几个特征:
• 黑白灰色
• 边界线条较重
• 相同或相近色彩趋于白色
• 略有光源效果
(1)梯度重构
利用像素之间的梯度值和虚拟深度值对图像进行重构
(2)光源效果
根据灰度变化来模拟人类视觉的远近程度
(3)
(4)
- from PIL import Image
- import numpy as np
- a = np.asarray(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L')).astype('float')
- depth = 10.
- grad = np.gradient(a) #梯度值,
- grad_x, grad_y = grad
- grad_x = grad_x*depth/100. #列梯度值*0.1
- grad_y = grad_y*depth/100.
- A = np.sqrt(grad_x**2 + grad_y**2 + 1.) #相当于grad_z=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) #长度为1,投影x,y,z长度
- b = 255*(dx*uni_x + dy*uni_y + dz*uni_z)
- b = b.clip(0,255)
- im = Image.fromarray(b.astype('uint8'))
- im.save(r"C:\Users\Administrator\Desktop\timg_6.jpg")
数据变化过程如下
目的其实是将数据两级化,要么黑要么白,更好凸显手绘的感觉
x,y梯度变化越大,,则z的梯度比例越小,此时求出的变化后的灰度值越小,颜色越黑。
相反,则灰度值越大,越白,将黑白分明就显示出来了。
Python——图像手绘效果的更多相关文章
- 使用numpy和PIL实现图像的手绘效果
输入 输出 代码如下 图像的手绘效果的实现 from PIL import Image import numpy as np a = np.array(Image.open("index.j ...
- 永中dcs实现浏览器上面的手绘效果
永中dcs是一款在线预览各种办公文件的网络产品,我们可以只用一个浏览器就可以实现对word,ppt和excel等文件的在线浏览,在其中有一个在线手绘功能很有特色,让我们来探一探它的实现原理吧. 第一, ...
- 图像的手绘效果(Python)
PIL库,Python Image Library PIL库是一个具有强大图像处理能力的第三方库 在命令行下的安装方法:pip install pillow from PIL import Image ...
- python之实现图像的手绘效果
https://blog.csdn.net/riba2534/article/details/74152285 原图: b: c: d: 最终图:
- Android手绘效果实现
效果图 原理 大概介绍一下实现原理.首先你得有一张图(废话~),接下来就是把这张图的轮廓提取出来,轮廓提取算法有很多,本人不是搞图像处理的,对图像处理感兴趣的童鞋可以查看相关资料.如果你有好的轮廓提取 ...
- 图像滤镜艺术---PS图像转手绘特效实现方案
原文:图像滤镜艺术---PS图像转手绘特效实现方案 手绘效果实现方案 本文介绍一种PS手绘效果的实现方案,PS步骤来自网络,本文介绍代码实现过程. 整体看来,虽然效果还是有很大差异,但是已经有了这种特 ...
- Microsoft Tech Summit 2018 课程简述:利用 Windows 新特性开发出更好的手绘视频应用
概述 Microsoft Tech Summit 2018 微软技术暨生态大会将于10月24日至27日在上海世博中心举行,这也会是国内举办的最后一届 Tech Summit,2019 年开始会以 Mi ...
- Python绘图还在用Matplotlib?out了 !发现一款手绘可视化神器!
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. GitHub 地址:https://github.com/chenjian ...
- 发现一款手绘可视化神器!Python绘图还在用Matplotlib?out了 !
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取htt ...
随机推荐
- 前端Bug解决方案
没错!我正在写bug呢!不管你是小白还是大牛,写bug无可避免,遇到bug怎么办?别慌!毛主席教导我们"战略上藐视BUG,战术上重视BUG"!前端遇到的bug无非就三个方面结构层( ...
- Mysql(Mariadb)数据库之Information Schema 库中GLOBAL_VARIABLES表 and SESSION_VARIABLES 表分析
Information Schema GLOBAL_VARIABLES and SESSION_VARIABLES Tables The Information Schema GLOBAL_VARIA ...
- 结题报告--洛谷P3915
题目:点此. 我处理这种多组数据的方法被我叫做“mains法”,就是先假设只有一组数据,写一个代码,然后把那个main函数改成mains,最后写一个真正的main函数. 这个“真正的”main函数一般 ...
- 建议11:增强数组排序的sort功能
sort方法不仅按字母顺序进行排序,还可以根据其他顺序执行操作.这时就必须为方法提供一个比较函数的参数,该函数要比较两个值,然后返回一个用于说明这两个值得相对顺序的数字.比较函数应该具有两个参数a和b ...
- vscode 对于 md的编写 左侧 大纲 很重要!!
vscode 对于 md的编写 左侧 大纲 很重要!!
- Netty源码分析一<序一Unix网络I/O模型简介>
Unix网络 I/O 模型 我们都知道,为了操作系统的安全性考虑,进程是无法直接操作I/O设备的,其必须通过系统调用请求内核来协助完成I/O动作,而内核会为每个I/O设备维护一个buffer.以下 ...
- C#winform如何主窗口最大化最小化默认大小
this.WindowState = FormWindowState.Minimized; bool b = true; private void button2_Click(object sende ...
- BFPRT算法(求第K小的数字)
BFPRT算法: 1.介绍: BFPRT算法又叫中位数的中位数算法,主要用于在无序数组中寻找第K大或第K小的数,它的最坏时间复杂度为O(n),它是由Blum,Floyd,Pratt,Rivest,Ta ...
- [C#] 命令总线模式
1 高内聚.低耦合 虽然已经毕业很多年了,但依然总是能记得,<软件工程>这门课的老师总是强调 "高内聚,低耦合". 这些年,在架构方面的技术发展方向,目标就是不断的拆分 ...
- C++ 类的继承和派生
继承的优点:减少代码的冗余 提高代码的重用性 派生类定义格式: Class 派生类名 : 继承方式 基类名{ //派生类新增的数据成员和成员函数 }; class 子类: 继承方式 父类名{ //子类 ...