Construindo um aplicativo gtk

Costumo ver referências de como as coisas são implementadas no qt, mas o gtk também é bom. Eu escrevo em C e não quero aprender os padrões C ++ a cada três anos para estar em cima disso. Um simples sishechki é suficiente para mim e para fazer software gráfico, a escolha recaiu sobre o gtk.



Eu uso a documentação para isso no programa devhelp. Então, vamos começar.



A primeira coisa a fazer é criar um aplicativo que ficará visível no barramento dbus.



GtkApplication *app;

static void app_activate_cb ( GtkApplication *app, gpointer user_data ) {
}

int main ( int argc, char **argv ) {
	app = gtk_application_new ( "com.xverizex.configurator", G_APPLICATION_FLAGS_NONE );
	g_application_register ( ( GApplication * ) app, NULL, NULL );
	g_signal_connect ( app, "activate", G_CALLBACK ( app_activate_cb ), NULL );
	return g_application_run ( ( GApplication * ) app, argc, argv );
}


Depois que o aplicativo foi ativado, você precisa preenchê-lo com widgets. Eu crio neste arquivo uma estrutura que armazenará todos os widgets que mudarão de aparência se você especificar um esquema de cores diferente.



Aqui está a estrutura:



struct widgets {
	GtkWidget *main_window;
	GtkWidget *notebook;
	GtkWidget *tree_view_sources;
	GtkWidget *label_tab_sources;
	GtkWidget *header_bar;
	GtkWidget *search_entry;
	GtkWidget *button_add_item;
	GtkWidget *tree_view_reactions;
	GtkWidget *label_tab_reactions;
	GtkWidget *window_add_source;
        ...
        GtkWidget *STUBS;


no final, crio uma variável especial chamada STUBS, à qual não atribuo nada. Existem muitos widgets no aplicativo e você precisa de alguma forma para atribuir o nome desejado aos widgets desejados. É assim que eu faço.



static void set_theme_name ( const char *name ) {
	struct widgets **p = ( struct widgets ** ) &w;
	for ( int i = 0; p[i] != NULL; i++ ) {
		gtk_widget_set_name ( ( GtkWidget * ) p[i], name );
	}
	char buf[255];
	snprintf ( buf, 255, "%s_info", name );
	gtk_widget_set_name ( w.label_info_db_settings, buf );
	gtk_widget_set_name ( w.label_info_mail_settings, buf );
}


para aqueles widgets que ainda precisam de um design especial, já atribuo a eles nomes separados. Nesta função, eu examino todos os widgets e dou a eles um nome de tema.

O código a seguir é usado para criar o menu.



static void create_actions ( void ) {
	const GActionEntry entries[] = {
		{ "quit", action_activate_quit },
		{ "settings", action_settings },
		{ "apply_settings", action_activate_apply_settings },
		{ "select_light_theme", action_activate_select_light_theme },
		{ "select_dark_theme", action_activate_select_dark_theme },
		{ "select_standard_theme", action_activate_select_standard_theme }
	};
	g_action_map_add_action_entries ( G_ACTION_MAP (app), entries, G_N_ELEMENTS (entries), NULL );
}


E então atribuímos esses comandos ao menu.



	pop_menu = g_menu_new ( );
	GMenu *menu_app = g_menu_new ( );
	GMenu *menu_themes = g_menu_new ( );
	g_menu_append ( menu_app, "", "app.settings" );
	g_menu_append ( menu_app, "", "app.apply_settings" );
	g_menu_append ( menu_themes, " ", "app.select_light_theme" );
	g_menu_append ( menu_themes, " ", "app.select_dark_theme" );
	g_menu_append ( menu_themes, " ", "app.select_standard_theme" );
	g_menu_append_submenu ( menu_app, " ", ( GMenuModel * ) menu_themes );
	g_menu_append ( menu_app, "", "app.quit" );

	gtk_application_set_app_menu ( app, ( GMenuModel * ) menu_app );


Como resultado, após fazer xixi neste aplicativo, ele se transforma em algo maravilhoso e bonito.



imagem



All Articles