diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2020-08-08 21:37:21 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2020-08-08 21:37:21 (GMT) |
commit | 4370d2d77d623f560c7df94a3bc15b1395e4878b (patch) | |
tree | 57cc6268f504c19aaac3b1adda4295ed3b1ddc7f /src/gui/panels/glance.c | |
parent | 34d28c7418342d3c67be4747b13cdcb124edda32 (diff) |
Updated all the code relative to GUI items.
Diffstat (limited to 'src/gui/panels/glance.c')
-rw-r--r-- | src/gui/panels/glance.c | 73 |
1 files changed, 59 insertions, 14 deletions
diff --git a/src/gui/panels/glance.c b/src/gui/panels/glance.c index fa99ceb..c7478b5 100644 --- a/src/gui/panels/glance.c +++ b/src/gui/panels/glance.c @@ -30,6 +30,7 @@ #include "../panel-int.h" +#include "../../gtkext/named.h" @@ -86,6 +87,9 @@ static void g_glance_panel_dispose(GGlancePanel *); /* Procède à la libération totale de la mémoire. */ static void g_glance_panel_finalize(GGlancePanel *); +/* Fournit le nom interne attribué à l'élément réactif. */ +static char *g_glance_panel_get_key(const GGlancePanel *); + /* Lance une actualisation du fait d'un changement de support. */ static void change_glance_panel_current_view(GGlancePanel *, GLoadedPanel *, GLoadedPanel *); @@ -137,7 +141,7 @@ G_DEFINE_TYPE(GGlancePanel, g_glance_panel, G_TYPE_PANEL_ITEM); static void g_glance_panel_class_init(GGlancePanelClass *klass) { GObjectClass *object; /* Autre version de la classe */ - GEditorItemClass *editem; /* Encore une autre vision... */ + GEditorItemClass *item; /* Encore une autre vision... */ GtkIconTheme *theme; /* Thème GTK offrant des icones*/ object = G_OBJECT_CLASS(klass); @@ -145,10 +149,12 @@ static void g_glance_panel_class_init(GGlancePanelClass *klass) object->dispose = (GObjectFinalizeFunc/* ! */)g_glance_panel_dispose; object->finalize = (GObjectFinalizeFunc)g_glance_panel_finalize; - editem = G_EDITOR_ITEM_CLASS(klass); + item = G_EDITOR_ITEM_CLASS(klass); + + item->get_key = (get_item_key_fc)g_glance_panel_get_key; - editem->change_view = (change_item_view_fc)change_glance_panel_current_view; - editem->update_view = (update_item_view_fc)update_glance_panel_view; + item->change_view = (change_item_view_fc)change_glance_panel_current_view; + item->update_view = (update_item_view_fc)update_glance_panel_view; theme = gtk_icon_theme_get_default(); @@ -173,26 +179,25 @@ static void g_glance_panel_class_init(GGlancePanelClass *klass) static void g_glance_panel_init(GGlancePanel *panel) { - GEditorItem *base; /* Version basique d'instance */ GPanelItem *pitem; /* Version parente du panneau */ GtkBuilder *builder; /* Constructeur utilisé */ /* Eléments de base */ - base = G_EDITOR_ITEM(panel); - - base->name = PANEL_GLANCE_ID; - pitem = G_PANEL_ITEM(panel); pitem->personality = PIP_SINGLETON; - pitem->lname = _("Glance"); + + pitem->widget = G_NAMED_WIDGET(gtk_built_named_widget_new_for_panel(_("Glance"), + _("Glimpse of the display content"), + PANEL_GLANCE_ID)); + pitem->dock_at_startup = true; pitem->path = strdup("MEs"); /* Représentation graphique */ - builder = g_panel_item_build(pitem, "glance"); + builder = gtk_built_named_widget_get_builder(GTK_BUILT_NAMED_WIDGET(pitem->widget)); /* Connexion des signaux */ @@ -206,6 +211,8 @@ static void g_glance_panel_init(GGlancePanel *panel) gtk_builder_connect_signals(builder, panel); + g_object_unref(G_OBJECT(builder)); + } @@ -275,6 +282,29 @@ GPanelItem *g_glance_panel_new(void) /****************************************************************************** * * +* Paramètres : panel = instance à consulter. * +* * +* Description : Fournit le nom interne attribué à l'élément réactif. * +* * +* Retour : Désignation (courte) de l'élément de l'éditeur. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static char *g_glance_panel_get_key(const GGlancePanel *panel) +{ + char *result; /* Description à renvoyer */ + + result = strdup(PANEL_GLANCE_ID); + + return result; + +} + + +/****************************************************************************** +* * * Paramètres : panel = panneau à actualiser. * * old = ancienne vue du contenu chargé analysé. * * new = nouvelle vue du contenu chargé analysé. * @@ -411,6 +441,7 @@ static void on_view_scrolled(GtkAdjustment *adj, GGlancePanel *panel) { GtkAdjustment *hadj; /* Gestionnaire du défilement */ GtkAdjustment *vadj; /* Gestionnaire du défilement */ + GtkWidget *widget; /* Surface de dessin pour GTK */ hadj = gtk_scrolled_window_get_hadjustment(panel->support); vadj = gtk_scrolled_window_get_vadjustment(panel->support); @@ -423,7 +454,11 @@ static void on_view_scrolled(GtkAdjustment *adj, GGlancePanel *panel) panel->visible.width = gtk_adjustment_get_page_size(hadj) * panel->scale; panel->visible.height = gtk_adjustment_get_page_size(vadj) * panel->scale; - gtk_widget_queue_draw(G_EDITOR_ITEM(panel)->widget); + widget = g_named_widget_get_widget(G_PANEL_ITEM(panel)->widget); + + gtk_widget_queue_draw(widget); + + g_object_unref(G_OBJECT(widget)); } @@ -467,6 +502,7 @@ static void on_glance_resize(GtkWidget *widget, GdkRectangle *allocation, GGlanc static void compute_glance_scale(GGlancePanel *panel) { + GtkWidget *widget; /* Surface de dessin pour GTK */ GtkAllocation available; /* Surface disponible totale */ GtkAllocation granted; /* Surface totale accordée */ double sx; /* Echelle sur l'axe X */ @@ -474,7 +510,11 @@ static void compute_glance_scale(GGlancePanel *panel) /* Superficies niveau GTK... */ - gtk_widget_get_allocation(G_EDITOR_ITEM(panel)->widget, &available); + widget = g_named_widget_get_widget(G_PANEL_ITEM(panel)->widget); + + gtk_widget_get_allocation(widget, &available); + + g_object_unref(G_OBJECT(widget)); /* Calcul des ratios et emplacements */ @@ -544,6 +584,7 @@ static void update_glance_panel_view(GGlancePanel *panel, GLoadedPanel *view) { cairo_t *cairo; /* Assistant pour le dessin */ GtkAllocation area; /* Dimension de la surface */ + GtkWidget *widget; /* Surface de dessin pour GTK */ /* Mise en place d'un cache adapté */ @@ -567,7 +608,11 @@ static void update_glance_panel_view(GGlancePanel *panel, GLoadedPanel *view) cairo_destroy(cairo); - gtk_widget_queue_draw(G_EDITOR_ITEM(panel)->widget); + widget = g_named_widget_get_widget(G_PANEL_ITEM(panel)->widget); + + gtk_widget_queue_draw(widget); + + g_object_unref(G_OBJECT(widget)); } |