mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-22 20:04:32 +08:00
Compare commits
2 Commits
44acdbcf7f
...
44f7948df3
Author | SHA1 | Date | |
---|---|---|---|
|
44f7948df3 | ||
|
0ab315e258 |
@ -2190,6 +2190,11 @@ Some contents...</source>
|
|||||||
<source>Open Animation</source>
|
<source>Open Animation</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="qml/page/T_Theme.qml" line="123"/>
|
||||||
|
<source>Open Blur Window</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>T_TimePicker</name>
|
<name>T_TimePicker</name>
|
||||||
|
@ -2280,6 +2280,11 @@ Some contents...</source>
|
|||||||
<source>Open Animation</source>
|
<source>Open Animation</source>
|
||||||
<translation type="unfinished">开启动画</translation>
|
<translation type="unfinished">开启动画</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="qml/page/T_Theme.qml" line="123"/>
|
||||||
|
<source>Open Blur Window</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>T_TimePicker</name>
|
<name>T_TimePicker</name>
|
||||||
|
@ -13,7 +13,7 @@ FluScrollablePage{
|
|||||||
|
|
||||||
FluFrame{
|
FluFrame{
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 340
|
Layout.preferredHeight: 400
|
||||||
padding: 10
|
padding: 10
|
||||||
|
|
||||||
ColumnLayout{
|
ColumnLayout{
|
||||||
@ -119,6 +119,17 @@ FluScrollablePage{
|
|||||||
FluTheme.animationEnabled = !FluTheme.animationEnabled
|
FluTheme.animationEnabled = !FluTheme.animationEnabled
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
FluText{
|
||||||
|
text: qsTr("Open Blur Window")
|
||||||
|
Layout.topMargin: 20
|
||||||
|
}
|
||||||
|
FluToggleSwitch{
|
||||||
|
Layout.topMargin: 5
|
||||||
|
checked: FluTheme.blurBehindWindowEnabled
|
||||||
|
onClicked: {
|
||||||
|
FluTheme.blurBehindWindowEnabled = !FluTheme.blurBehindWindowEnabled
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CodeExpander{
|
CodeExpander{
|
||||||
|
@ -21,4 +21,4 @@ private: \
|
|||||||
public: \
|
public: \
|
||||||
static Class* getInstance() { \
|
static Class* getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
} \
|
}
|
||||||
|
@ -14,7 +14,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
|
||||||
#define Q_PROPERTY_AUTO(TYPE, M) \
|
#define Q_PROPERTY_AUTO(TYPE, M) \
|
||||||
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
||||||
@ -30,7 +30,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
|
||||||
|
|
||||||
#define Q_PROPERTY_READONLY_AUTO(TYPE, M) \
|
#define Q_PROPERTY_READONLY_AUTO(TYPE, M) \
|
||||||
@ -47,4 +47,4 @@ Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
@ -143,11 +143,7 @@ if (QT_VERSION VERSION_GREATER_EQUAL "6.2")
|
|||||||
RESOURCE_PREFIX "/qt/qml"
|
RESOURCE_PREFIX "/qt/qml"
|
||||||
)
|
)
|
||||||
else ()
|
else ()
|
||||||
#加快qrc编译
|
qt_add_resources(QRC_RESOURCES Qt5/imports/fluentui.qrc)
|
||||||
set(QRC_FILE Qt5/imports/fluentui.qrc)
|
|
||||||
qt_add_big_resources(QRC_RESOURCES ${QRC_FILE})
|
|
||||||
list(APPEND QRC_RESOURCES ${QRC_FILE})
|
|
||||||
set_property(SOURCE ${QRC_FILE} PROPERTY SKIP_AUTORCC ON)
|
|
||||||
#如果是Qt6.2版本以下,则使用add_qmlplugin函数添加资源文件,这是个自定义的函数,详情见.cmake/QmlPlugin.cmake
|
#如果是Qt6.2版本以下,则使用add_qmlplugin函数添加资源文件,这是个自定义的函数,详情见.cmake/QmlPlugin.cmake
|
||||||
include(QmlPlugin)
|
include(QmlPlugin)
|
||||||
add_qmlplugin(${PROJECT_NAME}
|
add_qmlplugin(${PROJECT_NAME}
|
||||||
|
@ -2,9 +2,11 @@
|
|||||||
|
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
#include <QPalette>
|
#include <QPalette>
|
||||||
|
#include <QImage>
|
||||||
#include "Def.h"
|
#include "Def.h"
|
||||||
#include "FluentIconDef.h"
|
#include "FluentIconDef.h"
|
||||||
#include "FluColors.h"
|
#include "FluColors.h"
|
||||||
|
#include "FluTools.h"
|
||||||
|
|
||||||
bool systemDark() {
|
bool systemDark() {
|
||||||
QPalette palette = QGuiApplication::palette();
|
QPalette palette = QGuiApplication::palette();
|
||||||
@ -18,13 +20,20 @@ FluTheme::FluTheme(QObject *parent) : QObject{parent} {
|
|||||||
_nativeText = false;
|
_nativeText = false;
|
||||||
_animationEnabled = true;
|
_animationEnabled = true;
|
||||||
_systemDark = systemDark();
|
_systemDark = systemDark();
|
||||||
|
_desktopImagePath = "";
|
||||||
|
_blurBehindWindowEnabled = false;
|
||||||
QGuiApplication::instance()->installEventFilter(this);
|
QGuiApplication::instance()->installEventFilter(this);
|
||||||
|
refreshColors();
|
||||||
|
updateDesktopImage();
|
||||||
connect(this, &FluTheme::darkModeChanged, this, [=] {
|
connect(this, &FluTheme::darkModeChanged, this, [=] {
|
||||||
Q_EMIT darkChanged();
|
Q_EMIT darkChanged();
|
||||||
});
|
});
|
||||||
connect(this, &FluTheme::darkChanged, this, [=] { refreshColors(); });
|
connect(this, &FluTheme::darkChanged, this, [=] { refreshColors(); });
|
||||||
connect(this, &FluTheme::accentColorChanged, this, [=] { refreshColors(); });
|
connect(this, &FluTheme::accentColorChanged, this, [=] { refreshColors(); });
|
||||||
refreshColors();
|
connect(&_watcher, &QFileSystemWatcher::fileChanged, this, [=](const QString &path){
|
||||||
|
Q_EMIT desktopImagePathChanged();
|
||||||
|
});
|
||||||
|
startTimer(500);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTheme::refreshColors() {
|
void FluTheme::refreshColors() {
|
||||||
@ -38,6 +47,8 @@ void FluTheme::refreshColors() {
|
|||||||
fontSecondaryColor(isDark ? QColor(222, 222, 222, 255) : QColor(102, 102, 102, 255));
|
fontSecondaryColor(isDark ? QColor(222, 222, 222, 255) : QColor(102, 102, 102, 255));
|
||||||
fontTertiaryColor(isDark ? QColor(200, 200, 200, 255) : QColor(153, 153, 153, 255));
|
fontTertiaryColor(isDark ? QColor(200, 200, 200, 255) : QColor(153, 153, 153, 255));
|
||||||
itemNormalColor(isDark ? QColor(255, 255, 255, 0) : QColor(0, 0, 0, 0));
|
itemNormalColor(isDark ? QColor(255, 255, 255, 0) : QColor(0, 0, 0, 0));
|
||||||
|
frameColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12)) : QColor(0, 0, 0, qRound(255 * 0.09)));
|
||||||
|
frameActiveColor(isDark ? QColor(32, 32, 32, qRound(255 * 0.8)) : QColor(255, 255, 255, qRound(255 * 0.6)));
|
||||||
itemHoverColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.06)) : QColor(0, 0, 0, qRound(255 * 0.03)));
|
itemHoverColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.06)) : QColor(0, 0, 0, qRound(255 * 0.03)));
|
||||||
itemPressColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.09)) : QColor(0, 0, 0, qRound(255 * 0.06)));
|
itemPressColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.09)) : QColor(0, 0, 0, qRound(255 * 0.06)));
|
||||||
itemCheckColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12)) : QColor(0, 0, 0, qRound(255 * 0.09)));
|
itemCheckColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12)) : QColor(0, 0, 0, qRound(255 * 0.09)));
|
||||||
@ -78,3 +89,19 @@ bool FluTheme::dark() const {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FluTheme::updateDesktopImage(){
|
||||||
|
auto path = FluTools::getInstance()->getWallpaperFilePath();
|
||||||
|
if(_desktopImagePath != path){
|
||||||
|
if(!_desktopImagePath.isEmpty()){
|
||||||
|
_watcher.removePath(_desktopImagePath);
|
||||||
|
}
|
||||||
|
desktopImagePath(path);
|
||||||
|
_watcher.addPath(path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void FluTheme::timerEvent(QTimerEvent *event)
|
||||||
|
{
|
||||||
|
updateDesktopImage();
|
||||||
|
}
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
#include <QJsonArray>
|
#include <QJsonArray>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
#include <QColor>
|
#include <QColor>
|
||||||
|
#include <QTimer>
|
||||||
|
#include <QFileSystemWatcher>
|
||||||
#include "FluAccentColor.h"
|
#include "FluAccentColor.h"
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "singleton.h"
|
#include "singleton.h"
|
||||||
@ -15,7 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
class FluTheme : public QObject {
|
class FluTheme : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY(bool dark READ dark NOTIFY darkChanged)
|
Q_PROPERTY(bool dark READ dark NOTIFY darkChanged)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, accentColor);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, accentColor);
|
||||||
Q_PROPERTY_AUTO(QColor, primaryColor);
|
Q_PROPERTY_AUTO(QColor, primaryColor);
|
||||||
Q_PROPERTY_AUTO(QColor, backgroundColor);
|
Q_PROPERTY_AUTO(QColor, backgroundColor);
|
||||||
@ -26,12 +28,16 @@ Q_PROPERTY_AUTO(QColor, fontPrimaryColor);
|
|||||||
Q_PROPERTY_AUTO(QColor, fontSecondaryColor);
|
Q_PROPERTY_AUTO(QColor, fontSecondaryColor);
|
||||||
Q_PROPERTY_AUTO(QColor, fontTertiaryColor);
|
Q_PROPERTY_AUTO(QColor, fontTertiaryColor);
|
||||||
Q_PROPERTY_AUTO(QColor, itemNormalColor);
|
Q_PROPERTY_AUTO(QColor, itemNormalColor);
|
||||||
|
Q_PROPERTY_AUTO(QColor, frameColor);
|
||||||
|
Q_PROPERTY_AUTO(QColor, frameActiveColor);
|
||||||
Q_PROPERTY_AUTO(QColor, itemHoverColor);
|
Q_PROPERTY_AUTO(QColor, itemHoverColor);
|
||||||
Q_PROPERTY_AUTO(QColor, itemPressColor);
|
Q_PROPERTY_AUTO(QColor, itemPressColor);
|
||||||
Q_PROPERTY_AUTO(QColor, itemCheckColor);
|
Q_PROPERTY_AUTO(QColor, itemCheckColor);
|
||||||
|
Q_PROPERTY_AUTO(QString, desktopImagePath);
|
||||||
Q_PROPERTY_AUTO(int, darkMode);
|
Q_PROPERTY_AUTO(int, darkMode);
|
||||||
Q_PROPERTY_AUTO(bool, nativeText);
|
Q_PROPERTY_AUTO(bool, nativeText);
|
||||||
Q_PROPERTY_AUTO(bool, animationEnabled);
|
Q_PROPERTY_AUTO(bool, animationEnabled);
|
||||||
|
Q_PROPERTY_AUTO(bool, blurBehindWindowEnabled);
|
||||||
QML_NAMED_ELEMENT(FluTheme)
|
QML_NAMED_ELEMENT(FluTheme)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
@ -42,6 +48,14 @@ private:
|
|||||||
|
|
||||||
void refreshColors();
|
void refreshColors();
|
||||||
|
|
||||||
|
void updateBackgroundMainColor();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
void timerEvent(QTimerEvent *event) override;
|
||||||
|
|
||||||
|
void updateDesktopImage();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluTheme)
|
SINGLETON(FluTheme)
|
||||||
|
|
||||||
@ -55,6 +69,7 @@ SINGLETON(FluTheme)
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
bool _systemDark;
|
bool _systemDark;
|
||||||
|
QFileSystemWatcher _watcher;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUTHEME_H
|
#endif // FLUTHEME_H
|
||||||
|
@ -16,6 +16,14 @@
|
|||||||
#include <QDateTime>
|
#include <QDateTime>
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
|
|
||||||
|
#ifdef Q_OS_WIN
|
||||||
|
#pragma comment (lib, "user32.lib")
|
||||||
|
|
||||||
|
#include <windows.h>
|
||||||
|
#include <windowsx.h>
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
FluTools::FluTools(QObject *parent) : QObject{parent} {
|
FluTools::FluTools(QObject *parent) : QObject{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -244,3 +252,32 @@ bool FluTools::isWindows10OrGreater() {
|
|||||||
QRect FluTools::desktopAvailableGeometry(QQuickWindow *window) {
|
QRect FluTools::desktopAvailableGeometry(QQuickWindow *window) {
|
||||||
return window->screen()->availableGeometry();
|
return window->screen()->availableGeometry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString FluTools::getWallpaperFilePath() {
|
||||||
|
#if defined(Q_OS_WIN)
|
||||||
|
wchar_t path[MAX_PATH] = {};
|
||||||
|
if (::SystemParametersInfoW(SPI_GETDESKWALLPAPER, MAX_PATH, path, FALSE) == FALSE) {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
return QString::fromWCharArray(path);
|
||||||
|
#endif
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
QColor FluTools::imageMainColor(const QImage& image, double bright) {
|
||||||
|
int step = 20;
|
||||||
|
int t = 0;
|
||||||
|
int r = 0, g = 0, b = 0;
|
||||||
|
for (int i = 0; i < image.width(); i += step) {
|
||||||
|
for (int j = 0; j < image.height(); j += step) {
|
||||||
|
if (image.valid(i, j)) {
|
||||||
|
t++;
|
||||||
|
QColor c = image.pixel(i, j);
|
||||||
|
r += c.red();
|
||||||
|
b += c.blue();
|
||||||
|
g += c.green();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return QColor(int(bright * r / t) > 255 ? 255 : int(bright * r / t), int(bright * g / t) > 255 ? 255 : int(bright * g / t), int(bright * b / t) > 255 ? 255 : int(bright * b / t));
|
||||||
|
}
|
||||||
|
@ -92,4 +92,8 @@ SINGLETON(FluTools)
|
|||||||
Q_INVOKABLE bool isWindows10OrGreater();
|
Q_INVOKABLE bool isWindows10OrGreater();
|
||||||
|
|
||||||
Q_INVOKABLE QRect desktopAvailableGeometry(QQuickWindow *window);
|
Q_INVOKABLE QRect desktopAvailableGeometry(QQuickWindow *window);
|
||||||
};
|
|
||||||
|
Q_INVOKABLE QString getWallpaperFilePath();
|
||||||
|
|
||||||
|
Q_INVOKABLE QColor imageMainColor(const QImage& image, double bright = 1);
|
||||||
|
};
|
||||||
|
@ -8,7 +8,7 @@ Item {
|
|||||||
property real tintOpacity: 0.65
|
property real tintOpacity: 0.65
|
||||||
property real luminosity: 0.01
|
property real luminosity: 0.01
|
||||||
property real noiseOpacity: 0.02
|
property real noiseOpacity: 0.02
|
||||||
property alias target: effect_source.sourceItem
|
property var target
|
||||||
property int blurRadius: 32
|
property int blurRadius: 32
|
||||||
property rect targetRect: Qt.rect(control.x, control.y, control.width,control.height)
|
property rect targetRect: Qt.rect(control.x, control.y, control.width,control.height)
|
||||||
ShaderEffectSource {
|
ShaderEffectSource {
|
||||||
@ -16,6 +16,7 @@ Item {
|
|||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
visible: false
|
visible: false
|
||||||
sourceRect: control.targetRect
|
sourceRect: control.targetRect
|
||||||
|
sourceItem: control.target
|
||||||
}
|
}
|
||||||
FastBlur {
|
FastBlur {
|
||||||
id: fast_blur
|
id: fast_blur
|
||||||
@ -33,7 +34,7 @@ Item {
|
|||||||
}
|
}
|
||||||
Image {
|
Image {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
source: "../Image/noise.png"
|
source: "qrc:/qt/qml/FluentUI/Image/noise.png"
|
||||||
fillMode: Image.Tile
|
fillMode: Image.Tile
|
||||||
opacity: control.noiseOpacity
|
opacity: control.noiseOpacity
|
||||||
}
|
}
|
||||||
|
@ -76,10 +76,11 @@ FluButton {
|
|||||||
}
|
}
|
||||||
contentItem: Item{
|
contentItem: Item{
|
||||||
clip: true
|
clip: true
|
||||||
FluFrame{
|
Rectangle{
|
||||||
id:container
|
id:container
|
||||||
width: 300
|
width: 300
|
||||||
height: 360
|
height: 360
|
||||||
|
color: FluTheme.dark ? Qt.rgba(51/255,48/255,48/255,1) : Qt.rgba(248/255,250/255,253/255,1)
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
spacing: 0
|
spacing: 0
|
||||||
|
@ -27,7 +27,12 @@ Item {
|
|||||||
height: 45
|
height: 45
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
MouseArea{
|
MouseArea{
|
||||||
id:control_mouse
|
id:control_mouse
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
@ -84,12 +89,18 @@ Item {
|
|||||||
height: contentHeight+container.anchors.topMargin
|
height: contentHeight+container.anchors.topMargin
|
||||||
width: parent.width
|
width: parent.width
|
||||||
z:-999
|
z:-999
|
||||||
|
clip: true
|
||||||
Rectangle{
|
Rectangle{
|
||||||
id:container
|
id:container
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
radius: 4
|
radius: 4
|
||||||
clip: true
|
clip: true
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
anchors.topMargin: -contentHeight
|
anchors.topMargin: -contentHeight
|
||||||
states: [
|
states: [
|
||||||
|
@ -19,6 +19,11 @@ T.Frame {
|
|||||||
id:d
|
id:d
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,8 +8,13 @@ import FluentUI 1.0
|
|||||||
T.GroupBox {
|
T.GroupBox {
|
||||||
id: control
|
id: control
|
||||||
property int borderWidth : 1
|
property int borderWidth : 1
|
||||||
property color borderColor : FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1):Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
property color borderColor : FluTheme.dividerColor
|
||||||
property color color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
property color color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
property int radius: 4
|
property int radius: 4
|
||||||
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
|
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
|
||||||
contentWidth + leftPadding + rightPadding,
|
contentWidth + leftPadding + rightPadding,
|
||||||
|
@ -109,8 +109,53 @@ Window {
|
|||||||
}
|
}
|
||||||
Component{
|
Component{
|
||||||
id:com_background
|
id:com_background
|
||||||
Rectangle{
|
Item{
|
||||||
color: window.backgroundColor
|
Rectangle{
|
||||||
|
anchors.fill: parent
|
||||||
|
color: window.backgroundColor
|
||||||
|
}
|
||||||
|
Image{
|
||||||
|
id:img_back
|
||||||
|
visible: false
|
||||||
|
cache: false
|
||||||
|
Component.onCompleted: {
|
||||||
|
var geometry = FluTools.desktopAvailableGeometry(window)
|
||||||
|
width = geometry.width
|
||||||
|
height = geometry.height
|
||||||
|
sourceSize = Qt.size(width,height)
|
||||||
|
source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}
|
||||||
|
Connections{
|
||||||
|
target: FluTheme
|
||||||
|
function onDesktopImagePathChanged(){
|
||||||
|
timer_update_image.restart()
|
||||||
|
}
|
||||||
|
function onBlurBehindWindowEnabledChanged(){
|
||||||
|
if(FluTheme.blurBehindWindowEnabled){
|
||||||
|
img_back.source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}else{
|
||||||
|
img_back.source = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Timer{
|
||||||
|
id:timer_update_image
|
||||||
|
interval: 500
|
||||||
|
onTriggered: {
|
||||||
|
img_back.source = ""
|
||||||
|
img_back.source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
FluAcrylic{
|
||||||
|
anchors.fill: parent
|
||||||
|
target: img_back
|
||||||
|
tintOpacity: FluTheme.dark ? 0.80 : 0.75
|
||||||
|
blurRadius: 64
|
||||||
|
visible: window.active && FluTheme.blurBehindWindowEnabled
|
||||||
|
tintColor: FluTheme.dark ? Qt.rgba(0, 0, 0, 1) : Qt.rgba(1, 1, 1, 1)
|
||||||
|
targetRect: Qt.rect(window.x,window.y,window.width,window.height)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Component{
|
Component{
|
||||||
|
@ -8,7 +8,7 @@ Item {
|
|||||||
property real tintOpacity: 0.65
|
property real tintOpacity: 0.65
|
||||||
property real luminosity: 0.01
|
property real luminosity: 0.01
|
||||||
property real noiseOpacity: 0.02
|
property real noiseOpacity: 0.02
|
||||||
property alias target: effect_source.sourceItem
|
property var target
|
||||||
property int blurRadius: 32
|
property int blurRadius: 32
|
||||||
property rect targetRect: Qt.rect(control.x, control.y, control.width,control.height)
|
property rect targetRect: Qt.rect(control.x, control.y, control.width,control.height)
|
||||||
ShaderEffectSource {
|
ShaderEffectSource {
|
||||||
@ -16,6 +16,7 @@ Item {
|
|||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
visible: false
|
visible: false
|
||||||
sourceRect: control.targetRect
|
sourceRect: control.targetRect
|
||||||
|
sourceItem: control.target
|
||||||
}
|
}
|
||||||
FastBlur {
|
FastBlur {
|
||||||
id: fast_blur
|
id: fast_blur
|
||||||
@ -33,7 +34,7 @@ Item {
|
|||||||
}
|
}
|
||||||
Image {
|
Image {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
source: "../Image/noise.png"
|
source: "qrc:/qt/qml/FluentUI/Image/noise.png"
|
||||||
fillMode: Image.Tile
|
fillMode: Image.Tile
|
||||||
opacity: control.noiseOpacity
|
opacity: control.noiseOpacity
|
||||||
}
|
}
|
||||||
|
@ -75,10 +75,11 @@ FluButton {
|
|||||||
}
|
}
|
||||||
contentItem: Item{
|
contentItem: Item{
|
||||||
clip: true
|
clip: true
|
||||||
FluFrame{
|
Rectangle{
|
||||||
id:container
|
id:container
|
||||||
width: 300
|
width: 300
|
||||||
height: 360
|
height: 360
|
||||||
|
color: FluTheme.dark ? Qt.rgba(51/255,48/255,48/255,1) : Qt.rgba(248/255,250/255,253/255,1)
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
spacing: 0
|
spacing: 0
|
||||||
|
@ -27,7 +27,12 @@ Item {
|
|||||||
height: 45
|
height: 45
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
MouseArea{
|
MouseArea{
|
||||||
id:control_mouse
|
id:control_mouse
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
@ -84,12 +89,18 @@ Item {
|
|||||||
height: contentHeight+container.anchors.topMargin
|
height: contentHeight+container.anchors.topMargin
|
||||||
width: parent.width
|
width: parent.width
|
||||||
z:-999
|
z:-999
|
||||||
|
clip: true
|
||||||
Rectangle{
|
Rectangle{
|
||||||
id:container
|
id:container
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
radius: 4
|
radius: 4
|
||||||
clip: true
|
clip: true
|
||||||
color: FluTheme.dark ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
anchors.topMargin: -contentHeight
|
anchors.topMargin: -contentHeight
|
||||||
states: [
|
states: [
|
||||||
|
@ -17,6 +17,11 @@ T.Frame {
|
|||||||
id:d
|
id:d
|
||||||
radius: 4
|
radius: 4
|
||||||
border.color: FluTheme.dividerColor
|
border.color: FluTheme.dividerColor
|
||||||
color: FluTheme.dark ? Window.active ? Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,8 +8,13 @@ import FluentUI
|
|||||||
T.GroupBox {
|
T.GroupBox {
|
||||||
id: control
|
id: control
|
||||||
property int borderWidth : 1
|
property int borderWidth : 1
|
||||||
property color borderColor : FluTheme.dark ? Window.active ? Qt.rgba(55/255,55/255,55/255,1):Qt.rgba(45/255,45/255,45/255,1) : Qt.rgba(226/255,229/255,234/255,1)
|
property color borderColor : FluTheme.dividerColor
|
||||||
property color color: FluTheme.dark ? Window.active ? Qt.rgba(38/255,44/255,54/255,1) : Qt.rgba(39/255,39/255,39/255,1) : Qt.rgba(251/255,251/255,253/255,1)
|
property color color: {
|
||||||
|
if(Window.active){
|
||||||
|
return FluTheme.frameActiveColor
|
||||||
|
}
|
||||||
|
return FluTheme.frameColor
|
||||||
|
}
|
||||||
property int radius: 4
|
property int radius: 4
|
||||||
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
|
implicitWidth: Math.max(implicitBackgroundWidth + leftInset + rightInset,
|
||||||
contentWidth + leftPadding + rightPadding,
|
contentWidth + leftPadding + rightPadding,
|
||||||
|
@ -108,8 +108,53 @@ Window {
|
|||||||
}
|
}
|
||||||
Component{
|
Component{
|
||||||
id:com_background
|
id:com_background
|
||||||
Rectangle{
|
Item{
|
||||||
color: window.backgroundColor
|
Rectangle{
|
||||||
|
anchors.fill: parent
|
||||||
|
color: window.backgroundColor
|
||||||
|
}
|
||||||
|
Image{
|
||||||
|
id:img_back
|
||||||
|
visible: false
|
||||||
|
cache: false
|
||||||
|
Component.onCompleted: {
|
||||||
|
var geometry = FluTools.desktopAvailableGeometry(window)
|
||||||
|
width = geometry.width
|
||||||
|
height = geometry.height
|
||||||
|
sourceSize = Qt.size(width,height)
|
||||||
|
source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}
|
||||||
|
Connections{
|
||||||
|
target: FluTheme
|
||||||
|
function onDesktopImagePathChanged(){
|
||||||
|
timer_update_image.restart()
|
||||||
|
}
|
||||||
|
function onBlurBehindWindowEnabledChanged(){
|
||||||
|
if(FluTheme.blurBehindWindowEnabled){
|
||||||
|
img_back.source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}else{
|
||||||
|
img_back.source = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Timer{
|
||||||
|
id:timer_update_image
|
||||||
|
interval: 500
|
||||||
|
onTriggered: {
|
||||||
|
img_back.source = ""
|
||||||
|
img_back.source = FluTools.getUrlByFilePath(FluTheme.desktopImagePath)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
FluAcrylic{
|
||||||
|
anchors.fill: parent
|
||||||
|
target: img_back
|
||||||
|
tintOpacity: FluTheme.dark ? 0.80 : 0.75
|
||||||
|
blurRadius: 64
|
||||||
|
visible: window.active && FluTheme.blurBehindWindowEnabled
|
||||||
|
tintColor: FluTheme.dark ? Qt.rgba(0, 0, 0, 1) : Qt.rgba(1, 1, 1, 1)
|
||||||
|
targetRect: Qt.rect(window.x,window.y,window.width,window.height)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Component{
|
Component{
|
||||||
|
@ -21,4 +21,4 @@ private: \
|
|||||||
public: \
|
public: \
|
||||||
static Class* getInstance() { \
|
static Class* getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
} \
|
}
|
||||||
|
@ -14,7 +14,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
|
||||||
#define Q_PROPERTY_AUTO(TYPE, M) \
|
#define Q_PROPERTY_AUTO(TYPE, M) \
|
||||||
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
||||||
@ -30,7 +30,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
|
||||||
|
|
||||||
#define Q_PROPERTY_READONLY_AUTO(TYPE, M) \
|
#define Q_PROPERTY_READONLY_AUTO(TYPE, M) \
|
||||||
@ -47,4 +47,4 @@ Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL)
|
|||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M;
|
||||||
|
Loading…
Reference in New Issue
Block a user