博客
关于我
Qt开发之路——获取窗口位置和大小
阅读量:683 次
发布时间:2019-03-17

本文共 1031 字,大约阅读时间需要 3 分钟。

在项目开发过程中,我们遇到了一个需要解决的接口定位问题。界面采用无标题窗口设计,主界面之外还有多个子窗口。我们的目标是确保每次子窗口弹出时始终出现在主窗口的正中央,尽管主窗口可能被移动到屏幕边缘。此任务需要准确地获取主窗口在屏幕上的绝对坐标,并将其应用到子窗口的布置中。

解决方法

最初,我们尝试在子窗口的构造函数中使用与主窗口相关的坐标值进行设置。具体来说,我们预期使用这样的代码:

this->setGeometry(main.x() + 100, main.y() + 50, 100, 345);

但是,当运行此代码时,没有任何反应出现。经过调试,我们发现主窗口的坐标值始终为(0, 0),这表明我们在子窗口构造时访问主窗口的位置时,实际上可能已经在访问了一个尚未显示的主窗口。这就是为什么主窗口的坐标是(0, 0)。

通过查阅相关资料,我们了解到问题的根源在于主窗口在子窗口构造时尚未显示出来。因此,直接从子窗口访问主窗口的坐标无法获取其正确的屏幕位置。

解决思路

为了解决这个问题,我们采取了以下步骤:

  • 获取主窗口的实际坐标:在子窗口弹出时,由主窗口的pos()方法获取其当前位置坐标,并存储在一个全局变量中。

  • 储存主窗口坐标:使用全局变量保存主窗口的绝对坐标,以便后续处理。

  • 应用绝对坐标设置子窗口位置:在子窗口的构造函数中,使用全局变量保存的主窗口坐标,加上偏移量,调用setGeometry方法设定子窗口的绝对位置。

  • 具体实现步骤

  • 点击弹出子窗口的槽函数

    void主窗口的方法 clicked():{    全局变量p = this->pos(); // 获取主窗口的绝对坐标}
  • 在子窗口的构造函数中设置位置

    SubWindow::SubWindow(){    // 设置子窗口的绝对位置    this->setGeometry(p.x() + 100, p.y() + 50, 100, 345);}
  • 注意事项

    • 提前准备全局变量:在定义全局变量QPoint p;时,确保它在两个窗口之间共享数据。

    • 绝对坐标设置setGeometry方法接受绝对坐标值,以便窗口能够正确显示在屏幕上。相对于窗口的自身位置,绝对坐标用于定位窗口的左上角的位置。

    • 处理窗口移动问题:主窗口可能在其显示过程中发生位置变化,因此使用pos()方法获取其最新坐标至关重要。

    通过遵循上述方法,我们成功实现了子窗口在主窗口中央显示的功能,即使主窗口位于屏幕边缘。

    转载地址:http://bmzhz.baihongyu.com/

    你可能感兴趣的文章
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>