forked from pool/kf6-ksvg
- Add upstream fix (kde#488295):
* 0001-Restore-proper-devicepixelratio-when-extracting-from.patch - Rebase 0001-Revert-Support-for-fractional-scaling.patch OBS-URL: https://build.opensuse.org/package/show/KDE:Frameworks/kf6-ksvg?expand=0&rev=13
This commit is contained in:
parent
c928759481
commit
dbc3b97178
@ -0,0 +1,40 @@
|
|||||||
|
From 74f9f9cbd226407f8cde08c5cd5a711444e2775d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Marco Martin <notmart@gmail.com>
|
||||||
|
Date: Wed, 19 Jun 2024 09:11:56 +0000
|
||||||
|
Subject: [PATCH] Restore proper devicepixelratio when extracting from cache
|
||||||
|
|
||||||
|
like in base Svg, also in FrameSvg restore the proper devicepixelratio
|
||||||
|
when getting the image from the cache, as KImageCache doesn't save or
|
||||||
|
restore the information about it.
|
||||||
|
|
||||||
|
This fixes blur region mask sometimes wrong behind floating panels
|
||||||
|
|
||||||
|
BUG:488295
|
||||||
|
---
|
||||||
|
src/ksvg/framesvg.cpp | 6 ++++++
|
||||||
|
1 file changed, 6 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/src/ksvg/framesvg.cpp b/src/ksvg/framesvg.cpp
|
||||||
|
index c1d22b1a..3b094abd 100644
|
||||||
|
--- a/src/ksvg/framesvg.cpp
|
||||||
|
+++ b/src/ksvg/framesvg.cpp
|
||||||
|
@@ -524,10 +524,16 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
||||||
|
QPixmap overlay;
|
||||||
|
if (q->isUsingRenderingCache()) {
|
||||||
|
frameCached = q->imageSet()->d->findInCache(QString::number(id), frame->cachedBackground, frame->lastModified) && !frame->cachedBackground.isNull();
|
||||||
|
+ if (frameCached) {
|
||||||
|
+ frame->cachedBackground.setDevicePixelRatio(q->devicePixelRatio());
|
||||||
|
+ }
|
||||||
|
|
||||||
|
if (overlayAvailable) {
|
||||||
|
const size_t overlayId = qHash(cacheId(frame.data(), frame->prefix % QLatin1String("overlay")));
|
||||||
|
overlayCached = q->imageSet()->d->findInCache(QString::number(overlayId), overlay, frame->lastModified) && !overlay.isNull();
|
||||||
|
+ if (overlayCached) {
|
||||||
|
+ overlay.setDevicePixelRatio(q->devicePixelRatio());
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
||||||
|
2.45.2
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
From 42fd5bfb92893cd6e90e7ea0b88e33f4636d2ebf Mon Sep 17 00:00:00 2001
|
From ca06055c3eaeb716109f8126cd3e3e1976ed3e1c Mon Sep 17 00:00:00 2001
|
||||||
From: Fabian Vogt <fabian@ritter-vogt.de>
|
From: Fabian Vogt <fabian@ritter-vogt.de>
|
||||||
Date: Sun, 9 Jun 2024 21:42:10 +0200
|
Date: Sun, 9 Jun 2024 21:42:10 +0200
|
||||||
Subject: [PATCH] Revert "Support for fractional scaling"
|
Subject: [PATCH] Revert "Support for fractional scaling"
|
||||||
@ -15,7 +15,7 @@ This reverts commit 3dd28b0640d2c613654f992ad3453a0b92beebe1.
|
|||||||
7 files changed, 115 insertions(+), 120 deletions(-)
|
7 files changed, 115 insertions(+), 120 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/declarativeimports/framesvgitem.cpp b/src/declarativeimports/framesvgitem.cpp
|
diff --git a/src/declarativeimports/framesvgitem.cpp b/src/declarativeimports/framesvgitem.cpp
|
||||||
index 56c2b3a8..678bdcbe 100644
|
index 56c2b3a..678bdcb 100644
|
||||||
--- a/src/declarativeimports/framesvgitem.cpp
|
--- a/src/declarativeimports/framesvgitem.cpp
|
||||||
+++ b/src/declarativeimports/framesvgitem.cpp
|
+++ b/src/declarativeimports/framesvgitem.cpp
|
||||||
@@ -122,7 +122,7 @@ public:
|
@@ -122,7 +122,7 @@ public:
|
||||||
@ -49,7 +49,7 @@ index 56c2b3a8..678bdcbe 100644
|
|||||||
m_frameSvg->setDevicePixelRatio(newDevicePixelRatio);
|
m_frameSvg->setDevicePixelRatio(newDevicePixelRatio);
|
||||||
m_textureChanged = true;
|
m_textureChanged = true;
|
||||||
diff --git a/src/declarativeimports/svgitem.cpp b/src/declarativeimports/svgitem.cpp
|
diff --git a/src/declarativeimports/svgitem.cpp b/src/declarativeimports/svgitem.cpp
|
||||||
index bec45330..aa1f2a26 100644
|
index bec4533..aa1f2a2 100644
|
||||||
--- a/src/declarativeimports/svgitem.cpp
|
--- a/src/declarativeimports/svgitem.cpp
|
||||||
+++ b/src/declarativeimports/svgitem.cpp
|
+++ b/src/declarativeimports/svgitem.cpp
|
||||||
@@ -16,6 +16,8 @@
|
@@ -16,6 +16,8 @@
|
||||||
@ -74,7 +74,7 @@ index bec45330..aa1f2a26 100644
|
|||||||
m_svg->setDevicePixelRatio(newDevicePixelRatio);
|
m_svg->setDevicePixelRatio(newDevicePixelRatio);
|
||||||
m_textureChanged = true;
|
m_textureChanged = true;
|
||||||
diff --git a/src/ksvg/framesvg.cpp b/src/ksvg/framesvg.cpp
|
diff --git a/src/ksvg/framesvg.cpp b/src/ksvg/framesvg.cpp
|
||||||
index c1d22b1a..ecb5f5b8 100644
|
index 3b094ab..f2c8663 100644
|
||||||
--- a/src/ksvg/framesvg.cpp
|
--- a/src/ksvg/framesvg.cpp
|
||||||
+++ b/src/ksvg/framesvg.cpp
|
+++ b/src/ksvg/framesvg.cpp
|
||||||
@@ -15,7 +15,7 @@
|
@@ -15,7 +15,7 @@
|
||||||
@ -105,7 +105,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
return maskFrame->cachedBackground;
|
return maskFrame->cachedBackground;
|
||||||
@@ -536,8 +539,8 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
@@ -542,8 +545,8 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Overlays
|
// Overlays
|
||||||
@ -116,7 +116,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
if (overlayAvailable && !overlayCached) {
|
if (overlayAvailable && !overlayCached) {
|
||||||
overlaySize = q->elementSize(frame->prefix % QLatin1String("overlay")).toSize();
|
overlaySize = q->elementSize(frame->prefix % QLatin1String("overlay")).toSize();
|
||||||
|
|
||||||
@@ -563,13 +566,13 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
@@ -569,13 +572,13 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
||||||
// Tiling?
|
// Tiling?
|
||||||
if (q->hasElement(frame->prefix % QLatin1String("hint-overlay-tile-horizontal"))
|
if (q->hasElement(frame->prefix % QLatin1String("hint-overlay-tile-horizontal"))
|
||||||
|| q->hasElement(frame->prefix % QLatin1String("hint-overlay-tile-vertical"))) {
|
|| q->hasElement(frame->prefix % QLatin1String("hint-overlay-tile-vertical"))) {
|
||||||
@ -133,7 +133,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
overlayPainter.end();
|
overlayPainter.end();
|
||||||
@@ -582,14 +585,14 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
@@ -588,14 +591,14 @@ void FrameSvgPrivate::generateBackground(const QSharedPointer<FrameData> &frame)
|
||||||
if (!overlay.isNull()) {
|
if (!overlay.isNull()) {
|
||||||
QPainter p(&frame->cachedBackground);
|
QPainter p(&frame->cachedBackground);
|
||||||
p.setCompositionMode(QPainter::CompositionMode_SourceOver);
|
p.setCompositionMode(QPainter::CompositionMode_SourceOver);
|
||||||
@ -150,7 +150,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
|
|
||||||
if (!size.isValid()) {
|
if (!size.isValid()) {
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
@@ -602,14 +605,13 @@ void FrameSvgPrivate::generateFrameBackground(const QSharedPointer<FrameData> &f
|
@@ -608,14 +611,13 @@ void FrameSvgPrivate::generateFrameBackground(const QSharedPointer<FrameData> &f
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,7 +167,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
paintCenter(p, frame, contentRect, size);
|
paintCenter(p, frame, contentRect, size);
|
||||||
|
|
||||||
paintCorner(p, frame, FrameSvg::LeftBorder | FrameSvg::TopBorder, contentRect);
|
paintCorner(p, frame, FrameSvg::LeftBorder | FrameSvg::TopBorder, contentRect);
|
||||||
@@ -618,26 +620,25 @@ void FrameSvgPrivate::generateFrameBackground(const QSharedPointer<FrameData> &f
|
@@ -624,26 +626,25 @@ void FrameSvgPrivate::generateFrameBackground(const QSharedPointer<FrameData> &f
|
||||||
paintCorner(p, frame, FrameSvg::RightBorder | FrameSvg::BottomBorder, contentRect);
|
paintCorner(p, frame, FrameSvg::RightBorder | FrameSvg::BottomBorder, contentRect);
|
||||||
|
|
||||||
// Sides
|
// Sides
|
||||||
@ -207,7 +207,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
if (frame->enabledBorders & FrameSvg::LeftBorder && q->hasElement(frame->prefix % QLatin1String("left"))) {
|
if (frame->enabledBorders & FrameSvg::LeftBorder && q->hasElement(frame->prefix % QLatin1String("left"))) {
|
||||||
contentRect.translate(frame->leftWidth * q->devicePixelRatio(), 0);
|
contentRect.translate(frame->leftWidth * q->devicePixelRatio(), 0);
|
||||||
}
|
}
|
||||||
@@ -659,7 +660,7 @@ void FrameSvgPrivate::updateFrameData(uint lastModified, UpdateType updateType)
|
@@ -665,7 +666,7 @@ void FrameSvgPrivate::updateFrameData(uint lastModified, UpdateType updateType)
|
||||||
|
|
||||||
const QString oldPath = fd->imagePath;
|
const QString oldPath = fd->imagePath;
|
||||||
const FrameSvg::EnabledBorders oldBorders = fd->enabledBorders;
|
const FrameSvg::EnabledBorders oldBorders = fd->enabledBorders;
|
||||||
@ -216,7 +216,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
|
|
||||||
fd->enabledBorders = enabledBorders;
|
fd->enabledBorders = enabledBorders;
|
||||||
fd->frameSize = pendingFrameSize;
|
fd->frameSize = pendingFrameSize;
|
||||||
@@ -716,28 +717,27 @@ void FrameSvgPrivate::updateFrameData(uint lastModified, UpdateType updateType)
|
@@ -722,28 +723,27 @@ void FrameSvgPrivate::updateFrameData(uint lastModified, UpdateType updateType)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -251,7 +251,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
} else {
|
} else {
|
||||||
q->paint(&p, FrameSvgHelpers::sectionRect(FrameSvg::NoBorder, contentRect, fullSize * q->devicePixelRatio()), centerElementId);
|
q->paint(&p, FrameSvgHelpers::sectionRect(FrameSvg::NoBorder, contentRect, fullSize * q->devicePixelRatio()), centerElementId);
|
||||||
}
|
}
|
||||||
@@ -746,7 +746,7 @@ void FrameSvgPrivate::paintCenter(QPainter &p, const QSharedPointer<FrameData> &
|
@@ -752,7 +752,7 @@ void FrameSvgPrivate::paintCenter(QPainter &p, const QSharedPointer<FrameData> &
|
||||||
|
|
||||||
if (frame->composeOverBorder) {
|
if (frame->composeOverBorder) {
|
||||||
p.setCompositionMode(QPainter::CompositionMode_DestinationIn);
|
p.setCompositionMode(QPainter::CompositionMode_DestinationIn);
|
||||||
@ -260,7 +260,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
p.setCompositionMode(QPainter::CompositionMode_SourceOver);
|
p.setCompositionMode(QPainter::CompositionMode_SourceOver);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -754,51 +754,35 @@ void FrameSvgPrivate::paintCenter(QPainter &p, const QSharedPointer<FrameData> &
|
@@ -760,51 +760,35 @@ void FrameSvgPrivate::paintCenter(QPainter &p, const QSharedPointer<FrameData> &
|
||||||
void FrameSvgPrivate::paintBorder(QPainter &p,
|
void FrameSvgPrivate::paintBorder(QPainter &p,
|
||||||
const QSharedPointer<FrameData> &frame,
|
const QSharedPointer<FrameData> &frame,
|
||||||
const FrameSvg::EnabledBorders borders,
|
const FrameSvg::EnabledBorders borders,
|
||||||
@ -319,7 +319,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -846,7 +830,7 @@ void FrameSvgPrivate::updateSizes(FrameData *frame) const
|
@@ -852,7 +836,7 @@ void FrameSvgPrivate::updateSizes(FrameData *frame) const
|
||||||
// qCDebug(LOG_KSVG) << "!!!!!!!!!!!!!!!!!!!!!! updating sizes" << prefix;
|
// qCDebug(LOG_KSVG) << "!!!!!!!!!!!!!!!!!!!!!! updating sizes" << prefix;
|
||||||
Q_ASSERT(frame);
|
Q_ASSERT(frame);
|
||||||
|
|
||||||
@ -329,7 +329,7 @@ index c1d22b1a..ecb5f5b8 100644
|
|||||||
if (!frame->cachedBackground.isNull()) {
|
if (!frame->cachedBackground.isNull()) {
|
||||||
frame->cachedBackground = QPixmap();
|
frame->cachedBackground = QPixmap();
|
||||||
diff --git a/src/ksvg/private/framesvg_helpers.h b/src/ksvg/private/framesvg_helpers.h
|
diff --git a/src/ksvg/private/framesvg_helpers.h b/src/ksvg/private/framesvg_helpers.h
|
||||||
index 95cd6ba8..691aa3c1 100644
|
index 95cd6ba..691aa3c 100644
|
||||||
--- a/src/ksvg/private/framesvg_helpers.h
|
--- a/src/ksvg/private/framesvg_helpers.h
|
||||||
+++ b/src/ksvg/private/framesvg_helpers.h
|
+++ b/src/ksvg/private/framesvg_helpers.h
|
||||||
@@ -45,7 +45,7 @@ QString borderToElementId(FrameSvg::EnabledBorders borders)
|
@@ -45,7 +45,7 @@ QString borderToElementId(FrameSvg::EnabledBorders borders)
|
||||||
@ -379,7 +379,7 @@ index 95cd6ba8..691aa3c1 100644
|
|||||||
|
|
||||||
}
|
}
|
||||||
diff --git a/src/ksvg/private/framesvg_p.h b/src/ksvg/private/framesvg_p.h
|
diff --git a/src/ksvg/private/framesvg_p.h b/src/ksvg/private/framesvg_p.h
|
||||||
index 463b2ee4..2b9e881d 100644
|
index 463b2ee..2b9e881 100644
|
||||||
--- a/src/ksvg/private/framesvg_p.h
|
--- a/src/ksvg/private/framesvg_p.h
|
||||||
+++ b/src/ksvg/private/framesvg_p.h
|
+++ b/src/ksvg/private/framesvg_p.h
|
||||||
@@ -78,39 +78,38 @@ public:
|
@@ -78,39 +78,38 @@ public:
|
||||||
@ -486,7 +486,7 @@ index 463b2ee4..2b9e881d 100644
|
|||||||
static QHash<ImageSetPrivate *, QHash<uint, QWeakPointer<FrameData>>> s_sharedFrames;
|
static QHash<ImageSetPrivate *, QHash<uint, QWeakPointer<FrameData>>> s_sharedFrames;
|
||||||
|
|
||||||
diff --git a/src/ksvg/private/svg_p.h b/src/ksvg/private/svg_p.h
|
diff --git a/src/ksvg/private/svg_p.h b/src/ksvg/private/svg_p.h
|
||||||
index 818a4777..bb80c753 100644
|
index 818a477..bb80c75 100644
|
||||||
--- a/src/ksvg/private/svg_p.h
|
--- a/src/ksvg/private/svg_p.h
|
||||||
+++ b/src/ksvg/private/svg_p.h
|
+++ b/src/ksvg/private/svg_p.h
|
||||||
@@ -138,8 +138,8 @@ public:
|
@@ -138,8 +138,8 @@ public:
|
||||||
@ -510,7 +510,7 @@ index 818a4777..bb80c753 100644
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
diff --git a/src/ksvg/svg.cpp b/src/ksvg/svg.cpp
|
diff --git a/src/ksvg/svg.cpp b/src/ksvg/svg.cpp
|
||||||
index 1bdafd6b..01ce0581 100644
|
index 1bdafd6..01ce058 100644
|
||||||
--- a/src/ksvg/svg.cpp
|
--- a/src/ksvg/svg.cpp
|
||||||
+++ b/src/ksvg/svg.cpp
|
+++ b/src/ksvg/svg.cpp
|
||||||
@@ -272,7 +272,7 @@ void SvgRectsCache::dropImageFromCache(const QString &path)
|
@@ -272,7 +272,7 @@ void SvgRectsCache::dropImageFromCache(const QString &path)
|
||||||
@ -603,5 +603,5 @@ index 1bdafd6b..01ce0581 100644
|
|||||||
painter->drawPixmap(x, y, pix, 0, 0, pix.size().width(), pix.size().height());
|
painter->drawPixmap(x, y, pix, 0, 0, pix.size().width(), pix.size().height());
|
||||||
}
|
}
|
||||||
--
|
--
|
||||||
2.45.1
|
2.45.2
|
||||||
|
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jun 19 20:38:02 UTC 2024 - Christophe Marin <christophe@krop.fr>
|
||||||
|
|
||||||
|
- Add upstream fix (kde#488295):
|
||||||
|
* 0001-Restore-proper-devicepixelratio-when-extracting-from.patch
|
||||||
|
- Rebase 0001-Revert-Support-for-fractional-scaling.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Sun Jun 9 20:14:24 UTC 2024 - Fabian Vogt <fabian@ritter-vogt.de>
|
Sun Jun 9 20:14:24 UTC 2024 - Fabian Vogt <fabian@ritter-vogt.de>
|
||||||
|
|
||||||
|
@ -35,6 +35,8 @@ Source: %{rname}-%{version}.tar.xz
|
|||||||
Source1: %{rname}-%{version}.tar.xz.sig
|
Source1: %{rname}-%{version}.tar.xz.sig
|
||||||
Source2: frameworks.keyring
|
Source2: frameworks.keyring
|
||||||
%endif
|
%endif
|
||||||
|
# PATCH-FIX-UPSTREAM
|
||||||
|
Patch0: 0001-Restore-proper-devicepixelratio-when-extracting-from.patch
|
||||||
# PATCH-FIX-OPENSUSE
|
# PATCH-FIX-OPENSUSE
|
||||||
Patch1: 0001-Revert-Support-for-fractional-scaling.patch
|
Patch1: 0001-Revert-Support-for-fractional-scaling.patch
|
||||||
BuildRequires: doxygen
|
BuildRequires: doxygen
|
||||||
|
Loading…
Reference in New Issue
Block a user