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. linux环境下的mysql,httpd以及与宿主机的调试问题总结

    1. 首先www服务器,在宿主主机浏览器无法访问? (1)修改linux的防火墙,允许宿主主机ip访问即可. (2)关闭防火墙,即可访问. service iptables stop; 2. mysq ...

  2. ACL登陆认证

    前篇文章ACL授权实例介绍了授权,授权完成之后,就要进行认证.ACL的认证主要分为登陆认证与即时认证.所谓登录认证就是在用户登陆的时候,进行信息认证.根据用户Id,加载上来该用户所拥有的权限模块:而即 ...

  3. spring mvc的例子

    现在主流的Web MVC框架除了Struts这个主力 外,其次就是Spring MVC了,因此这也是作为一名程序员需要掌握的主流框架,框架选择多了,应对多变的需求和业务时,可实行的方案自然就多了.不过 ...

  4. swipe js bug

    最近因为要写新的mobile site页面,有好几个页面上面必须用到photo slider. 使用插件: /* * Swipe 2.0 * * Brad Birdsall * Copyright 2 ...

  5. Trystrtofloat

    TryStrToFloat为 ‘+1’和‘-1’和 ‘.1’是可以装换成功的

  6. unusedjs

    查看js的有效使用情况: https://github.com/gmetais/unusedjs Installation You need to open your console and writ ...

  7. Pipelines - .NET中的新IO API指引(三) 边看边记

    Pipelines - .NET中的新IO API指引 作者 marcgravell  原文 此系列前两篇网上已有的译文 Pipelines - .NET中的新IO API指引(一) Pipeline ...

  8. net生成图片验证码--转自Lisliefor

    目前,机器识别验证码已经相当强大了,比较常见的避免被机器识别的方法,就是将验证码的字符串连到一起,这样就加大的识别的难度,毕竟机器没有人工智能.我找了很多的.net生成图片验证码的例子,后来经过一些修 ...

  9. C# winform 去掉button的边框颜色

    Winform的话,设置FlatStyle为Flat,并且设置FlatAppearance下的BorderSize为0,foreColor设置成web下的Transparent

  10. MPU6050学习笔记(电源管理器1、2)

    Technorati Tags: 嵌入式开发.模块开发 寄存器107号:电源管理器1 PWR_MGMT_1: Description: This register allows the user to ...