/* Chrysalide - Outil d'analyse de fichiers binaires * gtkcontentview-int.h - définitions internes propres à la base d'affichage pour contenus divers * * Copyright (C) 2016-2024 Cyrille Bagard * * This file is part of Chrysalide. * * Chrysalide is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * Chrysalide is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Chrysalide. If not, see <http://www.gnu.org/licenses/>. */ #ifndef _GTKEXT_CONTENTVIEW_INT_H #define _GTKEXT_CONTENTVIEW_INT_H #include "contentview.h" #include "../glibext/bufferview.h" #include "../glibext/tokenstyle.h" /* Réagit à un défilement chez une barre associée au composant. */ typedef void (* adjust_scroll_value_fc) (GtkContentView *, GtkOrientation, GtkAdjustment *); #if 0 #include <stdbool.h> #include <gtk/gtk.h> #include "../analysis/binary.h" #include "../glibext/gloadedpanel.h" /* Amplitude de l'arrondi pour les coins */ #define BORDER_CORNER_RADIUS 10.0 /* Indique les dimensions de travail du composant d'affichage. */ typedef void (* compute_requested_size_fc) (GtkDisplayPanel *, gint *, gint *); /* Détermine la taille des bonds lors de défilements. */ //typedef void (* compute_scroll_inc_fc) (GtkDisplayPanel *, gint, GtkOrientation, gdouble *, gdouble *); /* Réagit à un défilement chez une barre associée au composant. */ //typedef void (* adjust_scroll_value_fc) (GtkDisplayPanel *, GtkAdjustment *, GtkOrientation); /* Ajuste au besoin la zone affichée pour un curseur. */ typedef void (* prepare_for_cursor_fc) (GtkDisplayPanel *, const GLineCursor *); /* Indique la position d'affichage d'une adresse donnée. */ typedef bool (* get_coordinates_fc) (const GtkDisplayPanel *, const GLineCursor *, gint *, gint *, ScrollPositionTweak); /* Fournit l'élément actif lié à la position courante. */ typedef GObject * (* get_active_object_fc) (const GtkDisplayPanel *); /* Fournit des éléments liés à la position courante dans la vue. */ typedef bool (* get_view_position_fc) (const GtkDisplayPanel *, GBufferLine **, GObject **); /* Déplace le curseur à un emplacement défini. */ typedef bool (* move_caret_to_fc) (GtkDisplayPanel *, gint, gint); /* Fournit le position courante dans un panneau de chargement. */ typedef GLineCursor * (* get_cursor_fc) (const GtkDisplayPanel *); /* Place en cache un rendu destiné à l'aperçu graphique rapide. */ typedef void (* cache_glance_fc) (GtkDisplayPanel *, cairo_t *, const GtkAllocation *, double); /* Spécifie l'échelle à appliquer à l'affichage du composant. */ typedef void (* apply_scale_fc) (GtkDisplayPanel *, double, double); /* Marque ou non le composant pour une exportation prochaine. */ typedef void (* prepare_export_fc) (GtkDisplayPanel *, bool); #endif /* Composant d'affichage générique (instance) */ struct _GtkContentView { GtkWidget parent; /* A laisser en premier */ GtkAdjustment *adjustments[2]; /* Barres de défilement h. & v.*/ GtkScrollablePolicy scroll_policies[2]; /* Politiques de défilement */ GDisplayOptions *options; /* Options de rendu */ /* Propriété des implémentations */ GtkWidget * const *sub_children; /* Composants embarqués */ size_t sub_count; /* Quantité de ces composants */ #if 0 double scale; /* Echelle de l'affichage */ bool show_border; /* Affichage d'une bordure ? */ unsigned int view_index; /* Indice du type de contenu */ GDisplayOptions *options; /* Affichage des colonnes ? */ GLoadedBinary *binary; /* Binaire à visualiser */ bool export; /* Exportation du rendu ? */ #endif }; /* Composant d'affichage générique (classe) */ struct _GtkContentViewClass { GtkWidgetClass parent; /* A laisser en premier */ #if 0 compute_requested_size_fc compute_size; /* Calcul de la taille requise */ #endif adjust_scroll_value_fc adjust; /* Réaction à un défilement */ #if 0 prepare_for_cursor_fc prepare; /* Préparation de zone affichée*/ get_coordinates_fc get_coordinates; /* Conversion adresse <-> pos. */ get_active_object_fc get_active; /* Infos sur l'objet actif */ move_caret_to_fc move_caret_to; /* Déplacement du curseur */ get_cursor_fc get_cursor; /* Fourniture d'une position */ cache_glance_fc cache_glance; /* Cache de la mignature */ apply_scale_fc scale; /* Mise à jour de l'échelle */ prepare_export_fc prepare_export; /* Préparation d'exportation */ /* Signaux */ void (* scaled) (GtkDisplayPanel *, double, double); #endif }; /* Propriétés propres au composant d'affichage */ typedef enum _ContentViewProps { CVP_0, CVP_HADJUSTMENT, CVP_VADJUSTMENT, CVP_HSCROLL_POLICY, CVP_VSCROLL_POLICY } ContentViewProps; #if 0 /* Définit un chemin décrivant la bordure autour du panneau. */ void gtk_display_panel_define_border_path(GtkDisplayPanel *, cairo_t *, const GtkAllocation *); /* Dessine si besoin est une bordure autour du composant. */ void gtk_display_panel_draw_border(GtkDisplayPanel *, cairo_t *); /* --------------------------- CONVERSIONS DE COORDONNEES --------------------------- */ /* Transcrit les coordonnées à l'écran en coordonnées absolues. */ void gtk_display_panel_compute_fake_coord(GtkDisplayPanel *, gint *, gint *); /* Transcrit les coordonnées absolues en coordonnées à l'écran. */ void gtk_display_panel_compute_real_coord(GtkDisplayPanel *, gint *, gint *); /* Transcrit les coordonnées absolues en coordonnées à l'écran. */ void gtk_display_panel_compute_relative_coords(GtkDisplayPanel *, gint *, gint *); #endif #endif /* _GTKEXT_CONTENTVIEW_INT_H */