1、图像的RGB色彩模式

PIL

PIL, Python Image Library

PIL库是一个具有强大图像处理能力的第三方库

在命令行下的安装方法: pip install pillow

from PIL import Image

Image是PIL库中代表一个图像的类(对象)

  1. from PIL import Image
  2.  
  3. import numpy as np
  4.  
  5. im=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg"))
  6.  
  7. print(im.shape,im.dtype)

可以看出图像是一个三维数组,800行,1200列,每一个点分别是RGB三个值。

2、图像的变换  

(1)

  1. b=[255,255,255]-im
  2.  
  3. a=Image.fromarray(b.astype('uint8'))%生成新的图像三维数组
  4.  
  5. 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”图像。

  1. a=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg"))
  2.  
  3. b=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L'))
  4.  
  5. c=Image.fromarray(b.astype('uint8'))
  6.  
  7. c.save(r"C:\Users\Administrator\Desktop\timg_5.jpg")

 

RGB三个数变为了一个数。

(3)

  1. a=np.array(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L'))%变为灰度值图片
  2.  
  3. a
  4. Out[12]:
  5. array([[104, 104, 104, ..., 145, 145, 145],
  6. [104, 104, 104, ..., 145, 145, 145],
  7. [104, 104, 104, ..., 145, 145, 145],
  8. ...,
  9. [ 70, 78, 79, ..., 73, 65, 78],
  10. [ 72, 79, 78, ..., 76, 49, 83],
  11. [ 73, 71, 69, ..., 118, 76, 97]], dtype=uint8)
  12.  
  13. b=255-a
  14.  
  15. b
  16. Out[14]:
  17. array([[151, 151, 151, ..., 110, 110, 110],
  18. [151, 151, 151, ..., 110, 110, 110],
  19. [151, 151, 151, ..., 110, 110, 110],
  20. ...,
  21. [185, 177, 176, ..., 182, 190, 177],
  22. [183, 176, 177, ..., 179, 206, 172],
  23. [182, 184, 186, ..., 137, 179, 158]], dtype=uint8)
  24.  
  25. im=Image.fromarray(b.astype('uint8'))
  26.  
  27. im.save(r"C:\Users\Administrator\Desktop\timg_3.jpg")

(4)

  1. d=255*(a/255)**2 %平方变换
  2.  
  3. im=Image.fromarray(d.astype('uint8'))
  4.  
  5. im.save(r"C:\Users\Administrator\Desktop\timg_4.jpg")

(5)

  1. d=(100/255)*a+150%区间变换
  2.  
  3. im=Image.fromarray(d.astype('uint8'))
  4.  
  5. im.save(r"C:\Users\Administrator\Desktop\timg_4.jpg")  

2、图像手绘效果分析

手绘效果的几个特征:

• 黑白灰色

• 边界线条较重

• 相同或相近色彩趋于白色

• 略有光源效果

(1)梯度重构

利用像素之间的梯度值和虚拟深度值对图像进行重构

(2)光源效果

根据灰度变化来模拟人类视觉的远近程度

(3)

(4)

  1. from PIL import Image
  2. import numpy as np
  3.  
  4. a = np.asarray(Image.open(r"C:\Users\Administrator\Desktop\timg.jpg").convert('L')).astype('float')
  5.  
  6. depth = 10.
  7. grad = np.gradient(a) #梯度值,
  8. grad_x, grad_y = grad
  9. grad_x = grad_x*depth/100. #列梯度值*0.1
  10. grad_y = grad_y*depth/100.
  11.  
  12. A = np.sqrt(grad_x**2 + grad_y**2 + 1.) #相当于grad_z=1

  13. uni_x = grad_x/A
  14. uni_y = grad_y/A
  15. uni_z = 1./A #梯度归一化
  16.  
  17. vec_el = np.pi/2.2
  18. vec_az = np.pi/4.
  19.  
  20. dx = np.cos(vec_el)*np.cos(vec_az)
  21. dy = np.cos(vec_el)*np.sin(vec_az)
  22. dz = np.sin(vec_el) #长度为1,投影x,y,z长度
  23.  
  24. b = 255*(dx*uni_x + dy*uni_y + dz*uni_z)
  25. b = b.clip(0,255)
  26.  
  27. im = Image.fromarray(b.astype('uint8'))
  28. im.save(r"C:\Users\Administrator\Desktop\timg_6.jpg")

 

数据变化过程如下

目的其实是将数据两级化,要么黑要么白,更好凸显手绘的感觉

x,y梯度变化越大,,则z的梯度比例越小,此时求出的变化后的灰度值越小,颜色越黑。

相反,则灰度值越大,越白,将黑白分明就显示出来了。

Python——图像手绘效果的更多相关文章

  1. 使用numpy和PIL实现图像的手绘效果

    输入 输出 代码如下 图像的手绘效果的实现 from PIL import Image import numpy as np a = np.array(Image.open("index.j ...

  2. 永中dcs实现浏览器上面的手绘效果

    永中dcs是一款在线预览各种办公文件的网络产品,我们可以只用一个浏览器就可以实现对word,ppt和excel等文件的在线浏览,在其中有一个在线手绘功能很有特色,让我们来探一探它的实现原理吧. 第一, ...

  3. 图像的手绘效果(Python)

    PIL库,Python Image Library PIL库是一个具有强大图像处理能力的第三方库 在命令行下的安装方法:pip install pillow from PIL import Image ...

  4. python之实现图像的手绘效果

    https://blog.csdn.net/riba2534/article/details/74152285 原图: b: c: d: 最终图:

  5. Android手绘效果实现

    效果图 原理 大概介绍一下实现原理.首先你得有一张图(废话~),接下来就是把这张图的轮廓提取出来,轮廓提取算法有很多,本人不是搞图像处理的,对图像处理感兴趣的童鞋可以查看相关资料.如果你有好的轮廓提取 ...

  6. 图像滤镜艺术---PS图像转手绘特效实现方案

    原文:图像滤镜艺术---PS图像转手绘特效实现方案 手绘效果实现方案 本文介绍一种PS手绘效果的实现方案,PS步骤来自网络,本文介绍代码实现过程. 整体看来,虽然效果还是有很大差异,但是已经有了这种特 ...

  7. Microsoft Tech Summit 2018 课程简述:利用 Windows 新特性开发出更好的手绘视频应用

    概述 Microsoft Tech Summit 2018 微软技术暨生态大会将于10月24日至27日在上海世博中心举行,这也会是国内举办的最后一届 Tech Summit,2019 年开始会以 Mi ...

  8. Python绘图还在用Matplotlib?out了 !发现一款手绘可视化神器!

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. GitHub 地址:https://github.com/chenjian ...

  9. 发现一款手绘可视化神器!Python绘图还在用Matplotlib?out了 !

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取htt ...

随机推荐

  1. 前端Bug解决方案

    没错!我正在写bug呢!不管你是小白还是大牛,写bug无可避免,遇到bug怎么办?别慌!毛主席教导我们"战略上藐视BUG,战术上重视BUG"!前端遇到的bug无非就三个方面结构层( ...

  2. Mysql(Mariadb)数据库之Information Schema 库中GLOBAL_VARIABLES表 and SESSION_VARIABLES 表分析

    Information Schema GLOBAL_VARIABLES and SESSION_VARIABLES Tables The Information Schema GLOBAL_VARIA ...

  3. 结题报告--洛谷P3915

    题目:点此. 我处理这种多组数据的方法被我叫做“mains法”,就是先假设只有一组数据,写一个代码,然后把那个main函数改成mains,最后写一个真正的main函数. 这个“真正的”main函数一般 ...

  4. 建议11:增强数组排序的sort功能

    sort方法不仅按字母顺序进行排序,还可以根据其他顺序执行操作.这时就必须为方法提供一个比较函数的参数,该函数要比较两个值,然后返回一个用于说明这两个值得相对顺序的数字.比较函数应该具有两个参数a和b ...

  5. vscode 对于 md的编写 左侧 大纲 很重要!!

    vscode 对于 md的编写 左侧 大纲 很重要!!

  6. Netty源码分析一<序一Unix网络I/O模型简介>

    Unix网络 I/O 模型   我们都知道,为了操作系统的安全性考虑,进程是无法直接操作I/O设备的,其必须通过系统调用请求内核来协助完成I/O动作,而内核会为每个I/O设备维护一个buffer.以下 ...

  7. C#winform如何主窗口最大化最小化默认大小

    this.WindowState = FormWindowState.Minimized; bool b = true; private void button2_Click(object sende ...

  8. BFPRT算法(求第K小的数字)

    BFPRT算法: 1.介绍: BFPRT算法又叫中位数的中位数算法,主要用于在无序数组中寻找第K大或第K小的数,它的最坏时间复杂度为O(n),它是由Blum,Floyd,Pratt,Rivest,Ta ...

  9. [C#] 命令总线模式

    1 高内聚.低耦合 虽然已经毕业很多年了,但依然总是能记得,<软件工程>这门课的老师总是强调 "高内聚,低耦合". 这些年,在架构方面的技术发展方向,目标就是不断的拆分 ...

  10. C++ 类的继承和派生

    继承的优点:减少代码的冗余 提高代码的重用性 派生类定义格式: Class 派生类名 : 继承方式 基类名{ //派生类新增的数据成员和成员函数 }; class 子类: 继承方式 父类名{ //子类 ...