mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-23 04:14:35 +08:00
Compare commits
2 Commits
2f4b4ee85e
...
8d1ee6fc36
Author | SHA1 | Date | |
---|---|---|---|
|
8d1ee6fc36 | ||
|
1dc726a61a |
130
.clang-format
Normal file
130
.clang-format
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
# References:
|
||||||
|
# https://clang.llvm.org/docs/ClangFormatStyleOptions.html
|
||||||
|
# https://code.qt.io/cgit/qt/qt5.git/tree/_clang-format
|
||||||
|
|
||||||
|
BasedOnStyle: LLVM
|
||||||
|
|
||||||
|
Standard: c++17
|
||||||
|
|
||||||
|
# 指针和引用的对齐方式。
|
||||||
|
# 可能的值有:
|
||||||
|
# PAS_Left (在配置中: Left) 指针左对齐。
|
||||||
|
# PAS_Right (在配置中: Right) 指针右对齐。
|
||||||
|
# PAS_Middle (在配置中: Middle) 指针中间对齐。
|
||||||
|
PointerAlignment: Right
|
||||||
|
|
||||||
|
# public/protected/private 等访问修饰符偏移量
|
||||||
|
AccessModifierOffset: -4
|
||||||
|
|
||||||
|
# 缩进长度
|
||||||
|
IndentWidth: 4
|
||||||
|
|
||||||
|
# 连续空行的最大数
|
||||||
|
MaxEmptyLinesToKeep: 999
|
||||||
|
|
||||||
|
# 在OC中的@property后面添加一个空格。例如:使用“@property (readonly)”而不是“@property(readonly)”
|
||||||
|
ObjCSpaceAfterProperty: true
|
||||||
|
|
||||||
|
# OC块中所拍的字符数
|
||||||
|
ObjCBlockIndentWidth: 4
|
||||||
|
|
||||||
|
# 取决于值, 语句“int f() { return 0; }”可以被放到一个单行。
|
||||||
|
# 可能的值有:
|
||||||
|
# SFS_None (在配置中: None) 从不合并方法或函数到单独的一行。
|
||||||
|
# SFS_Empty (在配置中: Empty) 仅合并空的函数。
|
||||||
|
# SFS_Inline (在配置中: Inline) 仅合并类中定义的方法或函数. 意味着 “empty”.
|
||||||
|
# SFS_All (在配置中: All) 合并所有的方法适应单行.
|
||||||
|
AllowShortFunctionsOnASingleLine: None
|
||||||
|
|
||||||
|
# 如果为真(true), 语句“if (a) return;” 能被放到单行。
|
||||||
|
AllowShortIfStatementsOnASingleLine: false
|
||||||
|
|
||||||
|
# 如果为真(true), 对齐注释。
|
||||||
|
AlignTrailingComments: true
|
||||||
|
|
||||||
|
# 如果为真,对齐连续的宏定义
|
||||||
|
AlignConsecutiveMacros: true
|
||||||
|
|
||||||
|
# 如果为真(true),将会在“[”之后和“]”之前插入空格。
|
||||||
|
SpacesInSquareBrackets: false
|
||||||
|
|
||||||
|
# 如果为真(true), 将会在“(”之后和“)”之前插入空格。
|
||||||
|
SpacesInParentheses : false
|
||||||
|
|
||||||
|
# 如果为真(true), 校准连续的声明。
|
||||||
|
# 这将会校准连续多行的声明的名字。这将会导致像下面这样的格式:
|
||||||
|
# int aaaa = 12;
|
||||||
|
# float b = 23;
|
||||||
|
# std::string ccc = 23;
|
||||||
|
AlignConsecutiveDeclarations: false
|
||||||
|
|
||||||
|
# 如果为真(true),连续调整多行
|
||||||
|
# 这将会调整连续行中的分配操作符。这将会导致像下面这样的格式:
|
||||||
|
# int aaaa = 12;
|
||||||
|
# int b = 23;
|
||||||
|
# int ccc = 23;
|
||||||
|
AlignConsecutiveAssignments: false
|
||||||
|
|
||||||
|
# 如果为假(false),移除分配操作符(=)前空格。
|
||||||
|
SpaceBeforeAssignmentOperators: true
|
||||||
|
|
||||||
|
# 如果为真(true), 将会在字面量容器中插入空格(例如 OC和Javascript的数组和字典字面量)。
|
||||||
|
SpacesInContainerLiterals: false
|
||||||
|
|
||||||
|
# 缩进case标签
|
||||||
|
IndentCaseLabels: true
|
||||||
|
|
||||||
|
# 如果表达式中包含函数调用,并且函数调用因为表达式太长被放到了下一行,是否缩进
|
||||||
|
IndentWrappedFunctionNames: true
|
||||||
|
|
||||||
|
# 如果为真(true), 保持块的起始空行。
|
||||||
|
# true: false:
|
||||||
|
# if (foo) { vs. if (foo) {
|
||||||
|
# bar();
|
||||||
|
# bar(); }
|
||||||
|
# }
|
||||||
|
KeepEmptyLinesAtTheStartOfBlocks: true
|
||||||
|
|
||||||
|
# 允许所有参数都被放在下一行
|
||||||
|
AllowAllParametersOfDeclarationOnNextLine: false
|
||||||
|
|
||||||
|
# 使用C风格强制类型转换后,是否在中间添加一个空格
|
||||||
|
SpaceAfterCStyleCast: true
|
||||||
|
|
||||||
|
# 在模板定义后换行
|
||||||
|
AlwaysBreakTemplateDeclarations: Yes
|
||||||
|
|
||||||
|
# Tab长度
|
||||||
|
TabWidth: 4
|
||||||
|
|
||||||
|
# 是否使用Tab
|
||||||
|
UseTab: Never
|
||||||
|
|
||||||
|
# 在括号后对齐参数
|
||||||
|
# someLongFunction(argument1,
|
||||||
|
# argument2);
|
||||||
|
AlignAfterOpenBracket: Align
|
||||||
|
|
||||||
|
# 名字空间内部缩进
|
||||||
|
NamespaceIndentation: All
|
||||||
|
|
||||||
|
# 一行最长列数
|
||||||
|
ColumnLimit: 100
|
||||||
|
|
||||||
|
# 按层次缩进宏定义
|
||||||
|
IndentPPDirectives: AfterHash
|
||||||
|
|
||||||
|
# 预处理语句缩进为 2
|
||||||
|
PPIndentWidth: 2
|
||||||
|
|
||||||
|
# 数组元素对齐
|
||||||
|
AlignArrayOfStructures: Left
|
||||||
|
|
||||||
|
# 不对头文件排序
|
||||||
|
SortIncludes: Never
|
||||||
|
|
||||||
|
FixNamespaceComments: false
|
||||||
|
|
||||||
|
StatementMacros: ['__qas_attr__', '__qas_exclude__', '__qas_include__']
|
||||||
|
|
||||||
|
ForEachMacros: [ foreach, Q_FOREACH, BOOST_FOREACH, forever, Q_FOREVER, QBENCHMARK, QBENCHMARK_ONCE ]
|
@ -4,11 +4,11 @@
|
|||||||
#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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
[[maybe_unused]] 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;
|
||||||
|
@ -13,6 +13,5 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(AppInfo)
|
SINGLETON(AppInfo)
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void testCrash();
|
||||||
[[maybe_unused]] Q_INVOKABLE void testCrash();
|
|
||||||
};
|
};
|
||||||
|
@ -11,21 +11,28 @@
|
|||||||
|
|
||||||
#pragma comment(lib, "Dbghelp.lib")
|
#pragma comment(lib, "Dbghelp.lib")
|
||||||
|
|
||||||
static void
|
static void miniDumpWriteDump(HANDLE hProcess, DWORD ProcessId, HANDLE hFile,
|
||||||
miniDumpWriteDump(HANDLE hProcess, DWORD ProcessId, HANDLE hFile, CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam, CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam) {
|
CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,
|
||||||
typedef HRESULT (WINAPI *MiniDumpWriteDumpPtr)(HANDLE hProcess, DWORD ProcessId, HANDLE hFile, MINIDUMP_TYPE DumpType, CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,
|
CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam) {
|
||||||
CONST PMINIDUMP_USER_STREAM_INFORMATION UserStreamParam, 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, static_cast<MINIDUMP_TYPE>(80),
|
||||||
|
ExceptionParam, nullptr, 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 == nullptr || output == nullptr)
|
if (input == nullptr || output == nullptr)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
@ -42,8 +49,7 @@ 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,7 +57,9 @@ 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, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr);
|
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;
|
||||||
@ -64,8 +72,10 @@ void WriteDump(EXCEPTION_POINTERS *exp, const std::wstring &path) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
LONG WINAPI MyUnhandledExceptionFilter(EXCEPTION_POINTERS *exp) {
|
LONG WINAPI MyUnhandledExceptionFilter(EXCEPTION_POINTERS *exp) {
|
||||||
const QString dumpFileName = QString("%1_%2.dmp").arg("crash", QDateTime::currentDateTime().toString("yyyyMMdd_hhmmss"));
|
const QString dumpFileName =
|
||||||
const QString dumpDirPath = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/dmp";
|
QString("%1_%2.dmp").arg("crash", QDateTime::currentDateTime().toString("yyyyMMdd_hhmmss"));
|
||||||
|
const QString dumpDirPath =
|
||||||
|
QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/dmp";
|
||||||
const QDir dumpDir(dumpDirPath);
|
const QDir dumpDir(dumpDirPath);
|
||||||
if (!dumpDir.exists()) {
|
if (!dumpDir.exists()) {
|
||||||
dumpDir.mkpath(dumpDirPath);
|
dumpDir.mkpath(dumpDirPath);
|
||||||
|
@ -15,9 +15,7 @@ CircularReveal::CircularReveal(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
|||||||
setVisible(false);
|
setVisible(false);
|
||||||
Q_EMIT animationFinished();
|
Q_EMIT animationFinished();
|
||||||
});
|
});
|
||||||
connect(this, &CircularReveal::radiusChanged, this, [=]() {
|
connect(this, &CircularReveal::radiusChanged, this, [=]() { update(); });
|
||||||
update();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CircularReveal::paint(QPainter *painter) {
|
void CircularReveal::paint(QPainter *painter) {
|
||||||
@ -36,7 +34,8 @@ void CircularReveal::paint(QPainter *painter) {
|
|||||||
_anim->setEndValue(radius);
|
_anim->setEndValue(radius);
|
||||||
_center = center;
|
_center = center;
|
||||||
_grabResult = _target->grabToImage(QSize(w, h));
|
_grabResult = _target->grabToImage(QSize(w, h));
|
||||||
connect(_grabResult.data(), &QQuickItemGrabResult::ready, this, &CircularReveal::handleGrabResult);
|
connect(_grabResult.data(), &QQuickItemGrabResult::ready, this,
|
||||||
|
&CircularReveal::handleGrabResult);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CircularReveal::handleGrabResult() {
|
void CircularReveal::handleGrabResult() {
|
||||||
|
@ -12,15 +12,10 @@ Q_PROPERTY_AUTO_P(QQuickItem*, target)
|
|||||||
Q_PROPERTY_AUTO(int, radius)
|
Q_PROPERTY_AUTO(int, radius)
|
||||||
public:
|
public:
|
||||||
explicit CircularReveal(QQuickItem *parent = nullptr);
|
explicit CircularReveal(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
void paint(QPainter *painter) override;
|
void paint(QPainter *painter) override;
|
||||||
|
Q_INVOKABLE [[maybe_unused]] void start(int w, int h, const QPoint ¢er, int radius);
|
||||||
[[maybe_unused]] Q_INVOKABLE 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:
|
||||||
|
@ -7,10 +7,9 @@
|
|||||||
|
|
||||||
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:
|
||||||
|
@ -12,7 +12,9 @@ FpsItem::FpsItem() {
|
|||||||
});
|
});
|
||||||
connect(this, &QQuickItem::windowChanged, this, [this] {
|
connect(this, &QQuickItem::windowChanged, this, [this] {
|
||||||
if (window()) {
|
if (window()) {
|
||||||
connect(window(), &QQuickWindow::afterRendering, this, [this] { _frameCount++; }, Qt::DirectConnection);
|
connect(
|
||||||
|
window(), &QQuickWindow::afterRendering, this, [this] { _frameCount++; },
|
||||||
|
Qt::DirectConnection);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
timer->start(1000);
|
timer->start(1000);
|
||||||
|
@ -11,5 +11,4 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
int _frameCount = 0;
|
int _frameCount = 0;
|
||||||
|
|
||||||
};
|
};
|
@ -7,11 +7,8 @@
|
|||||||
class FBORenderer : public QQuickFramebufferObject::Renderer, protected QOpenGLFunctions {
|
class FBORenderer : public QQuickFramebufferObject::Renderer, protected QOpenGLFunctions {
|
||||||
public:
|
public:
|
||||||
explicit FBORenderer(const OpenGLItem *item);
|
explicit FBORenderer(const OpenGLItem *item);
|
||||||
|
|
||||||
void render() override;
|
void render() override;
|
||||||
|
|
||||||
QOpenGLFramebufferObject *createFramebufferObject(const QSize &size) override;
|
QOpenGLFramebufferObject *createFramebufferObject(const QSize &size) override;
|
||||||
|
|
||||||
QOpenGLShaderProgram program;
|
QOpenGLShaderProgram program;
|
||||||
const OpenGLItem *item = nullptr;
|
const OpenGLItem *item = nullptr;
|
||||||
};
|
};
|
||||||
@ -19,14 +16,14 @@ public:
|
|||||||
FBORenderer::FBORenderer(const OpenGLItem *item) {
|
FBORenderer::FBORenderer(const OpenGLItem *item) {
|
||||||
this->item = item;
|
this->item = item;
|
||||||
initializeOpenGLFunctions();
|
initializeOpenGLFunctions();
|
||||||
program.addCacheableShaderFromSourceCode(QOpenGLShader::Vertex,
|
program.addCacheableShaderFromSourceCode(QOpenGLShader::Vertex, "attribute highp vec4 vertices;"
|
||||||
"attribute highp vec4 vertices;"
|
|
||||||
"varying highp vec2 coords;"
|
"varying highp vec2 coords;"
|
||||||
"void main() {"
|
"void main() {"
|
||||||
" gl_Position = vertices;"
|
" gl_Position = vertices;"
|
||||||
" coords = vertices.xy;"
|
" coords = vertices.xy;"
|
||||||
"}");
|
"}");
|
||||||
program.addCacheableShaderFromSourceCode(QOpenGLShader::Fragment,
|
program.addCacheableShaderFromSourceCode(
|
||||||
|
QOpenGLShader::Fragment,
|
||||||
"uniform lowp float t;"
|
"uniform lowp float t;"
|
||||||
"varying highp vec2 coords;"
|
"varying highp vec2 coords;"
|
||||||
"void main() {"
|
"void main() {"
|
||||||
@ -54,12 +51,7 @@ void FBORenderer::render() {
|
|||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
program.bind();
|
program.bind();
|
||||||
program.enableAttributeArray(0);
|
program.enableAttributeArray(0);
|
||||||
float values[] = {
|
float values[] = {-1, -1, 1, -1, -1, 1, 1, 1};
|
||||||
-1, -1,
|
|
||||||
1, -1,
|
|
||||||
-1, 1,
|
|
||||||
1, 1
|
|
||||||
};
|
|
||||||
glBindBuffer(GL_ARRAY_BUFFER, 0);
|
glBindBuffer(GL_ARRAY_BUFFER, 0);
|
||||||
program.setAttributeArray(0, GL_FLOAT, values, 2);
|
program.setAttributeArray(0, GL_FLOAT, values, 2);
|
||||||
program.setUniformValue("t", (float) item->t());
|
program.setUniformValue("t", (float) item->t());
|
||||||
|
@ -11,17 +11,13 @@ Q_OBJECT
|
|||||||
Q_PROPERTY(qreal t READ t WRITE setT NOTIFY tChanged)
|
Q_PROPERTY(qreal t READ t WRITE setT NOTIFY tChanged)
|
||||||
public:
|
public:
|
||||||
explicit OpenGLItem(QQuickItem *parent = nullptr);
|
explicit OpenGLItem(QQuickItem *parent = nullptr);
|
||||||
|
|
||||||
[[nodiscard]] QQuickFramebufferObject::Renderer *createRenderer() const override;
|
[[nodiscard]] QQuickFramebufferObject::Renderer *createRenderer() const override;
|
||||||
|
|
||||||
void timerEvent(QTimerEvent *) override;
|
void timerEvent(QTimerEvent *) override;
|
||||||
|
[[nodiscard]] qreal t() const {
|
||||||
[[nodiscard]] qreal t() const { return m_t; }
|
return m_t;
|
||||||
|
}
|
||||||
void setT(qreal t);
|
void setT(qreal t);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
|
|
||||||
void tChanged();
|
void tChanged();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -4,11 +4,11 @@
|
|||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
|
|
||||||
[[maybe_unused]] 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) {
|
||||||
const QDir &_formDir = fromDir;
|
const QDir &_formDir = fromDir;
|
||||||
QDir _toDir = toDir;
|
QDir _toDir = toDir;
|
||||||
@ -61,7 +61,8 @@ void InitializrHelper::templateToFile(const QString &source, const QString &dest
|
|||||||
|
|
||||||
void InitializrHelper::copyFile(const QString &source, const QString &dest) {
|
void InitializrHelper::copyFile(const QString &source, const QString &dest) {
|
||||||
QFile::copy(source, dest);
|
QFile::copy(source, dest);
|
||||||
QFile::setPermissions(dest, QFile::WriteOwner | QFile::WriteUser | QFile::WriteGroup | QFile::WriteOther);
|
QFile::setPermissions(dest, QFile::WriteOwner | QFile::WriteUser | QFile::WriteGroup |
|
||||||
|
QFile::WriteOther);
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] void InitializrHelper::generate(const QString &name, const QString &path) {
|
[[maybe_unused]] void InitializrHelper::generate(const QString &name, const QString &path) {
|
||||||
@ -87,12 +88,18 @@ void InitializrHelper::copyFile(const QString &source, const QString &dest) {
|
|||||||
projectDir.mkpath(projectPath);
|
projectDir.mkpath(projectPath);
|
||||||
QDir fluentDir(projectDir.filePath("FluentUI"));
|
QDir fluentDir(projectDir.filePath("FluentUI"));
|
||||||
copyDir(QDir(QGuiApplication::applicationDirPath() + "/source"), fluentDir);
|
copyDir(QDir(QGuiApplication::applicationDirPath() + "/source"), fluentDir);
|
||||||
templateToFile(":/example/res/template/CMakeLists.txt.in", projectDir.filePath("CMakeLists.txt"), name);
|
templateToFile(":/example/res/template/CMakeLists.txt.in",
|
||||||
templateToFile(":/example/res/template/src/CMakeLists.txt.in", projectDir.filePath("src/CMakeLists.txt"), name);
|
projectDir.filePath("CMakeLists.txt"), name);
|
||||||
templateToFile(":/example/res/template/src/main.cpp.in", projectDir.filePath("src/main.cpp"), name);
|
templateToFile(":/example/res/template/src/CMakeLists.txt.in",
|
||||||
templateToFile(":/example/res/template/src/main.qml.in", projectDir.filePath("src/main.qml"), name);
|
projectDir.filePath("src/CMakeLists.txt"), name);
|
||||||
templateToFile(":/example/res/template/src/en_US.ts.in", projectDir.filePath("src/" + name + "_en_US.ts"), name);
|
templateToFile(":/example/res/template/src/main.cpp.in", projectDir.filePath("src/main.cpp"),
|
||||||
templateToFile(":/example/res/template/src/zh_CN.ts.in", projectDir.filePath("src/" + name + "_zh_CN.ts"), name);
|
name);
|
||||||
|
templateToFile(":/example/res/template/src/main.qml.in", projectDir.filePath("src/main.qml"),
|
||||||
|
name);
|
||||||
|
templateToFile(":/example/res/template/src/en_US.ts.in",
|
||||||
|
projectDir.filePath("src/" + name + "_en_US.ts"), name);
|
||||||
|
templateToFile(":/example/res/template/src/zh_CN.ts.in",
|
||||||
|
projectDir.filePath("src/" + name + "_zh_CN.ts"), name);
|
||||||
copyFile(":/example/res/template/src/App.qml.in", projectDir.filePath("src/App.qml"));
|
copyFile(":/example/res/template/src/App.qml.in", projectDir.filePath("src/App.qml"));
|
||||||
copyFile(":/example/res/template/src/qml.qrc.in", projectDir.filePath("src/qml.qrc"));
|
copyFile(":/example/res/template/src/qml.qrc.in", projectDir.filePath("src/qml.qrc"));
|
||||||
copyFile(":/example/res/template/src/logo.ico.in", projectDir.filePath("src/logo.ico"));
|
copyFile(":/example/res/template/src/logo.ico.in", projectDir.filePath("src/logo.ico"));
|
||||||
|
@ -9,22 +9,15 @@ class InitializrHelper : public QObject {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
private:
|
private:
|
||||||
[[maybe_unused]] 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);
|
||||||
|
|
||||||
static 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 [[maybe_unused]] void generate(const QString &name, const QString &path);
|
||||||
[[maybe_unused]] Q_INVOKABLE 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);
|
||||||
};
|
};
|
||||||
|
@ -13,9 +13,7 @@
|
|||||||
#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
|
||||||
@ -49,7 +47,8 @@ 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)
|
||||||
auto macosVersionFile = QString::fromUtf8("/System/Library/CoreServices/.SystemVersionPlatform.plist");
|
auto macosVersionFile =
|
||||||
|
QString::fromUtf8("/System/Library/CoreServices/.SystemVersionPlatform.plist");
|
||||||
auto fi = QFileInfo(macosVersionFile);
|
auto fi = QFileInfo(macosVersionFile);
|
||||||
if (fi.exists() && fi.isReadable()) {
|
if (fi.exists() && fi.isReadable()) {
|
||||||
auto plistFile = QFile(macosVersionFile);
|
auto plistFile = QFile(macosVersionFile);
|
||||||
@ -72,7 +71,9 @@ QString Log::prettyProductInfoWrapper() {
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
QSettings regKey{QString::fromUtf8(R"(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) {
|
||||||
@ -91,7 +92,8 @@ 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;
|
||||||
}
|
}
|
||||||
@ -132,11 +134,12 @@ static inline void messageHandler(const QtMsgType type, const QMessageLogContext
|
|||||||
sprintf(fn, "%s", ptrTmp + 1);
|
sprintf(fn, "%s", ptrTmp + 1);
|
||||||
strFileTmp = fn;
|
strFileTmp = fn;
|
||||||
}
|
}
|
||||||
fileAndLineLogStr = QString::fromStdString("[%1:%2]").arg(QString::fromStdString(strFileTmp), QString::number(context.line));
|
fileAndLineLogStr = QString::fromStdString("[%1:%2]").arg(
|
||||||
|
QString::fromStdString(strFileTmp), QString::number(context.line));
|
||||||
}
|
}
|
||||||
const QString finalMessage = QString::fromStdString("%1[%2]%3[%4]:%5").arg(
|
const QString finalMessage =
|
||||||
QDateTime::currentDateTime().toString("yyyy/MM/dd hh:mm:ss.zzz"),
|
QString::fromStdString("%1[%2]%3[%4]:%5")
|
||||||
levelName,
|
.arg(QDateTime::currentDateTime().toString("yyyy/MM/dd hh:mm:ss.zzz"), levelName,
|
||||||
fileAndLineLogStr,
|
fileAndLineLogStr,
|
||||||
QString::number(reinterpret_cast<quintptr>(QThread::currentThreadId())),
|
QString::number(reinterpret_cast<quintptr>(QThread::currentThreadId())),
|
||||||
message);
|
message);
|
||||||
@ -151,7 +154,8 @@ static inline void messageHandler(const QtMsgType type, const QMessageLogContext
|
|||||||
if (!g_logFile) {
|
if (!g_logFile) {
|
||||||
g_logFile = std::make_unique<QFile>(g_file_path);
|
g_logFile = std::make_unique<QFile>(g_file_path);
|
||||||
if (!g_logFile->open(QFile::WriteOnly | QFile::Text | QFile::Append)) {
|
if (!g_logFile->open(QFile::WriteOnly | QFile::Text | QFile::Append)) {
|
||||||
std::cerr << "Can't open file to write: " << qPrintable(g_logFile->errorString()) << std::endl;
|
std::cerr << "Can't open file to write: " << qPrintable(g_logFile->errorString())
|
||||||
|
<< std::endl;
|
||||||
g_logFile.reset();
|
g_logFile.reset();
|
||||||
g_logError = true;
|
g_logError = true;
|
||||||
return;
|
return;
|
||||||
@ -179,8 +183,10 @@ void Log::setup(char *argv[], const QString &app, int level) {
|
|||||||
QString applicationPath = QString::fromStdString(argv[0]);
|
QString applicationPath = QString::fromStdString(argv[0]);
|
||||||
once = true;
|
once = true;
|
||||||
g_app = app;
|
g_app = app;
|
||||||
const QString logFileName = QString("%1_%2.log").arg(g_app, QDateTime::currentDateTime().toString("yyyyMMdd"));
|
const QString logFileName =
|
||||||
const QString logDirPath = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/log";
|
QString("%1_%2.log").arg(g_app, QDateTime::currentDateTime().toString("yyyyMMdd"));
|
||||||
|
const QString logDirPath =
|
||||||
|
QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/log";
|
||||||
const QDir logDir(logDirPath);
|
const QDir logDir(logDirPath);
|
||||||
if (!logDir.exists()) {
|
if (!logDir.exists()) {
|
||||||
logDir.mkpath(logDirPath);
|
logDir.mkpath(logDirPath);
|
||||||
|
@ -4,6 +4,5 @@
|
|||||||
|
|
||||||
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);
|
||||||
}
|
}
|
@ -19,9 +19,7 @@
|
|||||||
#include <QGuiApplication>
|
#include <QGuiApplication>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
|
||||||
NetworkCallable::NetworkCallable(QObject *parent) : QObject{parent} {
|
NetworkCallable::NetworkCallable(QObject *parent) : QObject{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QString NetworkParams::method2String() const {
|
QString NetworkParams::method2String() const {
|
||||||
@ -64,8 +62,7 @@ bool NetworkParams::getOpenLog() const {
|
|||||||
return Network::getInstance()->openLog();
|
return Network::getInstance()->openLog();
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
@ -178,12 +175,14 @@ void Network::handle(NetworkParams *params, NetworkCallable *c) {
|
|||||||
callable->start();
|
callable->start();
|
||||||
}
|
}
|
||||||
QString cacheKey = params->buildCacheKey();
|
QString cacheKey = params->buildCacheKey();
|
||||||
if (params->_cacheMode == NetworkType::CacheMode::FirstCacheThenRequest && cacheExists(cacheKey)) {
|
if (params->_cacheMode == NetworkType::CacheMode::FirstCacheThenRequest &&
|
||||||
|
cacheExists(cacheKey)) {
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
callable->cache(readCache(cacheKey));
|
callable->cache(readCache(cacheKey));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (params->_cacheMode == NetworkType::CacheMode::IfNoneCacheRequest && cacheExists(cacheKey)) {
|
if (params->_cacheMode == NetworkType::CacheMode::IfNoneCacheRequest &&
|
||||||
|
cacheExists(cacheKey)) {
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
callable->cache(readCache(cacheKey));
|
callable->cache(readCache(cacheKey));
|
||||||
callable->finish();
|
callable->finish();
|
||||||
@ -194,7 +193,8 @@ void Network::handle(NetworkParams *params, NetworkCallable *c) {
|
|||||||
QNetworkAccessManager manager;
|
QNetworkAccessManager manager;
|
||||||
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() - 1; ++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);
|
||||||
@ -216,9 +216,11 @@ void Network::handle(NetworkParams *params, NetworkCallable *c) {
|
|||||||
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(QGuiApplication::instance(), &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);
|
||||||
@ -247,7 +249,8 @@ void Network::handle(NetworkParams *params, NetworkCallable *c) {
|
|||||||
} else {
|
} else {
|
||||||
if (i == params->getRetry() - 1) {
|
if (i == params->getRetry() - 1) {
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
if (params->_cacheMode == NetworkType::CacheMode::RequestFailedReadCache && cacheExists(cacheKey)) {
|
if (params->_cacheMode == NetworkType::CacheMode::RequestFailedReadCache &&
|
||||||
|
cacheExists(cacheKey)) {
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
callable->cache(readCache(cacheKey));
|
callable->cache(readCache(cacheKey));
|
||||||
}
|
}
|
||||||
@ -332,20 +335,25 @@ void Network::handleDownload(NetworkParams *params, NetworkCallable *c) {
|
|||||||
reply->abort();
|
reply->abort();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
connect(&manager, &QNetworkAccessManager::finished, &manager, [&loop](QNetworkReply *reply) { loop.quit(); });
|
connect(&manager, &QNetworkAccessManager::finished, &manager,
|
||||||
connect(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager, [&loop, reply]() { reply->abort(), loop.quit(); });
|
[&loop](QNetworkReply *reply) { 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(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager, abortCallable);
|
conn_quit = connect(QGuiApplication::instance(), &QGuiApplication::aboutToQuit, &manager,
|
||||||
connect(reply, &QNetworkReply::readyRead, reply, [reply, seek, destFile, cacheFile, callable] {
|
abortCallable);
|
||||||
|
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;
|
||||||
qint64 contentLength = reply->header(QNetworkRequest::ContentLengthHeader).toLongLong() + seek;
|
qint64 contentLength =
|
||||||
|
reply->header(QNetworkRequest::ContentLengthHeader).toLongLong() + seek;
|
||||||
downInfo.insert("contentLength", contentLength);
|
downInfo.insert("contentLength", contentLength);
|
||||||
QString eTag = reply->header(QNetworkRequest::ETagHeader).toString();
|
QString eTag = reply->header(QNetworkRequest::ETagHeader).toString();
|
||||||
downInfo.insert("eTag", eTag);
|
downInfo.insert("eTag", eTag);
|
||||||
@ -354,7 +362,8 @@ void Network::handleDownload(NetworkParams *params, NetworkCallable *c) {
|
|||||||
downInfo.insert("fileSize", destFile->size());
|
downInfo.insert("fileSize", destFile->size());
|
||||||
if (cacheFile->isOpen()) {
|
if (cacheFile->isOpen()) {
|
||||||
cacheFile->resize(0);
|
cacheFile->resize(0);
|
||||||
cacheFile->write(QJsonDocument::fromVariant(QVariant(downInfo)).toJson().toBase64());
|
cacheFile->write(
|
||||||
|
QJsonDocument::fromVariant(QVariant(downInfo)).toJson().toBase64());
|
||||||
cacheFile->flush();
|
cacheFile->flush();
|
||||||
}
|
}
|
||||||
if (!callable.isNull()) {
|
if (!callable.isNull()) {
|
||||||
@ -430,7 +439,9 @@ 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, const 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: {
|
||||||
@ -440,7 +451,8 @@ void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest reques
|
|||||||
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);
|
||||||
}
|
}
|
||||||
@ -452,19 +464,23 @@ void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest reques
|
|||||||
file->open(QIODevice::ReadOnly);
|
file->open(QIODevice::ReadOnly);
|
||||||
file->setParent(multiPart);
|
file->setParent(multiPart);
|
||||||
QHttpPart part;
|
QHttpPart part;
|
||||||
part.setHeader(QNetworkRequest::ContentDispositionHeader, QString(R"(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);
|
||||||
}
|
}
|
||||||
reply = manager->sendCustomRequest(request, verb, multiPart);
|
reply = manager->sendCustomRequest(request, verb, multiPart);
|
||||||
multiPart->setParent(reply);
|
multiPart->setParent(reply);
|
||||||
connect(reply, &QNetworkReply::uploadProgress, reply, [callable](qint64 bytesSent, qint64 bytesTotal) {
|
connect(reply, &QNetworkReply::uploadProgress, reply,
|
||||||
|
[callable](qint64 bytesSent, qint64 bytesTotal) {
|
||||||
if (!callable.isNull() && bytesSent != 0 && bytesTotal != 0) {
|
if (!callable.isNull() && bytesSent != 0 && bytesTotal != 0) {
|
||||||
Q_EMIT callable->uploadProgress(bytesSent, bytesTotal);
|
Q_EMIT callable->uploadProgress(bytesSent, bytesTotal);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} 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());
|
||||||
@ -479,7 +495,8 @@ void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest reques
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
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());
|
||||||
@ -489,7 +506,8 @@ void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest reques
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
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;
|
||||||
@ -501,7 +519,8 @@ void Network::sendRequest(QNetworkAccessManager *manager, QNetworkRequest reques
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case NetworkParams::TYPE_BODY: {
|
case NetworkParams::TYPE_BODY: {
|
||||||
request.setHeader(QNetworkRequest::ContentTypeHeader, QString("text/plain;charset=utf-8"));
|
request.setHeader(QNetworkRequest::ContentTypeHeader,
|
||||||
|
QString("text/plain;charset=utf-8"));
|
||||||
QByteArray data = params->_body.toUtf8();
|
QByteArray data = params->_body.toUtf8();
|
||||||
reply = manager->sendCustomRequest(request, verb, data);
|
reply = manager->sendCustomRequest(request, verb, data);
|
||||||
break;
|
break;
|
||||||
@ -519,15 +538,20 @@ void Network::printRequestStartLog(const QNetworkRequest &request, NetworkParams
|
|||||||
if (!params->getOpenLog()) {
|
if (!params->getOpenLog()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
qDebug() << "<------" << qUtf8Printable(request.header(QNetworkRequest::UserAgentHeader).toString()) << "Request Start ------>";
|
qDebug() << "<------"
|
||||||
qDebug() << qUtf8Printable(QString::fromStdString("<%1>").arg(params->method2String())) << qUtf8Printable(params->_url);
|
<< qUtf8Printable(request.header(QNetworkRequest::UserAgentHeader).toString())
|
||||||
|
<< "Request Start ------>";
|
||||||
|
qDebug() << qUtf8Printable(QString::fromStdString("<%1>").arg(params->method2String()))
|
||||||
|
<< qUtf8Printable(params->_url);
|
||||||
auto contentType = request.header(QNetworkRequest::ContentTypeHeader).toString();
|
auto contentType = request.header(QNetworkRequest::ContentTypeHeader).toString();
|
||||||
if (!contentType.isEmpty()) {
|
if (!contentType.isEmpty()) {
|
||||||
qDebug() << qUtf8Printable(QString::fromStdString("<Header> %1=%2").arg("Content-Type", contentType));
|
qDebug() << qUtf8Printable(
|
||||||
|
QString::fromStdString("<Header> %1=%2").arg("Content-Type", contentType));
|
||||||
}
|
}
|
||||||
QList<QByteArray> headers = request.rawHeaderList();
|
QList<QByteArray> headers = request.rawHeaderList();
|
||||||
for (const QByteArray &header : headers) {
|
for (const QByteArray &header : headers) {
|
||||||
qDebug() << qUtf8Printable(QString::fromStdString("<Header> %1=%2").arg(header, request.rawHeader(header)));
|
qDebug() << qUtf8Printable(
|
||||||
|
QString::fromStdString("<Header> %1=%2").arg(header, request.rawHeader(header)));
|
||||||
}
|
}
|
||||||
if (!params->_queryMap.isEmpty()) {
|
if (!params->_queryMap.isEmpty()) {
|
||||||
qDebug() << "<Query>" << qUtf8Printable(map2String(params->_queryMap));
|
qDebug() << "<Query>" << qUtf8Printable(map2String(params->_queryMap));
|
||||||
@ -543,12 +567,16 @@ void Network::printRequestStartLog(const QNetworkRequest &request, NetworkParams
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::printRequestEndLog(const 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;
|
||||||
}
|
}
|
||||||
qDebug() << "<------" << qUtf8Printable(request.header(QNetworkRequest::UserAgentHeader).toString()) << "Request End ------>";
|
qDebug() << "<------"
|
||||||
qDebug() << qUtf8Printable(QString::fromStdString("<%1>").arg(params->method2String())) << qUtf8Printable(params->_url);
|
<< qUtf8Printable(request.header(QNetworkRequest::UserAgentHeader).toString())
|
||||||
|
<< "Request End ------>";
|
||||||
|
qDebug() << qUtf8Printable(QString::fromStdString("<%1>").arg(params->method2String()))
|
||||||
|
<< qUtf8Printable(params->_url);
|
||||||
qDebug() << "<Result>" << qUtf8Printable(response);
|
qDebug() << "<Result>" << qUtf8Printable(response);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -562,7 +590,10 @@ void Network::saveResponse(const QString &key, const 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();
|
||||||
@ -584,7 +615,9 @@ 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) {
|
||||||
@ -656,7 +689,8 @@ NetworkParams *Network::patchJsonArray(const QString &url) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
NetworkParams *Network::deleteJsonArray(const QString &url) {
|
NetworkParams *Network::deleteJsonArray(const QString &url) {
|
||||||
return new NetworkParams(url, NetworkParams::TYPE_JSONARRAY, NetworkParams::METHOD_DELETE, this);
|
return new NetworkParams(url, NetworkParams::TYPE_JSONARRAY, NetworkParams::METHOD_DELETE,
|
||||||
|
this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Network::setInterceptor(QJSValue interceptor) {
|
void Network::setInterceptor(QJSValue interceptor) {
|
||||||
|
@ -70,21 +70,8 @@ class NetworkParams : public QObject {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
QML_NAMED_ELEMENT(NetworkParams)
|
QML_NAMED_ELEMENT(NetworkParams)
|
||||||
public:
|
public:
|
||||||
enum Method {
|
enum Method { METHOD_GET, METHOD_HEAD, METHOD_POST, METHOD_PUT, METHOD_PATCH, METHOD_DELETE };
|
||||||
METHOD_GET,
|
enum Type { TYPE_NONE, TYPE_FORM, TYPE_JSON, TYPE_JSONARRAY, TYPE_BODY };
|
||||||
METHOD_HEAD,
|
|
||||||
METHOD_POST,
|
|
||||||
METHOD_PUT,
|
|
||||||
METHOD_PATCH,
|
|
||||||
METHOD_DELETE
|
|
||||||
};
|
|
||||||
enum Type {
|
|
||||||
TYPE_NONE,
|
|
||||||
TYPE_FORM,
|
|
||||||
TYPE_JSON,
|
|
||||||
TYPE_JSONARRAY,
|
|
||||||
TYPE_BODY
|
|
||||||
};
|
|
||||||
|
|
||||||
explicit NetworkParams(QObject *parent = nullptr);
|
explicit NetworkParams(QObject *parent = nullptr);
|
||||||
|
|
||||||
@ -159,7 +146,9 @@ private:
|
|||||||
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);
|
||||||
|
|
||||||
@ -204,7 +193,9 @@ SINGLETON(Network)
|
|||||||
void handleDownload(NetworkParams *params, NetworkCallable *result);
|
void handleDownload(NetworkParams *params, NetworkCallable *result);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static void sendRequest(QNetworkAccessManager *manager, QNetworkRequest request, NetworkParams *params, QNetworkReply *&reply, bool isFirst, const QPointer<NetworkCallable> &callable);
|
static void sendRequest(QNetworkAccessManager *manager, QNetworkRequest request,
|
||||||
|
NetworkParams *params, QNetworkReply *&reply, bool isFirst,
|
||||||
|
const QPointer<NetworkCallable> &callable);
|
||||||
|
|
||||||
static void addQueryParam(QUrl *url, const QMap<QString, QVariant> ¶ms);
|
static void addQueryParam(QUrl *url, const QMap<QString, QVariant> ¶ms);
|
||||||
|
|
||||||
@ -222,7 +213,8 @@ private:
|
|||||||
|
|
||||||
static void printRequestStartLog(const QNetworkRequest &request, NetworkParams *params);
|
static void printRequestStartLog(const QNetworkRequest &request, NetworkParams *params);
|
||||||
|
|
||||||
static void printRequestEndLog(const QNetworkRequest &request, NetworkParams *params, QNetworkReply *&reply, const QString &response);
|
static void printRequestEndLog(const QNetworkRequest &request, NetworkParams *params,
|
||||||
|
QNetworkReply *&reply, const QString &response);
|
||||||
|
|
||||||
static QString map2String(const QMap<QString, QVariant> &map);
|
static QString map2String(const QMap<QString, QVariant> &map);
|
||||||
|
|
||||||
|
@ -4,7 +4,6 @@
|
|||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
|
|
||||||
SettingsHelper::SettingsHelper(QObject *parent) : QObject(parent) {
|
SettingsHelper::SettingsHelper(QObject *parent) : QObject(parent) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SettingsHelper::~SettingsHelper() = default;
|
SettingsHelper::~SettingsHelper() = default;
|
||||||
@ -13,6 +12,7 @@ void SettingsHelper::save(const QString &key, QVariant val) {
|
|||||||
m_settings->setValue(key, val);
|
m_settings->setValue(key, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
QVariant SettingsHelper::get(const QString &key, QVariant def) {
|
QVariant SettingsHelper::get(const QString &key, QVariant def) {
|
||||||
QVariant data = m_settings->value(key);
|
QVariant data = m_settings->value(key);
|
||||||
if (!data.isNull() && data.isValid()) {
|
if (!data.isNull() && data.isValid()) {
|
||||||
@ -25,6 +25,7 @@ void SettingsHelper::init(char *argv[]) {
|
|||||||
QString applicationPath = QString::fromStdString(argv[0]);
|
QString applicationPath = QString::fromStdString(argv[0]);
|
||||||
const QFileInfo fileInfo(applicationPath);
|
const QFileInfo fileInfo(applicationPath);
|
||||||
const QString iniFileName = fileInfo.completeBaseName() + ".ini";
|
const QString iniFileName = fileInfo.completeBaseName() + ".ini";
|
||||||
const QString iniFilePath = QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/" + iniFileName;
|
const QString iniFilePath =
|
||||||
|
QStandardPaths::writableLocation(QStandardPaths::AppLocalDataLocation) + "/" + iniFileName;
|
||||||
m_settings.reset(new QSettings(iniFilePath, QSettings::IniFormat));
|
m_settings.reset(new QSettings(iniFilePath, QSettings::IniFormat));
|
||||||
}
|
}
|
||||||
|
@ -16,26 +16,29 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(SettingsHelper)
|
SINGLETON(SettingsHelper)
|
||||||
|
|
||||||
~SettingsHelper() override;
|
~SettingsHelper() override;
|
||||||
|
|
||||||
void init(char *argv[]);
|
void init(char *argv[]);
|
||||||
|
Q_INVOKABLE void saveDarkMode(int darkModel) {
|
||||||
Q_INVOKABLE void saveDarkMode(int darkModel) { save("darkMode", 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) {
|
||||||
Q_INVOKABLE bool getUseSystemAppBar() { return get("useSystemAppBar", QVariant(false)).toBool(); }
|
save("useSystemAppBar", useSystemAppBar);
|
||||||
|
}
|
||||||
Q_INVOKABLE void saveLanguage(const QString &language) { save("language", language); }
|
Q_INVOKABLE bool getUseSystemAppBar() {
|
||||||
|
return get("useSystemAppBar", QVariant(false)).toBool();
|
||||||
Q_INVOKABLE QString getLanguage() { return get("language", QVariant("en_US")).toString(); }
|
}
|
||||||
|
Q_INVOKABLE void saveLanguage(const QString &language) {
|
||||||
|
save("language", language);
|
||||||
|
}
|
||||||
|
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:
|
||||||
|
@ -18,7 +18,8 @@ void TranslateHelper::init(QQmlEngine *engine) {
|
|||||||
_translator = new QTranslator(this);
|
_translator = new QTranslator(this);
|
||||||
QGuiApplication::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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,9 +15,7 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
SINGLETON(TranslateHelper)
|
SINGLETON(TranslateHelper)
|
||||||
|
|
||||||
~TranslateHelper() override;
|
~TranslateHelper() override;
|
||||||
|
|
||||||
void init(QQmlEngine *engine);
|
void init(QQmlEngine *engine);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include "src/helper/TranslateHelper.h"
|
#include "src/helper/TranslateHelper.h"
|
||||||
#include "src/helper/Network.h"
|
#include "src/helper/Network.h"
|
||||||
|
|
||||||
|
|
||||||
#ifdef FLUENTUI_BUILD_STATIC_LIB
|
#ifdef FLUENTUI_BUILD_STATIC_LIB
|
||||||
# if (QT_VERSION > QT_VERSION_CHECK(6, 2, 0))
|
# if (QT_VERSION > QT_VERSION_CHECK(6, 2, 0))
|
||||||
Q_IMPORT_QML_PLUGIN(FluentUIPlugin)
|
Q_IMPORT_QML_PLUGIN(FluentUIPlugin)
|
||||||
@ -31,8 +32,7 @@ Q_IMPORT_QML_PLUGIN(FluentUIPlugin)
|
|||||||
# include "app_dmp.h"
|
# include "app_dmp.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[]) {
|
||||||
{
|
|
||||||
const char *uri = "example";
|
const char *uri = "example";
|
||||||
int major = 1;
|
int major = 1;
|
||||||
int minor = 0;
|
int minor = 0;
|
||||||
@ -66,7 +66,8 @@ int main(int argc, char *argv[])
|
|||||||
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
|
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
|
||||||
QApplication::setAttribute(Qt::AA_UseHighDpiPixmaps);
|
QApplication::setAttribute(Qt::AA_UseHighDpiPixmaps);
|
||||||
# if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0))
|
# if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0))
|
||||||
QApplication::setHighDpiScaleFactorRoundingPolicy(Qt::HighDpiScaleFactorRoundingPolicy::PassThrough);
|
QApplication::setHighDpiScaleFactorRoundingPolicy(
|
||||||
|
Qt::HighDpiScaleFactorRoundingPolicy::PassThrough);
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
QApplication app(argc, argv);
|
QApplication app(argc, argv);
|
||||||
@ -77,7 +78,8 @@ int main(int argc, char *argv[])
|
|||||||
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");
|
qmlRegisterType<OpenGLItem>(uri, major, minor, "OpenGLItem");
|
||||||
qmlRegisterUncreatableMetaObject(NetworkType::staticMetaObject, uri, major, minor, "NetworkType", "Access to enums & flags only");
|
qmlRegisterUncreatableMetaObject(NetworkType::staticMetaObject, uri, major, minor,
|
||||||
|
"NetworkType", "Access to enums & flags only");
|
||||||
|
|
||||||
QQmlApplicationEngine engine;
|
QQmlApplicationEngine engine;
|
||||||
TranslateHelper::getInstance()->init(&engine);
|
TranslateHelper::getInstance()->init(&engine);
|
||||||
@ -90,11 +92,13 @@ int main(int argc, char *argv[])
|
|||||||
FluentUI::getInstance()->registerTypes(&engine);
|
FluentUI::getInstance()->registerTypes(&engine);
|
||||||
#endif
|
#endif
|
||||||
const QUrl url(QStringLiteral("qrc:/example/qml/App.qml"));
|
const QUrl url(QStringLiteral("qrc:/example/qml/App.qml"));
|
||||||
QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,
|
QObject::connect(
|
||||||
&app, [url](QObject *obj, const QUrl &objUrl) {
|
&engine, &QQmlApplicationEngine::objectCreated, &app,
|
||||||
|
[url](QObject *obj, const QUrl &objUrl) {
|
||||||
if (!obj && url == objUrl)
|
if (!obj && url == objUrl)
|
||||||
QCoreApplication::exit(-1);
|
QCoreApplication::exit(-1);
|
||||||
}, Qt::QueuedConnection);
|
},
|
||||||
|
Qt::QueuedConnection);
|
||||||
engine.load(url);
|
engine.load(url);
|
||||||
const int exec = QApplication::exec();
|
const int exec = QApplication::exec();
|
||||||
if (exec == 931) {
|
if (exec == 931) {
|
||||||
|
@ -18,6 +18,7 @@ T *Singleton<T>::getInstance() {
|
|||||||
#define SINGLETON(Class) \
|
#define SINGLETON(Class) \
|
||||||
private: \
|
private: \
|
||||||
friend class Singleton<Class>; \
|
friend class Singleton<Class>; \
|
||||||
|
\
|
||||||
public: \
|
public: \
|
||||||
static Class *getInstance() { \
|
static Class *getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
|
@ -4,15 +4,14 @@
|
|||||||
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(TYPE in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
|
||||||
@ -20,15 +19,14 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
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(const TYPE& in_##M) \
|
void M(const TYPE &in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
|
||||||
@ -37,14 +35,13 @@ 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(const TYPE& in_##M) \
|
void M(const TYPE &in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
60
src/Def.h
60
src/Def.h
@ -59,11 +59,7 @@ namespace FluPageType {
|
|||||||
|
|
||||||
namespace FluWindowType {
|
namespace FluWindowType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum LaunchMode {
|
enum LaunchMode { Standard = 0x0000, SingleTask = 0x0001, SingleInstance = 0x0002 };
|
||||||
Standard = 0x0000,
|
|
||||||
SingleTask = 0x0001,
|
|
||||||
SingleInstance = 0x0002
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(LaunchMode)
|
Q_ENUM_NS(LaunchMode)
|
||||||
|
|
||||||
@ -72,11 +68,7 @@ namespace FluWindowType {
|
|||||||
|
|
||||||
namespace FluTreeViewType {
|
namespace FluTreeViewType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum SelectionMode {
|
enum SelectionMode { None = 0x0000, Single = 0x0001, Multiple = 0x0002 };
|
||||||
None = 0x0000,
|
|
||||||
Single = 0x0001,
|
|
||||||
Multiple = 0x0002
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(SelectionMode)
|
Q_ENUM_NS(SelectionMode)
|
||||||
|
|
||||||
@ -85,12 +77,7 @@ namespace FluTreeViewType {
|
|||||||
|
|
||||||
namespace FluStatusLayoutType {
|
namespace FluStatusLayoutType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum StatusMode {
|
enum StatusMode { Loading = 0x0000, Empty = 0x0001, Error = 0x0002, Success = 0x0004 };
|
||||||
Loading = 0x0000,
|
|
||||||
Empty = 0x0001,
|
|
||||||
Error = 0x0002,
|
|
||||||
Success = 0x0004
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(StatusMode)
|
Q_ENUM_NS(StatusMode)
|
||||||
|
|
||||||
@ -99,11 +86,7 @@ namespace FluStatusLayoutType {
|
|||||||
|
|
||||||
namespace FluContentDialogType {
|
namespace FluContentDialogType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum ButtonFlag {
|
enum ButtonFlag { NeutralButton = 0x0001, NegativeButton = 0x0002, PositiveButton = 0x0004 };
|
||||||
NeutralButton = 0x0001,
|
|
||||||
NegativeButton = 0x0002,
|
|
||||||
PositiveButton = 0x0004
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(ButtonFlag)
|
Q_ENUM_NS(ButtonFlag)
|
||||||
|
|
||||||
@ -112,10 +95,7 @@ namespace FluContentDialogType {
|
|||||||
|
|
||||||
namespace FluTimePickerType {
|
namespace FluTimePickerType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum HourFormat {
|
enum HourFormat { H = 0x0000, HH = 0x0001 };
|
||||||
H = 0x0000,
|
|
||||||
HH = 0x0001
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(HourFormat)
|
Q_ENUM_NS(HourFormat)
|
||||||
|
|
||||||
@ -124,11 +104,7 @@ namespace FluTimePickerType {
|
|||||||
|
|
||||||
namespace FluCalendarViewType {
|
namespace FluCalendarViewType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum DisplayMode {
|
enum DisplayMode { Month = 0x0000, Year = 0x0001, Decade = 0x0002 };
|
||||||
Month = 0x0000,
|
|
||||||
Year = 0x0001,
|
|
||||||
Decade = 0x0002
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(DisplayMode)
|
Q_ENUM_NS(DisplayMode)
|
||||||
|
|
||||||
@ -137,19 +113,11 @@ namespace FluCalendarViewType {
|
|||||||
|
|
||||||
namespace FluTabViewType {
|
namespace FluTabViewType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum TabWidthBehavior {
|
enum TabWidthBehavior { Equal = 0x0000, SizeToContent = 0x0001, Compact = 0x0002 };
|
||||||
Equal = 0x0000,
|
|
||||||
SizeToContent = 0x0001,
|
|
||||||
Compact = 0x0002
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(TabWidthBehavior)
|
Q_ENUM_NS(TabWidthBehavior)
|
||||||
|
|
||||||
enum CloseButtonVisibility {
|
enum CloseButtonVisibility { Never = 0x0000, Always = 0x0001, OnHover = 0x0002 };
|
||||||
Never = 0x0000,
|
|
||||||
Always = 0x0001,
|
|
||||||
OnHover = 0x0002
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(CloseButtonVisibility)
|
Q_ENUM_NS(CloseButtonVisibility)
|
||||||
|
|
||||||
@ -158,19 +126,11 @@ namespace FluTabViewType {
|
|||||||
|
|
||||||
namespace FluNavigationViewType {
|
namespace FluNavigationViewType {
|
||||||
Q_NAMESPACE
|
Q_NAMESPACE
|
||||||
enum DisplayMode {
|
enum DisplayMode { Open = 0x0000, Compact = 0x0001, Minimal = 0x0002, Auto = 0x0004 };
|
||||||
Open = 0x0000,
|
|
||||||
Compact = 0x0001,
|
|
||||||
Minimal = 0x0002,
|
|
||||||
Auto = 0x0004
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(DisplayMode)
|
Q_ENUM_NS(DisplayMode)
|
||||||
|
|
||||||
enum PageMode {
|
enum PageMode { Stack = 0x0000, NoStack = 0x0001 };
|
||||||
Stack = 0x0000,
|
|
||||||
NoStack = 0x0001
|
|
||||||
};
|
|
||||||
|
|
||||||
Q_ENUM_NS(PageMode)
|
Q_ENUM_NS(PageMode)
|
||||||
|
|
||||||
|
@ -34,7 +34,8 @@ void FluApp::init(QObject *launcher, QLocale locale) {
|
|||||||
|
|
||||||
[[maybe_unused]] QJsonArray FluApp::iconData(const QString &keyword) {
|
[[maybe_unused]] QJsonArray FluApp::iconData(const QString &keyword) {
|
||||||
QJsonArray arr;
|
QJsonArray arr;
|
||||||
QMetaEnum enumType = FluentIcons::staticMetaObject.enumerator(FluentIcons::staticMetaObject.indexOfEnumerator("Type"));
|
QMetaEnum enumType = FluentIcons::staticMetaObject.enumerator(
|
||||||
|
FluentIcons::staticMetaObject.indexOfEnumerator("Type"));
|
||||||
for (int i = 0; i <= enumType.keyCount() - 1; ++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);
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
*/
|
*/
|
||||||
class FluApp : public QObject {
|
class FluApp : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
Q_PROPERTY_AUTO(bool, useSystemAppBar)
|
Q_PROPERTY_AUTO(bool, useSystemAppBar)
|
||||||
Q_PROPERTY_AUTO(QString, windowIcon)
|
Q_PROPERTY_AUTO(QString, windowIcon)
|
||||||
Q_PROPERTY_AUTO(QLocale, locale)
|
Q_PROPERTY_AUTO(QLocale, locale)
|
||||||
@ -33,7 +32,9 @@ private:
|
|||||||
public:
|
public:
|
||||||
SINGLETON(FluApp)
|
SINGLETON(FluApp)
|
||||||
|
|
||||||
static FluApp *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
static FluApp *create(QQmlEngine *, QJSEngine *) {
|
||||||
|
return getInstance();
|
||||||
|
}
|
||||||
|
|
||||||
Q_INVOKABLE void init(QObject *launcher, QLocale locale = QLocale::system());
|
Q_INVOKABLE void init(QObject *launcher, QLocale locale = QLocale::system());
|
||||||
|
|
||||||
|
@ -40,7 +40,8 @@ void FluCaptcha::paint(QPainter *painter) {
|
|||||||
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();
|
||||||
}
|
}
|
||||||
|
@ -11,8 +11,8 @@
|
|||||||
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)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -13,39 +13,39 @@
|
|||||||
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)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey10);
|
Q_PROPERTY_AUTO(QColor, Grey10)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey20);
|
Q_PROPERTY_AUTO(QColor, Grey20)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey30);
|
Q_PROPERTY_AUTO(QColor, Grey30)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey40);
|
Q_PROPERTY_AUTO(QColor, Grey40)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey50);
|
Q_PROPERTY_AUTO(QColor, Grey50)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey60);
|
Q_PROPERTY_AUTO(QColor, Grey60)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey70);
|
Q_PROPERTY_AUTO(QColor, Grey70)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey80);
|
Q_PROPERTY_AUTO(QColor, Grey80)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey90);
|
Q_PROPERTY_AUTO(QColor, Grey90)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey100);
|
Q_PROPERTY_AUTO(QColor, Grey100)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey110);
|
Q_PROPERTY_AUTO(QColor, Grey110)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey120);
|
Q_PROPERTY_AUTO(QColor, Grey120)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey130);
|
Q_PROPERTY_AUTO(QColor, Grey130)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey140);
|
Q_PROPERTY_AUTO(QColor, Grey140)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey150);
|
Q_PROPERTY_AUTO(QColor, Grey150)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey160);
|
Q_PROPERTY_AUTO(QColor, Grey160)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey170);
|
Q_PROPERTY_AUTO(QColor, Grey170)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey180);
|
Q_PROPERTY_AUTO(QColor, Grey180)
|
||||||
Q_PROPERTY_AUTO(QColor, Grey190);
|
Q_PROPERTY_AUTO(QColor, Grey190)
|
||||||
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_P(FluAccentColor*, Yellow);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Yellow)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Orange);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Orange)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Red);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Red)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Magenta);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Magenta)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Purple);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Purple)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Blue);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Blue)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Teal);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Teal)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, Green);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, Green)
|
||||||
QML_NAMED_ELEMENT(FluColors)
|
QML_NAMED_ELEMENT(FluColors)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
@ -57,5 +57,7 @@ SINGLETON(FluColors)
|
|||||||
|
|
||||||
[[maybe_unused]] Q_INVOKABLE FluAccentColor *createAccentColor(const QColor &primaryColor);
|
[[maybe_unused]] Q_INVOKABLE FluAccentColor *createAccentColor(const QColor &primaryColor);
|
||||||
|
|
||||||
static FluColors *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
static FluColors *create(QQmlEngine *, QJSEngine *) {
|
||||||
|
return getInstance();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
@ -14,7 +14,6 @@ using QT_NATIVE_EVENT_RESULT_TYPE = long;
|
|||||||
using QT_ENTER_EVENT_TYPE = QEvent;
|
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_P(QQuickItem *, appbar)
|
Q_PROPERTY_AUTO_P(QQuickItem *, appbar)
|
||||||
@ -32,7 +31,8 @@ public:
|
|||||||
|
|
||||||
void componentComplete() override;
|
void componentComplete() override;
|
||||||
|
|
||||||
[[maybe_unused]] bool nativeEventFilter(const QByteArray &eventType, void *message, QT_NATIVE_EVENT_RESULT_TYPE *result) override;
|
[[maybe_unused]] bool nativeEventFilter(const QByteArray &eventType, void *message,
|
||||||
|
QT_NATIVE_EVENT_RESULT_TYPE *result) override;
|
||||||
|
|
||||||
[[maybe_unused]] Q_INVOKABLE void showFullScreen();
|
[[maybe_unused]] Q_INVOKABLE void showFullScreen();
|
||||||
|
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
#include "FluHotkey.h"
|
#include "FluHotkey.h"
|
||||||
|
|
||||||
|
|
||||||
#include "QGuiApplication"
|
#include "QGuiApplication"
|
||||||
|
|
||||||
FluHotkey::FluHotkey(QObject *parent)
|
|
||||||
: QObject{parent}
|
FluHotkey::FluHotkey(QObject *parent) : QObject{parent} {
|
||||||
{
|
|
||||||
_sequence = "";
|
_sequence = "";
|
||||||
_isRegistered = false;
|
_isRegistered = false;
|
||||||
connect(this, &FluHotkey::sequenceChanged, this, [=] {
|
connect(this, &FluHotkey::sequenceChanged, this, [=] {
|
||||||
@ -15,12 +13,9 @@ FluHotkey::FluHotkey(QObject *parent)
|
|||||||
}
|
}
|
||||||
_hotkey = new QHotkey(QKeySequence(_sequence), true, qApp);
|
_hotkey = new QHotkey(QKeySequence(_sequence), true, qApp);
|
||||||
this->isRegistered(_hotkey->isRegistered());
|
this->isRegistered(_hotkey->isRegistered());
|
||||||
QObject::connect(_hotkey, &QHotkey::activated, qApp, [=](){
|
QObject::connect(_hotkey, &QHotkey::activated, qApp, [=]() { Q_EMIT this->activated(); });
|
||||||
Q_EMIT this->activated();
|
QObject::connect(_hotkey, &QHotkey::registeredChanged, qApp,
|
||||||
});
|
[=]() { this->isRegistered(_hotkey->isRegistered()); });
|
||||||
QObject::connect(_hotkey, &QHotkey::registeredChanged, qApp, [=](){
|
|
||||||
this->isRegistered(_hotkey->isRegistered());
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,8 +6,8 @@
|
|||||||
#include "qhotkey/qhotkey.h"
|
#include "qhotkey/qhotkey.h"
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
class FluHotkey : public QObject
|
class FluHotkey : public QObject {
|
||||||
{
|
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY_AUTO(QString, sequence)
|
Q_PROPERTY_AUTO(QString, sequence)
|
||||||
Q_PROPERTY_AUTO(QString, name)
|
Q_PROPERTY_AUTO(QString, name)
|
||||||
@ -17,6 +17,7 @@ public:
|
|||||||
explicit FluHotkey(QObject *parent = nullptr);
|
explicit FluHotkey(QObject *parent = nullptr);
|
||||||
~FluHotkey();
|
~FluHotkey();
|
||||||
Q_SIGNAL void activated();
|
Q_SIGNAL void activated();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QHotkey *_hotkey = nullptr;
|
QHotkey *_hotkey = nullptr;
|
||||||
};
|
};
|
||||||
|
@ -14,7 +14,7 @@ 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)
|
||||||
Q_PROPERTY_AUTO(int, size);
|
Q_PROPERTY_AUTO(int, size)
|
||||||
QML_NAMED_ELEMENT(FluQrCodeItem)
|
QML_NAMED_ELEMENT(FluQrCodeItem)
|
||||||
public:
|
public:
|
||||||
explicit FluQrCodeItem(QQuickItem *parent = nullptr);
|
explicit FluQrCodeItem(QQuickItem *parent = nullptr);
|
||||||
|
@ -8,6 +8,7 @@ FluRectangle::FluRectangle(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
|||||||
connect(this, &FluRectangle::radiusChanged, this, [=] { update(); });
|
connect(this, &FluRectangle::radiusChanged, this, [=] { update(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void FluRectangle::paint(QPainter *painter) {
|
void FluRectangle::paint(QPainter *painter) {
|
||||||
painter->save();
|
painter->save();
|
||||||
painter->setRenderHint(QPainter::Antialiasing);
|
painter->setRenderHint(QPainter::Antialiasing);
|
||||||
@ -15,13 +16,19 @@ void FluRectangle::paint(QPainter *painter) {
|
|||||||
QRectF rect = boundingRect();
|
QRectF rect = boundingRect();
|
||||||
path.moveTo(rect.bottomRight() - QPointF(0, _radius[2]));
|
path.moveTo(rect.bottomRight() - QPointF(0, _radius[2]));
|
||||||
path.lineTo(rect.topRight() + QPointF(0, _radius[1]));
|
path.lineTo(rect.topRight() + QPointF(0, _radius[1]));
|
||||||
path.arcTo(QRectF(QPointF(rect.topRight() - QPointF(_radius[1] * 2, 0)), QSize(_radius[1] * 2, _radius[1] * 2)), 0, 90);
|
path.arcTo(QRectF(QPointF(rect.topRight() - QPointF(_radius[1] * 2, 0)),
|
||||||
|
QSize(_radius[1] * 2, _radius[1] * 2)),
|
||||||
|
0, 90);
|
||||||
path.lineTo(rect.topLeft() + QPointF(_radius[0], 0));
|
path.lineTo(rect.topLeft() + QPointF(_radius[0], 0));
|
||||||
path.arcTo(QRectF(QPointF(rect.topLeft()), QSize(_radius[0] * 2, _radius[0] * 2)), 90, 90);
|
path.arcTo(QRectF(QPointF(rect.topLeft()), QSize(_radius[0] * 2, _radius[0] * 2)), 90, 90);
|
||||||
path.lineTo(rect.bottomLeft() - QPointF(0, _radius[3]));
|
path.lineTo(rect.bottomLeft() - QPointF(0, _radius[3]));
|
||||||
path.arcTo(QRectF(QPointF(rect.bottomLeft() - QPointF(0, _radius[3] * 2)), QSize(_radius[3] * 2, _radius[3] * 2)), 180, 90);
|
path.arcTo(QRectF(QPointF(rect.bottomLeft() - QPointF(0, _radius[3] * 2)),
|
||||||
|
QSize(_radius[3] * 2, _radius[3] * 2)),
|
||||||
|
180, 90);
|
||||||
path.lineTo(rect.bottomRight() - QPointF(_radius[2], 0));
|
path.lineTo(rect.bottomRight() - QPointF(_radius[2], 0));
|
||||||
path.arcTo(QRectF(QPointF(rect.bottomRight() - QPointF(_radius[2] * 2, _radius[2] * 2)), QSize(_radius[2] * 2, _radius[2] * 2)), 270, 90);
|
path.arcTo(QRectF(QPointF(rect.bottomRight() - QPointF(_radius[2] * 2, _radius[2] * 2)),
|
||||||
|
QSize(_radius[2] * 2, _radius[2] * 2)),
|
||||||
|
270, 90);
|
||||||
painter->fillPath(path, _color);
|
painter->fillPath(path, _color);
|
||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
#include "FluTableModel.h"
|
#include "FluTableModel.h"
|
||||||
|
|
||||||
FluTableModel::FluTableModel(QObject *parent) : QAbstractTableModel{parent} {
|
FluTableModel::FluTableModel(QObject *parent) : QAbstractTableModel{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int FluTableModel::rowCount(const QModelIndex &parent) const {
|
int FluTableModel::rowCount(const QModelIndex &parent) const {
|
||||||
return _rows.count();
|
return _rows.count();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int FluTableModel::columnCount(const QModelIndex &parent) const {
|
int FluTableModel::columnCount(const QModelIndex &parent) const {
|
||||||
return this->_columnSource.size();
|
return this->_columnSource.size();
|
||||||
}
|
}
|
||||||
|
@ -13,10 +13,8 @@ Q_PROPERTY_AUTO(QList<QVariantMap>, rows)
|
|||||||
Q_PROPERTY(int rowCount READ rowCount CONSTANT)
|
Q_PROPERTY(int rowCount READ rowCount CONSTANT)
|
||||||
QML_NAMED_ELEMENT(FluTableModel)
|
QML_NAMED_ELEMENT(FluTableModel)
|
||||||
public:
|
public:
|
||||||
enum TableModelRoles {
|
enum TableModelRoles { RowModel = 0x0101, ColumnModel = 0x0102 };
|
||||||
RowModel = 0x0101,
|
|
||||||
ColumnModel = 0x0102
|
|
||||||
};
|
|
||||||
|
|
||||||
explicit FluTableModel(QObject *parent = nullptr);
|
explicit FluTableModel(QObject *parent = nullptr);
|
||||||
|
|
||||||
@ -24,7 +22,8 @@ public:
|
|||||||
|
|
||||||
[[nodiscard]] int columnCount(const QModelIndex &parent = {}) const override;
|
[[nodiscard]] int columnCount(const QModelIndex &parent = {}) const override;
|
||||||
|
|
||||||
[[nodiscard]] QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
[[nodiscard]] QVariant data(const QModelIndex &index,
|
||||||
|
int role = Qt::DisplayRole) const override;
|
||||||
|
|
||||||
[[nodiscard]] QHash<int, QByteArray> roleNames() const override;
|
[[nodiscard]] QHash<int, QByteArray> roleNames() const override;
|
||||||
|
|
||||||
@ -39,7 +38,6 @@ public:
|
|||||||
Q_INVOKABLE void removeRow(int rowIndex, int rows = 1);
|
Q_INVOKABLE void removeRow(int rowIndex, int rows = 1);
|
||||||
|
|
||||||
Q_INVOKABLE void appendRow(QVariant row);
|
Q_INVOKABLE void appendRow(QVariant row);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,13 +2,14 @@
|
|||||||
|
|
||||||
#include <QJSValueList>
|
#include <QJSValueList>
|
||||||
|
|
||||||
FluTableSortProxyModel::FluTableSortProxyModel(QSortFilterProxyModel *parent) : QSortFilterProxyModel{parent} {
|
FluTableSortProxyModel::FluTableSortProxyModel(QSortFilterProxyModel *parent)
|
||||||
connect(this, &FluTableSortProxyModel::modelChanged, this, [=] {
|
: QSortFilterProxyModel{parent} {
|
||||||
setSourceModel(this->model().value<QAbstractTableModel *>());
|
connect(this, &FluTableSortProxyModel::modelChanged, this,
|
||||||
});
|
[=] { setSourceModel(this->model().value<QAbstractTableModel *>()); });
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTableSortProxyModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const {
|
bool FluTableSortProxyModel::filterAcceptsRow(int source_row,
|
||||||
|
const QModelIndex &source_parent) const {
|
||||||
QJSValue filter = _filter;
|
QJSValue filter = _filter;
|
||||||
if (filter.isUndefined()) {
|
if (filter.isUndefined()) {
|
||||||
return true;
|
return true;
|
||||||
@ -18,11 +19,13 @@ bool FluTableSortProxyModel::filterAcceptsRow(int source_row, const QModelIndex
|
|||||||
return filter.call(data).toBool();
|
return filter.call(data).toBool();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTableSortProxyModel::filterAcceptsColumn(int source_column, const QModelIndex &source_parent) const {
|
bool FluTableSortProxyModel::filterAcceptsColumn(int source_column,
|
||||||
|
const QModelIndex &source_parent) const {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTableSortProxyModel::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const {
|
bool FluTableSortProxyModel::lessThan(const QModelIndex &source_left,
|
||||||
|
const QModelIndex &source_right) const {
|
||||||
QJSValue comparator = _comparator;
|
QJSValue comparator = _comparator;
|
||||||
if (comparator.isUndefined()) {
|
if (comparator.isUndefined()) {
|
||||||
return true;
|
return true;
|
||||||
@ -58,18 +61,25 @@ bool FluTableSortProxyModel::lessThan(const QModelIndex &source_left, const QMod
|
|||||||
|
|
||||||
[[maybe_unused]] QVariant FluTableSortProxyModel::getRow(int rowIndex) {
|
[[maybe_unused]] QVariant FluTableSortProxyModel::getRow(int rowIndex) {
|
||||||
QVariant result;
|
QVariant result;
|
||||||
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "getRow", Q_RETURN_ARG(QVariant, result), Q_ARG(int, mapToSource(index(rowIndex, 0)).row()));
|
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "getRow",
|
||||||
|
Q_RETURN_ARG(QVariant, result),
|
||||||
|
Q_ARG(int, mapToSource(index(rowIndex, 0)).row()));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] void FluTableSortProxyModel::setRow(int rowIndex, const QVariant &val) {
|
[[maybe_unused]] void FluTableSortProxyModel::setRow(int rowIndex, const QVariant &val) {
|
||||||
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "setRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(QVariant, val));
|
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "setRow",
|
||||||
|
Q_ARG(int, mapToSource(index(rowIndex, 0)).row()),
|
||||||
|
Q_ARG(QVariant, val));
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] void FluTableSortProxyModel::insertRow(int rowIndex, const QVariant &val) {
|
[[maybe_unused]] void FluTableSortProxyModel::insertRow(int rowIndex, const QVariant &val) {
|
||||||
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "insertRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(QVariant, val));
|
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "insertRow",
|
||||||
|
Q_ARG(int, mapToSource(index(rowIndex, 0)).row()),
|
||||||
|
Q_ARG(QVariant, val));
|
||||||
}
|
}
|
||||||
|
|
||||||
[[maybe_unused]] void FluTableSortProxyModel::removeRow(int rowIndex, int rows) {
|
[[maybe_unused]] void FluTableSortProxyModel::removeRow(int rowIndex, int rows) {
|
||||||
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "removeRow", Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(int, rows));
|
QMetaObject::invokeMethod(_model.value<QAbstractTableModel *>(), "removeRow",
|
||||||
|
Q_ARG(int, mapToSource(index(rowIndex, 0)).row()), Q_ARG(int, rows));
|
||||||
}
|
}
|
||||||
|
@ -11,15 +11,16 @@
|
|||||||
*/
|
*/
|
||||||
class FluTextStyle : public QObject {
|
class FluTextStyle : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Q_PROPERTY_AUTO(QString, family)
|
Q_PROPERTY_AUTO(QString, family)
|
||||||
Q_PROPERTY_AUTO(QFont, Caption);
|
Q_PROPERTY_AUTO(QFont, Caption)
|
||||||
Q_PROPERTY_AUTO(QFont, Body);
|
Q_PROPERTY_AUTO(QFont, Body)
|
||||||
Q_PROPERTY_AUTO(QFont, BodyStrong);
|
Q_PROPERTY_AUTO(QFont, BodyStrong)
|
||||||
Q_PROPERTY_AUTO(QFont, Subtitle);
|
Q_PROPERTY_AUTO(QFont, Subtitle)
|
||||||
Q_PROPERTY_AUTO(QFont, Title);
|
Q_PROPERTY_AUTO(QFont, Title)
|
||||||
Q_PROPERTY_AUTO(QFont, TitleLarge);
|
Q_PROPERTY_AUTO(QFont, TitleLarge)
|
||||||
Q_PROPERTY_AUTO(QFont, Display);
|
Q_PROPERTY_AUTO(QFont, Display)
|
||||||
QML_NAMED_ELEMENT(FluTextStyle)
|
QML_NAMED_ELEMENT(FluTextStyle)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
@ -29,5 +30,7 @@ private:
|
|||||||
public:
|
public:
|
||||||
SINGLETON(FluTextStyle)
|
SINGLETON(FluTextStyle)
|
||||||
|
|
||||||
static FluTextStyle *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
static FluTextStyle *create(QQmlEngine *, QJSEngine *) {
|
||||||
|
return getInstance();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
@ -24,15 +24,13 @@ FluTheme::FluTheme(QObject *parent) : QObject{parent} {
|
|||||||
_blurBehindWindowEnabled = false;
|
_blurBehindWindowEnabled = false;
|
||||||
QGuiApplication::instance()->installEventFilter(this);
|
QGuiApplication::instance()->installEventFilter(this);
|
||||||
refreshColors();
|
refreshColors();
|
||||||
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(); });
|
||||||
connect(&_watcher, &QFileSystemWatcher::fileChanged, this, [=](const QString &path) {
|
connect(&_watcher, &QFileSystemWatcher::fileChanged, this,
|
||||||
Q_EMIT desktopImagePathChanged();
|
[=](const QString &path) { Q_EMIT desktopImagePathChanged(); });
|
||||||
});
|
connect(this, &FluTheme::blurBehindWindowEnabledChanged, this,
|
||||||
connect(this, &FluTheme::blurBehindWindowEnabledChanged, this, [=] { checkUpdateDesktopImage(); });
|
[=] { checkUpdateDesktopImage(); });
|
||||||
startTimer(1000);
|
startTimer(1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,11 +45,16 @@ void FluTheme::refreshColors() {
|
|||||||
fontSecondaryColor(isDark ? QColor(222, 222, 222, 255) : QColor(102, 102, 102, 255));
|
fontSecondaryColor(isDark ? QColor(222, 222, 222, 255) : QColor(102, 102, 102, 255));
|
||||||
fontTertiaryColor(isDark ? QColor(200, 200, 200, 255) : QColor(153, 153, 153, 255));
|
fontTertiaryColor(isDark ? QColor(200, 200, 200, 255) : QColor(153, 153, 153, 255));
|
||||||
itemNormalColor(isDark ? QColor(255, 255, 255, 0) : QColor(0, 0, 0, 0));
|
itemNormalColor(isDark ? QColor(255, 255, 255, 0) : QColor(0, 0, 0, 0));
|
||||||
frameColor(isDark ? QColor(56, 56, 56, qRound(255 * 0.8)) : QColor(243, 243, 243, qRound(255 * 0.8)));
|
frameColor(isDark ? QColor(56, 56, 56, qRound(255 * 0.8))
|
||||||
frameActiveColor(isDark ? QColor(48, 48, 48, qRound(255 * 0.8)) : QColor(255, 255, 255, qRound(255 * 0.8)));
|
: QColor(243, 243, 243, qRound(255 * 0.8)));
|
||||||
itemHoverColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.06)) : QColor(0, 0, 0, qRound(255 * 0.03)));
|
frameActiveColor(isDark ? QColor(48, 48, 48, qRound(255 * 0.8))
|
||||||
itemPressColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.09)) : QColor(0, 0, 0, qRound(255 * 0.06)));
|
: QColor(255, 255, 255, qRound(255 * 0.8)));
|
||||||
itemCheckColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12)) : QColor(0, 0, 0, qRound(255 * 0.09)));
|
itemHoverColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.06))
|
||||||
|
: QColor(0, 0, 0, qRound(255 * 0.03)));
|
||||||
|
itemPressColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.09))
|
||||||
|
: QColor(0, 0, 0, qRound(255 * 0.06)));
|
||||||
|
itemCheckColor(isDark ? QColor(255, 255, 255, qRound(255 * 0.12))
|
||||||
|
: QColor(0, 0, 0, qRound(255 * 0.09)));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool FluTheme::eventFilter(QObject *, QEvent *event) {
|
bool FluTheme::eventFilter(QObject *, QEvent *event) {
|
||||||
|
@ -18,26 +18,26 @@
|
|||||||
class FluTheme : public QObject {
|
class FluTheme : public QObject {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
Q_PROPERTY(bool dark READ dark NOTIFY darkChanged)
|
Q_PROPERTY(bool dark READ dark NOTIFY darkChanged)
|
||||||
Q_PROPERTY_AUTO_P(FluAccentColor*, accentColor);
|
Q_PROPERTY_AUTO_P(FluAccentColor *, accentColor)
|
||||||
Q_PROPERTY_AUTO(QColor, primaryColor);
|
Q_PROPERTY_AUTO(QColor, primaryColor)
|
||||||
Q_PROPERTY_AUTO(QColor, backgroundColor);
|
Q_PROPERTY_AUTO(QColor, backgroundColor)
|
||||||
Q_PROPERTY_AUTO(QColor, dividerColor);
|
Q_PROPERTY_AUTO(QColor, dividerColor)
|
||||||
Q_PROPERTY_AUTO(QColor, windowBackgroundColor);
|
Q_PROPERTY_AUTO(QColor, windowBackgroundColor)
|
||||||
Q_PROPERTY_AUTO(QColor, windowActiveBackgroundColor);
|
Q_PROPERTY_AUTO(QColor, windowActiveBackgroundColor)
|
||||||
Q_PROPERTY_AUTO(QColor, fontPrimaryColor);
|
Q_PROPERTY_AUTO(QColor, fontPrimaryColor)
|
||||||
Q_PROPERTY_AUTO(QColor, fontSecondaryColor);
|
Q_PROPERTY_AUTO(QColor, fontSecondaryColor)
|
||||||
Q_PROPERTY_AUTO(QColor, fontTertiaryColor);
|
Q_PROPERTY_AUTO(QColor, fontTertiaryColor)
|
||||||
Q_PROPERTY_AUTO(QColor, itemNormalColor);
|
Q_PROPERTY_AUTO(QColor, itemNormalColor)
|
||||||
Q_PROPERTY_AUTO(QColor, frameColor);
|
Q_PROPERTY_AUTO(QColor, frameColor)
|
||||||
Q_PROPERTY_AUTO(QColor, frameActiveColor);
|
Q_PROPERTY_AUTO(QColor, frameActiveColor)
|
||||||
Q_PROPERTY_AUTO(QColor, itemHoverColor);
|
Q_PROPERTY_AUTO(QColor, itemHoverColor)
|
||||||
Q_PROPERTY_AUTO(QColor, itemPressColor);
|
Q_PROPERTY_AUTO(QColor, itemPressColor)
|
||||||
Q_PROPERTY_AUTO(QColor, itemCheckColor);
|
Q_PROPERTY_AUTO(QColor, itemCheckColor)
|
||||||
Q_PROPERTY_AUTO(QString, desktopImagePath);
|
Q_PROPERTY_AUTO(QString, desktopImagePath)
|
||||||
Q_PROPERTY_AUTO(int, darkMode);
|
Q_PROPERTY_AUTO(int, darkMode)
|
||||||
Q_PROPERTY_AUTO(bool, nativeText);
|
Q_PROPERTY_AUTO(bool, nativeText)
|
||||||
Q_PROPERTY_AUTO(bool, animationEnabled);
|
Q_PROPERTY_AUTO(bool, animationEnabled)
|
||||||
Q_PROPERTY_AUTO(bool, blurBehindWindowEnabled);
|
Q_PROPERTY_AUTO(bool, blurBehindWindowEnabled)
|
||||||
QML_NAMED_ELEMENT(FluTheme)
|
QML_NAMED_ELEMENT(FluTheme)
|
||||||
QML_SINGLETON
|
QML_SINGLETON
|
||||||
|
|
||||||
@ -49,7 +49,6 @@ private:
|
|||||||
void refreshColors();
|
void refreshColors();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
void timerEvent(QTimerEvent *event) override;
|
void timerEvent(QTimerEvent *event) override;
|
||||||
|
|
||||||
void checkUpdateDesktopImage();
|
void checkUpdateDesktopImage();
|
||||||
@ -59,7 +58,9 @@ SINGLETON(FluTheme)
|
|||||||
|
|
||||||
Q_SIGNAL void darkChanged();
|
Q_SIGNAL void darkChanged();
|
||||||
|
|
||||||
static FluTheme *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
static FluTheme *create(QQmlEngine *, QJSEngine *) {
|
||||||
|
return getInstance();
|
||||||
|
}
|
||||||
|
|
||||||
bool dark() const;
|
bool dark() const;
|
||||||
|
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
FluTools::FluTools(QObject *parent) : QObject{parent} {
|
FluTools::FluTools(QObject *parent) : QObject{parent} {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTools::clipText(const QString &text) {
|
void FluTools::clipText(const QString &text) {
|
||||||
@ -168,7 +167,8 @@ void FluTools::showFileInFolder(const QString &path) {
|
|||||||
QProcess::startDetached(process, arguments);
|
QProcess::startDetached(process, arguments);
|
||||||
#endif
|
#endif
|
||||||
#if defined(Q_OS_MACOS)
|
#if defined(Q_OS_MACOS)
|
||||||
QProcess::execute("/usr/bin/osascript", {"-e", "tell application \"Finder\" to reveal POSIX file \"" + path + "\""});
|
QProcess::execute("/usr/bin/osascript",
|
||||||
|
{"-e", "tell application \"Finder\" to reveal POSIX file \"" + path + "\""});
|
||||||
QProcess::execute("/usr/bin/osascript", {"-e", "tell application \"Finder\" to activate"});
|
QProcess::execute("/usr/bin/osascript", {"-e", "tell application \"Finder\" to activate"});
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -206,7 +206,9 @@ int FluTools::cursorScreenIndex() {
|
|||||||
|
|
||||||
int FluTools::windowBuildNumber() {
|
int FluTools::windowBuildNumber() {
|
||||||
#if defined(Q_OS_WIN)
|
#if defined(Q_OS_WIN)
|
||||||
QSettings regKey{QString::fromUtf8(R"(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;
|
||||||
@ -313,5 +315,7 @@ QColor FluTools::imageMainColor(const QImage &image, double bright) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return QColor(int(bright * r / t) > 255 ? 255 : int(bright * r / t), int(bright * g / t) > 255 ? 255 : int(bright * g / t), int(bright * b / t) > 255 ? 255 : int(bright * b / t));
|
return QColor(int(bright * r / t) > 255 ? 255 : int(bright * r / t),
|
||||||
|
int(bright * g / t) > 255 ? 255 : int(bright * g / t),
|
||||||
|
int(bright * b / t) > 255 ? 255 : int(bright * b / t));
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,9 @@ private:
|
|||||||
public:
|
public:
|
||||||
SINGLETON(FluTools)
|
SINGLETON(FluTools)
|
||||||
|
|
||||||
static FluTools *create(QQmlEngine *, QJSEngine *) { return getInstance(); }
|
static FluTools *create(QQmlEngine *, QJSEngine *) {
|
||||||
|
return getInstance();
|
||||||
|
}
|
||||||
|
|
||||||
Q_INVOKABLE int qtMajor();
|
Q_INVOKABLE int qtMajor();
|
||||||
|
|
||||||
|
@ -102,7 +102,6 @@ void FluTreeModel::checkRow(int row, bool checked) {
|
|||||||
itemData->_checked = checked;
|
itemData->_checked = checked;
|
||||||
}
|
}
|
||||||
Q_EMIT dataChanged(index(0, 0), index(rowCount() - 1, 0));
|
Q_EMIT dataChanged(index(0, 0), index(rowCount() - 1, 0));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FluTreeModel::setDataSource(QList<QMap<QString, QVariant>> data) {
|
void FluTreeModel::setDataSource(QList<QMap<QString, QVariant>> data) {
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include <QtQml/qqml.h>
|
#include <QtQml/qqml.h>
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The FluTreeNode class
|
* @brief The FluTreeNode class
|
||||||
*/
|
*/
|
||||||
@ -19,13 +20,21 @@ Q_OBJECT
|
|||||||
public:
|
public:
|
||||||
explicit FluTreeNode(QObject *parent = nullptr);
|
explicit FluTreeNode(QObject *parent = nullptr);
|
||||||
|
|
||||||
[[nodiscard]] Q_INVOKABLE int depth() const { return _depth; };
|
[[nodiscard]] Q_INVOKABLE int depth() const {
|
||||||
|
return _depth;
|
||||||
|
};
|
||||||
|
|
||||||
[[nodiscard]] Q_INVOKABLE bool isExpanded() const { return _isExpanded; };
|
[[nodiscard]] Q_INVOKABLE bool isExpanded() const {
|
||||||
|
return _isExpanded;
|
||||||
|
};
|
||||||
|
|
||||||
[[nodiscard]] Q_INVOKABLE QVariantMap data() const { return _data; };
|
[[nodiscard]] Q_INVOKABLE QVariantMap data() const {
|
||||||
|
return _data;
|
||||||
|
};
|
||||||
|
|
||||||
[[nodiscard]] Q_INVOKABLE bool hasChildren() const { return !_children.isEmpty(); };
|
[[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;
|
||||||
@ -92,10 +101,7 @@ Q_PROPERTY_AUTO(int, dataSourceSize)
|
|||||||
Q_PROPERTY_AUTO(QList<QVariantMap>, columnSource)
|
Q_PROPERTY_AUTO(QList<QVariantMap>, columnSource)
|
||||||
QML_NAMED_ELEMENT(FluTreeModel)
|
QML_NAMED_ELEMENT(FluTreeModel)
|
||||||
public:
|
public:
|
||||||
enum TreeModelRoles {
|
enum TreeModelRoles { RowModel = 0x0101, ColumnModel = 0x0102 };
|
||||||
RowModel = 0x0101,
|
|
||||||
ColumnModel = 0x0102
|
|
||||||
};
|
|
||||||
|
|
||||||
explicit FluTreeModel(QObject *parent = nullptr);
|
explicit FluTreeModel(QObject *parent = nullptr);
|
||||||
|
|
||||||
@ -103,7 +109,8 @@ public:
|
|||||||
|
|
||||||
[[nodiscard]] int columnCount(const QModelIndex &parent = {}) const override;
|
[[nodiscard]] int columnCount(const QModelIndex &parent = {}) const override;
|
||||||
|
|
||||||
[[nodiscard]] QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
[[nodiscard]] QVariant data(const QModelIndex &index,
|
||||||
|
int role = Qt::DisplayRole) const override;
|
||||||
|
|
||||||
[[nodiscard]] QHash<int, QByteArray> roleNames() const override;
|
[[nodiscard]] QHash<int, QByteArray> roleNames() const override;
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@ FluWatermark::FluWatermark(QQuickItem *parent) : QQuickPaintedItem(parent) {
|
|||||||
connect(this, &FluWatermark::textSizeChanged, this, [=] { update(); });
|
connect(this, &FluWatermark::textSizeChanged, this, [=] { update(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void FluWatermark::paint(QPainter *painter) {
|
void FluWatermark::paint(QPainter *painter) {
|
||||||
QFont font;
|
QFont font;
|
||||||
font.setFamily(FluTextStyle::getInstance()->family());
|
font.setFamily(FluTextStyle::getInstance()->family());
|
||||||
@ -37,7 +38,8 @@ void FluWatermark::paint(QPainter *painter) {
|
|||||||
painter->save();
|
painter->save();
|
||||||
painter->translate(centerX, centerY);
|
painter->translate(centerX, centerY);
|
||||||
painter->rotate(_rotate);
|
painter->rotate(_rotate);
|
||||||
painter->drawText(QRectF(-fontWidth / 2.0, -fontHeight / 2.0, fontWidth, fontHeight), _text);
|
painter->drawText(QRectF(-fontWidth / 2.0, -fontHeight / 2.0, fontWidth, fontHeight),
|
||||||
|
_text);
|
||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -132,7 +132,7 @@ quint32 QHotkeyPrivateX11::nativeKeycode(Qt::Key keycode, bool &ok)
|
|||||||
|
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(6, 2, 0)
|
#if QT_VERSION >= QT_VERSION_CHECK(6, 2, 0)
|
||||||
const QNativeInterface::QX11Application *x11Interface = qGuiApp->nativeInterface<QNativeInterface::QX11Application>();
|
const QNativeInterface::QX11Application *x11Interface = qGuiApp->nativeInterface<QNativeInterface::QX11Application>();
|
||||||
Display *display = x11Interface->display();
|
Display *display = x11Interface ? x11Interface->display() : nullptr;
|
||||||
#else
|
#else
|
||||||
const bool x11Interface = QX11Info::isPlatformX11();
|
const bool x11Interface = QX11Info::isPlatformX11();
|
||||||
Display *display = QX11Info::display();
|
Display *display = QX11Info::display();
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The Singleton class
|
* @brief The Singleton class
|
||||||
*/
|
*/
|
||||||
@ -18,6 +19,7 @@ T *Singleton<T>::getInstance() {
|
|||||||
#define SINGLETON(Class) \
|
#define SINGLETON(Class) \
|
||||||
private: \
|
private: \
|
||||||
friend class Singleton<Class>; \
|
friend class Singleton<Class>; \
|
||||||
|
\
|
||||||
public: \
|
public: \
|
||||||
static Class *getInstance() { \
|
static Class *getInstance() { \
|
||||||
return Singleton<Class>::getInstance(); \
|
return Singleton<Class>::getInstance(); \
|
||||||
|
22
src/stdafx.h
22
src/stdafx.h
@ -1,18 +1,18 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
#define Q_PROPERTY_AUTO_P(TYPE, M) \
|
#define Q_PROPERTY_AUTO_P(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(TYPE in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
|
||||||
@ -20,15 +20,14 @@ Q_PROPERTY(TYPE M MEMBER _##M NOTIFY M##Changed)
|
|||||||
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(const TYPE& in_##M) \
|
void M(const TYPE &in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
|
||||||
@ -37,14 +36,13 @@ 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(const TYPE& in_##M) \
|
void M(const TYPE &in_##M) { \
|
||||||
{ \
|
|
||||||
_##M = in_##M; \
|
_##M = in_##M; \
|
||||||
Q_EMIT M##Changed(); \
|
Q_EMIT M##Changed(); \
|
||||||
} \
|
} \
|
||||||
TYPE M() \
|
TYPE M() { \
|
||||||
{ \
|
|
||||||
return _##M; \
|
return _##M; \
|
||||||
} \
|
} \
|
||||||
|
\
|
||||||
private: \
|
private: \
|
||||||
TYPE _##M;
|
TYPE _##M;
|
||||||
|
Loading…
Reference in New Issue
Block a user