Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
authorJonathan 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)
commit09458b5fc51b3504582e76a12b7a57cbba332ac0 (patch)
treeabdc6fb099a4fab1cd79f9bd7a32f32aa6142ec1 /shell
parent6e5cbc7bbdd23310885fd983499008f544b269ee (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.c8
-rw-r--r--shell/ev-view.c26
-rw-r--r--shell/ev-view.h3
-rw-r--r--shell/ev-window.c37
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