М
МаркГлен05 серпня 2020 р. 10:58

QML: изменение стиля при наведении и при нажатии на кнопку

hover, containsMouse, mouseArea, onhover

Получается сделать либо одно либо другое, но не то и другое одновременно.
так работает: color: parent.pressed ? "violet" : "pink"
и так тоже: color: mouseArea.containsMouse ? "blue" : "magenta"

А вот так уже нет:

if (parent.pressed)
{
   color: "red"
}
else if (mouseArea.containsMouse)
{
   color: "blue"
}
else
{
   color: "green"
}

Пробовал и по-другому писать условия, не получается.

qml hover press

Весь работающий (по отдельности) код:

import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.12
import QtQuick.Layouts 1.12

Window {
    id: win
    visible: true
    width: 640
    height: 480
    title: qsTr("Hover and Press")

    ColumnLayout {
        anchors.fill: parent
        spacing: 25
        Item {
            Layout.fillHeight: true
        }
        Button {
            Layout.alignment: Qt.AlignCenter
            implicitWidth: 200
            implicitHeight: 100


            background: Rectangle {
                border.width:5
                border.color: parent.pressed ? "pink" : "violet"
                color: parent.pressed ? "violet" : "pink"
                radius: width/4

            Text {
                anchors.centerIn: parent
                font.pointSize: 16
                font.bold: true
                text: "PRESS"
            }
          }
        }
        Button {
            Layout.alignment: Qt.AlignCenter
            implicitWidth: 200
            implicitHeight: 100
            MouseArea {
                id: mouseArea
                anchors.fill: parent
                hoverEnabled: true
            }


            background: Rectangle {
                border.width:5
                border.color: mouseArea.containsMouse ? "magenta" : "blue"
                color: mouseArea.containsMouse ? "blue" : "magenta"
                radius: width/4

            Text {
                anchors.centerIn: parent
                font.pointSize: 16
                font.bold: true
                text: "HOVER"
            }
          }
        }
        Item {
            Layout.fillHeight: true
        }
    }
}

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

Вам це подобається? Поділіться в соціальних мережах!

8
t
  • 05 серпня 2020 р. 11:09
  • (відредаговано)
if (parent.pressed)
{
   return "red"
}
else if (mouseArea.containsMouse)
{
   return "blue"
}
else
{
   return "green"
}
    М
    • 05 серпня 2020 р. 13:06
    • (відредаговано)

    Да, с синтаксисом были проблемы, спасибо за подсказку. Правильно было бы так:

    color: if (parent.pressed)
    {
       return "red"
    }
    else if (mouseArea.containsMouse)
    {
       return "blue"
    }
    else
    {
       return "green"
    }
    

    И всё же так работает только наведение, на нажатие не рагирует. Попробовал так:

    color: if (parent.pressed)
    {
       return "red"
    }
    else if (mouseArea.containsMouse & !parent.pressed)
    {
       return "blue"
    }
    else
    {
       return "green"
    }
    

    То же самое.

    Добавил в MouseArea

    onPressed: { bacgroundRectangle.color = 'red' }
    

    Результат как с onClicked - один раз меняется цвет и больше не реагирует на события.
    Поэтому добавил onReleased - поведение оказалось не таким как предполагалось интуитивно, но меня устроит. После отжимания, кнопка приобретает указанный цвет и больше не реагирует на наведение. В моём случае это и не понадобится, а могло бы.

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

    import QtQuick 2.12
    import QtQuick.Window 2.12
    import QtQuick.Controls 2.12
    import QtQuick.Layouts 1.12
    
    Window {
        id: win
        visible: true
        width: 640
        height: 480
        title: qsTr("Hover and Press")
    
        ColumnLayout {
            anchors.fill: parent
            spacing: 25
            Item {
                Layout.fillHeight: true
            }
            Button {
                Layout.alignment: Qt.AlignCenter
                implicitWidth: 200
                implicitHeight: 100
    
    
                background: Rectangle {
                    border.width:5
                    border.color: parent.pressed ? "pink" : "violet"
                    color: parent.pressed ? "violet" : "pink"
                    radius: width/4
    
                Text {
                    anchors.centerIn: parent
                    font.pointSize: 16
                    font.bold: true
                    text: "PRESS"
                }
              }
            }
            Button {
                Layout.alignment: Qt.AlignCenter
                implicitWidth: 200
                implicitHeight: 100
                MouseArea {
                    id: mouseArea
                    anchors.fill: parent
                    hoverEnabled: true
                }
    
    
                background: Rectangle {
                    border.width:5
                    border.color: mouseArea.containsMouse ? "magenta" : "blue"
                    color: mouseArea.containsMouse ? "blue" : "magenta"
                    radius: width/4
    
                Text {
                    anchors.centerIn: parent
                    font.pointSize: 16
                    font.bold: true
                    text: "HOVER"
                }
              }
            }
    
            Button {
                Layout.alignment: Qt.AlignCenter
                implicitWidth: 200
                implicitHeight: 100
                hoverEnabled: true
    
                MouseArea {
                    id: mouseArea2
                    anchors.fill: parent
                    hoverEnabled: true
                    onPressed: { bacgroundRectangle.color = 'red' }
                    onReleased: { bacgroundRectangle.color = 'gray' }
                }
    
                background: Rectangle {
                    id: bacgroundRectangle
                    border.width:5
                    color: mouseArea2.containsMouse ? "blue" : "green"
                    radius: width/4
    
                Text {
                    anchors.centerIn: parent
                    font.pointSize: 16
                    font.bold: true
                    text: "HOVER & PUSH"
                }
              }
            }
            Item {
                Layout.fillHeight: true
            }
        }
    }
    
      М
      • 05 серпня 2020 р. 16:48
      • (відредаговано)

      Читал доки. Узнал про сигналы entered, exited в MouseArea QML Type.
      С ним можно сделать то о чём спрашивал, хотя может это и не лучший способ.
      А вот не спросил бы - не стал бы читать доков наверное, не знаю почему так.

        t
        • 05 серпня 2020 р. 17:33
        onPressed: { bacgroundRectangle.color = 'red' }
        

        Ломает биндинг, поэтому лучше не использовать.

          М
          • 06 серпня 2020 р. 01:36

          Ломает биндинг

          Как раз как бы его теперь сломать, чтобы после отжимания кнопка становилась серой и больше ни на что не реагировала.

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

          Button {
                      Layout.alignment: Qt.AlignCenter
                      implicitWidth: 200
                      implicitHeight: 100
                      hoverEnabled: true
          
                      MouseArea {
                          anchors.fill: parent
                          hoverEnabled: true
                          onPressed: { bacgroundRectangle.color = 'blue'
                          console.log("pressed?", pressed)
                          }
                          onReleased: { bacgroundRectangle.color = 'yellow'
                              console.log("released?", released)
                          }
                          onExited: { bacgroundRectangle.color = 'green'
                              console.log("exited?", exited)
                          }
                          onEntered: { bacgroundRectangle.color = 'yellow'
                              console.log("entered?", entered)
                          }
                      }
          
                      background: Rectangle {
                          id: bacgroundRectangle
                          border.width:5
                          color: "green"
                          radius: width/4
          
                      Text {
                          anchors.centerIn: parent
                          font.pointSize: 16
                          font.bold: true
                          text: "HOVER & PUSH"
                      }
                    }
                  }
          
            U
            • 06 серпня 2020 р. 04:59
            • (відредаговано)
            • Відповідь була позначена як рішення.
            Button{
                id: myButton
            
                MouseArea {
                    hoverEnabled: true
                    onReleased: myButton.enabled = false        
                }
            }
            

            Так кнопка перестанет быть активной и не будет ни на что реагировать)
            Ну там всякие anchors.fill: parent и тп - добавить по вкусу)

              М
              • 06 серпня 2020 р. 05:49

              enabled = false
              перестанет быть активной и не будет ни на что реагировать)

              Хм.. по-моему пробовал такое. Проверю ещё раз после работы.

                М
                • 06 серпня 2020 р. 15:37

                enabled = false
                перестанет быть активной и не будет ни на что реагировать)

                Хм.. по-моему пробовал такое. Проверю ещё раз после работы.

                Ура, спасибо большое! Работает.

                Всем спасибо за подсказки.

                  Коментарі

                  Only authorized users can post comments.
                  Please, Log in or Sign up
                  AD

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

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

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

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

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

                  • Результат:20бали,
                  • Рейтинг балів-10
                  Останні коментарі
                  ИМ
                  Игорь Максимов22 листопада 2024 р. 11:51
                  Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                  Evgenii Legotckoi
                  Evgenii Legotckoi31 жовтня 2024 р. 14:37
                  Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                  A
                  ALO1ZE19 жовтня 2024 р. 08:19
                  Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                  ИМ
                  Игорь Максимов05 жовтня 2024 р. 07:51
                  Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                  d
                  dblas505 липня 2024 р. 11:02
                  QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                  Тепер обговоріть на форумі
                  Evgenii Legotckoi
                  Evgenii Legotckoi24 червня 2024 р. 15:11
                  добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                  t
                  tonypeachey115 листопада 2024 р. 06:04
                  google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                  NSProject
                  NSProject04 червня 2022 р. 03:49
                  Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                  9
                  9Anonim25 жовтня 2024 р. 09:10
                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                  Слідкуйте за нами в соціальних мережах