don't multiply svg sizes by devicepixelratio
Summary: when the native high dpi scaling is enabled, some things gets scaled two times, as sizes taken from svgs should *not* be manually scaled by devicePixelRatio Test Plan: works correctly on wayland, svg.elementSize will have to be tweaked in x11 to return a value scaled by scalefactor, to homogenize the behavior compared to native qt high dpi scaling. to return a value scaled by scalefactor for this qml code to work there too. I advise everybody with high dpi laptops to test this on both wayland and x11 Reviewers: #plasma, davidedmundson Reviewed By: #plasma, davidedmundson Subscribers: hein, broulik, plasma-devel, #frameworks Tags: #plasma, #frameworks Differential Revision: https://phabricator.kde.org/D9286
This commit is contained in:
parent
f3cd5d55fa
commit
af00946f81
@ -28,8 +28,8 @@ PlasmaCore.FrameSvgItem {
|
|||||||
imagePath:"widgets/scrollbar"
|
imagePath:"widgets/scrollbar"
|
||||||
prefix: internalLoader.isVertical ? "background-vertical" : "background-horizontal"
|
prefix: internalLoader.isVertical ? "background-vertical" : "background-horizontal"
|
||||||
|
|
||||||
property int implicitWidth: (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width) * Math.max(1, Math.floor(units.devicePixelRatio))
|
property int implicitWidth: (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width)
|
||||||
property int implicitHeight: (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").height : scrollbarSvg.elementSize("arrow-left").height) * Math.max(1, Math.floor(units.devicePixelRatio))
|
property int implicitHeight: (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").height : scrollbarSvg.elementSize("arrow-left").height)
|
||||||
|
|
||||||
Keys.onUpPressed: {
|
Keys.onUpPressed: {
|
||||||
if (!enabled || !internalLoader.isVertical)
|
if (!enabled || !internalLoader.isVertical)
|
||||||
|
@ -28,8 +28,8 @@ PlasmaCore.FrameSvgItem {
|
|||||||
imagePath:"widgets/scrollbar"
|
imagePath:"widgets/scrollbar"
|
||||||
prefix: internalLoader.isVertical ? "background-vertical" : "background-horizontal"
|
prefix: internalLoader.isVertical ? "background-vertical" : "background-horizontal"
|
||||||
|
|
||||||
property int implicitWidth: scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width * Math.max(1, Math.floor(units.devicePixelRatio)) : 12
|
property int implicitWidth: scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : 12
|
||||||
property int implicitHeight: scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").height * Math.max(1, Math.floor(units.devicePixelRatio)) : 12
|
property int implicitHeight: scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").height : 12
|
||||||
|
|
||||||
opacity: 0
|
opacity: 0
|
||||||
Behavior on opacity {
|
Behavior on opacity {
|
||||||
|
@ -29,7 +29,7 @@ ProgressBarStyle {
|
|||||||
|
|
||||||
readonly property string imagePath: "widgets/bar_meter_horizontal"
|
readonly property string imagePath: "widgets/bar_meter_horizontal"
|
||||||
|
|
||||||
readonly property real implicitHeight: barSvg.preferredHeight * Math.max(1, Math.floor(units.devicePixelRatio))
|
readonly property real implicitHeight: barSvg.preferredHeight
|
||||||
|
|
||||||
PlasmaCore.Svg {
|
PlasmaCore.Svg {
|
||||||
id: barSvg
|
id: barSvg
|
||||||
|
@ -28,7 +28,7 @@ import org.kde.plasma.components 2.0 as PlasmaComponents
|
|||||||
QtQuickControlStyle.ScrollViewStyle {
|
QtQuickControlStyle.ScrollViewStyle {
|
||||||
property Flickable flickableItem: control.flickableItem
|
property Flickable flickableItem: control.flickableItem
|
||||||
|
|
||||||
property real widthHint: Math.round( (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width) * units.devicePixelRatio)
|
property real widthHint: Math.round( (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width))
|
||||||
|
|
||||||
property StyleItem __styleitem: StyleItem { elementType: "frame" }
|
property StyleItem __styleitem: StyleItem { elementType: "frame" }
|
||||||
readonly property int __wheelScrollLines: __styleitem.styleHint("wheelScrollLines")
|
readonly property int __wheelScrollLines: __styleitem.styleHint("wheelScrollLines")
|
||||||
|
@ -34,7 +34,7 @@ QtQuickControlStyle.TableViewStyle {
|
|||||||
activateItemOnSingleClick: false
|
activateItemOnSingleClick: false
|
||||||
|
|
||||||
|
|
||||||
property real scrollbarWidthHint: Math.round( (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width) * units.devicePixelRatio)
|
property real scrollbarWidthHint: Math.round( (scrollbarSvg.hasElement("hint-scrollbar-size") ? scrollbarSvg.elementSize("hint-scrollbar-size").width : scrollbarSvg.elementSize("arrow-up").width))
|
||||||
|
|
||||||
headerDelegate: PlasmaCore.FrameSvgItem {
|
headerDelegate: PlasmaCore.FrameSvgItem {
|
||||||
imagePath: "widgets/button"
|
imagePath: "widgets/button"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user