diff options
author | Jonathan Blandford <jrb@redhat.com> | 2005-08-15 04:41:30 (GMT) |
---|---|---|
committer | Jonathan Blandford <jrb@src.gnome.org> | 2005-08-15 04:41:30 (GMT) |
commit | 09458b5fc51b3504582e76a12b7a57cbba332ac0 (patch) | |
tree | abdc6fb099a4fab1cd79f9bd7a32f32aa6142ec1 /shell | |
parent | 6e5cbc7bbdd23310885fd983499008f544b269ee (diff) |
* shell/ev-metadata-manager.c: (ev_metadata_manager_init): *
Mon Aug 15 00:40:21 2005 Jonathan Blandford <jrb@redhat.com>
* pdf/ev-poppler.cc: * shell/ev-metadata-manager.c:
(ev_metadata_manager_init): * shell/ev-view.c:
(ev_view_rotate_left), (ev_view_set_rotation),
(ev_view_get_rotation): * shell/ev-view.h: * shell/ev-window.c:
(setup_view_from_metadata),
(save_rotation_to_file), (ev_window_cmd_edit_rotate_left),
(ev_window_cmd_edit_rotate_right): Fix rotation. Save it to disk.
Diffstat (limited to 'shell')
-rw-r--r-- | shell/ev-metadata-manager.c | 8 | ||||
-rw-r--r-- | shell/ev-view.c | 26 | ||||
-rw-r--r-- | shell/ev-view.h | 3 | ||||
-rw-r--r-- | shell/ev-window.c | 37 |
4 files changed, 61 insertions, 13 deletions
diff --git a/shell/ev-metadata-manager.c b/shell/ev-metadata-manager.c index 2bbd291..7acf6a1 100644 --- a/shell/ev-metadata-manager.c +++ b/shell/ev-metadata-manager.c @@ -43,7 +43,7 @@ #define MAX_ITEMS 50 -typedef struct _GeditMetadataManager GeditMetadataManager; +typedef struct _EvMetadataManager EvMetadataManager; typedef struct _Item Item; @@ -54,7 +54,7 @@ struct _Item GHashTable *values; }; -struct _GeditMetadataManager +struct _EvMetadataManager { gboolean values_loaded; /* It is true if the file has been read */ @@ -70,7 +70,7 @@ struct _GeditMetadataManager static gboolean ev_metadata_manager_save (gpointer data); -static GeditMetadataManager *ev_metadata_manager = NULL; +static EvMetadataManager *ev_metadata_manager = NULL; static void item_free (gpointer data) @@ -90,7 +90,7 @@ item_free (gpointer data) void ev_metadata_manager_init (void) { - ev_metadata_manager = g_new0 (GeditMetadataManager, 1); + ev_metadata_manager = g_new0 (EvMetadataManager, 1); ev_metadata_manager->values_loaded = FALSE; ev_metadata_manager->modified = FALSE; diff --git a/shell/ev-view.c b/shell/ev-view.c index b22b1f5..07fee0d 100644 --- a/shell/ev-view.c +++ b/shell/ev-view.c @@ -2409,15 +2409,6 @@ ev_view_zoom_out (EvView *view) ev_view_set_zoom (view, ZOOM_OUT_FACTOR, TRUE); } -static void -ev_view_set_rotation (EvView *view, int rotation) -{ - view->rotation = rotation; - - ev_pixbuf_cache_clear (view->pixbuf_cache); - gtk_widget_queue_resize (GTK_WIDGET (view)); -} - void ev_view_rotate_right (EvView *view) { @@ -2442,6 +2433,23 @@ ev_view_rotate_left (EvView *view) ev_view_set_rotation (view, rotation); } +void +ev_view_set_rotation (EvView *view, int rotation) +{ + view->rotation = rotation; + + if (view->pixbuf_cache) { + ev_pixbuf_cache_clear (view->pixbuf_cache); + gtk_widget_queue_resize (GTK_WIDGET (view)); + } +} + +int +ev_view_get_rotation (EvView *view) +{ + return view->rotation; +} + static double zoom_for_size_fit_width (int doc_width, int doc_height, diff --git a/shell/ev-view.h b/shell/ev-view.h index 2790a1c..09ac1ee 100644 --- a/shell/ev-view.h +++ b/shell/ev-view.h @@ -101,6 +101,9 @@ void ev_view_set_zoom_for_size (EvView *view, int hsb_height); void ev_view_rotate_left (EvView *view); void ev_view_rotate_right (EvView *view); +void ev_view_set_rotation (EvView *view, + int rotation); +int ev_view_get_rotation (EvView *view); /* Find */ gboolean ev_view_can_find_next (EvView *view); diff --git a/shell/ev-window.c b/shell/ev-window.c index dc67739..a264cbc 100644 --- a/shell/ev-window.c +++ b/shell/ev-window.c @@ -956,6 +956,7 @@ setup_view_from_metadata (EvWindow *window) GValue dual_page = { 0, }; GValue presentation = { 0, }; GValue fullscreen = { 0, }; + GValue rotation = { 0, }; /* Window size */ if (!GTK_WIDGET_VISIBLE (window)) { @@ -1018,6 +1019,25 @@ setup_view_from_metadata (EvWindow *window) ev_window_run_fullscreen (window); } } + + /* Rotation */ + if (ev_metadata_manager_get (uri, "rotation", &rotation)) { + if (g_value_get_int (&rotation)) { + switch (g_value_get_int (&rotation)) { + case 90: + ev_view_set_rotation (view, 90); + break; + case 180: + ev_view_set_rotation (view, 180); + break; + case 270: + ev_view_set_rotation (view, 270); + break; + default: + break; + } + } + } } void @@ -2036,11 +2056,27 @@ ev_window_cmd_edit_toolbar_cb (GtkDialog *dialog, gint response, gpointer data) gtk_widget_destroy (GTK_WIDGET (dialog)); } +/* should these be hooked up to properties?? */ +static void +save_rotation_to_file (EvWindow *window) +{ + int rotation; + + if (window->priv->uri) { + rotation = ev_view_get_rotation (EV_VIEW (window->priv->view)); + ev_metadata_manager_set_int (window->priv->uri, "rotation", + rotation); + } + + +} + static void ev_window_cmd_edit_rotate_left (GtkAction *action, EvWindow *ev_window) { ev_view_rotate_left (EV_VIEW (ev_window->priv->view)); ev_sidebar_thumbnails_refresh (EV_SIDEBAR_THUMBNAILS (ev_window->priv->sidebar_thumbs)); + save_rotation_to_file (ev_window); } static void @@ -2048,6 +2084,7 @@ ev_window_cmd_edit_rotate_right (GtkAction *action, EvWindow *ev_window) { ev_view_rotate_right (EV_VIEW (ev_window->priv->view)); ev_sidebar_thumbnails_refresh (EV_SIDEBAR_THUMBNAILS (ev_window->priv->sidebar_thumbs)); + save_rotation_to_file (ev_window); } static void |