mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-22 20:04:32 +08:00
Compare commits
4 Commits
6a31e86505
...
531f659e59
Author | SHA1 | Date | |
---|---|---|---|
|
531f659e59 | ||
|
3f6ef13cd0 | ||
|
96fef84c2d | ||
|
a3f375c9ef |
@ -171,5 +171,10 @@ if (CMAKE_BUILD_TYPE MATCHES "Release")
|
|||||||
SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_sources(Script-DeployRelease
|
||||||
|
PRIVATE
|
||||||
|
src/component/OpenGLItem.h src/component/OpenGLItem.cpp
|
||||||
|
)
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
endif ()
|
||||||
|
@ -209,5 +209,7 @@
|
|||||||
<file>qml/page/T_GroupBox.qml</file>
|
<file>qml/page/T_GroupBox.qml</file>
|
||||||
<file>res/image/bg_scenic.jpg</file>
|
<file>res/image/bg_scenic.jpg</file>
|
||||||
<file>qml/window/FluentInitializrWindow.qml</file>
|
<file>qml/window/FluentInitializrWindow.qml</file>
|
||||||
|
<file>qml/page/T_OpenGL.qml</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
|
<qresource prefix="/"/>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
@ -87,22 +87,22 @@
|
|||||||
<context>
|
<context>
|
||||||
<name>InitializrHelper</name>
|
<name>InitializrHelper</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="77"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="69"/>
|
||||||
<source>The name cannot be empty</source>
|
<source>The name cannot be empty</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="81"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="73"/>
|
||||||
<source>The creation path cannot be empty</source>
|
<source>The creation path cannot be empty</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="86"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="78"/>
|
||||||
<source>The path does not exist</source>
|
<source>The path does not exist</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="92"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="84"/>
|
||||||
<source>%1 folder already exists</source>
|
<source>%1 folder already exists</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
@ -475,7 +475,7 @@
|
|||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="qml/global/ItemsOriginal.qml" line="430"/>
|
<location filename="qml/global/ItemsOriginal.qml" line="430"/>
|
||||||
<source>CodeEditor</source>
|
<source>OpenGL</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -550,11 +550,6 @@
|
|||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>MainWindow</name>
|
<name>MainWindow</name>
|
||||||
<message>
|
|
||||||
<location filename="qml/window/MainWindow.qml" line="307"/>
|
|
||||||
<source>Dark Mode</source>
|
|
||||||
<translation type="unfinished"></translation>
|
|
||||||
</message>
|
|
||||||
<message>
|
<message>
|
||||||
<location filename="qml/window/MainWindow.qml" line="83"/>
|
<location filename="qml/window/MainWindow.qml" line="83"/>
|
||||||
<location filename="qml/window/MainWindow.qml" line="91"/>
|
<location filename="qml/window/MainWindow.qml" line="91"/>
|
||||||
@ -617,6 +612,11 @@
|
|||||||
<source>Previous</source>
|
<source>Previous</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<location filename="qml/window/MainWindow.qml" line="307"/>
|
||||||
|
<source>Dark Mode</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="qml/window/MainWindow.qml" line="307"/>
|
<location filename="qml/window/MainWindow.qml" line="307"/>
|
||||||
<source>Here you can switch to night mode.</source>
|
<source>Here you can switch to night mode.</source>
|
||||||
@ -1626,6 +1626,14 @@ My only desire is to be permitted to drive out the traitors and restore the Han.
|
|||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>T_OpenGL</name>
|
||||||
|
<message>
|
||||||
|
<location filename="qml/page/T_OpenGL.qml" line="11"/>
|
||||||
|
<source>OpenGL</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>T_Pagination</name>
|
<name>T_Pagination</name>
|
||||||
<message>
|
<message>
|
||||||
|
@ -87,22 +87,22 @@
|
|||||||
<context>
|
<context>
|
||||||
<name>InitializrHelper</name>
|
<name>InitializrHelper</name>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="77"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="69"/>
|
||||||
<source>The name cannot be empty</source>
|
<source>The name cannot be empty</source>
|
||||||
<translation type="unfinished">名称不能为空</translation>
|
<translation type="unfinished">名称不能为空</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="81"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="73"/>
|
||||||
<source>The creation path cannot be empty</source>
|
<source>The creation path cannot be empty</source>
|
||||||
<translation type="unfinished">创建路径不能为空</translation>
|
<translation type="unfinished">创建路径不能为空</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="86"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="78"/>
|
||||||
<source>The path does not exist</source>
|
<source>The path does not exist</source>
|
||||||
<translation type="unfinished">路径不存在</translation>
|
<translation type="unfinished">路径不存在</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="src/helper/InitializrHelper.cpp" line="92"/>
|
<location filename="src/helper/InitializrHelper.cpp" line="84"/>
|
||||||
<source>%1 folder already exists</source>
|
<source>%1 folder already exists</source>
|
||||||
<translation type="unfinished">%1 文件夹已经存在</translation>
|
<translation type="unfinished">%1 文件夹已经存在</translation>
|
||||||
</message>
|
</message>
|
||||||
@ -475,7 +475,7 @@
|
|||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<location filename="qml/global/ItemsOriginal.qml" line="430"/>
|
<location filename="qml/global/ItemsOriginal.qml" line="430"/>
|
||||||
<source>CodeEditor</source>
|
<source>OpenGL</source>
|
||||||
<translation type="unfinished"></translation>
|
<translation type="unfinished"></translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
@ -1665,6 +1665,14 @@ My only desire is to be permitted to drive out the traitors and restore the Han.
|
|||||||
<translation type="unfinished">网络</translation>
|
<translation type="unfinished">网络</translation>
|
||||||
</message>
|
</message>
|
||||||
</context>
|
</context>
|
||||||
|
<context>
|
||||||
|
<name>T_OpenGL</name>
|
||||||
|
<message>
|
||||||
|
<location filename="qml/page/T_OpenGL.qml" line="11"/>
|
||||||
|
<source>OpenGL</source>
|
||||||
|
<translation type="unfinished"></translation>
|
||||||
|
</message>
|
||||||
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>T_Pagination</name>
|
<name>T_Pagination</name>
|
||||||
<message>
|
<message>
|
||||||
|
@ -427,9 +427,9 @@ FluObject{
|
|||||||
title: qsTr("Other")
|
title: qsTr("Other")
|
||||||
icon: FluentIcons.Shop
|
icon: FluentIcons.Shop
|
||||||
FluPaneItem{
|
FluPaneItem{
|
||||||
title: qsTr("CodeEditor")
|
title: qsTr("OpenGL")
|
||||||
menuDelegate: paneItemMenu
|
menuDelegate: paneItemMenu
|
||||||
url: "qrc:/example/qml/page/T_CodeEditor.qml"
|
url: "qrc:/example/qml/page/T_OpenGL.qml"
|
||||||
onTap: { navigationView.push(url) }
|
onTap: { navigationView.push(url) }
|
||||||
}
|
}
|
||||||
FluPaneItem{
|
FluPaneItem{
|
||||||
|
26
example/qml/page/T_OpenGL.qml
Normal file
26
example/qml/page/T_OpenGL.qml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
import QtQuick 2.15
|
||||||
|
import QtQuick.Layouts 1.15
|
||||||
|
import QtQuick.Window 2.15
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
import FluentUI 1.0
|
||||||
|
import example 1.0
|
||||||
|
import "../component"
|
||||||
|
|
||||||
|
FluContentPage{
|
||||||
|
|
||||||
|
title: qsTr("OpenGL")
|
||||||
|
|
||||||
|
FluFrame{
|
||||||
|
anchors.fill: parent
|
||||||
|
OpenGLItem{
|
||||||
|
anchors.fill: parent
|
||||||
|
SequentialAnimation on t {
|
||||||
|
NumberAnimation { to: 1; duration: 2500; easing.type: Easing.InQuad }
|
||||||
|
NumberAnimation { to: 0; duration: 2500; easing.type: Easing.OutQuad }
|
||||||
|
loops: Animation.Infinite
|
||||||
|
running: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,17 +1,15 @@
|
|||||||
#include "AppInfo.h"
|
#include "AppInfo.h"
|
||||||
|
|
||||||
#include <QQmlContext>
|
#include <QQmlContext>
|
||||||
#include <QDebug>
|
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
#include "Version.h"
|
#include "Version.h"
|
||||||
|
|
||||||
AppInfo::AppInfo(QObject *parent)
|
AppInfo::AppInfo(QObject *parent)
|
||||||
: QObject{parent}
|
: QObject{parent} {
|
||||||
{
|
|
||||||
version(APPLICATION_VERSION);
|
version(APPLICATION_VERSION);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AppInfo::testCrash(){
|
[[maybe_unused]] void AppInfo::testCrash() {
|
||||||
auto *crash = reinterpret_cast<volatile int *>(0);
|
auto *crash = reinterpret_cast<volatile int *>(0);
|
||||||
*crash = 0;
|
*crash = 0;
|
||||||
}
|
}
|
||||||
|
@ -1,20 +1,18 @@
|
|||||||
#ifndef APPINFO_H
|
#pragma once
|
||||||
#define APPINFO_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QQmlApplicationEngine>
|
#include <QQmlApplicationEngine>
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "singleton.h"
|
#include "singleton.h"
|
||||||
|
|
||||||
class AppInfo : public QObject
|
class AppInfo : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QString, version)
|
Q_PROPERTY_AUTO(QString, version)
|
||||||
private:
|
private:
|
||||||
explicit AppInfo(QObject *parent = nullptr);
|
explicit AppInfo(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(AppInfo)
|
SINGLETON(AppInfo)
|
||||||
Q_INVOKABLE void testCrash();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // APPINFO_H
|
Q_INVOKABLE [[maybe_unused]] void testCrash();
|
||||||
|
};
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef APP_DUMP_H
|
#pragma once
|
||||||
#define APP_DUMP_H
|
|
||||||
|
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
#include <DbgHelp.h>
|
#include <DbgHelp.h>
|
||||||
@ -12,22 +11,22 @@
|
|||||||
|
|
||||||
#pragma comment(lib, "Dbghelp.lib")
|
#pragma comment(lib, "Dbghelp.lib")
|
||||||
|
|
||||||
static void miniDumpWriteDump(HANDLE hProcess,DWORD ProcessId,HANDLE hFile,MINIDUMP_TYPE DumpType,CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,CONST PMINIDUMP_USER_STREAM_INFORMATION UserStreamParam,CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam){
|
static void
|
||||||
typedef HRESULT (WINAPI* MiniDumpWriteDumpPtr)(HANDLE hProcess,DWORD ProcessId,HANDLE hFile,MINIDUMP_TYPE DumpType,CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,CONST PMINIDUMP_USER_STREAM_INFORMATION UserStreamParam,CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam);
|
miniDumpWriteDump(HANDLE hProcess, DWORD ProcessId, HANDLE hFile, CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam, CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam) {
|
||||||
|
typedef HRESULT (WINAPI *MiniDumpWriteDumpPtr)(HANDLE hProcess, DWORD ProcessId, HANDLE hFile, MINIDUMP_TYPE DumpType, CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,
|
||||||
|
CONST PMINIDUMP_USER_STREAM_INFORMATION UserStreamParam, CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam);
|
||||||
HMODULE module = LoadLibraryW(L"Dbghelp.dll");
|
HMODULE module = LoadLibraryW(L"Dbghelp.dll");
|
||||||
if (module)
|
if (module) {
|
||||||
{
|
|
||||||
MiniDumpWriteDumpPtr mini_dump_write_dump;
|
MiniDumpWriteDumpPtr mini_dump_write_dump;
|
||||||
mini_dump_write_dump = reinterpret_cast<MiniDumpWriteDumpPtr>(GetProcAddress(module, "MiniDumpWriteDump"));
|
mini_dump_write_dump = reinterpret_cast<MiniDumpWriteDumpPtr>(GetProcAddress(module, "MiniDumpWriteDump"));
|
||||||
if (mini_dump_write_dump)
|
if (mini_dump_write_dump) {
|
||||||
{
|
mini_dump_write_dump(hProcess, ProcessId, hFile, static_cast<MINIDUMP_TYPE>(80), ExceptionParam, nullptr, CallbackParam);
|
||||||
mini_dump_write_dump(hProcess,ProcessId,hFile,DumpType,ExceptionParam,UserStreamParam,CallbackParam);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL CALLBACK MyMiniDumpCallback(PVOID, const PMINIDUMP_CALLBACK_INPUT input, PMINIDUMP_CALLBACK_OUTPUT output) {
|
BOOL CALLBACK MyMiniDumpCallback(PVOID, const PMINIDUMP_CALLBACK_INPUT input, PMINIDUMP_CALLBACK_OUTPUT output) {
|
||||||
if (input == NULL || output == NULL)
|
if (input == nullptr || output == nullptr)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
BOOL ret = FALSE;
|
BOOL ret = FALSE;
|
||||||
@ -43,7 +42,8 @@ BOOL CALLBACK MyMiniDumpCallback(PVOID, const PMINIDUMP_CALLBACK_INPUT input, PM
|
|||||||
output->ModuleWriteFlags &= ~ModuleWriteModule;
|
output->ModuleWriteFlags &= ~ModuleWriteModule;
|
||||||
}
|
}
|
||||||
ret = TRUE;
|
ret = TRUE;
|
||||||
} break;
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -51,16 +51,15 @@ BOOL CALLBACK MyMiniDumpCallback(PVOID, const PMINIDUMP_CALLBACK_INPUT input, PM
|
|||||||
}
|
}
|
||||||
|
|
||||||
void WriteDump(EXCEPTION_POINTERS *exp, const std::wstring &path) {
|
void WriteDump(EXCEPTION_POINTERS *exp, const std::wstring &path) {
|
||||||
HANDLE h = ::CreateFileW(path.c_str(), GENERIC_WRITE | GENERIC_READ, FILE_SHARE_WRITE | FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
|
HANDLE h = ::CreateFileW(path.c_str(), GENERIC_WRITE | GENERIC_READ, FILE_SHARE_WRITE | FILE_SHARE_READ, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr);
|
||||||
MINIDUMP_EXCEPTION_INFORMATION info;
|
MINIDUMP_EXCEPTION_INFORMATION info;
|
||||||
info.ThreadId = ::GetCurrentThreadId();
|
info.ThreadId = ::GetCurrentThreadId();
|
||||||
info.ExceptionPointers = exp;
|
info.ExceptionPointers = exp;
|
||||||
info.ClientPointers = FALSE;
|
info.ClientPointers = FALSE;
|
||||||
MINIDUMP_CALLBACK_INFORMATION mci;
|
MINIDUMP_CALLBACK_INFORMATION mci;
|
||||||
mci.CallbackRoutine = (MINIDUMP_CALLBACK_ROUTINE) MyMiniDumpCallback;
|
mci.CallbackRoutine = (MINIDUMP_CALLBACK_ROUTINE) MyMiniDumpCallback;
|
||||||
mci.CallbackParam = 0;
|
mci.CallbackParam = nullptr;
|
||||||
MINIDUMP_TYPE mdt = (MINIDUMP_TYPE)(MiniDumpWithIndirectlyReferencedMemory | MiniDumpScanMemory);
|
miniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), h, &info, &mci);
|
||||||
miniDumpWriteDump(GetCurrentProcess(), GetCurrentProcessId(), h, mdt, &info, NULL, &mci);
|
|
||||||
::CloseHandle(h);
|
::CloseHandle(h);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,8 +74,6 @@ LONG WINAPI MyUnhandledExceptionFilter(EXCEPTION_POINTERS* exp) {
|
|||||||
WriteDump(exp, dumpFilePath.toStdWString());
|
WriteDump(exp, dumpFilePath.toStdWString());
|
||||||
QStringList arguments;
|
QStringList arguments;
|
||||||
arguments << "-crashed=" + dumpFilePath;
|
arguments << "-crashed=" + dumpFilePath;
|
||||||
QProcess::startDetached(qApp->applicationFilePath(), arguments);
|
QProcess::startDetached(QGuiApplication::applicationFilePath(), arguments);
|
||||||
return EXCEPTION_EXECUTE_HANDLER;
|
return EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // APP_DUMP_H
|
|
||||||
|
@ -3,12 +3,13 @@
|
|||||||
#include <QQuickItemGrabResult>
|
#include <QQuickItemGrabResult>
|
||||||
#include <QPainterPath>
|
#include <QPainterPath>
|
||||||
|
|
||||||
CircularReveal::CircularReveal(QQuickItem* parent) : QQuickPaintedItem(parent)
|
CircularReveal::CircularReveal(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
||||||
{
|
_target = nullptr;
|
||||||
|
_radius = 0;
|
||||||
_anim = new QPropertyAnimation(this, "radius", this);
|
_anim = new QPropertyAnimation(this, "radius", this);
|
||||||
setVisible(false);
|
|
||||||
_anim->setDuration(333);
|
_anim->setDuration(333);
|
||||||
_anim->setEasingCurve(QEasingCurve::OutCubic);
|
_anim->setEasingCurve(QEasingCurve::OutCubic);
|
||||||
|
setVisible(false);
|
||||||
connect(_anim, &QPropertyAnimation::finished, this, [=]() {
|
connect(_anim, &QPropertyAnimation::finished, this, [=]() {
|
||||||
update();
|
update();
|
||||||
setVisible(false);
|
setVisible(false);
|
||||||
@ -19,8 +20,7 @@ CircularReveal::CircularReveal(QQuickItem* parent) : QQuickPaintedItem(parent)
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void CircularReveal::paint(QPainter* painter)
|
void CircularReveal::paint(QPainter *painter) {
|
||||||
{
|
|
||||||
painter->save();
|
painter->save();
|
||||||
painter->drawImage(QRect(0, 0, static_cast<int>(width()), static_cast<int>(height())), _source);
|
painter->drawImage(QRect(0, 0, static_cast<int>(width()), static_cast<int>(height())), _source);
|
||||||
QPainterPath path;
|
QPainterPath path;
|
||||||
@ -31,7 +31,7 @@ void CircularReveal::paint(QPainter* painter)
|
|||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CircularReveal::start(int w,int h,const QPoint& center,int radius){
|
[[maybe_unused]] void CircularReveal::start(int w, int h, const QPoint ¢er, int radius) {
|
||||||
_anim->setStartValue(0);
|
_anim->setStartValue(0);
|
||||||
_anim->setEndValue(radius);
|
_anim->setEndValue(radius);
|
||||||
_center = center;
|
_center = center;
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef CIRCULARREVEAL_H
|
#pragma once
|
||||||
#define CIRCULARREVEAL_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QQuickPaintedItem>
|
#include <QQuickPaintedItem>
|
||||||
@ -7,23 +6,26 @@
|
|||||||
#include <QPropertyAnimation>
|
#include <QPropertyAnimation>
|
||||||
#include "src/stdafx.h"
|
#include "src/stdafx.h"
|
||||||
|
|
||||||
class CircularReveal : public QQuickPaintedItem
|
class CircularReveal : public QQuickPaintedItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QQuickItem*,target)
|
Q_PROPERTY_AUTO_P(QQuickItem*, target)
|
||||||
Q_PROPERTY_AUTO(int, radius)
|
Q_PROPERTY_AUTO(int, radius)
|
||||||
public:
|
public:
|
||||||
CircularReveal(QQuickItem* parent = nullptr);
|
explicit CircularReveal(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
Q_INVOKABLE void start(int w,int h,const QPoint& center,int radius);
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void start(int w, int h, const QPoint ¢er, int radius);
|
||||||
|
|
||||||
Q_SIGNAL void imageChanged();
|
Q_SIGNAL void imageChanged();
|
||||||
|
|
||||||
Q_SIGNAL void animationFinished();
|
Q_SIGNAL void animationFinished();
|
||||||
|
|
||||||
Q_SLOT void handleGrabResult();
|
Q_SLOT void handleGrabResult();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QPropertyAnimation *_anim = nullptr;
|
QPropertyAnimation *_anim = nullptr;
|
||||||
QImage _source;
|
QImage _source;
|
||||||
QPoint _center;
|
QPoint _center;
|
||||||
QSharedPointer<QQuickItemGrabResult> _grabResult;
|
QSharedPointer<QQuickItemGrabResult> _grabResult;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // CIRCULARREVEAL_H
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
#include "FileWatcher.h"
|
#include "FileWatcher.h"
|
||||||
|
|
||||||
FileWatcher::FileWatcher(QObject *parent)
|
FileWatcher::FileWatcher(QObject *parent) : QObject{parent} {
|
||||||
: QObject{parent}
|
|
||||||
{
|
|
||||||
connect(&_watcher, &QFileSystemWatcher::fileChanged, this, [=](const QString &path) {
|
connect(&_watcher, &QFileSystemWatcher::fileChanged, this, [=](const QString &path) {
|
||||||
Q_EMIT fileChanged();
|
Q_EMIT fileChanged();
|
||||||
clean();
|
clean();
|
||||||
@ -18,7 +16,8 @@ FileWatcher::FileWatcher(QObject *parent)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FileWatcher::clean() {
|
void FileWatcher::clean() {
|
||||||
foreach (const QString &item, _watcher.files()) {
|
for (int i = 0; i <= _watcher.files().size() - 1; ++i) {
|
||||||
|
auto item = _watcher.files().at(i);
|
||||||
_watcher.removePath(item);
|
_watcher.removePath(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,22 +1,21 @@
|
|||||||
#ifndef FILEWATCHER_H
|
#pragma once
|
||||||
#define FILEWATCHER_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QFileSystemWatcher>
|
#include <QFileSystemWatcher>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
#include "src/stdafx.h"
|
#include "src/stdafx.h"
|
||||||
|
|
||||||
class FileWatcher : public QObject
|
class FileWatcher : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QString, path);
|
Q_PROPERTY_AUTO(QString, path);
|
||||||
public:
|
public:
|
||||||
explicit FileWatcher(QObject *parent = nullptr);
|
explicit FileWatcher(QObject *parent = nullptr);
|
||||||
|
|
||||||
Q_SIGNAL void fileChanged();
|
Q_SIGNAL void fileChanged();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void clean();
|
void clean();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QFileSystemWatcher _watcher;
|
QFileSystemWatcher _watcher;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FILEWATCHER_H
|
|
||||||
|
@ -3,9 +3,9 @@
|
|||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <QQuickWindow>
|
#include <QQuickWindow>
|
||||||
|
|
||||||
FpsItem::FpsItem()
|
FpsItem::FpsItem() {
|
||||||
{
|
_fps = 0;
|
||||||
QTimer *timer = new QTimer(this);
|
auto *timer = new QTimer(this);
|
||||||
connect(timer, &QTimer::timeout, this, [this] {
|
connect(timer, &QTimer::timeout, this, [this] {
|
||||||
fps(_frameCount);
|
fps(_frameCount);
|
||||||
_frameCount = 0;
|
_frameCount = 0;
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
#ifndef FPSITEM_H
|
#pragma once
|
||||||
#define FPSITEM_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include "src/stdafx.h"
|
#include "src/stdafx.h"
|
||||||
|
|
||||||
class FpsItem : public QQuickItem
|
class FpsItem : public QQuickItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(int, fps)
|
Q_PROPERTY_AUTO(int, fps)
|
||||||
public:
|
public:
|
||||||
@ -15,5 +13,3 @@ private:
|
|||||||
int _frameCount = 0;
|
int _frameCount = 0;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FPSITEM_H
|
|
||||||
|
93
example/src/component/OpenGLItem.cpp
Normal file
93
example/src/component/OpenGLItem.cpp
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
#include "OpenGLItem.h"
|
||||||
|
|
||||||
|
#include <QOpenGLFramebufferObjectFormat>
|
||||||
|
#include <QOpenGLShaderProgram>
|
||||||
|
|
||||||
|
class FBORenderer : public QQuickFramebufferObject::Renderer, protected QOpenGLFunctions {
|
||||||
|
public:
|
||||||
|
explicit FBORenderer(const OpenGLItem *item);
|
||||||
|
|
||||||
|
void render() override;
|
||||||
|
|
||||||
|
QOpenGLFramebufferObject *createFramebufferObject(const QSize &size) override;
|
||||||
|
|
||||||
|
QOpenGLShaderProgram program;
|
||||||
|
const OpenGLItem *item = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
FBORenderer::FBORenderer(const OpenGLItem *item) {
|
||||||
|
this->item = item;
|
||||||
|
initializeOpenGLFunctions();
|
||||||
|
program.addCacheableShaderFromSourceCode(QOpenGLShader::Vertex,
|
||||||
|
"attribute highp vec4 vertices;"
|
||||||
|
"varying highp vec2 coords;"
|
||||||
|
"void main() {"
|
||||||
|
" gl_Position = vertices;"
|
||||||
|
" coords = vertices.xy;"
|
||||||
|
"}");
|
||||||
|
program.addCacheableShaderFromSourceCode(QOpenGLShader::Fragment,
|
||||||
|
"uniform lowp float t;"
|
||||||
|
"varying highp vec2 coords;"
|
||||||
|
"void main() {"
|
||||||
|
" lowp float i = 1. - (pow(abs(coords.x), 4.) + pow(abs(coords.y), 4.));"
|
||||||
|
" i = smoothstep(t - 0.8, t + 0.8, i);"
|
||||||
|
" i = floor(i * 20.) / 20.;"
|
||||||
|
" gl_FragColor = vec4(coords * .5 + .5, i, i);"
|
||||||
|
"}");
|
||||||
|
|
||||||
|
program.bindAttributeLocation("vertices", 0);
|
||||||
|
program.link();
|
||||||
|
}
|
||||||
|
|
||||||
|
QOpenGLFramebufferObject *FBORenderer::createFramebufferObject(const QSize &size) {
|
||||||
|
QOpenGLFramebufferObjectFormat format;
|
||||||
|
format.setAttachment(QOpenGLFramebufferObject::CombinedDepthStencil);
|
||||||
|
format.setSamples(4);
|
||||||
|
return new QOpenGLFramebufferObject(size, format);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FBORenderer::render() {
|
||||||
|
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
||||||
|
glEnable(GL_DEPTH_TEST);
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
program.bind();
|
||||||
|
program.enableAttributeArray(0);
|
||||||
|
float values[] = {
|
||||||
|
-1, -1,
|
||||||
|
1, -1,
|
||||||
|
-1, 1,
|
||||||
|
1, 1
|
||||||
|
};
|
||||||
|
glBindBuffer(GL_ARRAY_BUFFER, 0);
|
||||||
|
program.setAttributeArray(0, GL_FLOAT, values, 2);
|
||||||
|
program.setUniformValue("t", (float) item->t());
|
||||||
|
glViewport(0, 0, qRound(item->width()), qRound(item->height()));
|
||||||
|
glDisable(GL_DEPTH_TEST);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc(GL_SRC_ALPHA, GL_ONE);
|
||||||
|
glDrawArrays(GL_TRIANGLE_STRIP, 0, 4);
|
||||||
|
program.disableAttributeArray(0);
|
||||||
|
program.release();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
OpenGLItem::OpenGLItem(QQuickItem *parent) : QQuickFramebufferObject(parent) {
|
||||||
|
setMirrorVertically(true);
|
||||||
|
startTimer(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OpenGLItem::timerEvent(QTimerEvent *) {
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
||||||
|
void OpenGLItem::setT(qreal t) {
|
||||||
|
if (t == m_t)
|
||||||
|
return;
|
||||||
|
m_t = t;
|
||||||
|
emit tChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
QQuickFramebufferObject::Renderer *OpenGLItem::createRenderer() const {
|
||||||
|
return new FBORenderer(this);
|
||||||
|
}
|
29
example/src/component/OpenGLItem.h
Normal file
29
example/src/component/OpenGLItem.h
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QtQuick/QQuickItem>
|
||||||
|
#include <QOpenGLFunctions>
|
||||||
|
#include <QQuickFramebufferObject>
|
||||||
|
|
||||||
|
class FBORenderer;
|
||||||
|
|
||||||
|
class OpenGLItem : public QQuickFramebufferObject, protected QOpenGLFunctions {
|
||||||
|
Q_OBJECT
|
||||||
|
Q_PROPERTY(qreal t READ t WRITE setT NOTIFY tChanged)
|
||||||
|
public:
|
||||||
|
explicit OpenGLItem(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
|
[[nodiscard]] QQuickFramebufferObject::Renderer *createRenderer() const override;
|
||||||
|
|
||||||
|
void timerEvent(QTimerEvent *) override;
|
||||||
|
|
||||||
|
[[nodiscard]] qreal t() const { return m_t; }
|
||||||
|
|
||||||
|
void setT(qreal t);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
|
||||||
|
void tChanged();
|
||||||
|
|
||||||
|
private:
|
||||||
|
qreal m_t{};
|
||||||
|
};
|
@ -3,39 +3,31 @@
|
|||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
|
|
||||||
InitializrHelper::InitializrHelper(QObject *parent) : QObject(parent)
|
[[maybe_unused]] InitializrHelper::InitializrHelper(QObject *parent) : QObject(parent) {
|
||||||
{
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
InitializrHelper::~InitializrHelper() = default;
|
InitializrHelper::~InitializrHelper() = default;
|
||||||
|
|
||||||
bool InitializrHelper::copyDir(const QDir &fromDir, const QDir &toDir, bool coverIfFileExists) {
|
bool InitializrHelper::copyDir(const QDir &fromDir, const QDir &toDir, bool coverIfFileExists) {
|
||||||
QDir _formDir = fromDir;
|
const QDir &_formDir = fromDir;
|
||||||
QDir _toDir = toDir;
|
QDir _toDir = toDir;
|
||||||
if(!_toDir.exists())
|
if (!_toDir.exists()) {
|
||||||
{
|
|
||||||
if (!_toDir.mkdir(toDir.absolutePath()))
|
if (!_toDir.mkdir(toDir.absolutePath()))
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
QFileInfoList fileInfoList = _formDir.entryInfoList();
|
QFileInfoList fileInfoList = _formDir.entryInfoList();
|
||||||
foreach(QFileInfo fileInfo, fileInfoList)
|
foreach(QFileInfo fileInfo, fileInfoList) {
|
||||||
{
|
|
||||||
if (fileInfo.fileName() == "." || fileInfo.fileName() == "..")
|
if (fileInfo.fileName() == "." || fileInfo.fileName() == "..")
|
||||||
continue;
|
continue;
|
||||||
if(fileInfo.isDir())
|
if (fileInfo.isDir()) {
|
||||||
{
|
|
||||||
if (!copyDir(fileInfo.filePath(), _toDir.filePath(fileInfo.fileName()), true))
|
if (!copyDir(fileInfo.filePath(), _toDir.filePath(fileInfo.fileName()), true))
|
||||||
return false;
|
return false;
|
||||||
}
|
} else {
|
||||||
else
|
if (coverIfFileExists && _toDir.exists(fileInfo.fileName())) {
|
||||||
{
|
|
||||||
if(coverIfFileExists && _toDir.exists(fileInfo.fileName()))
|
|
||||||
{
|
|
||||||
_toDir.remove(fileInfo.fileName());
|
_toDir.remove(fileInfo.fileName());
|
||||||
}
|
}
|
||||||
if(!QFile::copy(fileInfo.filePath(), _toDir.filePath(fileInfo.fileName())))
|
if (!QFile::copy(fileInfo.filePath(), _toDir.filePath(fileInfo.fileName()))) {
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -72,7 +64,7 @@ void InitializrHelper::copyFile(const QString& source,const QString& dest){
|
|||||||
QFile::setPermissions(dest, QFile::WriteOwner | QFile::WriteUser | QFile::WriteGroup | QFile::WriteOther);
|
QFile::setPermissions(dest, QFile::WriteOwner | QFile::WriteUser | QFile::WriteGroup | QFile::WriteOther);
|
||||||
}
|
}
|
||||||
|
|
||||||
void InitializrHelper::generate(const QString& name,const QString& path){
|
[[maybe_unused]] void InitializrHelper::generate(const QString &name, const QString &path) {
|
||||||
if (name.isEmpty()) {
|
if (name.isEmpty()) {
|
||||||
error(tr("The name cannot be empty"));
|
error(tr("The name cannot be empty"));
|
||||||
return;
|
return;
|
||||||
|
@ -1,26 +1,30 @@
|
|||||||
#ifndef INITIALIZRHELPER_H
|
#pragma once
|
||||||
#define INITIALIZRHELPER_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include "src/singleton.h"
|
#include "src/singleton.h"
|
||||||
|
|
||||||
class InitializrHelper : public QObject
|
class InitializrHelper : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
private:
|
private:
|
||||||
explicit InitializrHelper(QObject* parent = nullptr);
|
[[maybe_unused]] explicit InitializrHelper(QObject *parent = nullptr);
|
||||||
|
|
||||||
bool copyDir(const QDir &fromDir, const QDir &toDir, bool coverIfFileExists = true);
|
bool copyDir(const QDir &fromDir, const QDir &toDir, bool coverIfFileExists = true);
|
||||||
void copyFile(const QString& source,const QString& dest);
|
|
||||||
|
static void copyFile(const QString &source, const QString &dest);
|
||||||
|
|
||||||
template<typename...Args>
|
template<typename...Args>
|
||||||
void templateToFile(const QString &source, const QString &dest, Args &&...args);
|
void templateToFile(const QString &source, const QString &dest, Args &&...args);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(InitializrHelper)
|
SINGLETON(InitializrHelper)
|
||||||
|
|
||||||
~InitializrHelper() override;
|
~InitializrHelper() override;
|
||||||
Q_INVOKABLE void generate(const QString& name,const QString& path);
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void generate(const QString &name, const QString &path);
|
||||||
|
|
||||||
Q_SIGNAL void error(const QString &message);
|
Q_SIGNAL void error(const QString &message);
|
||||||
|
|
||||||
Q_SIGNAL void success(const QString &path);
|
Q_SIGNAL void success(const QString &path);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // INITIALIZRHELPER_H
|
|
||||||
|
@ -11,8 +11,11 @@
|
|||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <QRegularExpression>
|
#include <QRegularExpression>
|
||||||
#include "Version.h"
|
#include "Version.h"
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
|
||||||
#include <process.h>
|
#include <process.h>
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
@ -42,8 +45,7 @@ std::map<QtMsgType, int> logLevelMap = {
|
|||||||
{QtDebugMsg, 4}
|
{QtDebugMsg, 4}
|
||||||
};
|
};
|
||||||
|
|
||||||
QString Log::prettyProductInfoWrapper()
|
QString Log::prettyProductInfoWrapper() {
|
||||||
{
|
|
||||||
auto productName = QSysInfo::prettyProductName();
|
auto productName = QSysInfo::prettyProductName();
|
||||||
#if QT_VERSION < QT_VERSION_CHECK(6, 5, 0)
|
#if QT_VERSION < QT_VERSION_CHECK(6, 5, 0)
|
||||||
#if defined(Q_OS_MACOS)
|
#if defined(Q_OS_MACOS)
|
||||||
@ -70,20 +72,17 @@ QString Log::prettyProductInfoWrapper()
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
QSettings regKey {QString::fromUtf8("HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion"), QSettings::NativeFormat};
|
QSettings regKey{QString::fromUtf8(R"(HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion)"), QSettings::NativeFormat};
|
||||||
if (regKey.contains(QString::fromUtf8("CurrentBuildNumber"))) {
|
if (regKey.contains(QString::fromUtf8("CurrentBuildNumber"))) {
|
||||||
auto buildNumber = regKey.value(QString::fromUtf8("CurrentBuildNumber")).toInt();
|
auto buildNumber = regKey.value(QString::fromUtf8("CurrentBuildNumber")).toInt();
|
||||||
if (buildNumber > 0) {
|
if (buildNumber > 0) {
|
||||||
if (buildNumber < 9200) {
|
if (buildNumber < 9200) {
|
||||||
productName = QString::fromUtf8("Windows 7 build %1").arg(buildNumber);
|
productName = QString::fromUtf8("Windows 7 build %1").arg(buildNumber);
|
||||||
}
|
} else if (buildNumber < 10240) {
|
||||||
else if (buildNumber < 10240) {
|
|
||||||
productName = QString::fromUtf8("Windows 8 build %1").arg(buildNumber);
|
productName = QString::fromUtf8("Windows 8 build %1").arg(buildNumber);
|
||||||
}
|
} else if (buildNumber < 22000) {
|
||||||
else if (buildNumber < 22000) {
|
|
||||||
productName = QString::fromUtf8("Windows 10 build %1").arg(buildNumber);
|
productName = QString::fromUtf8("Windows 10 build %1").arg(buildNumber);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
productName = QString::fromUtf8("Windows 11 build %1").arg(buildNumber);
|
productName = QString::fromUtf8("Windows 11 build %1").arg(buildNumber);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -92,8 +91,7 @@ QString Log::prettyProductInfoWrapper()
|
|||||||
return productName;
|
return productName;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void messageHandler(const QtMsgType type, const QMessageLogContext &context, const QString &message)
|
static inline void messageHandler(const QtMsgType type, const QMessageLogContext &context, const QString &message) {
|
||||||
{
|
|
||||||
if (message == "Could not get the INetworkConnection instance for the adapter GUID.") {
|
if (message == "Could not get the INetworkConnection instance for the adapter GUID.") {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -168,8 +166,7 @@ static inline void messageHandler(const QtMsgType type, const QMessageLogContext
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Log::setup(char *argv[],const QString &app,int level)
|
void Log::setup(char *argv[], const QString &app, int level) {
|
||||||
{
|
|
||||||
Q_ASSERT(!app.isEmpty());
|
Q_ASSERT(!app.isEmpty());
|
||||||
if (app.isEmpty()) {
|
if (app.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
#ifndef LOG_H
|
#pragma once
|
||||||
#define LOG_H
|
|
||||||
#include <QtCore/qstring.h>
|
#include <QtCore/qstring.h>
|
||||||
|
|
||||||
namespace Log
|
namespace Log {
|
||||||
{
|
|
||||||
QString prettyProductInfoWrapper();
|
QString prettyProductInfoWrapper();
|
||||||
|
|
||||||
void setup(char *argv[], const QString &app, int level = 4);
|
void setup(char *argv[], const QString &app, int level = 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // LOG_H
|
|
||||||
|
@ -17,12 +17,14 @@
|
|||||||
#include <QCryptographicHash>
|
#include <QCryptographicHash>
|
||||||
#include <QEventLoop>
|
#include <QEventLoop>
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
|
|
||||||
NetworkCallable::NetworkCallable(QObject *parent) : QObject{parent} {
|
NetworkCallable::NetworkCallable(QObject *parent) : QObject{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QString NetworkParams::method2String(){
|
QString NetworkParams::method2String() const {
|
||||||
switch (_method) {
|
switch (_method) {
|
||||||
case METHOD_GET:
|
case METHOD_GET:
|
||||||
return "GET";
|
return "GET";
|
||||||
@ -41,21 +43,21 @@ QString NetworkParams::method2String(){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int NetworkParams::getTimeout(){
|
int NetworkParams::getTimeout() const {
|
||||||
if (_timeout != -1) {
|
if (_timeout != -1) {
|
||||||
return _timeout;
|
return _timeout;
|
||||||
}
|
}
|
||||||
return Network::getInstance()->timeout();
|
return Network::getInstance()->timeout();
|
||||||
}
|
}
|
||||||
|
|
||||||
int NetworkParams::getRetry(){
|
int NetworkParams::getRetry() const {
|
||||||
if (_retry != -1) {
|
if (_retry != -1) {
|
||||||
return _retry;
|
return _retry;
|
||||||
}
|
}
|
||||||
return Network::getInstance()->retry();
|
return Network::getInstance()->retry();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NetworkParams::getOpenLog(){
|
bool NetworkParams::getOpenLog() const {
|
||||||
if (!_openLog.isNull()) {
|
if (!_openLog.isNull()) {
|
||||||
return _openLog.toBool();
|
return _openLog.toBool();
|
||||||
}
|
}
|
||||||
@ -63,52 +65,49 @@ bool NetworkParams::getOpenLog(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
FluDownloadParam::FluDownloadParam(QObject *parent)
|
FluDownloadParam::FluDownloadParam(QObject *parent)
|
||||||
: QObject{parent}
|
: QObject{parent} {
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FluDownloadParam::FluDownloadParam(QString destPath, bool append, QObject *parent)
|
FluDownloadParam::FluDownloadParam(QString destPath, bool append, QObject *parent)
|
||||||
: QObject{parent}
|
: QObject{parent} {
|
||||||
{
|
this->_destPath = std::move(destPath);
|
||||||
this->_destPath = destPath;
|
|
||||||
this->_append = append;
|
this->_append = append;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams::NetworkParams(QObject *parent)
|
NetworkParams::NetworkParams(QObject *parent) : QObject{parent} {
|
||||||
: QObject{parent}
|
_method = NetworkParams::Method::METHOD_GET;
|
||||||
{
|
_type = NetworkParams::Type::TYPE_BODY;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams::NetworkParams(QString url, Type type, Method method, QObject *parent)
|
NetworkParams::NetworkParams(QString url, Type type, Method method, QObject *parent)
|
||||||
: QObject{parent}
|
: QObject{parent} {
|
||||||
{
|
|
||||||
this->_method = method;
|
this->_method = method;
|
||||||
this->_url = url;
|
this->_url = std::move(url);
|
||||||
this->_type = type;
|
this->_type = type;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams* NetworkParams::add(QString key,QVariant val){
|
NetworkParams *NetworkParams::add(const QString &key, const QVariant &val) {
|
||||||
_paramMap.insert(key, val);
|
_paramMap.insert(key, val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams* NetworkParams::addFile(QString key,QVariant val){
|
NetworkParams *NetworkParams::addFile(const QString &key, const QVariant &val) {
|
||||||
_fileMap.insert(key, val);
|
_fileMap.insert(key, val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams* NetworkParams::addHeader(QString key,QVariant val){
|
NetworkParams *NetworkParams::addHeader(const QString &key, const QVariant &val) {
|
||||||
_headerMap.insert(key, val);
|
_headerMap.insert(key, val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams* NetworkParams::addQuery(QString key,QVariant val){
|
NetworkParams *NetworkParams::addQuery(const QString &key, const QVariant &val) {
|
||||||
_queryMap.insert(key, val);
|
_queryMap.insert(key, val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams *NetworkParams::setBody(QString val) {
|
NetworkParams *NetworkParams::setBody(QString val) {
|
||||||
_body = val;
|
_body = std::move(val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,7 +127,7 @@ NetworkParams* NetworkParams::setCacheMode(int val){
|
|||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams *NetworkParams::toDownload(QString destPath, bool append) {
|
NetworkParams *NetworkParams::toDownload(QString destPath, bool append) {
|
||||||
_downloadParam = new FluDownloadParam(destPath,append,this);
|
_downloadParam = new FluDownloadParam(std::move(destPath), append, this);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,11 +137,11 @@ NetworkParams* NetworkParams::bind(QObject* target){
|
|||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams *NetworkParams::openLog(QVariant val) {
|
NetworkParams *NetworkParams::openLog(QVariant val) {
|
||||||
_openLog = val;
|
_openLog = std::move(val);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString NetworkParams::buildCacheKey(){
|
QString NetworkParams::buildCacheKey() const {
|
||||||
QJsonObject obj;
|
QJsonObject obj;
|
||||||
obj.insert("url", _url);
|
obj.insert("url", _url);
|
||||||
obj.insert("method", method2String());
|
obj.insert("method", method2String());
|
||||||
@ -196,19 +195,19 @@ void Network::handle(NetworkParams* params,NetworkCallable* c){
|
|||||||
manager.setTransferTimeout(params->getTimeout());
|
manager.setTransferTimeout(params->getTimeout());
|
||||||
QEventLoop loop;
|
QEventLoop loop;
|
||||||
connect(&manager, &QNetworkAccessManager::finished, &manager, [&loop](QNetworkReply *reply) { loop.quit(); });
|
connect(&manager, &QNetworkAccessManager::finished, &manager, [&loop](QNetworkReply *reply) { loop.quit(); });
|
||||||
for (int i = 0; i < params->getRetry(); ++i) {
|
for (int i = 0; i <= params->getRetry() - 1; ++i) {
|
||||||
QUrl url(params->_url);
|
QUrl url(params->_url);
|
||||||
addQueryParam(&url, params->_queryMap);
|
addQueryParam(&url, params->_queryMap);
|
||||||
QNetworkRequest request(url);
|
QNetworkRequest request(url);
|
||||||
addHeaders(&request, params->_headerMap);
|
addHeaders(&request, params->_headerMap);
|
||||||
QNetworkReply *reply;
|
QNetworkReply *reply;
|
||||||
sendRequest(&manager, request, params, reply, i == 0, callable);
|
sendRequest(&manager, request, params, reply, i == 0, callable);
|
||||||
if(!QPointer<QGuiApplication>(qApp)){
|
if (!QPointer<QCoreApplication>(QGuiApplication::instance())) {
|
||||||
reply->deleteLater();
|
reply->deleteLater();
|
||||||
reply = nullptr;
|
reply = nullptr;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto abortCallable = [&loop,reply,&i,params]{
|
auto abortCallable = [reply, &i, params] {
|
||||||
if (reply) {
|
if (reply) {
|
||||||
i = params->getRetry();
|
i = params->getRetry();
|
||||||
reply->abort();
|
reply->abort();
|
||||||
@ -219,7 +218,7 @@ void Network::handle(NetworkParams* params,NetworkCallable* c){
|
|||||||
if (params->_target) {
|
if (params->_target) {
|
||||||
conn_destroyed = connect(params->_target, &QObject::destroyed, &manager, abortCallable);
|
conn_destroyed = connect(params->_target, &QObject::destroyed, &manager, abortCallable);
|
||||||
}
|
}
|
||||||
conn_quit = connect(qApp,&QGuiApplication::aboutToQuit,&manager, abortCallable);
|
conn_quit = connect(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager, abortCallable);
|
||||||
loop.exec();
|
loop.exec();
|
||||||
if (conn_destroyed) {
|
if (conn_destroyed) {
|
||||||
disconnect(conn_destroyed);
|
disconnect(conn_destroyed);
|
||||||
@ -282,14 +281,14 @@ void Network::handleDownload(NetworkParams* params,NetworkCallable* c){
|
|||||||
addHeaders(&request, params->_headerMap);
|
addHeaders(&request, params->_headerMap);
|
||||||
QString cachePath = getCacheFilePath(cacheKey);
|
QString cachePath = getCacheFilePath(cacheKey);
|
||||||
QString destPath = params->_downloadParam->_destPath;
|
QString destPath = params->_downloadParam->_destPath;
|
||||||
QFile* destFile = new QFile(destPath);
|
auto *destFile = new QFile(destPath);
|
||||||
QFile* cacheFile = new QFile(cachePath);
|
auto *cacheFile = new QFile(cachePath);
|
||||||
bool isOpen = false;
|
bool isOpen;
|
||||||
qint64 seek = 0;
|
qint64 seek;
|
||||||
if (cacheFile->exists() && destFile->exists() && params->_downloadParam->_append) {
|
if (cacheFile->exists() && destFile->exists() && params->_downloadParam->_append) {
|
||||||
QJsonObject cacheInfo = QJsonDocument::fromJson(readCache(cacheKey).toUtf8()).object();
|
QJsonObject cacheInfo = QJsonDocument::fromJson(readCache(cacheKey).toUtf8()).object();
|
||||||
qint64 fileSize = cacheInfo.value("fileSize").toDouble();
|
qint64 fileSize = qRound(cacheInfo.value("fileSize").toDouble());
|
||||||
qint64 contentLength = cacheInfo.value("contentLength").toDouble();
|
qint64 contentLength = qRound(cacheInfo.value("contentLength").toDouble());
|
||||||
if (fileSize == contentLength && destFile->size() == contentLength) {
|
if (fileSize == contentLength && destFile->size() == contentLength) {
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
callable->downloadProgress(fileSize, contentLength);
|
callable->downloadProgress(fileSize, contentLength);
|
||||||
@ -316,8 +315,7 @@ void Network::handleDownload(NetworkParams* params,NetworkCallable* c){
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (params->_downloadParam->_append) {
|
if (params->_downloadParam->_append) {
|
||||||
if (!cacheFile->open(QIODevice::WriteOnly|QIODevice::Truncate))
|
if (!cacheFile->open(QIODevice::WriteOnly | QIODevice::Truncate)) {
|
||||||
{
|
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
callable->error(-1, "cache file device not open", "");
|
callable->error(-1, "cache file device not open", "");
|
||||||
callable->finish();
|
callable->finish();
|
||||||
@ -329,22 +327,21 @@ void Network::handleDownload(NetworkParams* params,NetworkCallable* c){
|
|||||||
QNetworkReply *reply = manager.get(request);
|
QNetworkReply *reply = manager.get(request);
|
||||||
destFile->setParent(reply);
|
destFile->setParent(reply);
|
||||||
cacheFile->setParent(reply);
|
cacheFile->setParent(reply);
|
||||||
auto abortCallable = [&loop,reply,params]{
|
auto abortCallable = [reply] {
|
||||||
if (reply) {
|
if (reply) {
|
||||||
reply->abort();
|
reply->abort();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
connect(&manager, &QNetworkAccessManager::finished, &manager, [&loop](QNetworkReply *reply) { loop.quit(); });
|
connect(&manager, &QNetworkAccessManager::finished, &manager, [&loop](QNetworkReply *reply) { loop.quit(); });
|
||||||
connect(qApp,&QGuiApplication::aboutToQuit,&manager, [&loop,reply](){reply->abort(),loop.quit();});
|
connect(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager, [&loop, reply]() { reply->abort(), loop.quit(); });
|
||||||
QMetaObject::Connection conn_destroyed = {};
|
QMetaObject::Connection conn_destroyed = {};
|
||||||
QMetaObject::Connection conn_quit = {};
|
QMetaObject::Connection conn_quit = {};
|
||||||
if (params->_target) {
|
if (params->_target) {
|
||||||
conn_destroyed = connect(params->_target, &QObject::destroyed, &manager, abortCallable);
|
conn_destroyed = connect(params->_target, &QObject::destroyed, &manager, abortCallable);
|
||||||
}
|
}
|
||||||
conn_quit = connect(qApp,&QGuiApplication::aboutToQuit,&manager, abortCallable);
|
conn_quit = connect(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager, abortCallable);
|
||||||
connect(reply, &QNetworkReply::readyRead, reply, [reply, seek, destFile, cacheFile, callable] {
|
connect(reply, &QNetworkReply::readyRead, reply, [reply, seek, destFile, cacheFile, callable] {
|
||||||
if (!reply || !destFile || reply->error() != QNetworkReply::NoError)
|
if (!reply || !destFile || reply->error() != QNetworkReply::NoError) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
QMap<QString, QVariant> downInfo;
|
QMap<QString, QVariant> downInfo;
|
||||||
@ -433,31 +430,29 @@ QString Network::map2String(const QMap<QString, QVariant>& map){
|
|||||||
return parameters.join(" ");
|
return parameters.join(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::sendRequest(QNetworkAccessManager* manager,QNetworkRequest request,NetworkParams* params,QNetworkReply*& reply,bool isFirst,QPointer<NetworkCallable> callable){
|
void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest request, NetworkParams *params, QNetworkReply *&reply, bool isFirst, const QPointer<NetworkCallable> &callable) {
|
||||||
QByteArray verb = params->method2String().toUtf8();
|
QByteArray verb = params->method2String().toUtf8();
|
||||||
switch (params->_type) {
|
switch (params->_type) {
|
||||||
case NetworkParams::TYPE_FORM: {
|
case NetworkParams::TYPE_FORM: {
|
||||||
bool isFormData = !params->_fileMap.isEmpty();
|
bool isFormData = !params->_fileMap.isEmpty();
|
||||||
if (isFormData) {
|
if (isFormData) {
|
||||||
QHttpMultiPart *multiPart = new QHttpMultiPart();
|
auto *multiPart = new QHttpMultiPart();
|
||||||
multiPart->setContentType(QHttpMultiPart::FormDataType);
|
multiPart->setContentType(QHttpMultiPart::FormDataType);
|
||||||
for (const auto& each : params->_paramMap.toStdMap())
|
for (const auto &each: params->_paramMap.toStdMap()) {
|
||||||
{
|
|
||||||
QHttpPart part;
|
QHttpPart part;
|
||||||
part.setHeader(QNetworkRequest::ContentDispositionHeader, QString("form-data; name=\"%1\"").arg(each.first));
|
part.setHeader(QNetworkRequest::ContentDispositionHeader, QString("form-data; name=\"%1\"").arg(each.first));
|
||||||
part.setBody(each.second.toByteArray());
|
part.setBody(each.second.toByteArray());
|
||||||
multiPart->append(part);
|
multiPart->append(part);
|
||||||
}
|
}
|
||||||
for (const auto& each : params->_fileMap.toStdMap())
|
for (const auto &each: params->_fileMap.toStdMap()) {
|
||||||
{
|
|
||||||
QString filePath = each.second.toString();
|
QString filePath = each.second.toString();
|
||||||
QString name = each.first;
|
QString name = each.first;
|
||||||
QFile *file = new QFile(filePath);
|
auto *file = new QFile(filePath);
|
||||||
QString fileName = QFileInfo(filePath).fileName();
|
QString fileName = QFileInfo(filePath).fileName();
|
||||||
file->open(QIODevice::ReadOnly);
|
file->open(QIODevice::ReadOnly);
|
||||||
file->setParent(multiPart);
|
file->setParent(multiPart);
|
||||||
QHttpPart part;
|
QHttpPart part;
|
||||||
part.setHeader(QNetworkRequest::ContentDispositionHeader, QString("form-data; name=\"%1\"; filename=\"%2\"").arg(name,fileName));
|
part.setHeader(QNetworkRequest::ContentDispositionHeader, QString(R"(form-data; name="%1"; filename="%2")").arg(name, fileName));
|
||||||
part.setBodyDevice(file);
|
part.setBodyDevice(file);
|
||||||
multiPart->append(part);
|
multiPart->append(part);
|
||||||
}
|
}
|
||||||
@ -471,8 +466,7 @@ void Network::sendRequest(QNetworkAccessManager* manager,QNetworkRequest request
|
|||||||
} else {
|
} else {
|
||||||
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/x-www-form-urlencoded"));
|
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/x-www-form-urlencoded"));
|
||||||
QString value;
|
QString value;
|
||||||
for (const auto& each : params->_paramMap.toStdMap())
|
for (const auto &each: params->_paramMap.toStdMap()) {
|
||||||
{
|
|
||||||
value += QString("%1=%2").arg(each.first, each.second.toString());
|
value += QString("%1=%2").arg(each.first, each.second.toString());
|
||||||
value += "&";
|
value += "&";
|
||||||
}
|
}
|
||||||
@ -487,8 +481,7 @@ void Network::sendRequest(QNetworkAccessManager* manager,QNetworkRequest request
|
|||||||
case NetworkParams::TYPE_JSON: {
|
case NetworkParams::TYPE_JSON: {
|
||||||
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/json;charset=utf-8"));
|
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/json;charset=utf-8"));
|
||||||
QJsonObject json;
|
QJsonObject json;
|
||||||
for (const auto& each : params->_paramMap.toStdMap())
|
for (const auto &each: params->_paramMap.toStdMap()) {
|
||||||
{
|
|
||||||
json.insert(each.first, each.second.toJsonValue());
|
json.insert(each.first, each.second.toJsonValue());
|
||||||
}
|
}
|
||||||
QByteArray data = QJsonDocument(json).toJson(QJsonDocument::Compact);
|
QByteArray data = QJsonDocument(json).toJson(QJsonDocument::Compact);
|
||||||
@ -498,8 +491,7 @@ void Network::sendRequest(QNetworkAccessManager* manager,QNetworkRequest request
|
|||||||
case NetworkParams::TYPE_JSONARRAY: {
|
case NetworkParams::TYPE_JSONARRAY: {
|
||||||
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/json;charset=utf-8"));
|
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("application/json;charset=utf-8"));
|
||||||
QJsonArray jsonArray;
|
QJsonArray jsonArray;
|
||||||
for (const auto& each : params->_paramMap.toStdMap())
|
for (const auto &each: params->_paramMap.toStdMap()) {
|
||||||
{
|
|
||||||
QJsonObject json;
|
QJsonObject json;
|
||||||
json.insert(each.first, each.second.toJsonValue());
|
json.insert(each.first, each.second.toJsonValue());
|
||||||
jsonArray.append(json);
|
jsonArray.append(json);
|
||||||
@ -523,7 +515,7 @@ void Network::sendRequest(QNetworkAccessManager* manager,QNetworkRequest request
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::printRequestStartLog(QNetworkRequest request,NetworkParams* params){
|
void Network::printRequestStartLog(const QNetworkRequest &request, NetworkParams *params) {
|
||||||
if (!params->getOpenLog()) {
|
if (!params->getOpenLog()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -551,7 +543,7 @@ void Network::printRequestStartLog(QNetworkRequest request,NetworkParams* params
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::printRequestEndLog(QNetworkRequest request,NetworkParams* params,QNetworkReply*& reply,const QString& response){
|
void Network::printRequestEndLog(const QNetworkRequest &request, NetworkParams *params, QNetworkReply *&reply, const QString &response) {
|
||||||
if (!params->getOpenLog()) {
|
if (!params->getOpenLog()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -560,11 +552,10 @@ void Network::printRequestEndLog(QNetworkRequest request,NetworkParams* params,Q
|
|||||||
qDebug() << "<Result>" << qUtf8Printable(response);
|
qDebug() << "<Result>" << qUtf8Printable(response);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::saveResponse(QString key,QString response){
|
void Network::saveResponse(const QString &key, const QString &response) {
|
||||||
QSharedPointer<QFile> file(new QFile(getCacheFilePath(key)));
|
QSharedPointer<QFile> file(new QFile(getCacheFilePath(key)));
|
||||||
QIODevice::OpenMode mode = QIODevice::WriteOnly | QIODevice::Truncate;
|
QIODevice::OpenMode mode = QIODevice::WriteOnly | QIODevice::Truncate;
|
||||||
if (!file->open(mode))
|
if (!file->open(mode)) {
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
file->write(response.toUtf8().toBase64());
|
file->write(response.toUtf8().toBase64());
|
||||||
@ -573,8 +564,7 @@ void Network::saveResponse(QString key,QString response){
|
|||||||
void Network::addHeaders(QNetworkRequest *request, const QMap<QString, QVariant> &headers) {
|
void Network::addHeaders(QNetworkRequest *request, const QMap<QString, QVariant> &headers) {
|
||||||
request->setHeader(QNetworkRequest::UserAgentHeader, QString::fromStdString("Mozilla/5.0 %1/%2").arg(QGuiApplication::applicationName(), QGuiApplication::applicationVersion()));
|
request->setHeader(QNetworkRequest::UserAgentHeader, QString::fromStdString("Mozilla/5.0 %1/%2").arg(QGuiApplication::applicationName(), QGuiApplication::applicationVersion()));
|
||||||
QMapIterator<QString, QVariant> iter(headers);
|
QMapIterator<QString, QVariant> iter(headers);
|
||||||
while (iter.hasNext())
|
while (iter.hasNext()) {
|
||||||
{
|
|
||||||
iter.next();
|
iter.next();
|
||||||
request->setRawHeader(iter.key().toUtf8(), iter.value().toString().toUtf8());
|
request->setRawHeader(iter.key().toUtf8(), iter.value().toString().toUtf8());
|
||||||
}
|
}
|
||||||
@ -583,20 +573,18 @@ void Network::addHeaders(QNetworkRequest* request,const QMap<QString, QVariant>&
|
|||||||
void Network::addQueryParam(QUrl *url, const QMap<QString, QVariant> ¶ms) {
|
void Network::addQueryParam(QUrl *url, const QMap<QString, QVariant> ¶ms) {
|
||||||
QMapIterator<QString, QVariant> iter(params);
|
QMapIterator<QString, QVariant> iter(params);
|
||||||
QUrlQuery urlQuery(*url);
|
QUrlQuery urlQuery(*url);
|
||||||
while (iter.hasNext())
|
while (iter.hasNext()) {
|
||||||
{
|
|
||||||
iter.next();
|
iter.next();
|
||||||
urlQuery.addQueryItem(iter.key(), iter.value().toString());
|
urlQuery.addQueryItem(iter.key(), iter.value().toString());
|
||||||
}
|
}
|
||||||
url->setQuery(urlQuery);
|
url->setQuery(urlQuery);
|
||||||
}
|
}
|
||||||
|
|
||||||
Network::Network(QObject *parent): QObject{parent}
|
Network::Network(QObject *parent) : QObject{parent} {
|
||||||
{
|
_timeout = 5000;
|
||||||
timeout(5000);
|
_retry = 3;
|
||||||
retry(3);
|
_openLog = false;
|
||||||
openLog(false);
|
_cacheDir = QStandardPaths::writableLocation(QStandardPaths::CacheLocation).append(QDir::separator()).append("network");
|
||||||
cacheDir(QStandardPaths::writableLocation(QStandardPaths::CacheLocation).append(QDir::separator()).append("network"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams *Network::get(const QString &url) {
|
NetworkParams *Network::get(const QString &url) {
|
||||||
@ -672,5 +660,5 @@ NetworkParams* Network::deleteJsonArray(const QString& url){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Network::setInterceptor(QJSValue interceptor) {
|
void Network::setInterceptor(QJSValue interceptor) {
|
||||||
this->_interceptor = interceptor;
|
this->_interceptor = std::move(interceptor);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef NETWORK_H
|
#pragma once
|
||||||
#define NETWORK_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -19,7 +18,9 @@ enum CacheMode {
|
|||||||
IfNoneCacheRequest = 0x0002,
|
IfNoneCacheRequest = 0x0002,
|
||||||
FirstCacheThenRequest = 0x0004,
|
FirstCacheThenRequest = 0x0004,
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(CacheMode)
|
Q_ENUM_NS(CacheMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(NetworkType)
|
QML_NAMED_ELEMENT(NetworkType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,12 +32,19 @@ class NetworkCallable : public QObject{
|
|||||||
QML_NAMED_ELEMENT(NetworkCallable)
|
QML_NAMED_ELEMENT(NetworkCallable)
|
||||||
public:
|
public:
|
||||||
explicit NetworkCallable(QObject *parent = nullptr);
|
explicit NetworkCallable(QObject *parent = nullptr);
|
||||||
|
|
||||||
Q_SIGNAL void start();
|
Q_SIGNAL void start();
|
||||||
|
|
||||||
Q_SIGNAL void finish();
|
Q_SIGNAL void finish();
|
||||||
|
|
||||||
Q_SIGNAL void error(int status, QString errorString, QString result);
|
Q_SIGNAL void error(int status, QString errorString, QString result);
|
||||||
|
|
||||||
Q_SIGNAL void success(QString result);
|
Q_SIGNAL void success(QString result);
|
||||||
|
|
||||||
Q_SIGNAL void cache(QString result);
|
Q_SIGNAL void cache(QString result);
|
||||||
|
|
||||||
Q_SIGNAL void uploadProgress(qint64 sent, qint64 total);
|
Q_SIGNAL void uploadProgress(qint64 sent, qint64 total);
|
||||||
|
|
||||||
Q_SIGNAL void downloadProgress(qint64 recv, qint64 total);
|
Q_SIGNAL void downloadProgress(qint64 recv, qint64 total);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -47,17 +55,18 @@ class FluDownloadParam : public QObject{
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit FluDownloadParam(QObject *parent = nullptr);
|
explicit FluDownloadParam(QObject *parent = nullptr);
|
||||||
|
|
||||||
FluDownloadParam(QString destPath, bool append, QObject *parent = nullptr);
|
FluDownloadParam(QString destPath, bool append, QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
QString _destPath;
|
QString _destPath;
|
||||||
bool _append;
|
bool _append{};
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The NetworkParams class
|
* @brief The NetworkParams class
|
||||||
*/
|
*/
|
||||||
class NetworkParams : public QObject
|
class NetworkParams : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
QML_NAMED_ELEMENT(NetworkParams)
|
QML_NAMED_ELEMENT(NetworkParams)
|
||||||
public:
|
public:
|
||||||
@ -76,25 +85,45 @@ public:
|
|||||||
TYPE_JSONARRAY,
|
TYPE_JSONARRAY,
|
||||||
TYPE_BODY
|
TYPE_BODY
|
||||||
};
|
};
|
||||||
|
|
||||||
explicit NetworkParams(QObject *parent = nullptr);
|
explicit NetworkParams(QObject *parent = nullptr);
|
||||||
|
|
||||||
NetworkParams(QString url, Type type, Method method, QObject *parent = nullptr);
|
NetworkParams(QString url, Type type, Method method, QObject *parent = nullptr);
|
||||||
Q_INVOKABLE NetworkParams* addQuery(QString key,QVariant val);
|
|
||||||
Q_INVOKABLE NetworkParams* addHeader(QString key,QVariant val);
|
Q_INVOKABLE NetworkParams *addQuery(const QString &key, const QVariant &val);
|
||||||
Q_INVOKABLE NetworkParams* add(QString key,QVariant val);
|
|
||||||
Q_INVOKABLE NetworkParams* addFile(QString key,QVariant val);
|
Q_INVOKABLE NetworkParams *addHeader(const QString &key, const QVariant &val);
|
||||||
|
|
||||||
|
Q_INVOKABLE NetworkParams *add(const QString &key, const QVariant &val);
|
||||||
|
|
||||||
|
Q_INVOKABLE NetworkParams *addFile(const QString &key, const QVariant &val);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *setBody(QString val);
|
Q_INVOKABLE NetworkParams *setBody(QString val);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *setTimeout(int val);
|
Q_INVOKABLE NetworkParams *setTimeout(int val);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *setRetry(int val);
|
Q_INVOKABLE NetworkParams *setRetry(int val);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *setCacheMode(int val);
|
Q_INVOKABLE NetworkParams *setCacheMode(int val);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *toDownload(QString destPath, bool append = false);
|
Q_INVOKABLE NetworkParams *toDownload(QString destPath, bool append = false);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *bind(QObject *target);
|
Q_INVOKABLE NetworkParams *bind(QObject *target);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *openLog(QVariant val);
|
Q_INVOKABLE NetworkParams *openLog(QVariant val);
|
||||||
|
|
||||||
Q_INVOKABLE void go(NetworkCallable *result);
|
Q_INVOKABLE void go(NetworkCallable *result);
|
||||||
QString buildCacheKey();
|
|
||||||
QString method2String();
|
QString buildCacheKey() const;
|
||||||
int getTimeout();
|
|
||||||
int getRetry();
|
QString method2String() const;
|
||||||
bool getOpenLog();
|
|
||||||
|
int getTimeout() const;
|
||||||
|
|
||||||
|
int getRetry() const;
|
||||||
|
|
||||||
|
bool getOpenLog() const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FluDownloadParam *_downloadParam = nullptr;
|
FluDownloadParam *_downloadParam = nullptr;
|
||||||
QObject *_target = nullptr;
|
QObject *_target = nullptr;
|
||||||
@ -115,8 +144,7 @@ public:
|
|||||||
/**
|
/**
|
||||||
* @brief The Network class
|
* @brief The Network class
|
||||||
*/
|
*/
|
||||||
class Network : public QObject
|
class Network : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(int, timeout)
|
Q_PROPERTY_AUTO(int, timeout)
|
||||||
Q_PROPERTY_AUTO(int, retry)
|
Q_PROPERTY_AUTO(int, retry)
|
||||||
@ -124,46 +152,80 @@ class Network : public QObject
|
|||||||
Q_PROPERTY_AUTO(bool, openLog)
|
Q_PROPERTY_AUTO(bool, openLog)
|
||||||
QML_NAMED_ELEMENT(Network)
|
QML_NAMED_ELEMENT(Network)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit Network(QObject *parent = nullptr);
|
explicit Network(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(Network)
|
SINGLETON(Network)
|
||||||
|
|
||||||
static Network *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine) { return getInstance(); }
|
static Network *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine) { return getInstance(); }
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *get(const QString &url);
|
Q_INVOKABLE NetworkParams *get(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *head(const QString &url);
|
Q_INVOKABLE NetworkParams *head(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *postBody(const QString &url);
|
Q_INVOKABLE NetworkParams *postBody(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *putBody(const QString &url);
|
Q_INVOKABLE NetworkParams *putBody(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *patchBody(const QString &url);
|
Q_INVOKABLE NetworkParams *patchBody(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *deleteBody(const QString &url);
|
Q_INVOKABLE NetworkParams *deleteBody(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *postForm(const QString &url);
|
Q_INVOKABLE NetworkParams *postForm(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *putForm(const QString &url);
|
Q_INVOKABLE NetworkParams *putForm(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *patchForm(const QString &url);
|
Q_INVOKABLE NetworkParams *patchForm(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *deleteForm(const QString &url);
|
Q_INVOKABLE NetworkParams *deleteForm(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *postJson(const QString &url);
|
Q_INVOKABLE NetworkParams *postJson(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *putJson(const QString &url);
|
Q_INVOKABLE NetworkParams *putJson(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *patchJson(const QString &url);
|
Q_INVOKABLE NetworkParams *patchJson(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *deleteJson(const QString &url);
|
Q_INVOKABLE NetworkParams *deleteJson(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *postJsonArray(const QString &url);
|
Q_INVOKABLE NetworkParams *postJsonArray(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *putJsonArray(const QString &url);
|
Q_INVOKABLE NetworkParams *putJsonArray(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *patchJsonArray(const QString &url);
|
Q_INVOKABLE NetworkParams *patchJsonArray(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE NetworkParams *deleteJsonArray(const QString &url);
|
Q_INVOKABLE NetworkParams *deleteJsonArray(const QString &url);
|
||||||
|
|
||||||
Q_INVOKABLE void setInterceptor(QJSValue interceptor);
|
Q_INVOKABLE void setInterceptor(QJSValue interceptor);
|
||||||
|
|
||||||
void handle(NetworkParams *params, NetworkCallable *result);
|
void handle(NetworkParams *params, NetworkCallable *result);
|
||||||
|
|
||||||
void handleDownload(NetworkParams *params, NetworkCallable *result);
|
void handleDownload(NetworkParams *params, NetworkCallable *result);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void sendRequest(QNetworkAccessManager* manager,QNetworkRequest request,NetworkParams* params,QNetworkReply*& reply,bool isFirst,QPointer<NetworkCallable> callable);
|
static void sendRequest(QNetworkAccessManager *manager, QNetworkRequest request, NetworkParams *params, QNetworkReply *&reply, bool isFirst, const QPointer<NetworkCallable> &callable);
|
||||||
void addQueryParam(QUrl* url,const QMap<QString, QVariant>& params);
|
|
||||||
void addHeaders(QNetworkRequest* request,const QMap<QString, QVariant>& headers);
|
static void addQueryParam(QUrl *url, const QMap<QString, QVariant> ¶ms);
|
||||||
void saveResponse(QString key,QString response);
|
|
||||||
|
static void addHeaders(QNetworkRequest *request, const QMap<QString, QVariant> &headers);
|
||||||
|
|
||||||
|
void saveResponse(const QString &key, const QString &response);
|
||||||
|
|
||||||
QString readCache(const QString &key);
|
QString readCache(const QString &key);
|
||||||
|
|
||||||
bool cacheExists(const QString &key);
|
bool cacheExists(const QString &key);
|
||||||
|
|
||||||
QString getCacheFilePath(const QString &key);
|
QString getCacheFilePath(const QString &key);
|
||||||
QString map2String(const QMap<QString, QVariant>& map);
|
|
||||||
QString headerList2String(const QList<QNetworkReply::RawHeaderPair>& data);
|
static QString headerList2String(const QList<QNetworkReply::RawHeaderPair> &data);
|
||||||
void printRequestStartLog(QNetworkRequest request,NetworkParams* params);
|
|
||||||
void printRequestEndLog(QNetworkRequest request,NetworkParams* params,QNetworkReply*& reply,const QString& response);
|
static void printRequestStartLog(const QNetworkRequest &request, NetworkParams *params);
|
||||||
|
|
||||||
|
static void printRequestEndLog(const QNetworkRequest &request, NetworkParams *params, QNetworkReply *&reply, const QString &response);
|
||||||
|
|
||||||
|
static QString map2String(const QMap<QString, QVariant> &map);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
QJSValue _interceptor;
|
QJSValue _interceptor;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // Network_H
|
|
||||||
|
@ -3,15 +3,13 @@
|
|||||||
#include <QDataStream>
|
#include <QDataStream>
|
||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
|
|
||||||
SettingsHelper::SettingsHelper(QObject *parent) : QObject(parent)
|
SettingsHelper::SettingsHelper(QObject *parent) : QObject(parent) {
|
||||||
{
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SettingsHelper::~SettingsHelper() = default;
|
SettingsHelper::~SettingsHelper() = default;
|
||||||
|
|
||||||
void SettingsHelper::save(const QString& key,QVariant val)
|
void SettingsHelper::save(const QString &key, QVariant val) {
|
||||||
{
|
|
||||||
m_settings->setValue(key, val);
|
m_settings->setValue(key, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef SETTINGSHELPER_H
|
#pragma once
|
||||||
#define SETTINGSHELPER_H
|
|
||||||
|
|
||||||
#include <QtCore/qobject.h>
|
#include <QtCore/qobject.h>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -10,26 +9,35 @@
|
|||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include "src/singleton.h"
|
#include "src/singleton.h"
|
||||||
|
|
||||||
class SettingsHelper : public QObject
|
class SettingsHelper : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
private:
|
private:
|
||||||
explicit SettingsHelper(QObject *parent = nullptr);
|
explicit SettingsHelper(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(SettingsHelper)
|
SINGLETON(SettingsHelper)
|
||||||
|
|
||||||
~SettingsHelper() override;
|
~SettingsHelper() override;
|
||||||
|
|
||||||
void init(char *argv[]);
|
void init(char *argv[]);
|
||||||
|
|
||||||
Q_INVOKABLE void saveDarkMode(int darkModel) { save("darkMode", darkModel); }
|
Q_INVOKABLE void saveDarkMode(int darkModel) { save("darkMode", darkModel); }
|
||||||
|
|
||||||
Q_INVOKABLE int getDarkMode() { return get("darkMode", QVariant(0)).toInt(); }
|
Q_INVOKABLE int getDarkMode() { return get("darkMode", QVariant(0)).toInt(); }
|
||||||
|
|
||||||
Q_INVOKABLE void saveUseSystemAppBar(bool useSystemAppBar) { save("useSystemAppBar", useSystemAppBar); }
|
Q_INVOKABLE void saveUseSystemAppBar(bool useSystemAppBar) { save("useSystemAppBar", useSystemAppBar); }
|
||||||
|
|
||||||
Q_INVOKABLE bool getUseSystemAppBar() { return get("useSystemAppBar", QVariant(false)).toBool(); }
|
Q_INVOKABLE bool getUseSystemAppBar() { return get("useSystemAppBar", QVariant(false)).toBool(); }
|
||||||
Q_INVOKABLE void saveLanguage(QString language){save("language",language);}
|
|
||||||
|
Q_INVOKABLE void saveLanguage(const QString &language) { save("language", language); }
|
||||||
|
|
||||||
Q_INVOKABLE QString getLanguage() { return get("language", QVariant("en_US")).toString(); }
|
Q_INVOKABLE QString getLanguage() { return get("language", QVariant("en_US")).toString(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void save(const QString &key, QVariant val);
|
void save(const QString &key, QVariant val);
|
||||||
|
|
||||||
QVariant get(const QString &key, QVariant def = {});
|
QVariant get(const QString &key, QVariant def = {});
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QScopedPointer<QSettings> m_settings;
|
QScopedPointer<QSettings> m_settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SETTINGSHELPER_H
|
|
||||||
|
@ -5,8 +5,7 @@
|
|||||||
|
|
||||||
#include "SettingsHelper.h"
|
#include "SettingsHelper.h"
|
||||||
|
|
||||||
TranslateHelper::TranslateHelper(QObject *parent) : QObject(parent)
|
[[maybe_unused]] TranslateHelper::TranslateHelper(QObject *parent) : QObject(parent) {
|
||||||
{
|
|
||||||
_languages << "en_US";
|
_languages << "en_US";
|
||||||
_languages << "zh_CN";
|
_languages << "zh_CN";
|
||||||
_current = SettingsHelper::getInstance()->getLanguage();
|
_current = SettingsHelper::getInstance()->getLanguage();
|
||||||
@ -17,7 +16,7 @@ TranslateHelper::~TranslateHelper() = default;
|
|||||||
void TranslateHelper::init(QQmlEngine *engine) {
|
void TranslateHelper::init(QQmlEngine *engine) {
|
||||||
_engine = engine;
|
_engine = engine;
|
||||||
_translator = new QTranslator(this);
|
_translator = new QTranslator(this);
|
||||||
qApp->installTranslator(_translator);
|
QGuiApplication::installTranslator(_translator);
|
||||||
QString translatorPath = QGuiApplication::applicationDirPath() + "/i18n";
|
QString translatorPath = QGuiApplication::applicationDirPath() + "/i18n";
|
||||||
if (_translator->load(QString::fromStdString("%1/example_%2.qm").arg(translatorPath, _current))) {
|
if (_translator->load(QString::fromStdString("%1/example_%2.qm").arg(translatorPath, _current))) {
|
||||||
_engine->retranslate();
|
_engine->retranslate();
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef TRANSLATEHELPER_H
|
#pragma once
|
||||||
#define TRANSLATEHELPER_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -7,20 +6,21 @@
|
|||||||
#include "src/singleton.h"
|
#include "src/singleton.h"
|
||||||
#include "src/stdafx.h"
|
#include "src/stdafx.h"
|
||||||
|
|
||||||
class TranslateHelper : public QObject
|
class TranslateHelper : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QString, current)
|
Q_PROPERTY_AUTO(QString, current)
|
||||||
Q_PROPERTY_READONLY_AUTO(QStringList, languages)
|
Q_PROPERTY_READONLY_AUTO(QStringList, languages)
|
||||||
private:
|
private:
|
||||||
explicit TranslateHelper(QObject* parent = nullptr);
|
[[maybe_unused]] explicit TranslateHelper(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(TranslateHelper)
|
SINGLETON(TranslateHelper)
|
||||||
|
|
||||||
~TranslateHelper() override;
|
~TranslateHelper() override;
|
||||||
|
|
||||||
void init(QQmlEngine *engine);
|
void init(QQmlEngine *engine);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QQmlEngine *_engine = nullptr;
|
QQmlEngine *_engine = nullptr;
|
||||||
QTranslator *_translator = nullptr;
|
QTranslator *_translator = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // TRANSLATEHELPER_H
|
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#include "src/component/CircularReveal.h"
|
#include "src/component/CircularReveal.h"
|
||||||
#include "src/component/FileWatcher.h"
|
#include "src/component/FileWatcher.h"
|
||||||
#include "src/component/FpsItem.h"
|
#include "src/component/FpsItem.h"
|
||||||
|
#include "src/component/OpenGLItem.h"
|
||||||
#include "src/helper/SettingsHelper.h"
|
#include "src/helper/SettingsHelper.h"
|
||||||
#include "src/helper/InitializrHelper.h"
|
#include "src/helper/InitializrHelper.h"
|
||||||
#include "src/helper/TranslateHelper.h"
|
#include "src/helper/TranslateHelper.h"
|
||||||
@ -75,6 +76,9 @@ int main(int argc, char *argv[])
|
|||||||
qmlRegisterType<FpsItem>(uri, major, minor, "FpsItem");
|
qmlRegisterType<FpsItem>(uri, major, minor, "FpsItem");
|
||||||
qmlRegisterType<NetworkCallable>(uri,major,minor,"NetworkCallable");
|
qmlRegisterType<NetworkCallable>(uri,major,minor,"NetworkCallable");
|
||||||
qmlRegisterType<NetworkParams>(uri,major,minor,"NetworkParams");
|
qmlRegisterType<NetworkParams>(uri,major,minor,"NetworkParams");
|
||||||
|
qmlRegisterType<OpenGLItem>(uri,major,minor,"OpenGLItem");
|
||||||
|
qmlRegisterUncreatableMetaObject(NetworkType::staticMetaObject, uri, major, minor, "NetworkType", "Access to enums & flags only");
|
||||||
|
|
||||||
QQmlApplicationEngine engine;
|
QQmlApplicationEngine engine;
|
||||||
TranslateHelper::getInstance()->init(&engine);
|
TranslateHelper::getInstance()->init(&engine);
|
||||||
engine.rootContext()->setContextProperty("AppInfo",AppInfo::getInstance());
|
engine.rootContext()->setContextProperty("AppInfo",AppInfo::getInstance());
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef SINGLETON_H
|
#pragma once
|
||||||
#define SINGLETON_H
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The Singleton class
|
* @brief The Singleton class
|
||||||
@ -23,5 +22,3 @@ private: \
|
|||||||
static Class* getInstance() { \
|
static Class* getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SINGLETON_H
|
|
||||||
|
@ -1,11 +1,26 @@
|
|||||||
#ifndef STDAFX_H
|
#pragma once
|
||||||
#define STDAFX_H
|
|
||||||
|
#define Q_PROPERTY_AUTO_P(TYPE, M) \
|
||||||
|
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
||||||
|
public: \
|
||||||
|
Q_SIGNAL void M##Changed(); \
|
||||||
|
void M(TYPE in_##M) \
|
||||||
|
{ \
|
||||||
|
_##M = in_##M; \
|
||||||
|
Q_EMIT M##Changed(); \
|
||||||
|
} \
|
||||||
|
TYPE M() \
|
||||||
|
{ \
|
||||||
|
return _##M; \
|
||||||
|
} \
|
||||||
|
private: \
|
||||||
|
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) \
|
||||||
public: \
|
public: \
|
||||||
Q_SIGNAL void M##Changed(); \
|
Q_SIGNAL void M##Changed(); \
|
||||||
void M(TYPE in_##M) \
|
void M(const TYPE& in_##M) \
|
||||||
{ \
|
{ \
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
@ -22,7 +37,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL) \
|
Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL) \
|
||||||
public: \
|
public: \
|
||||||
Q_SIGNAL void M##Changed(); \
|
Q_SIGNAL void M##Changed(); \
|
||||||
void M(TYPE in_##M) \
|
void M(const TYPE& in_##M) \
|
||||||
{ \
|
{ \
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
@ -33,5 +48,3 @@ Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL)
|
|||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M; \
|
||||||
|
|
||||||
#endif // STDAFX_H
|
|
||||||
|
@ -24,7 +24,7 @@ option(FLUENTUI_BUILD_STATIC_LIB "Build static library." OFF)
|
|||||||
|
|
||||||
#导入Qt相关依赖包
|
#导入Qt相关依赖包
|
||||||
find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Core Quick Qml)
|
find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Core Quick Qml)
|
||||||
find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Core Quick Qml)
|
find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Core Quick)
|
||||||
|
|
||||||
set(QT_SDK_DIR "${Qt${QT_VERSION_MAJOR}_DIR}/../../..")
|
set(QT_SDK_DIR "${Qt${QT_VERSION_MAJOR}_DIR}/../../..")
|
||||||
cmake_path(SET QT_SDK_DIR NORMALIZE ${QT_SDK_DIR})
|
cmake_path(SET QT_SDK_DIR NORMALIZE ${QT_SDK_DIR})
|
||||||
@ -59,7 +59,7 @@ file(GLOB QM_FILE_PATHS ${CMAKE_CURRENT_LIST_DIR}/ *.qm)
|
|||||||
file(COPY ${QM_FILE_PATHS} DESTINATION "${CMAKE_CURRENT_SOURCE_DIR}/Qt${QT_VERSION_MAJOR}/imports/FluentUI/i18n")
|
file(COPY ${QM_FILE_PATHS} DESTINATION "${CMAKE_CURRENT_SOURCE_DIR}/Qt${QT_VERSION_MAJOR}/imports/FluentUI/i18n")
|
||||||
|
|
||||||
#遍历所有Cpp文件
|
#遍历所有Cpp文件
|
||||||
file(GLOB_RECURSE CPP_FILES *.cpp *.h)
|
file(GLOB_RECURSE CPP_FILES *.cpp *.h *.cxx)
|
||||||
foreach (filepath ${CPP_FILES})
|
foreach (filepath ${CPP_FILES})
|
||||||
string(REPLACE "${CMAKE_CURRENT_SOURCE_DIR}/" "" filename ${filepath})
|
string(REPLACE "${CMAKE_CURRENT_SOURCE_DIR}/" "" filename ${filepath})
|
||||||
list(APPEND sources_files ${filename})
|
list(APPEND sources_files ${filename})
|
||||||
|
@ -1 +0,0 @@
|
|||||||
#include "Def.h"
|
|
35
src/Def.h
35
src/Def.h
@ -1,5 +1,4 @@
|
|||||||
#ifndef DEF_H
|
#pragma once
|
||||||
#define DEF_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -12,7 +11,9 @@ enum Position {
|
|||||||
Right = 0x0002,
|
Right = 0x0002,
|
||||||
Bottom = 0x0004,
|
Bottom = 0x0004,
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(Position)
|
Q_ENUM_NS(Position)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluSheetType)
|
QML_NAMED_ELEMENT(FluSheetType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -23,7 +24,9 @@ enum DarkMode {
|
|||||||
Light = 0x0001,
|
Light = 0x0001,
|
||||||
Dark = 0x0002,
|
Dark = 0x0002,
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(DarkMode)
|
Q_ENUM_NS(DarkMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluThemeType)
|
QML_NAMED_ELEMENT(FluThemeType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,7 +37,9 @@ enum Mode {
|
|||||||
Right = 0x0001,
|
Right = 0x0001,
|
||||||
Alternate = 0x0002,
|
Alternate = 0x0002,
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(Mode)
|
Q_ENUM_NS(Mode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluTimelineType)
|
QML_NAMED_ELEMENT(FluTimelineType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,7 +51,9 @@ enum LaunchMode {
|
|||||||
SingleTop = 0x0002,
|
SingleTop = 0x0002,
|
||||||
SingleInstance = 0x0004
|
SingleInstance = 0x0004
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(LaunchMode)
|
Q_ENUM_NS(LaunchMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluPageType)
|
QML_NAMED_ELEMENT(FluPageType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +64,9 @@ enum LaunchMode {
|
|||||||
SingleTask = 0x0001,
|
SingleTask = 0x0001,
|
||||||
SingleInstance = 0x0002
|
SingleInstance = 0x0002
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(LaunchMode)
|
Q_ENUM_NS(LaunchMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluWindowType)
|
QML_NAMED_ELEMENT(FluWindowType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,7 +77,9 @@ enum SelectionMode {
|
|||||||
Single = 0x0001,
|
Single = 0x0001,
|
||||||
Multiple = 0x0002
|
Multiple = 0x0002
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(SelectionMode)
|
Q_ENUM_NS(SelectionMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluTreeViewType)
|
QML_NAMED_ELEMENT(FluTreeViewType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -80,7 +91,9 @@ enum StatusMode {
|
|||||||
Error = 0x0002,
|
Error = 0x0002,
|
||||||
Success = 0x0004
|
Success = 0x0004
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(StatusMode)
|
Q_ENUM_NS(StatusMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluStatusLayoutType)
|
QML_NAMED_ELEMENT(FluStatusLayoutType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,7 +104,9 @@ enum ButtonFlag {
|
|||||||
NegativeButton = 0x0002,
|
NegativeButton = 0x0002,
|
||||||
PositiveButton = 0x0004
|
PositiveButton = 0x0004
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(ButtonFlag)
|
Q_ENUM_NS(ButtonFlag)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluContentDialogType)
|
QML_NAMED_ELEMENT(FluContentDialogType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -101,7 +116,9 @@ enum HourFormat {
|
|||||||
H = 0x0000,
|
H = 0x0000,
|
||||||
HH = 0x0001
|
HH = 0x0001
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(HourFormat)
|
Q_ENUM_NS(HourFormat)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluTimePickerType)
|
QML_NAMED_ELEMENT(FluTimePickerType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,7 +129,9 @@ enum DisplayMode {
|
|||||||
Year = 0x0001,
|
Year = 0x0001,
|
||||||
Decade = 0x0002
|
Decade = 0x0002
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(DisplayMode)
|
Q_ENUM_NS(DisplayMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluCalendarViewType)
|
QML_NAMED_ELEMENT(FluCalendarViewType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -123,13 +142,17 @@ enum TabWidthBehavior {
|
|||||||
SizeToContent = 0x0001,
|
SizeToContent = 0x0001,
|
||||||
Compact = 0x0002
|
Compact = 0x0002
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(TabWidthBehavior)
|
Q_ENUM_NS(TabWidthBehavior)
|
||||||
|
|
||||||
enum CloseButtonVisibility {
|
enum CloseButtonVisibility {
|
||||||
Never = 0x0000,
|
Never = 0x0000,
|
||||||
Always = 0x0001,
|
Always = 0x0001,
|
||||||
OnHover = 0x0002
|
OnHover = 0x0002
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(CloseButtonVisibility)
|
Q_ENUM_NS(CloseButtonVisibility)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluTabViewType)
|
QML_NAMED_ELEMENT(FluTabViewType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,12 +164,16 @@ enum DisplayMode {
|
|||||||
Minimal = 0x0002,
|
Minimal = 0x0002,
|
||||||
Auto = 0x0004
|
Auto = 0x0004
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(DisplayMode)
|
Q_ENUM_NS(DisplayMode)
|
||||||
|
|
||||||
enum PageMode {
|
enum PageMode {
|
||||||
Stack = 0x0000,
|
Stack = 0x0000,
|
||||||
NoStack = 0x0001
|
NoStack = 0x0001
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(PageMode)
|
Q_ENUM_NS(PageMode)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluNavigationViewType)
|
QML_NAMED_ELEMENT(FluNavigationViewType)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1557,8 +1584,8 @@ enum class Fluent_AwesomeType {
|
|||||||
SpeechSolidBold = 0xf8b2,
|
SpeechSolidBold = 0xf8b2,
|
||||||
ClickedOutLoudSolidBold = 0xf8b3,
|
ClickedOutLoudSolidBold = 0xf8b3,
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_ENUM_NS(Fluent_AwesomeType)
|
Q_ENUM_NS(Fluent_AwesomeType)
|
||||||
|
|
||||||
QML_NAMED_ELEMENT(FluentIcons)
|
QML_NAMED_ELEMENT(FluentIcons)
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // DEF_H
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "FluAccentColor.h"
|
#include "FluAccentColor.h"
|
||||||
|
|
||||||
FluAccentColor::FluAccentColor(QObject *parent) : QObject{parent} {
|
FluAccentColor::FluAccentColor(QObject *parent) : QObject{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUACCENTCOLOR_H
|
#pragma once
|
||||||
#define FLUACCENTCOLOR_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -9,9 +8,9 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluAccentColor class
|
* @brief The FluAccentColor class
|
||||||
*/
|
*/
|
||||||
class FluAccentColor : public QObject
|
class FluAccentColor : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PROPERTY_AUTO(QColor, darkest)
|
Q_PROPERTY_AUTO(QColor, darkest)
|
||||||
Q_PROPERTY_AUTO(QColor, darker)
|
Q_PROPERTY_AUTO(QColor, darker)
|
||||||
Q_PROPERTY_AUTO(QColor, dark)
|
Q_PROPERTY_AUTO(QColor, dark)
|
||||||
@ -23,5 +22,3 @@ class FluAccentColor : public QObject
|
|||||||
public:
|
public:
|
||||||
explicit FluAccentColor(QObject *parent = nullptr);
|
explicit FluAccentColor(QObject *parent = nullptr);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUACCENTCOLOR_H
|
|
||||||
|
@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
#include <QQmlEngine>
|
#include <QQmlEngine>
|
||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
#include <QQmlContext>
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <QUuid>
|
#include <QUuid>
|
||||||
@ -11,11 +10,10 @@
|
|||||||
#include <QTranslator>
|
#include <QTranslator>
|
||||||
|
|
||||||
FluApp::FluApp(QObject *parent) : QObject{parent} {
|
FluApp::FluApp(QObject *parent) : QObject{parent} {
|
||||||
useSystemAppBar(false);
|
_useSystemAppBar = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
FluApp::~FluApp(){
|
FluApp::~FluApp() = default;
|
||||||
}
|
|
||||||
|
|
||||||
void FluApp::init(QObject *target, QLocale locale) {
|
void FluApp::init(QObject *target, QLocale locale) {
|
||||||
_locale = locale;
|
_locale = locale;
|
||||||
|
27
src/FluApp.h
27
src/FluApp.h
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUAPP_H
|
#pragma once
|
||||||
#define FLUAPP_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QWindow>
|
#include <QWindow>
|
||||||
@ -15,24 +14,28 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluApp class
|
* @brief The FluApp class
|
||||||
*/
|
*/
|
||||||
class FluApp : public QObject
|
class FluApp : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(bool,useSystemAppBar);
|
|
||||||
Q_PROPERTY_AUTO(QString,windowIcon);
|
Q_PROPERTY_AUTO(bool, useSystemAppBar)
|
||||||
Q_PROPERTY_AUTO(QLocale,locale);
|
Q_PROPERTY_AUTO(QString, windowIcon)
|
||||||
|
Q_PROPERTY_AUTO(QLocale, locale)
|
||||||
QML_NAMED_ELEMENT(FluApp)
|
QML_NAMED_ELEMENT(FluApp)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit FluApp(QObject *parent = nullptr);
|
explicit FluApp(QObject *parent = nullptr);
|
||||||
~FluApp();
|
|
||||||
|
~FluApp() override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluApp)
|
SINGLETON(FluApp)
|
||||||
static FluApp *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine){return getInstance();}
|
|
||||||
|
static FluApp *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
||||||
|
|
||||||
Q_INVOKABLE void init(QObject *target, QLocale locale = QLocale::system());
|
Q_INVOKABLE void init(QObject *target, QLocale locale = QLocale::system());
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QQmlEngine *_engine;
|
QQmlEngine *_engine{};
|
||||||
QTranslator *_translator = nullptr;
|
QTranslator *_translator = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUAPP_H
|
|
||||||
|
@ -3,14 +3,17 @@
|
|||||||
#include <QChar>
|
#include <QChar>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
#include <QRandomGenerator>
|
#include <QRandomGenerator>
|
||||||
#include <qmath.h>
|
|
||||||
|
int generaNumber(int number) {
|
||||||
|
return QRandomGenerator::global()->bounded(0, number);
|
||||||
|
}
|
||||||
|
|
||||||
FluCaptcha::FluCaptcha(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
FluCaptcha::FluCaptcha(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
||||||
ignoreCase(true);
|
_ignoreCase = false;
|
||||||
QFont fontStype;
|
QFont fontStyle;
|
||||||
fontStype.setPixelSize(28);
|
fontStyle.setPixelSize(28);
|
||||||
fontStype.setBold(true);
|
fontStyle.setBold(true);
|
||||||
font(fontStype);
|
font(fontStyle);
|
||||||
setWidth(180);
|
setWidth(180);
|
||||||
setHeight(80);
|
setHeight(80);
|
||||||
refresh();
|
refresh();
|
||||||
@ -21,55 +24,42 @@ void FluCaptcha::paint(QPainter* painter){
|
|||||||
painter->fillRect(boundingRect().toRect(), QColor(255, 255, 255, 255));
|
painter->fillRect(boundingRect().toRect(), QColor(255, 255, 255, 255));
|
||||||
QPen pen;
|
QPen pen;
|
||||||
painter->setFont(_font);
|
painter->setFont(_font);
|
||||||
for(int i=0;i<100;i++)
|
for (int i = 0; i < 100; i++) {
|
||||||
{
|
pen = QPen(QColor(generaNumber(256), generaNumber(256), generaNumber(256)));
|
||||||
pen = QPen(QColor(_generaNumber(256),_generaNumber(256),_generaNumber(256)));
|
|
||||||
painter->setPen(pen);
|
painter->setPen(pen);
|
||||||
painter->drawPoint(_generaNumber(180),_generaNumber(80));
|
painter->drawPoint(generaNumber(180), generaNumber(80));
|
||||||
}
|
}
|
||||||
for(int i=0;i<5;i++)
|
for (int i = 0; i < 5; i++) {
|
||||||
{
|
pen = QPen(QColor(generaNumber(256), generaNumber(256), generaNumber(256)));
|
||||||
pen = QPen(QColor(_generaNumber(256),_generaNumber(256),_generaNumber(256)));
|
|
||||||
painter->setPen(pen);
|
painter->setPen(pen);
|
||||||
painter->drawLine(_generaNumber(180),_generaNumber(80),_generaNumber(180),_generaNumber(80));
|
painter->drawLine(generaNumber(180), generaNumber(80), generaNumber(180), generaNumber(80));
|
||||||
}
|
}
|
||||||
for(int i=0;i<4;i++)
|
for (int i = 0; i < 4; i++) {
|
||||||
{
|
pen = QPen(QColor(generaNumber(255), generaNumber(255), generaNumber(255)));
|
||||||
pen = QPen(QColor(_generaNumber(255),_generaNumber(255),_generaNumber(255)));
|
|
||||||
painter->setPen(pen);
|
painter->setPen(pen);
|
||||||
painter->drawText(15+35*i,10+_generaNumber(15),30,40,Qt::AlignCenter, QString(_code[i]));
|
painter->drawText(15 + 35 * i, 10 + generaNumber(15), 30, 40, Qt::AlignCenter, QString(_code[i]));
|
||||||
}
|
}
|
||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
int FluCaptcha::_generaNumber(int number){
|
|
||||||
return QRandomGenerator::global()->bounded(0,number);
|
|
||||||
}
|
|
||||||
|
|
||||||
void FluCaptcha::refresh() {
|
void FluCaptcha::refresh() {
|
||||||
this->_code.clear();
|
this->_code.clear();
|
||||||
for(int i = 0;i < 4;++i)
|
for (int i = 0; i < 4; ++i) {
|
||||||
{
|
int num = generaNumber(3);
|
||||||
int num = _generaNumber(3);
|
if (num == 0) {
|
||||||
if(num == 0)
|
this->_code += QString::number(generaNumber(10));
|
||||||
{
|
} else if (num == 1) {
|
||||||
this->_code += QString::number(_generaNumber(10));
|
|
||||||
}
|
|
||||||
else if(num == 1)
|
|
||||||
{
|
|
||||||
int temp = 'A';
|
int temp = 'A';
|
||||||
this->_code += static_cast<QChar>(temp + _generaNumber(26));
|
this->_code += static_cast<QChar>(temp + generaNumber(26));
|
||||||
}
|
} else if (num == 2) {
|
||||||
else if(num == 2)
|
|
||||||
{
|
|
||||||
int temp = 'a';
|
int temp = 'a';
|
||||||
this->_code += static_cast<QChar>(temp + _generaNumber(26));
|
this->_code += static_cast<QChar>(temp + generaNumber(26));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluCaptcha::verify(const QString& code){
|
[[maybe_unused]] bool FluCaptcha::verify(const QString &code) {
|
||||||
if (_ignoreCase) {
|
if (_ignoreCase) {
|
||||||
return this->_code.toUpper() == code.toUpper();
|
return this->_code.toUpper() == code.toUpper();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUCAPTCHA_H
|
#pragma once
|
||||||
#define FLUCAPTCHA_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QQuickPaintedItem>
|
#include <QQuickPaintedItem>
|
||||||
@ -9,21 +8,22 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluCaptcha class
|
* @brief The FluCaptcha class
|
||||||
*/
|
*/
|
||||||
class FluCaptcha : public QQuickPaintedItem
|
class FluCaptcha : public QQuickPaintedItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PROPERTY_AUTO(QFont, font);
|
Q_PROPERTY_AUTO(QFont, font);
|
||||||
Q_PROPERTY_AUTO(bool, ignoreCase);
|
Q_PROPERTY_AUTO(bool, ignoreCase);
|
||||||
QML_NAMED_ELEMENT(FluCaptcha)
|
QML_NAMED_ELEMENT(FluCaptcha)
|
||||||
private:
|
|
||||||
int _generaNumber(int number);
|
|
||||||
public:
|
public:
|
||||||
explicit FluCaptcha(QQuickItem *parent = nullptr);
|
explicit FluCaptcha(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
|
|
||||||
Q_INVOKABLE void refresh();
|
Q_INVOKABLE void refresh();
|
||||||
Q_INVOKABLE bool verify(const QString& code);
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] bool verify(const QString &code);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString _code;
|
QString _code;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUCAPTCHA_H
|
|
||||||
|
@ -2,34 +2,33 @@
|
|||||||
#include "FluTools.h"
|
#include "FluTools.h"
|
||||||
|
|
||||||
FluColors::FluColors(QObject *parent) : QObject{parent} {
|
FluColors::FluColors(QObject *parent) : QObject{parent} {
|
||||||
Transparent(QColor(0, 0, 0, 0));
|
_Transparent = QColor(0, 0, 0, 0);
|
||||||
Black(QColor(0, 0, 0));
|
_Black = QColor(0, 0, 0);
|
||||||
White(QColor(255, 255, 255));
|
_White = QColor(255, 255, 255);
|
||||||
Grey10(QColor(250, 249, 248));
|
_Grey10 = QColor(250, 249, 248);
|
||||||
Grey20(QColor(243, 242, 241));
|
_Grey20 = QColor(243, 242, 241);
|
||||||
Grey30(QColor(237, 235, 233));
|
_Grey30 = QColor(237, 235, 233);
|
||||||
Grey40(QColor(225, 223, 221));
|
_Grey40 = QColor(225, 223, 221);
|
||||||
Grey50(QColor(210, 208, 206));
|
_Grey50 = QColor(210, 208, 206);
|
||||||
Grey60(QColor(200, 198, 196));
|
_Grey60 = QColor(200, 198, 196);
|
||||||
Grey70(QColor(190, 185, 184));
|
_Grey70 = QColor(190, 185, 184);
|
||||||
Grey80(QColor(179, 176, 173));
|
_Grey80 = QColor(179, 176, 173);
|
||||||
Grey90(QColor(161, 159, 157));
|
_Grey90 = QColor(161, 159, 157);
|
||||||
Grey100(QColor(151, 149, 146));
|
_Grey100 = QColor(151, 149, 146);
|
||||||
Grey110(QColor(138, 136, 134));
|
_Grey110 = QColor(138, 136, 134);
|
||||||
Grey120(QColor(121, 119, 117));
|
_Grey120 = QColor(121, 119, 117);
|
||||||
Grey130(QColor(96, 94, 92));
|
_Grey130 = QColor(96, 94, 92);
|
||||||
Grey140(QColor(72, 70, 68));
|
_Grey140 = QColor(72, 70, 68);
|
||||||
Grey150(QColor(59, 58, 57));
|
_Grey150 = QColor(59, 58, 57);
|
||||||
Grey160(QColor(50, 49, 48));
|
_Grey160 = QColor(50, 49, 48);
|
||||||
Grey170(QColor(41, 40, 39));
|
_Grey170 = QColor(41, 40, 39);
|
||||||
Grey180(QColor(37, 36, 35));
|
_Grey180 = QColor(37, 36, 35);
|
||||||
Grey190(QColor(32, 31, 30));
|
_Grey190 = QColor(32, 31, 30);
|
||||||
Grey200(QColor(27, 26, 25));
|
_Grey200 = QColor(27, 26, 25);
|
||||||
Grey210(QColor(22, 21, 20));
|
_Grey210 = QColor(22, 21, 20);
|
||||||
Grey220(QColor(17, 16, 15));
|
_Grey220 = QColor(17, 16, 15);
|
||||||
|
|
||||||
|
auto yellow = new FluAccentColor(this);
|
||||||
FluAccentColor *yellow = new FluAccentColor(this);
|
|
||||||
yellow->darkest(QColor(249, 168, 37));
|
yellow->darkest(QColor(249, 168, 37));
|
||||||
yellow->darker(QColor(251, 192, 45));
|
yellow->darker(QColor(251, 192, 45));
|
||||||
yellow->dark(QColor(253, 212, 53));
|
yellow->dark(QColor(253, 212, 53));
|
||||||
@ -37,9 +36,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
yellow->light(QColor(255, 238, 88));
|
yellow->light(QColor(255, 238, 88));
|
||||||
yellow->lighter(QColor(255, 241, 118));
|
yellow->lighter(QColor(255, 241, 118));
|
||||||
yellow->lightest(QColor(255, 245, 155));
|
yellow->lightest(QColor(255, 245, 155));
|
||||||
Yellow(yellow);
|
_Yellow = yellow;
|
||||||
|
|
||||||
FluAccentColor *orange = new FluAccentColor(this);
|
auto orange = new FluAccentColor(this);
|
||||||
orange->darkest(QColor(153, 61, 7));
|
orange->darkest(QColor(153, 61, 7));
|
||||||
orange->darker(QColor(172, 68, 8));
|
orange->darker(QColor(172, 68, 8));
|
||||||
orange->dark(QColor(209, 88, 10));
|
orange->dark(QColor(209, 88, 10));
|
||||||
@ -47,9 +46,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
orange->light(QColor(248, 122, 48));
|
orange->light(QColor(248, 122, 48));
|
||||||
orange->lighter(QColor(249, 145, 84));
|
orange->lighter(QColor(249, 145, 84));
|
||||||
orange->lightest(QColor(250, 192, 106));
|
orange->lightest(QColor(250, 192, 106));
|
||||||
Orange(orange);
|
_Orange = orange;
|
||||||
|
|
||||||
FluAccentColor *red = new FluAccentColor(this);
|
auto red = new FluAccentColor(this);
|
||||||
red->darkest(QColor(143, 10, 21));
|
red->darkest(QColor(143, 10, 21));
|
||||||
red->darker(QColor(162, 11, 24));
|
red->darker(QColor(162, 11, 24));
|
||||||
red->dark(QColor(185, 13, 28));
|
red->dark(QColor(185, 13, 28));
|
||||||
@ -57,9 +56,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
red->light(QColor(236, 64, 79));
|
red->light(QColor(236, 64, 79));
|
||||||
red->lighter(QColor(238, 88, 101));
|
red->lighter(QColor(238, 88, 101));
|
||||||
red->lightest(QColor(240, 107, 118));
|
red->lightest(QColor(240, 107, 118));
|
||||||
Red(red);
|
_Red = red;
|
||||||
|
|
||||||
FluAccentColor *magenta = new FluAccentColor(this);
|
auto magenta = new FluAccentColor(this);
|
||||||
magenta->darkest(QColor(111, 0, 79));
|
magenta->darkest(QColor(111, 0, 79));
|
||||||
magenta->darker(QColor(160, 7, 108));
|
magenta->darker(QColor(160, 7, 108));
|
||||||
magenta->dark(QColor(181, 13, 125));
|
magenta->dark(QColor(181, 13, 125));
|
||||||
@ -67,9 +66,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
magenta->light(QColor(234, 77, 168));
|
magenta->light(QColor(234, 77, 168));
|
||||||
magenta->lighter(QColor(238, 110, 193));
|
magenta->lighter(QColor(238, 110, 193));
|
||||||
magenta->lightest(QColor(241, 140, 213));
|
magenta->lightest(QColor(241, 140, 213));
|
||||||
Magenta(magenta);
|
_Magenta = magenta;
|
||||||
|
|
||||||
FluAccentColor *purple = new FluAccentColor(this);
|
auto purple = new FluAccentColor(this);
|
||||||
purple->darkest(QColor(44, 15, 118));
|
purple->darkest(QColor(44, 15, 118));
|
||||||
purple->darker(QColor(61, 15, 153));
|
purple->darker(QColor(61, 15, 153));
|
||||||
purple->dark(QColor(78, 17, 174));
|
purple->dark(QColor(78, 17, 174));
|
||||||
@ -77,9 +76,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
purple->light(QColor(123, 76, 157));
|
purple->light(QColor(123, 76, 157));
|
||||||
purple->lighter(QColor(141, 110, 189));
|
purple->lighter(QColor(141, 110, 189));
|
||||||
purple->lightest(QColor(158, 142, 217));
|
purple->lightest(QColor(158, 142, 217));
|
||||||
Purple(purple);
|
_Purple = purple;
|
||||||
|
|
||||||
FluAccentColor *blue = new FluAccentColor(this);
|
auto blue = new FluAccentColor(this);
|
||||||
blue->darkest(QColor(0, 74, 131));
|
blue->darkest(QColor(0, 74, 131));
|
||||||
blue->darker(QColor(0, 84, 148));
|
blue->darker(QColor(0, 84, 148));
|
||||||
blue->dark(QColor(0, 102, 180));
|
blue->dark(QColor(0, 102, 180));
|
||||||
@ -87,9 +86,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
blue->light(QColor(38, 140, 220));
|
blue->light(QColor(38, 140, 220));
|
||||||
blue->lighter(QColor(76, 160, 224));
|
blue->lighter(QColor(76, 160, 224));
|
||||||
blue->lightest(QColor(96, 171, 228));
|
blue->lightest(QColor(96, 171, 228));
|
||||||
Blue(blue);
|
_Blue = blue;
|
||||||
|
|
||||||
FluAccentColor *teal = new FluAccentColor(this);
|
auto teal = new FluAccentColor(this);
|
||||||
teal->darkest(QColor(0, 110, 91));
|
teal->darkest(QColor(0, 110, 91));
|
||||||
teal->darker(QColor(0, 124, 103));
|
teal->darker(QColor(0, 124, 103));
|
||||||
teal->dark(QColor(0, 151, 125));
|
teal->dark(QColor(0, 151, 125));
|
||||||
@ -97,9 +96,9 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
teal->light(QColor(38, 189, 164));
|
teal->light(QColor(38, 189, 164));
|
||||||
teal->lighter(QColor(77, 201, 180));
|
teal->lighter(QColor(77, 201, 180));
|
||||||
teal->lightest(QColor(96, 207, 188));
|
teal->lightest(QColor(96, 207, 188));
|
||||||
Teal(teal);
|
_Teal = teal;
|
||||||
|
|
||||||
FluAccentColor *green = new FluAccentColor(this);
|
auto green = new FluAccentColor(this);
|
||||||
green->darkest(QColor(9, 76, 9));
|
green->darkest(QColor(9, 76, 9));
|
||||||
green->darker(QColor(12, 93, 12));
|
green->darker(QColor(12, 93, 12));
|
||||||
green->dark(QColor(14, 111, 14));
|
green->dark(QColor(14, 111, 14));
|
||||||
@ -107,11 +106,11 @@ FluColors::FluColors(QObject *parent):QObject{parent}{
|
|||||||
green->light(QColor(39, 137, 57));
|
green->light(QColor(39, 137, 57));
|
||||||
green->lighter(QColor(76, 156, 76));
|
green->lighter(QColor(76, 156, 76));
|
||||||
green->lightest(QColor(106, 173, 106));
|
green->lightest(QColor(106, 173, 106));
|
||||||
Green(green);
|
_Green = green;
|
||||||
}
|
}
|
||||||
|
|
||||||
FluAccentColor* FluColors::createAccentColor(QColor primaryColor){
|
[[maybe_unused]] FluAccentColor *FluColors::createAccentColor(QColor primaryColor) {
|
||||||
FluAccentColor *accentColor = new FluAccentColor(this);
|
auto accentColor = new FluAccentColor(this);
|
||||||
accentColor->darkest(FluTools::getInstance()->withOpacity(primaryColor, 0.7));
|
accentColor->darkest(FluTools::getInstance()->withOpacity(primaryColor, 0.7));
|
||||||
accentColor->darker(FluTools::getInstance()->withOpacity(primaryColor, 0.8));
|
accentColor->darker(FluTools::getInstance()->withOpacity(primaryColor, 0.8));
|
||||||
accentColor->dark(FluTools::getInstance()->withOpacity(primaryColor, 0.9));
|
accentColor->dark(FluTools::getInstance()->withOpacity(primaryColor, 0.9));
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUCOLORS_H
|
#pragma once
|
||||||
#define FLUCOLORS_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -11,9 +10,9 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluColors class
|
* @brief The FluColors class
|
||||||
*/
|
*/
|
||||||
class FluColors : public QObject
|
class FluColors : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PROPERTY_AUTO(QColor, Transparent);
|
Q_PROPERTY_AUTO(QColor, Transparent);
|
||||||
Q_PROPERTY_AUTO(QColor, Black);
|
Q_PROPERTY_AUTO(QColor, Black);
|
||||||
Q_PROPERTY_AUTO(QColor, White);
|
Q_PROPERTY_AUTO(QColor, White);
|
||||||
@ -39,22 +38,24 @@ class FluColors : public QObject
|
|||||||
Q_PROPERTY_AUTO(QColor, Grey200);
|
Q_PROPERTY_AUTO(QColor, Grey200);
|
||||||
Q_PROPERTY_AUTO(QColor, Grey210);
|
Q_PROPERTY_AUTO(QColor, Grey210);
|
||||||
Q_PROPERTY_AUTO(QColor, Grey220);
|
Q_PROPERTY_AUTO(QColor, Grey220);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Yellow);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Yellow);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Orange);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Orange);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Red);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Red);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Magenta);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Magenta);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Purple);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Purple);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Blue);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Blue);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Teal);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Teal);
|
||||||
Q_PROPERTY_AUTO(FluAccentColor*,Green);
|
Q_PROPERTY_AUTO_P(FluAccentColor*, Green);
|
||||||
QML_NAMED_ELEMENT(FluColors)
|
QML_NAMED_ELEMENT(FluColors)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit FluColors(QObject *parent = nullptr);
|
explicit FluColors(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluColors)
|
SINGLETON(FluColors)
|
||||||
Q_INVOKABLE FluAccentColor* createAccentColor(QColor primaryColor);
|
|
||||||
static FluColors *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine){return getInstance();}
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // FLUCOLORS_H
|
Q_INVOKABLE [[maybe_unused]] FluAccentColor *createAccentColor(QColor primaryColor);
|
||||||
|
|
||||||
|
static FluColors *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
||||||
|
};
|
@ -8,48 +8,59 @@
|
|||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
#pragma comment (lib, "user32.lib")
|
#pragma comment (lib, "user32.lib")
|
||||||
#pragma comment (lib, "dwmapi.lib")
|
#pragma comment (lib, "dwmapi.lib")
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <windowsx.h>
|
#include <windowsx.h>
|
||||||
#include <dwmapi.h>
|
#include <dwmapi.h>
|
||||||
static inline QByteArray qtNativeEventType()
|
|
||||||
{
|
static inline QByteArray qtNativeEventType() {
|
||||||
static const auto result = "windows_generic_MSG";
|
static const auto result = "windows_generic_MSG";
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool isCompositionEnabled() {
|
static inline bool isCompositionEnabled() {
|
||||||
typedef HRESULT (WINAPI *DwmIsCompositionEnabledPtr)(BOOL *pfEnabled);
|
typedef HRESULT (WINAPI *DwmIsCompositionEnabledPtr)(BOOL *pfEnabled);
|
||||||
HMODULE module = ::LoadLibraryW(L"dwmapi.dll");
|
HMODULE module = ::LoadLibraryW(L"dwmapi.dll");
|
||||||
if (module)
|
if (module) {
|
||||||
{
|
|
||||||
BOOL composition_enabled = false;
|
BOOL composition_enabled = false;
|
||||||
DwmIsCompositionEnabledPtr dwm_is_composition_enabled;
|
DwmIsCompositionEnabledPtr dwm_is_composition_enabled;
|
||||||
dwm_is_composition_enabled = reinterpret_cast<DwmIsCompositionEnabledPtr>(::GetProcAddress(module, "DwmIsCompositionEnabled"));
|
dwm_is_composition_enabled = reinterpret_cast<DwmIsCompositionEnabledPtr>(::GetProcAddress(module, "DwmIsCompositionEnabled"));
|
||||||
if (dwm_is_composition_enabled)
|
if (dwm_is_composition_enabled) {
|
||||||
{
|
|
||||||
dwm_is_composition_enabled(&composition_enabled);
|
dwm_is_composition_enabled(&composition_enabled);
|
||||||
}
|
}
|
||||||
return composition_enabled;
|
return composition_enabled;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
FluFrameless::FluFrameless(QQuickItem *parent)
|
bool containsCursorToItem(QQuickItem *item) {
|
||||||
: QQuickItem{parent}
|
if (!item || !item->isVisible()) {
|
||||||
{
|
return false;
|
||||||
appbar(nullptr);
|
}
|
||||||
maximizeButton(nullptr);
|
auto point = QCursor::pos();
|
||||||
minimizedButton(nullptr);
|
auto rect = QRectF(item->mapToGlobal(QPoint(0, 0)), item->size());
|
||||||
closeButton(nullptr);
|
if (point.x() > rect.x() && point.x() < (rect.x() + rect.width()) && point.y() > rect.y() && point.y() < (rect.y() + rect.height())) {
|
||||||
topmost(false);
|
return true;
|
||||||
disabled(false);
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
FluFrameless::~FluFrameless(){
|
FluFrameless::FluFrameless(QQuickItem *parent) : QQuickItem{parent} {
|
||||||
|
_fixSize = false;
|
||||||
|
_appbar = nullptr;
|
||||||
|
_maximizeButton = nullptr;
|
||||||
|
_minimizedButton = nullptr;
|
||||||
|
_closeButton = nullptr;
|
||||||
|
_topmost = false;
|
||||||
|
_disabled = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluFrameless::onDestruction(){
|
FluFrameless::~FluFrameless() = default;
|
||||||
qApp->removeNativeEventFilter(this);
|
|
||||||
|
[[maybe_unused]] void FluFrameless::onDestruction() {
|
||||||
|
QGuiApplication::instance()->removeNativeEventFilter(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluFrameless::componentComplete() {
|
void FluFrameless::componentComplete() {
|
||||||
@ -67,7 +78,7 @@ void FluFrameless::componentComplete(){
|
|||||||
window()->setFlag(Qt::WindowMaximizeButtonHint);
|
window()->setFlag(Qt::WindowMaximizeButtonHint);
|
||||||
}
|
}
|
||||||
window()->installEventFilter(this);
|
window()->installEventFilter(this);
|
||||||
qApp->installNativeEventFilter(this);
|
QGuiApplication::instance()->installNativeEventFilter(this);
|
||||||
if (_maximizeButton) {
|
if (_maximizeButton) {
|
||||||
setHitTestVisible(_maximizeButton);
|
setHitTestVisible(_maximizeButton);
|
||||||
}
|
}
|
||||||
@ -82,8 +93,8 @@ void FluFrameless::componentComplete(){
|
|||||||
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
||||||
if (_fixSize) {
|
if (_fixSize) {
|
||||||
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_THICKFRAME);
|
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_THICKFRAME);
|
||||||
for (int i = 0; i < qApp->screens().count(); ++i) {
|
for (int i = 0; i <= QGuiApplication::screens().count() - 1; ++i) {
|
||||||
connect( qApp->screens().at(i),&QScreen::logicalDotsPerInchChanged,this,[=]{
|
connect(QGuiApplication::screens().at(i), &QScreen::logicalDotsPerInchChanged, this, [=] {
|
||||||
SetWindowPos(hwnd, nullptr, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_FRAMECHANGED);
|
SetWindowPos(hwnd, nullptr, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_FRAMECHANGED);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -92,8 +103,8 @@ void FluFrameless::componentComplete(){
|
|||||||
}
|
}
|
||||||
SetWindowPos(hwnd, nullptr, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_NOSIZE | SWP_FRAMECHANGED);
|
SetWindowPos(hwnd, nullptr, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOOWNERZORDER | SWP_NOMOVE | SWP_NOSIZE | SWP_FRAMECHANGED);
|
||||||
connect(window(), &QQuickWindow::screenChanged, this, [hwnd] {
|
connect(window(), &QQuickWindow::screenChanged, this, [hwnd] {
|
||||||
::SetWindowPos(hwnd,0,0,0,0,0,SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | SWP_FRAMECHANGED | SWP_NOOWNERZORDER);
|
::SetWindowPos(hwnd, nullptr, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | SWP_FRAMECHANGED | SWP_NOOWNERZORDER);
|
||||||
::RedrawWindow(hwnd, NULL, NULL, RDW_INVALIDATE | RDW_UPDATENOW);
|
::RedrawWindow(hwnd, nullptr, nullptr, RDW_INVALIDATE | RDW_UPDATENOW);
|
||||||
});
|
});
|
||||||
#endif
|
#endif
|
||||||
connect(this, &FluFrameless::topmostChanged, this, [this] {
|
connect(this, &FluFrameless::topmostChanged, this, [this] {
|
||||||
@ -102,28 +113,27 @@ void FluFrameless::componentComplete(){
|
|||||||
_setWindowTopmost(topmost());
|
_setWindowTopmost(topmost());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message, QT_NATIVE_EVENT_RESULT_TYPE *result){
|
[[maybe_unused]] bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message, QT_NATIVE_EVENT_RESULT_TYPE *result) {
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
if ((eventType != qtNativeEventType()) || !message) {
|
if ((eventType != qtNativeEventType()) || !message) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
const auto msg = static_cast<const MSG *>(message);
|
const auto msg = static_cast<const MSG *>(message);
|
||||||
const HWND hwnd = msg->hwnd;
|
auto hwnd = msg->hwnd;
|
||||||
if (!hwnd || !msg) {
|
if (!hwnd) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
const qint64 wid = reinterpret_cast<qint64>(hwnd);
|
const quint64 wid = reinterpret_cast<qint64>(hwnd);
|
||||||
if (wid != _current) {
|
if (wid != _current) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
const UINT uMsg = msg->message;
|
const auto uMsg = msg->message;
|
||||||
const WPARAM wParam = msg->wParam;
|
const auto wParam = msg->wParam;
|
||||||
const LPARAM lParam = msg->lParam;
|
const auto lParam = msg->lParam;
|
||||||
static QPoint offsetXY;
|
static QPoint offsetXY;
|
||||||
if (uMsg == WM_WINDOWPOSCHANGING) {
|
if (uMsg == WM_WINDOWPOSCHANGING) {
|
||||||
WINDOWPOS* wp = reinterpret_cast<WINDOWPOS*>(lParam);
|
auto *wp = reinterpret_cast<WINDOWPOS *>(lParam);
|
||||||
if (wp != nullptr && (wp->flags & SWP_NOSIZE) == 0)
|
if (wp != nullptr && (wp->flags & SWP_NOSIZE) == 0) {
|
||||||
{
|
|
||||||
wp->flags |= SWP_NOCOPYBITS;
|
wp->flags |= SWP_NOCOPYBITS;
|
||||||
*result = ::DefWindowProcW(hwnd, uMsg, wParam, lParam);
|
*result = ::DefWindowProcW(hwnd, uMsg, wParam, lParam);
|
||||||
return true;
|
return true;
|
||||||
@ -140,7 +150,7 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
*result = hitTestResult;
|
*result = hitTestResult;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
int offsetSize = 0;
|
int offsetSize;
|
||||||
bool isMaximum = ::IsZoomed(hwnd);
|
bool isMaximum = ::IsZoomed(hwnd);
|
||||||
offsetXY = QPoint(abs(clientRect->left - originalLeft), abs(clientRect->top - originalTop));
|
offsetXY = QPoint(abs(clientRect->left - originalLeft), abs(clientRect->top - originalTop));
|
||||||
if (isMaximum || _isFullScreen()) {
|
if (isMaximum || _isFullScreen()) {
|
||||||
@ -151,12 +161,19 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
if (!isCompositionEnabled()) {
|
if (!isCompositionEnabled()) {
|
||||||
offsetSize = 0;
|
offsetSize = 0;
|
||||||
}
|
}
|
||||||
if (!isMaximum || QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) {
|
#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
|
||||||
|
if (!isMaximum) {
|
||||||
clientRect->top = originalTop + offsetSize;
|
clientRect->top = originalTop + offsetSize;
|
||||||
clientRect->bottom = originalBottom - offsetSize;
|
clientRect->bottom = originalBottom - offsetSize;
|
||||||
clientRect->left = originalLeft + offsetSize;
|
clientRect->left = originalLeft + offsetSize;
|
||||||
clientRect->right = originalRight - offsetSize;
|
clientRect->right = originalRight - offsetSize;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
clientRect->top = originalTop + offsetSize;
|
||||||
|
clientRect->bottom = originalBottom - offsetSize;
|
||||||
|
clientRect->left = originalLeft + offsetSize;
|
||||||
|
clientRect->right = originalRight - offsetSize;
|
||||||
|
#endif
|
||||||
_setMaximizeHovered(false);
|
_setMaximizeHovered(false);
|
||||||
*result = WVR_REDRAW;
|
*result = WVR_REDRAW;
|
||||||
return true;
|
return true;
|
||||||
@ -232,15 +249,15 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
*result = ::DefWindowProcW(hwnd, WM_NCACTIVATE, wParam, -1);
|
*result = ::DefWindowProcW(hwnd, WM_NCACTIVATE, wParam, -1);
|
||||||
return true;
|
return true;
|
||||||
} else if (uMsg == WM_GETMINMAXINFO) {
|
} else if (uMsg == WM_GETMINMAXINFO) {
|
||||||
MINMAXINFO* minmaxInfo = reinterpret_cast<MINMAXINFO *>(lParam);
|
auto *minmaxInfo = reinterpret_cast<MINMAXINFO *>(lParam);
|
||||||
auto pixelRatio = window()->devicePixelRatio();
|
auto pixelRatio = window()->devicePixelRatio();
|
||||||
auto geometry = window()->screen()->availableGeometry();
|
auto geometry = window()->screen()->availableGeometry();
|
||||||
RECT rect;
|
RECT rect;
|
||||||
SystemParametersInfo(SPI_GETWORKAREA, 0, &rect, 0);
|
SystemParametersInfo(SPI_GETWORKAREA, 0, &rect, 0);
|
||||||
minmaxInfo->ptMaxPosition.x = rect.left - offsetXY.x();
|
minmaxInfo->ptMaxPosition.x = rect.left - offsetXY.x();
|
||||||
minmaxInfo->ptMaxPosition.y = rect.top - offsetXY.x();
|
minmaxInfo->ptMaxPosition.y = rect.top - offsetXY.x();
|
||||||
minmaxInfo->ptMaxSize.x = geometry.width()*pixelRatio + offsetXY.x() * 2;
|
minmaxInfo->ptMaxSize.x = qRound(geometry.width() * pixelRatio) + offsetXY.x() * 2;
|
||||||
minmaxInfo->ptMaxSize.y = geometry.height()*pixelRatio + offsetXY.y() * 2;
|
minmaxInfo->ptMaxSize.y = qRound(geometry.height() * pixelRatio) + offsetXY.y() * 2;
|
||||||
return false;
|
return false;
|
||||||
} else if (uMsg == WM_NCRBUTTONDOWN) {
|
} else if (uMsg == WM_NCRBUTTONDOWN) {
|
||||||
if (wParam == HTCAPTION) {
|
if (wParam == HTCAPTION) {
|
||||||
@ -251,7 +268,7 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
const bool spacePressed = ((wParam == VK_SPACE) || (::GetKeyState(VK_SPACE) < 0));
|
const bool spacePressed = ((wParam == VK_SPACE) || (::GetKeyState(VK_SPACE) < 0));
|
||||||
if (altPressed && spacePressed) {
|
if (altPressed && spacePressed) {
|
||||||
auto pos = window()->position();
|
auto pos = window()->position();
|
||||||
_showSystemMenu(QPoint(pos.x(),pos.y()+_appbar->height()));
|
_showSystemMenu(QPoint(pos.x(), qRound(pos.y() + _appbar->height())));
|
||||||
}
|
}
|
||||||
} else if (uMsg == WM_SYSCOMMAND) {
|
} else if (uMsg == WM_SYSCOMMAND) {
|
||||||
if (wParam == SC_MINIMIZE) {
|
if (wParam == SC_MINIMIZE) {
|
||||||
@ -265,8 +282,9 @@ bool FluFrameless::nativeEventFilter(const QByteArray &eventType, void *message,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
#endif
|
#else
|
||||||
return false;
|
return false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluFrameless::_isMaximized() {
|
bool FluFrameless::_isMaximized() {
|
||||||
@ -282,7 +300,7 @@ void FluFrameless::_showSystemMenu(QPoint point){
|
|||||||
HWND hwnd = reinterpret_cast<HWND>(window()->winId());
|
HWND hwnd = reinterpret_cast<HWND>(window()->winId());
|
||||||
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
DWORD style = ::GetWindowLongPtr(hwnd, GWL_STYLE);
|
||||||
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_SYSMENU);
|
::SetWindowLongPtr(hwnd, GWL_STYLE, style | WS_SYSMENU);
|
||||||
const HMENU hMenu = ::GetSystemMenu(hwnd, FALSE);
|
auto hMenu = ::GetSystemMenu(hwnd, FALSE);
|
||||||
if (_isMaximized() || _isFullScreen()) {
|
if (_isMaximized() || _isFullScreen()) {
|
||||||
::EnableMenuItem(hMenu, SC_MOVE, MFS_DISABLED);
|
::EnableMenuItem(hMenu, SC_MOVE, MFS_DISABLED);
|
||||||
::EnableMenuItem(hMenu, SC_RESTORE, MFS_ENABLED);
|
::EnableMenuItem(hMenu, SC_RESTORE, MFS_ENABLED);
|
||||||
@ -297,7 +315,8 @@ void FluFrameless::_showSystemMenu(QPoint point){
|
|||||||
::EnableMenuItem(hMenu, SC_SIZE, MFS_DISABLED);
|
::EnableMenuItem(hMenu, SC_SIZE, MFS_DISABLED);
|
||||||
::EnableMenuItem(hMenu, SC_MAXIMIZE, MFS_DISABLED);
|
::EnableMenuItem(hMenu, SC_MAXIMIZE, MFS_DISABLED);
|
||||||
}
|
}
|
||||||
const int result = ::TrackPopupMenu(hMenu, (TPM_RETURNCMD | (QGuiApplication::isRightToLeft() ? TPM_RIGHTALIGN : TPM_LEFTALIGN)), point.x()*window()->devicePixelRatio(), point.y()*window()->devicePixelRatio(), 0, hwnd, nullptr);
|
const int result = ::TrackPopupMenu(hMenu, (TPM_RETURNCMD | (QGuiApplication::isRightToLeft() ? TPM_RIGHTALIGN : TPM_LEFTALIGN)), qRound(point.x() * window()->devicePixelRatio()),
|
||||||
|
qRound(point.y() * window()->devicePixelRatio()), 0, hwnd, nullptr);
|
||||||
if (result != FALSE) {
|
if (result != FALSE) {
|
||||||
::PostMessageW(hwnd, WM_SYSCOMMAND, result, 0);
|
::PostMessageW(hwnd, WM_SYSCOMMAND, result, 0);
|
||||||
}
|
}
|
||||||
@ -305,32 +324,21 @@ void FluFrameless::_showSystemMenu(QPoint point){
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluFrameless::_containsCursorToItem(QQuickItem* item){
|
|
||||||
if(!item || !item->isVisible()){
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
auto point = QCursor::pos();
|
|
||||||
auto rect = QRectF(item->mapToGlobal(QPoint(0,0)),item->size());
|
|
||||||
if(point.x()>rect.x() && point.x()<(rect.x()+rect.width()) && point.y()>rect.y() && point.y()<(rect.y()+rect.height())){
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool FluFrameless::_hitAppBar() {
|
bool FluFrameless::_hitAppBar() {
|
||||||
foreach (auto item, _hitTestList) {
|
for (int i = 0; i <= _hitTestList.size() - 1; ++i) {
|
||||||
if(_containsCursorToItem(item)){
|
auto item = _hitTestList.at(i);
|
||||||
|
if (containsCursorToItem(item)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(_containsCursorToItem(_appbar)){
|
if (containsCursorToItem(_appbar)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluFrameless::_hitMaximizeButton() {
|
bool FluFrameless::_hitMaximizeButton() {
|
||||||
if(_containsCursorToItem(_maximizeButton)){
|
if (containsCursorToItem(_maximizeButton)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -365,10 +373,12 @@ void FluFrameless::_updateCursor(int edges){
|
|||||||
case Qt::LeftEdge | Qt::BottomEdge:
|
case Qt::LeftEdge | Qt::BottomEdge:
|
||||||
window()->setCursor(Qt::SizeBDiagCursor);
|
window()->setCursor(Qt::SizeBDiagCursor);
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluFrameless::showFullScreen(){
|
[[maybe_unused]] void FluFrameless::showFullScreen() {
|
||||||
window()->showFullScreen();
|
window()->showFullScreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,7 +391,7 @@ void FluFrameless::showMaximized(){
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluFrameless::showMinimized(){
|
[[maybe_unused]] void FluFrameless::showMinimized() {
|
||||||
window()->showMinimized();
|
window()->showMinimized();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUFRAMELESS_H
|
#pragma once
|
||||||
#define FLUFRAMELESS_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
@ -15,47 +14,63 @@ using QT_ENTER_EVENT_TYPE = QEvent;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
class FluFrameless : public QQuickItem,QAbstractNativeEventFilter
|
class FluFrameless : public QQuickItem, QAbstractNativeEventFilter {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QQuickItem*,appbar)
|
Q_PROPERTY_AUTO_P(QQuickItem*, appbar)
|
||||||
|
Q_PROPERTY_AUTO_P(QQuickItem*, maximizeButton)
|
||||||
|
Q_PROPERTY_AUTO_P(QQuickItem*, minimizedButton)
|
||||||
|
Q_PROPERTY_AUTO_P(QQuickItem*, closeButton)
|
||||||
Q_PROPERTY_AUTO(bool, topmost)
|
Q_PROPERTY_AUTO(bool, topmost)
|
||||||
Q_PROPERTY_AUTO(QQuickItem*,maximizeButton)
|
|
||||||
Q_PROPERTY_AUTO(QQuickItem*,minimizedButton)
|
|
||||||
Q_PROPERTY_AUTO(QQuickItem*,closeButton)
|
|
||||||
Q_PROPERTY_AUTO(bool, disabled)
|
Q_PROPERTY_AUTO(bool, disabled)
|
||||||
Q_PROPERTY_AUTO(bool, fixSize)
|
Q_PROPERTY_AUTO(bool, fixSize)
|
||||||
QML_NAMED_ELEMENT(FluFrameless)
|
QML_NAMED_ELEMENT(FluFrameless)
|
||||||
public:
|
public:
|
||||||
explicit FluFrameless(QQuickItem *parent = nullptr);
|
explicit FluFrameless(QQuickItem *parent = nullptr);
|
||||||
~FluFrameless();
|
|
||||||
|
~FluFrameless() override;
|
||||||
|
|
||||||
void componentComplete() override;
|
void componentComplete() override;
|
||||||
bool nativeEventFilter(const QByteArray &eventType, void *message, QT_NATIVE_EVENT_RESULT_TYPE *result) override;
|
|
||||||
Q_INVOKABLE void showFullScreen();
|
[[maybe_unused]] bool nativeEventFilter(const QByteArray &eventType, void *message, QT_NATIVE_EVENT_RESULT_TYPE *result) override;
|
||||||
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void showFullScreen();
|
||||||
|
|
||||||
Q_INVOKABLE void showMaximized();
|
Q_INVOKABLE void showMaximized();
|
||||||
Q_INVOKABLE void showMinimized();
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void showMinimized();
|
||||||
|
|
||||||
Q_INVOKABLE void showNormal();
|
Q_INVOKABLE void showNormal();
|
||||||
|
|
||||||
Q_INVOKABLE void setHitTestVisible(QQuickItem *);
|
Q_INVOKABLE void setHitTestVisible(QQuickItem *);
|
||||||
Q_INVOKABLE void onDestruction();
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void onDestruction();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool eventFilter(QObject *obj, QEvent *event) override;
|
bool eventFilter(QObject *obj, QEvent *event) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool _isFullScreen();
|
bool _isFullScreen();
|
||||||
|
|
||||||
bool _isMaximized();
|
bool _isMaximized();
|
||||||
|
|
||||||
void _updateCursor(int edges);
|
void _updateCursor(int edges);
|
||||||
|
|
||||||
void _setWindowTopmost(bool topmost);
|
void _setWindowTopmost(bool topmost);
|
||||||
|
|
||||||
void _showSystemMenu(QPoint point);
|
void _showSystemMenu(QPoint point);
|
||||||
bool _containsCursorToItem(QQuickItem* item);
|
|
||||||
bool _hitAppBar();
|
bool _hitAppBar();
|
||||||
|
|
||||||
bool _hitMaximizeButton();
|
bool _hitMaximizeButton();
|
||||||
|
|
||||||
void _setMaximizePressed(bool val);
|
void _setMaximizePressed(bool val);
|
||||||
|
|
||||||
void _setMaximizeHovered(bool val);
|
void _setMaximizeHovered(bool val);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
qint64 _current;
|
quint64 _current = 0;
|
||||||
int _edges = 0;
|
int _edges = 0;
|
||||||
int _margins = 8;
|
int _margins = 8;
|
||||||
qint64 _clickTimer = 0;
|
quint64 _clickTimer = 0;
|
||||||
QList<QPointer<QQuickItem>> _hitTestList;
|
QList<QPointer<QQuickItem>> _hitTestList;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUFRAMELESS_H
|
|
||||||
|
@ -3,9 +3,9 @@
|
|||||||
#include "qrcode/qrencode.h"
|
#include "qrcode/qrencode.h"
|
||||||
|
|
||||||
FluQrCodeItem::FluQrCodeItem(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
FluQrCodeItem::FluQrCodeItem(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
||||||
color(QColor(0,0,0,255));
|
_color = QColor(0, 0, 0, 255);
|
||||||
bgColor(QColor(255,255,255,255));
|
_bgColor = QColor(255, 255, 255, 255);
|
||||||
size(100);
|
_size = 100;
|
||||||
setWidth(_size);
|
setWidth(_size);
|
||||||
setHeight(_size);
|
setHeight(_size);
|
||||||
connect(this, &FluQrCodeItem::textChanged, this, [=] { update(); });
|
connect(this, &FluQrCodeItem::textChanged, this, [=] { update(); });
|
||||||
@ -18,7 +18,6 @@ FluQrCodeItem::FluQrCodeItem(QQuickItem* parent):QQuickPaintedItem(parent){
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void FluQrCodeItem::paint(QPainter *painter) {
|
void FluQrCodeItem::paint(QPainter *painter) {
|
||||||
if (_text.isEmpty()) {
|
if (_text.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
@ -28,8 +27,8 @@ void FluQrCodeItem::paint(QPainter* painter){
|
|||||||
}
|
}
|
||||||
painter->save();
|
painter->save();
|
||||||
QRcode *qrcode = QRcode_encodeString(_text.toUtf8().constData(), 2, QR_ECLEVEL_Q, QR_MODE_8, 1);
|
QRcode *qrcode = QRcode_encodeString(_text.toUtf8().constData(), 2, QR_ECLEVEL_Q, QR_MODE_8, 1);
|
||||||
qint32 w = width();
|
auto w = qint32(width());
|
||||||
qint32 h = height();
|
auto h = qint32(height());
|
||||||
qint32 qrcodeW = qrcode->width > 0 ? qrcode->width : 1;
|
qint32 qrcodeW = qrcode->width > 0 ? qrcode->width : 1;
|
||||||
double scaleX = (double) w / (double) qrcodeW;
|
double scaleX = (double) w / (double) qrcodeW;
|
||||||
double scaleY = (double) h / (double) qrcodeW;
|
double scaleY = (double) h / (double) qrcodeW;
|
||||||
@ -39,13 +38,10 @@ void FluQrCodeItem::paint(QPainter* painter){
|
|||||||
p.setPen(Qt::NoPen);
|
p.setPen(Qt::NoPen);
|
||||||
p.drawRect(0, 0, w, h);
|
p.drawRect(0, 0, w, h);
|
||||||
p.setBrush(_color);
|
p.setBrush(_color);
|
||||||
for (qint32 y = 0; y < qrcodeW; y++)
|
for (qint32 y = 0; y < qrcodeW; y++) {
|
||||||
{
|
for (qint32 x = 0; x < qrcodeW; x++) {
|
||||||
for (qint32 x = 0; x < qrcodeW; x++)
|
|
||||||
{
|
|
||||||
unsigned char b = qrcode->data[y * qrcodeW + x];
|
unsigned char b = qrcode->data[y * qrcodeW + x];
|
||||||
if (b & 0x01)
|
if (b & 0x01) {
|
||||||
{
|
|
||||||
QRectF r(x * scaleX, y * scaleY, scaleX, scaleY);
|
QRectF r(x * scaleX, y * scaleY, scaleX, scaleY);
|
||||||
p.drawRects(&r, 1);
|
p.drawRects(&r, 1);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUQRCODEITEM_H
|
#pragma once
|
||||||
#define FLUQRCODEITEM_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QQuickPaintedItem>
|
#include <QQuickPaintedItem>
|
||||||
@ -9,9 +8,9 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluQrCodeItem class
|
* @brief The FluQrCodeItem class
|
||||||
*/
|
*/
|
||||||
class FluQrCodeItem : public QQuickPaintedItem
|
class FluQrCodeItem : public QQuickPaintedItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PROPERTY_AUTO(QString, text)
|
Q_PROPERTY_AUTO(QString, text)
|
||||||
Q_PROPERTY_AUTO(QColor, color)
|
Q_PROPERTY_AUTO(QColor, color)
|
||||||
Q_PROPERTY_AUTO(QColor, bgColor)
|
Q_PROPERTY_AUTO(QColor, bgColor)
|
||||||
@ -19,7 +18,6 @@ class FluQrCodeItem : public QQuickPaintedItem
|
|||||||
QML_NAMED_ELEMENT(FluQrCodeItem)
|
QML_NAMED_ELEMENT(FluQrCodeItem)
|
||||||
public:
|
public:
|
||||||
explicit FluQrCodeItem(QQuickItem *parent = nullptr);
|
explicit FluQrCodeItem(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUQRCODEITEM_H
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLURECTANGLE_H
|
#pragma once
|
||||||
#define FLURECTANGLE_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QQuickPaintedItem>
|
#include <QQuickPaintedItem>
|
||||||
@ -9,15 +8,13 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluRectangle class
|
* @brief The FluRectangle class
|
||||||
*/
|
*/
|
||||||
class FluRectangle : public QQuickPaintedItem
|
class FluRectangle : public QQuickPaintedItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QColor, color)
|
Q_PROPERTY_AUTO(QColor, color)
|
||||||
Q_PROPERTY_AUTO(QList<int>, radius)
|
Q_PROPERTY_AUTO(QList<int>, radius)
|
||||||
QML_NAMED_ELEMENT(FluRectangle)
|
QML_NAMED_ELEMENT(FluRectangle)
|
||||||
public:
|
public:
|
||||||
explicit FluRectangle(QQuickItem *parent = nullptr);
|
explicit FluRectangle(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLURECTANGLE_H
|
|
||||||
|
@ -2,9 +2,7 @@
|
|||||||
|
|
||||||
#include <QJSValueList>
|
#include <QJSValueList>
|
||||||
|
|
||||||
FluTableSortProxyModel::FluTableSortProxyModel(QSortFilterProxyModel *parent)
|
FluTableSortProxyModel::FluTableSortProxyModel(QSortFilterProxyModel *parent) : QSortFilterProxyModel{parent} {
|
||||||
: QSortFilterProxyModel {parent}
|
|
||||||
{
|
|
||||||
_model = nullptr;
|
_model = nullptr;
|
||||||
connect(this, &FluTableSortProxyModel::modelChanged, this, [=] {
|
connect(this, &FluTableSortProxyModel::modelChanged, this, [=] {
|
||||||
setSourceModel(this->model());
|
setSourceModel(this->model());
|
||||||
@ -41,7 +39,7 @@ bool FluTableSortProxyModel::lessThan(const QModelIndex &source_left, const QMod
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTableSortProxyModel::setComparator(QJSValue comparator){
|
[[maybe_unused]] void FluTableSortProxyModel::setComparator(const QJSValue &comparator) {
|
||||||
int column = 0;
|
int column = 0;
|
||||||
if (comparator.isUndefined()) {
|
if (comparator.isUndefined()) {
|
||||||
column = -1;
|
column = -1;
|
||||||
@ -54,22 +52,22 @@ void FluTableSortProxyModel::setComparator(QJSValue comparator){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTableSortProxyModel::setFilter(QJSValue filter){
|
[[maybe_unused]] void FluTableSortProxyModel::setFilter(const QJSValue &filter) {
|
||||||
this->_filter = filter;
|
this->_filter = filter;
|
||||||
invalidateFilter();
|
invalidateFilter();
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant FluTableSortProxyModel::getRow(int rowIndex){
|
[[maybe_unused]] QVariant FluTableSortProxyModel::getRow(int rowIndex) {
|
||||||
QVariant result;
|
QVariant result;
|
||||||
QMetaObject::invokeMethod(_model, "getRow", Q_RETURN_ARG(QVariant, result), Q_ARG(int, mapToSource(index(rowIndex, 0)).row()));
|
QMetaObject::invokeMethod(_model, "getRow", Q_RETURN_ARG(QVariant, result), Q_ARG(int, mapToSource(index(rowIndex, 0)).row()));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTableSortProxyModel::setRow(int rowIndex,QVariant val){
|
[[maybe_unused]] void FluTableSortProxyModel::setRow(int rowIndex, const QVariant &val) {
|
||||||
QMetaObject::invokeMethod(_model, "setRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(QVariant, val));
|
QMetaObject::invokeMethod(_model, "setRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(QVariant, val));
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTableSortProxyModel::removeRow(int rowIndex,int rows){
|
[[maybe_unused]] void FluTableSortProxyModel::removeRow(int rowIndex, int rows) {
|
||||||
QMetaObject::invokeMethod(_model, "removeRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(int, rows));
|
QMetaObject::invokeMethod(_model, "removeRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(int, rows));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUTABLESORTPROXYMODEL_H
|
#pragma once
|
||||||
#define FLUTABLESORTPROXYMODEL_H
|
|
||||||
|
|
||||||
#include <QSortFilterProxyModel>
|
#include <QSortFilterProxyModel>
|
||||||
#include <QAbstractTableModel>
|
#include <QAbstractTableModel>
|
||||||
@ -7,24 +6,30 @@
|
|||||||
#include <QJSValue>
|
#include <QJSValue>
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
class FluTableSortProxyModel : public QSortFilterProxyModel
|
class FluTableSortProxyModel : public QSortFilterProxyModel {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QAbstractTableModel*,model)
|
Q_PROPERTY_AUTO_P(QAbstractTableModel*, model)
|
||||||
QML_NAMED_ELEMENT(FluTableSortProxyModel)
|
QML_NAMED_ELEMENT(FluTableSortProxyModel)
|
||||||
public:
|
public:
|
||||||
explicit FluTableSortProxyModel(QSortFilterProxyModel *parent = nullptr);
|
explicit FluTableSortProxyModel(QSortFilterProxyModel *parent = nullptr);
|
||||||
|
|
||||||
bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const override;
|
bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const override;
|
||||||
|
|
||||||
bool filterAcceptsColumn(int sourceColumn, const QModelIndex &sourceParent) const override;
|
bool filterAcceptsColumn(int sourceColumn, const QModelIndex &sourceParent) const override;
|
||||||
|
|
||||||
bool lessThan(const QModelIndex &sourceLeft, const QModelIndex &sourceRight) const override;
|
bool lessThan(const QModelIndex &sourceLeft, const QModelIndex &sourceRight) const override;
|
||||||
Q_INVOKABLE QVariant getRow(int rowIndex);
|
|
||||||
Q_INVOKABLE void setRow(int rowIndex,QVariant val);
|
Q_INVOKABLE [[maybe_unused]] QVariant getRow(int rowIndex);
|
||||||
Q_INVOKABLE void removeRow(int rowIndex,int rows);
|
|
||||||
Q_INVOKABLE void setComparator(QJSValue comparator);
|
Q_INVOKABLE [[maybe_unused]] void setRow(int rowIndex, const QVariant &val);
|
||||||
Q_INVOKABLE void setFilter(QJSValue filter);
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void removeRow(int rowIndex, int rows);
|
||||||
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] [[maybe_unused]] void setComparator(const QJSValue &comparator);
|
||||||
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void setFilter(const QJSValue &filter);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QJSValue _filter;
|
QJSValue _filter;
|
||||||
QJSValue _comparator;
|
QJSValue _comparator;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUTABLESORTPROXYMODEL_H
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUTEXTSTYLE_H
|
#pragma once
|
||||||
#define FLUTEXTSTYLE_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
@ -10,8 +9,7 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluTextStyle class
|
* @brief The FluTextStyle class
|
||||||
*/
|
*/
|
||||||
class FluTextStyle : public QObject
|
class FluTextStyle : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
Q_PROPERTY_AUTO(QString, family)
|
Q_PROPERTY_AUTO(QString, family)
|
||||||
@ -24,11 +22,12 @@ public:
|
|||||||
Q_PROPERTY_AUTO(QFont, Display);
|
Q_PROPERTY_AUTO(QFont, Display);
|
||||||
QML_NAMED_ELEMENT(FluTextStyle)
|
QML_NAMED_ELEMENT(FluTextStyle)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit FluTextStyle(QObject *parent = nullptr);
|
explicit FluTextStyle(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluTextStyle)
|
SINGLETON(FluTextStyle)
|
||||||
static FluTextStyle *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine){return getInstance();}
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // FLUTEXTSTYLE_H
|
static FluTextStyle *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
||||||
|
};
|
@ -5,18 +5,25 @@
|
|||||||
#include "Def.h"
|
#include "Def.h"
|
||||||
#include "FluColors.h"
|
#include "FluColors.h"
|
||||||
|
|
||||||
|
bool systemDark() {
|
||||||
|
QPalette palette = QGuiApplication::palette();
|
||||||
|
QColor color = palette.color(QPalette::Window).rgb();
|
||||||
|
return color.red() * 0.2126 + color.green() * 0.7152 + color.blue() * 0.0722 <= 255.0f / 2;
|
||||||
|
}
|
||||||
|
|
||||||
FluTheme::FluTheme(QObject *parent) : QObject{parent} {
|
FluTheme::FluTheme(QObject *parent) : QObject{parent} {
|
||||||
|
_accentColor = FluColors::getInstance()->Blue();
|
||||||
|
_darkMode = FluThemeType::DarkMode::Light;
|
||||||
|
_nativeText = false;
|
||||||
|
_animationEnabled = true;
|
||||||
|
_systemDark = systemDark();
|
||||||
|
QGuiApplication::instance()->installEventFilter(this);
|
||||||
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(); });
|
||||||
accentColor(FluColors::getInstance()->Blue());
|
refreshColors();
|
||||||
darkMode(FluThemeType::DarkMode::Light);
|
|
||||||
nativeText(false);
|
|
||||||
animationEnabled(true);
|
|
||||||
_systemDark = systemDark();
|
|
||||||
qApp->installEventFilter(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTheme::refreshColors() {
|
void FluTheme::refreshColors() {
|
||||||
@ -30,15 +37,13 @@ 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));
|
||||||
itemHoverColor(isDark ? QColor(255,255,255,255*0.06) : QColor(0,0,0,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,255*0.09) : QColor(0,0,0,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,255*0.12) : QColor(0,0,0,255*0.09));
|
itemCheckColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12)) : QColor(0, 0, 0, qRound(255 * 0.09)));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTheme::eventFilter(QObject *obj, QEvent *event){
|
bool FluTheme::eventFilter(QObject *, QEvent *event) {
|
||||||
Q_UNUSED(obj);
|
if (event->type() == QEvent::ApplicationPaletteChange || event->type() == QEvent::ThemeChange) {
|
||||||
if (event->type() == QEvent::ApplicationPaletteChange || event->type() == QEvent::ThemeChange)
|
|
||||||
{
|
|
||||||
_systemDark = systemDark();
|
_systemDark = systemDark();
|
||||||
Q_EMIT darkChanged();
|
Q_EMIT darkChanged();
|
||||||
event->accept();
|
event->accept();
|
||||||
@ -47,10 +52,10 @@ bool FluTheme::eventFilter(QObject *obj, QEvent *event){
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QJsonArray FluTheme::awesomeList(const QString& keyword){
|
[[maybe_unused]] QJsonArray FluTheme::awesomeList(const QString &keyword) {
|
||||||
QJsonArray arr;
|
QJsonArray arr;
|
||||||
QMetaEnum enumType = Fluent_Awesome::staticMetaObject.enumerator(Fluent_Awesome::staticMetaObject.indexOfEnumerator("Fluent_AwesomeType"));
|
QMetaEnum enumType = Fluent_Awesome::staticMetaObject.enumerator(Fluent_Awesome::staticMetaObject.indexOfEnumerator("Fluent_AwesomeType"));
|
||||||
for(int i=0; i < enumType.keyCount(); ++i){
|
for (int i = 0; i <= enumType.keyCount() - 1; ++i) {
|
||||||
QString name = enumType.key(i);
|
QString name = enumType.key(i);
|
||||||
int icon = enumType.value(i);
|
int icon = enumType.value(i);
|
||||||
if (keyword.isEmpty() || name.contains(keyword)) {
|
if (keyword.isEmpty() || name.contains(keyword)) {
|
||||||
@ -63,17 +68,9 @@ QJsonArray FluTheme::awesomeList(const QString& keyword){
|
|||||||
return arr;
|
return arr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTheme::systemDark(){
|
bool FluTheme::dark() const {
|
||||||
QPalette palette = qApp->palette();
|
|
||||||
QColor color = palette.color(QPalette::Window).rgb();
|
|
||||||
return !(color.red() * 0.2126 + color.green() * 0.7152 + color.blue() * 0.0722 > 255 / 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool FluTheme::dark(){
|
|
||||||
if (_darkMode == FluThemeType::DarkMode::Dark) {
|
if (_darkMode == FluThemeType::DarkMode::Dark) {
|
||||||
return true;
|
return true;
|
||||||
}else if(_darkMode == FluThemeType::DarkMode::Light){
|
|
||||||
return false;
|
|
||||||
} else if (_darkMode == FluThemeType::DarkMode::System) {
|
} else if (_darkMode == FluThemeType::DarkMode::System) {
|
||||||
return _systemDark;
|
return _systemDark;
|
||||||
} else {
|
} else {
|
||||||
|
@ -13,11 +13,10 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluTheme class
|
* @brief The FluTheme class
|
||||||
*/
|
*/
|
||||||
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(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);
|
||||||
Q_PROPERTY_AUTO(QColor, dividerColor);
|
Q_PROPERTY_AUTO(QColor, dividerColor);
|
||||||
@ -35,17 +34,25 @@ class FluTheme : public QObject
|
|||||||
Q_PROPERTY_AUTO(bool, animationEnabled);
|
Q_PROPERTY_AUTO(bool, animationEnabled);
|
||||||
QML_NAMED_ELEMENT(FluTheme)
|
QML_NAMED_ELEMENT(FluTheme)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit FluTheme(QObject *parent = nullptr);
|
explicit FluTheme(QObject *parent = nullptr);
|
||||||
bool eventFilter(QObject *obj, QEvent *event);
|
|
||||||
bool systemDark();
|
bool eventFilter(QObject *obj, QEvent *event) override;
|
||||||
|
|
||||||
void refreshColors();
|
void refreshColors();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluTheme)
|
SINGLETON(FluTheme)
|
||||||
Q_INVOKABLE QJsonArray awesomeList(const QString& keyword = "");
|
|
||||||
|
Q_INVOKABLE [[maybe_unused]] static QJsonArray awesomeList(const QString &keyword = "");
|
||||||
|
|
||||||
Q_SIGNAL void darkChanged();
|
Q_SIGNAL void darkChanged();
|
||||||
static FluTheme *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine){return getInstance();}
|
|
||||||
bool dark();
|
static FluTheme *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
||||||
|
|
||||||
|
bool dark() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool _systemDark;
|
bool _systemDark;
|
||||||
};
|
};
|
||||||
|
@ -75,21 +75,20 @@ int FluTools::qtMinor(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::setQuitOnLastWindowClosed(bool val) {
|
void FluTools::setQuitOnLastWindowClosed(bool val) {
|
||||||
qApp->setQuitOnLastWindowClosed(val);
|
QGuiApplication::setQuitOnLastWindowClosed(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::setOverrideCursor(Qt::CursorShape shape) {
|
void FluTools::setOverrideCursor(Qt::CursorShape shape) {
|
||||||
qApp->setOverrideCursor(QCursor(shape));
|
QGuiApplication::setOverrideCursor(QCursor(shape));
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::restoreOverrideCursor() {
|
void FluTools::restoreOverrideCursor() {
|
||||||
qApp->restoreOverrideCursor();
|
QGuiApplication::restoreOverrideCursor();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::deleteLater(QObject *p) {
|
void FluTools::deleteLater(QObject *p) {
|
||||||
if (p) {
|
if (p) {
|
||||||
p->deleteLater();
|
p->deleteLater();
|
||||||
p = nullptr;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,11 +107,11 @@ QString FluTools::html2PlantText(const QString& html){
|
|||||||
}
|
}
|
||||||
|
|
||||||
QRect FluTools::getVirtualGeometry() {
|
QRect FluTools::getVirtualGeometry() {
|
||||||
return qApp->primaryScreen()->virtualGeometry();
|
return QGuiApplication::primaryScreen()->virtualGeometry();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::getApplicationDirPath() {
|
QString FluTools::getApplicationDirPath() {
|
||||||
return qApp->applicationDirPath();
|
return QGuiApplication::applicationDirPath();
|
||||||
}
|
}
|
||||||
|
|
||||||
QUrl FluTools::getUrlByFilePath(const QString &path) {
|
QUrl FluTools::getUrlByFilePath(const QString &path) {
|
||||||
@ -124,33 +123,33 @@ QColor FluTools::withOpacity(const QColor& color,qreal opacity){
|
|||||||
return QColor::fromRgba((alpha << 24) | (color.rgba() & 0xffffff));
|
return QColor::fromRgba((alpha << 24) | (color.rgba() & 0xffffff));
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::md5(QString text){
|
QString FluTools::md5(const QString &text) {
|
||||||
return QCryptographicHash::hash(text.toUtf8(), QCryptographicHash::Md5).toHex();
|
return QCryptographicHash::hash(text.toUtf8(), QCryptographicHash::Md5).toHex();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::toBase64(QString text){
|
QString FluTools::toBase64(const QString &text) {
|
||||||
return text.toUtf8().toBase64();
|
return text.toUtf8().toBase64();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::fromBase64(QString text){
|
QString FluTools::fromBase64(const QString &text) {
|
||||||
return QByteArray::fromBase64(text.toUtf8());
|
return QByteArray::fromBase64(text.toUtf8());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTools::removeDir(QString dirPath){
|
bool FluTools::removeDir(const QString &dirPath) {
|
||||||
QDir qDir(dirPath);
|
QDir qDir(dirPath);
|
||||||
return qDir.removeRecursively();
|
return qDir.removeRecursively();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTools::removeFile(QString filePath){
|
bool FluTools::removeFile(const QString &filePath) {
|
||||||
QFile file(filePath);
|
QFile file(filePath);
|
||||||
return file.remove();
|
return file.remove();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FluTools::sha256(QString text){
|
QString FluTools::sha256(const QString &text) {
|
||||||
return QCryptographicHash::hash(text.toUtf8(), QCryptographicHash::Sha256).toHex();
|
return QCryptographicHash::hash(text.toUtf8(), QCryptographicHash::Sha256).toHex();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::showFileInFolder(QString path){
|
void FluTools::showFileInFolder(const QString &path) {
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
QProcess::startDetached("explorer.exe", {"/select,", QDir::toNativeSeparators(path)});
|
QProcess::startDetached("explorer.exe", {"/select,", QDir::toNativeSeparators(path)});
|
||||||
#endif
|
#endif
|
||||||
@ -184,11 +183,11 @@ QIcon FluTools::windowIcon(){
|
|||||||
|
|
||||||
int FluTools::cursorScreenIndex() {
|
int FluTools::cursorScreenIndex() {
|
||||||
int screenIndex = 0;
|
int screenIndex = 0;
|
||||||
int screenCount = qApp->screens().count();
|
int screenCount = QGuiApplication::screens().count();
|
||||||
if (screenCount > 1) {
|
if (screenCount > 1) {
|
||||||
QPoint pos = QCursor::pos();
|
QPoint pos = QCursor::pos();
|
||||||
for (int i = 0; i < screenCount; ++i) {
|
for (int i = 0; i <= screenCount - 1; ++i) {
|
||||||
if (qApp->screens().at(i)->geometry().contains(pos)) {
|
if (QGuiApplication::screens().at(i)->geometry().contains(pos)) {
|
||||||
screenIndex = i;
|
screenIndex = i;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -199,7 +198,7 @@ int FluTools::cursorScreenIndex(){
|
|||||||
|
|
||||||
int FluTools::windowBuildNumber() {
|
int FluTools::windowBuildNumber() {
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
QSettings regKey {QString::fromUtf8("HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion"), QSettings::NativeFormat};
|
QSettings regKey{QString::fromUtf8(R"(HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion)"), QSettings::NativeFormat};
|
||||||
if (regKey.contains(QString::fromUtf8("CurrentBuildNumber"))) {
|
if (regKey.contains(QString::fromUtf8("CurrentBuildNumber"))) {
|
||||||
auto buildNumber = regKey.value(QString::fromUtf8("CurrentBuildNumber")).toInt();
|
auto buildNumber = regKey.value(QString::fromUtf8("CurrentBuildNumber")).toInt();
|
||||||
return buildNumber;
|
return buildNumber;
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUTOOLS_H
|
#pragma once
|
||||||
#define FLUTOOLS_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
@ -11,51 +10,86 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluTools class
|
* @brief The FluTools class
|
||||||
*/
|
*/
|
||||||
class FluTools : public QObject
|
class FluTools : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
QML_NAMED_ELEMENT(FluTools)
|
QML_NAMED_ELEMENT(FluTools)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit FluTools(QObject *parent = nullptr);
|
explicit FluTools(QObject *parent = nullptr);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluTools)
|
SINGLETON(FluTools)
|
||||||
static FluTools *create(QQmlEngine *qmlEngine, QJSEngine *jsEngine){return getInstance();}
|
|
||||||
|
static FluTools *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
||||||
|
|
||||||
Q_INVOKABLE int qtMajor();
|
Q_INVOKABLE int qtMajor();
|
||||||
|
|
||||||
Q_INVOKABLE int qtMinor();
|
Q_INVOKABLE int qtMinor();
|
||||||
|
|
||||||
Q_INVOKABLE bool isMacos();
|
Q_INVOKABLE bool isMacos();
|
||||||
|
|
||||||
Q_INVOKABLE bool isLinux();
|
Q_INVOKABLE bool isLinux();
|
||||||
|
|
||||||
Q_INVOKABLE bool isWin();
|
Q_INVOKABLE bool isWin();
|
||||||
|
|
||||||
Q_INVOKABLE void clipText(const QString &text);
|
Q_INVOKABLE void clipText(const QString &text);
|
||||||
|
|
||||||
Q_INVOKABLE QString uuid();
|
Q_INVOKABLE QString uuid();
|
||||||
|
|
||||||
Q_INVOKABLE QString readFile(const QString &fileName);
|
Q_INVOKABLE QString readFile(const QString &fileName);
|
||||||
|
|
||||||
Q_INVOKABLE void setQuitOnLastWindowClosed(bool val);
|
Q_INVOKABLE void setQuitOnLastWindowClosed(bool val);
|
||||||
|
|
||||||
Q_INVOKABLE void setOverrideCursor(Qt::CursorShape shape);
|
Q_INVOKABLE void setOverrideCursor(Qt::CursorShape shape);
|
||||||
|
|
||||||
Q_INVOKABLE void restoreOverrideCursor();
|
Q_INVOKABLE void restoreOverrideCursor();
|
||||||
|
|
||||||
Q_INVOKABLE QString html2PlantText(const QString &html);
|
Q_INVOKABLE QString html2PlantText(const QString &html);
|
||||||
|
|
||||||
Q_INVOKABLE QString toLocalPath(const QUrl &url);
|
Q_INVOKABLE QString toLocalPath(const QUrl &url);
|
||||||
|
|
||||||
Q_INVOKABLE void deleteLater(QObject *p);
|
Q_INVOKABLE void deleteLater(QObject *p);
|
||||||
|
|
||||||
Q_INVOKABLE QString getFileNameByUrl(const QUrl &url);
|
Q_INVOKABLE QString getFileNameByUrl(const QUrl &url);
|
||||||
|
|
||||||
Q_INVOKABLE QRect getVirtualGeometry();
|
Q_INVOKABLE QRect getVirtualGeometry();
|
||||||
|
|
||||||
Q_INVOKABLE QString getApplicationDirPath();
|
Q_INVOKABLE QString getApplicationDirPath();
|
||||||
|
|
||||||
Q_INVOKABLE QUrl getUrlByFilePath(const QString &path);
|
Q_INVOKABLE QUrl getUrlByFilePath(const QString &path);
|
||||||
|
|
||||||
Q_INVOKABLE QColor withOpacity(const QColor &, qreal alpha);
|
Q_INVOKABLE QColor withOpacity(const QColor &, qreal alpha);
|
||||||
Q_INVOKABLE QString md5(QString text);
|
|
||||||
Q_INVOKABLE QString sha256(QString text);
|
Q_INVOKABLE QString md5(const QString &text);
|
||||||
Q_INVOKABLE QString toBase64(QString text);
|
|
||||||
Q_INVOKABLE QString fromBase64(QString text);
|
Q_INVOKABLE QString sha256(const QString &text);
|
||||||
Q_INVOKABLE bool removeDir(QString dirPath);
|
|
||||||
Q_INVOKABLE bool removeFile(QString filePath);
|
Q_INVOKABLE QString toBase64(const QString &text);
|
||||||
Q_INVOKABLE void showFileInFolder(QString path);
|
|
||||||
|
Q_INVOKABLE QString fromBase64(const QString &text);
|
||||||
|
|
||||||
|
Q_INVOKABLE bool removeDir(const QString &dirPath);
|
||||||
|
|
||||||
|
Q_INVOKABLE bool removeFile(const QString &filePath);
|
||||||
|
|
||||||
|
Q_INVOKABLE void showFileInFolder(const QString &path);
|
||||||
|
|
||||||
Q_INVOKABLE bool isSoftware();
|
Q_INVOKABLE bool isSoftware();
|
||||||
|
|
||||||
Q_INVOKABLE qint64 currentTimestamp();
|
Q_INVOKABLE qint64 currentTimestamp();
|
||||||
|
|
||||||
Q_INVOKABLE QPoint cursorPos();
|
Q_INVOKABLE QPoint cursorPos();
|
||||||
|
|
||||||
Q_INVOKABLE QIcon windowIcon();
|
Q_INVOKABLE QIcon windowIcon();
|
||||||
|
|
||||||
Q_INVOKABLE int cursorScreenIndex();
|
Q_INVOKABLE int cursorScreenIndex();
|
||||||
|
|
||||||
Q_INVOKABLE int windowBuildNumber();
|
Q_INVOKABLE int windowBuildNumber();
|
||||||
|
|
||||||
Q_INVOKABLE bool isWindows11OrGreater();
|
Q_INVOKABLE bool isWindows11OrGreater();
|
||||||
|
|
||||||
Q_INVOKABLE bool isWindows10OrGreater();
|
Q_INVOKABLE bool isWindows10OrGreater();
|
||||||
|
|
||||||
Q_INVOKABLE QRect desktopAvailableGeometry(QQuickWindow *window);
|
Q_INVOKABLE QRect desktopAvailableGeometry(QQuickWindow *window);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUTOOLS_H
|
|
||||||
|
@ -1,31 +1,32 @@
|
|||||||
#include "FluTreeModel.h"
|
#include "FluTreeModel.h"
|
||||||
|
|
||||||
#include <QMetaEnum>
|
#include <QMetaEnum>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
FluTreeNode::FluTreeNode(QObject *parent) : QObject{parent} {
|
FluTreeNode::FluTreeNode(QObject *parent) : QObject{parent} {
|
||||||
}
|
}
|
||||||
|
|
||||||
FluTreeModel::FluTreeModel(QObject *parent) : QAbstractItemModel{parent} {
|
FluTreeModel::FluTreeModel(QObject *parent) : QAbstractItemModel{parent} {
|
||||||
dataSourceSize(0);
|
_dataSourceSize = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
QModelIndex FluTreeModel::parent(const QModelIndex &child) const {
|
QModelIndex FluTreeModel::parent(const QModelIndex &child) const {
|
||||||
return QModelIndex();
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
QModelIndex FluTreeModel::index(int row, int column, const QModelIndex &parent) const {
|
QModelIndex FluTreeModel::index(int row, int column, const QModelIndex &parent) const {
|
||||||
if (!hasIndex(row, column, parent) || parent.isValid())
|
if (!hasIndex(row, column, parent) || parent.isValid())
|
||||||
return QModelIndex();
|
return {};
|
||||||
return createIndex(row, column, _rows.at(row));
|
return createIndex(row, column, _rows.at(row));
|
||||||
}
|
}
|
||||||
|
|
||||||
int FluTreeModel::rowCount(const QModelIndex &parent) const {
|
int FluTreeModel::rowCount(const QModelIndex &parent) const {
|
||||||
return _rows.count();
|
return _rows.count();
|
||||||
};
|
}
|
||||||
|
|
||||||
int FluTreeModel::columnCount(const QModelIndex &parent) const {
|
int FluTreeModel::columnCount(const QModelIndex &parent) const {
|
||||||
return this->_columnSource.size();
|
return this->_columnSource.size();
|
||||||
};
|
}
|
||||||
|
|
||||||
QVariant FluTreeModel::data(const QModelIndex &index, int role) const {
|
QVariant FluTreeModel::data(const QModelIndex &index, int role) const {
|
||||||
switch (role) {
|
switch (role) {
|
||||||
@ -36,19 +37,19 @@ QVariant FluTreeModel::data(const QModelIndex &index, int role) const {
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return QVariant();
|
return {};
|
||||||
};
|
}
|
||||||
|
|
||||||
QHash<int, QByteArray> FluTreeModel::roleNames() const {
|
QHash<int, QByteArray> FluTreeModel::roleNames() const {
|
||||||
return {
|
return {
|
||||||
{TreeModelRoles::RowModel, "rowModel"},
|
{TreeModelRoles::RowModel, "rowModel"},
|
||||||
{TreeModelRoles::ColumnModel, "columnModel"}
|
{TreeModelRoles::ColumnModel, "columnModel"}
|
||||||
};
|
};
|
||||||
};
|
}
|
||||||
|
|
||||||
void FluTreeModel::setData(QList<FluTreeNode *> data) {
|
void FluTreeModel::setData(QList<FluTreeNode *> data) {
|
||||||
beginResetModel();
|
beginResetModel();
|
||||||
_rows = data;
|
_rows = std::move(data);
|
||||||
endResetModel();
|
endResetModel();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,9 +65,9 @@ void FluTreeModel::removeRows(int row,int count){
|
|||||||
endRemoveRows();
|
endRemoveRows();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTreeModel::insertRows(int row,QList<FluTreeNode*> data){
|
void FluTreeModel::insertRows(int row, const QList<FluTreeNode *> &data) {
|
||||||
if (row < 0 || row > _rows.size() || data.size() == 0)
|
if (row < 0 || row > _rows.size() || data.empty())
|
||||||
return;;
|
return;
|
||||||
beginInsertRows(QModelIndex(), row, row + data.size() - 1);
|
beginInsertRows(QModelIndex(), row, row + data.size() - 1);
|
||||||
QList<FluTreeNode *> firstPart = _rows.mid(0, row);
|
QList<FluTreeNode *> firstPart = _rows.mid(0, row);
|
||||||
QList<FluTreeNode *> secondPart = _rows.mid(row);
|
QList<FluTreeNode *> secondPart = _rows.mid(row);
|
||||||
@ -82,7 +83,7 @@ QObject* FluTreeModel::getRow(int row){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FluTreeModel::setRow(int row, QVariantMap data) {
|
void FluTreeModel::setRow(int row, QVariantMap data) {
|
||||||
_rows.at(row)->_data = data;
|
_rows.at(row)->_data = std::move(data);
|
||||||
Q_EMIT dataChanged(index(row, 0), index(row, columnCount() - 1));
|
Q_EMIT dataChanged(index(row, 0), index(row, columnCount() - 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,7 +135,7 @@ void FluTreeModel::setDataSource(QList<QMap<QString,QVariant>> data){
|
|||||||
while (data.count() > 0) {
|
while (data.count() > 0) {
|
||||||
auto item = data.at(data.count() - 1);
|
auto item = data.at(data.count() - 1);
|
||||||
data.pop_back();
|
data.pop_back();
|
||||||
FluTreeNode* node = new FluTreeNode(this);
|
auto *node = new FluTreeNode(this);
|
||||||
node->_depth = item.value("__depth").toInt();
|
node->_depth = item.value("__depth").toInt();
|
||||||
node->_parent = item.value("__parent").value<FluTreeNode *>();
|
node->_parent = item.value("__parent").value<FluTreeNode *>();
|
||||||
node->_data = item;
|
node->_data = item;
|
||||||
@ -150,9 +151,9 @@ void FluTreeModel::setDataSource(QList<QMap<QString,QVariant>> data){
|
|||||||
QList<QVariant> children = item.value("children").toList();
|
QList<QVariant> children = item.value("children").toList();
|
||||||
if (!children.isEmpty()) {
|
if (!children.isEmpty()) {
|
||||||
std::reverse(children.begin(), children.end());
|
std::reverse(children.begin(), children.end());
|
||||||
for (int i = 0; i < children.count(); ++i) {
|
for (int i = 0; i <= children.count() - 1; ++i) {
|
||||||
auto child = children.at(i).toMap();
|
auto child = children.at(i).toMap();
|
||||||
child.insert("__depth",item.value("__depth").toInt(0)+1);
|
child.insert("__depth", item.value("__depth").toInt(nullptr) + 1);
|
||||||
child.insert("__parent", QVariant::fromValue(node));
|
child.insert("__parent", QVariant::fromValue(node));
|
||||||
data.append(child);
|
data.append(child);
|
||||||
}
|
}
|
||||||
@ -220,7 +221,7 @@ bool FluTreeModel::hitHasChildrenExpanded(int row){
|
|||||||
|
|
||||||
void FluTreeModel::refreshNode(int row) {
|
void FluTreeModel::refreshNode(int row) {
|
||||||
Q_EMIT dataChanged(index(row, 0), index(row, 0));
|
Q_EMIT dataChanged(index(row, 0), index(row, 0));
|
||||||
};
|
}
|
||||||
|
|
||||||
FluTreeNode *FluTreeModel::getNode(int row) {
|
FluTreeNode *FluTreeModel::getNode(int row) {
|
||||||
return _rows.at(row);
|
return _rows.at(row);
|
||||||
@ -249,6 +250,7 @@ void FluTreeModel::allExpand(){
|
|||||||
_rows = data;
|
_rows = data;
|
||||||
endResetModel();
|
endResetModel();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTreeModel::allCollapse() {
|
void FluTreeModel::allCollapse() {
|
||||||
beginResetModel();
|
beginResetModel();
|
||||||
QList<FluTreeNode *> stack = _root->_children;
|
QList<FluTreeNode *> stack = _root->_children;
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUTREEMODEL_H
|
#pragma once
|
||||||
#define FLUTREEMODEL_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QAbstractTableModel>
|
#include <QAbstractTableModel>
|
||||||
@ -19,13 +18,18 @@ class FluTreeNode : public QObject{
|
|||||||
Q_PROPERTY(bool checked READ checked CONSTANT)
|
Q_PROPERTY(bool checked READ checked CONSTANT)
|
||||||
public:
|
public:
|
||||||
explicit FluTreeNode(QObject *parent = nullptr);
|
explicit FluTreeNode(QObject *parent = nullptr);
|
||||||
Q_INVOKABLE int depth(){return _depth;};
|
|
||||||
Q_INVOKABLE bool isExpanded(){return _isExpanded;};
|
[[nodiscard]] Q_INVOKABLE int depth() const { return _depth; };
|
||||||
Q_INVOKABLE QVariantMap data(){return _data;};
|
|
||||||
Q_INVOKABLE bool hasChildren(){ return !_children.isEmpty();};
|
[[nodiscard]] Q_INVOKABLE bool isExpanded() const { return _isExpanded; };
|
||||||
|
|
||||||
|
[[nodiscard]] Q_INVOKABLE QVariantMap data() const { return _data; };
|
||||||
|
|
||||||
|
[[nodiscard]] Q_INVOKABLE bool hasChildren() const { return !_children.isEmpty(); };
|
||||||
|
|
||||||
Q_INVOKABLE bool hasNextNodeByIndex(int index) {
|
Q_INVOKABLE bool hasNextNodeByIndex(int index) {
|
||||||
FluTreeNode *p = this;
|
FluTreeNode *p = this;
|
||||||
for(int i=0;i<(_depth - index -1);i++){
|
for (int i = 0; i <= _depth - index - 1; i++) {
|
||||||
p = p->_parent;
|
p = p->_parent;
|
||||||
}
|
}
|
||||||
if (p->_parent->_children.indexOf(p) == p->_parent->_children.count() - 1) {
|
if (p->_parent->_children.indexOf(p) == p->_parent->_children.count() - 1) {
|
||||||
@ -33,18 +37,20 @@ public:
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
Q_INVOKABLE bool checked(){
|
|
||||||
|
[[nodiscard]] Q_INVOKABLE bool checked() const {
|
||||||
if (!hasChildren()) {
|
if (!hasChildren()) {
|
||||||
return _checked;
|
return _checked;
|
||||||
}
|
}
|
||||||
foreach (auto item, _children) {
|
for (int i = 0; i <= _children.size() - 1; ++i) {
|
||||||
|
auto item = _children.at(i);
|
||||||
if (!item->checked()) {
|
if (!item->checked()) {
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
Q_INVOKABLE bool hideLineFooter() {
|
Q_INVOKABLE bool hideLineFooter() {
|
||||||
if (_parent) {
|
if (_parent) {
|
||||||
auto childIndex = _parent->_children.indexOf(this);
|
auto childIndex = _parent->_children.indexOf(this);
|
||||||
@ -58,7 +64,8 @@ public:
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
bool isShown(){
|
|
||||||
|
[[nodiscard]] bool isShown() const {
|
||||||
auto p = _parent;
|
auto p = _parent;
|
||||||
while (p) {
|
while (p) {
|
||||||
if (!p->_isExpanded) {
|
if (!p->_isExpanded) {
|
||||||
@ -68,6 +75,7 @@ public:
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
QString _title = "";
|
QString _title = "";
|
||||||
int _depth = 0;
|
int _depth = 0;
|
||||||
@ -78,8 +86,7 @@ public:
|
|||||||
FluTreeNode *_parent = nullptr;
|
FluTreeNode *_parent = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
class FluTreeModel : public QAbstractItemModel
|
class FluTreeModel : public QAbstractItemModel {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(int, dataSourceSize)
|
Q_PROPERTY_AUTO(int, dataSourceSize)
|
||||||
Q_PROPERTY_AUTO(QList<FluTreeNode *>, selectionModel)
|
Q_PROPERTY_AUTO(QList<FluTreeNode *>, selectionModel)
|
||||||
@ -91,32 +98,51 @@ public:
|
|||||||
RowModel = 0x0101,
|
RowModel = 0x0101,
|
||||||
ColumnModel = 0x0102
|
ColumnModel = 0x0102
|
||||||
};
|
};
|
||||||
|
|
||||||
explicit FluTreeModel(QObject *parent = nullptr);
|
explicit FluTreeModel(QObject *parent = nullptr);
|
||||||
int rowCount(const QModelIndex &parent = QModelIndex()) const override;
|
|
||||||
int columnCount(const QModelIndex &parent = QModelIndex()) const override;
|
[[nodiscard]] int rowCount(const QModelIndex &parent = {}) const override;
|
||||||
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
|
||||||
QHash<int, QByteArray> roleNames() const override;
|
[[nodiscard]] int columnCount(const QModelIndex &parent = {}) const override;
|
||||||
QModelIndex parent(const QModelIndex &child) const override;
|
|
||||||
QModelIndex index(int row, int column,const QModelIndex &parent = QModelIndex()) const override;
|
[[nodiscard]] QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
||||||
|
|
||||||
|
[[nodiscard]] QHash<int, QByteArray> roleNames() const override;
|
||||||
|
|
||||||
|
[[nodiscard]] QModelIndex parent(const QModelIndex &child) const override;
|
||||||
|
|
||||||
|
[[nodiscard]] QModelIndex index(int row, int column, const QModelIndex &parent = {}) const override;
|
||||||
|
|
||||||
Q_INVOKABLE void removeRows(int row, int count);
|
Q_INVOKABLE void removeRows(int row, int count);
|
||||||
Q_INVOKABLE void insertRows(int row,QList<FluTreeNode*> data);
|
|
||||||
|
Q_INVOKABLE void insertRows(int row, const QList<FluTreeNode *> &data);
|
||||||
|
|
||||||
Q_INVOKABLE QObject *getRow(int row);
|
Q_INVOKABLE QObject *getRow(int row);
|
||||||
|
|
||||||
Q_INVOKABLE void setRow(int row, QVariantMap data);
|
Q_INVOKABLE void setRow(int row, QVariantMap data);
|
||||||
|
|
||||||
Q_INVOKABLE void setData(QList<FluTreeNode *> data);
|
Q_INVOKABLE void setData(QList<FluTreeNode *> data);
|
||||||
|
|
||||||
Q_INVOKABLE void setDataSource(QList<QMap<QString, QVariant>> data);
|
Q_INVOKABLE void setDataSource(QList<QMap<QString, QVariant>> data);
|
||||||
|
|
||||||
Q_INVOKABLE void collapse(int row);
|
Q_INVOKABLE void collapse(int row);
|
||||||
|
|
||||||
Q_INVOKABLE void expand(int row);
|
Q_INVOKABLE void expand(int row);
|
||||||
|
|
||||||
Q_INVOKABLE FluTreeNode *getNode(int row);
|
Q_INVOKABLE FluTreeNode *getNode(int row);
|
||||||
|
|
||||||
Q_INVOKABLE void refreshNode(int row);
|
Q_INVOKABLE void refreshNode(int row);
|
||||||
|
|
||||||
Q_INVOKABLE void checkRow(int row, bool checked);
|
Q_INVOKABLE void checkRow(int row, bool checked);
|
||||||
|
|
||||||
Q_INVOKABLE bool hitHasChildrenExpanded(int row);
|
Q_INVOKABLE bool hitHasChildrenExpanded(int row);
|
||||||
|
|
||||||
Q_INVOKABLE void allExpand();
|
Q_INVOKABLE void allExpand();
|
||||||
|
|
||||||
Q_INVOKABLE void allCollapse();
|
Q_INVOKABLE void allCollapse();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QList<FluTreeNode *> _rows;
|
QList<FluTreeNode *> _rows;
|
||||||
QList<FluTreeNode *> _dataSource;
|
QList<FluTreeNode *> _dataSource;
|
||||||
FluTreeNode *_root = nullptr;
|
FluTreeNode *_root = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUTREEMODEL_H
|
|
||||||
|
@ -3,12 +3,12 @@
|
|||||||
#include "FluTextStyle.h"
|
#include "FluTextStyle.h"
|
||||||
|
|
||||||
FluWatermark::FluWatermark(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
FluWatermark::FluWatermark(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
||||||
gap(QPoint(100,100));
|
_gap = QPoint(100, 100);
|
||||||
offset(QPoint(_gap.x()/2,_gap.y()/2));
|
_offset = QPoint(_gap.x() / 2, _gap.y() / 2);
|
||||||
rotate(22);
|
_rotate = 22;
|
||||||
|
_textColor = QColor(222, 222, 222, 222);
|
||||||
|
_textSize = 16;
|
||||||
setZ(9999);
|
setZ(9999);
|
||||||
textColor(QColor(222,222,222,222));
|
|
||||||
textSize(16);
|
|
||||||
connect(this, &FluWatermark::textColorChanged, this, [=] { update(); });
|
connect(this, &FluWatermark::textColorChanged, this, [=] { update(); });
|
||||||
connect(this, &FluWatermark::gapChanged, this, [=] { update(); });
|
connect(this, &FluWatermark::gapChanged, this, [=] { update(); });
|
||||||
connect(this, &FluWatermark::offsetChanged, this, [=] { update(); });
|
connect(this, &FluWatermark::offsetChanged, this, [=] { update(); });
|
||||||
@ -26,14 +26,12 @@ void FluWatermark::paint(QPainter* painter){
|
|||||||
QFontMetricsF fontMetrics(font);
|
QFontMetricsF fontMetrics(font);
|
||||||
qreal fontWidth = fontMetrics.horizontalAdvance(_text);
|
qreal fontWidth = fontMetrics.horizontalAdvance(_text);
|
||||||
qreal fontHeight = fontMetrics.height();
|
qreal fontHeight = fontMetrics.height();
|
||||||
int stepX = fontWidth + _gap.x();
|
int stepX = qRound(fontWidth + _gap.x());
|
||||||
int stepY = fontHeight + _gap.y();
|
int stepY = qRound(fontHeight + _gap.y());
|
||||||
int rowCount = width() / stepX+1;
|
int rowCount = qRound(width() / stepX + 1);
|
||||||
int colCount = height() / stepY+1;
|
int colCount = qRound(height() / stepY + 1);
|
||||||
for (int r = 0; r < rowCount; r++)
|
for (int r = 0; r < rowCount; r++) {
|
||||||
{
|
for (int c = 0; c < colCount; c++) {
|
||||||
for (int c = 0; c < colCount; c++)
|
|
||||||
{
|
|
||||||
qreal centerX = stepX * r + _offset.x() + fontWidth / 2.0;
|
qreal centerX = stepX * r + _offset.x() + fontWidth / 2.0;
|
||||||
qreal centerY = stepY * c + _offset.y() + fontHeight / 2.0;
|
qreal centerY = stepY * c + _offset.y() + fontHeight / 2.0;
|
||||||
painter->save();
|
painter->save();
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUWATERMARK_H
|
#pragma once
|
||||||
#define FLUWATERMARK_H
|
|
||||||
|
|
||||||
#include <QQuickItem>
|
#include <QQuickItem>
|
||||||
#include <QQuickPaintedItem>
|
#include <QQuickPaintedItem>
|
||||||
@ -9,8 +8,7 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluWatermark class
|
* @brief The FluWatermark class
|
||||||
*/
|
*/
|
||||||
class FluWatermark : public QQuickPaintedItem
|
class FluWatermark : public QQuickPaintedItem {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QString, text)
|
Q_PROPERTY_AUTO(QString, text)
|
||||||
Q_PROPERTY_AUTO(QPoint, gap)
|
Q_PROPERTY_AUTO(QPoint, gap)
|
||||||
@ -21,7 +19,6 @@ class FluWatermark : public QQuickPaintedItem
|
|||||||
QML_NAMED_ELEMENT(FluWatermark)
|
QML_NAMED_ELEMENT(FluWatermark)
|
||||||
public:
|
public:
|
||||||
explicit FluWatermark(QQuickItem *parent = nullptr);
|
explicit FluWatermark(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUWATERMARK_H
|
|
||||||
|
@ -16,14 +16,15 @@
|
|||||||
#include "FluFrameless.h"
|
#include "FluFrameless.h"
|
||||||
|
|
||||||
void FluentUI::registerTypes(QQmlEngine *engine) {
|
void FluentUI::registerTypes(QQmlEngine *engine) {
|
||||||
initializeEngine(engine,uri);
|
initializeEngine(engine, _uri);
|
||||||
registerTypes(uri);
|
registerTypes(_uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluentUI::registerTypes(const char *uri){
|
void FluentUI::registerTypes(const char *uri) const {
|
||||||
#if (QT_VERSION < QT_VERSION_CHECK(6, 2, 0))
|
#if (QT_VERSION < QT_VERSION_CHECK(6, 2, 0))
|
||||||
Q_INIT_RESOURCE(fluentui);
|
Q_INIT_RESOURCE(fluentui);
|
||||||
|
int major = _major;
|
||||||
|
int minor = _minor;
|
||||||
//@uri FluentUI
|
//@uri FluentUI
|
||||||
qmlRegisterType<FluQrCodeItem>(uri, major, minor, "FluQrCodeItem");
|
qmlRegisterType<FluQrCodeItem>(uri, major, minor, "FluQrCodeItem");
|
||||||
qmlRegisterType<FluCaptcha>(uri, major, minor, "FluCaptcha");
|
qmlRegisterType<FluCaptcha>(uri, major, minor, "FluCaptcha");
|
||||||
@ -148,7 +149,7 @@ void FluentUI::registerTypes(const char *uri){
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluentUI::initializeEngine(QQmlEngine *engine, const char *uri){
|
void FluentUI::initializeEngine(QQmlEngine *engine, [[maybe_unused]] const char *uri) {
|
||||||
engine->rootContext()->setContextProperty("FluApp", FluApp::getInstance());
|
engine->rootContext()->setContextProperty("FluApp", FluApp::getInstance());
|
||||||
engine->rootContext()->setContextProperty("FluColors", FluColors::getInstance());
|
engine->rootContext()->setContextProperty("FluColors", FluColors::getInstance());
|
||||||
engine->rootContext()->setContextProperty("FluTheme", FluTheme::getInstance());
|
engine->rootContext()->setContextProperty("FluTheme", FluTheme::getInstance());
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef FLUENTUI_H
|
#pragma once
|
||||||
#define FLUENTUI_H
|
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QQmlEngine>
|
#include <QQmlEngine>
|
||||||
@ -8,18 +7,20 @@
|
|||||||
/**
|
/**
|
||||||
* @brief The FluentUI class
|
* @brief The FluentUI class
|
||||||
*/
|
*/
|
||||||
class FluentUI : public QObject
|
class FluentUI : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(FluentUI)
|
SINGLETON(FluentUI)
|
||||||
Q_DECL_EXPORT void registerTypes(QQmlEngine *engine);
|
|
||||||
void registerTypes(const char *uri);
|
|
||||||
void initializeEngine(QQmlEngine *engine, const char *uri);
|
|
||||||
private:
|
|
||||||
const int major = 1;
|
|
||||||
const int minor = 0;
|
|
||||||
const char *uri = "FluentUI";
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // FLUENTUI_H
|
Q_DECL_EXPORT void registerTypes(QQmlEngine *engine);
|
||||||
|
|
||||||
|
void registerTypes(const char *uri) const;
|
||||||
|
|
||||||
|
void initializeEngine(QQmlEngine *engine, [[maybe_unused]] const char *uri);
|
||||||
|
|
||||||
|
private:
|
||||||
|
const int _major = 1;
|
||||||
|
const int _minor = 0;
|
||||||
|
const char *_uri = "FluentUI";
|
||||||
|
};
|
@ -2,18 +2,12 @@
|
|||||||
|
|
||||||
#include "FluentUI.h"
|
#include "FluentUI.h"
|
||||||
|
|
||||||
FluentUIPlugin::FluentUIPlugin()
|
FluentUIPlugin::FluentUIPlugin() = default;
|
||||||
{
|
|
||||||
|
|
||||||
}
|
void FluentUIPlugin::registerTypes(const char *uri) {
|
||||||
|
|
||||||
void FluentUIPlugin::registerTypes(const char *uri)
|
|
||||||
{
|
|
||||||
FluentUI::getInstance()->registerTypes(uri);
|
FluentUI::getInstance()->registerTypes(uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluentUIPlugin::initializeEngine(QQmlEngine *engine, const char *uri)
|
void FluentUIPlugin::initializeEngine(QQmlEngine *engine, const char *uri) {
|
||||||
{
|
|
||||||
Q_UNUSED(uri)
|
|
||||||
FluentUI::getInstance()->initializeEngine(engine, uri);
|
FluentUI::getInstance()->initializeEngine(engine, uri);
|
||||||
}
|
}
|
||||||
|
@ -1,19 +1,18 @@
|
|||||||
#ifndef FLUENTUIPLUGIN_H
|
#pragma once
|
||||||
#define FLUENTUIPLUGIN_H
|
|
||||||
|
|
||||||
#include <QQmlExtensionPlugin>
|
#include <QQmlExtensionPlugin>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The FluentUIPlugin class
|
* @brief The FluentUIPlugin class
|
||||||
*/
|
*/
|
||||||
class FluentUIPlugin : public QQmlExtensionPlugin
|
class FluentUIPlugin : public QQmlExtensionPlugin {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PLUGIN_METADATA(IID QQmlExtensionInterface_iid)
|
Q_PLUGIN_METADATA(IID QQmlExtensionInterface_iid)
|
||||||
public:
|
public:
|
||||||
FluentUIPlugin();
|
FluentUIPlugin();
|
||||||
|
|
||||||
void registerTypes(const char *uri) Q_DECL_OVERRIDE;
|
void registerTypes(const char *uri) Q_DECL_OVERRIDE;
|
||||||
|
|
||||||
void initializeEngine(QQmlEngine *engine, const char *uri) Q_DECL_OVERRIDE;
|
void initializeEngine(QQmlEngine *engine, const char *uri) Q_DECL_OVERRIDE;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FLUENTUIPLUGIN_H
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#ifndef SINGLETON_H
|
#pragma once
|
||||||
#define SINGLETON_H
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The Singleton class
|
* @brief The Singleton class
|
||||||
@ -23,5 +22,3 @@ private: \
|
|||||||
static Class* getInstance() { \
|
static Class* getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SINGLETON_H
|
|
||||||
|
25
src/stdafx.h
25
src/stdafx.h
@ -1,11 +1,26 @@
|
|||||||
#ifndef STDAFX_H
|
#pragma once
|
||||||
#define STDAFX_H
|
|
||||||
|
#define Q_PROPERTY_AUTO_P(TYPE, M) \
|
||||||
|
Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed) \
|
||||||
|
public: \
|
||||||
|
Q_SIGNAL void M##Changed(); \
|
||||||
|
void M(TYPE in_##M) \
|
||||||
|
{ \
|
||||||
|
_##M = in_##M; \
|
||||||
|
Q_EMIT M##Changed(); \
|
||||||
|
} \
|
||||||
|
TYPE M() \
|
||||||
|
{ \
|
||||||
|
return _##M; \
|
||||||
|
} \
|
||||||
|
private: \
|
||||||
|
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) \
|
||||||
public: \
|
public: \
|
||||||
Q_SIGNAL void M##Changed(); \
|
Q_SIGNAL void M##Changed(); \
|
||||||
void M(TYPE in_##M) \
|
void M(const TYPE& in_##M) \
|
||||||
{ \
|
{ \
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
@ -22,7 +37,7 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL) \
|
Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL) \
|
||||||
public: \
|
public: \
|
||||||
Q_SIGNAL void M##Changed(); \
|
Q_SIGNAL void M##Changed(); \
|
||||||
void M(TYPE in_##M) \
|
void M(const TYPE& in_##M) \
|
||||||
{ \
|
{ \
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
@ -33,5 +48,3 @@ Q_PROPERTY(TYPE M READ M NOTIFY M##Changed FINAL)
|
|||||||
} \
|
} \
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M; \
|
TYPE _##M; \
|
||||||
|
|
||||||
#endif // STDAFX_H
|
|
||||||
|
Loading…
Reference in New Issue
Block a user