한국어
Qt
 

C++ Class QPushButton 의 커스텀 이미지버튼

makersweb 2019.11.05 22:54 조회 수 : 11644

C++ Class Qt 응용프로그램을 개발할 때 사용자정의 이미지버튼을 만드는 방법은 여러가지가 있지만 기본은 QWidget을 서브클래싱하여 구현한다. 위젯 기반의 Qt응용프로그램 개발에서 자주 사용되는 QPushButton이 있는데 QPushButton 클래스 또한 QWidget 을 기반으로 두고있음을 알 수 있다.

 

간단한 이미지 버튼을 만드는 방법중에 QPushButton을 사용하는 방법으로 Qt Style Sheet를 이용하면 간단하게 구현할 수 있다. Qt Style Sheets는 위젯의 모양을 사용자 정의하여 다양한 형태로 바꿀 수 있다. https://doc.qt.io/qt-5/stylesheet-reference.html

 

다음은 버튼을 클릭하지 않았을 때의 normal상태와 클릭했을때의 pressed 상태의 이미지 버튼을 구현하는 간단한 예제이다.

QPushButton *mybutton = new QPushButton(this);

mybutton->setStyleSheet(
            "                                  \
            QPushButton {                      \
                border-image: url(:/normal.png); \
                background-repeat: no-repeat;  \
            }                                  \
                                                \
            QPushButton:pressed {              \
                border-image: url(:/pressed.png); \
                background-repeat: no-repeat;  \
            }                                  \
            ");

mybutton->setGeometry(0, 0, 45, 131);

 

다음과 같이 간단한 사용자 정의 이미지 버튼을 만들 수 있다.

makerswebImageButton.gif

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 118557
100 Qt로 데이터를 직렬화(serialization)하는 방법 makersweb 2020.08.04 6931
99 qbs 사용 방법(Helloworld) file makersweb 2019.10.23 6923
98 ShaderEffect QML Type 을 이용한 그래픽효과 file makersweb 2018.12.09 6887
97 [Qt News] Qt for Python을 위한 기술 비전 j2doll 2019.08.20 6795
96 Qt Creator 에서 GitHub Copilot 사용하기 file makersweb 2024.04.13 6737
95 QML에서 멀티 스레드(multithreading) 프로그래밍 file makersweb 2019.05.25 6695
94 Qt 6.0의 개발 호스트 및 대상 플랫폼 makersweb 2020.09.16 6688
93 [Qt News] Qt6 Git 개발 초기 단계 시작하기 j2doll 2019.08.02 6671
92 Qml 어플리케이션 정적 빌드 file makersweb 2018.07.27 6652
91 [Qt News] Qt 6 기술 비전 (Technical vision for Qt 6) [2] j2doll 2019.08.08 6617
90 많은 리소스를 사용하는 Qt프로젝트에서 고려해봐야 할 qmake 옵션 makersweb 2019.10.11 6531
89 QML에서 undefined를 확인하는 방법 makersweb 2017.11.29 6521
88 싱글 샷(Single-Shot) 시그널/슬롯 연결 makersweb 2021.05.12 6514
87 안드로이드용 Qt 6.2 makersweb 2021.10.02 6484
86 앱을 종료할 때 QML 바인딩 오류를 피하는 방법 makersweb 2021.08.08 6454
85 라즈베리파이3에서 Boot to Qt 실행해보기 makersweb 2019.11.13 6377
84 Qt for MCU 1.0 릴리즈 makersweb 2019.12.10 6367
83 소스코드에서 환경변수 가져오기와 설정하기 makersweb 2018.10.08 6354
82 GPU가 없는 장치에서 Qt Quick을 사용 makersweb 2019.04.02 6350
81 QML의 사용자 정의 Image makersweb 2023.09.17 6290