您的位置:首页 > 编程语言 > Qt开发

Qt学习——堆栈窗体QStackedWidget类

2013-12-05 10:13 483 查看


Qt学习——堆栈窗体QStackedWidget类

分类: Meego2011-07-27
09:25 6012人阅读 评论(2) 收藏 举报

qtdialogsignal测试list

这些窗体都比较类似,相对简单,就没什么可以深入研究的了。



下面用代码实现上面窗口的设计:

1.建立项目时基类选择QDialog,取消Gernerate form复选框的选中状态。

2.在头文件dialog.h中编写如下代码:

#include <QtGui/QDialog>  

#include <QListWidget>  

#include <QStackedWidget>  

#include <QLabel>  

  

class Dialog : public QDialog  

{  

    Q_OBJECT  

  

public:  

    Dialog(QWidget *parent = 0);  

    ~Dialog();  

private:  

    QListWidget *leftlist;  

    QStackedWidget *stack;  

    QLabel *label1;  

    QLabel *label2;  

    QLabel *label3;  

};  

3.在源文件dialog.cpp中编写如下代码:

#include "dialog.h"  

#include <QHBoxLayout>  

Dialog::Dialog(QWidget *parent)  

    : QDialog(parent)  

{  

     setWindowTitle(tr("StackedWidget"));  

     //设置列表框  

     leftlist=new QListWidget(this);  

     leftlist->insertItem(0,tr("window1"));  

     leftlist->insertItem(1,tr("window2"));  

     leftlist->insertItem(2,tr("window3"));  

     //设置堆栈窗体  

     label1=new QLabel(tr("WindowTest1\n\tby liming"));  

     label2=new QLabel(tr("WindowTest2\n\tby liming"));  

     label3=new QLabel(tr("WindowTest3\n\tby liming"));  

  

     stack=new QStackedWidget(this);  

     stack->addWidget(label1);  

     stack->addWidget(label2);  

     stack->addWidget(label3);  

     //设置主窗体布局  

     QHBoxLayout *mainLayout=new QHBoxLayout(this);  

     mainLayout->setMargin(5);  

     mainLayout->setSpacing(5);  

     mainLayout->addWidget(leftlist);  

     mainLayout->addWidget(stack,0,Qt::AlignHCenter);  

     mainLayout->setStretchFactor(leftlist,1);  

     mainLayout->setStretchFactor(stack,3);  

     connect(leftlist,SIGNAL(currentRowChanged(int)),stack,SLOT(setCurrentIndex(int)));  

}  

解析:

1.这里的程序是,选中左边列表框内的内容,显示相应的窗体。

2.所以,第一步是初始化列表框QListWidget。

3.第二步新建堆栈窗体:

stack=new QStackedWidget(this);

然后将三个相应的label放入其中:

stack->addWidget(label1);

stack->addWidget(label2);
stack->addWidget(label3);


4.设置主窗体布局时,用到了布局管理器。这里用到的是水平排列窗体QHBoxLayout:

QHBoxLayout *mainLayout=new QHBoxLayout(this);


这个布局管理器用法为:
×对话框边距设为5

mainLayout->setMargin(5);


×内部控件间距为5

mainLayout->setSpacing(5);


×对于setStetchFactor函数,借用别的文章说明(http://blog.csdn.net/lin49940/article/details/6033727):

这里讲得是QSplitter的setStetchFactor函数:
程序为


 对于B 和 A 来说, 他们的本身的大小相对于整个窗口来说, 都是很小的. 这样就存在着一些多余的空间, 这些空间可以给B, 也可以给A, 或者两个平分. 对于B 和 A 各自空间大小的控制, 是通过 QSplitter 的 setStretchFactor 方法, 该方法的声明:

 

      void setStretchFactor(int index, int stretch);

 

      第一个参数index 是子微件的索引值, 从0 开始. 这里的话, B 是0, A 是1; 第二个参数 stretch 是拉伸系数, int 类型, 下面主要对stretch 的数值进行说明.

 

      1.  mainSplitter->setStretchFactor(0, -2);

      效果如下,

      


      B占据了所有多余的空间, 看来 stretch 的值如果为负整数, 那这个微件将占据最大的空间.

 

      2.     mainSplitter->setStretchFactor(0, -2);

              mainSplitter->setStretchFactor(1, -4);

      效果如下:

      


 

      B 和 A 平分了空间, 看来stretch 如果是负整数就会尽可能的占据空间, 而不看负整数的大小, 把 -2 改为 -12, 结果一样的.

 

      3.     mainSplitter->setStretchFactor(0, 0);

              mainSplitter->setStretchFactor(1, 0);

       效果同第二.

 

       4.       mainSplitter->setStretchFactor(0, 0);  //可以把这段注释掉, 效果一样

                 mainSplitter->setStretchFactor(1, 1);

       效果如下:

       


 

       5.     mainSplitter->setStretchFactor(0, 4);

               mainSplitter->setStretchFactor(1, 8);

       效果如下:

       


 

       6.     mainSplitter->setStretchFactor(0, -4);

               mainSplitter->setStretchFactor(1, 8);

      效果如下,

      


 

       从 1, 2 和 6 的测试效果可以看出, 拉伸系数为负整数的微件将占据最大的多余空间.

       从3, 4 和 5 的测试效果来看, 就算我们不设置 B 或 A 的拉伸系数stretch, 他们内部也应该存在着一个默认拉伸系数值0. stretch为 0 的微件, 将把最大多余空间让给stretch 为正整数的微件. 如果有多个stretch 为正整数的微件, 他们的多余空间的占有率由通过数字的比例来确定的.

注:因此,我的堆栈窗体程序中的

mainLayout->setStretchFactor(leftlist,1);

mainLayout->setStretchFactor(stack,3);

就是设定了list与stack比例为1:3。

5.设定消息相应的信号与槽:

connect(leftlist,SIGNAL(currentRowChanged(int)),stack,SLOT(setCurrentIndex(int)));

都是控件自带的信号与槽,这里将其关联起来,就达到了程序的设计效果:

更改第几行就显示第几个Label。

最后编译运行:





更多0

上一篇:Qt学习——停靠窗体QDo
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: