From 37bc8522ff9b4ef1d8f2d66c4e5ca4596d83ec30 Mon Sep 17 00:00:00 2001
From: Michael Meeks <mmeeks@src.gnome.org>
Date: Tue, 3 Aug 1999 16:45:55 +0000
Subject: [PATCH] Now you can see the whole page ( but only page 2 :-)

---
 pdf/xpdf/ChangeLog  |   8 +++
 pdf/xpdf/gpdf.cc    | 130 +++++++++++++++++++++++++++-----------------
 pdf/xpdf/gpdf.glade |   6 +-
 3 files changed, 91 insertions(+), 53 deletions(-)

diff --git a/pdf/xpdf/ChangeLog b/pdf/xpdf/ChangeLog
index 8dc28958..e564419b 100644
--- a/pdf/xpdf/ChangeLog
+++ b/pdf/xpdf/ChangeLog
@@ -1,3 +1,11 @@
+1999-08-03  Michael Meeks  <michael@imaginator.com>
+
+	* gpdf.cc: Lots of updates.
+
+1999-08-02  Michael Meeks  <michael@edenproject.org>
+
+	* GOutputDev.cc: Fix more silly region merging bugs.
+
 1999-08-01  Michael Meeks  <michael@edenproject.org>
 
 	* Makefile.in: Added -lglade, -lglade-gnome & Added -Wall
diff --git a/pdf/xpdf/gpdf.cc b/pdf/xpdf/gpdf.cc
index 6b1485a0..7da47d58 100644
--- a/pdf/xpdf/gpdf.cc
+++ b/pdf/xpdf/gpdf.cc
@@ -44,12 +44,17 @@ GBool printCommands = gFalse;
 gint  gpdf_debug=1;
 poptContext ctx;
 
+#define DEV_DEBUG 0
+
+double zoom = 86.0;
+gint page = 2;
+
 #define DOC_KEY "xpdf_doc_key"
 struct DOC_ROOT {
   GString        *title;
   PDFDoc         *pdf;
   GtkDrawingArea *area;
-  GdkPixmap      *pixmap;
+  GtkPixmap      *pixmap;
   OutputDev      *out;
   GdkColor        paper;
   GtkScrolledWindow *scroll;
@@ -67,49 +72,67 @@ const struct poptOption gpdf_popt_options [] = {
 // loadFile / displayPage
 //------------------------------------------------------------------------
 
-static gint
-doc_config_event (GtkWidget *widget, void *ugly)
+static void
+get_page_geom (int *w, int *h, Page *p)
 {
-  DOC_ROOT *doc;
+  double pw = p->getWidth();
+  double ph = p->getHeight();
 
-  doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
-  
-  g_return_val_if_fail (doc, FALSE);
+  *w = 612;
+  *h = 792;
 
-  if (doc->pixmap)
-    gdk_pixmap_unref(doc->pixmap);
+  if (!p)
+    return;
+
+  *w = (int)((pw * zoom)/72.0 + 28.0);
+  *h = (int)((ph * zoom)/72.0 + 56.0);
+}
+
+static GdkPixmap *
+setup_pixmap (DOC_ROOT *doc, GdkWindow *window)
+{
+  GdkGCValues  gcValues;
+  GdkGC       *strokeGC;
+  PDFDoc      *pdf = doc->pdf;
+  int          w, h;
+  GdkPixmap   *pixmap = NULL;
+
+  if (pixmap)
+    gdk_pixmap_unref(pixmap);
 
-  doc->pixmap = gdk_pixmap_new(widget->window,
-                               widget->allocation.width,
-                               widget->allocation.height,
-                               -1);
+  Catalog *cat = pdf->getCatalog();
+  get_page_geom (&w, &h, cat->getPage (page));
 
-  printf ("Creating pixmap of size %d %d\n",
-	  widget->allocation.width, widget->allocation.height);
+  pixmap = gdk_pixmap_new (window, w, h, -1);
+  gtk_widget_set_usize (GTK_WIDGET (doc->scroll), w, h);
+
+  printf ("Creating pixmap of size %d %d\n", w, h);
   gdk_color_white (gtk_widget_get_default_colormap(), &doc->paper);
-  doc->out    = new GOutputDev (doc->pixmap, doc->paper,
-				gtk_widget_get_parent_window (widget));
+  doc->out    = new GOutputDev (pixmap, doc->paper, window);
+
+  gdk_color_white (gtk_widget_get_default_colormap (), &gcValues.foreground);
+  gdk_color_black (gtk_widget_get_default_colormap (), &gcValues.background);
+  gcValues.line_width = 1;
+  gcValues.line_style = GDK_LINE_SOLID;
+  strokeGC = gdk_gc_new_with_values (
+    pixmap, &gcValues, 
+    (enum GdkGCValuesMask)(GDK_GC_FOREGROUND | GDK_GC_BACKGROUND | GDK_GC_LINE_WIDTH | GDK_GC_LINE_STYLE));
+  
+  gdk_draw_rectangle (pixmap, strokeGC,
+		      TRUE, 0, 0,
+		      w, h);
+  return pixmap;
+}
 
+/*static gint
+doc_config_event (GtkWidget *widget, void *ugly)
+{
+  DOC_ROOT *doc;
+
+  doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
+  
+  g_return_val_if_fail (doc, FALSE);
 
-  {
-    GdkGCValues gcValues;
-    GdkGC *strokeGC;
-    
-    gdk_color_white (gtk_widget_get_default_colormap (), &gcValues.foreground);
-    gdk_color_black (gtk_widget_get_default_colormap (), &gcValues.background);
-    gcValues.line_width = 1;
-    gcValues.line_style = GDK_LINE_SOLID;
-    strokeGC = gdk_gc_new_with_values (
-      doc->pixmap, &gcValues, 
-      (enum GdkGCValuesMask)(GDK_GC_FOREGROUND | GDK_GC_BACKGROUND | GDK_GC_LINE_WIDTH | GDK_GC_LINE_STYLE));
-
-    gdk_draw_rectangle (doc->pixmap,
-			strokeGC,
-			TRUE,
-			0, 0,
-			widget->allocation.width,
-			widget->allocation.height);
-  }
   return TRUE;
 }
 
@@ -125,7 +148,9 @@ doc_redraw_event (GtkWidget *widget, GdkEventExpose *event)
   g_return_val_if_fail (doc != NULL, FALSE);
 
   if (doc->out && doc->pdf) {
+#if DEV_DEBUG > 0
     printf ("There are %d pages\n", doc->pdf->getNumPages());
+#endif
 
     doc->pdf->displayPage(doc->out, 1, 86, 0, gTrue);
     gdk_draw_pixmap(widget->window,
@@ -138,7 +163,7 @@ doc_redraw_event (GtkWidget *widget, GdkEventExpose *event)
     printf ("Null pointer error %p %p\n", doc->out, doc->pdf);
   
   return FALSE;
-}
+}*/
 
 static PDFDoc *
 getPDF (GString *fname)
@@ -160,6 +185,7 @@ loadPDF(GString *fileName)
   DOC_ROOT *doc = new DOC_ROOT();
   GtkVBox  *pane;
   GtkAdjustment *hadj, *vadj;
+  GdkPixmap *pix;
 
   // open PDF file
   doc->pdf = getPDF (fileName);
@@ -177,20 +203,16 @@ loadPDF(GString *fileName)
     delete doc;
     return gFalse;
   }
+/*  glade_xml_signal_autoconnect (doc->gui);*/
     
-  doc->pixmap = NULL;
-  doc->area   = GTK_DRAWING_AREA (gtk_drawing_area_new ());
-
-  gtk_object_set_data (GTK_OBJECT (doc->area), DOC_KEY, doc);
-  gtk_signal_connect  (GTK_OBJECT (doc->area),"configure_event",
-		       (GtkSignalFunc) doc_config_event, doc);
-  gtk_signal_connect  (GTK_OBJECT (doc->area), "expose_event",
-		       (GtkSignalFunc) doc_redraw_event, doc);
-
-  hadj = GTK_ADJUSTMENT (gtk_adjustment_new (0, 0, 1, 0.01, 0.1, 2));
-  vadj = GTK_ADJUSTMENT (gtk_adjustment_new (0, 0, 1, 0.01, 0.1, 2));
-  doc->scroll = GTK_SCROLLED_WINDOW (gtk_scrolled_window_new (hadj, vadj));
-  gtk_scrolled_window_add_with_viewport (doc->scroll, GTK_WIDGET (doc->area));
+  pix = setup_pixmap (doc, gtk_widget_get_parent_window (GTK_WIDGET (pane)));
+  doc->pixmap = GTK_PIXMAP (gtk_pixmap_new (pix, NULL));
+  
+  doc->scroll = GTK_SCROLLED_WINDOW (gtk_scrolled_window_new (NULL, NULL));
+  gtk_scrolled_window_set_policy (doc->scroll, GTK_POLICY_AUTOMATIC,
+				  GTK_POLICY_AUTOMATIC);
+  doc->pdf->displayPage(doc->out, page, zoom, 0, gTrue);
+  gtk_scrolled_window_add_with_viewport (doc->scroll, GTK_WIDGET (doc->pixmap));
   gtk_box_pack_start (GTK_BOX (pane), GTK_WIDGET (doc->scroll), TRUE, TRUE, 0);
 
   gtk_widget_show_all (doc->mainframe);
@@ -233,6 +255,14 @@ loadPDF(GString *fileName)
   win->setBusyCursor(gFalse);
   }*/
 
+extern "C" {
+  void
+  on_close_activate (GtkWidget *window, void *data)
+  {
+    printf ("Bye...");
+    gtk_widget_destroy (window);
+  }
+}
 
 int
 main (int argc, char *argv [])
diff --git a/pdf/xpdf/gpdf.glade b/pdf/xpdf/gpdf.glade
index 91b67d7a..1d71de57 100644
--- a/pdf/xpdf/gpdf.glade
+++ b/pdf/xpdf/gpdf.glade
@@ -87,11 +87,11 @@
 
 	    <widget>
 	      <class>GtkPixmapMenuItem</class>
-	      <name>close1</name>
+	      <name>close</name>
 	      <signal>
 		<name>activate</name>
-		<handler>on_close1_activate</handler>
-		<last_modification_time>Sun, 01 Aug 1999 03:04:00 GMT</last_modification_time>
+		<handler>on_close_activate</handler>
+		<last_modification_time>Sun, 01 Aug 1999 23:33:35 GMT</last_modification_time>
 	      </signal>
 	      <stock_item>GNOMEUIINFO_MENU_CLOSE_ITEM</stock_item>
 	    </widget>
-- 
2.43.5