From 5fdd0cbbf6081afa85661a89061eacbd099e97d9 Mon Sep 17 00:00:00 2001 From: tobiglaser <76131623+tobiglaser@users.noreply.github.com> Date: Tue, 2 Aug 2022 23:43:39 +0200 Subject: [PATCH] introduce Qt with minimal gui application --- CMakeLists.txt | 53 ++++++++++++++++++++++++++++++++++++++++ src/ControlDeveloper.cpp | 11 +++++++++ src/mainwindow.cpp | 17 +++++++++++++ src/mainwindow.h | 17 +++++++++++++ 4 files changed, 98 insertions(+) create mode 100644 src/ControlDeveloper.cpp create mode 100644 src/mainwindow.cpp create mode 100644 src/mainwindow.h diff --git a/CMakeLists.txt b/CMakeLists.txt index c7fa4b6..1689e18 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -7,6 +7,59 @@ project("Info3_Praktikum" C CXX) set(CMAKE_C_STANDARD 17) set(CMAKE_CXX_STANDARD 20) +set(CMAKE_CXX_STANDARD_REQUIRED ON) +set(CMAKE_INCLUDE_CURRENT_DIR ON) + +set(CMAKE_AUTOUIC ON) +set(CMAKE_AUTOMOC ON) +set(CMAKE_AUTORCC ON) + +find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets) +find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Widgets) + +set(PROJECT_SOURCES + src/ControlDeveloper.cpp + src/mainwindow.cpp + src/mainwindow.h +) + +if(${QT_VERSION_MAJOR} GREATER_EQUAL 6) + qt_add_executable(ControlDeveloper + MANUAL_FINALIZATION + ${PROJECT_SOURCES} + ) +# Define target properties for Android with Qt 6 as: +# set_property(TARGET Text2Console 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(ControlDeveloper 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(ControlDeveloper + ${PROJECT_SOURCES} + ) + endif() +endif() + +target_link_libraries(ControlDeveloper PRIVATE Qt${QT_VERSION_MAJOR}::Widgets) + +set_target_properties(ControlDeveloper 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(ControlDeveloper) +endif() + add_executable("Test_Command_List" src/testCommandList.cpp diff --git a/src/ControlDeveloper.cpp b/src/ControlDeveloper.cpp new file mode 100644 index 0000000..46d850b --- /dev/null +++ b/src/ControlDeveloper.cpp @@ -0,0 +1,11 @@ +#include <QApplication> +#include "mainwindow.h" + + +int main(int argc, char *argv[]) +{ + QApplication a(argc, argv); + MainWindow w; + w.show(); + return a.exec(); +} \ No newline at end of file diff --git a/src/mainwindow.cpp b/src/mainwindow.cpp new file mode 100644 index 0000000..2f94d13 --- /dev/null +++ b/src/mainwindow.cpp @@ -0,0 +1,17 @@ +#include <QPushButton> +#include <QLineEdit> +#include <QBoxLayout> + +#include "mainwindow.h" + +MainWindow::MainWindow(QWidget *parent) + : QMainWindow(parent) +{ +//general + setWindowTitle("ControlDeveloper"); +} + +MainWindow::~MainWindow() +{ +} + diff --git a/src/mainwindow.h b/src/mainwindow.h new file mode 100644 index 0000000..e38abb1 --- /dev/null +++ b/src/mainwindow.h @@ -0,0 +1,17 @@ +#ifndef MAINWINDOW_H +#define MAINWINDOW_H + +#include <QMainWindow> + +class MainWindow : public QMainWindow +{ + Q_OBJECT + +private: + +public: + MainWindow(QWidget *parent = nullptr); + ~MainWindow(); + +}; +#endif // MAINWINDOW_H -- GitLab