matplotlib.figure#
matplotlib.figure implements the following classes:
FigureTop level
Artist, which holds all plot elements. Many methods are implemented inFigureBase.SubFigureA logical figure inside a figure, usually added to a figure (or parent
SubFigure) withFigure.add_subfigureorFigure.subfiguresmethods.
Figures are typically created using pyplot methods figure,
subplots, and subplot_mosaic.
fig, ax = plt.subplots(figsize=(2, 2), facecolor='lightskyblue',
layout='constrained')
fig.suptitle('Figure')
ax.set_title('Axes', loc='left', fontstyle='oblique', fontsize='medium')
(Source code, 2x.png, png)
Some situations call for directly instantiating a Figure class,
usually inside an application of some sort (see Embedding Matplotlib in graphical user interfaces for a
list of examples) . More information about Figures can be found at
Introduction to Figures.
Figure#
Figure class#
The top level container for all the plot elements. |
Adding Axes and SubFigures#
Add an |
|
Add an |
|
Add a set of subplots to this figure. |
|
Build a layout of Axes based on ASCII art or nested lists. |
|
Low-level API for creating a |
|
List of Axes in the Figure. |
|
List of Axes in the Figure. |
|
Remove the |
|
Add a set of subfigures to this figure or subfigure. |
|
Add a |
Saving#
Save the current figure as an image or vector graphic to a file. |
Annotating#
Add a colorbar to a plot. |
|
Place a legend on the figure. |
|
Add text to figure. |
|
Add a centered super title to the figure. |
|
Return the suptitle as string or an empty string if not set. |
|
Add a centered super xlabel to the figure. |
|
Return the supxlabel as string or an empty string if not set. |
|
Add a centered super ylabel to the figure. |
|
Return the supylabel as string or an empty string if not set. |
|
Align the xlabels and ylabels of subplots with the same subplots row or column (respectively) if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the xlabels of subplots in the same subplot row if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the ylabels of subplots in the same subplot column if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the titles of subplots in the same subplot row if title alignment is being done automatically (i.e. the title position is not manually set). |
|
Date ticklabels often overlap, so it is useful to rotate them and right align them. |
Figure geometry#
Set the figure size in inches. |
|
Return the current size of the figure in inches. |
|
Set the height of the figure in inches. |
|
Return the figure height in inches. |
|
Set the width of the figure in inches. |
|
Return the figure width in inches. |
|
The resolution in dots per inch. |
|
Set the resolution of the figure in dots-per-inch. |
|
Return the resolution in dots per inch as a float. |
Subplot layout#
Adjust the subplot layout parameters. |
|
Set the layout engine for this figure. |
|
Discouraged or deprecated#
Adjust the padding between and around subplots. |
|
[Deprecated] Set whether and how |
|
Return whether |
|
[Deprecated] Set whether |
|
Return whether constrained layout is being used. |
|
[Deprecated] Set padding for |
|
[Deprecated] Get padding for |
Interactive#
See also
Blocking call to interact with a figure. |
|
Whenever the Axes state change, |
|
Blocking call to interact with the figure. |
|
Process a pick event. |
Modifying appearance#
Set the figure's background patch visibility, i.e. whether the figure background will be drawn. |
|
Return the figure's background patch visibility, i.e. whether the figure background will be drawn. |
|
Set the line width of the Figure rectangle. |
|
Get the line width of the Figure rectangle. |
|
Set the face color of the Figure rectangle. |
|
Get the face color of the Figure rectangle. |
|
Set the edge color of the Figure rectangle. |
|
Get the edge color of the Figure rectangle. |
Adding and getting Artists#
Add an |
|
Get a list of artists contained in the figure. |
|
Add a non-resampled image to the figure. |
Getting and modifying state#
See also
Clear the figure. |
|
Get the current Axes. |
|
Set the current Axes to be a and return a. |
|
Return a (tight) bounding box of the figure in inches. |
|
Get the artist's bounding box in display space, ignoring clipping. |
|
If using a GUI backend with pyplot, display the figure window. |
|
Set the canvas that contains the figure |
|
Draw the Artist (and its children) using the given renderer. |
|
Draw the figure with no output. |
|
Draw |
SubFigure#
Matplotlib has the concept of a SubFigure, which is a logical figure inside
a parent Figure. It has many of the same methods as the parent. See
Nested Axes layouts.
(Source code, 2x.png, png)
SubFigure class#
Logical figure that can be placed inside a figure. |
Adding Axes and SubFigures#
Add an |
|
Add an |
|
Add a set of subplots to this figure. |
|
Build a layout of Axes based on ASCII art or nested lists. |
|
Low-level API for creating a |
|
Remove the |
|
Add a |
|
Add a set of subfigures to this figure or subfigure. |
Annotating#
Add a colorbar to a plot. |
|
Place a legend on the figure. |
|
Add text to figure. |
|
Add a centered super title to the figure. |
|
Return the suptitle as string or an empty string if not set. |
|
Add a centered super xlabel to the figure. |
|
Return the supxlabel as string or an empty string if not set. |
|
Add a centered super ylabel to the figure. |
|
Return the supylabel as string or an empty string if not set. |
|
Align the xlabels and ylabels of subplots with the same subplots row or column (respectively) if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the xlabels of subplots in the same subplot row if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the ylabels of subplots in the same subplot column if label alignment is being done automatically (i.e. the label position is not manually set). |
|
Align the titles of subplots in the same subplot row if title alignment is being done automatically (i.e. the title position is not manually set). |
Adding and getting Artists#
Add an |
|
Get a list of artists contained in the figure. |
Modifying appearance#
Set the figure's background patch visibility, i.e. whether the figure background will be drawn. |
|
Return the figure's background patch visibility, i.e. whether the figure background will be drawn. |
|
Set the line width of the Figure rectangle. |
|
Get the line width of the Figure rectangle. |
|
Set the face color of the Figure rectangle. |
|
Get the face color of the Figure rectangle. |
|
Set the edge color of the Figure rectangle. |
|
Get the edge color of the Figure rectangle. |
Passthroughs#
Set the resolution of parent figure in dots-per-inch. |
|
Return the resolution of the parent figure in dots-per-inch as a float. |
FigureBase parent class#
- class matplotlib.figure.FigureBase(**kwargs)[source]#
Base class for
FigureandSubFigurecontaining the methods that add artists to the figure or subfigure, create Axes, etc.- add_artist(artist, clip=False)[source]#
Add an
Artistto the figure.Usually artists are added to
Axesobjects usingAxes.add_artist; this method can be used in the rare cases where one needs to add artists directly to the figure instead.
- add_axes(*args, **kwargs)[source]#
Add an
Axesto the figure.Call signatures:
add_axes(rect, projection=None, polar=False, **kwargs) add_axes(ax)
- Parameters:
- recttuple (left, bottom, width, height)
The dimensions (left, bottom, width, height) of the new
Axes. All quantities are in fractions of figure width and height.- projection{None, 'aitoff', 'hammer', 'lambert', 'mollweide', 'polar', 'rectilinear', str}, optional
The projection type of the
Axes. str is the name of a custom projection, seeprojections. The default None results in a 'rectilinear' projection.- polarbool, default: False
If True, equivalent to projection='polar'.
- axes_classsubclass type of
Axes, optional The
axes.Axessubclass that is instantiated. This parameter is incompatible with projection and polar. See axisartist for examples.- sharex, sharey
Axes, optional Share the x or y
axiswith sharex and/or sharey. The axis will have the same limits, ticks, and scale as the axis of the shared Axes.- labelstr
A label for the returned Axes.
- Returns:
Axes, or a subclass ofAxesThe returned Axes class depends on the projection used. It is
Axesif rectilinear projection is used andprojections.polar.PolarAxesif polar projection is used.
- Other Parameters:
- **kwargs
This method also takes the keyword arguments for the returned Axes class. The keyword arguments for the rectilinear Axes class
Axescan be found in the following table but there might also be other keyword arguments if another projection is used, see the actual Axes class.Property
Description
{'box', 'datalim'}
a filter function, which takes a (m, n, 3) float array and a dpi value, and returns a (m, n, 3) array and two offsets from the bottom left corner of the image
float or None
(float, float) or {'C', 'SW', 'S', 'SE', 'E', 'NE', ...}
bool
{'auto', 'equal'} or float
bool
unknown
unknown
Callable[[Axes, Renderer], Bbox]
bool or 'line'
float or None
BboxBaseor Nonebool
Patch or (Path, Transform) or None
bool or "auto"
bool
str
bool
object
bool
bool
unknown
list of
AbstractPathEffectNone or bool or float or callable
[left, bottom, width, height] or
Bboxfloat or None
bool
(scale: float, length: float, randomness: float)
bool or None
unknown
str
str
bool
(lower: float, upper: float)
unknown
str
(left: float, right: float)
float greater than -0.5
unknown
unknown
unknown
(lower: float, upper: float)
unknown
str
(bottom: float, top: float)
float greater than -0.5
unknown
unknown
unknown
float
Notes
In rare circumstances,
add_axesmay be called with a single argument, an Axes instance already created in the present figure but not in the figure's list of Axes.Examples
Some simple examples:
rect = l, b, w, h fig = plt.figure() fig.add_axes(rect) fig.add_axes(rect, frameon=False, facecolor='g') fig.add_axes(rect, polar=True) ax = fig.add_axes(rect, projection='polar') fig.delaxes(ax) fig.add_axes(ax)
- add_gridspec(nrows=1, ncols=1, **kwargs)[source]#
Low-level API for creating a
GridSpecthat has this figure as a parent.This is a low-level API, allowing you to create a gridspec and subsequently add subplots based on the gridspec. Most users do not need that freedom and should use the higher-level methods
subplotsorsubplot_mosaic.- Parameters:
- nrowsint, default: 1
Number of rows in grid.
- ncolsint, default: 1
Number of columns in grid.
- Returns:
- Other Parameters:
- **kwargs
Keyword arguments are passed to
GridSpec.
See also
Examples
Adding a subplot that spans two rows:
fig = plt.figure() gs = fig.add_gridspec(2, 2) ax1 = fig.add_subplot(gs[0, 0]) ax2 = fig.add_subplot(gs[1, 0]) # spans two rows: ax3 = fig.add_subplot(gs[:, 1])
- add_subfigure(subplotspec, **kwargs)[source]#
Add a
SubFigureto the figure as part of a subplot arrangement.- Parameters:
- subplotspec
gridspec.SubplotSpec Defines the region in a parent gridspec where the subfigure will be placed.
- subplotspec
- Returns:
- Other Parameters:
- **kwargs
Are passed to the
SubFigureobject.
See also
- add_subplot(*args, **kwargs)[source]#
Add an
Axesto the figure as part of a subplot arrangement.Call signatures:
add_subplot(nrows, ncols, index, **kwargs) add_subplot(pos, **kwargs) add_subplot(ax) add_subplot()
- Parameters:
- *argsint, (int, int, index), or
SubplotSpec, default: (1, 1, 1) The position of the subplot described by one of
Three integers (nrows, ncols, index). The subplot will take the index position on a grid with nrows rows and ncols columns. index starts at 1 in the upper left corner and increases to the right. index can also be a two-tuple specifying the (first, last) indices (1-based, and including last) of the subplot, e.g.,
fig.add_subplot(3, 1, (1, 2))makes a subplot that spans the upper 2/3 of the figure.A 3-digit integer. The digits are interpreted as if given separately as three single-digit integers, i.e.
fig.add_subplot(235)is the same asfig.add_subplot(2, 3, 5). Note that this can only be used if there are no more than 9 subplots.A
SubplotSpec.
In rare circumstances,
add_subplotmay be called with a single argument, a subplot Axes instance already created in the present figure but not in the figure's list of Axes.- projection{None, 'aitoff', 'hammer', 'lambert', 'mollweide', 'polar', 'rectilinear', str}, optional
The projection type of the subplot (
Axes). str is the name of a custom projection, seeprojections. The default None results in a 'rectilinear' projection.- polarbool, default: False
If True, equivalent to projection='polar'.
- axes_classsubclass type of
Axes, optional The
axes.Axessubclass that is instantiated. This parameter is incompatible with projection and polar. See axisartist for examples.- sharex, sharey
Axes, optional Share the x or y
axiswith sharex and/or sharey. The axis will have the same limits, ticks, and scale as the axis of the shared Axes.- labelstr
A label for the returned Axes.
- *argsint, (int, int, index), or
- Returns:
AxesThe Axes of the subplot. The returned Axes can actually be an instance of a subclass, such as
projections.polar.PolarAxesfor polar projections.
- Other Parameters:
- **kwargs
This method also takes the keyword arguments for the returned Axes base class; except for the figure argument. The keyword arguments for the rectilinear base class
Axescan be found in the following table but there might also be other keyword arguments if another projection is used.Property
Description
{'box', 'datalim'}
a filter function, which takes a (m, n, 3) float array and a dpi value, and returns a (m, n, 3) array and two offsets from the bottom left corner of the image
float or None
(float, float) or {'C', 'SW', 'S', 'SE', 'E', 'NE', ...}
bool
{'auto', 'equal'} or float
bool
unknown
unknown
Callable[[Axes, Renderer], Bbox]
bool or 'line'
float or None
BboxBaseor Nonebool
Patch or (Path, Transform) or None
bool or "auto"
bool
str
bool
object
bool
bool
unknown
list of
AbstractPathEffectNone or bool or float or callable
[left, bottom, width, height] or
Bboxfloat or None
bool
(scale: float, length: float, randomness: float)
bool or None
unknown
str
str
bool
(lower: float, upper: float)
unknown
str
(left: float, right: float)
float greater than -0.5
unknown
unknown
unknown
(lower: float, upper: float)
unknown
str
(bottom: float, top: float)
float greater than -0.5
unknown
unknown
unknown
float
Examples
fig = plt.figure() fig.add_subplot(231) ax1 = fig.add_subplot(2, 3, 1) # equivalent but more general fig.add_subplot(232, frameon=False) # subplot with no frame fig.add_subplot(233, projection='polar') # polar subplot fig.add_subplot(234, sharex=ax1) # subplot sharing x-axis with ax1 fig.add_subplot(235, facecolor="red") # red subplot ax1.remove() # delete ax1 from the figure fig.add_subplot(ax1) # add ax1 back to the figure
- align_labels(axs=None)[source]#
Align the xlabels and ylabels of subplots with the same subplots row or column (respectively) if label alignment is being done automatically (i.e. the label position is not manually set).
Alignment persists for draw events after this is called.
- Parameters:
See also
Notes
This assumes that all Axes in
axsare from the sameGridSpec, so that theirSubplotSpecpositions correspond to figure positions.
- align_titles(axs=None)[source]#
Align the titles of subplots in the same subplot row if title alignment is being done automatically (i.e. the title position is not manually set).
Alignment persists for draw events after this is called.
- Parameters:
See also
Notes
This assumes that all Axes in
axsare from the sameGridSpec, so that theirSubplotSpecpositions correspond to figure positions.Examples
Example with titles:
fig, axs = plt.subplots(1, 2) axs[0].set_aspect('equal') axs[0].set_title('Title 0') axs[1].set_title('Title 1') fig.align_titles()
- align_xlabels(axs=None)[source]#
Align the xlabels of subplots in the same subplot row if label alignment is being done automatically (i.e. the label position is not manually set).
Alignment persists for draw events after this is called.
If a label is on the bottom, it is aligned with labels on Axes that also have their label on the bottom and that have the same bottom-most subplot row. If the label is on the top, it is aligned with labels on Axes with the same top-most row.
- Parameters:
See also
Notes
This assumes that all Axes in
axsare from the sameGridSpec, so that theirSubplotSpecpositions correspond to figure positions.Examples
Example with rotated xtick labels:
fig, axs = plt.subplots(1, 2) axs[0].tick_params(axis='x', rotation=55) axs[0].set_xlabel('XLabel 0') axs[1].set_xlabel('XLabel 1') fig.align_xlabels()
- align_ylabels(axs=None)[source]#
Align the ylabels of subplots in the same subplot column if label alignment is being done automatically (i.e. the label position is not manually set).
Alignment persists for draw events after this is called.
If a label is on the left, it is aligned with labels on Axes that also have their label on the left and that have the same left-most subplot column. If the label is on the right, it is aligned with labels on Axes with the same right-most column.
- Parameters:
See also
Notes
This assumes that all Axes in
axsare from the sameGridSpec, so that theirSubplotSpecpositions correspond to figure positions.Examples
Example with large yticks labels:
fig, axs = plt.subplots(2, 1) axs[0].plot(np.arange(0, 1000, 50)) axs[0].set_ylabel('YLabel 0') axs[1].set_ylabel('YLabel 1') fig.align_ylabels()
- autofmt_xdate(bottom=0.2, rotation=30, ha='right', which='major')[source]#
Date ticklabels often overlap, so it is useful to rotate them and right align them. Also, a common use case is a number of subplots with shared x-axis where the x-axis is date data. The ticklabels are often long, and it helps to rotate them on the bottom subplot and turn them off on other subplots, as well as turn off xlabels.
- Parameters:
- bottomfloat, default: 0.2
The bottom of the subplots for
subplots_adjust.- rotationfloat, default: 30 degrees
The rotation angle of the xtick labels in degrees.
- ha{'left', 'center', 'right'}, default: 'right'
The horizontal alignment of the xticklabels.
- which{'major', 'minor', 'both'}, default: 'major'
Selects which ticklabels to rotate.
- clear(keep_observers=False)[source]#
Clear the figure.
- Parameters:
- keep_observersbool, default: False
Set keep_observers to True if, for example, a gui widget is tracking the Axes in the figure.
- clf(keep_observers=False)[source]#
[Discouraged] Alias for the
clear()method.Discouraged
The use of
clf()is discouraged. Useclear()instead.- Parameters:
- keep_observersbool, default: False
Set keep_observers to True if, for example, a gui widget is tracking the Axes in the figure.
- colorbar(mappable, cax=None, ax=None, use_gridspec=True, **kwargs)[source]#
Add a colorbar to a plot.
- Parameters:
- mappable
The
matplotlib.colorizer.ColorizingArtist(i.e.,AxesImage,ContourSet, etc.) described by this colorbar. This argument is mandatory for theFigure.colorbarmethod but optional for thepyplot.colorbarfunction, which sets the default to the current image.Note that one can create a
colorizer.ColorizingArtist"on-the-fly" to generate colorbars not attached to a previously drawn artist, e.g.cr = colorizer.Colorizer(norm=norm, cmap=cmap) fig.colorbar(colorizer.ColorizingArtist(cr), ax=ax)
- cax
Axes, optional Axes into which the colorbar will be drawn. If
None, then a new Axes is created and the space for it will be stolen from the Axes(s) specified in ax.- ax
Axesor iterable ornumpy.ndarrayof Axes, optional The one or more parent Axes from which space for a new colorbar Axes will be stolen. This parameter is only used if cax is not set.
Defaults to the Axes that contains the mappable used to create the colorbar.
- use_gridspecbool, optional
If cax is
None, a new cax is created as an instance of Axes. If ax is positioned with a subplotspec and use_gridspec isTrue, then cax is also positioned with a subplotspec.
- Returns:
- colorbar
Colorbar
- colorbar
- Other Parameters:
- locationNone or {'left', 'right', 'top', 'bottom'}
The location, relative to the parent Axes, where the colorbar Axes is created. It also determines the orientation of the colorbar (colorbars on the left and right are vertical, colorbars at the top and bottom are horizontal). If None, the location will come from the orientation if it is set (vertical colorbars on the right, horizontal ones at the bottom), or default to 'right' if orientation is unset.
- orientationNone or {'vertical', 'horizontal'}
The orientation of the colorbar. It is preferable to set the location of the colorbar, as that also determines the orientation; passing incompatible values for location and orientation raises an exception.
- fractionfloat, default: 0.15
Fraction of original Axes to use for colorbar.
- shrinkfloat, default: 1.0
Fraction by which to multiply the size of the colorbar.
- aspectfloat, default: 20
Ratio of long to short dimensions.
- padfloat, default: 0.05 if vertical, 0.15 if horizontal
Fraction of original Axes between colorbar and new image Axes.
- anchor(float, float), optional
The anchor point of the colorbar Axes. Defaults to (0.0, 0.5) if vertical; (0.5, 1.0) if horizontal.
- panchor(float, float), or False, optional
The anchor point of the colorbar parent Axes. If False, the parent axes' anchor will be unchanged. Defaults to (1.0, 0.5) if vertical; (0.5, 0.0) if horizontal.
- extend{'neither', 'both', 'min', 'max'}
Make pointed end(s) for out-of-range values (unless 'neither'). These are set for a given colormap using the colormap set_under and set_over methods.
- extendfrac{None, 'auto', length, lengths}
If set to None, both the minimum and maximum triangular colorbar extensions will have a length of 5% of the interior colorbar length (this is the default setting).
If set to 'auto', makes the triangular colorbar extensions the same lengths as the interior boxes (when spacing is set to 'uniform') or the same lengths as the respective adjacent interior boxes (when spacing is set to 'proportional').
If a scalar, indicates the length of both the minimum and maximum triangular colorbar extensions as a fraction of the interior colorbar length. A two-element sequence of fractions may also be given, indicating the lengths of the minimum and maximum colorbar extensions respectively as a fraction of the interior colorbar length.
- extendrectbool
If False the minimum and maximum colorbar extensions will be triangular (the default). If True the extensions will be rectangular.
- ticksNone or list of ticks or Locator
If None, ticks are determined automatically from the input.
- formatNone or str or Formatter
If None,
ScalarFormatteris used. Format strings, e.g.,"%4.2e"or"{x:.2e}", are supported. An alternativeFormattermay be given instead.- drawedgesbool
Whether to draw lines at color boundaries.
- labelstr
The label on the colorbar's long axis.
- boundaries, valuesNone or a sequence
If unset, the colormap will be displayed on a 0-1 scale. If sequences, values must have a length 1 less than boundaries. For each region delimited by adjacent entries in boundaries, the color mapped to the corresponding value in values will be used. The size of each region is determined by the spacing parameter. Normally only useful for indexed colors (i.e.
norm=NoNorm()) or other unusual circumstances.- spacing{'uniform', 'proportional'}
For discrete colorbars (
BoundaryNormor contours), 'uniform' gives each color the same space; 'proportional' makes the space proportional to the data interval.
Notes
If mappable is a
ContourSet, its extend kwarg is included automatically.The shrink kwarg provides a simple way to scale the colorbar with respect to the Axes. Note that if cax is specified, it determines the size of the colorbar, and shrink and aspect are ignored.
For more precise control, you can manually specify the positions of the axes objects in which the mappable and the colorbar are drawn. In this case, do not use any of the Axes properties kwargs.
It is known that some vector graphics viewers (svg and pdf) render white gaps between segments of the colorbar. This is due to bugs in the viewers, not Matplotlib. As a workaround, the colorbar can be rendered with overlapping segments:
cbar = colorbar() cbar.solids.set_edgecolor("face") draw()
However, this has negative consequences in other circumstances, e.g. with semi-transparent images (alpha < 1) and colorbar extensions; therefore, this workaround is not used by default (see issue #1188).
- contains(mouseevent)[source]#
Test whether the mouse event occurred on the figure.
- Returns:
- bool, {}
- draw(renderer)[source]#
Draw the Artist (and its children) using the given renderer.
This has no effect if the artist is not visible (
Artist.get_visiblereturns False).- Parameters:
- renderer
RendererBasesubclass.
- renderer
Notes
This method is overridden in the Artist subclasses.
- property figure#
The root
Figure. To get the parent of aSubFigure, use theget_figuremethod.
- property frameon#
Return the figure's background patch visibility, i.e. whether the figure background will be drawn. Equivalent to
Figure.patch.get_visible().
- gca()[source]#
Get the current Axes.
If there is currently no Axes on this Figure, a new one is created using
Figure.add_subplot. (To test whether there is currently an Axes on a Figure, check whetherfigure.axesis empty. To test whether there is currently a Figure on the pyplot figure stack, check whetherpyplot.get_fignums()is empty.)
- get_default_bbox_extra_artists()[source]#
Return a list of Artists typically used in
Figure.get_tightbbox.
- get_figure(root=None)[source]#
Return the
FigureorSubFigureinstance the (Sub)Figure belongs to.- Parameters:
- rootbool, default=True
If False, return the (Sub)Figure this artist is on. If True, return the root Figure for a nested tree of SubFigures.
Deprecated since version 3.10: From version 3.12 root will default to False.
- get_frameon()[source]#
Return the figure's background patch visibility, i.e. whether the figure background will be drawn. Equivalent to
Figure.patch.get_visible().
- get_tightbbox(renderer=None, *, bbox_extra_artists=None)[source]#
Return a (tight) bounding box of the figure in inches.
Note that
FigureBasediffers from all other artists, which return theirBboxin pixels.Artists that have
artist.set_in_layout(False)are not included in the bbox.- Parameters:
- renderer
RendererBasesubclass Renderer that will be used to draw the figures (i.e.
fig.canvas.get_renderer())- bbox_extra_artistslist of
ArtistorNone List of artists to include in the tight bounding box. If
None(default), then all artist children of each Axes are included in the tight bounding box.
- renderer
- Returns:
BboxBasecontaining the bounding box (in figure inches).
- get_window_extent(renderer=None)[source]#
Get the artist's bounding box in display space, ignoring clipping.
The bounding box's width and height are non-negative.
Subclasses should override for inclusion in the bounding box "tight" calculation. Default is to return an empty bounding box at 0, 0.
Warning
The extent can change due to any changes in the transform stack, such as changing the Axes limits, the figure size, the canvas used (as is done when saving a figure), or the DPI.
Relying on a once-retrieved window extent can lead to unexpected behavior in various cases such as interactive figures being resized or moved to a screen with different dpi, or figures that look fine on screen render incorrectly when saved to file.
To get accurate results you may need to manually call
savefigordraw_without_renderingto have Matplotlib compute the rendered size.- Parameters:
- renderer
RendererBase, optional Renderer used to draw the figure (i.e.
fig.canvas.get_renderer()).
- renderer
See also
Artist.get_tightbboxGet the artist bounding box, taking clipping into account.