zoukankan      html  css  js  c++  java
  • QSizePolicy的一些函数以及拉伸因子的理解

    QSizePolicy包含了两个独立的QSizePolicy::Policy值和两个缩放因子,一个描述了部件水平方向上的大小策略,另一个描述了垂直方向上的大小策略。它还包含一个标志表明高度和宽度是否与首选大小有关。

    水平和垂直方向的大小策略可以在构造函数中设置,也可以通过setHorizontalPolicy()和setVerticalPolicy()函数改变。缩放因子可以使用setHorizontalStretch()和setVerticalStretch()函数设置。setHeightForWidth()函数的标志表示部件的缺省大小(sizeHint())是否是width-dependent(例如:菜单栏或自动换行标签) 。

    可以使用horizontalPolicy()、verticalPolicy()、horizontalStretch()和verticalStretch()函数来返回当前的大小策略和缩放因子。另外,使用transpose()函数可以互换水平和垂直的大小策略和缩放因子。hasHeightForWidth()函数返回了当前状态表示的大小依赖性。

    为了确定相关的部件是否可以比sizeHint()函数利用更多的空间,可以使用expandingDirections()函数,通过它,还可以找出哪个方向可以展开。

    最后,QSizePolicy类可以进行大小策略之间的比较,并且可以用QVariant来存储QSizePolicy。

    构造函数:QSizePolicy(Policy horizontal, Policy vertical, ControlType type = DefaultType)

    第一个参数:水平方向大小策略。

    第二个参数:垂直方向大小策略。

    第三个参数:指定了布局交互时不同的部件类型(一般都不用管)。

      • ControlType QSizePolicy::controlType() const 
        返回部件大小策略所依赖的控制类型

      • Qt::Orientations QSizePolicy::expandingDirections() const 
        返回一个部件是否可以比QWidget::sizeHint()使用更多的空间

        Qt::Horizontal 或 Qt::Vertical意味着可以在水平或垂直方向上伸展(例如:水平或垂直策略是Expanding或MinimumExpanding),然而Qt::Horizontal | Qt::Vertical意味着可以在两个方向上均可以伸展。

      • bool QSizePolicy::hasHeightForWidth() const 
        如果部件的首选高度依赖于它的宽度,则返回true;否则,返回false。

      • bool QSizePolicy::hasWidthForHeight() const 
        如果部件的宽度取决于其高度,则返回true;否则返回false。

      • Policy QSizePolicy::horizontalPolicy() const 
        返回水平方向上的大小策略

      • int QSizePolicy::horizontalStretch() const 
        返回水平方向上大小策略的缩放因子

      • bool QSizePolicy::retainSizeWhenHidden() const 
        部件被隐藏时,返回布局是否应保留它的尺寸,默认为false。

      • void QSizePolicy::setControlType(ControlType type) 
        设置部件大小策略所依赖的控制类型

      • void QSizePolicy::setHeightForWidth(bool dependent) 
        设置标志判断窗口部件的首选高度是否依赖于它的宽度。

      • void QSizePolicy::setHorizontalPolicy(Policy policy) 
        设置水平方向上的大小策略

      • void QSizePolicy::setHorizontalStretch(int stretchFactor) 
        设置水平大小策略的缩放因子,取值范围[0,255]。

        当两个部件在一个水平布局中彼此相邻,如果左侧的缩放因子设置为2,右侧的缩放因子设置为1,那么,左侧部件大小将总是右边的两倍。

      • void QSizePolicy::setRetainSizeWhenHidden(bool retainSize) 
        当部件被隐藏时,设置其所在布局是否应保留它的大小。如果为true,布局将不被隐藏部件所改变。

      • void QSizePolicy::setVerticalPolicy(Policy policy) 
        设置垂直方向上的大小策略

      • void QSizePolicy::setVerticalStretch(int stretchFactor) 
        设置垂直大小策略的缩放因子,取值范围[0,255]。

      • void QSizePolicy::setWidthForHeight(bool dependent) 
        设置标志确定部件的宽度是否依赖于它的高度。

        仅支持QGraphicsLayout的子类,不可能有布局同时存在height-for-width和width-for-height。

      • void QSizePolicy::transpose() 
        互换水平和垂直策略和伸展。

      • Policy QSizePolicy::verticalPolicy() const 
        返回垂直方向上的大小策略

      • int QSizePolicy::verticalStretch() const 
        返回垂直方向上大小策略的缩放因子

     示例1、

     源码:

    QTreeWidget *pTreeWidget = new QTreeWidget(this);
    QTableWidget *pTableWidget = new QTableWidget(this);
     
    ...
     
    QHBoxLayout *pLayout = new QHBoxLayout();
    pLayout->addWidget(pTreeWidget);
    pLayout->addWidget(pTableWidget);
    pLayout->setSpacing(10);
    pLayout->setContentsMargins(10, 10, 10, 10);
     
    setLayout(pLayout);
     
    // 获取大小策略
    QSizePolicy treeSizePolicy = pTreeWidget->sizePolicy();
    QSizePolicy tableSizePolicy = pTableWidget->sizePolicy();

    将QTreeWidget和QTableWidget加入布局后,分别获取它们的大小策略,可以很容易的发现水平和垂直方向的值均为7。

    7代表什么?

    由于QSizePolicy::Policy由QSizePolicy::PolicyFlag组合而成,所以可以很轻易地发现对应的值是:QSizePolicy::Expanding,递推分析:7 = (1 | 2 | 4) = (QSizePolicy::GrowFlag | QSizePolicy::ExpandFlag | QSizePolicy::ShrinkFlag) = QSizePolicy::Expanding。

    可以看出,它们同时缩小、同时放大,并且等比均匀划分。

    示例2、

    当界面缩小时,我们尽可能的让左边的QTreeWidget缩小;而界面放大时,尽可能的让右边的TableView放大,且QTreeWidget达到缺省宽度时就不会被放大。

    QTreeWidget *pTreeWidget = new QTreeWidget(this);
    QTableWidget *pTableWidget = new QTableWidget(this);
     
    ...
     
    QHBoxLayout *pLayout = new QHBoxLayout();
    pLayout->addWidget(pTreeWidget);
    pLayout->addWidget(pTableWidget);
    pLayout->setSpacing(10);
    pLayout->setContentsMargins(10, 10, 10, 10);
     
    setLayout(pLayout);
     
    // 获取大小策略
    QSizePolicy treeSizePolicy = pTreeWidget->sizePolicy();
    QSizePolicy tableSizePolicy = pTableWidget->sizePolicy();
     
    treeSizePolicy.setHorizontalPolicy(QSizePolicy::Maximum);  //通过使用QSizePolicy::Maximum来控制
    pTreeWidget->setSizePolicy(treeSizePolicy);
    tableSizePolicy.setHorizontalPolicy(QSizePolicy::Expanding);
    pTableWidget->setSizePolicy(tableSizePolicy);

    示例3、

    当界面缩放时,为了保持一定的比例,右边的QTableWidget永远是左边QTreeWidget的2倍,我们可以通过setHorizontalStretch()来设置缩放因子。

    QTreeWidget *pTreeWidget = new QTreeWidget(this);
    QTableWidget *pTableWidget = new QTableWidget(this);
     
    ...
     
    QHBoxLayout *pLayout = new QHBoxLayout();
    pLayout->addWidget(pTreeWidget);
    pLayout->addWidget(pTableWidget);
    pLayout->setSpacing(10);
    pLayout->setContentsMargins(10, 10, 10, 10);
     
    setLayout(pLayout);
     
    // 获取大小策略
    QSizePolicy treeSizePolicy = pTreeWidget->sizePolicy();
    QSizePolicy tableSizePolicy = pTableWidget->sizePolicy();
    //控制拉伸因子
    treeSizePolicy.setHorizontalStretch(1);
    tableSizePolicy.setHorizontalStretch(2);
    pTreeWidget->setSizePolicy(treeSizePolicy);
    pTableWidget->setSizePolicy(tableSizePolicy);

    拉伸因子:

    示例1、

    QGridLayout *LeftLayout =new QGridLayout(this);
    LeftLayout->addWidget(label1, 0, 0);       //label1在第1行第1列
    LeftLayout->addWidget(label2, 0, 1);       //label2在第1行第2列
    LeftLayout->addWidget(btn1, 1, 0, 1, 2);   //btn1在第2行第1列,占用的列数为1,占用的行数为2
    LeftLayout->setColumnStretch(0, 1);   //第1列占表格布局的1/4
    LeftLayout->setColumnStretch(1, 3);   //第2列占表格布局的3/4

    效果:

    示例2、

    QHBoxLayout *RightLayout =new QHBoxLayout(this);
    RightLayout->setMargin(10);  //控件与窗体左右边距
    RightLayout->setSpacing(10); //控件之间的边距
    RightLayout->addWidget(label3);
    RightLayout->addWidget(label4);
    RightLayout->setStretchFactor(label3, 1);  //label3占水平布局的1/4
    RightLayout->setStretchFactor(label4, 3);  //label4占水平布局的3/4

    示例3、

    QVBoxLayout *ButtomLayout = new QVBoxLayout(this);  
    ButtomLayout->addStretch(1);    //在label5前面的空白占总空白的1/6
    ButtomLayout->addWidget(label5);    
    ButtomLayout->addStretch(3);   //在label6前面的空白占总空白的3/6
    ButtomLayout->addWidget(label6); 
    ButtomLayout->addStretch(2);   //在label6后面的空白占总空白的2/6

    原文链接:http://blog.csdn.net/u012319493/article/details/51866152

         https://blog.csdn.net/liang19890820/article/details/51986284#%E6%BA%90%E7%A0%81-1

  • 相关阅读:
    java如何计算对象的大小
    java多线程实现主线程等待子线程执行完问题
    再次理解多线程线程安全问题(理解java内存模型后)
    关于局部变量在循环里的生存法则
    【CSS3】transform-origin原点旋转
    面向对象编程(本章小结)
    引入在线编程和编译站点
    关于获取素数 一个小程序
    C++ I/O
    HDU2571
  • 原文地址:https://www.cnblogs.com/kongbursi-2292702937/p/15108748.html
Copyright © 2011-2022 走看看