Qt应用程序中的高dpi缩放使图标平滑

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Qt应用程序中的高dpi缩放使图标平滑相关的知识,希望对你有一定的参考价值。

我使用QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling);在我的Qt应用程序中启用了高dpi支持,但现在我的图像看起来并不清晰,而是看起来“平滑”了。例如下面有一些按钮的图片,这些按钮意味着使用高dpi图像。当我禁用高dpi支持并手动缩放ui时,使用相同的图像,图标清晰明了。

enter image description here

我试图设置Qt::AA_UseHighDpiPixmaps没有成功。这是一个示例代码:

import QtQuick 2.11
import QtQuick.Window 2.11
import QtQuick.Controls 2.2

Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    ToolButton{
        anchors.centerIn: parent
        icon.source: "qrc:/ic_star_white_48dp.png"
    }
}

我使用的图标来自Google材料设计图标,它是为高dpi屏幕设备制作的(分辨率为192x192)。启用高dpi时,工具按钮中的图标显示为平滑。如果我禁用高dpi支持并将图标(icon.heighticon.width)的高度和宽度设置为640/160 * 48640是我的设备的dpi),图标清晰明了。但是,如果我启用高dpi并将高度和宽度设置为48,则图标不清晰。

答案

我猜Qt的图标属性可以缩放图像以提高性能(例如,ToolButton是48 x 48,源图像将缩放到48 x 48),但不会补偿HighDpiScaling。

例如,您的ToolButton通过HighDpiScaling从48 x 48逻辑像素缩放到192 x 192物理像素,但它仍然使用缩小的48 x 48图像。

我倾向于使用:

ToolButton{
anchors.centerIn: parent

    Image {
        anchors.centerIn: parent
        anchors.margins: 5
        //You can play around with those to balance quality and performance
        //mipmap: true
        //sourceSize.height: height * 2
        //sourceSize.width: width * 2
        fillMode: Image.PreserveAspectFit
        source: "qrc:/image.png"
    }
}

以上是关于Qt应用程序中的高dpi缩放使图标平滑的主要内容,如果未能解决你的问题,请参考以下文章

更改显示的 DPI 缩放大小使 Qt 应用程序的字体大小变得更大

如何在 linux 的高 dpi 显示器上修复基于 java 的应用程序的缩放?

Qt之高DPI显示器 - 解决方案整理

qt 设计师:如何关闭 dpi 缩放

linux (wayland) 上的 SoapUI - 高 DPI/4K 缩放问题

Qt 5 缩放整个窗口