最简单的分割窗体

  1. #include <QApplication>
  2. #include <QLabel>
  3. #include <QSplitter>
  4. int main(int argc, char *argv[])
  5. {
  6. QApplication app(argc, argv);
  7. QSplitter * mainSplitter = new QSplitter(Qt::Horizontal);
  8. mainSplitter->setHandleWidth(10);
  9. mainSplitter->setStyleSheet("QSplitter::handle { background-color: black }"); //设置分界线的样式
  10. QLabel *label = new QLabel(QObject::tr("TestA"));
  11. QLabel *label2 = new QLabel(QObject::tr("TestB"));
  12. mainSplitter->addWidget(label2);
  13. mainSplitter->addWidget(label);
  14. mainSplitter->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
  15. mainSplitter->show();
  16. return app.exec();
  17. }

结果截图如下

竖向排列子窗口

  1. #include <QApplication>
  2. #include <QLabel>
  3. #include <QSplitter>
  4. int main(int argc, char *argv[])
  5. {
  6. QApplication app(argc, argv);
  7. QSplitter * mainSplitter = new QSplitter(Qt::Horizontal);
  8. mainSplitter->setHandleWidth(10);
  9. mainSplitter->setStyleSheet("QSplitter::handle { background-color: black }"); //设置分界线的样式
  10. QLabel *label = new QLabel(QObject::tr("TestA"));
  11. QLabel *label2 = new QLabel(QObject::tr("TestB"));
  12. mainSplitter->addWidget(label2);
  13. mainSplitter->addWidget(label);
  14. mainSplitter->setOrientation(Qt::Vertical);
  15. mainSplitter->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
  16. mainSplitter->show();
  17. return app.exec();
  18. }

结果截图如下

http://blog.csdn.net/a649518776/article/details/6633857

  1. #include <QApplication>
  2. #include <QSplitter>
  3. #include <QTextCodec>
  4. #include <QTextEdit>
  5. int main(int argc, char *argv[])
  6. {
  7. QApplication a(argc, argv);
  8. //设置字体
  9. QFont font("ZYSong18030",12);
  10. a.setFont(font);
  11. //The QTextCodec class provides conversions between text encodings
  12. //Returns a pointer to the codec most suitable for this locale.On Windows, the codec will be based on a system locale.
  13. QTextCodec::setCodecForTr(QTextCodec::codecForLocale());
  14. //主splitter,以下填充text和子splitter
  15. //QSplitter::QSplitter ( Qt::Orientation orientation, QWidget * parent = 0 )
  16. QSplitter *splitterMain=new QSplitter(Qt::Horizontal,0);
  17. QTextEdit *textLeft=new QTextEdit(QObject::tr("Left Widget"),splitterMain);
  18. textLeft->setAlignment(Qt::AlignCenter);
  19. QSplitter *splitterRight=new QSplitter(Qt::Vertical,splitterMain);
  20. splitterRight->setOpaqueResize(false);
  21. //开始填充右边的splitter,放上两个text
  22. QTextEdit *textTop=new QTextEdit(QObject::tr("Right Top Widget"),splitterRight);
  23. textTop->setAlignment(Qt::AlignCenter);
  24. QTextEdit *textBottom=new QTextEdit(QObject::tr("Right Bottom Widget"),splitterRight);
  25. textBottom->setAlignment(Qt::AlignCenter);
  26. //设置主splitter
  27. splitterMain->setStretchFactor(1,1);
  28. splitterMain->setWindowTitle(QObject::tr("Splitter"));
  29. splitterMain->show();
  30. return a.exec();
  31. }

解析:

1.QSplitter的构造方法:

QSplitter *splitterMain=new QSplitter(Qt::Horizontal,0);

第一个参数通过Qt::Horizontal 和 Qt::Vertical来设定为水平分割或垂直分割。第二个设定0代表是主窗口,无父窗口。

不过子splitter设置的

new QSplitter(Qt::Vertical,splitterMain);

代表主窗口是splitterMain。则子splitter就被添加到splitterMain中。

添加时为从左至右(或从上至下)添加;

2.添加QTextEdit控件。

QTextEdit *textLeft=new QTextEdit(QObject::tr("Left Widget"),splitterMain);

第一个参数设置文本内容,第二个参数设置主窗体。

3.设置拖动时是否实时更新

splitterRight->setOpaqueResize(false);

false为不实时更新——在拖动时候只显示一条灰色的线条,在拖动到位并释放鼠标后再显示分割条。默认为true——实时更新。

4.设定可伸缩控件:

splitterMain->setStretchFactor(1,1);

第一个参数代表控件序号,第一个序号为0.后面参数0代表不可伸缩,非0代表可伸缩。

这里设置右边的可伸缩。当拉伸整个窗口时候,左边保持原来宽度。

拉伸后,我们发现左边的宽度不变

Qt5的更多相关文章

  1. QT5利用chromium内核与HTML页面交互

    在QT5.4之前,做QT开发浏览器只能选择QWebkit,但是有过使用的都会发现,这个webkit不是出奇的慢,简直是慢的令人发指,Release模式下还行,debug下你就无语了,但是webkit毕 ...

  2. qt5中信号和槽的新语法

    qt5中的连接 有下列几种方式可以连接到信号上 旧语法 qt5将继续支持旧的语法去连接,在QObject对象上定义信号和槽函数,及任何继承QObjec的对象(包含QWidget). connect(s ...

  3. Ubuntu在wps-office等qt5程序下不能切换中文fcitx输入法的问题

    经检查,是缺了fcitx-qt的包.比如qt5的程序,需要一个叫fcitx-libs-qt5的包. 如果您在基于qt的程序下不能使用基于fcitx的中文输入法,请检查以下包是否已安装: sudo ap ...

  4. qt5中文代码编码编译问题

    qt中文代码用vs2010编译问题解决 总结说就是qt5默认UTF8不支持微软默认的ANSI(GB2312/GBK).解决办法是把中文字符串全部用 QString::fromLocal8Bit() 封 ...

  5. VS2010+Qt5.4.0 环境搭建(离线安装)

    原创作者:http://blog.csdn.net/solomon1558/article/details/44084969 前言 因项目需要Qt开发GUI,我根据网上资料及自己的经验整理了搭建vs2 ...

  6. qt5.5程序打包发布以及依赖【转】

    玩qt5也有一段时间了,惭愧的是一直没有好好的发布过程序,因为写的都是小程序没啥需要用到发布,而且qt也说不上很熟悉,本来打算到基本掌握qt之后再来研究研究怎么打包程序,最近晚上的空闲时间多了,闲着也 ...

  7. Qt5.5.1编译出来的程序出现libgcc_s_dw2-1.dll的解决方案

    问题如图: 输入"myudp2016.exe 1  " 后出现 这是因为没有在系统环境变量path里加上相关路径,我们添加如下路径: 比如说WIN7系统-开始-计算机-右键-属性- ...

  8. ubuntu 16.04 + N驱动安装 +CUDA+Qt5 + opencv

    Nvidia driver installation(after download XX.run installation file) 1. ctrl+Alt+F1   //go to virtual ...

  9. Qt5中的信号槽

    Qt4中的信号槽 Qt4中的信号槽是通过SIGNAL,SLOT两个宏,将参数转换成字符串.Qt编译前,会从源码的头文件中提取由signal和slot声明的信号和槽的函数, 将其组成一张信号和槽对应的字 ...

  10. qt5.4.0编译错误

    error1: 进程"C:\Qt\Qt5.4.0\Tools\QtCreator\bin\jom.exe"退出,退出代码 2 solution:去工具->选项->构建和 ...

随机推荐

  1. jQuery缓存机制(二)

    1.从用户调用的入口开始阅读,因为这是我们比较熟悉的部分(主要做参数的调整,根据不同的完成不同的功能) // 进入jQuery Data模块的入口 使用方法有三种,不传参,传一个参,传两个参.示例$( ...

  2. hadoop 日常问题汇总(持续更新)

    问题描述:每次执行hadoop的shell命令时均出现如下警告: [hadoop@MyDB01 ~]$ hadoop fs -ls / 16/09/25 07:59:13 WARN util.Nati ...

  3. sencha touch JsonP 自动提示消息 masked

    //公用类 Ext.define('app.util', { alternateClassName: 'util', statics: { /*为Ext.Viewport添加一个消息提示组件(需要初始 ...

  4. win10 与linux mint双系统 只能进入mint而无法进入windows的解决方案

    新购买了一块ssd,和以前的hdd硬盘一起装双系统:win10和mint ssd:win10       sdb1  sdb2 sdb3    sda2 hdd:  mint         sda1 ...

  5. Visual Studio 2012创建SQL Server Database Project提示失败解决方法

    新建一个SQL Server Database Project,提示: Unable to open Database project This version of SQL Server Data ...

  6. 微信小游戏 交互接口的使用 wx.showToast wx.showLoading

    在小游戏中,会有如下图的提示窗口,这些可以使用微信提供的交互接口实现. 使用loading等待的接口.mask=true表示遮罩,防止等待时点击其他按钮触发其他操作导致异常. wx.showLoadi ...

  7. Django---渲染到模板

    简单的路由操作: from index import views urlpatterns = [ path('admin/', admin.site.urls), path('index/', vie ...

  8. 国外很有多优秀的HTML5前端开发框架

    国外很有多优秀的HTML5前端开发框架 相信大家都耳熟能详:JQuery Mobile,Twitter Bootstrap, Schena Touch,  BackBone等等. 同样,也存在很多国内 ...

  9. Asp.net MVC]Asp.net MVC5系列——实现编辑、删除与明细信息视图

    目录 概述 实现信息的明细视图 实现信息的编辑视图 实现信息的删除视图 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net ...

  10. Scikit-learn技巧(拓展)总结

    Scikit-learn技巧(拓展)总结 本文转载自:http://www.jianshu.com/p/516f009c0875 最近看了<Python数据挖掘入门与实战>,网上有说翻译地 ...