
在控件上边下边分别添加一个竖直的d簧,选中这三个控件,然后点击竖直布局,如下图所示。布局结果如右图。
然后在上次布局的两侧添加水平的d簧,选中两个d簧和上次的布局,点击水平布局。布局效果如图
最后选中最外层的窗口,然后点击水平或竖直布局,进行整体布局
布局效果如下图,现在可以运行一下,然后拖动界面改变大小来试一下效果了。
代码生成一个QDockWidget,使用addDockWidget,添加到MainWindows;对于DockWidget,可以使用setWidget来把Dock内容进行修改;
//新建一个空白的QDockWidget作为主对话框,在新建工程的时候要继承QMainWindow,不然后面的新建的浮动窗口会出现问题
QDockWidget *Multi_Function_Dock = new QDockWidget(tr("多功能按键"), this)
Multi_Function_Dock->setFeatures(QDockWidget::AllDockWidgetFeatures)
Multi_Function_Dock->setFixedSize(300, 200)
QWidget *widget = new QWidget()
QPushButton *btn_Play = new QPushButton("Play", widget)
btn_Play->setFixedSize(40, 30)
QPushButton *btn_Pause = new QPushButton("Pause", widget)
btn_Pause->setFixedSize(40, 30)
QPushButton *btn_Stop = new QPushButton("Stop", widget)
btn_Stop->setFixedSize(40, 30)
//新建布局器将这些QPushButton控件在QWidget上进行布局,这里采用水平布局方式:
QHBoxLayout *HorizontalLayout = new QHBoxLayout(Multi_Function_Dock)
HorizontalLayout->addWidget(btn_Play)
HorizontalLayout->addWidget(btn_Pause)
HorizontalLayout->addWidget(btn_Stop)
//下面就可以添加控件到QWidget上以及将QWidget放到浮动窗口QDockWidget上,过程如下:
widget->setLayout(HorizontalLayout)//在QWidget上进行布局
Multi_Function_Dock->setWidget(widget)//添加QWidget到QDockWidget上,并设置放置位置
addDockWidget(Qt::LeftDockWidgetArea, Multi_Function_Dock)
这两天看源码,研究了下这个问题,总算搞出来了,先看效果
步骤1,写一个自己的myTabWidget继承QTabWidget()
在构造函数里调用tabBar(),得到QTabBar* bar
步骤2,写一个自己 的myStyle继承QProxyStyle,重写drawItemText()函数,在这个函数里绘制自己想要的效果
步骤3,把这个myStyle设到步骤1里的bar上
步骤4,把ui里的TabWidget提升为myTabWidget
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)