-
Notifications
You must be signed in to change notification settings - Fork 153
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Don’t use tight layout as it causes bouncing around of axes #745
Conversation
@ChrisBeaumont - it would be great if you could try this out when you get a chance. I've now added a class factory that ensures that the margin between axes and the edge of the figure is constant in absolute terms. This allows us to minimize whitespace while avoiding the issues due to the tight layout option. At the moment, this isn't perfect for the |
(I will fix the test failures if we go with this approach) |
@ChrisBeaumont - I'm pretty happy with this approach now which works even for the |
f9546ca
to
aecead4
Compare
…e AxesCache works
aecead4
to
06480f1
Compare
Fixes #730 |
Will take a look tmrw morning On Thursday, September 10, 2015, Thomas Robitaille notifications@github.com
|
Cool, this seems to work well for me. Do you know how this works if a plot has multiple axes on it? I'm trying to think and I don't think there are any standard viewers that do so, so It's probably not a blocker either way. |
@ChrisBeaumont - thanks for reviewing! None of the viewers I am using this for have multiple axes. If a user defined axes in a custom viewer I am not applying this method to those to be safe, but I could document how to use the AxesResizer since it's pretty easy (alternatively, if the custom viewer can be used only with single axes, I can attach the AxesResizer to those too. |
IIRC it's not easy to build a custom viewer with multiple axes (the axes are auto-built and handed off to the user). It might be nice to:
|
@ChrisBeaumont - actually at the moment If so, then we can also make it that to set the axes margins, the user/developer can specify |
Sorry, just realized you said the same thing about the fact the user doesn't create the axes. I will implement the axes_margins parameter so the user can set them. |
``[left, right, bottom, top]`` | ||
""" | ||
|
||
resizer = AxesResizer(axes, margins) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it might be nice to store this resizer as an attribute on the axes somewhere, in case downstream code wishes to modify it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm, that might be a way to customize the margins then, if it's accessible as axes.resizer.margins
. I worry a bit about adding axes.resizer
though in case it conflicts with Matplotlib in future for any reason. Do you think we should just do it anyway and cross that bridge if it happens?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think we should worry about future name clashes with resizer
On Friday, September 11, 2015, Thomas Robitaille notifications@github.com
wrote:
In glue/utils/matplotlib.py
#745 (comment):
+def fix_margins(axes, margins=[1, 1, 1, 1]):
- """
- Make sure margins of axes stay fixed.
- Parameters
- ax_class : matplotlib.axes.Axes
The axes class for which to fix the margins
- margins : iterable
The margins, in inches. The order of the margins is
`[left, right, bottom, top]`
- """
- resizer = AxesResizer(axes, margins)
Hmm, that might be a way to customize the margins then, if it's accessible
as axes.resizer.margins. I worry a bit about adding axes.resizer though
in case it conflicts with Matplotlib in future for any reason. Do you think
we should just do it anyway and cross that bridge if it happens?—
Reply to this email directly or view it on GitHub
/~https://github.com/glue-viz/glue/pull/745/files#r39279062.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done :)
@ChrisBeaumont - I implemented your suggestions, thanks! I'll keep this open for another day in case you want to review again. |
Don’t use tight layout as it causes bouncing around of axes
I was thinking about this a little more. I guess the main advantage of tight_layout is that it auto-chooses sensible initial margins for an arbitrary plot (and potentially complicated ones with multiple axes, weird axis labels, etc). Its drawback (fixed in this PR) is that it auto-updates these margins, leading to jumpy panning/zooming. So maybe the ideal solution is one that uses tight_layout's internal mechanism to determine good initial margins, and then passes these values to freeze_margins. That's not a high priority, but something we could consider if we start to notice that the current hard-coded frozen margins don't look good in certain situations. |
@ChrisBeaumont - yeah, I was thinking of that too. That might be possible if we can avoid an initial draw before tight_layout figures out the best margins (otherwise we'll get jumpy behavior upon initialization) |
Do you actually notice jumpiness at init time? I mostly see this during pan or zoom, when a new tick label is created which changes the margins. I haven't noticed any jumpiness when you first open a window |
Ah, I will double check |
I looked into the issue described in #730, namely that the axes appear to bounce around when being resized. This is due to the tight layout option, which causes the axes to be re-drawn after every draw with a different bounding box.
This PR disables this, and tries to instead optimize space used by setting the rect for the axes created. Of course, this isn't perfect either because the axes size is relative to the window so for larger axes there is a lot of wasted space. I am going to look into whether there is a better way to do that, but in the mean time, this does produce smoother axes resizing without any bouncing.