From f95a0949671220acda632884a65e73630dbad8de Mon Sep 17 00:00:00 2001 From: Andreas Tsouchlos Date: Tue, 12 Apr 2022 20:54:00 +0200 Subject: [PATCH] Minor changes --- CMakeLists.txt | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++ MainWindow.cpp | 15 +++++++++++++ MainWindow.h | 21 ++++++++++++++++++ main.cpp | 11 ++++++++++ mainwindow.ui | 26 ++++++++++++++++++++++ 5 files changed, 132 insertions(+) create mode 100644 CMakeLists.txt create mode 100644 MainWindow.cpp create mode 100644 MainWindow.h create mode 100644 main.cpp create mode 100644 mainwindow.ui diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..e04c18d --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,59 @@ +cmake_minimum_required(VERSION 3.5) + +project(qt_test VERSION 0.1 LANGUAGES CXX) + +set(CMAKE_INCLUDE_CURRENT_DIR ON) + +set(CMAKE_AUTOUIC ON) +set(CMAKE_AUTOMOC ON) +set(CMAKE_AUTORCC ON) + +set(CMAKE_CXX_STANDARD 17) +set(CMAKE_CXX_STANDARD_REQUIRED ON) + +find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets) +find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Widgets) + +set(PROJECT_SOURCES + main.cpp + MainWindow.cpp + MainWindow.h + mainwindow.ui +) + +if(${QT_VERSION_MAJOR} GREATER_EQUAL 6) + qt_add_executable(qt_test + MANUAL_FINALIZATION + ${PROJECT_SOURCES} + ) +# Define target properties for Android with Qt 6 as: +# set_property(TARGET qt_test APPEND PROPERTY QT_ANDROID_PACKAGE_SOURCE_DIR +# ${CMAKE_CURRENT_SOURCE_DIR}/android) +# For more information, see https://doc.qt.io/qt-6/qt-add-executable.html#target-creation +else() + if(ANDROID) + add_library(qt_test SHARED + ${PROJECT_SOURCES} + ) +# Define properties for Android with Qt 5 after find_package() calls as: +# set(ANDROID_PACKAGE_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/android") + else() + add_executable(qt_test + ${PROJECT_SOURCES} + ) + endif() +endif() + +target_link_libraries(qt_test PRIVATE Qt${QT_VERSION_MAJOR}::Widgets) + +set_target_properties(qt_test PROPERTIES + MACOSX_BUNDLE_GUI_IDENTIFIER my.example.com + MACOSX_BUNDLE_BUNDLE_VERSION ${PROJECT_VERSION} + MACOSX_BUNDLE_SHORT_VERSION_STRING ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR} + MACOSX_BUNDLE TRUE + WIN32_EXECUTABLE TRUE +) + +if(QT_VERSION_MAJOR EQUAL 6) + qt_finalize_executable(qt_test) +endif() diff --git a/MainWindow.cpp b/MainWindow.cpp new file mode 100644 index 0000000..f092709 --- /dev/null +++ b/MainWindow.cpp @@ -0,0 +1,15 @@ +#include "MainWindow.h" +#include "./ui_mainwindow.h" + +MainWindow::MainWindow(QWidget *parent) + : QMainWindow(parent) + , ui(new Ui::MainWindow) +{ + ui->setupUi(this); +} + +MainWindow::~MainWindow() +{ + delete ui; +} + diff --git a/MainWindow.h b/MainWindow.h new file mode 100644 index 0000000..4643e32 --- /dev/null +++ b/MainWindow.h @@ -0,0 +1,21 @@ +#ifndef MAINWINDOW_H +#define MAINWINDOW_H + +#include + +QT_BEGIN_NAMESPACE +namespace Ui { class MainWindow; } +QT_END_NAMESPACE + +class MainWindow : public QMainWindow +{ + Q_OBJECT + +public: + MainWindow(QWidget *parent = nullptr); + ~MainWindow(); + +private: + Ui::MainWindow *ui; +}; +#endif // MAINWINDOW_H diff --git a/main.cpp b/main.cpp new file mode 100644 index 0000000..0a0916f --- /dev/null +++ b/main.cpp @@ -0,0 +1,11 @@ +#include "MainWindow.h" + +#include + +int main(int argc, char *argv[]) +{ + QApplication a(argc, argv); + MainWindow w; + w.show(); + return a.exec(); +} diff --git a/mainwindow.ui b/mainwindow.ui new file mode 100644 index 0000000..9085ec5 --- /dev/null +++ b/mainwindow.ui @@ -0,0 +1,26 @@ + + + MainWindow + + + + 0 + 0 + 800 + 631 + + + + MainWindow + + + + + + + + + + + +