QMLDay2:圆角按钮,关联键盘左右键,鼠标点击。状态切换控制。

news2024/9/22 21:31:02

QMLDay2

test1

作用:

圆角按钮,关联键盘左右键,鼠标点击。状态切换控制。

代码:

import QtQuick 2.15
import QtQuick.Window 2.15
import QtQuick.Controls 2.15

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

    Rectangle {
        id: btn1
        width: 200
        height: 200

        focus: true
        objectName: "btn1"
        radius: 20 // 控制圆角的半径
        //color: "purple" // 默认按钮的背景颜色
        //border.color: "black" // 默认边框颜色
        border.width: 2 // 默认边框宽度
        Text {
            anchors.centerIn: parent
            text: "左!"
            color: "green" // 文本颜色
            font.pixelSize: 16 // 字体大小
        }
        MouseArea {
            anchors.fill: parent
            onClicked: {
                console.log("Button clicked!")
                btn1.state = "pressed"
                btn2.state = "default"
            }
        }

        // 定义按钮的状态
        states: [
            State {
                name: "pressed"
                // 设置按钮选中时的样式
                PropertyChanges {
                    target: btn1
                    color: "pink" // 按钮背景颜色
                    border.color: "yellow" // 边框颜色
                }
            },
            State {
                name: "default" // 默认状态
                // 设置按钮默认状态的样式
                PropertyChanges {
                    target: btn1
                    color: "purple" // 按钮背景颜色
                    border.color: "black" // 边框颜色
                }
            }
        ]

        // 设置默认状态
        state: "default"

        // 定义按钮状态切换的过渡效果
        transitions: Transition {
            from: "*"//表示该过渡效果适用于任何状态。
            to: "default"//表示该过渡效果用于从任何状态切换到"default"状态。
            NumberAnimation { properties: "color,border.color"; duration: 200 }
            //NumberAnimation是指定动画类型为数字动画,它可以控制目标属性的数值变化。
            //properties: "color, border.color"表示这个动画将同时作用于color和border.color属性。
            //这意味着在按钮状态切换时,按钮的背景颜色和边框颜色都会通过动画进行过渡。
        }
    }

    Rectangle {
        id: btn2
        x: 300
        width: 200
        height: 200

        objectName: "btn2"
        radius: 20 // 控制圆角的半径
        //color: "purple" // 默认按钮的背景颜色
        //border.color: "black" // 默认边框颜色
        border.width: 2 // 默认边框宽度

        Text {
            anchors.centerIn: parent
            text: "右!"
            color: "green" // 文本颜色
            font.pixelSize: 16 // 字体大小
        }
        MouseArea {
            anchors.fill: parent
            onClicked: {
                console.log("Button clicked!")
                btn2.state = "pressed"
                btn1.state = "default"
            }
        }

        // 定义按钮的状态
        states: [
            State {
                name: "pressed"
                // 设置按钮选中时的样式
                PropertyChanges {
                    target: btn2
                    color: "pink" // 按钮背景颜色
                    border.color: "yellow" // 边框颜色
                }
            },
            State {
                name: "default" // 默认状态
                // 设置按钮默认状态的样式
                PropertyChanges {
                    target: btn2
                    color: "purple" // 按钮背景颜色
                    border.color: "black" // 边框颜色
                }
            }
        ]

        // 设置默认状态
        state: "default"

        // 定义按钮状态切换的过渡效果
        transitions: Transition {
            from: "*"
            to: "default"
            NumberAnimation { properties: "color,border.color"; duration: 200 }
        }
    }

    // 处理键盘事件
    Shortcut {
        sequence: "Left"
        onActivated: {
            btn1.state = "pressed"
            btn2.state = "default"
        }
    }

    Shortcut {
        sequence: "Right"
        onActivated: {
            btn2.state = "pressed"
            btn1.state = "default"
        }
    }
}

运行截图

image-20230801115531312

image-20230801115640220

        btn1.state = "default"
    }
}

}


### 运行截图

[外链图片转存中...(img-fw71flua-1690883676631)]



[外链图片转存中...(img-5WUqxaa0-1690883676632)]



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/823886.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

H.265/HEVC 速率控制

文章目录 速率控制视频编码速率控制速率控制的基本原理缓冲机制速率控制技术 H.265/HEVC 速率控制1. 目标比特分配2. 量化参数确定 速率控制 目前实际的视频编码率失真优化过程包括两部分:速率控制部分将视频序列分成编码单元,考虑编码单元的相关性通过…

C#,数值计算——t-分布(Student distribution)的计算方法与源程序

在概率论和统计学中,学生t-分布(Students t-distribution)经常应用在对呈正态分布的总体的均值进行估计。它是对两个样本均值差异进行显著性测试的学生t测定的基础。t检定改进了Z检定(en:Z-test),不论样本数…

【PyQt实现复现框CheckBox】

PyQt实现复现框CheckBox 1 安装环境2 CtrlN,新建Main Window窗口,保存为checkBox.ui文件3 CheckBox的三种状态4 实现通用复选框的选中状态设置用户权限功能 1 安装环境 1)Python环境安装PyQt5、PyQt-sip、PyQt5Designer、PyQt5-tools 2&…

【搜索】BFS中的最短路模型

算法提高课笔记 目录 单源最短路迷宫问题题意思路代码 武士风度的牛题意思路代码 抓住那头牛题意思路代码 多源最短路矩阵距离题意思路代码 双端队列BFS电路维修题意思路代码(加了注释) BFS可以解决边权为1的最短路问题,下面是相关例题 单源…

Mybatis 知识点

Mybatis 知识点 1.1 Mybatis 简介 1.1.1 什么是 Mybatis Mybatis 是一款优秀的持久层框架支持定制化 SQL、存储过程及高级映射Mybatis 几乎避免了所有的 JDBC 代码和手动设置参数以及获取结果集MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO…

PyTorch深度学习实战(8)——批归一化

PyTorch深度学习实战(8)——批归一化 0. 前言1. 批归一化原理2. 批归一化优势3. 批归一化对模型训练的影响3.1 未使用批归一化,且输入值较小3.2 使用批归一化,且输入值较小3.3 使用批归一化,且输入值较大 小结系列链接…

Redis—环境搭建

Redis—环境搭建 🔎Centos 安装 Redis5创建符号链接修改配置文件启动 Redis停止 Redis 🔎Centos 安装 Redis5 Centos8 安装 Redis5 yum install -y redisCentos7 安装 Redis5 Centos7 中 yum 源提供的 Redis 版本是 Redis3(有点老), 因此先安装 scl 源 …

算法综合篇专题二:滑动窗口

“在混沌想法中&#xff0c;最不可理喻念头。” 1、长度最小的子数组 (1) 题目解析 (2) 算法原理 class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {int n nums.size();int sum 0;int len INT_MAX;for(int left0,r…

mysql进阶-用户的创建_修改_删除

1. 使用mysql单次查询 [rootVM-4-6-centos /]# mysql -h localhost -P 3306 -p mytest -e "select * from book1"; Enter password: ------------------------------------------- | id | category_id | book_name | num | ----------------------------…

数据结构 | 基本数据结构——队列

目录 一、何谓队列 二、队列抽象数据类型 三、用Python实现队列 四、模拟&#xff1a;传土豆 五、模拟&#xff1a;打印任务 5.1 主要模拟步骤 5.2 Python实现 一、何谓队列 队列是有序集合&#xff0c;添加操作发生在“尾部”&#xff0c;移除操作则发生在“头部”。新…

【Javascript】基础知识

文章目录 01 变量的声明02 数据类型字符串型boolean类型undefined null类型symbol类型超大整数 bigint数组类型普通对象 01 变量的声明 02 数据类型 复习: 声明 ​ 声明变量关键词 ​ let ​ const ​ 变量名 >变量命名规范 ​ 英文 数字 _ $不要以数字开头 ​ 见名知意 ​…

深度学习之tensorboard可视化工具

(1)什么是tensorboard tensorboard是TensorFlow 的一个可视化工具包&#xff0c;提供机器学习实验所需的可视化和工具&#xff0c;该工具的功能如下&#xff1a; 跟踪和可视化指标&#xff0c;例如损失和精度可视化模型图&#xff08;操作和层&#xff09;查看权重、偏差或其…

【Java多线程学习4】volatile关键字及其作用

说说对于volatile关键字的理解&#xff0c;及的作用 概述 1、我们知道要想线程安全&#xff0c;就需要保证三大特性&#xff1a;原子性&#xff0c;有序性&#xff0c;可见性。 2、被volatile关键字修饰的变量&#xff0c;可以保证其可见性和有序性&#xff0c;但是volatile…

uniApp 对接安卓平板刷卡器, 读取串口数据

背景: 设备: 鸿合 电子班牌 刷卡对接 WS-B22CS, 安卓11; 需求: 将刷卡器的数据传递到自己的App中, 作为上下岗信息使用, 以完成业务; 对接方式: 1. 厂家技术首先推荐使用 接收自定义广播的方式来获取, 参考代码如下 对应到uniApp 中的实现如下 <template><view c…

python数据可视化Matplotlib

1.绘制简单的折线图 # -*- coding: utf-8 -*- import matplotlib.pyplot as pltinput_values [1, 2, 3, 4, 5] squares [1, 4, 9, 16, 25] plt.style.use(seaborn) fig, ax plt.subplots() ax.plot(input_values, squares, linewidth3) # 线条粗细# 设置图表标题并给坐标…

2023年第四届“华数杯”数学建模思路 - 复盘:光照强度计算的优化模型

文章目录 0 赛题思路1 问题要求2 假设约定3 符号约定4 建立模型5 模型求解6 实现代码 0 赛题思路 &#xff08;赛题出来以后第一时间在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 1 问题要求 现在已知一个教室长为15米&#xff0c;宽为12米&#xff0…

less的使用

less的介绍&#xff1a; less使用 1、 less使用的第一种用法&#xff0c;起变量名&#xff0c;变量名区分大小写&#xff1a; 这里我们定义一个粉色变量 我想使用直接把变量拿过来就行 2、vscode使用插件&#xff0c;直接将Css文件转换less文件&#xff1a; 3、第二种用法&…

8.泛型

目录 1 基本使用 2 多个泛型 3 泛型约束 3.1 数组 3.2 extends约束 3.3 用泛型约束泛型 4 泛型接口 5 ts中的数组用的就是泛型 6 泛型类 7 常用泛型工具类型 7.1 让所有属性变为可选属性 Partial 7.2 将所有属性都变为只读属性 Readonly 7.3 从指定类…

git-版本控制器

集中式版本控制工具&#xff08;不常用&#xff09; 版本库集中于中央服务器&#xff0c;team要联网才能工作&#xff08;下载代码&#xff09; SVN CVS 分布式版本控制工具 每个电脑上都有一个完整的版本库&#xff0c;工作时无需联网&#xff0c;可以把修改推送给其他人来…

ThreadLocal有内存泄漏问题吗

对于ThreadLocal的原理不了解或者连Java中的引用类型都不了解的可以看一下我的之前的一篇文章Java中的引用和ThreadLocal_鱼跃鹰飞的博客-CSDN博客 我这里也简单总结一下: 1. 每个Thread里都存储着一个成员变量&#xff0c;ThreadLocalMap 2. ThreadLocal本身不存储数据&…