Arrow29 серпня 2018 р. 09:55
Анимация элементов в QML
Добрый день!
Пытаюсь сделать анимацию прямоугольника (служит стилизированой кнопкой) при нажатии на него мышкой.
Все отображается корректно, клик по MouseArea отрабатывает, только анимации не происходит.
Сделал по примеру из документации.
Вот код файла MenuButton.qml:
import QtQuick 2.10 Item { property string itemText: "Text" property int fontSize: 18 property int itemHeight: 40 property int itemWidth: 100 height: itemHeight width: itemWidth Rectangle { id: rect anchors.fill: parent color: "#0b1160" gradient: Gradient { GradientStop { position: 0.47 color: "#0b1160" } GradientStop { position: 1.00 color: "#ffffff" } } border.color: "#1313af" border.width: 1 Text { anchors.centerIn: rect text: itemText font.pixelSize: fontSize color: "white" } states: State { name: "clicked" when: mouseArea.pressed PropertyChanges { target: rect; x: 50; y: 50 } } transitions: Transition { NumberAnimation { properties: "x,y"; easing.type: Easing.InOutQuad } } MouseArea { id: mouseArea anchors.fill: rect onClicked: console.log(itemText) } } }
Код main.qml:
import QtQuick 2.10 import QtQuick.Window 2.10 Window { id: root visible: true width: Screen.width-500 height: Screen.height-300 title: qsTr("Test") Image { source: "qrc:/pict/background.jpg" anchors.fill: parent } Row { x: 0 y: 0 width: root.width spacing: 2 MenuButton { id: optimizeBtn itemText: qsTr("Меню 1") itemWidth: parent.width/5 - parent.spacing } MenuButton { id: quickBtn itemText: qsTr("Меню 2") itemWidth: parent.width/5 - parent.spacing } MenuButton { id: protectionBtn itemText: qsTr("Меню 3") itemWidth: parent.width/5 - parent.spacing } MenuButton { id: toollBtn itemText: qsTr("Меню 4") itemWidth: parent.width/5 - parent.spacing } MenuButton { id: actionsBtn itemText: qsTr("Меню 5") itemWidth: parent.width/5 - parent.spacing } } }
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 12 листопада 2024 р. 02:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 12:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 12:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 23:51
Evgenii Legotckoi01 листопада 2024 р. 01:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 18:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi25 червня 2024 р. 02:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 18:04
NSProject04 червня 2022 р. 14:49
IscanderChe01 листопада 2024 р. 02:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день!
Там за иконку таскбара отвечает какой-то из флагов. Когда вы отключаете обрамление, вы перезаписываете все флаги которые там существуют, оставляя только флаг отключения обрамления. Видимо под линуксом это работает иначе, чем под виндовс. Нужно либо найти этот флаг, почитать документацию внимательно, либо сохранить все предыдущие флаги и добавить в них флаг отключения обрамления. Мне было лень читать документацию, поэтому я пошёл вторым путём :D