码迷,mamicode.com
首页 > 其他好文 > 详细

Qt中的 Size Hints 和 Size Policies

时间:2014-07-16 21:27:07      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   width   art   

  • sizeHint
    这个属性所保存的 QSize 类型的值是一个被推荐给窗口或其它组件(为了方便下面统称为widget)的尺寸,也就是说一个 widget 该有多大,它的一个参考来源就是这个 sizeHint 属性的值,而这个值由 sizeHint() 函数来确定。但是 widget 的大小的确定还有其它因素作用,下面会讲到。现在只需知道 sizeHint() 会返回一个被推荐的尺寸。那么这个尺寸的取值是怎样的呢?当它是一个无效值的时候(sizeHint().isValid() 返回 false,QSize 中 width 或者 height 有一个为复数就会是无效的),什么作用也没有;当它是一个有效值的时候,它就成了 widget 大小的一个参考。Qt 中对 sizeHint() 的默认实现是这样的:当 widget 没有布局(layout),返回无效值;否则返回其 layout 的首选尺寸
  • 例1:
     QWidget *widget = new QWidget;
    
      widget->show();
    
     qDebug() << widget->width() << "," << widget->height();
    
     qDebug() << widget->sizeHint().width() << "," << widget->sizeHint().height();
    
        //output:
    
       //1009 , 520
    
       //-1 , –1
    

     输出结果中第二行:sizeHint() 返回的是一个无效的 QSize,因为 widget 没有布局。

  •  

    例2:
        QWidget *widget = new QWidget;
    
        QHBoxLayout *layout = new QHBoxLayout;
    
       QPushButton *button = new QPushButton("Ggicci");
    
       layout->addWidget(button);
    
        widget->setLayout(layout);
    
        widget->show();
    
        qDebug() << widget->width() << "," << widget->height();
    
        qDebug() << widget->sizeHint().width() << "," << widget->sizeHint().height();
    
        qDebug() << button->width() << "," << button->height();
       1: //output:
       2: //112 , 45 
       3: //97 , 45 
       4: //90 , 23

    bubuko.com,布布扣
    
    
    输出结果中第一行:widget 的实际尺寸 (112, 45);
    输出结果中第二行:sizeHint() 返回 layout 的首选尺寸(97,45)供 widget 参考;
    输出结果中第三行:中间 button 的实际大小;
    从输出结果中可以证明以上说过的两点:
    1) 在 widget 有 layout 的情况下,其 sizeHint() 函数返回的是有效值作为其自身实际尺寸的参考;
    2) sizeHint() 返回的值并不一定会作为 widget 的实际尺寸,因为 widget 的尺寸的决定还有其它因素作用;
    详情请参考:http://www.tuicool.com/articles/uyaYn2

Qt中的 Size Hints 和 Size Policies,布布扣,bubuko.com

Qt中的 Size Hints 和 Size Policies

标签:style   blog   http   color   width   art   

原文地址:http://www.cnblogs.com/haoyuanyuan/p/3835971.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!