##// END OF EJS Templates
Refining the matplotlib APIs in IPython.display.
Brian E. Granger -
Show More
@@ -24,7 +24,7 b' import struct'
24
24
25 from IPython.utils.py3compat import (string_types, cast_bytes_py2, cast_unicode,
25 from IPython.utils.py3compat import (string_types, cast_bytes_py2, cast_unicode,
26 unicode_type)
26 unicode_type)
27
27 from IPython.testing.skipdoctest import skip_doctest
28 from .displaypub import publish_display_data
28 from .displaypub import publish_display_data
29
29
30 #-----------------------------------------------------------------------------
30 #-----------------------------------------------------------------------------
@@ -719,18 +719,53 b' def clear_output(wait=False):'
719 io.stderr.flush()
719 io.stderr.flush()
720
720
721
721
722 def select_matplotlib_formats(formats, quality=90):
722 @skip_doctest
723 """Select figure formats for the inline backend.
723 def set_matplotlib_formats(*formats, **kwargs):
724 """Select figure formats for the inline backend. Optionally pass quality for JPEG.
725
726 For example, this enables PNG and JPEG output with a JPEG quality of 90%::
727
728 In [1]: set_matplotlib_formats('png', 'jpeg', quality=90)
729
730 To set this in your config files use the following::
731
732 c.InlineBackend.figure_formats = {'pdf', 'png', 'svg'}
724
733
725 Parameters
734 Parameters
726 ==========
735 ----------
727 formats : list
736 *formats : list, tuple
728 One or a set of figure formats to enable: 'png', 'retina', 'jpeg', 'svg', 'pdf'.
737 One or a set of figure formats to enable: 'png', 'retina', 'jpeg', 'svg', 'pdf'.
729 quality : int
738 quality : int
730 A percentage for the quality of JPEG figures.
739 A percentage for the quality of JPEG figures. Defaults to 90.
731 """
740 """
732 from IPython.core.interactiveshell import InteractiveShell
741 from IPython.core.interactiveshell import InteractiveShell
733 from IPython.core.pylabtools import select_figure_formats
742 from IPython.core.pylabtools import select_figure_formats
734 shell = InteractiveShell.instance()
743 shell = InteractiveShell.instance()
735 select_figure_formats(shell, formats, quality=90)
744 select_figure_formats(shell, formats, quality=90)
736
745
746 @skip_doctest
747 def set_matplotlib_close(close):
748 """Should the inline backend close all figures automatically.
749
750 By default, the inline backend used in the IPython Notebook will close all
751 matplotlib figures automatically after each cell is run. This means that
752 plots in different cells won't interfere. Sometimes, you may want to make
753 a plot in one cell and then refine it in later cells. This can be accomplished
754 by::
755
756 In [1]: set_matplotlib_close(False)
757
758 To set this in your config files use the following::
759
760 c.InlineBackend.close_figures = False
761
762 Parameters
763 ----------
764 close : bool
765 Should all matplotlib figures be automatically closed after each cell is
766 run?
767 """
768 from IPython.kernel.zmq.pylab.backend_inline import InlineBackend
769 ilbe = InlineBackend.instance()
770 ilbe.close_figures = close
771
@@ -47,28 +47,32 b' class PylabMagics(Magics):'
47 """Set up matplotlib to work interactively.
47 """Set up matplotlib to work interactively.
48
48
49 This function lets you activate matplotlib interactive support
49 This function lets you activate matplotlib interactive support
50 at any point during an IPython session.
50 at any point during an IPython session. It does not import anything
51 It does not import anything into the interactive namespace.
51 into the interactive namespace.
52
52
53 If you are using the inline matplotlib backend for embedded figures,
53 If you are using the inline matplotlib backend in the IPython Notebook
54 you can adjust its behavior via the %config magic::
54 you can set which figure formats are enabled using the following::
55
55
56 # enable SVG figures, necessary for SVG+XHTML export in the qtconsole
56 In [1]: from IPython.display import set_matplotlib_formats
57 In [1]: %config InlineBackend.figure_format = 'svg'
58
57
59 # change the behavior of closing all figures at the end of each
58 In [2]: set_matplotlib_formats('pdf', 'svg')
60 # execution (cell), or allowing reuse of active figures across
59
61 # cells:
60 See the docstring of `IPython.display.set_matplotlib_formats` and
62 In [2]: %config InlineBackend.close_figures = False
61 `IPython.display.set_matplotlib_close` for more information on
62 changing the behavior of the inline backend.
63
63
64 Examples
64 Examples
65 --------
65 --------
66 In this case, where the MPL default is TkAgg::
66 To enable the inline backend for usage with the IPython Notebook::
67
68 In [1]: %matplotlib inline
69
70 In this case, where the matplotlib default is TkAgg::
67
71
68 In [2]: %matplotlib
72 In [2]: %matplotlib
69 Using matplotlib backend: TkAgg
73 Using matplotlib backend: TkAgg
70
74
71 But you can explicitly request a different backend::
75 But you can explicitly request a different GUI backend::
72
76
73 In [3]: %matplotlib qt
77 In [3]: %matplotlib qt
74 """
78 """
General Comments 0
You need to be logged in to leave comments. Login now