Skip to content

Fix AxesWidgets on inset_axes that are outside their parent. #29966

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

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

anntzer
Copy link
Contributor

@anntzer anntzer commented Apr 25, 2025

When axes are overlapping, LocationEvent.inaxes can point not to the axes we care about, but to another one. Widgets currently recompute location event axes coordinates relative to the axes to which the widget is assigned (#25555), but this recomputation code was previously brittle wrt. events that are outside the axes they wrongly believe they belong to (so x/ydata is None), even though they are indeed within the axes they actually belong to. This can occur when a widget is associated with an "inset_axes" that's actually outside the parent axes. A practical case is given by

from pylab import *
ax = figure(layout="constrained").add_subplot()
ax1 = ax.inset_axes([0, 1, 1, .25], sharex=ax)
ss = mpl.widgets.SpanSelector(ax1, print, "horizontal")
show()  # try to trigger the spanselector

which would raise an exception prior to this patch.

Improve the recomputation logic by fully reparenting the event passed to the widget to the correct parent axes from the onset.

PR summary

PR checklist

When axes are overlapping, LocationEvent.inaxes can point not to the
axes we care about, but to another one.  Widgets currently recompute
location event axes coordinates relative to the axes to which the widget
is assigned, but this recomputation code was previously brittle wrt.
events that are outside the axes they wrongly believe they belong to
(so x/ydata is None), even though they are indeed within the axes they
actually belong to.  This can occur when a widget is associated with an
"inset_axes" that's actually outside the parent axes.  A practical case
is given by
```python
from pylab import *
ax = figure(layout="constrained").add_subplot()
ax1 = ax.inset_axes([0, 1, 1, .25], sharex=ax)
ss = mpl.widgets.SpanSelector(ax1, print, "horizontal")
show()  # try to trigger the spanselector
```
which would raise an exception prior to this patch.

Improve the recomputation logic by fully reparenting the event passed to
the widget to the correct parent axes from the onset.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant