第8篇 基础(八)设置Qt状态栏
林中静月下仙
原创Java领域优质创作者
关注
0点赞·320人阅读
导语
在程序主窗口QMainWindow中,主要包含菜单栏,工具栏,中心部件和状态栏。前面几个已经讲过了,这一篇讲解状态栏的使用。
环境是:Windows 7 + Qt 4.8.1 +Qt Creator 2.4.1
目录
一、添加动作状态提示
三、显示永久信息
正文
一、添加动作状态提示
1.首先还是打开上一篇完成的程序。对于菜单动作添加状态提示,可以很容易的在设计器中来完成。
2.下面进入设计模式,在Action编辑器中选中新建动作,然后在右面的属性编辑器中将其statusTip更改为“新建文件”。如下图所示。
3.这时运行程序,当光标移动到新建动作上时,在下面的状态栏将会出现设置的提示。如下图所示。
我们可以按照这种方式来设置其他动作的状态栏提示信息。
二、显示其他临时信息
状态信息可以被分为三类:临时信息,如一般的提示信息,上面讲到的动作提示就是临时信息;正常信息,如显示页数和行号;永久信息,如显示版本号或者日期。可以使用showMessage()函数来显示一个临时消息,它会出现在状态栏的最左边。一般用addWidget()函数添加一个QLabel到状态栏上用于显示正常信息,它会生成到状态栏的最左边,可能会被临时消息所掩盖。
1.我们到mainwindow.cpp文件的构造函数最后面添加如下一行代码:
ui->statusBar->showMessage(tr("欢迎访问Qt爱好者社区!"))
登录后复制
这样就可以在运行程序时显示指定的状态提示了。效果如下图所示。
这个提示还可以设置显示的时间。如:
ui->statusBar->showMessage(tr("欢迎访问Qt爱好者社区!"), 2000)
登录后复制
这样提示显示2000毫秒即2秒后会自动消失。
2.下面我们在状态栏添加一个标签部件用来显示一般的提示信息。因为无法在设计模式向状态栏添加部件,所以只能使用代码来实现。先在mainwindow.h文件中添加类的前置声明:
class QLabel
登录后复制
然后添加一个私有对象定义:
QLabel *statusLabel
登录后复制
下面到mainwindow.cpp文件中,先添加头文件声明:
#include <QLabel>
登录后复制
然后到构造函数中将前面添加的:
ui->statusBar->showMessage(tr("欢迎访问Qt爱好者社区!"), 2000)
登录后复制
一行代码注释掉,再添加如下代码:
statusLabel = new QLabel
statusLabel->setMinimumSize(150, 20)// 设置标签最小大小
statusLabel->setFrameShape(QFrame::WinPanel)// 设置标签形状
statusLabel->setFrameShadow(QFrame::Sunken)// 设置标签阴影
ui->statusBar->addWidget(statusLabel)
statusLabel->setText(tr("欢迎访问Qt爱好者社区!"))
登录后复制
这时运行程序,效果如下图所示。
下面就可以在需要显示状态的时候,调用statusLabel来设置文本了。
三、显示永久信息
如果要显示永久信息,要使用addPermanentWidget()函数来添加一个如QLabel一样的可以显示信息的部件,它会生成在状态栏的最右端,不会被临时消息所掩盖。
我们在构造函数中添加如下代码:
QLabel *permanent = new QLabel(this)
permanent->setFrameStyle(QFrame::Box | QFrame::Sunken)
permanent->setText(
tr("<a href=\"http://www.yafeilinux.com\">yafeilinux.com</a>"))
permanent->setTextFormat(Qt::RichText)
permanent->setOpenExternalLinks(true)
ui->statusBar->addPermanentWidget(permanent)
登录后复制
这样就在状态栏的右侧添加了一个网站的超链接,点击该链接就会自动在浏览器中打开网站。运行程序,效果如下图所示。
结语
到这里整个文本编辑器的程序就算写完了。我们这里没有写帮助菜单的功能实现,大家可以自己添加。而且程序中也有很多漏洞和不完善的地方,如果有兴趣,大家也可以自己修改。因为时间和篇幅的原因,我们这里就不再过多的讲述。如果想学习一下多文档编辑器的实现,可以参考《Qt及Qt Quick开发实战精解》一书的多文档编辑器的实例。
#ifndef WIDGET_H#define WIDGET_H
#include <QtGui/QWidget>
#include <QPushButton>
#include <QLabel>
#include <QHBoxLayout>
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = 0)
~Widget()
QPushButton *clearNO,*addNO
QLabel *label
QHBoxLayout *qhboxlayout
private slots:
void clearNOhandle()
void addNOhandle()
}
#endif // WIDGET_H
///////////widget.cpp
#include "widget.h"
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
clearNO =new QPushButton("CLEAR")
addNO =new QPushButton("ADD")
label =new QLabel("0")
qhboxlayout =new QHBoxLayout(this)
qhboxlayout->addWidget(label)
qhboxlayout->addWidget(clearNO)
qhboxlayout->addWidget(addNO)
connect(clearNO,SIGNAL(clicked()),this,SLOT(clearNOhandle()))
connect(addNO,SIGNAL(clicked()),this,SLOT(addNOhandle()))
}
void Widget::addNOhandle(){
QString nostr
int no
nostr = label->text()
no = nostr.toInt()
no++
nostr.setNum(no)
label->setText(nostr)
}
////////main函数
void Widget::clearNOhandle(){
label->setText("0")
}
Widget::~Widget()
{
}
#include <QtGui/QApplication>
#include "widget.h"
int main(int argc, char *argv[])
{
QApplication a(argc, argv)
Widget w
w.show()
return a.exec()
}
// ----- 答案肯定是可以的 -----//// 先创建原先的界面,用布局进行管理
QWidget *widgetMain = new QWidget()
// 加入一个输入框和按钮
QLineEdit *lineEdit = new QLineEdit(widgetMain)
QPushButton *btn = new QPushButton(widgetMain)
// 用水平布局将这2个控件框起,并且置于界面顶部
QHBoxLayout *horLayout = new QHBoxLayout()
horLayout->addWidget(lineEdit, 4)
horLayout->addWidget(btn, 1) // 设置布局比例为4:1
// 然后添加一个全局布局控件
QVBoxLayout *verLayout = new QVBoxLayout(widgetMain)
verLayout->addLayout(horLayout)// 加入刚才的输入组,底部添加d簧
verLayout->addStretch()
// --------- 基本界面创建完成 -------------- //
// 关联处理动态创建
int nCnt = lineEdit->text().toInt() // 输入的个数
for (int i = 0 i < nCnt i++) {
QLabel *label = new QLabel(widgetMain)
// 插入之前的布局
label->setText(QString("动态创建label %1).arg(i + 1))
verLayout->insertWidget(1 + i, label)
}
// 大功告成
// 备注,以上代码纯手工,写法或其他错误请自行修改,仅作参考
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)