summaryrefslogtreecommitdiff
path: root/src/gui/panels/glance.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/panels/glance.c')
-rw-r--r--src/gui/panels/glance.c73
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));
}