diff --git a/Gtk4/gtk148_listview/.vscode/settings.json b/Gtk4/gtk148_listview/.vscode/settings.json new file mode 100644 index 0000000..b4d8c35 --- /dev/null +++ b/Gtk4/gtk148_listview/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "C_Cpp.default.configurationProvider": "ms-vscode.cmake-tools" +} \ No newline at end of file diff --git a/Gtk4/gtk148_listview/CMakeLists.txt b/Gtk4/gtk148_listview/CMakeLists.txt new file mode 100644 index 0000000..55f0cf1 --- /dev/null +++ b/Gtk4/gtk148_listview/CMakeLists.txt @@ -0,0 +1,76 @@ +set(CMAKE_CXX_STANDARD 17) +cmake_minimum_required(VERSION 3.0.0) +project(gtk147_listview 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 PkgConfig to use gtkmm3 +find_package (PkgConfig REQUIRED) +pkg_check_modules (GTKMM4 REQUIRED gtkmm-4.0) +include_directories (${GTKMM4_INCLUDE_DIRS}) +link_directories (${GTKMM4_LIBRARY_DIRS}) + +#Find Gettext +# find_package (Gettext REQUIRED) +# set(PO_DIR ${CMAKE_BINARY_DIR}/po/zh_CN/LC_MESSAGES) + +#Source files +set(SOURCE_FILE src/main.cpp src/MainWin.cpp) + +#Compile Resource + +# set(RESOURCE_LIST +# custom_style.css +# STRIPBLANKS context_menu.xml +# STRIPBLANKS default_menu.xml +# STRIPBLANKS prefs_stack.ui +# ) + +# compile_gresources(RESOURCE_FILE +# XML_OUT +# TYPE EMBED_C +# RESOURCES ${RESOURCE_LIST} +# PREFIX "/org/gtk/daleclack" +# SOURCE_DIR ${PROJECT_SOURCE_DIR}/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 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} ${SOURCE_FILE}) + add_custom_command( TARGET ${PROJECT_NAME} + COMMAND echo * > ${CMAKE_BINARY_DIR}/.gitignore + COMMAND echo **/* > ${CMAKE_BINARY_DIR}/.hgignore) +else() + add_executable(${PROJECT_NAME} ${SOURCE_FILE}) + add_custom_command( TARGET ${PROJECT_NAME} + COMMAND echo \"*\" > ${CMAKE_BINARY_DIR}/.gitignore + COMMAND echo \"**/*\" > ${CMAKE_BINARY_DIR}/.hgignore) +endif(WIN32) + +#Add command to generate .gitignore and .mo files +# add_custom_command( TARGET ${PROJECT_NAME} +# COMMAND mkdir -p ${PO_DIR} +# COMMAND ${GETTEXT_MSGFMT_EXECUTABLE} ${CMAKE_SOURCE_DIR}/po/zh_CN.po -o ${PO_DIR}/${PROJECT_NAME}.mo) + +SET (CMAKE_EXTRA_CXX_FLAGS ${GTKMM4_CFLAGS_OTHER}) +target_link_libraries (${PROJECT_NAME} ${GTKMM4_LIBRARIES} -lpthread) diff --git a/Gtk4/gtk148_listview/src/MainWin.cpp b/Gtk4/gtk148_listview/src/MainWin.cpp new file mode 100644 index 0000000..7eb4d4b --- /dev/null +++ b/Gtk4/gtk148_listview/src/MainWin.cpp @@ -0,0 +1,35 @@ +#include "MainWin.hh" + +struct _MainWin{ + GtkApplicationWindow parent_instance; + GListModel *model; + GtkListView *view; +}; + +G_DEFINE_TYPE(MainWin, main_win, GTK_TYPE_APPLICATION_WINDOW) + +static GListModel *create_list_model() +{ + GListStore *store; + + // Create the list store + store = g_list_store_new(G_TYPE_STRING); + + // Fill the store + g_list_store_append(store, g_string_new("Item 1")); + g_list_store_append(store, g_string_new("Item 2")); + g_list_store_append(store, g_string_new("Item 3")); + + return G_LIST_MODEL(store); +} + +static void main_win_init(MainWin *self){ + +} + +static void main_win_class_init(MainWinClass *klass){ +} + +MainWin *main_win_new(GtkApplication *app){ + return MAIN_WIN(g_object_new(main_win_get_type(), "application", app, NULL)); +} diff --git a/Gtk4/gtk148_listview/src/MainWin.hh b/Gtk4/gtk148_listview/src/MainWin.hh new file mode 100644 index 0000000..184fd6b --- /dev/null +++ b/Gtk4/gtk148_listview/src/MainWin.hh @@ -0,0 +1,7 @@ +#pragma once + +#include + +G_DECLARE_FINAL_TYPE(MainWin, main_win, MAIN, WIN, GtkApplicationWindow) + +MainWin *main_win_new(GtkApplication *app); diff --git a/Gtk4/gtk148_listview/src/main.cpp b/Gtk4/gtk148_listview/src/main.cpp new file mode 100644 index 0000000..6bec0bb --- /dev/null +++ b/Gtk4/gtk148_listview/src/main.cpp @@ -0,0 +1,14 @@ +#include "MainWin.hh" + +static void gtkmain(GtkApplication *app, gpointer data){ + MainWin *window = main_win_new(app); + gtk_window_present(GTK_WINDOW(window)); +} + +int main(int argc, char **argv){ + // Create a application and run + GtkApplication *app = gtk_application_new("org.gtk.daleclack", G_APPLICATION_NON_UNIQUE); + g_signal_connect(app, "activate", G_CALLBACK(gtkmain), NULL); + return g_application_run(G_APPLICATION(app), argc, argv); +} +