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