QT学习日记27——无边框窗口的制作

课时2 开发环境,无边框窗口拖拽和阴影_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV14t411b7EL?p=2&vd_source=0471cde1c644648fafd07b54e303c905

目录

一、设置无边框 和 鼠标可以拖动窗口

1.1 设置无边框

1.2 鼠标拖动

1.3 展示阴影

二、内部美化和逻辑

2.1 放大缩小按钮和标题

2.2 槽函数


一、设置无边框 和 鼠标可以拖动窗口

1.1 设置无边框

QT学习日记27——无边框窗口的制作_第1张图片

1.2 鼠标拖动

实现三个虚函数

QT学习日记27——无边框窗口的制作_第2张图片

QT学习日记27——无边框窗口的制作_第3张图片

算法相关

QT学习日记27——无边框窗口的制作_第4张图片

 鼠标相对于左上角的 z 是不变的

添加 QPoint 头文件

QT学习日记27——无边框窗口的制作_第5张图片

因为作用域的原因,我们把 z 定义为类的成员变量。现在就可以正常的拖动窗口了

1.3 展示阴影

包含头文件  #include

QT学习日记27——无边框窗口的制作_第6张图片

阴影的高度

QT学习日记27——无边框窗口的制作_第7张图片

阴影的颜色

shadow->setColor(Qt::black);

阴影的偏移

shadow->setOffset(0);

设置主窗口透明

QT学习日记27——无边框窗口的制作_第8张图片

二、内部美化和逻辑

2.1 放大缩小按钮和标题

添加按钮和标题

QT学习日记27——无边框窗口的制作_第9张图片

QT学习日记27——无边框窗口的制作_第10张图片

#shadowWidget
{
	background-color: rgb(255, 255, 255);
}

按钮渐变色和点击后改变样

QT学习日记27——无边框窗口的制作_第11张图片

QPushButton {
	border: 2px solid #8f8f91;
	border-radius: 6px;
	background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1, stop:0 #f6f7fa, stop:1 #dadbde);
	min-width: 80px;
}

QPushButton:pressed {
	background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1, stop:0 #dadbde, stop:1 #f6f7fa);
}

QpushButton:flat {
	border:none;
}

QpushButton:default {
	border-color: navy;
}

文字标签里面加图片

QT学习日记27——无边框窗口的制作_第12张图片

鼠标移动上去变色

QT学习日记27——无边框窗口的制作_第13张图片

QPushButton:hover {
	background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1, stop:0 #f05020, stop:1 #ff5b29);
}

2.2 槽函数

三次转到槽

QT学习日记27——无边框窗口的制作_第14张图片

解决最大化不能占满屏幕

视频里面使用的是这个方法,但是我 QT 上没有这个函数,就暂时不演示了

QT学习日记27——无边框窗口的制作_第15张图片

你可能感兴趣的:(QT,qt,开发语言)