이번 글에서는 체크 박스를 만들어 보겠습니다.
이번에는 새로운 프로젝트를 생성할 때 Form 파일을 만들어 보겠습니다.
우선 프로젝트를 생성합니다.
data:image/s3,"s3://crabby-images/8c9c9/8c9c92952cd1cdf15a23215ee8be8d5d73ff5d06" alt=""
data:image/s3,"s3://crabby-images/5b53f/5b53fd7dc7a31245f345e1992c621a6cc166d761" alt=""
data:image/s3,"s3://crabby-images/f506d/f506d4c37475ebefc031383110161b255e2800c3" alt=""
data:image/s3,"s3://crabby-images/3f16b/3f16b2170f1572c25faad00f44fb265bc96c616c" alt=""
data:image/s3,"s3://crabby-images/c614f/c614f977391c6ccf2ff721832ec3e8d161526cda" alt=""
data:image/s3,"s3://crabby-images/87112/8711201afd8185e15c05288ddc75b880d1e506e1" alt=""
data:image/s3,"s3://crabby-images/3f156/3f156f750fa3ceb96ee0fced9bb5af646af9139c" alt=""
위 순서대로 프로젝트를 생성하면서 Generate form 체크 박스엔 체크를 해서 생성합니다.
data:image/s3,"s3://crabby-images/f1267/f1267d6a122ecc47f8b8f5b68019623087cb9186" alt=""
Generate form에 체크를 하면 위와 같이 Form 폴더 하위에 .ui파일이 생성된 것을 볼 수 있습니다.
data:image/s3,"s3://crabby-images/97852/97852887d205c8750fec24cce5c5c54c4b2b0556" alt=""
.ui파일을 더블클릭 하면 위와 같이 폼 파일을 수정할 수 있는 화면을 볼 수 있습니다.
data:image/s3,"s3://crabby-images/29467/294678d4e0c62228a0379dec6ecfc8be6eb8c0bf" alt=""
그 다음 위와 같이 Vertical Layout을 드래그 하여 Widget에 추가한 뒤, Widget 사이즈 만큼 크기를 늘려줍니다.
data:image/s3,"s3://crabby-images/f42f2/f42f208e1db195285d207e23ea3024b6a7e9784d" alt=""
그리고 위와 같이 Horizontal Layout을 두 개 넣어줍니다.
data:image/s3,"s3://crabby-images/66042/660429734be9abed25ac297b1bb0930b8c23ee29" alt=""
data:image/s3,"s3://crabby-images/26126/2612679b6458dcdcb1164dfc5cdd522acd455785" alt=""
data:image/s3,"s3://crabby-images/f0095/f0095cbdfcfaaba41e8909b6266316eb927eddb0" alt=""
data:image/s3,"s3://crabby-images/e25f9/e25f9a11a704ad335642f6ab7de254d1a005669c" alt=""
그 다음 위쪽 Horizontal Layout에 체크 박스를 3개 넣어줍니다. 각 체크 박스의 objectName, text도 위 이미지같이 맞춰줍니다.
이제 코드로 넘어갑니다. widget.h에 아래와 같이 slot함수를 추가해줍니다.
#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QButtonGroup>
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE
class Widget : public QWidget
{
Q_OBJECT
public:
Widget(QWidget *parent = nullptr);
~Widget();
private:
Ui::Widget *ui;
private:
QButtonGroup *m_pbtnGroup; // 버튼 그룹
public slots:
void slot_checkbox_clicked();
};
#endif // WIDGET_H
wiget.cpp에 아래와 같이 코딩합니다.
#include "widget.h"
#include "ui_widget.h"
#include <QDebug>
Widget::Widget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
ui->setupUi(this);
m_pbtnGroup = new QButtonGroup(this);
m_pbtnGroup->addButton(ui->checkBox1);
m_pbtnGroup->setId(ui->checkBox1, 0); // checkbox1에 아이디 0
m_pbtnGroup->addButton(ui->checkBox2);
m_pbtnGroup->setId(ui->checkBox2, 1); // checkbox2에 아이디 1
m_pbtnGroup->addButton(ui->checkBox3);
m_pbtnGroup->setId(ui->checkBox3, 2); // checkbox3에 아이디 2
m_pbtnGroup->setExclusive(true); // 버튼 그룹에 등록된 체크박스끼리 체크가 중복되지 않게 설정
// 시그널, 슬롯 연결
connect(ui->checkBox1, SIGNAL(clicked()), this, SLOT(slot_checkbox_clicked()));
connect(ui->checkBox2, SIGNAL(clicked()), this, SLOT(slot_checkbox_clicked()));
connect(ui->checkBox3, SIGNAL(clicked()), this, SLOT(slot_checkbox_clicked()));
}
Widget::~Widget()
{
delete ui;
}
void Widget::slot_checkbox_clicked()
{
int iId = m_pbtnGroup->checkedId(); // 현재 체크되어 있는 체크박스 아이디 얻어오기
qDebug() << Q_FUNC_INFO << "(ID: " << iId << ")";
}
코드 내용은 주석을 확인해주세요
data:image/s3,"s3://crabby-images/ee84d/ee84d7bb3e16a0a49ff6698b8e929fd48ed375cd" alt=""
실행 시켜 확인해 봅니다.
data:image/s3,"s3://crabby-images/cccb6/cccb69c8762a6ff6cb3dc1788a41b7a58255509a" alt=""
출력창에 위와 같이 출력 된 것을 볼 수 있습니다.
원래 QComboBox도 같이 하려고 했는데 글이 길어져서 다음 글에 QComboBox를 하겠습니다.