]> www.fi.muni.cz Git - evince.git/blobdiff - pixbuf/pixbuf-document.c
More work on find implementation, mostly there now
[evince.git] / pixbuf / pixbuf-document.c
index 7eeb8fdaf986e699b568151e8775e536976818f6..a3b06d97d4084f54ac298460e514d0df35fc2b3c 100644 (file)
 #include "pixbuf-document.h"
 #include "ev-document-thumbnails.h"
 
+enum {
+       PROP_0,
+       PROP_TITLE
+};
+
 struct _PixbufDocumentClass
 {
        GObjectClass parent_class;
@@ -48,8 +53,6 @@ G_DEFINE_TYPE_WITH_CODE (PixbufDocument, pixbuf_document, G_TYPE_OBJECT,
                                                pixbuf_document_document_thumbnails_iface_init)                            
                                   });
 
-static GObjectClass *parent_class;
-
 static gboolean
 pixbuf_document_load (EvDocument  *document,
                      const char  *uri,
@@ -75,6 +78,15 @@ pixbuf_document_load (EvDocument  *document,
        return TRUE;
 }
 
+static gboolean
+pixbuf_document_save (EvDocument  *document,
+                     const char  *uri,
+                     GError     **error)
+{
+       g_warning ("pixbuf_document_save not implemented"); /* FIXME */
+       return TRUE;
+}
+
 static int
 pixbuf_document_get_n_pages (EvDocument  *document)
 {
@@ -130,8 +142,10 @@ pixbuf_document_get_page_size (EvDocument   *document,
 {
        PixbufDocument *pixbuf_document = PIXBUF_DOCUMENT (document);
 
-       *width = gdk_pixbuf_get_width (pixbuf_document->pixbuf);
-       *height = gdk_pixbuf_get_height (pixbuf_document->pixbuf);
+       if (width)
+               *width = gdk_pixbuf_get_width (pixbuf_document->pixbuf);
+       if (height)
+               *height = gdk_pixbuf_get_height (pixbuf_document->pixbuf);
 }
 
 static void
@@ -176,26 +190,41 @@ pixbuf_document_render (EvDocument  *document,
 }
 
 static void
-pixbuf_document_begin_find (EvDocument   *document,
-                           const char   *search_string,
-                           gboolean      case_sensitive)
+pixbuf_document_finalize (GObject *object)
 {
+       PixbufDocument *pixbuf_document = PIXBUF_DOCUMENT (object);
+
+       g_object_unref (pixbuf_document->pixbuf);
        
+       G_OBJECT_CLASS (pixbuf_document_parent_class)->finalize (object);
 }
 
 static void
-pixbuf_document_end_find (EvDocument   *document)
+pixbuf_document_set_property (GObject *object,
+                             guint prop_id,
+                             const GValue *value,
+                             GParamSpec *pspec)
 {
+       switch (prop_id)
+       {
+               case PROP_TITLE:
+                       /* read only */
+                       break;
+       }
 }
 
 static void
-pixbuf_document_finalize (GObject *object)
+pixbuf_document_get_property (GObject *object,
+                             guint prop_id,
+                             GValue *value,
+                             GParamSpec *pspec)
 {
-       PixbufDocument *pixbuf_document = PIXBUF_DOCUMENT (object);
-
-       g_object_unref (pixbuf_document->pixbuf);
-       
-       G_OBJECT_CLASS (parent_class)->finalize (object);
+       switch (prop_id)
+       {
+               case PROP_TITLE:
+                       g_value_set_string (value, NULL);
+                       break;
+       }
 }
 
 static void
@@ -203,15 +232,37 @@ pixbuf_document_class_init (PixbufDocumentClass *klass)
 {
        GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
 
-       parent_class = g_type_class_peek_parent (klass);
-       
        gobject_class->finalize = pixbuf_document_finalize;
+       gobject_class->get_property = pixbuf_document_get_property;
+       gobject_class->set_property = pixbuf_document_set_property;
+
+       g_object_class_override_property (gobject_class, PROP_TITLE, "title");
+}
+
+static char *
+pixbuf_document_get_text (EvDocument *document, GdkRectangle *rect)
+{
+       /* FIXME this method should not be in EvDocument */
+       g_warning ("pixbuf_document_get_text not implemented");
+       return NULL;
+}
+
+
+static EvLink *
+pixbuf_document_get_link (EvDocument *document,
+                         int         x,
+                         int         y)
+{
+       return NULL;
 }
 
 static void
 pixbuf_document_document_iface_init (EvDocumentIface *iface)
 {
        iface->load = pixbuf_document_load;
+       iface->save = pixbuf_document_save;
+       iface->get_text = pixbuf_document_get_text;
+       iface->get_link = pixbuf_document_get_link;
        iface->get_n_pages = pixbuf_document_get_n_pages;
        iface->set_page = pixbuf_document_set_page;
        iface->get_page = pixbuf_document_get_page;
@@ -220,8 +271,6 @@ pixbuf_document_document_iface_init (EvDocumentIface *iface)
        iface->set_page_offset = pixbuf_document_set_page_offset;
        iface->get_page_size = pixbuf_document_get_page_size;
        iface->render = pixbuf_document_render;
-        iface->begin_find = pixbuf_document_begin_find;
-        iface->end_find = pixbuf_document_end_find;
 }
 
 static GdkPixbuf *
@@ -244,11 +293,27 @@ pixbuf_document_thumbnails_get_thumbnail (EvDocumentThumbnails   *document,
        return pixbuf;
 }
 
+static void
+pixbuf_document_thumbnails_get_dimensions (EvDocumentThumbnails *document,
+                                          gint                  page,
+                                          gint                  suggested_width,
+                                          gint                  *width,
+                                          gint                  *height)
+{
+       PixbufDocument *pixbuf_document = PIXBUF_DOCUMENT (document);
+       gdouble page_ratio;
+
+       page_ratio = ((double)gdk_pixbuf_get_height (pixbuf_document->pixbuf)) /
+                    gdk_pixbuf_get_width (pixbuf_document->pixbuf);
+       *width = suggested_width;
+       *height = (gint) (suggested_width * page_ratio);
+}
 
 static void
 pixbuf_document_document_thumbnails_iface_init (EvDocumentThumbnailsIface *iface)
 {
        iface->get_thumbnail = pixbuf_document_thumbnails_get_thumbnail;
+       iface->get_dimensions = pixbuf_document_thumbnails_get_dimensions;
 }