/* 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 .
*/
#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
#include
#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 */