From 2450ecbdc2d0631fdacd49d306ed8ab3299a69cf Mon Sep 17 00:00:00 2001 From: Ruth Comer <10599679+rcomer@users.noreply.github.com> Date: Sun, 15 Dec 2024 14:07:31 +0000 Subject: [PATCH] FIX: pass renderer through _auto_legend_data --- lib/matplotlib/legend.py | 6 +++--- lib/matplotlib/tests/test_legend.py | 16 ++++++++++++++++ 2 files changed, 19 insertions(+), 3 deletions(-) diff --git a/lib/matplotlib/legend.py b/lib/matplotlib/legend.py index ace3f668e740..0c2dfc19705c 100644 --- a/lib/matplotlib/legend.py +++ b/lib/matplotlib/legend.py @@ -934,7 +934,7 @@ def _init_legend_box(self, handles, labels, markerfirst=True): self.texts = text_list self.legend_handles = handle_list - def _auto_legend_data(self): + def _auto_legend_data(self, renderer): """ Return display coordinates for hit testing for "best" positioning. @@ -969,7 +969,7 @@ def _auto_legend_data(self): if len(hoffsets): offsets.extend(transOffset.transform(hoffsets)) elif isinstance(artist, Text): - bboxes.append(artist.get_window_extent()) + bboxes.append(artist.get_window_extent(renderer)) return bboxes, lines, offsets @@ -1150,7 +1150,7 @@ def _find_best_position(self, width, height, renderer): start_time = time.perf_counter() - bboxes, lines, offsets = self._auto_legend_data() + bboxes, lines, offsets = self._auto_legend_data(renderer) bbox = Bbox.from_bounds(0, 0, width, height) diff --git a/lib/matplotlib/tests/test_legend.py b/lib/matplotlib/tests/test_legend.py index 61892378bd03..67b10fb2a365 100644 --- a/lib/matplotlib/tests/test_legend.py +++ b/lib/matplotlib/tests/test_legend.py @@ -1,4 +1,5 @@ import collections +import io import itertools import platform import time @@ -1427,6 +1428,21 @@ def test_legend_text(): assert_allclose(leg_bboxes[1].bounds, leg_bboxes[0].bounds) +def test_legend_annotate(): + fig, ax = plt.subplots() + + ax.plot([1, 2, 3], label="Line") + ax.annotate("a", xy=(1, 1)) + ax.legend(loc=0) + + with mock.patch.object( + fig, '_get_renderer', wraps=fig._get_renderer) as mocked_get_renderer: + fig.savefig(io.BytesIO()) + + # Finding the legend position should not require _get_renderer to be called + mocked_get_renderer.assert_not_called() + + def test_boxplot_legend_labels(): # Test that legend entries are generated when passing `label`. np.random.seed(19680801)