QGridLayout QT5 예제입니다.
아래 사이트의 QT 강좌를 공부하며 정리 차원에서 작성하는 포스트입니다.
2021. 08. 31 - 최초작성
터미널에서 빌드 및 실행을 진행합니다. 편집기는 익숙한 것을 사용하세요.
1. 프로젝트 파일들을 저장할 디렉토리를 생성하고 이동합니다.
webnautes@DESKTOP-8TRVTF8:~$ mkdir Grid_Layout
webnautes@DESKTOP-8TRVTF8:~$ cd Grid_Layout
2. grid.cpp 파일을 생성하여 다음 코드를 복사하여 붙여넣기합니다.
#include <QApplication> #include <QWidget> #include <QGridLayout> #include <QLabel> #include <QLineEdit> #include <QTextEdit> class MainWindow : public QWidget { public: MainWindow(QWidget *parent = nullptr); }; MainWindow::MainWindow(QWidget *parent) : QWidget(parent) { auto *grid = new QGridLayout(this); grid->setVerticalSpacing(15); grid->setHorizontalSpacing(10); auto *title = new QLabel("Title:", this); grid->addWidget(title, 0, 0, 1, 1); title->setAlignment(Qt::AlignRight | Qt::AlignVCenter); auto *edt1 = new QLineEdit(this); grid->addWidget(edt1, 0, 1, 1, 1); auto *author = new QLabel("Author:", this); grid->addWidget(author, 1, 0, 1, 1); author->setAlignment(Qt::AlignRight | Qt::AlignVCenter); auto *edt2 = new QLineEdit(this); grid->addWidget(edt2, 1, 1, 1, 1); auto *review = new QLabel("Review:", this); grid->addWidget(review, 2, 0, 1, 1); review->setAlignment(Qt::AlignRight | Qt::AlignTop); auto *te = new QTextEdit(this); grid->addWidget(te, 2, 1, 3, 1); setLayout(grid); } int main(int argc, char *argv[]) { QApplication app(argc, argv); MainWindow window; window.setWindowTitle("Review"); window.show(); return app.exec(); } |
auto *grid = new QGridLayout(this);
그리드 레이아웃 객체를 생성합니다.
grid->setVerticalSpacing(15);
grid->setHorizontalSpacing(10);
위젯 추가시 가로, 세로 간격을 설정합니다.
auto *title = new QLabel("Title:", this);
grid->addWidget(title, 0, 0, 1, 1);
title->setAlignment(Qt::AlignRight | Qt::AlignVCenter);
라벨 객체를 생성하고 addWidget 메소드를 사용하여 라벨 객체를 0행 0열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
SetAlignment 메소드를 사용하여 라벨을 수평방향으론 오른쪽, 수직 방향은 중앙으로 합니다.
auto *edt1 = new QLineEdit(this);
grid->addWidget(edt1, 0, 1, 1, 1);
에디터 객체를 생성하고 addWidget 메소드를 사용하여 에디터 객체를 0행 1열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
auto *author = new QLabel("Author:", this);
grid->addWidget(author, 1, 0, 1, 1);
author->setAlignment(Qt::AlignRight | Qt::AlignVCenter);
라벨 객체를 생성하고 addWidget 메소드를 사용하여 라벨 객체를 1행 0열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
SetAlignment 메소드를 사용하여 라벨을 수평방향으론 오른쪽, 수직 방향은 중앙으로 합니다.
auto *edt2 = new QLineEdit(this);
grid->addWidget(edt2, 1, 1, 1, 1);
에디터 객체를 생성하고 addWidget 메소드를 사용하여 에디터 객체를 1행 1열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
auto *review = new QLabel("Review:", this);
grid->addWidget(review, 2, 0, 1, 1);
review->setAlignment(Qt::AlignRight | Qt::AlignTop);
라벨 객체를 생성하고 addWidget 메소드를 사용하여 라벨 객체를 2행 0열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
SetAlignment 메소드를 사용하여 라벨을 수평방향으론 오른쪽, 수직 방향은 중앙으로 합니다.
auto *te = new QTextEdit(this);
grid->addWidget(te, 2, 1, 3, 1);
에디터 객체를 생성하고 addWidget 메소드를 사용하여 에디터 객체를 2행 1열에 배치합니다. 뒤에 파라미터 2개는 셀병합처럼 사용하기 위해 필요한데 지금은 병합하지 않으므로 행, 열 방향 모두 1입니다.
setLayout(grid);
그리드 레이아웃 객체를 레이아웃으로 설정합니다.
3. qmake -project 명령을 사용하면 qt 프로젝트 파일을 생성해줍니다.
프로젝트를 구성하는 파일의 정보를 가지고 확장자가 pro인 파일이 자동으로 생성합니다.
webnautes@DESKTOP-8TRVTF8:~/Grid_Layout$ qmake -project
4. 확장자가 pro인 qt 프로젝트 파일이 생성될 때, qt 코드에서 사용중인 qt 모듈 이름이 자동으로 추가되지 않습니다.
일단 진행해보고 컴파일 에러가 나면 qt 프로젝트 파일을 열어서 사용중인 qt 모듈 이름을 추가해줘야 합니다.
다음 한줄을 추가합니다.
QT += widgets
5. qmake 명령으로 Makefile을 생성합니다.
webnautes@DESKTOP-8TRVTF8:~/Grid_Layout$ qmake
6. make 명령은 Makefile에 기술된대로 컴파일 및 링크를 실행합니다.
중간 결과물인 확장자 .o인 오브젝트 파일과 프로젝트 디렉토리와 동일한 이름을 갖는 실행파일이 생성됩니다.
webnautes@DESKTOP-8TRVTF8:~/Grid_Layout$ make
이제 실행시켜 보면 푸쉬버튼 두 개가 추가된 윈도우가 보입니다.
webnautes@DESKTOP-8TRVTF8:~/Form_Example$ ./Grid_Layout
QT 강좌 01 - Hello World
https://webnautes.tistory.com/1859
QT 강좌 02 - Simple GUI
https://webnautes.tistory.com/1860
QT 강좌 03 - Push Button
https://webnautes.tistory.com/1861
QT 강좌 04 - QLabel
https://webnautes.tistory.com/1862
QT 강좌 05 - QMenu
https://webnautes.tistory.com/1863
QT 강좌 06 - QToolBar
https://webnautes.tistory.com/1864
QT 강좌 07 - QVBoxLayout, QHBoxLayout
https://webnautes.tistory.com/1865
QT 강좌 08 - Button
https://webnautes.tistory.com/1866
QT 강좌 09 - QListWidget
https://webnautes.tistory.com/1867
QT 강좌 10 - QFormLayout
https://webnautes.tistory.com/1868
QT 강좌 11 - QGridLayout
https://webnautes.tistory.com/1869
QT 강좌 12 - QGridLayout 2
https://webnautes.tistory.com/1870
'Qt > Qt 강좌' 카테고리의 다른 글
QT 강좌 11 - QGridLayout (0) | 2023.10.05 |
---|---|
QT 강좌 10 - QFormLayout (0) | 2023.10.05 |
QT 강좌 09 - QListWidget (0) | 2023.10.05 |
QT 강좌 08 - Button (0) | 2023.10.05 |
QT 강좌 07 - QVBoxLayout, QHBoxLayout (0) | 2023.10.05 |
시간날때마다 틈틈이 이것저것 해보며 블로그에 글을 남깁니다.
블로그의 문서는 종종 최신 버전으로 업데이트됩니다.
여유 시간이 날때 진행하는 거라 언제 진행될지는 알 수 없습니다.
영화,책, 생각등을 올리는 블로그도 운영하고 있습니다.
https://freewriting2024.tistory.com
제가 쓴 책도 한번 검토해보세요 ^^
그렇게 천천히 걸으면서도 그렇게 빨리 앞으로 나갈 수 있다는 건.
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!