한국어
Qt
 

QCoreApplication, QGuiApplication, QApplication 클래스

QCoreApplication 클래스는 UI가 없는 Qt 애플리케이션을 위한 기본 이벤트 루프와 애플리케이션의 설정, 실행 경로등의 정보들이 포함되어 있다. 프로세스내에서 오직 하나의 QCoreApplication 객체만 생성되어야한다. QCoreApplication 의 이벤트 루프에서는 내부 이벤트 및 운영 체제의 이벤트 (예 : 타이머 및 소켓 이벤트등) 를 처리하는데 exec() 호출로 시작된다. 이벤트 루프가 종료(quit()) 될 때까지 exec() 함수는 반환되지 않으며 일반적으로 exec()함수는 main()함수의 return 으로 호출한다.

 

만약 메인 스레드에서 오래걸리는 작업을 실행하면 이벤트를 처리할 수 없으므로 애플리케이션의 응답성을 잃을 수 있다. 따라서 오래걸리는 작업은 별도의 스레드에서 처리하거나 processEvents()를 호출하여 응용프로그램의 응답성을 유지해야 한다.

 

QGuiApplication 은 QCoreApplication 의 파생클래스로써 윈도우 시스템과 관련된 이벤트(입력장치 이벤트등) 처리가 포함되어 있다. 또한 폰트(QFont)를 설정하거나 QClipboard, QInputMethod, QWindowList 등을 제공한다. GUI가 없는 Qt 애플리케이션의 경우 Qt GUI 모듈에 의존하지 않으므로 QCoreApplication 을 대신 사용한다.

 

QApplication 은 QWidget 기반 애플리케이션에 필요한 기능을 갖춘 QGuiApplication 의 파생클래스이다. 위젯의 초기화, 마무리등 QWidget과 밀접하게 관련된 일을 수행하기 때문에 QWidget을 사용하는 응응프로그램에서 QApplication 을 생성하지 않으면 다음과 같은 메세지만 출력할 뿐 실행되지 않는다.

QWidget: Cannot create a QWidget without QApplication

 

QApplication 을 사용하려면 프로젝트파일(*.pro)에 다음줄을 추가한다.

QT += widgets

 

비 QWidget 기반 Qt 애플리케이션의 경우(예를 들면 Qt Quick 2)는 QtWidget 라이브러리에 의존하지 않으므로 QGuiApplication 을 사용하면된다.

 

다음 예제는 적절한 유형의 애플리케이션 객체를 동적으로 생성하는 방법을 보여준다. 이 애플리케이션을 -no-gui 옵션과 함께 실행하면 GUI가 없는 버전이 된다.

QCoreApplication* createApplication(int &argc, char *argv[])
{
    for (int i = 1; i < argc; ++i)
        if (!qstrcmp(argv[i], "-no-gui"))
            return new QCoreApplication(argc, argv);
    return new QApplication(argc, argv);
}

int main(int argc, char* argv[])
{
    QScopedPointer<QCoreApplication> app(createApplication(argc, argv));

    if (qobject_cast<QApplication *>(app.data())) {
       // start GUI version...
    } else {
       // start non-GUI version...
    }

    return app->exec();
}

 

qApp 및 qGuiApp 전역 포인터

생성된 애플리케이션 객체는 qApp 또는 qGuiApp 전역 포인터로 액세스 할 수 있다. 이 전역 포인터는 다음과 같이 정의된다.

 

QCoreApplication 을 생성한 경우

#define qApp QCoreApplication::instance()

 

QApplication 을 생성한 경우

#define qApp (static_cast<QApplication *>(QCoreApplication::instance()))

 

QGuiApplication 을 생성한 경우

#define qApp (static_cast<QGuiApplication *>(QCoreApplication::instance()))

#define qGuiApp (static_cast<QGuiApplication *>(QCoreApplication::instance()))

 

또한 qApp 포인터와 동등한 포인터를 반환하는 instance() 함수를 통해서도 액세스 할 수 있다.

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 85965
139 Qml 기본 컴포넌트 강좌 (1) file makersweb 2019.01.03 12087
138 Qml 기본 컴포넌트 강좌 (2) [2] file makersweb 2019.01.05 8632
137 안드로이드 가상장치 사용 file makersweb 2019.01.13 1074
136 Qt응용프로그램 실행 시 콘솔창(터미널)같이 띄우기 file makersweb 2019.01.16 4490
135 QNetworkAccessManager를 통해 HTTP POST 하는 예제 makersweb 2019.01.17 4776
134 구글 클라우드 Speech-To-Text API를 Qt기반(C++, Qml)테스트 [7] file makersweb 2019.01.20 2620
133 Qt SQL을 이용한 가벼운 데이터베이스 다루기 [1] file 운영자 2019.01.23 6968
132 QString 문자열 다루기 예제 운영자 2019.01.26 40163
131 Qml 기본 컴포넌트 강좌 (3) - 배치(positioning) 컴포넌트 file 운영자 2019.02.10 4877
130 Qt Bluetooth를 이용한 시리얼(Serial) 통신 file makersweb 2019.02.17 3571
129 Qml 기본 컴포넌트 강좌 (4) - 모델 리스팅(Listing) file 운영자 2019.02.23 5312
128 Qt5기반 독립 프로세스(out-of-process)로 동작하는 가상키보드(virtual keyboard) file makersweb 2019.02.24 2628
127 qInstallMessageHandler를 이용한 디버그 메세지 출력 제어하기 makersweb 2019.02.25 1353
126 QTextCodec클래스를 사용하여 유니코드와 EUC-KR 변환 makersweb 2019.03.25 2893
125 GPU가 없는 장치에서 Qt Quick을 사용 makersweb 2019.04.02 1857
124 tslib의 ts_calibrate를 응용해서 Qt로 터치보정기능 구현 file makersweb 2019.04.06 1368
123 QML 전역 객체 (Global Object) file makersweb 2019.04.10 1049
122 QML과 QtQuick 모듈 개념과 기본 타입들 makersweb 2019.04.26 13411
121 Windows에서 Qt D-Bus를 사용하여 프로세스간 통신(IPC) file makersweb 2019.05.02 4483
120 가상키보드(Qt Virtual Keyboard)를 사용하는 방법 [32] file makersweb 2019.05.03 221333