当前位置: 首页 > article >正文

QML 部件获得焦点触发的全局槽函数 onActiveFocusItemChanged

在qml的window窗口中,假如添加里许多其他部件,当这些部件改变时,会有一个全局部件焦点改变槽函数触发,就是 onActiveFocusItemChanged 

可以通过此槽函数就可以知道当前焦点在哪一个部件上,也可以做一些自动化测试等;

如下案例,在窗体中添加两个按钮,通过鼠标点击按钮或者键盘左右键触发焦点,最后onActiveFocusItemChanged 槽函数就会监听到有焦点事件了,可以通过activeFocusItem.objectName 将当前获得焦点的部件的名字打印出来,前提是部件有设置了名字。

import QtQuick 2.9
import QtQuick.Window 2.2

import QtQuick.Controls 2.2

Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")
    color: "white"


    Button {
        id: btn1
        width: 50
        height: 50
        objectName: "btn1"
        background: Rectangle {
            border.color: btn1.focus ? "red" : "black";
            color: "pink"
        }

        // 键盘右键按下
        Keys.onRightPressed: {
            btn2.focus = true
        }
    }

    Button {
        id: btn2
        x:70
        width: 50
        height: 50
        objectName: "btn2"
        background: Rectangle {
            border.color: btn2.focus ? "red" : "black";
        }

        // 键盘左键按下
        Keys.onLeftPressed: {
            btn1.focus = true
        }
    }



    // 焦点改变触发
    onActiveFocusItemChanged: {
        console.log("Active focus item changed", activeFocusItem, "object name:", activeFocusItem.objectName);
    }
}


http://www.kler.cn/a/550423.html

相关文章:

  • Android车机DIY开发之软件篇(十七) Android模拟器移植Automotive
  • 使用 AbilityKit 创建服务卡片
  • iOS 中使用 FFmpeg 的高级功能 - 滤镜(Filters)
  • Office word打开加载比较慢处理方法
  • 【PCIe 总线及设备入门学习专栏 1.1 -- PCI 设备访问方法】
  • B2B2C商城系统:如何利用大数据实现精准营销?
  • JavaScript 内置对象-字符串对象
  • SSH远程服务器免密码连接|含注意事项细节
  • 【PowerBI】使用形状地图创建地图可视化
  • 【设计模式精讲】六大设计原则 (SOLID)
  • 软件测试需要考的证书
  • 关于DeepSeek与ChatGPT等模型的原始训练数据
  • java数据结构_二叉树_5.5
  • learngit git常用指令
  • 并发编程 - 线程同步(八)之自旋锁SpinLock
  • 【ProtoBuf】文件编写及序列化
  • 事件传递和监控
  • 《Stable Diffusion绘画完全指南:从入门到精通的Prompt设计艺术》-配套代码示例
  • isp专业名词-sensor摄像头没有AEC 功能
  • 解决IDEA报错:java 找不到符号