实例:图像的手绘效果

图像的数组表示

图像的RGB色彩模式

RGB三个颜色通道的变化和叠加得到各种颜色,其中

  • R红色,取值范围0-255
  • G绿色,取值范围0-255
  • B蓝色,取值范围0-255

RGB形成的颜色包括了人类视力所能感知的所有颜色。


PIL库

PIL,Python Image Library

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

在命令行下的安装方法:

pip install pillow

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

from PIL import Image

图像的数组表示

图像是一个由像素组成的二维矩阵,每个元素是一个RGB值。

如图所示,图片可以转化为一个由x轴和y轴形成的阵列,其中的每一个像素是一个RGB值,我们知道RGB值中的每一部分都是一个字节,所以一个图像就是由三个字节作为元素形成的一个二维矩阵。


图像的变换

读入图像后,获得像素RGB值,修改之后保存为新的文件。





图像的手绘效果

手绘效果的几个特征:

  • 黑白灰色
  • 边界线条较重
  • 相同或相近色彩趋于白色
  • 略有光源效果

手绘效果是在对图像进行灰度化的基础上,由立体效果、明暗效果叠加而成的。灰度表示图像的明暗变化,而梯度值表示了灰度的变化率。所以我们利用像素之间的梯度值和虚拟深度值对图像进行重构,跟据灰度变化来模拟人类视觉的明暗程度

实例代码:

from PIL import Image
import numpy as npa = np.asarray(Image.open('./beijing.jpg').convert('L')).astype('float')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./Avec_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)im = Image.fromarray(b.astype('uint8'))    #重构图像
im.save('./beijingHD.jpg')


代码解析:

depth = 10.                         # 预设深度值为10,取值范围0-100
grad = np.gradient(a)
grad_x, grad_y = grad              # 提取x和y方向的梯度值
grad_x = grad_x*depth/100.
grad_y = grad_y*depth/100.          # 跟据深度调整x和y方向的梯度值

vec_el = np.pi/2.2                  #np.cos(vec_el)为单位光线在地平面上的投影长度
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 轴的影响
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
b = 255*(dx*uni_x + dy*uni_y + dz*uni_z)  #梯度与光源相互作用,将梯度转化为灰度
b = b.clip(0,255)                         #为了避免数据越界,将生成的灰度值裁剪至0-255区间
im = Image.fromarray(b.astype('uint8'))
im.save('./beijingHD.jpg')                #生成图像

#所有视频截图均来自中国大学mooc北京理工大学嵩天老师的课程
《Python数据分析与展示》

Python数据分析与展示:实例:图像的手绘效果相关推荐

  1. python数据分析与展示--图像的手绘效果

    目录 一.图像的数组表示 1.图像的RGB色彩模式 2.PIL库 二.图像变换 1.image转换成array 2.array转换成image 三.图像的手绘效果 1.实例介绍  ​ 2.编程实例 一 ...

  2. 利用Numpy+PIL读取图像实现手绘效果

    读取图像+简单处理 import numpy as np from PIL import Imagepath = "" #图像路径im = np.array(Image.open( ...

  3. Python实现图像的手绘效果

      用Python实现手绘图像的效果 1.图像的RGB色彩模式   图像一般使用RGB色彩模式,即每个像素点的颜色由红®.绿(G).蓝(B)组成.RGB三个颜色通道的变化和叠加得到各种颜色,其中: R ...

  4. python数据分析及展示(一)

    一.IDE选择 Anaconda软件:开源免费,https://www.anaconda.com下载,根据系统进行安装.由于下载速度慢,可以去清华大学开源软件镜像站下载. Spyder软件设置:Too ...

  5. Python 神仙姐姐图像手绘效果实现

    文章目录 一.图像的 RGB 色彩模式 二.Python的 PIL 库 三.图像的数组表示 四.图像的变换 五.图像的手绘效果实现 一.图像的 RGB 色彩模式 图像一般使用 RGB 色彩模式,即每个 ...

  6. Python 数据分析与展示笔记2 -- 图像手绘效果

    Python 数据分析与展示笔记2 – 图像手绘效果 Python 数据分析与展示系列笔记是笔者学习.实践Python 数据分析与展示的相关笔记 课程链接: Python 数据分析与展示 参考文档: ...

  7. 嵩天《Python数据分析与展示》实例4:引力波的绘制

    这一部分讲解的是如何利用已有的数据文件绘制引力波图形,相关讲解见注释,数据文件分别为H1_Strain.wav.L1_Strain.wav.wf_template.txt,可从嵩天老师提供的网址下载: ...

  8. Python 数据分析与展示笔记3 -- Matplotlib 库基础

    Python 数据分析与展示笔记3 – Matplotlib 库基础 Python 数据分析与展示系列笔记是笔者学习.实践Python 数据分析与展示的相关笔记 课程链接: Python 数据分析与展 ...

  9. python绘制直方图的函数_(六)pyplot基础图表函数(学习笔记)|python数据分析与展示...

    1.pyplot基础图表函数概述 2.pyplot图饼的绘制 3.pyplot直方图的绘制 4.pyplot极坐标图的绘制 5.pyplot散点图的绘制 6.单元小结 [网页链接[Python数据分析 ...

  10. Python数据分析之展示-matplotlib2

    目录 Python数据分析之展示-matplotlib2 双轴图的画法 5.根据电影时长和电影评分绘制散点图 marker属性 6.绘制各个地区的评分箱型图 美国电影评分的箱线图 多组数据箱线图 通过 ...

最新文章

  1. asp.net MD5 加密
  2. 计算机视觉组队学习预告!提前进群
  3. Pytorch中的序列化容器-度消失和梯度爆炸-nn.Sequential-nn.BatchNorm1d-nn.Dropout
  4. sqlplus怎样将名次显示在表的后面_一分一段表怎么用?2019年辽宁高考一分一段表...
  5. GPU Gems翻译
  6. 【NLP傻瓜式教程】手把手带你CNN文本分类(附代码)
  7. 首选System.lineSeparator()以用Java编写系统相关的行分隔符字符串
  8. 搭建zookeeper集群环境详解
  9. ASP.NET Form Authentication安全漏洞及对策
  10. C++ 虚函数,纯虚函数,抽象类整理
  11. Vs2012使用strcpy出错之解决方法
  12. 多线程java_由浅入深地介绍Java多线程,让你如何快速进入Java多线程的学习
  13. ubuntu 安装 sublime
  14. 【御数·原创】数据治理的坑你遇到过几个?
  15. pcb天线和纯铜天线_PCB天线和FPC天线有怎样的特性
  16. oracle excel更新,excel表格的数据如何更新-如何将excel表格更新oracle数据库中数据...
  17. 修改android设备型号
  18. TA_Lib库指标中文说明
  19. RT-Thread Studio中使用DHT11软件包
  20. Adobe Photoshop CS5 12.0 Extend 绿色免安装版

热门文章

  1. 计算机ps一级知识点,2018年全国计算机一级Photoshop考什么内容?
  2. ENet-论文笔记-理解
  3. 淘宝直通车补单方法技巧 短期打造爆款
  4. libcef-框架架构中概念介绍-网络层(请求)-请求处理-请求拦截-代理解析(六)
  5. SaaS公司投资分析时,MRR比ARR指标更有用 | 投资人说
  6. wx小程序 解决子组件样式不起效
  7. 小技巧 - 如何下载微信公众号音频?(附:此方法可用于类似的Web)
  8. 如何压缩pdf文件 把pdf文件变小
  9. 学用计算机 关机,电脑关机命令是什么?快速关机必备(你学会了吗)
  10. 【MacOS】必备的常用快捷键