经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
Python?matplotlib的spines模块实例详解
来源:jb51  时间:2022/8/2 18:46:42  对本文有异议

spines 模块详解

matplotlib 设计了一个 spines模块,用于在创建 axes 时生成 Spine对象(坐标轴线)。

spines模块定义了一个 Spine 类,为类定义了 25 个方法,其中有 3 个是 classmethod。

Spine 类

Spine 类的定义

一个 axis spine – 标注数据区域边界的 line。

Spines 是连接 axis tick 标记的直线,并且标注数据区域的边界。可以通过 set_position 将它放置在任意的位置。

默认的位置是:('outward', 0)

Spines 是 Patch的子类,并且继承了Patch的大多数行为。

Spines 绘制 a line, a circle, 或者 an arc,取决于调用了 set_patch_line, set_patch_circle, or set_patch_arc 中的哪一个。默认是 Line。

  1. class matplotlib.spines.Spine(axes, spine_type, path, **kwargs)

基类:matplotlib.patches.Patch

Spine 类参数

axesAxes

容纳该 Spine 的 Axes 实例。

spine_type

str, spine 的类型,‘left’/‘right’/‘top’/‘bottom’/‘circle’。

spine 的类型分为两大类:

  • 直线型的,包括 ‘left’/‘right’/‘top’/‘bottom’;
  • ‘circle’ 类型, 包括 arc, circle;

path

用于绘制该 spine 的 Path 实例。

注意:

  • Spine 本质就是一条线。用于连接 axis 的 tick,并标记数据区域。
  • Spine 首先是为 _axes 子包在创建 Axes 时提供创建 axis spine 的工具。
  • 更重要的用途是提供了一系列方法供一般用户设置、控制 axes 的 axis spines 的外观和行为。
  • 为 axes 创建附加的 axis,或称之为"寄生轴"提供工具。

我们只能设置让 Axes 的默认 axis Spines 不可见,不能真的删除 axes 自动创建的 axis spines 对象。

创建 Spine 对象的实例

实例化 matplotlib.spines.Spine 类即创建一个 Spine 对象,axes, spine_type, path 是必需参数。

spine_type'left'/'right'/'top'/'bottom'之一,即直线类型时, path 只能是两个 vertices。理由很简单,两点决定一条直线。

直线类型的 spine 默认的长度由 axes 的数据边界决定。

创建直线型 Spine 并添加到 axes

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(6.4,4.8))
  7. ax = plt.axes(polar=False)
  8.  
  9. x = np.linspace(-1, 1., 100)
  10. ax.plot(x, np.sin(x*np.pi))
  11.  
  12. path = Path([(0,0),(0.2,0.0)]) #两个顶点的 path,
  13. # 否则会出发声明错误 AssertionError: unexpected vertices shape
  14. spine = Spine(ax, 'right',path)
  15. spine.set_color('r')
  16.  
  17. ax.add_patch(spine)
  18.  
  19. plt.savefig('spines131.png',facecolor='w')
  20.  
  21. plt.show()

spine_type=‘circle’

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(6.4,4.8))
  7. ax = plt.axes(polar=False)
  8.  
  9. x = np.linspace(-1, 1., 100)
  10. ax.plot(x, np.sin(x*np.pi))
  11.  
  12. path = Path([(-0.75,-0.75),(-0.25,0.5),(0.2,0.05),(0,-0.25)])
  13.  
  14. # path 的 vertices >=3 时,spine_type 只能是 'circle'
  15. spine = Spine(ax, 'circle',path)
  16. spine.set_color('r')
  17.  
  18. #set_patch_arc(self, center, radius, theta1, theta2)
  19. #set_patch_circle(self, center, radius)
  20.  
  21. #set_patch_arc, circle, 的参数会覆盖 path 的参数定义
  22. spine.set_patch_arc((0.25,0.25),0.4,15,75)
  23.  
  24. ax.add_patch(spine)
  25.  
  26. plt.savefig('spines132.png',facecolor='w')
  27.  
  28. plt.show()

默认的 Spine 对象的存储和调用

在 matplotlib, 创建 axes 时自动创建的 spines 被保存在一个 OrderDict 中。即使设置 axis 不可见,axes.Spines 对象依然存在。

Axes 的 projection 不同, OrderDict 的 keys 也不同:

  • 笛卡尔坐标系的 OrderDict.keys() = odict_keys([‘left’, ‘right’, ‘bottom’, ‘top’])
  • polar 坐标系的 OrderDict.keys() = odict_keys([‘polar’, ‘start’, ‘end’, ‘inner’])

在matplotlib的图中,可以通过ax = plt.gca()方法获取figureaxes对象,gca‘get current axes’的缩写。axes默认有四个 Spine对象,两个横轴和两个竖轴,分别是 top、bottom、left、right

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3.  
  4. fig = plt.figure(figsize=(9.6,4.8))
  5.  
  6. ax = plt.subplot(121)
  7. ax = plt.subplot(122, projection='polar')
  8.  
  9. N = 100
  10. theta = np.linspace(0.0, 2 * np.pi, N, endpoint=True)
  11.  
  12. ax.plot(theta,theta/6,'--',lw=2)
  13. ax.plot(theta,theta/6,'--',lw=2)
  14.  
  15. print(plt.gca()) #返回当前 axes,如果需要则创建一个
  16.  
  17. print(ax.spines.keys())
  18. print(ax.spines.keys())
  19.  
  20. plt.savefig('spines21.png',facecolor='w',dpi=200)
  21. plt.show()
  1. PolarAxesSubplot(0.547727,0.125;0.352273x0.755)
  2. odict_keys(['left', 'right', 'bottom', 'top'])
  3. odict_keys(['polar', 'start', 'end', 'inner'])

  1. print(ax.spines)
  1. OrderedDict([('left', <matplotlib.spines.Spine object at 0x000001C6228F11C0>), ('right', <matplotlib.spines.Spine object at 0x000001C6228F1C40>), ('bottom', <matplotlib.spines.Spine object at 0x000001C6228F1BB0>), ('top', <matplotlib.spines.Spine object at 0x000001C6228E7F10>)])

可以通过 axes.Spines['key'] 来获取 axes.spines 中的单个对象,并设置它的属性。

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(6.4,4.8))
  7. ax = plt.axes(polar=False)
  8.  
  9. x = np.linspace(-1, 1., 100)
  10. ax.plot(x, np.sin(x*np.pi))
  11.  
  12. ax.spines['left'].set_color('r') #left's Spine 设置为红色
  13. ax.spines['left'].set_linewidth(5) #left's 线宽
  14. ax.spines['top'].set_visible(False) #top's Spine 不可见
  15.  
  16. print(ax.spines['bottom']) # axes.spines['key']返回的是 Spine 实例
  17.  
  18. plt.savefig('spines22.png',facecolor='w')
  19.  
  20. plt.show()

Spine

Spine 对象的方法

对于一般用户,最重要的就是 spine.set_方法:

  • set_position()
  • set_color()
  • set_bounds()
  • set_patch_arc()
  • set_patch_circle()
  • set_pathc_line()

set_position(self, position)

设置 spine 对象的位置。

position 通过 (position type, amount) 元组定义。

position types 有:

  • ‘outward’: 将 spine 从数据区移出指定的点数。(负值是指 spine inwards。)
  • ‘axes’: 将 spine 放到定义的 Axes 坐标系中,(0, 1)
  • ‘data’: 将 spine 放到定义的 data 坐标系中。

此外,速记符号定义了特殊的位置:

  • ‘center’ -> (‘axes’, 0.5)
  • ‘zero’ -> (‘data’, 0.0)

移动 axis 到 (0, 0) 位置

  1. aimport matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(9.6,4.8))
  7.  
  8. ax = plt.subplot(121)
  9. ax2 = plt.subplot(122)
  10.  
  11.  
  12. x = np.linspace(-1, 1., 100)
  13. ax.plot(x, np.sin(x*np.pi))
  14. ax2.plot(x, np.sin(x*np.pi),c='r')
  15.  
  16. # 移动 left 和 bottom spines 到 (0,0) 位置
  17. ax.spines["left"].set_position(("data", 0))
  18. ax.spines["bottom"].set_position(("data", 0))
  19. # 隐藏 top 和 right spines.
  20. ax.spines["top"].set_visible(False)
  21. ax.spines["right"].set_visible(False)
  22.  
  23. ax.plot(1, 0, ">k", transform=ax.get_yaxis_transform(), clip_on=False)
  24. ax.plot(0, 1, "^k", transform=ax.get_xaxis_transform(), clip_on=False)
  25.  
  26. plt.savefig('spines32.png',facecolor='w')
  27.  
  28. plt.show()

set_bounds()

  1. set_bounds(*self*, *low=None*, *high=None*)

设置 spine 的边界。

Parameters:

low

float or None, optional

spine 的下界。传递 None,保留原 limit 不改变。

也可以在第一个位置参数传递 (low, high) tuple.

high

float or None, optional

spine 的上界。传递 None,保留原 limit 不改变。

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3.  
  4. np.random.seed(19680801)
  5.  
  6. x = np.linspace(0, 2*np.pi, 50)
  7. y = np.sin(x)
  8.  
  9. fig, ax = plt.subplots()
  10. ax.plot(x, y)
  11.  
  12. ax.set_xlim((0, 2*np.pi))
  13. ax.set_xticks([0, np.pi, 2*np.pi])
  14. ax.set_xticklabels(['0', r'$\pi$', r'2$\pi$'])
  15. ax.set_ylim((-1.5, 1.5))
  16. ax.set_yticks([-1, 0, 1])
  17.  
  18. ax.spines['left'].set_bounds((-1, 1))
  19.  
  20. ax.spines['right'].set_visible(False)
  21. ax.spines['top'].set_visible(False)
  22.  
  23. ax.yaxis.set_ticks_position('left')
  24. ax.xaxis.set_ticks_position('bottom')
  25.  
  26. plt.savefig('spines33.png',facecolor='w')
  27.  
  28. plt.show()

用法示例

创建多个 yaxis

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5. import random
  6.  
  7.  
  8. fig, host = plt.subplots(figsize=(6.4,4.8),tight_layout=True)
  9. parasite1 = host.twinx()
  10. parasite2 = host.twinx()
  11.  
  12. x = np.arange(0, 3,0.25)
  13.  
  14. parasite2.spines["right"].set_position(("axes", 1.2))
  15.  
  16. parasite2.spines["right"].set_visible(True)
  17.  
  18. p1, = host.plot(x, x*np.sin(x), "b-")
  19. p2, = parasite1.plot(x, x**2*np.sin(x), "r--")
  20. p3, = parasite2.plot(x, x*np.sin(x)*25, "g-.")
  21.  
  22.  
  23. host.set_xlim(0, 2)
  24. host.set_ylim(0, 2)
  25. parasite1.set_ylim(0, 4)
  26. parasite2.set_ylim(1, 65)
  27.  
  28.  
  29. tkw = dict(size=4, width=1.5)
  30. host.tick_params(axis='y', colors=p1.get_color(),**tkw)
  31. parasite1.tick_params(axis='y', colors=p2.get_color(),**tkw)
  32. parasite2.tick_params(axis='y', colors=p3.get_color(),**tkw)
  33. host.tick_params(axis='x',**tkw)
  34.  
  35. plt.savefig('spines41.png',facecolor='w')
  36.  
  37. plt.show()

偏移 axis

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(9.6,4.8))
  7.  
  8. # 灰色的矩形区域是 Axes 区域
  9. ax = plt.subplot(121,facecolor=[0.85,0.85,0.85])
  10. ax2 = plt.subplot(122,facecolor=[0.85,0.85,0.85])
  11.  
  12. x = np.linspace(-1, 1., 100)
  13. ax.plot(x, np.sin(x*np.pi))
  14. ax2.plot(x, np.sin(x*np.pi),c='r')
  15.  
  16. # 偏移 ax 的 left 和 bottom spines outward 20 points
  17. # 默认的 axis 是紧贴 axes 的
  18. ax.spines['left'].set_position(('outward', 20))
  19. ax.spines['bottom'].set_position(('outward', 20))
  20.  
  21. ax.spines['right'].set_visible(False)
  22. ax.spines['top'].set_visible(False)
  23.  
  24. ax.yaxis.set_ticks_position('left')
  25. ax.xaxis.set_ticks_position('bottom')
  26.  
  27. plt.savefig('spines42.png',facecolor='w')
  28.  
  29. plt.show()

多 vertices 的 path

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. from matplotlib.path import Path
  4. from matplotlib.spines import Spine
  5.  
  6. fig = plt.figure(figsize=(6.4,4.8))
  7. ax = plt.axes(polar=False)
  8.  
  9. path_data = [
  10. (0.018, -0.11),
  11. (-0.031, -0.051),
  12. (-0.115, 0.073),
  13. (-0.03, 0.073),
  14. (-0.011, 0.039),
  15. (0.043, 0.121),
  16. (0.075, -0.005),
  17. (0.035, -0.027),
  18. (0.018, -0.11)]
  19.  
  20. path = Path(path_data)
  21.  
  22. x = np.linspace(-1, 1., 100)
  23. ax.plot(x, np.sin(x*np.pi)/7)
  24.  
  25. spine = Spine(ax, spine_type='circle', path=path)
  26.  
  27. ax.add_patch(spine)
  28. spine.set_color('r')
  29. spine.register_axis(ax.xaxis)
  30.  
  31. plt.savefig('spine43.png',facecolor='w')
  32.  
  33. plt.show()

axis 是连接 ticks 的线,我们已经可以控制 axis 的 spine,下一篇开始将讨论 ticks 对象。

总结

到此这篇关于Python matplotlib的spines模块的文章就介绍到这了,更多相关matplotlib spines模块详解内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号