Михаиллл
Михаиллл4. April 2019 06:44

Как в QML изменить текст лэйбла

QML, Label, text

Добрый день.
Как в QML изменить текст лэйбла?
В файле Page1Form.ui.qml прописан лэйбл

    Label {
        id: page1Label2
        x: 122
        y: 409
        width: 156
        height: 56
        text: qsTr("1 из 20")
        horizontalAlignment: Text.AlignHCenter
        font.pointSize: 20
    }

В файле Page1.qml пытаюсь изменить текст лэйбла:

    page1Button0.onClicked: //left button
    {     
        page1Label2.text = "text"   
    }

Но это не работает, компилятор говорит что page1Button0 не определен.

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

Magst du es? In sozialen Netzwerken teilen!

17
Алексей Внуков
  • 4. April 2019 06:49

a page1Button0 существует? так уж сложилось, что при работе с QML нужно регулярно запускать qmake и пересобирать проект

    Михаиллл
    • 4. April 2019 06:56

    page1Button0 существует. запуск qmake не помог

      Алексей Внуков
      • 4. April 2019 07:03
      • (bearbeitet)

      без полного кода страниц тяжело сказать, кроме очевидного что компилятор не видит кнопку.

      п.с. по моему опыту, мне проще работать без Form, просто Page.qml, ее и в дизайнере можно открыть и так все необходимое на одной странице. как-то с формами не подружился

        Михаиллл
        • 4. April 2019 07:25

        Компилятор видит кнопку, но не видит лэйбел
        Вот код Page1Form.ui.qml

        import QtQuick 2.4
        import QtQuick.Controls 2.4
        
        Item {
            id: element
            width: 400
            height: 600
            property alias page1Button1: page1Button1
            property alias page1Button0: page1Button0
            property alias page1ButtonMenu: page1ButtonMenu
        
            Button {
                id: page1Button0
                x: 66
                y: 172
                width: 128
                height: 128
                //font.capitalization: Font.AllUppercase
                //display: AbstractButton.TextOnly
                //topPadding: 5
                Image {
                    id: image
                    width: 130
                    height: 130
                    anchors.topMargin: 0
                    anchors.leftMargin: 0
                    anchors.rightMargin: 0
                    anchors.bottomMargin: 0
                    anchors.fill: parent
                    source: "qrc:/images/images/close.png"
                    fillMode: Image.Stretch
                }
            }
        
            Button {
                id: page1Button1
                x: 251
                y: 172
                width: 130
                height: 130
                Image {
                    id: image1
                    width: 130
                    height: 130
                    anchors.rightMargin: 0
                    anchors.bottomMargin: 0
                    anchors.fill: parent
                    source: "qrc:/images/images/close.png"
                    fillMode: Image.Stretch
                }
            }
        
            Button {
                id: page1ButtonMenu
                x: 150
                y: 479
                text: qsTr("МЕНЮ")
                font.pointSize: 18
            }
        
            Label {
                id: page1labe0
                x: 57
                y: 47
                width: 286
                height: 33
                text: qsTr("Выберете красный цвет")
                horizontalAlignment: Text.AlignHCenter
                font.pixelSize: 22
                font.family: "Verdana"
                font.weight: Font.Thin
            }
        
            Label {
                id: page1Label1
                x: 122
                y: 340
                width: 156
                height: 56
                text: qsTr("Побед: 0%")
                font.pointSize: 20
                horizontalAlignment: Text.AlignHCenter
            }
        
            Label {
                id: page1Label2
                x: 122
                y: 409
                width: 156
                height: 56
                text: qsTr("1 из 20")
                horizontalAlignment: Text.AlignHCenter
                font.pointSize: 20
            }
            states: [
                State {
                    name: "Page1State1"
        
                    PropertyChanges {
                        target: image
                        source: "qrc:/images/images/red.png"
                    }
        
                    PropertyChanges {
                        target: image1
                        source: "qrc:/images/images/black.png"
                    }
                },
                State {
                    name: "Page1State2"
        
                    PropertyChanges {
                        target: image
                        source: "qrc:/images/images/black.png"
                    }
        
                    PropertyChanges {
                        target: image1
                        source: "qrc:/images/images/red.png"
                    }
                },
                State {
                    name: "Page1State0"
                }
            ]
        }
        
        

        вызвать пытаюсь в Page1.qml

        import QtQuick 2.4
        import QtQml 2.12
        
        Page1Form {
        
            page1Button0.onClicked: //left button
            {  
                page1Label2.text = "weg"
            }
        
            page1Button1.onClicked: //rigth button
            {
                state = "Page1State1"
            }
        
            page1ButtonMenu.onClicked:
            {
                loader.source = "Page0.qml"
            }
        
        }
        
        
          Алексей Внуков
          • 4. April 2019 08:15
          • (bearbeitet)
          • Die Antwort wurde als Lösung markiert.

          добавил в форму
          property alias page1Label2: page1Label2
          и все заработало. ну или обработку клик делать на форме, тоже работать будет

          а вот если бы было все в одном файле, то можно обойтись без алиасов

            Михаиллл
            • 4. April 2019 08:25

            Странно, но у меня все еще не работае.
            Покажите пожалуйста ваш вариант.
            Сделал так:

                Label {
                    id: page1Label2
                    x: 122
                    y: 409
                    width: 156
                    height: 56
                    text: qsTr("1 из 20")
                    horizontalAlignment: Text.AlignHCenter
                    font.pointSize: 20
                    property alias page1Label2: page1Label2
                }
            
              Михаиллл
              • 4. April 2019 08:35

              Сделал так, заработало. Спасибо!

                Алексей Внуков
                • 4. April 2019 08:43
                • (bearbeitet)

                работать будет как так

                import QtQuick 2.4
                import QtQml 2.12
                
                Page1Form {
                
                   page1Button0.onClicked: //left button
                    {
                        page1Label2.text = "weg"
                    }
                    page1Button1.onClicked: //rigth button
                    {
                        state = "Page1State1"
                    }
                
                    page1ButtonMenu.onClicked:
                    {
                        loader.source = "Page0.qml"
                    }
                
                }
                
                
                import QtQuick 2.4
                import QtQuick.Controls 2.4
                
                
                Item {
                    id: element
                    width: 400
                    height: 600
                    property alias page1Button1: page1Button1
                    property alias page1Button0: page1Button0
                    property alias page1ButtonMenu: page1ButtonMenu
                    property alias page1Label2: page1Label2
                
                    Button {
                        id: page1Button0
                        x: 66
                        y: 172
                        width: 128
                        height: 128
                
                        Image {
                            id: image
                            width: 130
                            height: 130
                            anchors.topMargin: 0
                            anchors.leftMargin: 0
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                
                
                    }
                
                    Button {
                        id: page1Button1
                        x: 251
                        y: 172
                        width: 130
                        height: 130
                        Image {
                            id: image1
                            width: 130
                            height: 130
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                    }
                
                    Button {
                        id: page1ButtonMenu
                        x: 150
                        y: 479
                        text: qsTr("МЕНЮ")
                        font.pointSize: 18
                    }
                
                    Label {
                        id: page1labe0
                        x: 57
                        y: 47
                        width: 286
                        height: 33
                        text: qsTr("Выберете красный цвет")
                        horizontalAlignment: Text.AlignHCenter
                        font.pixelSize: 22
                        font.family: "Verdana"
                        font.weight: Font.Thin
                    }
                
                    Label {
                        id: page1Label1
                        x: 122
                        y: 340
                        width: 156
                        height: 56
                        text: qsTr("Побед: 0%")
                        font.pointSize: 20
                        horizontalAlignment: Text.AlignHCenter
                    }
                
                    Label {
                        id: page1Label2
                        x: 122
                        y: 409
                        width: 156
                        height: 56
                        text: qsTr("1 из 20")
                        horizontalAlignment: Text.AlignHCenter
                        font.pointSize: 20
                    }
                    states: [
                        State {
                            name: "Page1State1"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/red.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/black.png"
                            }
                        },
                        State {
                            name: "Page1State2"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/black.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/red.png"
                            }
                        },
                        State {
                            name: "Page1State0"
                        }
                    ]
                }
                
                

                так и так

                import QtQuick 2.4
                import QtQml 2.12
                
                Page1Form {
                
                    page1Button1.onClicked: //rigth button
                    {
                        state = "Page1State1"
                    }
                
                    page1ButtonMenu.onClicked:
                    {
                        loader.source = "Page0.qml"
                    }
                
                }
                
                
                import QtQuick 2.4
                import QtQuick.Controls 2.4
                
                
                Item {
                    id: element
                    width: 400
                    height: 600
                    property alias page1Button1: page1Button1
                    property alias page1Button0: page1Button0
                    property alias page1ButtonMenu: page1ButtonMenu
                   // property alias page1Label2: page1Label2
                
                    Button {
                        id: page1Button0
                        x: 66
                        y: 172
                        width: 128
                        height: 128
                
                        Image {
                            id: image
                            width: 130
                            height: 130
                            anchors.topMargin: 0
                            anchors.leftMargin: 0
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                        onClicked: page1Label2.text = "weg"
                
                
                    }
                
                    Button {
                        id: page1Button1
                        x: 251
                        y: 172
                        width: 130
                        height: 130
                        Image {
                            id: image1
                            width: 130
                            height: 130
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                    }
                
                    Button {
                        id: page1ButtonMenu
                        x: 150
                        y: 479
                        text: qsTr("МЕНЮ")
                        font.pointSize: 18
                    }
                
                    Label {
                        id: page1labe0
                        x: 57
                        y: 47
                        width: 286
                        height: 33
                        text: qsTr("Выберете красный цвет")
                        horizontalAlignment: Text.AlignHCenter
                        font.pixelSize: 22
                        font.family: "Verdana"
                        font.weight: Font.Thin
                    }
                
                    Label {
                        id: page1Label1
                        x: 122
                        y: 340
                        width: 156
                        height: 56
                        text: qsTr("Побед: 0%")
                        font.pointSize: 20
                        horizontalAlignment: Text.AlignHCenter
                    }
                
                    Label {
                        id: page1Label2
                        x: 122
                        y: 409
                        width: 156
                        height: 56
                        text: qsTr("1 из 20")
                        horizontalAlignment: Text.AlignHCenter
                        font.pointSize: 20
                    }
                    states: [
                        State {
                            name: "Page1State1"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/red.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/black.png"
                            }
                        },
                        State {
                            name: "Page1State2"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/black.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/red.png"
                            }
                        },
                        State {
                            name: "Page1State0"
                        }
                    ]
                }
                
                

                и вот так тоже(без Form.ui)

                import QtQuick 2.4
                import QtQuick.Controls 2.4
                
                
                Item {
                    id: element
                    width: 400
                    height: 600
                
                    Button {
                        id: page1Button0
                        x: 66
                        y: 172
                        width: 128
                        height: 128
                
                        Image {
                            id: image
                            width: 130
                            height: 130
                            anchors.topMargin: 0
                            anchors.leftMargin: 0
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                        onClicked: page1Label2.text = "weg"
                
                
                    }
                
                    Button {
                        id: page1Button1
                        x: 251
                        y: 172
                        width: 130
                        height: 130
                        Image {
                            id: image1
                            width: 130
                            height: 130
                            anchors.rightMargin: 0
                            anchors.bottomMargin: 0
                            anchors.fill: parent
                            source: "qrc:/images/images/close.png"
                            fillMode: Image.Stretch
                        }
                        onClicked:  state = "Page1State1"
                
                    }
                
                    Button {
                        id: page1ButtonMenu
                        x: 150
                        y: 479
                        text: qsTr("МЕНЮ")
                        font.pointSize: 18
                        onClicked: loader.source = "Page0.qml"
                
                    }
                
                    Label {
                        id: page1labe0
                        x: 57
                        y: 47
                        width: 286
                        height: 33
                        text: qsTr("Выберете красный цвет")
                        horizontalAlignment: Text.AlignHCenter
                        font.pixelSize: 22
                        font.family: "Verdana"
                        font.weight: Font.Thin
                    }
                
                    Label {
                        id: page1Label1
                        x: 122
                        y: 340
                        width: 156
                        height: 56
                        text: qsTr("Побед: 0%")
                        font.pointSize: 20
                        horizontalAlignment: Text.AlignHCenter
                    }
                
                    Label {
                        id: page1Label2
                        x: 122
                        y: 409
                        width: 156
                        height: 56
                        text: qsTr("1 из 20")
                        horizontalAlignment: Text.AlignHCenter
                        font.pointSize: 20
                    }
                    states: [
                        State {
                            name: "Page1State1"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/red.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/black.png"
                            }
                        },
                        State {
                            name: "Page1State2"
                
                            PropertyChanges {
                                target: image
                                source: "qrc:/images/images/black.png"
                            }
                
                            PropertyChanges {
                                target: image1
                                source: "qrc:/images/images/red.png"
                            }
                        },
                        State {
                            name: "Page1State0"
                        }
                    ]
                }
                
                
                  Михаиллл
                  • 4. April 2019 08:47

                  Забыл код вставить.
                  При той задаче вот так заработало:

                      property alias page1Label2: page1Label2
                  
                      Label {
                          id: page1Label2
                          x: 122
                          y: 409
                          width: 156
                          height: 56
                          text: qsTr("1 из 20")
                          horizontalAlignment: Text.AlignHCenter
                          font.pointSize: 20        
                      }
                  

                  Но при попытке сделать тоже действие из Page0.qml получаю старую ошибку.
                  Скажите пожалуйста, почему опять не видно этот лэйбел?

                    Михаиллл
                    • 4. April 2019 08:47

                    Забыл код вставить.
                    При той задаче вот так заработало:

                        property alias page1Label2: page1Label2
                    
                        Label {
                            id: page1Label2
                            x: 122
                            y: 409
                            width: 156
                            height: 56
                            text: qsTr("1 из 20")
                            horizontalAlignment: Text.AlignHCenter
                            font.pointSize: 20        
                        }
                    

                    Но при попытке сделать тоже действие из Page0.qml получаю старую ошибку.
                    Скажите пожалуйста, почему опять не видно этот лэйбел?

                      Михаиллл
                      • 4. April 2019 08:54

                      Попробовал так:

                      Page1.page1Label2.text = "111 из "
                      

                      компилируется, но при переходе на страничку всегда появляется базовое значение
                      это похоже тоже странная магическая часть QML

                        Алексей Внуков
                        • 4. April 2019 08:55
                        • (bearbeitet)

                        еще работает такой вариант page.lable.text="some text" (page - это страница где нужный лейбл, при обрщении с одной страницы на другую, но при этом они должны быть все загружены и активны(например если в одном окне показывает сразу несколько страниц))

                        п.с. скорее всего при смене страницы через лоадер, старая страница становится недоступной. поэтому ее и не видно.

                          Михаиллл
                          • 4. April 2019 09:01

                          но оно еще все обнуляет при смене через лодер. никак не пойму, пока, как с этим обнулением бороться

                            Михаиллл
                            • 4. April 2019 09:04

                            и еще беда, в form.ui.qml почему то нельзя брать информацию из класса из с++ слоя.

                              Алексей Внуков
                              • 4. April 2019 09:04

                              как вариант, можно загружать несколько страниц одним пакетом, напремер через TabView, где каждый Tab нужная страница из одной группы, и через алиасы передавть значения(тогда может отпасть необходимость в лоадере). или можно передавть нужные значения в слой С++, и при загрузке новой страницы в лоадере брать данные из этого слоя

                                Алексей Внуков
                                • 4. April 2019 09:07

                                поэтому мне проще без форм

                                  Михаиллл
                                  • 4. April 2019 09:08

                                  хорошо придумано.

                                    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