Evgenii Legotckoi
Evgenii Legotckoi12. Oktober 2015 11:15

QML - Lektion 002. Benutzerdefinierte Schaltfläche in QML Android

Ich werde eine Reihe von Tutorials zu QML Android mit anpassen Schaltflächen oder genauer Styling starten, da dieser Begriff in diesem Fall besser geeignet ist. Wir werden in diesem Tutorial keine Dialogfelder aufrufen, sondern einfach unseren eigenen QML Cutom Button erstellen, der die Farbe ändert, wenn Sie darauf klicken. Und der Übersichtlichkeit halber gibt es zwei solcher Schaltflächen.

Die erste Schaltfläche ist rot mit schwarzem Rand und schwarzem Text, und wenn sie gedrückt wird, ändert sich die Hintergrundfarbe in Schwarz mit rotem Rand und Rot. Und die zweite Schaltfläche hat die gleichen Farben, jedoch in umgekehrter Reihenfolge.

Struktur des QML Custom Button-Projekts

Das Projekt wird in QtCreator als Qt Quick Application-Projekt mit Quick Controls erstellt. Tatsächlich wird es bereits eine Menüleiste, mehrere Dialoge und ein paar Schaltflächen geben. Also haben wir alles außer zwei Knöpfen weggeworfen und sie angepasst.

Und die Struktur des Projekts sieht in diesem Fall wie folgt aus:

  • QMLCutomButton.pro - Uns bekanntes Projektprofil;
  • deploy.pri - Datei zum Installieren des Quellcodes auf dem Gerät;
  • main.cpp - seit langem bekannte Startdatei für Anwendungen
  • qml.qrc - Projektressourcendatei, qml-Dateien werden dort gespeichert
  • main.qml - qml-Datei des Hauptanwendungsfensters
  • MainForm.ui.qml - und wieder die Ressourcendatei des Designers, verzeiht mir die Hardcore-Jungs. Die Schaltflächen werden darin versteckt. Das Projekt wurde für die Mindestversion Qt 5.5 erstellt.

QMLCustomButton.pro

Da dies die erste Lektion zu diesem Thema ist, werde ich diese Datei auflisten.

TEMPLATE = app

QT += qml quick widgets

SOURCES += main.cpp

RESOURCES += qml.qrc

# Additional import path used to resolve QML modules in Qt Creator's code model
QML_IMPORT_PATH =

# Default rules for deployment.
include(deployment.pri)

Bereitstellung.pri

Und auch diese Datei hat einiges zu bieten, obwohl sie standardmäßig erstellt wird.

unix:!android {
    isEmpty(target.path) {
        qnx {
            target.path = /tmp/$${TARGET}/bin
        } else {
            target.path = /opt/$${TARGET}/bin
        }
        export(target.path)
    }
    INSTALLS += target
}

export(INSTALLS)

main.cpp

In dieser Datei müssen Sie eine Engine für QML erstellen und die Quelldatei hinein laden.

#include <QApplication>
#include <QQmlApplicationEngine>

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);

    QQmlApplicationEngine engine; // Создаём движок qml
    // И загружаем в него исходники
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));

    return app.exec();
}

MainForm.ui.qml

QtCreator warnt, dass diese Datei nur im Designer bearbeitet werden kann, dies jedoch nicht ist. Aber wir werden es nicht manuell bearbeiten.

import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Layouts 1.2

Item {
    width: 640
    height: 480

    // Указываем кнопкам имя для доступа к ним
    property alias button1: button1
    property alias button2: button2

    // Слой с кнопками
    RowLayout {
        anchors.centerIn: parent

        // Первая кнопка
        Button {
            id: button1
        }

        // вторая кнопка
        Button {
            id: button2
        }
    }
}

main.qml

Schauen wir uns nun an, worum es ging, nämlich um die Logik der Buttons, die ganz am Anfang des Artikels beschrieben wurde. Um die Schaltflächen zu stylen, verwenden Sie die Einstellung style , die den ButtonStyle definiert. Der Körper unseres Custom Button ist ein Rechteck , das als Hintergrund der Schaltfläche fungiert. Um dies zu tun, Rechteck Gibt seine Farbe und seinen Strich mit abgerundeten Ecken an. Und um den Text anzupassen, benötigen Sie Schaltflächenstil, um die Schaltflächenbeschriftung durch Angabe der Textfarbe zu überschreiben.

Beachten Sie auch, dass die Farbe durch einen bedingten Ausdruck angegeben wird, indem das control Objekt überprüft wird, das auf das Widget zeigt, dh die Schaltfläche, die den angegebenen Stil steuert. Und wenn dieser Regler gedrückt wird, dann ist die Farbe eins, sonst ist sie anders.

import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Controls.Styles 1.4

ApplicationWindow {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World") // Ну как же без Приветствия Миру

    MainForm {
        // Растягиваем объект главного окна по всему родительскому элементу
        anchors.fill: parent

        // Стилизуем первую кнопку
        button1.style: ButtonStyle {
            // Стилизуем внешний вид кнопки
            background: Rectangle {
                /* Если кнопка нажата, то она будет красного цвета
                 * с черным ободком со скруглёнными краями,
                 * в противном случае она будет черного цвета с красным ободком
                 */
                color: control.pressed ? "red" : "black"
                border.color: control.pressed ? "black" : "red"
                border.width: 2
                radius: 5

            }

            // Стилизуем цвет текста кнопки
            label: Text {
                /* Если кнопка нажата, то цвет будет черным
                 * в противном случае красным
                 */
                text: qsTr("Press Me 1")
                color: control.pressed ? "black" : "red"
            }
        }

        // Стилизуем вторую кнопку
        button2.style: ButtonStyle {
            // Стилизуем внешний вид кнопки
            background: Rectangle {
                /* аналогично, что и для первой кнопки,
                 * но в противоположном порядке
                 */
                color: control.pressed ? "black" : "red"
                border.color: control.pressed ? "red" : "black"
                border.width: 2
                radius: 5
            }
            // Стилизуем цвет кнопки
            label: Text {
                /* аналогично, что и для первой кнопки,
                 * но в противоположном порядке
                 */
                text: qsTr("Press Me 2")
                color: control.pressed ? "red" : "black"
            }
        }
    }
}

Ergebnis

Es hat mich auf jeden Fall gefreut, dass es die Möglichkeit gibt, ohne Emulatoren und Installation auf Android Device das Ergebnis der geleisteten Arbeit zu sehen, und das ist sehr inspirierend. Und plattformübergreifend ist eine gute Nachricht.

Und das Aussehen der resultierenden Schaltflächen ist das gleiche wie in den Screenshots unten für Dextop und vom Smartphone Meizu M1 Note . Sie können sich die Logik der Anwendung auch im Video-Tutorial ansehen, das den Screenshots folgt.

Benutzerdefinierte QML-Schaltfläche auf dem Desktop

Benutzerdefinierte QML-Schaltfläche für Android

QML Custom Button auf Android linke Taste gedrückt

QML Custom Button auf Android rechte Taste gedrückt

Video-Tutorial

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

Magst du es? In sozialen Netzwerken teilen!

alex_lip
  • 17. November 2017 05:37

А как кастомайзить Button если использовать QtQuick.Controls 2.0 ? В этом случае пишет Cannot assign to non-existent property "style"

alex_lip
  • 17. November 2017 06:04

Нашел
http://doc.qt.io/Qt-5/qtquickcontrols2-customize.html#customizing-button

U
  • 3. Mai 2019 23:14
  • (bearbeitet)

Делаю вроде правильно, а ничего не получается. Что упустил? После button1. в выпадающем списке нет style.
Да, и откуда в уроке взялся файл .pri и зачем он нужен?

Evgenii Legotckoi
  • 6. Mai 2019 02:39

Добрый день. Этот урок для Qt Quick Control версии 1, Вы используете вторую версию. Здесь style уже нет, кастомизацию можно делать уже или черещ соответствующие property или через contentItem , или через делегаты, в зависимости от типа кастомизируемого объекта. Нужно отталкиваться от документации на конкретный объект

ЕВ
  • 8. November 2019 07:18

Добрый день. Не могу найти ссылки на скачивание проекта.

Добрый день. Её здесь нет.

Будьте добры, выложите проект-пример. QT быстро эволюционирует, сейчас уже 5.13 версия. В вашем проекте версия 5.5 и много отличий. Очень тормозится изучение.

Стараюсь ничего не обещать в этом направлении, ибо много основной работы и тем более, как вы и сказали - Qt очень быстро эволюционирует, но постараюсь обновить эту статью на выходных для Qt Quick 2

Evgenii Legotckoi
  • 9. November 2019 02:50
  • (bearbeitet)

Как и обещал, вы можете посмотреть новую статью QML - Урок 037. Кастомизация кнопок в QML (Обновление урока 002) . Там же найдёте ссылку на Git репозиторий. Не забудьте поставить звёздочку репозиторию )))

ac
  • 27. Dezember 2020 04:09

А есть ли первый урок в серии QML ?

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