无标题栏的Qt子窗体在父窗体中停靠时,如何做到严丝合缝

目录

1. 问题的提出

2. 一般实现

3. 加强版


1. 问题的提出

       由于业务的要求,需要从父窗体弹出一个子窗体,该子窗体无标题栏,且该子窗体要停靠到父窗体右下角。这个看似很容易的问题,细研起来其实不容易!

2. 一般实现

        通常用如下代码为窗体设置无标题栏:

setWindowFlags(Qt::FramelessWindowHint);

下面代码,在CUavGuarMainWnd窗体创建了子窗体m_pFunOperPanel,

#include "uavguarmainwnd.h"
#include "ui_uavguarmainwnd.h"
#include "funoperpanel.h"
CUavGuarMainWnd::CUavGuarMainWnd(QWidget *parent): QWidget(parent), ui(new Ui::CUavGuarMainWnd)
{m_pFunOperPanel = new CFunOperPanel(this);
}

为了简约,在此不列出.h文件。其中m_pFunOperPanel为CFunOperPanel类对象的指针,其为CUavGuarMainWnd的成员变量。为了将m_pFunOperPanel停靠到CUavGuarMainWnd窗体的右下角,一般会写出如下代码:

void CUavGuarMainWnd::resizeEvent(QResizeEvent *event)
{Q_UNUSED(event);auto nWidth = m_pFunOperPanel->width();auto nHeight = m_pFunOperPanel->height();m_pFunOperPanel->move(width() - nWidth, height() - nHeight);}

上面的代码很简单,就是响应父窗体的resizeEvent事件,从而将子窗体m_pFunOperPanel移动到父窗体的右下角,效果如下:

从上图可以看到,子窗体在停靠时,子窗体底边没有完全挨着父窗体的底边,还存在不小的间隙呢!!!如何让子窗体的底边完全挨着父窗体的底边,做到严丝合缝?

3. 加强版

      造成第2节提到的问题的原因是:开发人员以为窗体去掉了标题栏,标题栏就不占据平面区域了。这肯定是错误的,在解决这个问题之前,需要明确如下3点:

  • 窗体虽然去掉了标题栏,但标题栏依然占据宽度和高度,即依然占据平面区域,故要减去标题栏高度,而标题栏的高度是通过QStyle::PM_TitleBarHeight 枚举常量表示的。
  • 如果窗体去掉了标题栏,则边框也去掉了,故也要减去边框厚(高)度。标题栏和边框是两种不同的东西,不要认为标题栏包含了边框。QStyle::PM_DefaultFrameWidth枚举常量就是表示边框厚(高)度)。
  • 子窗体高度即本例的如下代码:
auto nHeight = m_pFunOperPanel->height();

返回的窗体高度值包含了标题栏和边框厚(高)度,由于Qt窗体默认的坐标系是Y轴向下,故去掉标题栏和边框厚(高)度,反应到程序上是加上这两个值。按此分析,更改2节代码,如下:

void CUavGuarMainWnd::resizeEvent(QResizeEvent *event)
{Q_UNUSED(event);auto nWidth = m_pFunOperPanel->width();auto nHeight = m_pFunOperPanel->height();auto yPos = height() - nHeight + QStyle::PM_TitleBarHeight + QStyle::PM_DefaultFrameWidth;m_pFunOperPanel->move(width() - nWidth, yPos);}

注意,在cpp文件的顶部需要加入如下头文件:

#include<QStyle>

效果如下:

可以看到:子窗体底边完全挨着父窗体的底边,严丝合缝了。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VScode+python开发,多个解释器切换问题

内容&#xff1a;主要VScode使用多个解释器 环境准备 VScode编辑器&#xff0c;两个版本python解释器 python3.7.2 python3.11.6 问题&#xff1a; 目前我们的电脑安装了python3.7.2、python3.11.6两个解释器&#xff0c;在vscode编辑器中&#xff0c;无法切换解释器使用如…

​软考-高级-系统架构设计师教程(清华第2版)【第6章 数据库设计基础知识(234~262)-思维导图】​

软考-高级-系统架构设计师教程&#xff08;清华第2版&#xff09;【第6章 数据库设计基础知识&#xff08;234~262&#xff09;-思维导图】 课本里章节里所有蓝色字体的思维导图

简单实现,在nodejs中简单使用kafka

什么是 Kafka Kafka 是由 Linkedin 公司开发的&#xff0c;它是一个分布式的&#xff0c;支持多分区、多副本&#xff0c;基于 Zookeeper 的分布式消息流平台&#xff0c;它同时也是一款开源的基于发布订阅模式的消息引擎系统。 Kafka 的基本术语 消息&#xff1a;Kafka 中的…

Django 的国际化与本地化详解

概要 随着全球化的发展&#xff0c;为 Web 应用提供多语言支持变得日益重要。Django 作为一个功能强大的 Web 框架&#xff0c;提供了一套完整的国际化&#xff08;i18n&#xff09;和本地化&#xff08;l10n&#xff09;工具&#xff0c;使得开发多语言应用变得简单。本文将详…

【软考篇】中级软件设计师 第一部分

中级软件设计师 第一部分 一. 计算机硬件1.1 运算器1.2 控制器 二. 数据的进制2.1 数的表示2.2 数的编码方式2.2.1 数据运算用补码运算 2.3 码制的取值范围2.3.1 例题一 三. 浮点的表示3.1 浮点数运算 四. 运算符五. 校验码5.1 海明校验码 六. 计算机指令6.1 计算机体系结构分类…

Android Matrix的使用详解(通过矩阵获取到图片缩放比例和角度)

网上查了好久相关的资料&#xff0c;都没有明确的答案。最终通过多次测试结果&#xff0c;结合安卓定义的矩阵含义&#xff0c;推算出来矩阵的数学含义以及相关的计算公式 1.获取Matrix矩阵&#xff1a; Matrix matrix new Matrix(); float[] matrixValues new float[9]; …

VSCode 好用的插件分享

文章目录 Introlistcode runner 【在文本编辑器中编辑好各类语言的源代码&#xff0c;然后一键运行】gitlens - 【git提交信息即时查看&#xff0c;类似IDEA中的 show annotation】还有更多&#xff0c;会日常补充。 Intro 大四毕业前&#xff0c;我只有一台dell latitude 455…

自定义Graph Component:1.2-其它Tokenizer具体实现

本文主要介绍了Rasa中相关Tokenizer的具体实现&#xff0c;包括默认Tokenizer和第三方Tokenizer。前者包括JiebaTokenizer、MitieTokenizer、SpacyTokenizer和WhitespaceTokenizer&#xff0c;后者包括BertTokenizer和AnotherWhitespaceTokenizer。 一.JiebaTokenizer   Ji…

人工智能基础_机器学习027_L2正则化_岭回归_非稀疏性_原理解读_公式推导---人工智能工作笔记0067

然后我们再来看一下岭回归,也就是第二范数对吧, 他的公式,平方以后,加和然后开平方.L2的公式是 可以看到L2公式,也是有个阿尔法,惩罚项对吧. 可以看到因为L2带有平方,所以他的图形是个圆形 我们可以把L2范数,进行画出来看看 这里我们先看L2的公式,这里我们让 这个公式写成1 …

Leetcode—70.爬楼梯【简单】

2023每日刷题&#xff08;二十七&#xff09; Leetcode—70.爬楼梯 动态规划思想 动态规划算法的本质是使用空间换时间&#xff0c;通过计算和记录状态来得到最优解。 在分析动态规划类题目时&#xff0c;我们可以通过3个问题对题目进行基本的拆解。 1.问题是否分阶段&…

基于rosbridge 与业务系统长链接网关架构设计

技术背景&#xff1a; 业务系统&#xff1a;管理机器人&#xff0c;机器人任务执行等等 机器人使用是ros1 &#xff0c;业务系统与机器人交互使用rosbridge, rosbridge 就是websocket 链接&#xff0c;所以就有了如下的一些架构思想 架构图 客户端 客户端主要分为app端、pc端…

数据结构第四课 -----线性表之栈

作者前言 &#x1f382; ✨✨✨✨✨✨&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f382; ​&#x1f382; 作者介绍&#xff1a; &#x1f382;&#x1f382; &#x1f382; &#x1f389;&#x1f389;&#x1f389…