
Эдуард НеткачёвНаурыз 25, 2022, 12:29 Т.Ж.
Выделение нескольких объектов
QML, выделение нескольких элементов мышкой
Приветствую всех.
Не могу разобраться как сделать выделение нескольких элементов с помощью удержания клавиши мыши. Уже разные способы пробовал, но каждый раз какой-то затык.
Вот кусок основной программы main.qml:
import QtQuick 2.12 import QtQuick.Window 2.12 import QtQuick.Controls 2.5 ApplicationWindow { visible: true title: qsTr("Selection and Scaling") width: Screen.desktopAvailableWidth*50/100 height: Screen.desktopAvailableHeight*80/100 color: "whitesmoke" property double my_scale: 1.0 Flickable { id: _scrollSetup anchors.fill: parent boundsMovement: Flickable.StopAtBounds // если контент больше видимой области, то при перемещении контента он останавливается на границе контента с видимой областью contentWidth: _сolumn.width*my_scale >parent.width ? (_сolumn.width*my_scale):parent.width contentHeight: _сolumn.height*my_scale >parent.height ? (_сolumn.height*my_scale):parent.height MouseArea { id: _mouseFlickable anchors.fill: parent property point clickPos: "0,0" onWheel: if (wheel.angleDelta.y>0) { my_scale*=1.05; } else { my_scale*=0.95; } // реакция на скролл onClicked: console.log("_mouseFlickable.onClicked"); onPressed: { console.log("_mouseFlickable.onPressed"); clickPos = Qt.point(mouse.x,mouse.y) _rect_select.x=clickPos.x; _rect_select.y=clickPos.y; _rect_select.width=0; _rect_select.height=0; _rect_select.visible=true; } onReleased: { console.log("_mouseFlickable.onReleased"); _rect_select.visible=false; } onEntered: console.log("_mouseFlickable.onEntered"); onExited: console.log("_mouseFlickable.onExited"); onPositionChanged: { _rect_select.x=Math.min(mouse.x,clickPos.x) _rect_select.y=Math.min(mouse.y,clickPos.y) _rect_select.width=Math.abs(clickPos.x-mouse.x) _rect_select.height=Math.abs(clickPos.y-mouse.y) } Column { id: _сolumn anchors.verticalCenter: parent.verticalCenter anchors.horizontalCenter: parent.horizontalCenter scale: my_scale Row { id: _rowUpper MyElement { id: element_1 number: 1 height: 160 width: 160 } MyElement { id: element_2 number: 2 height: 160 width: 160 } MyElement { id: element_3 number: 3 height: 160 width: 160 } MyElement { id: element_4 number: 4 height: 160 width: 160 } } Rectangle { anchors.horizontalCenter: parent.horizontalCenter height: 4 color: "lightsteelblue" width: parent.width } Row { id: _rowLower MyElement { id: element_5 number: 5 height: 160 width: 160 } MyElement { id: element_6 number: 6 height: 160 width: 160 } MyElement { id: element_7 number: 7 height: 160 width: 160 } MyElement { id: element_8 number: 8 height: 160 width: 160 } } } } } Rectangle { id: _rect_select visible: false color: "blue" opacity : 0.3 } }
Вот код элемента MyElement.qml:
import QtQuick 2.0 Item { property int number: 0 property bool select: false MouseArea { id: _mouseArea anchors.fill: parent hoverEnabled: true // это для работы функции containsMouse (наведение курсора мыши на область) propagateComposedEvents: true onClicked: { console.log("_mouse_" + number + ".onClicked"); mouse.accepted = false; } onPressed: { console.log("_mouse_" + number + ".onPressed"); mouse.accepted = false; } onReleased:{ console.log("_mouse_" + number + ".onReleased"); mouse.accepted = false; } onEntered: { console.log("_mouse_" + number + ".onEntered"); } onExited: { console.log("_mouse_" + number + ".onExited"); } Rectangle { id: _rect anchors.fill: parent color: "green" scale: select ? 1.0 : _mouseArea.containsMouse ? 0.95 : 0.90 } } }
Может есть мысли как это сделать.

Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!
Пікірлер
Ua
- Unknown akadamn
- Қаң. 24, 2025, 5:14 Т.Қ.
Qt - Тест 001. Сигналы и слоты
- Нәтиже:84ұпай,
- Бағалау ұпайлары4
Ua
- Unknown akadamn
- Қаң. 24, 2025, 4:22 Т.Қ.
Qt - Тест 001. Сигналы и слоты
- Нәтиже:42ұпай,
- Бағалау ұпайлары-8
Соңғы пікірлер
ИМ
Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь МаксимовҚар. 22, 2024, 9:51 Т.Қ.

Evgenii LegotckoiҚаз. 31, 2024, 11:37 Т.Қ.
Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь МаксимовҚаз. 5, 2024, 4:51 Т.Қ.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Енді форумда талқылаңыз
f
Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
firstlunoxodАқп. 15, 2025, 1:46 Т.Қ.

ДмитрийАқп. 3, 2025, 4:24 Т.Қ.
не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Как вариант, считать пересечение объектов с прямоугольником выделения,
примерный код набрасал: