Merge branch 'style' into 0.3
This commit is contained in:
commit
5f3ecef408
3
.gitmodules
vendored
3
.gitmodules
vendored
@ -4,3 +4,6 @@
|
||||
[submodule "submodules/RadialBarDemo"]
|
||||
path = submodules/RadialBarDemo
|
||||
url = https://github.com/mirukan/RadialBarDemo/
|
||||
[submodule "submodules/hsluv-c"]
|
||||
path = submodules/hsluv-c
|
||||
url = https://github.com/hsluv/hsluv-c
|
||||
|
@ -13,9 +13,11 @@ QRC_FILE = $$BUILD_DIR/resources.qrc
|
||||
|
||||
RESOURCES += $$QRC_FILE
|
||||
HEADERS += src/utils.h src/clipboard.h \
|
||||
submodules/RadialBarDemo/radialbar.h
|
||||
submodules/RadialBarDemo/radialbar.h \
|
||||
submodules/hsluv-c/src/hsluv.h
|
||||
SOURCES += src/main.cpp src/utils.cpp src/clipboard.cpp \
|
||||
submodules/RadialBarDemo/radialbar.cpp
|
||||
submodules/RadialBarDemo/radialbar.cpp \
|
||||
submodules/hsluv-c/src/hsluv.c
|
||||
TARGET = harmonyqml
|
||||
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
hsluv == 0.0.2
|
||||
Pillow >= 5.4.1, < 6
|
||||
pymediainfo >= 4.1, < 5
|
||||
cairosvg >= 2.4.2, < 3
|
||||
|
@ -7,7 +7,6 @@ import traceback
|
||||
from pathlib import Path
|
||||
from typing import Any, DefaultDict, Dict, List, Optional, Tuple
|
||||
|
||||
import hsluv
|
||||
from appdirs import AppDirs
|
||||
|
||||
import nio
|
||||
@ -245,13 +244,6 @@ class Backend:
|
||||
|
||||
# General functions
|
||||
|
||||
@staticmethod
|
||||
def hsluv(hue: int, saturation: int, lightness: int) -> List[float]:
|
||||
"""Convert HSLuv (0-360, 0-100, 0-100) to RGB (0-1, 0-1, 0-1) color."""
|
||||
|
||||
return hsluv.hsluv_to_rgb([hue, saturation, lightness])
|
||||
|
||||
|
||||
async def load_settings(self) -> tuple:
|
||||
"""Return parsed user config files."""
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||
|
||||
import QtQuick 2.12
|
||||
import Clipboard 0.1
|
||||
|
||||
FocusScope {
|
||||
signal deselectAll()
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Controls 2.12
|
||||
import Clipboard 0.1
|
||||
import "Base"
|
||||
|
||||
Item {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import Clipboard 0.1
|
||||
import "../Base"
|
||||
|
||||
HTileDelegate {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import Clipboard 0.1
|
||||
import "../Base"
|
||||
|
||||
HTileDelegate {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import Clipboard 0.1
|
||||
import "../../Base"
|
||||
import "../../Dialogs"
|
||||
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import CppUtils 0.1
|
||||
import "../../../Base"
|
||||
|
||||
HColumnLayout {
|
||||
|
@ -1,6 +1,7 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||
|
||||
import QtQuick 2.12
|
||||
import Clipboard 0.1
|
||||
import "../../../Base"
|
||||
|
||||
HTileDelegate {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import Clipboard 0.1
|
||||
import "../../../Base"
|
||||
|
||||
HColumnLayout {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import QtQuick.Layouts 1.12
|
||||
import CppUtils 0.1
|
||||
import "../../../Base"
|
||||
|
||||
HTile {
|
||||
|
@ -2,6 +2,7 @@
|
||||
|
||||
import QtQuick 2.12
|
||||
import io.thp.pyotherside 1.5
|
||||
import CppUtils 0.1
|
||||
|
||||
Python {
|
||||
id: py
|
||||
|
@ -1,6 +1,7 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||
|
||||
import QtQuick 2.12
|
||||
import CppUtils 0.1
|
||||
|
||||
QtObject {
|
||||
function makeObject(urlComponent, parent=null, properties={},
|
||||
@ -91,9 +92,7 @@ QtObject {
|
||||
|
||||
|
||||
function hsluv(hue, saturation, lightness, alpha=1.0) {
|
||||
hue = numberWrapAt(hue, 360)
|
||||
let rgb = py.callSync("hsluv", [hue, saturation, lightness])
|
||||
return Qt.rgba(rgb[0], rgb[1], rgb[2], alpha)
|
||||
return CppUtils.hsluv(hue, saturation, lightness, alpha)
|
||||
}
|
||||
|
||||
|
||||
|
32
src/main.cpp
32
src/main.cpp
@ -37,13 +37,33 @@ int main(int argc, char *argv[]) {
|
||||
objectContext->setContextProperty("debugMode", false);
|
||||
#endif
|
||||
|
||||
// Add our custom non-visual `QObject `s as properties.
|
||||
// Their attributes and methods will be accessing like normal QML objects.
|
||||
objectContext->setContextProperty("CppUtils", new Utils());
|
||||
objectContext->setContextProperty("Clipboard", new Clipboard());
|
||||
// Register our custom non-visual QObject singletons,
|
||||
// that will be importable anywhere in QML. Example:
|
||||
// import Clipboard 0.1
|
||||
// ...
|
||||
// Component.onCompleted: print(Clipboard.text)
|
||||
qmlRegisterSingletonType<Clipboard>(
|
||||
"Clipboard", 0, 1, "Clipboard",
|
||||
[](QQmlEngine *engine, QJSEngine *scriptEngine) -> QObject * {
|
||||
Q_UNUSED(engine)
|
||||
Q_UNUSED(scriptEngine)
|
||||
return new Clipboard();
|
||||
}
|
||||
);
|
||||
|
||||
// Register our custom visual items that will be importable from QML,
|
||||
// e.g. `import RadialBar 1.0`
|
||||
qmlRegisterSingletonType<Utils>(
|
||||
"CppUtils", 0, 1, "CppUtils",
|
||||
[](QQmlEngine *engine, QJSEngine *scriptEngine) -> QObject * {
|
||||
Q_UNUSED(engine)
|
||||
Q_UNUSED(scriptEngine)
|
||||
return new Utils();
|
||||
}
|
||||
);
|
||||
|
||||
// Register our custom visual items that will be importable from QML, e.g.
|
||||
// import RadialBar 1.0
|
||||
// ...
|
||||
// RadialBar { ... }
|
||||
qmlRegisterType<RadialBar>("RadialBar", 1, 0, "RadialBar");
|
||||
|
||||
// Create the QML root component by loading its file from the Qt Resource
|
||||
|
@ -2,10 +2,12 @@
|
||||
|
||||
// Function implementations of the Utils class, see the utils.h file.
|
||||
|
||||
#include <QColor>
|
||||
#include <QLocale>
|
||||
#include <QUuid>
|
||||
|
||||
#include "utils.h"
|
||||
#include "../submodules/hsluv-c/src/hsluv.h"
|
||||
|
||||
|
||||
Utils::Utils() {
|
||||
@ -23,3 +25,10 @@ QString Utils::formattedBytes(qint64 bytes, int precision) {
|
||||
QString Utils::uuid() {
|
||||
return QUuid::createUuid().toString(QUuid::WithoutBraces);
|
||||
}
|
||||
|
||||
|
||||
QColor Utils::hsluv(qreal hue, qreal saturation, qreal luv, qreal alpha) {
|
||||
double red, green, blue;
|
||||
hsluv2rgb(hue, saturation, luv, &red, &green, &blue);
|
||||
return QColor::fromRgbF(red, green, blue, alpha);
|
||||
}
|
||||
|
@ -1,13 +1,14 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||
|
||||
// The Utils class exposes various useful functions for QML that aren't
|
||||
// normally provided by Qt.
|
||||
// provided by the `Qt` object.
|
||||
|
||||
#ifndef UTILS_H
|
||||
#define UTILS_H
|
||||
|
||||
#include <QObject>
|
||||
#include <QColor>
|
||||
#include <QLocale>
|
||||
#include <QObject>
|
||||
|
||||
|
||||
class Utils : public QObject {
|
||||
@ -20,6 +21,7 @@ public:
|
||||
public slots:
|
||||
QString formattedBytes(qint64 bytes, int precision = 2);
|
||||
QString uuid();
|
||||
QColor hsluv(qreal hue, qreal saturation, qreal luv, qreal alpha = 1.0);
|
||||
|
||||
private:
|
||||
QLocale m_locale;
|
||||
|
1
submodules/hsluv-c
Submodule
1
submodules/hsluv-c
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 9e9be32d6010cad484a7b12b1a3d19c6cf4c1353
|
Loading…
Reference in New Issue
Block a user