QMainWindow添加状态栏提示

QMainWindow添加状态栏提示

直接上代码:

//其中ui.statusBar是MainWindow状态栏指针
QLabel* m_pMousePoint = nullptr;//屏幕坐标
QLabel* m_pMapPoint = nullptr;	//地理坐标
QLabel* m_pMapScale = nullptr;	//当前比例尺
m_pMousePoint = new QLabel(QString::fromLocal8Bit("屏幕坐标:(0,0)"),ui.statusBar);
m_pMousePoint->setGeometry(1,ui.statusBar->y()-2,200,ui.statusBar->height());
m_pMapPoint = new QLabel(QString::fromLocal8Bit("地理:(0,0)"),ui.statusBar);
m_pMapPoint->setGeometry(200,ui.statusBar->y()-2,200,ui.statusBar->height());
m_pMapScale = new QLabel(QString::fromLocal8Bit("比例尺:(0,0)"),ui.statusBar);
m_pMapScale->setGeometry(400,ui.statusBar->y()-2,200,ui.statusBar->height());

使用的是绝对坐标,通过stausBar自身的坐标来获取位置,并同时获取宽高

推测

QMainWindow的类中ui.statusBar是类QStatusBar,继承于QWidget,如此一来便可使用布局,使得状态栏中所有的内容都挤在右侧或者左侧,类似于以下代码:

QVBoxLayout* pLayout = new QVBoxLayout(ui.statusBar);
ui.statusBar->setLayout(pLayout);
//添加第一个label
{
    QLabel* pLabel = new QLabel(QString::fromLocal8Bit("屏幕坐标:(0,0)"),ui.statusBar);
    pLayout->addWidget(pLabel);
}
//添加第二个label
{
    QLabel* pLabel = new QLabel(QString::fromLocal8Bit("屏幕坐标:(0,0)"),ui.statusBar);
    pLayout->addWidget(pLabel);
}
//添加第三个label
{
    QLabel* pLabel = new QLabel(QString::fromLocal8Bit("屏幕坐标:(0,0)"),ui.statusBar);
    pLayout->addWidget(pLabel);
}
//添加拉伸
{
    auto pSpacer = new QSpacerItem(40, 20, QSizePolicy::Expanding, QSizePolicy::Minimum);
    pLayout->addItem(pSpacer);
}

注:上面的这一段代码是直接手写的,没有经过验证,应该没有问题。

其他

  • 关于{}的使用

    • 有的时候不想写循环,但是代码又有很多重复,每一次都重新命名变量属实没有必要,这个时候可以使用{}将上下文断开;

    • 还有一种情况就是,为了初始化一个量,可以有下面的写法:

    • QLabel* pLabel = nullptr;
      {
          //初始化pLabel
          //设定一系列的参数
      }
      

      这样写法可以让代码看着比较简洁。

  • 用代码书写ui布局

    • 参考官方文档进行书写
    • 复制uic出来的的ui_xxxx.h文件中的内容
      • 编译ui文件的时候,会自动生成一个ui_xxxx.h文件
      • 这个文件中有比较标准的布局使用代码
      • 推荐使用这种方式来掌握ui布局的代码写法
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值