프로그래밍/python

PyQt5 QSlider와 QDial의 모든 기능과 속성 사용법

마루의 일상 2024. 5. 23. 01:07
728x90
반응형

QSlider와 QDial은 PyQt5에서 제공하는 두 가지 주요 위젯으로, 각각 슬라이더와 다이얼 형태의 입력 컨트롤을 제공합니다. 이 포스팅에서는 QSlider와 QDial의 모든 기능과 속성 사용법에 대해 자세히 알아보겠습니다.

목차

  1. QSlider 사용법
    • QSlider 개요
    • 주요 메서드와 속성
    • 이벤트 처리
    • 예제 코드
  2. QDial 사용법
    • QDial 개요
    • 주요 메서드와 속성
    • 이벤트 처리
    • 예제 코드
  3. 결론

1. QSlider 사용법

QSlider 개요

QSlider는 수평 또는 수직 방향으로 값을 조정할 수 있는 슬라이더 위젯입니다. 주로 사용자로부터 정수 입력을 받을 때 사용됩니다.

주요 메서드와 속성

  • QSlider(orientation, parent=None): 슬라이더 객체를 초기화합니다. orientation은 Qt.Horizontal 또는 Qt.Vertical을 사용하여 슬라이더의 방향을 설정합니다.
  • setMinimum(value): 슬라이더의 최소값을 설정합니다.
  • setMaximum(value): 슬라이더의 최대값을 설정합니다.
  • setValue(value): 슬라이더의 현재 값을 설정합니다.
  • value(): 슬라이더의 현재 값을 반환합니다.
  • setTickInterval(interval): 슬라이더의 틱 간격을 설정합니다.
  • setTickPosition(position): 슬라이더의 틱 위치를 설정합니다. QSlider.NoTicks, QSlider.TicksAbove, QSlider.TicksBelow, QSlider.TicksBothSides, QSlider.TicksLeft, QSlider.TicksRight 값을 사용할 수 있습니다.
  • setOrientation(orientation): 슬라이더의 방향을 설정합니다.

이벤트 처리

QSlider는 다양한 이벤트를 처리할 수 있습니다. 주요 시그널은 다음과 같습니다.

  • valueChanged: 슬라이더의 값이 변경될 때 발생합니다.
  • sliderPressed: 슬라이더가 눌릴 때 발생합니다.
  • sliderReleased: 슬라이더가 놓일 때 발생합니다.
  • sliderMoved: 슬라이더가 움직일 때 발생합니다.

예제 코드

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QSlider, QLabel, QVBoxLayout, QWidget
from PyQt5.QtCore import Qt

class SliderExample(QMainWindow):
    def __init__(self):
        super().__init__()

        self.slider = QSlider(Qt.Horizontal)
        self.slider.setMinimum(0)
        self.slider.setMaximum(100)
        self.slider.setValue(50)
        self.slider.setTickInterval(10)
        self.slider.setTickPosition(QSlider.TicksBelow)

        self.label = QLabel('Value: 50')

        self.slider.valueChanged.connect(self.update_label)

        layout = QVBoxLayout()
        layout.addWidget(self.slider)
        layout.addWidget(self.label)

        container = QWidget()
        container.setLayout(layout)
        self.setCentralWidget(container)

    def update_label(self, value):
        self.label.setText(f'Value: {value}')

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = SliderExample()
    ex.show()
    sys.exit(app.exec_())

 

2. QDial 사용법

QDial 개요

QDial은 회전식 다이얼 위젯으로, 주로 사용자로부터 각도를 기반으로 정수 입력을 받을 때 사용됩니다.

주요 메서드와 속성

  • QDial(parent=None): 다이얼 객체를 초기화합니다.
  • setMinimum(value): 다이얼의 최소값을 설정합니다.
  • setMaximum(value): 다이얼의 최대값을 설정합니다.
  • setValue(value): 다이얼의 현재 값을 설정합니다.
  • value(): 다이얼의 현재 값을 반환합니다.
  • setWrapping(on): 다이얼의 래핑 여부를 설정합니다. True로 설정하면 다이얼이 한 바퀴 돌아 다시 처음으로 돌아갑니다.
  • setNotchesVisible(visible): 다이얼의 눈금을 표시할지 여부를 설정합니다.

이벤트 처리

QDial도 QSlider와 비슷한 시그널을 제공합니다.

  • valueChanged: 다이얼의 값이 변경될 때 발생합니다.
  • sliderPressed: 다이얼이 눌릴 때 발생합니다.
  • sliderReleased: 다이얼이 놓일 때 발생합니다.
  • sliderMoved: 다이얼이 움직일 때 발생합니다.

예제 코드

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QDial, QLabel, QVBoxLayout, QWidget

class DialExample(QMainWindow):
    def __init__(self):
        super().__init__()

        self.dial = QDial()
        self.dial.setMinimum(0)
        self.dial.setMaximum(100)
        self.dial.setValue(50)
        self.dial.setNotchesVisible(True)

        self.label = QLabel('Value: 50')

        self.dial.valueChanged.connect(self.update_label)

        layout = QVBoxLayout()
        layout.addWidget(self.dial)
        layout.addWidget(self.label)

        container = QWidget()
        container.setLayout(layout)
        self.setCentralWidget(container)

    def update_label(self, value):
        self.label.setText(f'Value: {value}')

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = DialExample()
    ex.show()
    sys.exit(app.exec_())

결론

이 포스팅에서는 PyQt5에서 QSlider와 QDial의 모든 기능과 속성에 대해 알아보았습니다. 두 위젯 모두 다양한 사용자 입력을 처리할 수 있는 강력한 기능을 제공하며, 각 위젯의 다양한 메서드와 속성을 활용하여 원하는 동작을 구현할 수 있습니다. 이 글의 예제 코드를 통해 실제 애플리케이션에서 QSlider와 QDial을 어떻게 사용하는지 이해할 수 있기를 바랍니다. PyQt5를 사용하여 더욱 다양한 사용자 인터페이스를 구현해보세요!

728x90
반응형