> 백엔드 개발 > 파이썬 튜토리얼 > PyQt5에서 매일 배워야 하는 레이아웃 관리

PyQt5에서 매일 배워야 하는 레이아웃 관리

不言
풀어 주다: 2018-04-19 13:50:04
원래의
3918명이 탐색했습니다.

이 글에서는 PyQt5에서 매일 배워야 할 레이아웃 관리 관련 정보를 중심으로 자세히 소개하고 있습니다. 참고할만한 가치가 있으니 관심 있는 친구들이 참고하면 됩니다.

GUI 프로그래밍에서 빼놓을 수 없는 부분이 있는데, 레이아웃 관리입니다. 레이아웃 관리는 애플리케이션 창에 컨트롤이 배치되는 방식을 제어합니다. 레이아웃 관리는 두 가지 방법으로 수행할 수 있습니다. 절대 위치 지정 또는 레이아웃 클래스 메서드를 사용하여 프로그램 창에서 컨트롤의 위치를 ​​제어할 수 있습니다.

절대 위치 지정

각 컨트롤은 프로그래머가 지정한 위치에 따라 배치됩니다. 절대 위치 지정을 사용할 때 다음 제한 사항을 알고 싶습니다.

  • 창 크기를 조정해도 컨트롤의 크기와 위치는 동일하게 유지됩니다.

  • 애플리케이션이 플랫폼에 따라 다르게 보일 수 있습니다

  • 글꼴 변경으로 인해 애플리케이션의 레이아웃이 손상될 수 있습니다

  • 레이아웃을 변경하기로 결정한 경우 각 컨트롤을 완전히 수정해야 하므로 지루하고 시간이 많이 걸립니다

다음 예는 절대 좌표 위치 지정 방법입니다. 통제의.

#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

这个例子显示了在窗口中使用绝对定位的三个标签。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLabel

class Example(QWidget):

 def __init__(self):
  super().__init__()

  self.initUI()

 def initUI(self):

  lbl1 = QLabel('我的世界你曾经来过', self)
  lbl1.move(15, 10)

  lbl2 = QLabel('CSND博客', self)
  lbl2.move(35, 40)

  lbl3 = QLabel('程序员', self)
  lbl3.move(55, 70)

  self.setGeometry(300, 300, 250, 150)
  self.setWindowTitle('绝对定位')  
  self.show()

if __name__ == '__main__':

 app = QApplication(sys.argv)
 ex = Example()
 sys.exit(app.exec_())
로그인 후 복사

이 예에서는 라벨이 사용되었습니다. x 및 y 좌표 값을 제공하여 위치를 지정합니다. 좌표계의 원점은 컨트롤의 왼쪽 상단입니다. x 값은 왼쪽에서 오른쪽으로 증가합니다. y 값은 위에서 아래로 증가합니다.

lbl1 = QLabel('我的世界你曾经来过', self)
lbl1.move(15, 10)
로그인 후 복사

레이블 컨트롤은 x=15 및 y=10에 배치됩니다.

프로그램 실행 후

PyQt5에서 매일 배워야 하는 레이아웃 관리

Box 레이아웃 상자 레이아웃

레이아웃 관리는 레이아웃 클래스를 사용하여 보다 유연하고 실용적입니다. 이는 창에 컨트롤을 배치하는 데 선호되는 방법입니다. QHBoxLayout 및 QVBoxLayout은 각각 가로 및 세로로 정렬된 컨트롤의 기본 레이아웃 클래스입니다.

프로그램 오른쪽 하단에 두 개의 버튼을 넣는다고 상상해 보세요. 이러한 레이아웃을 생성하려면 가로 하나와 세로 하나, 두 개의 상자를 사용할 수 있습니다. 필요한 여유 공간을 만들기 위해 스트레치 팩터를 추가하겠습니다.


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们在窗口的右下角放置两个按钮。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget,
  QPushButton, QVBoxLayout, QHBoxLayout)

class Example(QWidget):

 def __init__(self):
  super().__init__()

  self.initUI()

 def initUI(self):

  okButton = QPushButton('确定')
  cancelButton = QPushButton('取消')

  hbox = QHBoxLayout()
  hbox.addStretch(1)
  hbox.addWidget(okButton)
  hbox.addWidget(cancelButton)

  vbox = QVBoxLayout()
  vbox.addStretch(1)
  vbox.addLayout(hbox)

  self.setLayout(vbox)

  self.setGeometry(300, 300, 350, 150)
  self.setWindowTitle('Box布局')  
  self.show()

if __name__ == '__main__':

 app = QApplication(sys.argv)
 ex = Example()
 sys.exit(app.exec_())
로그인 후 복사

이 예에서는 창의 오른쪽 하단에 두 개의 버튼을 배치합니다. 응용 프로그램 창의 크기를 조정하면 오른쪽 하단 모서리에 고정됩니다. 우리는 HBoxLayout과 QVBoxLayout 레이아웃을 모두 사용합니다.

okButton = QPushButton('确定')
 cancelButton = QPushButton('取消')
로그인 후 복사

여기서 두 개의 버튼을 만들었습니다.

hbox = QHBoxLayout()
hbox.addStretch(1)
hbox.addWidget(okButton)
hbox.addWidget(cancelButton)
로그인 후 복사

가로 상자 레이아웃을 만들고, 늘이기 요소를 늘리고(addStretch), 두 개의 버튼을 추가했습니다(addWidget). 두 개의 버튼을 추가하기 전에 스트레치 요소를 추가하여 두 개의 버튼을 창 오른쪽으로 밀어냅니다.

vbox = QVBoxLayout()
vbox.addStretch(1)
vbox.addLayout(hbox)
로그인 후 복사

원하는 레이아웃을 얻으려면 가로 레이아웃을 세로 레이아웃에도 넣어야 합니다. 수직 상자의 확장 요소는 내부 컨트롤을 포함하여 수평 상자를 창 아래쪽으로 밀어냅니다.

self.setLayout(vbox)
로그인 후 복사

마지막으로 창의 기본 레이아웃을 설정합니다.

프로그램 실행 후

PyQt5에서 매일 배워야 하는 레이아웃 관리

QGridLayout 그리드 레이아웃

가장 일반적으로 사용되는 레이아웃 클래스는 그리드 레이아웃입니다. 이 레이아웃은 공간을 행과 열로 나눕니다. 그리드 레이아웃을 생성하기 위해 QGridLayout 클래스를 사용합니다.

#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们使用网格布局创建一个计算器的框架。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget,
QPushButton, QGridLayout)

class Example(QWidget):

 def __init__(self):
  super().__init__()

  self.initUI()

 def initUI(self):

  grid = QGridLayout()  
  self.setLayout(grid)

  names = ['Cls', 'Bck', '', 'Close', 
  '7', '8', '9', '/',
  '4', '5', '6', '*',
  '1', '2', '3', '-',
  '0', '.', '=', '+',]

  positions = [(i, j) for i in range(5) for j in range(4)]

  for position, name in zip(positions, names):

   if name == '':
    continue
   button = QPushButton(name)
   grid.addWidget(button, *position)

  self.move(300, 150)
  self.setWindowTitle('计算器')  
  self.show()

if __name__ == '__main__':

 app = QApplication(sys.argv)
 ex = Example()
 sys.exit(app.exec_())
로그인 후 복사

이 경우 생성된 버튼 컨트롤을 그리드에 배치하겠습니다.

grid = QGridLayout()  
self.setLayout(grid)
로그인 후 복사

QGridLayout을 인스턴스화하고 응용 프로그램 창의 레이아웃을 설정합니다.

 names = ['Cls', 'Bck', '', 'Close', 
  '7', '8', '9', '/',
  '4', '5', '6', '*',
  '1', '2', '3', '-',
  '0', '.', '=', '+',]
로그인 후 복사

앞으로 사용될 버튼 라벨입니다.

positions = [(i, j) for i in range(5) for j in range(4)]
로그인 후 복사

x 그리드 위치 목록을 만들었습니다.

for position, name in zip(positions, names):

   if name == '':
    continue
   button = QPushButton(name)
   grid.addWidget(button, *position)
로그인 후 복사

버튼을 생성하고 레이아웃에 (addWidget)을 추가하세요.

프로그램이 실행된 후

PyQt5에서 매일 배워야 하는 레이아웃 관리

그리드 레이아웃 확장

창의 컨트롤은 그리드의 여러 열이나 행에 걸쳐 있을 수 있습니다. 다음 예에서는 이를 설명합니다.


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们使用GridLayout的跨行创建了一个更复杂的窗口布局。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget, QLabel, 
QTextEdit, QLineEdit, QGridLayout)

class Example(QWidget):

 def __init__(self):
  super().__init__()

  self.initUI()

 def initUI(self):

  title = QLabel('标题')
  author = QLabel('作者')
  review = QLabel('评论')

  titleEdit = QLineEdit()
  authorEdit = QLineEdit()
  reviewEdit = QTextEdit()

  grid =QGridLayout()
  grid.setSpacing(10)

  grid.addWidget(title, 1, 0)
  grid.addWidget(titleEdit, 1, 1)

  grid.addWidget(author, 2, 0)
  grid.addWidget(authorEdit, 2, 1)

  grid.addWidget(review, 3, 0)
  grid.addWidget(reviewEdit, 3, 1, 5, 1)

  self.setLayout(grid)

  self.setGeometry(300, 300, 350, 300)
  self.setWindowTitle('评论')  
  self.show()

if __name__ == '__main__':

 app = QApplication(sys.argv)
 ex = Example()
 sys.exit(app.exec_())
로그인 후 복사

우리가 만든 프로그램에는 QGridLayout 레이아웃을 사용하는 세 개의 레이블, 두 개의 한 줄 텍스트 입력 상자 및 텍스트 편집 컨트롤이 포함되어 있습니다.

grid =QGridLayout()
grid.setSpacing(10)
로그인 후 복사

그리드 레이아웃을 인스턴스화하고 간격을 설정하세요.

grid.addWidget(reviewEdit, 3, 1, 5, 1)
로그인 후 복사

그리드 레이아웃에 컨트롤을 추가하면 이 컨트롤에 행 범위 또는 열 범위를 사용할 수 있습니다. 이 예에서는 reviewEdit 컨트롤이 5개 행에 걸쳐 있어야 합니다.

프로그램 실행 후

PyQt5에서 매일 배워야 하는 레이아웃 관리

PyQt5 튜토리얼의 이 부분은 레이아웃 관리에 전념합니다. PyQt5의 이벤트 관련 내용은 추후 소개하겠습니다.

관련 추천:

PyQt5는 라벨이 있는 체크박스를 매일 배워야 합니다

PyQt5는 창 중심 효과를 만드는 방법을 매일 배워야 합니다

PyQt5는 창을 닫는 방법을 매일 배워야 합니다

위 내용은 PyQt5에서 매일 배워야 하는 레이아웃 관리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿