이번 글에서는 Widget에 QPushButton과 QLabel을 만들어 보도록 하겠습니다.
QPushButton은 화면에서 버튼을 그리며 QLabel은 텍스트를 표시하기 위해 사용됩니다.
우선 아래와 순서에 맞춰 Widget을 생성해줍니다.
data:image/s3,"s3://crabby-images/715e7/715e729b76fa73e93111175c6a45945a9eaa8eed" alt=""
data:image/s3,"s3://crabby-images/9539f/9539ff06b30ba5ba5e3190fcb10d7d01e8191c09" alt=""
data:image/s3,"s3://crabby-images/068cf/068cffa9d7ded94182dbbd981f8e8ee74cd22455" alt=""
data:image/s3,"s3://crabby-images/b22e5/b22e57b75e4e6ad3d8ff926575d9415109853faf" alt=""
data:image/s3,"s3://crabby-images/24618/2461861cdde53e11397524f752ba4504d1adb5d4" alt=""
data:image/s3,"s3://crabby-images/90fa6/90fa65825e1cddf3dfe9a9a2de4aa457f547f1c2" alt=""
data:image/s3,"s3://crabby-images/581d9/581d9c53d732263dfa2ecbf3dd1ff7bc24385dd7" alt=""
QPushButton 만들기
우선 QPushButton 부터 만들어 보겠습니다.
widget.h에 아래와 같이 코딩합니다.
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QPushButton>
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = nullptr);
~Widget();
private:
QPushButton *m_pButton;
int m_iNumber;
private slots:
void slot_btn_push();
};
#endif // WIDGET_H
widget.cpp에 아래와 같이 코딩합니다.
#include "widget.h"
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
m_iNumber = 0;
setFixedSize(300, 200);
m_pButton = new QPushButton("버튼", this);
m_pButton->setGeometry(10, 10, 100, 30);
connect(m_pButton, SIGNAL(pressed()), this, SLOT(slot_btn_push()));
}
Widget::~Widget()
{
}
void Widget::slot_btn_push()
{
m_iNumber++;
}
여기까지 정상적으로 작성하셨으면 아래와 같이 실행됩니다.
data:image/s3,"s3://crabby-images/b3fe8/b3fe814eb4a3489dad914991eff30b07c7a30ab1" alt=""
하지만 버튼을 눌러도 아무런 표시를 하지 않습니다. QLabel 클래스를 사용하여 표시를 해보겠습니다.
QLabel 만들기
QLabel을 아래와 같이 .h에 선언해줍니다.
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QPushButton>
#include <QLabel>
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = nullptr);
~Widget();
private:
QPushButton *m_pButton;
int m_iNumber;
QLabel *m_pLabel;
private slots:
void slot_btn_push();
};
#endif // WIDGET_H
cpp에 QLabel을 생성하는 코드를 짜줍니다.
#include "widget.h"
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
m_iNumber = 0;
setFixedSize(300, 200);
m_pButton = new QPushButton("버튼", this);
m_pButton->setGeometry(10, 10, 100, 30);
connect(m_pButton, SIGNAL(pressed()), this, SLOT(slot_btn_push()));
m_pLabel = new QLabel(this);
m_pLabel->setGeometry(10, 40, 100, 30);
}
Widget::~Widget()
{
}
void Widget::slot_btn_push()
{
m_iNumber++;
}
버튼을 클릭했을 때 QLabel에 표시하기 위해 아래와 같이 slot 함수를 정의합니다.
void Widget::slot_btn_push()
{
m_iNumber++;
QString str = QString("Number: %1").arg(m_iNumber);
m_pLabel->setText(str);
}
전체 실행
실행시켜 확인해봅니다.
data:image/s3,"s3://crabby-images/6efd3/6efd39d810f393802d753f5af34f827b04512248" alt=""
이상으로 QPushButton과 QLabel에 대해 알아보았습니다.
깃허브: https://github.com/3001ssw/qt_cpp_study/tree/main/3QPushButton_QLabel/code