Evgenii Legotckoi
Evgenii Legotckoi5. März 2018 03:13

Android. Java vs Qt QML - Tutorial 000. Materialdesign aktivieren

Für die Entwicklung von Java und Qt QML muss Material Design aktiviert sein.

Materialdesign in Java

Bei Java reicht es aus, das Theme in der Datei styles.xml zu aktivieren und das gewünschte Farbschema für die Anwendung einzustellen.

Stile.xml

<resources>

    <style name="AppTheme" parent="android:Theme.Material">
        <!-- Main theme colors -->
        <!--   your app branding color for the app bar -->
        <item name="android:colorPrimary">@color/colorPrimary</item>
        <!--   darker variant for the status bar and contextual app bars -->
        <item name="android:colorPrimaryDark">@color/colorPrimaryDark</item>
        <!--   theme UI controls like checkboxes and text fields -->
        <item name="android:colorAccent">@color/colorAccent</item>
    </style>

</resources>

Farben.xml

Farben werden in dieser Datei angegeben.

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#3F51B5</color>
    <color name="colorPrimaryDark">#303F9F</color>
    <color name="colorAccent">#FF4081</color>
</resources>

Materialdesign auf Qt QML

Um Material Design auf Qt QML verwenden zu können, müssen Sie die Verwendung von Qt Quick Controls 2 in Ihrem Projektprofil aktivieren.

QT += quick quickcontrols2

Als Nächstes fügen wir die QQuickStyle-Klasse in die main.cpp-Datei ein, um die statische Methode dieser Klasse zu verwenden, um den Material Design-Stil für die gesamte Anwendung zu aktivieren.

#include <QGuiApplication>
#include <QQuickStyle> // Класс для включения стилизации
#include <QQmlApplicationEngine>

int main(int argc, char *argv[])
{
    QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);

    QGuiApplication app(argc, argv);

    QQuickStyle::setStyle("Material"); // Включение Material Design

    QQmlApplicationEngine engine;
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
    if (engine.rootObjects().isEmpty())
        return -1;

    return app.exec();
}

Farbwechsel

Die Konfigurationsdatei qtquickcontrols2.conf dient zum Ändern des Farbschemas des Stils, der im Projektstamm neben dem Projektprofil platziert werden muss. Sie können diese Datei zu Ressourcen hinzufügen, um die Arbeit mit dieser Datei von der IDE aus zu vereinfachen.

[Material]
Primary=#3F51B5
Accent=#FF4081
Theme=#303F9F
Foreground=#ffff00
Background=#00ffff

Farbschemaeinstellungen

Java hat die folgenden Farbschemaeinstellungen

  • colorPrimary - Primärfarbe, zum Beispiel die Farbe der Aktionsleiste
  • colorPrimaryDark - Farbe der Statusleiste
  • textColorPrimary - Textfarbe für Beschriftungen über Elementen mit HintergrundfarbePrimary
  • windowBackground - Hintergrundfarbe der Anwendung
  • navigationBarColor - Farbe des Navigationsmenüs des Telefons
  • colorAccent - Farbe von Elementen wie Checkboxen etc.

Es gibt nur fünf Farbeinstellungen in Qt QML

  • Primär - Primärfarbe, Elemente ähnlich der Aktionsleiste
  • Akzent - Farbe von Elementen wie Kontrollkästchen
  • Design - Designfarbe, die sowohl für das Hauptanwendungsfenster als Hintergrund als auch für Popup-Menüs oder andere Elemente verwendet wird. Kann auch durch die Foreground- und Background-Eigenschaften überschrieben werden
  • Vordergrund - separate Themenfarbeinstellung, kann auf Text angewendet werden, überschreibt Themeneinstellungen.
  • Hintergrund - wird verwendet, um den Hintergrund von Elementen wie Menüs, Navigationsleiste usw. zu definieren. überschreibt Designeinstellungen.

Für Design können Sie System als Wert verwenden, was bedeutet, dass die Systemfarbpaletten verwendet werden. Aber gleichzeitig können Sie Farbanpassungen mit Vordergrund und Hintergrund vornehmen.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

A
  • 2. Juli 2020 17:05

Подскажите пожалуйста, эта тема все еще актуальна? Или есть другие способы работать с темой? Вообщем хочу изменить цвет статус бара и бара навигации в приложении, но не знаю как это делать правильно. Можно сделать полный экран, но это кажется совсем не то...

Evgenii Legotckoi
  • 3. Juli 2020 01:29

Это актуально для изменения цвета. В файле qtquickcontrols2.conf переменная Primary должна влиять на цвет приложения соответственно и цвет ApplicationBar должен поменяться. Но у status bar вроде как нужно запускать код в Java потоке Android приложения.

Вот есть такое решение

QtAndroid::runOnAndroidThread([=]()
{
    QAndroidJniObject window = QtAndroid::androidActivity().callObjectMethod("getWindow", "()Landroid/view/Window;");
    window.callMethod<void>("addFlags", "(I)V", 0x80000000);
    window.callMethod<void>("clearFlags", "(I)V", 0x04000000);
    window.callMethod<void>("setStatusBarColor", "(I)V", 0xffffffff); // Desired statusbar color
});

Для изменения цвета текста

QAndroidJniObject decorView = window.callObjectMethod("getDecorView", "()Landroid/view/View;");
decorView.callMethod<void>("setSystemUiVisibility", "(I)V", 0x00002000);

Есть ещё вот такой репозиторий, который должен с этим работать github . Но насколько он актуален, я не знаю.
Но думаю, что лучше подключите проект из github в своём проекте. Он выглядит достаточно адекватным на беглый взгляд.

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken