Михаиллл
Михаиллл29 марта 2019 г. 9:31

Как в QML сделать переход между состояниями

состояние, QML

Добрый день.

На одной из страниц я сделал 3 состояния

Как сделать переключение из 1 состояния во 2 или 3 состояние и обратно при нажатии кнопки?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

9
Evgenii Legotckoi
  • 29 марта 2019 г. 9:42

Добрый день.

Без кода тут даже подсказывать нечего.

    Михаиллл
    • 29 марта 2019 г. 10:40
    import QtQuick 2.4
    import QtQuick.Controls 2.2
    
    Item {
        id: element
        width: 400
        height: 600
        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: 358
            width: 156
            height: 56
            text: qsTr("Побед: 0%")
            font.pointSize: 20
            horizontalAlignment: Text.AlignHCenter
        }
        states: [
            State {
                name: "State1"
    
                PropertyChanges {
                    target: image
                    source: "images/red.png"
                }
    
                PropertyChanges {
                    target: image1
                    source: "images//black.png"
                }
            },
            State {
                name: "State2"
    
                PropertyChanges {
                    target: image
                    source: "images//black.png"
                }
    
                PropertyChanges {
                    target: image1
                    source: "images//red.png"
                }
            }
        ]
    }
    
    
      Михаиллл
      • 29 марта 2019 г. 10:53

      и отсюда еще один вопрос: фактически 3 состояния, а в коде только 2. почему так? как с этим работать?

        Михаиллл
        • 31 марта 2019 г. 7:44

        как я понял нужно сделать третий states и вызвавть так states:имя состояния

          Михаиллл
          • 1 апреля 2019 г. 4:13

          Хотя почему то не работает.
          В файле main.qml прописал

              Loader
                        {
                            id: loader
                            anchors.fill: parent
                            source: "Page1.qml"
                            state: "Page1State1"
                        }
          

          но почему то состояние не меняется. Скажите пожалуйста почему так и как исправть.

            Михаиллл
            • 1 апреля 2019 г. 4:33
            • (ред.)

            а если я в описании страницы Page1 прописываю state: "Page1State2", то почему то не загружаются картинки

              Михаиллл
              • 1 апреля 2019 г. 4:39

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

                Михаиллл
                • 1 апреля 2019 г. 4:59

                Также попробовал прикрепить переход к сигналу кнопки, но переход не работает

                    page1Button0.onClicked: {  //left button
                        state: "Page1State0"
                    }
                
                  Михаиллл
                  • 3 апреля 2019 г. 2:30
                  • Ответ был помечен как решение.

                  Вот так заработало

                      page1Button0.onClicked: {  //left button
                          state = "Page1State2"
                      }
                  

                    Комментарии

                    Только авторизованные пользователи могут публиковать комментарии.
                    Пожалуйста, авторизуйтесь или зарегистрируйтесь
                    AD

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:50баллов,
                    • Очки рейтинга-4
                    m
                    • molni99
                    • 26 октября 2024 г. 8:37

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:80баллов,
                    • Очки рейтинга4
                    m
                    • molni99
                    • 26 октября 2024 г. 8:29

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:20баллов,
                    • Очки рейтинга-10
                    Последние комментарии
                    i
                    innorwall15 ноября 2024 г. 13:44
                    Qt/C++ - Урок 039. Как закрасить строку в QSqlTableModel по значению в столбце Many OPKs would advise users to start using the test strips around day 9 of your cycle, considering day 1 to be the first day of full menstrual flow buy priligy australia
                    i
                    innorwall15 ноября 2024 г. 10:27
                    Релиз утилиты развертывания С++/Qt и QML приложений CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
                    i
                    innorwall15 ноября 2024 г. 5:26
                    Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                    i
                    innorwall15 ноября 2024 г. 3:03
                    Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                    Сейчас обсуждают на форуме
                    t
                    tonypeachey115 ноября 2024 г. 14:04
                    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                    i
                    innorwall15 ноября 2024 г. 13:50
                    добавить qlineseries в функции priligy for sale Gently flush using an ear syringe
                    i
                    innorwall11 ноября 2024 г. 18:55
                    Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                    9
                    9Anonim25 октября 2024 г. 16:10
                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                    Следите за нами в социальных сетях