support for user removing background and automatic shadow

Summary:
add the ability for the user to override the background hints anddecide
about applets having background or a shadow
A new handle button will be added to manually enable/disable background for
plasmoids that support it
if they don't, the ImmutableBackground flag is set in the hints.

PlasmaCore.ColorScope has been expanded to work more like Kirigami.Theme (which will be replaced by) even if it's oòld behavior still works. This makes the complementary colorscope in applets with shadow actually work (and at the same time gives a clearer porting path for kf6)

Test Plan: Tested the functionality and correct save/restore

Reviewers: #plasma, davidedmundson

Reviewed By: #plasma, davidedmundson

Subscribers: davidedmundson, ndavis, kde-frameworks-devel

Tags: #frameworks

Differential Revision: https://phabricator.kde.org/D25590
This commit is contained in:
Marco Martin 2019-11-29 10:21:56 +01:00
parent 15e3d10ef8
commit 57fdb56790
6 changed files with 161 additions and 50 deletions

View File

@ -25,6 +25,8 @@
#include <QQmlEngine> #include <QQmlEngine>
#include <QColor> #include <QColor>
#include <PlasmaQuick/AppletQuickItem>
QHash<QObject *, ColorScope *> ColorScope::s_attachedScopes = QHash<QObject *, ColorScope *>(); QHash<QObject *, ColorScope *> ColorScope::s_attachedScopes = QHash<QObject *, ColorScope *>();
QWeakPointer<Plasma::Theme> ColorScope::s_theme; QWeakPointer<Plasma::Theme> ColorScope::s_theme;
@ -47,11 +49,12 @@ ColorScope::ColorScope(QQuickItem *parent, QObject *parentObject)
connect(this, &ColorScope::colorGroupChanged, this, &ColorScope::colorsChanged); connect(this, &ColorScope::colorGroupChanged, this, &ColorScope::colorsChanged);
QQuickItem *parentItem = qobject_cast<QQuickItem *>(parentObject); if (parentObject && qobject_cast<QQuickItem *>(parentObject)) {
if (parentItem) { connect(static_cast<QQuickItem *>(parentObject), &QQuickItem::parentChanged,
connect(parentItem, &QQuickItem::parentChanged, this, &ColorScope::checkColorGroupChanged); this, &ColorScope::checkColorGroupChanged);
} else if (m_parent) { } else if (parent) {
m_parent->installEventFilter(this); connect(parent, &QQuickItem::parentChanged,
this, &ColorScope::checkColorGroupChanged);
} }
} }
@ -76,15 +79,6 @@ ColorScope *ColorScope::qmlAttachedProperties(QObject *object)
return s; return s;
} }
bool ColorScope::eventFilter(QObject* watched, QEvent* event)
{
Q_ASSERT(watched == m_parent && !qobject_cast<QQuickItem *>(watched));
if (event->type() == QEvent::ParentChange) {
checkColorGroupChanged();
}
return QQuickItem::eventFilter(watched, event);
}
void ColorScope::setParentScope(ColorScope* parentScope) void ColorScope::setParentScope(ColorScope* parentScope)
{ {
if (parentScope == m_parentScope) if (parentScope == m_parentScope)
@ -105,29 +99,24 @@ void ColorScope::setParentScope(ColorScope* parentScope)
ColorScope *ColorScope::findParentScope() ColorScope *ColorScope::findParentScope()
{ {
QObject *p = nullptr; QQuickItem *candidate = qobject_cast<QQuickItem *>(parentItem());
if (m_parent) { if (!candidate) {
QQuickItem *gp = qobject_cast<QQuickItem *>(m_parent); candidate = qobject_cast<QQuickItem *>(parent());
if (gp) {
p = gp->parentItem();
} else {
p = m_parent->parent();
} }
while (candidate) {
candidate = candidate->parentItem();
ColorScope *s = qobject_cast<ColorScope *>(candidate);
if (!s) {
// Make sure AppletInterface always has a ColorScope
s = static_cast<ColorScope *>(qmlAttachedPropertiesObject<ColorScope>(candidate, qobject_cast<PlasmaQuick::AppletQuickItem *>(candidate)));
} }
if (!p || !m_parent) { if (s) {
setParentScope(nullptr); setParentScope(s);
return s;
}
}
return nullptr; return nullptr;
}
ColorScope *c = qobject_cast<ColorScope *>(p);
if (!c) {
c = qmlAttachedProperties(p);
}
setParentScope(c);
return m_parentScope;
} }
void ColorScope::setColorGroup(Plasma::Theme::ColorGroup group) void ColorScope::setColorGroup(Plasma::Theme::ColorGroup group)

View File

@ -119,8 +119,6 @@ public:
ColorScope *findParentScope(); ColorScope *findParentScope();
void itemChange(ItemChange change, const ItemChangeData &value) override; void itemChange(ItemChange change, const ItemChangeData &value) override;
bool eventFilter(QObject * watched, QEvent * event) override;
Q_SIGNALS: Q_SIGNALS:
void colorGroupChanged(); void colorGroupChanged();
void colorsChanged(); void colorsChanged();

View File

@ -14,8 +14,8 @@
viewBox="0 0 32.808331 13.758333" viewBox="0 0 32.808331 13.758333"
id="svg2" id="svg2"
version="1.1" version="1.1"
inkscape:version="0.48.5 r10040" inkscape:version="0.92.2 5c3e80d, 2017-08-06"
sodipodi:docname="configuration-icons.svgz"> sodipodi:docname="configuration-icons.svg">
<defs <defs
id="defs4"> id="defs4">
<style <style
@ -89,8 +89,8 @@
inkscape:pageopacity="0" inkscape:pageopacity="0"
inkscape:pageshadow="2" inkscape:pageshadow="2"
inkscape:zoom="5.6568543" inkscape:zoom="5.6568543"
inkscape:cx="99.567016" inkscape:cx="77.028937"
inkscape:cy="20.265624" inkscape:cy="12.789538"
inkscape:document-units="px" inkscape:document-units="px"
inkscape:current-layer="layer1" inkscape:current-layer="layer1"
showgrid="true" showgrid="true"
@ -98,9 +98,9 @@
inkscape:showpageshadow="false" inkscape:showpageshadow="false"
borderlayer="true" borderlayer="true"
inkscape:window-width="1920" inkscape:window-width="1920"
inkscape:window-height="1029" inkscape:window-height="1015"
inkscape:window-x="0" inkscape:window-x="0"
inkscape:window-y="-3" inkscape:window-y="0"
inkscape:window-maximized="1" inkscape:window-maximized="1"
fit-margin-top="0" fit-margin-top="0"
fit-margin-left="0" fit-margin-left="0"
@ -115,19 +115,23 @@
<sodipodi:guide <sodipodi:guide
position="2.4294816e-09,13.758295" position="2.4294816e-09,13.758295"
orientation="16.000015,0" orientation="16.000015,0"
id="guide4136" /> id="guide4136"
inkscape:locked="false" />
<sodipodi:guide <sodipodi:guide
position="2.4294816e-09,9.524957" position="2.4294816e-09,9.524957"
orientation="0,16" orientation="0,16"
id="guide4138" /> id="guide4138"
inkscape:locked="false" />
<sodipodi:guide <sodipodi:guide
position="4.2333331,9.524957" position="4.2333331,9.524957"
orientation="-16.000015,0" orientation="-16.000015,0"
id="guide4140" /> id="guide4140"
inkscape:locked="false" />
<sodipodi:guide <sodipodi:guide
position="4.2333331,13.758295" position="4.2333331,13.758295"
orientation="0,-16" orientation="0,-16"
id="guide4142" /> id="guide4142"
inkscape:locked="false" />
</sodipodi:namedview> </sodipodi:namedview>
<metadata <metadata
id="metadata7"> id="metadata7">
@ -658,13 +662,54 @@
cx="25.400003" cx="25.400003"
id="path4139" id="path4139"
style="opacity:1;fill:currentColor;fill-opacity:1;stroke:none" style="opacity:1;fill:currentColor;fill-opacity:1;stroke:none"
class="ColorScheme-Background" class="ColorScheme-Background" />
d="m 26.458337,261.0166 c 0,0.5845 -0.473832,1.05833 -1.058334,1.05833 -0.584501,0 -1.058333,-0.47383 -1.058333,-1.05833 0,-0.5845 0.473832,-1.05833 1.058333,-1.05833 0.584502,0 1.058334,0.47383 1.058334,1.05833 z" />
<path <path
inkscape:connector-curvature="0" inkscape:connector-curvature="0"
id="path4142" id="path4142"
d="m 25.400004,259.42911 a 1.5875,1.5875 0 0 0 -1.5875,1.5875 1.5875,1.5875 0 0 0 1.5875,1.5875 1.5875,1.5875 0 0 0 1.5875,-1.5875 1.5875,1.5875 0 0 0 -1.5875,-1.5875 z m -0.606682,0.79375 0.606682,0.60668 0.606681,-0.60668 0.187069,0.18707 -0.606682,0.60668 0.606682,0.60668 -0.187069,0.18707 -0.606681,-0.60668 -0.606682,0.60668 -0.187068,-0.18707 0.606681,-0.60668 -0.606681,-0.60668 0.187068,-0.18707 z" d="m 25.400004,259.42911 a 1.5875,1.5875 0 0 0 -1.5875,1.5875 1.5875,1.5875 0 0 0 1.5875,1.5875 1.5875,1.5875 0 0 0 1.5875,-1.5875 1.5875,1.5875 0 0 0 -1.5875,-1.5875 z m -0.606682,0.79375 0.606682,0.60668 0.606681,-0.60668 0.187069,0.18707 -0.606682,0.60668 0.606682,0.60668 -0.187069,0.18707 -0.606681,-0.60668 -0.606682,0.60668 -0.187068,-0.18707 0.606681,-0.60668 -0.606681,-0.60668 0.187068,-0.18707 z"
style="opacity:1;fill:#da4453;fill-opacity:1;stroke:none" /> style="opacity:1;fill:#da4453;fill-opacity:1;stroke:none" />
</g> </g>
<g
id="showbackground">
<g
id="g942">
<rect
class="ColorScheme-Background"
ry="0.12427091"
y="259.69373"
x="28.574997"
height="2.6458437"
width="2.6458342"
id="rect929"
style="opacity:0.8;fill:currentColor" />
<rect
y="258.89993"
x="27.858765"
height="4.2333322"
width="4.2333336"
id="rect908"
style="opacity:1;fill:none;fill-opacity:1;stroke:none" />
<path
inkscape:connector-curvature="0"
class="ColorScheme-Text"
style="opacity:0.4;fill:currentColor"
d="m 110,38 c -0.55407,0 -1,0.445928 -1,1 v 10 c 0,0.554072 0.44593,1 1,1 h 10 c 0.55407,0 1,-0.445928 1,-1 V 39 c 0,-0.554072 -0.44593,-1 -1,-1 z m 0.46875,1 h 9.0625 C 119.79146,39 120,39.210497 120,39.470703 V 48.53125 C 120,48.791456 119.79146,49 119.53125,49 h -9.0625 C 110.20854,49 110,48.791456 110,48.53125 V 39.470703 C 110,39.210497 110.20854,39 110.46875,39 Z"
transform="matrix(0.26458332,0,0,0.26458332,-0.5291667,249.37493)"
id="rect910" />
<g
aria-label="a"
transform="scale(0.92487808,1.0812236)"
style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:2.64862061px;line-height:125%;font-family:'Noto Sans';-inkscape-font-specification:'Noto Sans';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.26458335px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
id="text927">
<path
class="ColorScheme-Text"
d="m 32.390856,240.67151 c 0.173043,0 0.30106,0.038 0.38405,0.11389 0.08299,0.0759 0.124486,0.19688 0.124486,0.36286 v 0.99379 H 32.72988 l -0.04503,-0.22834 h -0.01059 c -0.0618,0.0777 -0.127133,0.13508 -0.195998,0.17216 -0.06886,0.0371 -0.162449,0.0556 -0.280754,0.0556 -0.1289,0 -0.235727,-0.0335 -0.320483,-0.10065 -0.08476,-0.0689 -0.122393,-0.17569 -0.122393,-0.32048 0,-0.14126 0.05088,-0.28618 0.162122,-0.3621 0.111242,-0.0777 0.282519,-0.11816 0.513833,-0.12522 l 0.241024,-0.008 v -0.0504 c 0,-0.11831 -0.0256,-0.20042 -0.07681,-0.24633 -0.05121,-0.0459 -0.123603,-0.0689 -0.217187,-0.0689 -0.07416,0 -0.144791,0.0115 -0.211889,0.0344 -0.0671,0.0212 -0.129783,0.0459 -0.188052,0.0742 l -0.07151,-0.17481 c 0.0618,-0.0335 0.135078,-0.0618 0.219835,-0.0848 0.08476,-0.0247 0.173043,-0.0371 0.264862,-0.0371 z m 0.278106,0.73618 -0.209242,0.008 c -0.176575,0.007 -0.299294,0.0334 -0.368158,0.0829 -0.0671,0.0495 -0.100647,0.1345 -0.100647,0.22453 0,0.0795 0.02384,0.13773 0.07151,0.17481 0.04944,0.0371 0.112124,0.0556 0.188052,0.0556 0.118305,0 0.217187,-0.0327 0.296646,-0.098 0.08122,-0.0671 0.121837,-0.16951 0.121837,-0.30724 z"
style="fill:currentColor"
id="path934"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccscccccscscccscscccccccccscsccc" />
</g>
</g>
</g>
</g> </g>
</svg> </svg>

Before

Width:  |  Height:  |  Size: 28 KiB

After

Width:  |  Height:  |  Size: 31 KiB

View File

@ -280,9 +280,13 @@ public:
NoBackground = 0, /**< Not drawing a background under the applet, the applet has its own implementation */ NoBackground = 0, /**< Not drawing a background under the applet, the applet has its own implementation */
StandardBackground = 1, /**< The standard background from the theme is drawn */ StandardBackground = 1, /**< The standard background from the theme is drawn */
TranslucentBackground = 2, /**< An alternate version of the background is drawn, usually more translucent */ TranslucentBackground = 2, /**< An alternate version of the background is drawn, usually more translucent */
ShadowBackground = 4, /**< The applet won't have a svg background but a drop shadow of its content done via a shader */
ConfigurableBackground = 8, /** If the hint has this flag, the user is able to configure this background */
DefaultBackground = StandardBackground /**< Default settings: both standard background */ DefaultBackground = StandardBackground /**< Default settings: both standard background */
}; };
Q_ENUM(BackgroundHints) Q_ENUM(BackgroundHints)
//TODO KF6: BackgroundHint and BackgroundHints
Q_DECLARE_FLAGS(BackgroundFlags, BackgroundHints)
private: private:
Types(QObject *parent = nullptr); Types(QObject *parent = nullptr);
@ -311,5 +315,5 @@ PLASMA_EXPORT Types::Direction locationToInverseDirection(Types::Location locati
Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::Constraints) Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::Constraints)
Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::Flip) Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::Flip)
Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::ComponentTypes) Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::ComponentTypes)
Q_DECLARE_OPERATORS_FOR_FLAGS(Plasma::Types::BackgroundFlags)
#endif // multiple inclusion guard #endif // multiple inclusion guard

View File

@ -54,6 +54,7 @@ AppletInterface::AppletInterface(DeclarativeAppletScript *script, const QVariant
m_toolTipItem(nullptr), m_toolTipItem(nullptr),
m_args(args), m_args(args),
m_backgroundHints(Plasma::Types::StandardBackground), m_backgroundHints(Plasma::Types::StandardBackground),
m_userBackgroundHints(Plasma::Types::StandardBackground),
m_hideOnDeactivate(true), m_hideOnDeactivate(true),
m_oldKeyboardShortcut(0), m_oldKeyboardShortcut(0),
m_dummyNativeInterface(nullptr), m_dummyNativeInterface(nullptr),
@ -193,6 +194,19 @@ void AppletInterface::init()
} else if (!m_args.isEmpty()) { } else if (!m_args.isEmpty()) {
emit externalData(QString(), m_args); emit externalData(QString(), m_args);
} }
QByteArray hintsString = applet()->config().readEntry("UserBackgroundHints", QString()).toUtf8();
QMetaEnum hintEnum = QMetaEnum::fromType<Plasma::Types::BackgroundHints>();
bool ok;
int value = hintEnum.keyToValue(hintsString.constData(), &ok);
if (ok) {
m_userBackgroundHints = Plasma::Types::BackgroundHints(value);
m_userBackgroundHintsInitialized = true;
emit userBackgroundHintsChanged();
if (m_backgroundHints & Plasma::Types::ConfigurableBackground) {
emit effectiveBackgroundHintsChanged();
}
}
} }
void AppletInterface::destroyedChanged(bool destroyed) void AppletInterface::destroyedChanged(bool destroyed)
@ -395,8 +409,50 @@ void AppletInterface::setBackgroundHints(Plasma::Types::BackgroundHints hint)
return; return;
} }
Plasma::Types::BackgroundHints oldeffectiveHints = effectiveBackgroundHints();
m_backgroundHints = hint; m_backgroundHints = hint;
emit backgroundHintsChanged(); emit backgroundHintsChanged();
if (oldeffectiveHints != effectiveBackgroundHints()) {
emit effectiveBackgroundHintsChanged();
}
}
Plasma::Types::BackgroundHints AppletInterface::effectiveBackgroundHints() const
{
if (m_userBackgroundHintsInitialized
&& (m_backgroundHints & Plasma::Types::ConfigurableBackground)) {
return m_userBackgroundHints;
} else {
return m_backgroundHints;
}
}
Plasma::Types::BackgroundHints AppletInterface::userBackgroundHints() const
{
return m_userBackgroundHints;
}
void AppletInterface::setUserBackgroundHints(Plasma::Types::BackgroundHints hint)
{
if (m_userBackgroundHints == hint && m_userBackgroundHintsInitialized) {
return;
}
m_userBackgroundHints = hint;
m_userBackgroundHintsInitialized = true;
QMetaEnum hintEnum = QMetaEnum::fromType<Plasma::Types::BackgroundHints>();
applet()->config().writeEntry("UserBackgroundHints", hintEnum.valueToKey(m_userBackgroundHints));
if (applet()->containment() && applet()->containment()->corona()) {
applet()->containment()->corona()->requestConfigSync();
}
emit userBackgroundHintsChanged();
if (m_backgroundHints & Plasma::Types::ConfigurableBackground) {
emit effectiveBackgroundHintsChanged();
}
} }
void AppletInterface::setConfigurationRequired(bool needsConfiguring, const QString &reason) void AppletInterface::setConfigurationRequired(bool needsConfiguring, const QString &reason)

View File

@ -147,6 +147,16 @@ class AppletInterface : public PlasmaQuick::AppletQuickItem
*/ */
Q_PROPERTY(Plasma::Types::BackgroundHints backgroundHints WRITE setBackgroundHints READ backgroundHints NOTIFY backgroundHintsChanged) Q_PROPERTY(Plasma::Types::BackgroundHints backgroundHints WRITE setBackgroundHints READ backgroundHints NOTIFY backgroundHintsChanged)
/**
* The containment (and/or the user) may decide to use another kind of background instead (if supported by the applet)
*/
Q_PROPERTY(Plasma::Types::BackgroundHints userBackgroundHints WRITE setUserBackgroundHints READ userBackgroundHints NOTIFY userBackgroundHintsChanged)
/**
* The effective background hints the applet has, internally decided how to mix with userBackgroundHints
*/
Q_PROPERTY(Plasma::Types::BackgroundHints effectiveBackgroundHints READ effectiveBackgroundHints NOTIFY effectiveBackgroundHintsChanged)
/** /**
* Whether the Corona is immutable. The plasmoid implementation should avoid allowing "dangerous" modifications from the user when in an immutable mode * Whether the Corona is immutable. The plasmoid implementation should avoid allowing "dangerous" modifications from the user when in an immutable mode
* *
@ -368,6 +378,11 @@ public:
Plasma::Types::BackgroundHints backgroundHints() const; Plasma::Types::BackgroundHints backgroundHints() const;
void setBackgroundHints(Plasma::Types::BackgroundHints hint); void setBackgroundHints(Plasma::Types::BackgroundHints hint);
Plasma::Types::BackgroundHints userBackgroundHints() const;
void setUserBackgroundHints(Plasma::Types::BackgroundHints hint);
Plasma::Types::BackgroundHints effectiveBackgroundHints() const;
void setAssociatedApplication(const QString &string); void setAssociatedApplication(const QString &string);
QString associatedApplication() const; QString associatedApplication() const;
@ -436,6 +451,8 @@ Q_SIGNALS:
void immutabilityChanged(); void immutabilityChanged();
void statusChanged(); void statusChanged();
void backgroundHintsChanged(); void backgroundHintsChanged();
void userBackgroundHintsChanged();
void effectiveBackgroundHintsChanged();
void busyChanged(); void busyChanged();
void screenChanged(); void screenChanged();
void screenGeometryChanged(); void screenGeometryChanged();
@ -486,6 +503,8 @@ private:
QPointer<QQuickItem> m_toolTipItem; QPointer<QQuickItem> m_toolTipItem;
QVariantList m_args; QVariantList m_args;
Plasma::Types::BackgroundHints m_backgroundHints; Plasma::Types::BackgroundHints m_backgroundHints;
Plasma::Types::BackgroundHints m_userBackgroundHints;
bool m_userBackgroundHintsInitialized = false;
bool m_hideOnDeactivate : 1; bool m_hideOnDeactivate : 1;
bool m_loading = false; bool m_loading = false;
//this is used to build an emacs style shortcut //this is used to build an emacs style shortcut