演示Axes Divider

轴分割器用于计算轴的位置,并使用现有轴实例为它们创建分隔线。

演示Axes Divider示例

  1. import matplotlib.pyplot as plt
  2. def get_demo_image():
  3. import numpy as np
  4. from matplotlib.cbook import get_sample_data
  5. f = get_sample_data("axes_grid/bivariate_normal.npy", asfileobj=False)
  6. z = np.load(f)
  7. # z is a numpy array of 15x15
  8. return z, (-3, 4, -4, 3)
  9. def demo_simple_image(ax):
  10. Z, extent = get_demo_image()
  11. im = ax.imshow(Z, extent=extent, interpolation="nearest")
  12. cb = plt.colorbar(im)
  13. plt.setp(cb.ax.get_yticklabels(), visible=False)
  14. def demo_locatable_axes_hard(fig1):
  15. from mpl_toolkits.axes_grid1 import SubplotDivider, Size
  16. from mpl_toolkits.axes_grid1.mpl_axes import Axes
  17. divider = SubplotDivider(fig1, 2, 2, 2, aspect=True)
  18. # axes for image
  19. ax = Axes(fig1, divider.get_position())
  20. # axes for colorbar
  21. ax_cb = Axes(fig1, divider.get_position())
  22. h = [Size.AxesX(ax), # main axes
  23. Size.Fixed(0.05), # padding, 0.1 inch
  24. Size.Fixed(0.2), # colorbar, 0.3 inch
  25. ]
  26. v = [Size.AxesY(ax)]
  27. divider.set_horizontal(h)
  28. divider.set_vertical(v)
  29. ax.set_axes_locator(divider.new_locator(nx=0, ny=0))
  30. ax_cb.set_axes_locator(divider.new_locator(nx=2, ny=0))
  31. fig1.add_axes(ax)
  32. fig1.add_axes(ax_cb)
  33. ax_cb.axis["left"].toggle(all=False)
  34. ax_cb.axis["right"].toggle(ticks=True)
  35. Z, extent = get_demo_image()
  36. im = ax.imshow(Z, extent=extent, interpolation="nearest")
  37. plt.colorbar(im, cax=ax_cb)
  38. plt.setp(ax_cb.get_yticklabels(), visible=False)
  39. def demo_locatable_axes_easy(ax):
  40. from mpl_toolkits.axes_grid1 import make_axes_locatable
  41. divider = make_axes_locatable(ax)
  42. ax_cb = divider.new_horizontal(size="5%", pad=0.05)
  43. fig1 = ax.get_figure()
  44. fig1.add_axes(ax_cb)
  45. Z, extent = get_demo_image()
  46. im = ax.imshow(Z, extent=extent, interpolation="nearest")
  47. plt.colorbar(im, cax=ax_cb)
  48. ax_cb.yaxis.tick_right()
  49. ax_cb.yaxis.set_tick_params(labelright=False)
  50. def demo_images_side_by_side(ax):
  51. from mpl_toolkits.axes_grid1 import make_axes_locatable
  52. divider = make_axes_locatable(ax)
  53. Z, extent = get_demo_image()
  54. ax2 = divider.new_horizontal(size="100%", pad=0.05)
  55. fig1 = ax.get_figure()
  56. fig1.add_axes(ax2)
  57. ax.imshow(Z, extent=extent, interpolation="nearest")
  58. ax2.imshow(Z, extent=extent, interpolation="nearest")
  59. ax2.yaxis.set_tick_params(labelleft=False)
  60. def demo():
  61. fig1 = plt.figure(1, (6, 6))
  62. fig1.clf()
  63. # PLOT 1
  64. # simple image & colorbar
  65. ax = fig1.add_subplot(2, 2, 1)
  66. demo_simple_image(ax)
  67. # PLOT 2
  68. # image and colorbar whose location is adjusted in the drawing time.
  69. # a hard way
  70. demo_locatable_axes_hard(fig1)
  71. # PLOT 3
  72. # image and colorbar whose location is adjusted in the drawing time.
  73. # a easy way
  74. ax = fig1.add_subplot(2, 2, 3)
  75. demo_locatable_axes_easy(ax)
  76. # PLOT 4
  77. # two images side by side with fixed padding.
  78. ax = fig1.add_subplot(2, 2, 4)
  79. demo_images_side_by_side(ax)
  80. plt.show()
  81. demo()

下载这个示例