对于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)
首先,我们要编写一个主动态库,来实现我们自己的控件。其次,还要写一个接口动态库,用来实现designer中调用我们自己的控件。这一步很关键。这个动态库中程序结构都是qt固定的。具体参见附录。
最后,编译写好的上面两个插件,要拷贝一些文件到相应目录下:
分别将主动态库和库文件拷贝到qt安装的bin和lib目录下;
将接口动态库和库文件拷贝到qt安装目录的plugins\designer目录下;
将主动态库的接口头文件拷贝到qt安装目录的include目录下;
这样,我们的写的控件就添加完成了。这时打开desinger就可以在工具条中看到我们写的控件了。我们就可以像其它控件一样使用这个控件了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)