QML笔记(六)之QML自定义信号的创建与使用

2023-11-06

一.前言
信号槽是Qt的核心所在,不管是对于QtWidgets还是QML都是,连接自带的信号槽很容易就就比较容易,但有时候自带的信号槽不能满足我们的业务需要,于是就需要自定义信号,在需要的时候扔出,然后处理。
自定义信号的使用场景一般都是组件和主页的通信,组件扔出信号,主页处理对应的业务逻辑,楼主该文章主要涉及自定义信号的使用,对于自定义组件不做陈述

二.自定义信号的使用
整体思路:创建信号->根据需要扔出信号->连接信号->绑定槽函数进行处理
1.新建一个myText.qml,用signal声明自定义的信号,楼主这里分别举例了无参的信号和带参数的信号

 // 自定义信号
    signal signal_1()
    signal signal_2()
    signal signal_3(var x,var y)  // 带参数的信号

2.扔出信号,信号扔出很简单,这里分别是将鼠标事件扔出了

    MouseArea{
        anchors.fill: parent
        hoverEnabled: true
        onExited: {
            parent.color="blue"

            // 信号扔出
            text_rect.signal_1()
        }
        onEntered: {
            parent.color="red"

            // 信号扔出
            text_rect.signal_2()
        }

        onClicked: {
            // 信号扔出
            text_rect.signal_3(mouse.x,mouse.y)
        }
    }

3.信号槽的连接
3.1首先是使用自定义的组件,然后再连接槽函数,这里的槽函数采用JavaScript编写,这样完成了

    MyText{
        id:my_text_1
        text: "自定义信号"
        anchors.centerIn: parent
    }

    Component.onCompleted: {
        console.log("信号槽连接初始化")
        my_text_1.signal_1.connect(onSignal1)
        my_text_1.signal_2.connect(onSignal2)
        my_text_1.signal_3.connect(onSignal3)
    }

    function onSignal1(){
        console.log("Signal1槽函数-鼠标移出范围")
    }
    function onSignal2(){
        console.log("Signal2槽函数-鼠标进入范围")
    }
    function onSignal3(x,y){
        console.log("Signal3槽函数-获取鼠标点击坐标")
        console.log("("+x+","+y+")")
    }

4.效果
在这里插入图片描述sn
三.源文件
MySig.qml

import QtQuick 2.0
import QtQuick.Window 2.0
import QtQuick.Controls 2.1

Window{
    visible: true
    width: 640
    height: 480
    title: qsTr("QML自定义信号")
    signal win_signal()

    MyText{
        id:my_text_1
        text: "自定义信号"
        anchors.centerIn: parent
    }

    Component.onCompleted: {
        console.log("信号槽连接初始化")
        my_text_1.signal_1.connect(onSignal1)
        my_text_1.signal_2.connect(onSignal2)
        my_text_1.signal_3.connect(onSignal3)
    }

    function onSignal1(){
        console.log("Signal1槽函数-鼠标移出范围")
    }
    function onSignal2(){
        console.log("Signal2槽函数-鼠标进入范围")
    }
    function onSignal3(x,y){
        console.log("Signal3槽函数-获取鼠标点击坐标")
        console.log("("+x+","+y+")")
    }

}

MyText.qml

import QtQuick 2.0

Rectangle{
    id:text_rect
    property alias text: my_text.text

    // 自定义信号
    signal signal_1()
    signal signal_2()
    signal signal_3(var x,var y)  // 带参数的信号

    color: "red"
    border.width: 5
    width: 100
    height: 50
    radius: 15

    Text {
        id: my_text
        anchors.horizontalCenter: parent.horizontalCenter
        anchors.verticalCenter: parent.verticalCenter
        text: qsTr("自定义文本")
    }

    MouseArea{
        anchors.fill: parent
        hoverEnabled: true
        onExited: {
            parent.color="blue"

            // 信号扔出
            text_rect.signal_1()
        }
        onEntered: {
            parent.color="red"

            // 信号扔出
            text_rect.signal_2()
        }

        onClicked: {
            // 信号扔出
            text_rect.signal_3(mouse.x,mouse.y)
        }
    }
}

附源文件下载(不用积分,若需要积分可以联系楼主)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

QML笔记(六)之QML自定义信号的创建与使用 的相关文章

随机推荐

  • 1.9 C++ vector

    include
  • 安卓期末课设-缘分星座匹配app,(附下载链接,源码注释详细,含运行截图和apk文件)

    安卓期末课设 缘分星座匹配app 附下载链接 源码注释详细 含运行截图和apk文件 2023年移动开发上半年期末大作业 星座匹配app 可以根据你的星座匹配最适合你的那个他 她 的星座 当然这种匹配你们别信哈 软件仅供学习意义 开发工具 A
  • 如何创建自己的网址?

    如何创建自己的网址 其实网址不是创建的 我们看到网址是需要注册购买的 正确来说应该创建网站 是要有网址才能访问你的网站 下面简单说说如何创建自己的网站和注册网址 一 注册网址 有些人喜欢在创建网站前注册网址 以免看中的网址被抢走 有些人觉得
  • 执行shell脚本的方法有哪些

    1 bash data scripts37 hello sh 2 cat data scripts37 hello sh bash 3 data scripts37 hello sh 加执行权限chmod x cd data scripts
  • 排序算法-归并排序详细讲解(MergeSort)

    归并排序 归并 指合并 合在一起 归并排序 Merge Sort 是建立在归并操作上的一种排序算法 其主要思想是分而治之 若将两个有序集合并成一个有序表 称为2 路归并 与之对应的还有多路归并 怎么分 对于排序最好的情况来讲 就是只有两个元
  • shell脚本之while、until循环以及循环控制语句

    目录 一 while循环语句 1 1 语法结构 1 格式 2 案列 1 2 while死循环 1 格式 2 案例 二 until循环 1 语法结构 补充 死循环结构 2 案例 三 循环控制语句 3 1 continue 3 2 break
  • win10计算机重新启动,win10电脑一直自动重启是怎么回事?

    我们在日常使用电脑办公的过程当中偶尔会出现一些小故障 今天小编想要给大家分享其中最常见的一个问题就是win10电脑出现一直重启的这个故障问题 电脑重启之后开机 结果又进入了重启 一直无限循环 这是怎么回事 其实遇到这种问题千万别急 今天小编
  • 邀请参与第四季度 Flutter 开发者调查

    外链图片转存失败 源站可能有防盗链机制 建议将图片保存下来直接上传 img Cdl2Tvp0 1671677470593 https devrel andfun cn devrel posts 2022 12 ETzaca png 本次调研
  • 彻底解决VScode C++调试的路径问题(配置PATH以及快捷键优化)

    彻底解决VScode C 调试的路径问题 配置PATH以及快捷键优化 前言 用VScode调试C 的难题可谓是人尽皆知 引得各路神仙大佬来解决 目前的主流方法有改变运行程序的路径 参考这篇文章 还有改变本地的Unicode编码设置的 也非常
  • [36]javascript入门

    入门程序
  • 【系统篇 / 安装】❀ 01. 安装镜像 ISO 文件下载 ❀ Windows Server 2016

    简介 2016年10月13日 微软正式发布Windows Server 2016和System Center 2016 全球可用 用户可以到MSDN VLSC 批量授权服务中心 获取下载 服务器2016走的路线和以前一样 新的Windows
  • 帆软认证报表工程师FCRA试题

    Part 1 判断题 总分 48分 第1题 判断题 智能运维 负载管理中 实时负载通过使用图表直观的展示当前系统的最多最近半小时内存利用率和CPU利用率 满分 2分 正确答案 A 第2题 判断题 远程设计连接时 本地设计器版本和服务器工程的
  • 全国程序员高考卷曝光,你能答对几题?

    普通高等学校招生全国统一考试 程序员卷 1 本试卷分为单选题 简答题 编程题三种类型 选择题每题5分 简答题每题10分 编程题每题20分 2 考试时间为30分钟 3 全部答案请填写在本文评论区 4 考试结束后 请将本试卷分享到CSDN AP
  • java 模拟用户注册

    模拟用户注册 用户输入用户名 密码 确认密码 生日 格式为yyyy MM dd 手机号 长度为11位 并且以13 15 17 18开头的手机号码为正确 之后 判断信息正确后 验证用户是否重复 重复则给出相应提示 不重复则注册成功 此案例使用
  • web安全攻防渗透测试实训笔记

    1 Nmap的基本 Nmap ip 6 ip Nmap A 开启操作系统识别和版本识别功能 T 0 6档 设置扫描的速度 一般设置T4 过快容易被发现 v 显示信息的级别 vv显示更详细的信息 192 168 1 1 24 扫描C段 192
  • Class 03 - R语言的 Vectors(向量) 与 lists(列表)

    Class 03 R语言的 Vector与 列表 list R语言语法 脚本文件的创建 保存 和修改名称 第一个函数 使用帮助功能查看函数详细说明 语法问题 变量与赋值 定义变量名称格式 调用变量 R中的数据结构 Vectors 向量 创建
  • STM32移植FreeRTOS的Tips

    转自 http bbs armfly com read php tid 7140 1 在FreeRTOS的demo文件夹中拷贝对应的FreeRTOSConfig h文件后 需要加入一行 define configUSE MUTEXES 1
  • Http协议和Https协议的区别

    Http协议我们就不多说了 这篇主要就是简单的提提Https协议 Https协议是基于Http协议开发的 它是一个安全的通信通道 用于客户端和服务器端进行信息的交换 它主要使用了安全套接字层 SSL 来来进行信息的交换的 简单的说它就是Ht
  • 【设计模式】用Java实现装饰模式

    一 装饰模式介绍与使用场景 装饰模式 Decorator Pattern 是一种结构型设计模式 它允许在不改变现有对象结构的情况下 动态地将责任附加到对象上 装饰模式通过将对象包装在装饰器对象中 形成一条装饰链 每个装饰器对象都可以在被装饰
  • QML笔记(六)之QML自定义信号的创建与使用

    一 前言 信号槽是Qt的核心所在 不管是对于QtWidgets还是QML都是 连接自带的信号槽很容易就就比较容易 但有时候自带的信号槽不能满足我们的业务需要 于是就需要自定义信号 在需要的时候扔出 然后处理 自定义信号的使用场景一般都是组件