]> www.fi.muni.cz Git - evince.git/blobdiff - libview/ev-view-presentation.c
Replace GTK_WIDGET_STATE() with gtk_widget_get_state()
[evince.git] / libview / ev-view-presentation.c
index 5074e4e12ef995536fc19ab35ddd998d05949789..6ef1bb09d59c848917ee08dd74ae73b05a8c68e9 100644 (file)
@@ -62,6 +62,7 @@ struct _EvViewPresentation
        guint                  rotation;
        EvPresentationState    state;
        gdouble                scale;
+       gint                   monitor_width;
        gint                   monitor_height;
 
        /* Cursors */
@@ -164,23 +165,21 @@ static gdouble
 ev_view_presentation_get_scale_for_page (EvViewPresentation *pview,
                                         guint               page)
 {
-       gdouble width, height;
+       if (!ev_document_is_page_size_uniform (pview->document) || pview->scale == 0) {
+               gdouble width, height;
 
-       ev_document_get_page_size (pview->document, page, &width, &height);
+               ev_document_get_page_size (pview->document, page, &width, &height);
+               if (pview->rotation == 90 || pview->rotation == 270) {
+                       gdouble tmp;
 
-       if (pview->rotation == 90 || pview->rotation == 270)
-               return pview->monitor_height / width;
-       else
-               return pview->monitor_height / height;
-}
-
-static void
-ev_view_presentation_update_scale (EvViewPresentation *pview)
-{
-       if (ev_document_is_page_size_uniform (pview->document) && pview->scale != 0)
-               return;
+                       tmp = width;
+                       width = height;
+                       height = tmp;
+               }
+               pview->scale = MIN (pview->monitor_width / width, pview->monitor_height / height);
+       }
 
-       pview->scale = ev_view_presentation_get_scale_for_page (pview, pview->current_page);
+       return pview->scale;
 }
 
 static void
@@ -190,17 +189,19 @@ ev_view_presentation_get_page_area (EvViewPresentation *pview,
        GtkWidget *widget = GTK_WIDGET (pview);
        gdouble    doc_width, doc_height;
        gint       view_width, view_height;
+       gdouble    scale;
 
        ev_document_get_page_size (pview->document,
                                   pview->current_page,
                                   &doc_width, &doc_height);
+       scale = ev_view_presentation_get_scale_for_page (pview, pview->current_page);
 
        if (pview->rotation == 90 || pview->rotation == 270) {
-               view_width = (gint)((doc_height * pview->scale) + 0.5);
-               view_height = (gint)((doc_width * pview->scale) + 0.5);
+               view_width = (gint)((doc_height * scale) + 0.5);
+               view_height = (gint)((doc_width * scale) + 0.5);
        } else {
-               view_width = (gint)((doc_width * pview->scale) + 0.5);
-               view_height = (gint)((doc_height * pview->scale) + 0.5);
+               view_width = (gint)((doc_width * scale) + 0.5);
+               view_height = (gint)((doc_height * scale) + 0.5);
        }
 
        area->x = (MAX (0, widget->allocation.width - view_width)) / 2;
@@ -345,11 +346,8 @@ ev_view_presentation_schedule_new_job (EvViewPresentation *pview,
        if (page < 0 || page >= ev_document_get_n_pages (pview->document))
                return NULL;
 
-       if (ev_document_is_page_size_uniform (pview->document))
-               scale = pview->scale;
-       else
-               scale = ev_view_presentation_get_scale_for_page (pview, page);
-       job = ev_job_render_new (pview->document, page, pview->rotation, pview->scale, 0, 0);
+       scale = ev_view_presentation_get_scale_for_page (pview, page);
+       job = ev_job_render_new (pview->document, page, pview->rotation, scale, 0, 0);
        g_signal_connect (job, "finished",
                          G_CALLBACK (job_finished_cb),
                          pview);
@@ -459,7 +457,7 @@ ev_view_presentation_update_current_page (EvViewPresentation *pview,
        }
 
        pview->current_page = page;
-       ev_view_presentation_update_scale (pview);
+
        if (pview->page_cache)
                ev_page_cache_set_page_range (pview->page_cache, page, page);
 
@@ -749,14 +747,16 @@ ev_view_presentation_get_link_at_location (EvViewPresentation *pview,
        EvLink      *link;
        gdouble      width, height;
        gdouble      new_x, new_y;
+       gdouble      scale;
 
        if (!pview->page_cache)
                return NULL;
 
        ev_document_get_page_size (pview->document, pview->current_page, &width, &height);
        ev_view_presentation_get_page_area (pview, &page_area);
-       x = (x - page_area.x) / pview->scale;
-       y = (y - page_area.y) / pview->scale;
+       scale = ev_view_presentation_get_scale_for_page (pview, pview->current_page);
+       x = (x - page_area.x) / scale;
+       y = (y - page_area.y) / scale;
        switch (pview->rotation) {
        case 0:
        case 360:
@@ -831,7 +831,7 @@ ev_view_presentation_set_cursor (EvViewPresentation *pview,
                return;
 
        widget = GTK_WIDGET (pview);
-       if (!GTK_WIDGET_REALIZED (widget))
+       if (!gtk_widget_get_realized (widget))
                gtk_widget_realize (widget);
 
        pview->cursor = view_cursor;
@@ -986,7 +986,7 @@ ev_view_presentation_draw_end_page (EvViewPresentation *pview)
 
        gtk_paint_layout (widget->style,
                          widget->window,
-                         GTK_WIDGET_STATE (widget),
+                         gtk_widget_get_state (widget),
                          FALSE,
                          &area,
                          widget,
@@ -1201,9 +1201,9 @@ init_presentation (GtkWidget *widget)
 
        monitor_num = gdk_screen_get_monitor_at_window (screen, widget->window);
        gdk_screen_get_monitor_geometry (screen, monitor_num, &monitor);
+       pview->monitor_width = monitor.width;
        pview->monitor_height = monitor.height;
 
-       ev_view_presentation_update_scale (pview);
        ev_view_presentation_update_current_page (pview, pview->current_page);
        ev_view_presentation_hide_cursor_timeout_start (pview);