一、概述
1. matplotlib的三层api
matplotlib的原理或者说基础逻辑是,用Artist对象在画布(canvas)上绘制(Render)图形。
就和人作画的步骤类似:
- 准备一块画布或画纸
- 准备好颜料、画笔等制图工具
- 作画
所以matplotlib有三个层次的API:
matplotlib.backend_bases.FigureCanvas
代表了绘图区,所有的图像都是在绘图区完成的matplotlib.backend_bases.Renderer
代表了渲染器,可以近似理解为画笔,控制如何在 FigureCanvas 上画图。matplotlib.artist.Artist
代表了具体的图表组件,即调用了Renderer的接口在Canvas上作图。
前两者处理程序和计算机的底层交互的事项,第三项Artist就是具体的调用接口来做出我们想要的图,比如图形、文本、线条的设定。所以通常来说,我们95%的时间,都是用来和matplotlib.artist.Artist类打交道的。
2. Artist的分类
Artist有两种类型:primitives
和containers
。primitive
是基本要素,它包含一些我们要在绘图区作图用到的标准图形对象,如曲线Line2D,文字text,矩形Rectangle,图像image等。container
是容器,即用来装基本要素的地方,包括图形figure、坐标系Axes和坐标轴Axis。
3. matplotlib标准用法
matplotlib的标准使用流程为:
- 创建一个
Figure
实例 - 使用
Figure
实例创建一个或者多个Axes
或Subplot
实例 - 使用
Axes
实例的辅助方法来创建primitive
值得一提的是,Axes是一种容器,它可能是matplotlib API中最重要的类,并且我们大多数时间都花在和它打交道上。更具体的信息会在之后容器小节说明。
二、自定义你的Artist对象
1. Artist属性
在图形中的每一个元素都对应着一个matplotlib Artist
,且都有其对应的配置属性列表。
Figure
本身包含一个Rectangle,Rectangle的大小就是Figure的大小;你可以用来设置Figure的背景色和透明度。
每个Axes
边界框(默认白底黑边),也有一个Rectangle,通过它可以设置Axes的颜色、透明度等。
这些实例都存储在成员变量(member variables) Figure.patch
和 Axes.patch
中。 (Patch是一个来源于MATLAB的名词,它是图形上颜色的一个2D补丁,包含rectangels-矩形,circles-圆 和 plygons-多边形)
换个表达方式:
Figure.patch属性:是一个Rectangle,代表了图表的矩形框,它的大小就是图表的大小, 并且可以通过它设置figure的背景色和透明度。
Axes.patch属性:也是一个Rectangle,代表了绘图坐标轴内部的矩形框(白底黑边), 通过它可以设置Axes的颜色、透明度等。
每个matplotlib Artist
都有以下属性:
.alpha
属性:透明度。值为0—1之间的浮点数.axes
属性:返回这个Artist所属的axes,可能为None.figure
属性:该Artist所属的Figure,可能为None.label
:一个text label.visible
:布尔值,控制Artist是否绘制
三、基本元素 - primitives
现在我们知道了如何检查和设置给定对象的属性,我们还需要知道如何获取该对象。
前文介绍到,Artist
包含两种对象:基本要素-primitives
和 容器-containers
。primitives
是基本要素,它包含一些我们要在绘图区作图用到的标准图形对象,如曲线Line2D,文本text,矩形Rectangle,图像image等。container
是容器,即用来装基本要素的地方,包括图形figure、坐标系Axes和坐标轴Axis。
本章重点介绍下 primitives
的几种类型:曲线-Line2D,矩形-Rectangle,图像-image (其中文本-Text较为复杂,会在之后单独详细说明。)
1. 2DLines
在matplotlib中曲线的绘制,主要是通过类 matplotlib.lines.Line2D
来完成的。
它的基类: matplotlib.artist.Artist
matplotlib中线-line
的含义:它表示的可以是连接所有顶点的实线样式,也可以是每个顶点的标记。此外,这条线也会受到绘画风格的影响。
其中常用的的参数有:
- xdata:需要绘制的line中点的在x轴上的取值,若忽略,则默认为range(1,len(ydata)+1)
- ydata:需要绘制的line中点的在y轴上的取值
- linewidth:线条的宽度
- linestyle:线型
- color:线条的颜色
- marker:点的标记,详细可参考markers API 2
- markersize:标记的size
2. patches
matplotlib.patches.Patch类是二维图形类。它的基类是matplotlib.artist.Artist,它的构造函数:
详细清单见 matplotlib.patches API