12
12
"""
13
13
14
14
import logging
15
- import textwrap
16
15
17
16
import numpy as np
18
17
28
27
29
28
_log = logging .getLogger (__name__ )
30
29
31
- _make_axes_kw_doc = """
30
+ _docstring .interpd .update (
31
+ _make_axes_kw_doc = """
32
32
location : None or {'left', 'right', 'top', 'bottom'}
33
33
The location, relative to the parent axes, where the colorbar axes
34
34
is created. It also determines the *orientation* of the colorbar
61
61
panchor : (float, float), or *False*, optional
62
62
The anchor point of the colorbar parent axes. If *False*, the parent
63
63
axes' anchor will be unchanged.
64
- Defaults to (1.0, 0.5) if vertical; (0.5, 0.0) if horizontal.
65
- """
66
-
67
- _colormap_kw_doc = """
64
+ Defaults to (1.0, 0.5) if vertical; (0.5, 0.0) if horizontal.""" ,
65
+ _colormap_kw_doc = """
68
66
extend : {'neither', 'both', 'min', 'max'}
69
67
Make pointed end(s) for out-of-range values (unless 'neither'). These are
70
68
set for a given colormap using the colormap set_under and set_over methods.
114
112
each region delimited by adjacent entries in *boundaries*, the color mapped
115
113
to the corresponding value in values will be used.
116
114
Normally only useful for indexed colors (i.e. ``norm=NoNorm()``) or other
117
- unusual circumstances.
118
- """
119
-
120
- _docstring .interpd .update (colorbar_doc = """
121
- Add a colorbar to a plot.
122
-
123
- Parameters
124
- ----------
125
- mappable
126
- The `matplotlib.cm.ScalarMappable` (i.e., `~matplotlib.image.AxesImage`,
127
- `~matplotlib.contour.ContourSet`, etc.) described by this colorbar.
128
- This argument is mandatory for the `.Figure.colorbar` method but optional
129
- for the `.pyplot.colorbar` function, which sets the default to the current
130
- image.
131
-
132
- Note that one can create a `.ScalarMappable` "on-the-fly" to generate
133
- colorbars not attached to a previously drawn artist, e.g. ::
134
-
135
- fig.colorbar(cm.ScalarMappable(norm=norm, cmap=cmap), ax=ax)
136
-
137
- cax : `~matplotlib.axes.Axes`, optional
138
- Axes into which the colorbar will be drawn.
139
-
140
- ax : `~matplotlib.axes.Axes`, list of Axes, optional
141
- One or more parent axes from which space for a new colorbar axes will be
142
- stolen, if *cax* is None. This has no effect if *cax* is set.
143
-
144
- use_gridspec : bool, optional
145
- If *cax* is ``None``, a new *cax* is created as an instance of Axes. If
146
- *ax* is an instance of Subplot and *use_gridspec* is ``True``, *cax* is
147
- created as an instance of Subplot using the :mod:`.gridspec` module.
148
-
149
- Returns
150
- -------
151
- colorbar : `~matplotlib.colorbar.Colorbar`
152
-
153
- Notes
154
- -----
155
- Additional keyword arguments are of two kinds:
156
-
157
- axes properties:
158
- %s
159
- colorbar properties:
160
- %s
161
-
162
- If *mappable* is a `~.contour.ContourSet`, its *extend* kwarg is included
163
- automatically.
164
-
165
- The *shrink* kwarg provides a simple way to scale the colorbar with respect
166
- to the axes. Note that if *cax* is specified, it determines the size of the
167
- colorbar and *shrink* and *aspect* kwargs are ignored.
168
-
169
- For more precise control, you can manually specify the positions of
170
- the axes objects in which the mappable and the colorbar are drawn. In
171
- this case, do not use any of the axes properties kwargs.
172
-
173
- It is known that some vector graphics viewers (svg and pdf) renders white gaps
174
- between segments of the colorbar. This is due to bugs in the viewers, not
175
- Matplotlib. As a workaround, the colorbar can be rendered with overlapping
176
- segments::
177
-
178
- cbar = colorbar()
179
- cbar.solids.set_edgecolor("face")
180
- draw()
181
-
182
- However this has negative consequences in other circumstances, e.g. with
183
- semi-transparent images (alpha < 1) and colorbar extensions; therefore, this
184
- workaround is not used by default (see issue #1188).
185
- """ % (textwrap .indent (_make_axes_kw_doc , " " ),
186
- textwrap .indent (_colormap_kw_doc , " " )))
115
+ unusual circumstances.""" )
187
116
188
117
189
118
def _set_ticks_on_axis_warn (* args , ** kwargs ):
@@ -267,7 +196,7 @@ def get_subplotspec(self):
267
196
return ss ()
268
197
269
198
270
- @_docstring .Substitution ( _colormap_kw_doc )
199
+ @_docstring .interpd
271
200
class Colorbar :
272
201
r"""
273
202
Draw a colorbar in an existing axes.
@@ -327,7 +256,7 @@ class Colorbar:
327
256
drawedges : bool
328
257
329
258
filled : bool
330
- %s
259
+ %(_colormap_kw_doc) s
331
260
"""
332
261
333
262
n_rasterize = 50 # rasterize solids if number of colors >= n_rasterize
@@ -1425,7 +1354,7 @@ def _normalize_location_orientation(location, orientation):
1425
1354
return loc_settings
1426
1355
1427
1356
1428
- @_docstring .Substitution ( _make_axes_kw_doc )
1357
+ @_docstring .interpd
1429
1358
def make_axes (parents , location = None , orientation = None , fraction = 0.15 ,
1430
1359
shrink = 1.0 , aspect = 20 , ** kwargs ):
1431
1360
"""
@@ -1438,7 +1367,7 @@ def make_axes(parents, location=None, orientation=None, fraction=0.15,
1438
1367
----------
1439
1368
parents : `~.axes.Axes` or list of `~.axes.Axes`
1440
1369
The Axes to use as parents for placing the colorbar.
1441
- %s
1370
+ %(_make_axes_kw_doc) s
1442
1371
1443
1372
Returns
1444
1373
-------
@@ -1527,7 +1456,7 @@ def make_axes(parents, location=None, orientation=None, fraction=0.15,
1527
1456
return cax , kwargs
1528
1457
1529
1458
1530
- @_docstring .Substitution ( _make_axes_kw_doc )
1459
+ @_docstring .interpd
1531
1460
def make_axes_gridspec (parent , * , location = None , orientation = None ,
1532
1461
fraction = 0.15 , shrink = 1.0 , aspect = 20 , ** kwargs ):
1533
1462
"""
@@ -1553,7 +1482,7 @@ def make_axes_gridspec(parent, *, location=None, orientation=None,
1553
1482
----------
1554
1483
parent : `~.axes.Axes`
1555
1484
The Axes to use as parent for placing the colorbar.
1556
- %s
1485
+ %(_make_axes_kw_doc) s
1557
1486
1558
1487
Returns
1559
1488
-------
0 commit comments