프로그래밍/python
Qsplitter 의 모든 기능과 사용법
마루의 일상
2024. 5. 24. 01:00
728x90
반응형
PyQt5의 QSplitter는 사용자가 위젯의 크기를 조절할 수 있게 해주는 위젯입니다. QSplitter는 주로 창을 여러 영역으로 나누고, 사용자가 각 영역의 크기를 드래그하여 조절할 수 있도록 하는 데 사용됩니다.
QSplitter 개요
QSplitter는 PyQt5에서 제공하는 레이아웃 위젯 중 하나로, 여러 자식 위젯을 수평 또는 수직으로 배치할 수 있게 해줍니다. 사용자는 이 위젯을 통해 각 자식 위젯의 크기를 드래그하여 조절할 수 있습니다.
기본 사용법
QSplitter를 사용하려면 PyQt5 모듈을 임포트하고, QSplitter 객체를 생성한 후, 자식 위젯을 추가하면 됩니다.
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QSplitter, QTextEdit
from PyQt5.QtCore import Qt
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle('QSplitter Example')
# QSplitter 생성
splitter = QSplitter(Qt.Horizontal)
# QTextEdit 위젯 생성 및 추가
text_edit1 = QTextEdit()
text_edit2 = QTextEdit()
text_edit3 = QTextEdit()
splitter.addWidget(text_edit1)
splitter.addWidget(text_edit2)
splitter.addWidget(text_edit3)
self.setCentralWidget(splitter)
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
주요 메서드와 속성
- addWidget(widget): QSplitter에 자식 위젯을 추가합니다.
- setOrientation(orientation): QSplitter의 방향을 설정합니다. Qt.Horizontal 또는 Qt.Vertical을 사용할 수 있습니다.
- setSizes(sizes): QSplitter의 각 위젯 크기를 설정합니다.
- sizes(): 현재 QSplitter의 각 위젯 크기를 반환합니다.
- setHandleWidth(width): QSplitter 핸들의 너비를 설정합니다.
- handleWidth(): 현재 QSplitter 핸들의 너비를 반환합니다.
- setStretchFactor(index, stretch): 특정 인덱스의 위젯에 대한 스트레치 팩터를 설정합니다. 큰 값일수록 더 많은 공간을 차지합니다.
예제 코드
다양한 QSplitter 기능을 사용하는 예제 코드를 살펴보겠습니다.
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QSplitter, QTextEdit, QVBoxLayout, QWidget
from PyQt5.QtCore import Qt
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle('QSplitter Example')
# QSplitter 생성 및 방향 설정
splitter = QSplitter(Qt.Vertical)
# QTextEdit 위젯 생성
text_edit1 = QTextEdit()
text_edit2 = QTextEdit()
text_edit3 = QTextEdit()
# QSplitter에 위젯 추가
splitter.addWidget(text_edit1)
splitter.addWidget(text_edit2)
splitter.addWidget(text_edit3)
# 초기 크기 설정
splitter.setSizes([100, 200, 100])
# 핸들 너비 설정
splitter.setHandleWidth(10)
# 스트레치 팩터 설정
splitter.setStretchFactor(0, 1)
splitter.setStretchFactor(1, 2)
splitter.setStretchFactor(2, 1)
# 레이아웃 설정
layout = QVBoxLayout()
layout.addWidget(splitter)
# 메인 위젯 설정
container = QWidget()
container.setLayout(layout)
self.setCentralWidget(container)
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
QSplitter의 시그널
QSplitter는 사용자가 위젯의 크기를 변경할 때 시그널을 발생시킵니다.
- splitterMoved(int pos, int index): 사용자가 스플리터를 이동할 때 발생합니다. pos는 핸들의 위치, index는 이동된 핸들의 인덱스입니다.
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle('QSplitter Example with Signal')
splitter = QSplitter(Qt.Horizontal)
text_edit1 = QTextEdit()
text_edit2 = QTextEdit()
splitter.addWidget(text_edit1)
splitter.addWidget(text_edit2)
splitter.splitterMoved.connect(self.on_splitter_moved)
self.setCentralWidget(splitter)
def on_splitter_moved(self, pos, index):
print(f'Splitter moved to position {pos} at index {index}')
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec_())
결론
QSplitter는 PyQt5에서 자주 사용되는 위젯으로, 복잡한 레이아웃을 구성할 때 매우 유용합니다. 이 포스팅에서는 QSplitter의 기본 사용법과 주요 메서드, 시그널을 소개했습니다. QSplitter를 활용하여 사용자에게 더 나은 인터페이스를 제공할 수 있습니다. QSplitter의 다양한 기능을 활용해보세요!
728x90
반응형