From 27504922e961eb8b0ed3dc6413d3098b0163c6e3 Mon Sep 17 00:00:00 2001 From: daleclack Date: Sun, 7 Nov 2021 17:52:33 +0800 Subject: [PATCH] Add gtk115 --- GCR_CMake | 2 +- Gtkmm3/gtk115_calander/CMakeLists.txt | 62 +++++++++++++++++++++++++++ Gtkmm3/gtk115_calander/src/main.cc | 22 ++++++++++ 3 files changed, 85 insertions(+), 1 deletion(-) create mode 100644 Gtkmm3/gtk115_calander/CMakeLists.txt create mode 100644 Gtkmm3/gtk115_calander/src/main.cc diff --git a/GCR_CMake b/GCR_CMake index b5a7fe5..6ea69ec 160000 --- a/GCR_CMake +++ b/GCR_CMake @@ -1 +1 @@ -Subproject commit b5a7fe5719ed0df8998b2ba961e09d967a385ec6 +Subproject commit 6ea69eca6817aead20a2cb87cdd08ab8e9a173cd diff --git a/Gtkmm3/gtk115_calander/CMakeLists.txt b/Gtkmm3/gtk115_calander/CMakeLists.txt new file mode 100644 index 0000000..69319de --- /dev/null +++ b/Gtkmm3/gtk115_calander/CMakeLists.txt @@ -0,0 +1,62 @@ +set(CMAKE_CXX_STANDARD 17) +cmake_minimum_required(VERSION 3.0.0) +project(gtk115 VERSION 1.0.0) + +list(APPEND CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/../../GCR_CMake/macros) +include(GlibCompileResourcesSupport) + +include(CTest) +enable_testing() + +set(CPACK_PROJECT_NAME ${PROJECT_NAME}) +set(CPACK_PROJECT_VERSION ${PROJECT_VERSION}) + +include(CPack) +include_directories(.) +include_directories(..) + +find_package (PkgConfig REQUIRED) +pkg_check_modules (GTKMM3 REQUIRED gtkmm-3.0) +include_directories (${GTKMM3_INCLUDE_DIRS}) +link_directories (${GTKMM3_LIBRARY_DIRS}) + +#Compile Resource + +# set(RESOURCE_LIST +# gnome-fs-directory.png +# gnome-fs-regular.png +# icons/24x24/actions/view-grid-symbolic.png +# icons/24x24/actions/view-list-symbolic.png +# icons/48x48/actions/dialog-error.png) + +# compile_gresources(RESOURCE_FILE +# XML_OUT +# TYPE EMBED_C +# RESOURCES ${RESOURCE_LIST} +# PREFIX "/org/gtk/daleclack" +# SOURCE_DIR ${PROJECT_SOURCE_DIR}/../default_res) + +# Add a custom target to the makefile. Now make builds our resource file. +# It depends on the output RESOURCE_FILE. +# add_custom_target(resource ALL DEPENDS ${RESOURCE_FILE}) + +#For win32 platform,use rc resource and .ico icon +if(WIN32) + SET(CMAKE_RC_COMPILER x86_64-w64-mingw32-windres) + set(app_WINRC ../icon.rc) + set_property(SOURCE ../icon.rc APPEND PROPERTY + OBJECT_DEPENDS ${PROJECT_SOURCE_DIR}/../icon.ico + ) + add_executable(${PROJECT_NAME} WIN32 ${app_WINRC} src/main.cc) +else() + add_executable(${PROJECT_NAME} src/main.cc) + +endif(WIN32) + +#Add command to generate .gitignore +add_custom_command(TARGET ${PROJECT_NAME} + COMMAND echo \"*\" > ${CMAKE_BINARY_DIR}/.gitignore + COMMAND echo \"**/*\" > ${CMAKE_BINARY_DIR}/.hgignore) + +SET (CMAKE_EXTRA_CXX_FLAGS ${GTKMM3_CFLAGS_OTHER}) +target_link_libraries (${PROJECT_NAME} ${GTKMM3_LIBRARIES} -lpthread) diff --git a/Gtkmm3/gtk115_calander/src/main.cc b/Gtkmm3/gtk115_calander/src/main.cc new file mode 100644 index 0000000..ffc6aac --- /dev/null +++ b/Gtkmm3/gtk115_calander/src/main.cc @@ -0,0 +1,22 @@ +#include + +class MyWin : public Gtk::Window{ + public: + MyWin(){ + //Initalize Window + set_icon_name("org.gtk.daleclack"); + set_default_size(400,300); + + //Add a Calander + add(calander); + show_all_children(); + } + private: + Gtk::Calendar calander; +}; + +int main(int argc,char ** argv){ + auto app = Gtk::Application::create(argc,argv,"org.gtk.daleclack"); + MyWin window; + app->run(window); +}