1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
| import matplotlib.pyplot as plt
def get_demo_image(): import numpy as np from matplotlib.cbook import get_sample_data f = get_sample_data("axes_grid/bivariate_normal.npy", asfileobj=False) z = np.load(f) return z, (-3, 4, -4, 3)
def demo_simple_image(ax): Z, extent = get_demo_image()
im = ax.imshow(Z, extent=extent, interpolation="nearest") cb = plt.colorbar(im) plt.setp(cb.ax.get_yticklabels(), visible=False)
def demo_locatable_axes_hard(fig1):
from mpl_toolkits.axes_grid1 import SubplotDivider, Size from mpl_toolkits.axes_grid1.mpl_axes import Axes
divider = SubplotDivider(fig1, 2, 2, 2, aspect=True)
ax = Axes(fig1, divider.get_position())
ax_cb = Axes(fig1, divider.get_position())
h = [Size.AxesX(ax), Size.Fixed(0.05), Size.Fixed(0.2), ]
v = [Size.AxesY(ax)]
divider.set_horizontal(h) divider.set_vertical(v)
ax.set_axes_locator(divider.new_locator(nx=0, ny=0)) ax_cb.set_axes_locator(divider.new_locator(nx=2, ny=0))
fig1.add_axes(ax) fig1.add_axes(ax_cb)
ax_cb.axis["left"].toggle(all=False) ax_cb.axis["right"].toggle(ticks=True)
Z, extent = get_demo_image()
im = ax.imshow(Z, extent=extent, interpolation="nearest") plt.colorbar(im, cax=ax_cb) plt.setp(ax_cb.get_yticklabels(), visible=False)
def demo_locatable_axes_easy(ax): from mpl_toolkits.axes_grid1 import make_axes_locatable
divider = make_axes_locatable(ax)
ax_cb = divider.new_horizontal(size="5%", pad=0.05) fig1 = ax.get_figure() fig1.add_axes(ax_cb)
Z, extent = get_demo_image() im = ax.imshow(Z, extent=extent, interpolation="nearest")
plt.colorbar(im, cax=ax_cb) ax_cb.yaxis.tick_right() ax_cb.yaxis.set_tick_params(labelright=False)
def demo_images_side_by_side(ax): from mpl_toolkits.axes_grid1 import make_axes_locatable
divider = make_axes_locatable(ax)
Z, extent = get_demo_image() ax2 = divider.new_horizontal(size="100%", pad=0.05) fig1 = ax.get_figure() fig1.add_axes(ax2)
ax.imshow(Z, extent=extent, interpolation="nearest") ax2.imshow(Z, extent=extent, interpolation="nearest") ax2.yaxis.set_tick_params(labelleft=False)
def demo():
fig1 = plt.figure(1, (6, 6)) fig1.clf()
ax = fig1.add_subplot(2, 2, 1) demo_simple_image(ax)
demo_locatable_axes_hard(fig1)
ax = fig1.add_subplot(2, 2, 3) demo_locatable_axes_easy(ax)
ax = fig1.add_subplot(2, 2, 4) demo_images_side_by_side(ax)
plt.show()
demo()
|