Qml学习——鼠标事件处理MouseArea
创始人
2024-05-24 17:05:56
0

最近在学习Qml,但对Qml的各种用法都不太熟悉,总是会搞忘,所以写几篇文章对学习过程中的遇到的东西做一个记录。
学习参考视频:https://www.bilibili.com/video/BV1Ay4y1W7xd?p=1&vd_source=0b527ff208c63f0b1150450fd7023fd8
其他文章:
Qml学习——动态加载控件
Qml学习——控件状态
Qml学习——使用JavaScript
Qml学习——动画
Qml学习——鼠标事件处理MouseArea
Qml学习——布局
Qml学习——基本控件

目录

  • 1 MouseArea
    • 1.1 拖动控件
    • 1.2 鼠标事件过滤问题


1 MouseArea

MouseArea是一个处理鼠标事件的项目,它和可见项目是结合使用的。
如以下例程。

import QtQuick 2.12
import QtQuick.Window 2.12Window {visible: true; width: 200; height: 120Rectangle {width: 30; height: 30; color: 'red'MouseArea {anchors.fill: parentonClicked: console.log('red rect')}}Rectangle {width: 30; height: 30; color: 'yellow'anchors.right: parent.rightMouseArea {anchors.fill: parentonClicked: console.log('yellow rect')}}
}

请添加图片描述
可以捕捉并处理范围内的鼠标事件。

1.1 拖动控件

import QtQuick 2.12
import QtQuick.Window 2.12Window {visible: true; width: 200; height: 120Text {text: 'text'MouseArea {anchors.fill: parentdrag.target: parent}}
}

请添加图片描述

1.2 鼠标事件过滤问题

import QtQuick 2.12
import QtQuick.Window 2.12Window {visible: true; width: 200; height: 120Rectangle {anchors.fill: parentMouseArea {anchors.fill: parentonClicked: console.log('rectangle')}Text {anchors.centerIn: parenttext: "text"MouseArea {anchors.fill: parentonClicked: console.log('text')}}}
}

请添加图片描述
点击Text时,事件只被触发了一次,原因是Text处理事件时,默认把事件过滤掉了,导致Rectangle无法接收事件,想要让事件不被过滤,可以把代码改成如下所示。

import QtQuick 2.12
import QtQuick.Window 2.12Window {visible: true; width: 200; height: 120Rectangle {anchors.fill: parentMouseArea {anchors.fill: parentonClicked: console.log('rectangle')}Text {anchors.centerIn: parenttext: "text"MouseArea {anchors.fill: parentpropagateComposedEvents: trueonClicked: {console.log('text')mouse.accepted = false;}}}}
}

请添加图片描述

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...