X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-view-private.h;h=4908711fbe06c1e01e88456f4a25b16ffeb713b4;hb=4cabc192ea93da44cbeb53396c21b1d7589cee46;hp=b5831e4fbe5413829cd0d55434919c7e79be6a40;hpb=92603d06e3606238f25df947fed3666c5814440d;p=evince.git diff --git a/shell/ev-view-private.h b/shell/ev-view-private.h index b5831e4f..4908711f 100644 --- a/shell/ev-view-private.h +++ b/shell/ev-view-private.h @@ -24,6 +24,8 @@ #include "ev-view.h" #include "ev-pixbuf-cache.h" #include "ev-page-cache.h" +#include "ev-image.h" +#include "ev-form-field.h" /* Information for middle clicking and moving around the doc */ typedef struct { @@ -41,10 +43,18 @@ typedef struct { GList *selections; } SelectionInfo; +/* Information for handling images DND */ +typedef struct { + gboolean in_drag; + GdkPoint start; + EvImage *image; +} ImageDNDInfo; + typedef enum { SCROLL_TO_KEEP_POSITION, SCROLL_TO_PAGE_POSITION, SCROLL_TO_CENTER, + SCROLL_TO_FIND_LOCATION, } PendingScroll; typedef enum { @@ -56,14 +66,22 @@ typedef enum { EV_VIEW_CURSOR_DRAG } EvViewCursor; +typedef enum { + EV_PRESENTATION_NORMAL, + EV_PRESENTATION_BLACK, + EV_PRESENTATION_WHITE, + EV_PRESENTATION_END +} EvPresentationState; + struct _EvView { - GtkWidget parent_instance; + GtkLayout layout; EvDocument *document; char *status; char *find_status; int find_result; + gboolean jump_to_find_result; EvPageCache *page_cache; EvPixbufCache *pixbuf_cache; @@ -87,9 +105,12 @@ struct _EvView { gint end_page; gint current_page; - int rotation; - double scale; - int spacing; + gint rotation; + gdouble scale; + gint spacing; + gdouble dpi; + gdouble max_scale; + gdouble min_scale; gboolean loading; gboolean continuous; @@ -97,6 +118,13 @@ struct _EvView { gboolean fullscreen; gboolean presentation; EvSizingMode sizing_mode; + cairo_surface_t *loading_text; + + /* Presentation */ + EvPresentationState presentation_state; + EvSizingMode sizing_mode_saved; + double scale_saved; + guint trans_timeout_id; /* Common for button press handling */ int pressed_button; @@ -112,23 +140,29 @@ struct _EvView { EvViewSelectionMode selection_mode; SelectionInfo selection_info; + /* Image DND */ + ImageDNDInfo image_dnd_info; + /* Links */ GtkWidget *link_tooltip; EvLink *hovered_link; + + /* Goto Popup */ + GtkWidget *goto_window; + GtkWidget *goto_entry; }; struct _EvViewClass { - GtkWidgetClass parent_class; + GtkLayoutClass parent_class; - void (*set_scroll_adjustments) (EvView *view, - GtkAdjustment *hadjustment, - GtkAdjustment *vadjustment); void (*binding_activated) (EvView *view, EvScrollType scroll, gboolean horizontal); void (*zoom_invalid) (EvView *view); - void (*external_link) (EvView *view, + void (*handle_link) (EvView *view, EvLink *link); + void (*external_link) (EvView *view, + EvLinkAction *action); void (*popup_menu) (EvView *view, EvLink *link); };