Make figure parameter optional when constructing canvases.#18746
Merged
QuLogic merged 1 commit intomatplotlib:masterfrom Feb 5, 2021
Merged
Make figure parameter optional when constructing canvases.#18746QuLogic merged 1 commit intomatplotlib:masterfrom
QuLogic merged 1 commit intomatplotlib:masterfrom
Conversation
Member
|
We are going to redudently create and discard a I am 👍 on this, but it needs atleast one test that exercises it! |
Contributor
Author
|
Initializing a FigureCanvasBase should be pretty cheap (it's mostly just setting a bunch of attributes, the most complex likely being creating the CallbackRegistry but as you know I'm trying to move that to the Figure instance anyways). |
jklymak
approved these changes
Feb 1, 2021
Member
|
linter needs to pass... |
Contributor
Author
|
should be better now... |
Member
|
Seems like you didn't rebase on latest master? Docs should be fixed by now. |
Auto-instantiating a Figure seems reasonable enough, and helps with GUI builders. (The auto-instantiated figure must be a plain Figure(), not a a pyplot-registered figure, both because most likely one should not use pyplot when building GUIs, and also more prosaically because that would run into a circular dependency (pyplot needs a canvas already instantiated (actually a manager that holds a canvas) to store into its global registry).
Contributor
Author
|
retry. |
QuLogic
approved these changes
Feb 5, 2021
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Auto-instantiating a Figure seems reasonable enough, and helps with GUI
builders. (The auto-instantiated figure must be a plain Figure(), not
a a pyplot-registered figure, both because most likely one should not
use pyplot when building GUIs, and also more prosaically because that
would run into a circular dependency (pyplot needs a canvas already
instantiated (actually a manager that holds a canvas) to store into its
global registry).
Closes #17349.
PR Summary
PR Checklist
pytestpasses).flake8on changed files to check).flake8-docstringsandpydocstyle<4and runflake8 --docstring-convention=all).doc/users/next_whats_new/(follow instructions in README.rst there).doc/api/next_api_changes/(follow instructions in README.rst there).