Skip to content

Commit 56fe546

Browse files
committed
Fix set_size_inches on HiDPI screens
This passes physical pixels to the backend, as it will be more accurate due to the int-cast. Fixes #21090
1 parent ea3f98b commit 56fe546

File tree

5 files changed

+16
-6
lines changed

5 files changed

+16
-6
lines changed

lib/matplotlib/backend_bases.py

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1760,7 +1760,12 @@ def blit(self, bbox=None):
17601760
"""Blit the canvas in bbox (default entire canvas)."""
17611761

17621762
def resize(self, w, h):
1763-
"""Set the canvas size in pixels."""
1763+
"""
1764+
UNUSED: Set the canvas size in pixels.
1765+
1766+
Certain backends may implement a similar method internally, but this is
1767+
not a requirement of, nor is it used by, Matplotlib itself.
1768+
"""
17641769

17651770
def draw_event(self, renderer):
17661771
"""Pass a `DrawEvent` to all functions connected to ``draw_event``."""
@@ -2813,7 +2818,7 @@ def full_screen_toggle(self):
28132818
pass
28142819

28152820
def resize(self, w, h):
2816-
"""For GUI backends, resize the window (in pixels)."""
2821+
"""For GUI backends, resize the window (in physical pixels)."""
28172822

28182823
@_api.deprecated(
28192824
"3.4", alternative="self.canvas.callbacks.process(event.name, event)")

lib/matplotlib/backends/backend_gtk3.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -421,6 +421,8 @@ def set_window_title(self, title):
421421

422422
def resize(self, width, height):
423423
"""Set the canvas size in pixels."""
424+
width = int(width / self.canvas.device_pixel_ratio)
425+
height = int(height / self.canvas.device_pixel_ratio)
424426
if self.toolbar:
425427
toolbar_size = self.toolbar.size_request()
426428
height += toolbar_size.height

lib/matplotlib/backends/backend_gtk4.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -373,6 +373,8 @@ def set_window_title(self, title):
373373

374374
def resize(self, width, height):
375375
"""Set the canvas size in pixels."""
376+
width = int(width / self.canvas.device_pixel_ratio)
377+
height = int(height / self.canvas.device_pixel_ratio)
376378
if self.toolbar:
377379
min_size, nat_size = self.toolbar.get_preferred_size()
378380
height += nat_size.height

lib/matplotlib/backends/backend_qt.py

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -589,8 +589,10 @@ def _get_toolbar(self, canvas, parent):
589589
return toolbar
590590

591591
def resize(self, width, height):
592-
# these are Qt methods so they return sizes in 'virtual' pixels
593-
# so we do not need to worry about dpi scaling here.
592+
# The Qt methods return sizes in 'virtual' pixels so we do need to
593+
# rescale from physical to logical pixels.
594+
width = int(width / self.canvas.device_pixel_ratio)
595+
height = int(height / self.canvas.device_pixel_ratio)
594596
extra_width = self.window.width() - self.canvas.width()
595597
extra_height = self.window.height() - self.canvas.height()
596598
self.canvas.resize(width, height)

lib/matplotlib/figure.py

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2658,10 +2658,9 @@ def set_size_inches(self, w, h=None, forward=True):
26582658
if forward:
26592659
canvas = getattr(self, 'canvas')
26602660
if canvas is not None:
2661-
dpi_ratio = getattr(canvas, '_dpi_ratio', 1)
26622661
manager = getattr(canvas, 'manager', None)
26632662
if manager is not None:
2664-
manager.resize(*(size * self.dpi / dpi_ratio).astype(int))
2663+
manager.resize(*(size * self.dpi).astype(int))
26652664
self.stale = True
26662665

26672666
def get_size_inches(self):

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy