From 769e969eff394ff3d0535f55a81a8c7059c2b84f Mon Sep 17 00:00:00 2001 From: daleclack Date: Wed, 29 Dec 2021 23:12:35 +0800 Subject: [PATCH] Add gtk120 --- Gtk4/gtk120_music_res/.vscode/settings.json | 3 + Gtk4/gtk120_music_res/CMakeLists.txt | 61 +++++++++++++++++++ .../res/Yanni-Nightingale.mp3.md | 0 Gtk4/gtk120_music_res/src/main.cpp | 22 +++++++ 4 files changed, 86 insertions(+) create mode 100644 Gtk4/gtk120_music_res/.vscode/settings.json create mode 100644 Gtk4/gtk120_music_res/CMakeLists.txt create mode 100644 Gtk4/gtk120_music_res/res/Yanni-Nightingale.mp3.md create mode 100644 Gtk4/gtk120_music_res/src/main.cpp diff --git a/Gtk4/gtk120_music_res/.vscode/settings.json b/Gtk4/gtk120_music_res/.vscode/settings.json new file mode 100644 index 0000000..b4d8c35 --- /dev/null +++ b/Gtk4/gtk120_music_res/.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/gtk120_music_res/CMakeLists.txt b/Gtk4/gtk120_music_res/CMakeLists.txt new file mode 100644 index 0000000..16e6b96 --- /dev/null +++ b/Gtk4/gtk120_music_res/CMakeLists.txt @@ -0,0 +1,61 @@ +set(CMAKE_CXX_STANDARD 17) +cmake_minimum_required(VERSION 3.0.0) +project(gtk118 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 (GTK4 REQUIRED gtk4) +include_directories (${GTK4_INCLUDE_DIRS}) +link_directories (${GTK4_LIBRARY_DIRS}) + +#Compile Resource + +set(RESOURCE_LIST + Yanni-Nightingale.mp3) + +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}) + +#SOURCE FILES LIST +set(SOURCES src/main.cpp) + +#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} ${SOURCES} ${RESOURCE_FILE}) +else() + add_executable(${PROJECT_NAME} ${SOURCES} ${RESOURCE_FILE}) + +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 ${GTK4_CFLAGS_OTHER}) +target_link_libraries (${PROJECT_NAME} ${GTK4_LIBRARIES} -lpthread) diff --git a/Gtk4/gtk120_music_res/res/Yanni-Nightingale.mp3.md b/Gtk4/gtk120_music_res/res/Yanni-Nightingale.mp3.md new file mode 100644 index 0000000..e69de29 diff --git a/Gtk4/gtk120_music_res/src/main.cpp b/Gtk4/gtk120_music_res/src/main.cpp new file mode 100644 index 0000000..0278037 --- /dev/null +++ b/Gtk4/gtk120_music_res/src/main.cpp @@ -0,0 +1,22 @@ +#include + +static void gtkmain(GtkApplication * app,gpointer user_data){ + GtkWidget * window, * media_control; + //Initalize window + window = gtk_application_window_new(app); + gtk_window_set_icon_name(GTK_WINDOW(window),"org.gtk.daleclack"); + gtk_window_set_default_size(GTK_WINDOW(window),400,100); + //Create Media Stream and control + GtkMediaStream * media_stream = gtk_media_file_new_for_resource("/org/gtk/daleclack/Yanni-Nightingale.mp3"); + media_control = gtk_media_controls_new(media_stream); + gtk_window_set_child(GTK_WINDOW(window),media_control); + //show the window + gtk_widget_show(window); +} + +int main(int argc,char ** argv){ + GtkApplication * app; + 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); +}