1.垂直布局,水平布局和网格布局

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtLayout')
         self.resize(600, 480)

         row1 = QtGui.QHBoxLayout()#第一行,水平布局
         lbl1 = QtGui.QLabel('水平布局:上')
         lbl1.setAlignment(QtCore.Qt.AlignCenter)
         row1.addWidget(lbl1)

         row2 = QtGui.QHBoxLayout()#第二行,水平布局
         clm1 = QtGui.QVBoxLayout()#第二行第一列,垂直布局
         lbl2 = QtGui.QLabel('垂直布局:左上')
         lbl2.setAlignment(QtCore.Qt.AlignCenter)
         lbl3 = QtGui.QLabel('垂直布局:左下')
         lbl3.setAlignment(QtCore.Qt.AlignCenter)
         clm1.addWidget(lbl2)
         clm1.addWidget(lbl3)
         clm2 = QtGui.QVBoxLayout()#第二行第二列,垂直布局
         lbl4 = QtGui.QLabel('垂直布局:右上')
         lbl4.setAlignment(QtCore.Qt.AlignCenter)
         lbl5 = QtGui.QLabel('垂直布局:右下')
         lbl5.setAlignment(QtCore.Qt.AlignCenter)
         clm2.addWidget(lbl4)
         clm2.addWidget(lbl5)
         row2.addLayout(clm1)
         row2.addLayout(clm2)

         grid = QtGui.QGridLayout()#整体,网格布局
         grid.addLayout(row1, 0, 0)
         grid.addLayout(row2, 1, 0)
         grid.setRowMinimumHeight(1, 440)
         self.setLayout(grid)

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

qtLayout

2.在布局中使用QSpacerItem占位

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtSpacer')
         self.resize(300, 200)

         row1 = QtGui.QSpacerItem(0, 0)
         row2 = QtGui.QLabel('你逃我也逃')
         row2.setAlignment(QtCore.Qt.AlignCenter)
         row3 = QtGui.QSpacerItem(0, 0)

         grid = QtGui.QGridLayout()
         grid.addItem(row1)
         grid.addWidget(row2)
         grid.addItem(row3)
         self.setLayout(grid)

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

qtSpacer.py

3.按钮QPushButton

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtButton')
         self.resize(485, 300)

         self.btn1 = QtGui.QPushButton('大西洋帝国')
         self.btn2 = QtGui.QPushButton('太空堡垒')
         self.btn2.setFlat(True)

         grid = QtGui.QGridLayout()
         grid.addWidget(self.btn1, 0, 0, 1, 3)
         grid.addWidget(self.btn2, 1, 1)
         self.setLayout(grid)

         self.connect(self.btn1, QtCore.SIGNAL('clicked()'), self.onBtn1)
         self.connect(self.btn2, QtCore.SIGNAL('clicked()'), self.onBtn2)

     def onBtn1(self):
         self.btn1.setText('Clicked')
     def onBtn2(self):
         self.btn2.setText('Clicked')

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

qtButton.py

4.单行文本QLineEdit

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtLineEdit')
         self.resize(485, 300)

         self.lbl1 = QtGui.QLabel('Normal LineEdit')
         self.lbl1.setAlignment(QtCore.Qt.AlignCenter)
         self.txt1 = QtGui.QLineEdit()
         self.lbl2 = QtGui.QLabel('Password LineEdit')
         self.lbl2.setAlignment(QtCore.Qt.AlignCenter)
         self.txt2 = QtGui.QLineEdit()
         self.txt2.setEchoMode(QtGui.QLineEdit.Password)

         grid = QtGui.QGridLayout()
         grid.addWidget(self.lbl1)
         grid.addWidget(self.txt1)
         grid.addWidget(self.lbl2)
         grid.addWidget(self.txt2)

         self.setLayout(grid)

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

qtLineEdit

5.多行文本框

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtText')
         self.resize(485, 300)

         self.lbl = QtGui.QLabel('TextEdit')
         self.lbl.setAlignment(QtCore.Qt.AlignCenter)
         self.txt = QtGui.QTextEdit()
         self.txt.setText('权利游戏\n杯具淘汰法')

         grid = QtGui.QGridLayout()
         grid.addWidget(self.lbl)
         grid.addWidget(self.txt)

         self.setLayout(grid)

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()

qtText.py

6.单选框、复选框

 import sys
 from PyQt4 import QtCore, QtGui

 class MyWindow(QtGui.QWidget):
     def __init__(self):
         QtGui.QWidget.__init__(self)
         self.setWindowTitle('QtRCButton')
         self.resize(485, 300)

         self.rad1 = QtGui.QRadioButton('鬼地方')
         self.rad2 = QtGui.QRadioButton('爱痒痒')
         self.rad3 = QtGui.QRadioButton('阿尔法战士')
         self.chk = QtGui.QCheckBox('安全警报')
         self.btn = QtGui.QPushButton('Test')
         self.lbl = QtGui.QLabel()
         self.lbl.setAlignment(QtCore.Qt.AlignCenter)

         self.connect(self.btn, QtCore.SIGNAL('clicked()'), self.onBtn)

         grid = QtGui.QGridLayout()
         grid.addWidget(self.rad1, 0, 0)
         grid.addWidget(self.rad2, 0, 1)
         grid.addWidget(self.rad3, 0, 2)
         grid.addWidget(self.chk, 1, 1)
         grid.addWidget(self.btn, 2, 0)
         grid.addWidget(self.lbl, 2, 1, 1, 2)
         self.setLayout(grid)

     def onBtn(self):
         self.lbl.clear()
         if self.rad1.isChecked():
             self.lbl.setText(self.rad1.text())
         elif self.rad2.isChecked():
             self.lbl.setText(self.rad2.text())
         else:
             self.lbl.setText(self.rad3.text())
         if self.chk.isChecked():
             self.lbl.setText(self.lbl.text()+' '+self.chk.text())

 app = QtGui.QApplication(sys.argv)
 mywindow = MyWindow()
 mywindow.show()
 app.exec_()
 input('')

Python -- Gui编程 -- Qt库的使用 -- 布局与基本控件的更多相关文章

  1. Python -- Gui编程 -- Qt库的使用 -- 配置资源文件

    1.源文件(qtRes.py) import sys from PyQt4 import QtCore, QtGui, uic class MyDialog(QtGui.QDialog): def _ ...

  2. Python -- Gui编程 -- Qt库的使用 -- 菜单与对话框

    1.菜单 import sys from PyQt4 import QtCore, QtGui class MyWindow(QtGui.QMainWindow): def __init__(self ...

  3. C/C++ -- Gui编程 -- Qt库的使用 -- HelloWorld

    1.纯代码写对话框HelloWorld 创建空Qt工程,添加C++源文件main.cpp 需要设置编码以支持中文 -----源代码main.cpp----- #include <QApplica ...

  4. C/C++ -- Gui编程 -- Qt库的使用 -- Qt窗体的类型状态布局

    -----工程WindowTest----- 1.-----窗体类型type.cpp----- #include <QtGui> int main(int argc, char * arg ...

  5. C/C++ -- Gui编程 -- Qt库的使用 -- 理解主窗体构造函数

    MyWidget做父窗体 MyWidget的构造函数中可以手动添加组件 Ui::MyWidget存放子部件 Ui::MyWidget执行setupUi()函数为子部件开辟空间,指定父窗体 MyWidg ...

  6. C/C++ -- Gui编程 -- Qt库的使用 -- 标准对话框

    -----mywidget.cpp----- #include "mywidget.h" #include "ui_mywidget.h" #include & ...

  7. C/C++ -- Gui编程 -- Qt库的使用 -- 信号与槽 -- 欢迎界面

    程序运行先显示一个对话框,确定进入主程序 1.新建Qt工程,类MyWidget,基类QWidget 2.新建设计师界面类MyDialog,基类QDialog 3.-----main.cpp----- ...

  8. C/C++ -- Gui编程 -- Qt库的使用 -- 信号与槽的关联

    Qt信号与槽的三种关联方法:1.设计界面关联,编辑信号/槽,自动关联 2.手动关联(1).头文件中定义槽 -----mywidget.h----- #ifndef MYWIDGET_H #define ...

  9. C/C++ -- Gui编程 -- Qt库的使用 -- Qt5总结

    主要变化: 1.与Qt4相比,Qt5可以直接显示中文不需要手工转码2.Qt5模块发生变化,大部分组件并入widgets模块 注意事项:工程文件加一句greaterThan(QT_MAJOR_VERSI ...

随机推荐

  1. html使用技巧

    line-height: 27px;  /* lineheight和height保持一致就能达到文本垂直居中*/ .top_content li { list-style-image: url(../ ...

  2. 从0学习JQ

    转 张子秋的博客 为以后用到的时候好查询! 从零开始学习jQuery (一) 开天辟地入门篇 从零开始学习jQuery (二) 万能的选择器 从零开始学习jQuery (三) 管理jQuery包装集 ...

  3. VCL消息处理机制

    http://www.cnblogs.com/railgunman/archive/2010/12/10/1902524.html#2868236 说到VCL中的消息处理就不能不提到TApplicat ...

  4. Python学习-28.Python中的列表切片

    在实际的业务过程中,经常有这么一个操作:取一个列表的一部分进行操作,而不影响原来的列表.也就是将原来的列表复制一个部分副本并对其进行操作. 举个完整例子: list = ['a','b','c','d ...

  5. log.debug(e.getMessage());

    private static final Log log = LogFactory.getLog(AbcAction.class); @ManagedProperty(name = "abc ...

  6. boot分区剩余空间不足

      Linux boot分区用于存放内核文件以及Linux一些启动配置文件,一般情况下分区大小为500M足够使用,如果出现空间不足的问题可以使用以下方法来解决. 查看已经安装的内核 dpkg --ge ...

  7. jQuery之noConflict() 方法

    jQuery 核心 - noConflict() 方法,运行这个函数将变量 $ 的控制权让渡给第一个实现它的那个库.这有助于确保jQuery不会与其他库的$对象发生冲突. noConflict() 方 ...

  8. 在TFS持续集成(持续发布)中执行Telnet任务

    Telnet是一种在因特网或局域网上使用虚拟终端连接,提供双向交互式文本通信设备的协议. 它是最早的互联网通讯协议之一.自1969年启用以来,已经经过了将近50年时间,在开放式的操作系统中拥有广泛的用 ...

  9. [.net 多线程]线程基础

    一.线程状态 1.新建状态(New):         当用new操作符创建一个线程时, 例如new Thread(r),线程还没有开始运行,此时线程处在新建状态. 当一个线程处于新生状态时,程序还没 ...

  10. wpf 右下角弹出窗

    自己写的wpf 弹出框,欢迎拍砖,动画都写在了后台代码,前台代码不太重要,用了一下iconfont,具体样式我就不贴出来了,本次主要是后台代码的动画 需要有父级窗口才可以使用. 前台代码: <W ...