QML 鼠标和键盘事件
创始人
2025-01-08 23:04:17
0

学习目标:Qml 鼠标和键盘事件

学习内容

1、QML 鼠标事件处理QML 直接提供 MouseArea 来捕获鼠标事件,该操作必须配合Rectangle 获取指定区域内的鼠标事件,

2、QML 键盘事件处理,并且获取对OML直接通过键盘事件 Keys 监控键盘任意按键应的消息。

项目效果

键盘事件

 

鼠标事件

项目代码

键盘事件

import QtQuick 2.12 import QtQuick.Window 2.12  Window {     visible: true     width: 640     height: 480     title: qsTr("Hello World")       Rectangle{         id:keyserctn         anchors.centerIn: parent          width: 450         height: 200         color: "green"          // 不设置焦点,获取不了键盘事件         focus: true          //捕获键盘按键事件。         Keys.onPressed: {             //按下的按键的键值 相当于枚举的值 d:68             console.log("key:"+event.key)             //按下的按键的原生扫描码。 "A" 时,event.nativeScanCode 的值通常是 30。             console.log("scancode:"+event.nativeScanCode)             //按下的按键所对应的文本字符             console.log("text:"+event.text)         }         //捕获特殊 tab键         Keys.onTabPressed: {             console.log("监控区域提示:你已经按下Tab键!")         }         //捕获特殊 空格键         Keys.onSpacePressed: {             console.log("监控区域提示:你已经按下空格键!")         }     } } 

鼠标事件 

import QtQuick 2.12 import QtQuick.Window 2.12  import QtQuick.Controls 2.0  Window {     visible: true     width: 640     height: 480     title: qsTr("Hello World")       Rectangle{         id :mouse         anchors.centerIn: parent          width: 450         height: 200         color: "red"          radius: width/2          //鼠标事件         MouseArea{             anchors.fill: parent //沾满             //接受的按钮:全部             acceptedButtons: Qt.AllButtons              // 此属性为false,鼠标进入、离开、移动不能捕获到             hoverEnabled: true              onPositionChanged: {                 console.log("监控区域提示:你当前鼠标移动坐标为:("+mouseX+","+mouseY+")");             }              onClicked: {                 if(mouse.button===Qt.LeftButton){                     console.log("监控区域提示:你已经按下鼠标左键!");                 }                 else if(mouse.button===Qt.RightButton){                     console.log("监控区域提示:你已经按下鼠标右键!");                 }                 else if(mouse.button===Qt.MidButton){                     console.log("监控区域提示:你已经按下鼠标中间键!");                 }             }             onDoubleClicked: {                  console.log("监控区域提示:你已经双击按下鼠标!");             }         }      }  } 

 

 最后附上源代码链接
对您有帮助的话,帮忙点个star

Qt demo: 学习qt过程 (gitee.com)

相关内容

热门资讯

总结辅助挂!网易棋牌辅助器(辅... 总结辅助挂!网易棋牌辅助器(辅助)一直真的有辅助软件(有挂方法)网易棋牌辅助器透视方法中分为三种模型...
经核实!九江讨赏辅助中至小程序... 经核实!九江讨赏辅助中至小程序(辅助)原来真的有辅助攻略(有挂教学)1、完成九江讨赏辅助中至小程序有...
相较于以往!青龙辅助最新下载(... 相较于以往!青龙辅助最新下载(辅助)总是真的是有辅助插件(详细教程)1、每一步都需要思考,不同水平的...
第三方插件!蜂娱辅助(辅助)切... 第三方插件!蜂娱辅助(辅助)切实确实有辅助挂(有挂讲解)1、金币登录送、破产送、升级送、活动送。详细...
近日!朋朋政和510k辅助器(... 近日!朋朋政和510k辅助器(辅助)都是真的有辅助神器(有挂透视)1、每一步都需要思考,不同水平的挑...
2026版技巧!途游游戏辅助脚... 2026版技巧!途游游戏辅助脚本(辅助)原来是有辅助软件(的确有挂)1、任何途游游戏辅助脚本透视是真...
连日来!圣盛鄂州晃晃辅助(辅助... 连日来!圣盛鄂州晃晃辅助(辅助)总是是真的有辅助软件(有挂方针)1、打开软件启动之后找到中间准星的标...
据权威媒体报道!闲来辅助软件靠... 据权威媒体报道!闲来辅助软件靠谱吗(辅助)一直是有辅助技巧(有挂功能)一、闲来辅助软件靠谱吗可以开透...
做出回应!圣盛鄂州晃晃辅助(辅... 做出回应!圣盛鄂州晃晃辅助(辅助)一直真的是有辅助器(真是有挂);该软件可以轻松地帮助玩家将圣盛鄂州...
有玩家发现!丰城呱呱辅助器(辅... 有玩家发现!丰城呱呱辅助器(辅助)竟然是有辅助工具(有挂存在)1、首先打开丰城呱呱辅助器辅助器下载最...