在 PyQt5 的 HiDPI 显示器上使用 SVG 图标

Using SVG icons on HiDPI displays in PyQt5

我想在我的 PyQt5 应用程序中使用高分辨率图标。然而,以下代码片段在我的 HiDPI macOS 平台上生成了一个非常低分辨率的渲染(可以下载所需的图标 here):

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QAction
from PyQt5.QtGui import QIcon


app = QApplication(sys.argv)
main = QMainWindow()
icon = QIcon("waves-24px.svg")
action = QAction(icon, "Test")
toolbar = main.addToolBar("toolbar")
toolbar.addAction(action)
toolbar.show()
main.show()
sys.exit(app.exec_())

这是结果的样子(注意图标的低分辨率):

我做错了什么?

当从 SVG 加载图标时,QT 首先将其渲染为像素图。默认情况下,像素图的尺寸取自 svg 页面大小,即 svg 根元素的宽度和高度属性。为您的 svg 渲染器生成 24px x 24px 像素图。因此,Qt 首先将您的图片加载到低分辨率缓冲区中,然后缩放 ins 内容。要解决此问题,请尝试放大 svg 宽度和高度属性以增加页面大小和缩放图像。在 Inkscape 中,页面大小设置位于“文件”>“文档属性”>“页面”选项卡中。

事实证明有一个简单的解决方案:

app.setAttribute(Qt.AA_UseHighDpiPixmaps)