File: MEP23.rst

package info (click to toggle)
matplotlib 3.10.1%2Bdfsg1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 78,340 kB
  • sloc: python: 147,118; cpp: 62,988; objc: 1,679; ansic: 1,426; javascript: 786; makefile: 92; sh: 53
file content (120 lines) | stat: -rw-r--r-- 3,652 bytes parent folder | download | duplicates (2)
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
========================================
 MEP23: Multiple Figures per GUI window
========================================

.. contents::
   :local:



Status
======

**Discussion**

Branches and Pull requests
==========================

**Previous work**
- https://github.com/matplotlib/matplotlib/pull/2465 **To-delete**


Abstract
========

Add the possibility to have multiple figures grouped under the same
`~.backend_template.FigureManager`

Detailed description
====================

Under the current structure, every canvas has its own window.

This is and may continue to be the desired method of operation for
most use cases.

Sometimes when there are too many figures open at the same time, it is
desirable to be able to group these under the same window. See :ghpull:`2194`.


The proposed solution modifies `.FigureManagerBase` to contain and manage more
than one ``Canvas``. The ``backend.multifigure`` rcParam controls when the
**MultiFigure** behaviour is desired.

**Note**

It is important to note, that the proposed solution, assumes that the
`MEP22 <https://github.com/matplotlib/matplotlib/wiki/Mep22>`_. is
already in place. This is simply because the actual implementation of
the ``Toolbar`` makes it pretty hard to switch between canvases.

Implementation
==============

The first implementation will be done in GTK3 using a Notebook as
canvas container.

``FigureManagerBase``
---------------------

will add the following new methods

* ``add_canvas``: To add a canvas to an existing
  `~.backend_template.FigureManager` object
* ``remove_canvas``: To remove a canvas from a
  `~.backend_template.FigureManager` object, if it is the last one, it will be
  destroyed
* ``move_canvas``: To move a canvas from one `~.backend_template.FigureManager`
  to another.
* ``set_canvas_title``: To change the title associated with a specific
  canvas container
* ``get_canvas_title``: To get the title associated with a specific
  canvas container
* ``get_active_canvas``: To get the canvas that is in the foreground and
  is subject to the gui events. There is no ``set_active_canvas``
  because the active canvas, is defined when ``show`` is called on a
  ``Canvas`` object.

``new_figure_manager``
----------------------

To control which `~.backend_template.FigureManager` will contain the new
figures, an extra optional parameter *figuremanager* will be added, this
parameter value will be passed to ``new_figure_manager_given_figure``.

``new_figure_manager_given_figure``
-----------------------------------

* If *figuremanager* parameter is given, this
  `~.backend_template.FigureManager` object will be used instead of creating a
  new one.
* If ``rcParams['backend.multifigure']`` is True: The last
  `~.backend_template.FigureManager` object will be used instead of creating a
  new one.

``NavigationBase``
------------------

Modifies the ``NavigationBase`` to keep a list of canvases, directing the
actions to the active one.

Backward compatibility
======================

For the **MultiFigure** properties to be visible, the user has to
activate them directly setting ``rcParams['backend.multifigure'] =
True``

It should be backwards compatible for backends that adhere to the
current `.FigureManagerBase` structure even if they have not
implemented the **MultiFigure** magic yet.


Alternatives
============

Instead of modifying the `.FigureManagerBase` it could be possible to add
a parallel class, that handles the cases where
``rcParams['backend.multifigure'] = True``.  This will warranty that
there won't be any problems with custom made backends, but also makes
bigger the code, and more things to maintain.