文档库 最新最全的文档下载
当前位置:文档库 › Qt总结第五课

Qt总结第五课

Qt总结第五课
Qt总结第五课

2015.3.16星期一

遇到的问题

1.问题

1.1按钮什么时候可以触发切换事件

1.2

2.解决的办法

2.1当按钮勾选上checkbox时就可以。

void layWidget::on_pushButton_toggled(bool checked) {

ui->textEdit->setVisible(checked);

qDebug()<

}

2.2

新的知识和方法

1.Qt标准对话框之QmessageBox

这次来说一下QMessageBox以及类似的几种对话框。其实,我们已经用过QMessageBox了,就在之前的几个程序中。不过,当时是大略的说了一下,现在专门来说说这几种对话框。

先来看一下最熟悉的QMessageBox::information。我们在以前的代码中这样使用过:

QMessageBox::information(NULL, "Title", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

下面是一个简单的例子:

现在我们从API中看看它的函数签名:

static StandardButton QMessageBox::information ( QWidget *

parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton );

首先,它是static的,所以我们能够使用类名直接访问到(怎么看都像废话…);然后看它那一堆参数,第一个参数parent,说明它的父组件;第二个参数title,也就是对话框的标题;第三个参数text,是对话框显示的内容;第四个参数buttons,声明对话框放置的按钮,默认是只放置一个OK按钮,这个参

数可以使用或运算,例如我们希望有一个Yes和一个No的按钮,可以使用QMessageBox::Yes | QMessageBox::No,所有的按钮类型可以在QMessageBox声明的StandarButton枚举中找到;第五个参数defaultButton就是默认选中的按钮,默认值是NoButton,也就是哪个按钮都不选中。这么多参数,豆子也是记不住的啊!所以,我们在用QtCreator写的时候,可以在输入QMessageBox::information之后输入(,稍等一下,QtCreator就会帮我们把函数签名显示在右上方了,还是挺方便的一个功能!

Qt提供了五个类似的接口,用于显示类似的窗口。具体代码这里就不做介绍,只是来看一下样子吧!

QMessageBox::critical(NULL, "critical", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

QMessageBox::warning(NULL, "warning", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

QMessageBox::question(NULL, "question", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes)

QMessageBox::about(NULL, "About", "About this application");

请注意,最后一个about()函数是没有后两个关于button设置的按钮的!QMessageBox对话框的文本信息时可以支持HTML标签的。例如:

QMessageBox::about(NULL, "About", "About this

color='red'>application");

运行效果如下:

如果我们想自定义图片的话,也是很简单的。这时候就不能使用这几个

static的函数了,而是要我们自己定义一个QMessagebox来使用

QMessageBox message(QMessageBox::NoIcon, "Title", "Content with icon."); message.setIconPixmap(QPixmap("icon.png"));

message.exec();

这里我们使用的是exec()函数,而不是show(),因为这是一个模态对话框,需要有它自己的事件循环,否则的话,我们的对话框会一闪而过哦。需要注意的是,同其他的程序类似,我们在程序中定义的相对路径都是要相对于运行时的.exe文件的地址的。比如我们写"icon.png",意思是是在.exe的当前目录下寻找一个"icon.png"的文件。这个程序的运行效果如下:

还有一点要注意,我们使用的是png格式的图片。因为Qt内置的处理图片格式是png,所以这不会引起很大的麻烦,如果你要使用jpeg格式的图片的话,Qt是以插件的形式支持的。在开发时没有什么问题,不过如果要部署的话,需要注意这一点。

最后再来说一下怎么处理对话框的交互。我们使用QMessageBox类的时候有两种方式,一是使用static函数,另外是使用构造函数。

首先来说一下static函数的方式。注意,static函数都是要返回一个StandardButton,我们就可以通过判断这个返回值来对用户的操作做出相应

QMessageBox::StandardButton rb = QMessageBox::question(NULL, "Show Qt", "Do you want to show Qt dialog?", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

if(rb == QMessageBox::Yes)

{

QMessageBox::aboutQt(NULL, "About Qt");

}

如果要使用构造函数的方式,那么我们就要自己运行判断一下啦:

QMessageBox message(QMessageBox::NoIcon, "Show Qt", "Do you want to show Qt dialog?", QMessageBox::Yes | QMessageBox::No, NULL);

if(message.exec() == QMessageBox::Yes)

{

QMessageBox::aboutQt(NULL, "About Qt");

}

2.时间控件设置时间

ui->dateTimeEdit->setDateTime(QDateTime::currentDateTime());

3.滑动块和标度盘建立关联

QObject::connect(dial,SIGNAL(sliderMoved(int)),spinBox,

SLOT(setValue(int)));

4.添加菜单栏

//添加编辑菜单

QMenu*editMenu=ui->menuBar->addMenu(tr("编辑(&E)"));

//添加打开菜单

QAction*action_Open=editMenu->addAction(

QIcon(":/myImage/images/open.png"),tr("打开文件(&O)"));

//设置快捷键

action_Open->setShortcut(QKeySequence("Ctrl+O"));

//在工具栏中添加动作

ui->mainToolBar->addAction(action_Open);

5.窗口部件的理解

6.布局管理器

7.布局管理器自动为部件分配位置和大小

相关文档