]> www.fi.muni.cz Git - evince.git/blob - pdf/xpdf/gpdf.cc
6b1485a061d72b9e571a60892ed16275dc841a9d
[evince.git] / pdf / xpdf / gpdf.cc
1 //========================================================================
2 //
3 // gpdf.cc
4 //
5 // Copyright 1996 Derek B. Noonburg
6 // Copyright 1999 Michael Meeks.
7 // Copyright 1999 Miguel de Icaza
8 //
9 //========================================================================
10
11
12 #include <stdio.h>
13 #include <stdlib.h>
14 #include <stddef.h>
15 #include <string.h>
16 #define GString G_String
17 #include <gnome.h>
18 #include <glade/glade.h>
19 #undef  GString 
20 #include "gtypes.h"
21 #include "GString.h"
22 #include "parseargs.h"
23 #include "gfile.h"
24 #include "gmem.h"
25 #include "Object.h"
26 #include "Stream.h"
27 #include "Array.h"
28 #include "Dict.h"
29 #include "XRef.h"
30 #include "Catalog.h"
31 #include "Page.h"
32 #include "Link.h"
33 #include "PDFDoc.h"
34 #include "GOutputDev.h"
35 #include "PSOutputDev.h"
36 #include "TextOutputDev.h"
37 #include "Params.h"
38 #include "Error.h"
39 #include "config.h"
40
41 #define GPDF_GLADE_DIR "/opt/gnome/src/xpdf/xpdf"
42
43 GBool printCommands = gFalse;
44 gint  gpdf_debug=1;
45 poptContext ctx;
46
47 #define DOC_KEY "xpdf_doc_key"
48 struct DOC_ROOT {
49   GString        *title;
50   PDFDoc         *pdf;
51   GtkDrawingArea *area;
52   GdkPixmap      *pixmap;
53   OutputDev      *out;
54   GdkColor        paper;
55   GtkScrolledWindow *scroll;
56   GtkWidget      *mainframe;
57   GladeXML       *gui;
58 };
59
60 const struct poptOption gpdf_popt_options [] = {
61   { "debug", '\0', POPT_ARG_INT, &gpdf_debug, 0,
62     N_("Enables some debugging functions"), N_("LEVEL") },
63   { NULL, '\0', 0, NULL, 0 }
64 };
65
66 //------------------------------------------------------------------------
67 // loadFile / displayPage
68 //------------------------------------------------------------------------
69
70 static gint
71 doc_config_event (GtkWidget *widget, void *ugly)
72 {
73   DOC_ROOT *doc;
74
75   doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
76   
77   g_return_val_if_fail (doc, FALSE);
78
79   if (doc->pixmap)
80     gdk_pixmap_unref(doc->pixmap);
81
82   doc->pixmap = gdk_pixmap_new(widget->window,
83                                widget->allocation.width,
84                                widget->allocation.height,
85                                -1);
86
87   printf ("Creating pixmap of size %d %d\n",
88           widget->allocation.width, widget->allocation.height);
89   gdk_color_white (gtk_widget_get_default_colormap(), &doc->paper);
90   doc->out    = new GOutputDev (doc->pixmap, doc->paper,
91                                 gtk_widget_get_parent_window (widget));
92
93
94   {
95     GdkGCValues gcValues;
96     GdkGC *strokeGC;
97     
98     gdk_color_white (gtk_widget_get_default_colormap (), &gcValues.foreground);
99     gdk_color_black (gtk_widget_get_default_colormap (), &gcValues.background);
100     gcValues.line_width = 1;
101     gcValues.line_style = GDK_LINE_SOLID;
102     strokeGC = gdk_gc_new_with_values (
103       doc->pixmap, &gcValues, 
104       (enum GdkGCValuesMask)(GDK_GC_FOREGROUND | GDK_GC_BACKGROUND | GDK_GC_LINE_WIDTH | GDK_GC_LINE_STYLE));
105
106     gdk_draw_rectangle (doc->pixmap,
107                         strokeGC,
108                         TRUE,
109                         0, 0,
110                         widget->allocation.width,
111                         widget->allocation.height);
112   }
113   return TRUE;
114 }
115
116 static gint
117 doc_redraw_event (GtkWidget *widget, GdkEventExpose *event)
118 {
119   DOC_ROOT *doc;
120  
121   g_return_val_if_fail (widget != NULL, FALSE);
122
123   doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
124
125   g_return_val_if_fail (doc != NULL, FALSE);
126
127   if (doc->out && doc->pdf) {
128     printf ("There are %d pages\n", doc->pdf->getNumPages());
129
130     doc->pdf->displayPage(doc->out, 1, 86, 0, gTrue);
131     gdk_draw_pixmap(widget->window,
132                     widget->style->fg_gc[GTK_WIDGET_STATE (widget)],
133                     doc->pixmap,
134                     0, 0,
135                     event->area.x, event->area.y,
136                     event->area.width, event->area.height);
137   } else
138     printf ("Null pointer error %p %p\n", doc->out, doc->pdf);
139   
140   return FALSE;
141 }
142
143 static PDFDoc *
144 getPDF (GString *fname)
145 {
146   PDFDoc *pdf;
147   pdf = new PDFDoc(fname);
148   if (!pdf->isOk()) {
149     delete pdf;
150     return NULL;
151   }
152   g_return_val_if_fail (pdf->getCatalog(), NULL);
153   return pdf;
154 }
155
156
157 static GBool
158 loadPDF(GString *fileName)
159 {
160   DOC_ROOT *doc = new DOC_ROOT();
161   GtkVBox  *pane;
162   GtkAdjustment *hadj, *vadj;
163
164   // open PDF file
165   doc->pdf = getPDF (fileName);
166   if (!doc->pdf) {
167     delete doc;
168     return gFalse;
169   }
170
171   doc->gui = glade_xml_new (GPDF_GLADE_DIR "/gpdf.glade", NULL);
172   if (!doc->gui ||
173       !(doc->mainframe = glade_xml_get_widget (doc->gui, "gpdf")) ||
174       !(pane = GTK_VBOX (glade_xml_get_widget (doc->gui, "pane")))) {
175     printf ("Couldn't find " GPDF_GLADE_DIR "/gpdf.glade\n");
176     delete doc->pdf;
177     delete doc;
178     return gFalse;
179   }
180     
181   doc->pixmap = NULL;
182   doc->area   = GTK_DRAWING_AREA (gtk_drawing_area_new ());
183
184   gtk_object_set_data (GTK_OBJECT (doc->area), DOC_KEY, doc);
185   gtk_signal_connect  (GTK_OBJECT (doc->area),"configure_event",
186                        (GtkSignalFunc) doc_config_event, doc);
187   gtk_signal_connect  (GTK_OBJECT (doc->area), "expose_event",
188                        (GtkSignalFunc) doc_redraw_event, doc);
189
190   hadj = GTK_ADJUSTMENT (gtk_adjustment_new (0, 0, 1, 0.01, 0.1, 2));
191   vadj = GTK_ADJUSTMENT (gtk_adjustment_new (0, 0, 1, 0.01, 0.1, 2));
192   doc->scroll = GTK_SCROLLED_WINDOW (gtk_scrolled_window_new (hadj, vadj));
193   gtk_scrolled_window_add_with_viewport (doc->scroll, GTK_WIDGET (doc->area));
194   gtk_box_pack_start (GTK_BOX (pane), GTK_WIDGET (doc->scroll), TRUE, TRUE, 0);
195
196   gtk_widget_show_all (doc->mainframe);
197   return gTrue;
198 }
199
200 /*static void displayPage(int page1, int zoom1, int rotate1) {
201   char s[20];
202
203   // check for document
204   if (!doc)
205     return;
206
207   // busy cursor
208   if (win)
209     win->setBusyCursor(gTrue);
210
211   // new page/zoom/rotate values
212   page = page1;
213   zoom = zoom1;
214   rotate = rotate1;
215
216   // initialize mouse-related stuff
217   linkAction = NULL;
218   win->setDefaultCursor();
219   linkLabel->setText(NULL);
220   selectXMin = selectXMax = 0;
221   selectYMin = selectYMax = 0;
222   lastDragLeft = lastDragTop = gTrue;
223
224   // draw the page
225   doc->displayPage(out, page, zoomDPI[zoom - minZoom], rotate, gTrue);
226   layoutCbk(win);
227
228   // update page number display
229   sprintf(s, "%d", page);
230   pageNumText->setText(s);
231
232   // back to regular cursor
233   win->setBusyCursor(gFalse);
234   }*/
235
236
237 int
238 main (int argc, char *argv [])
239 {
240   char **view_files = NULL;
241   int    i;
242   
243   gnome_init_with_popt_table (
244     "gpdf", "0.1", argc, argv,
245     gpdf_popt_options, 0, &ctx);
246
247   errorInit();
248   
249   initParams (xpdfConfigFile); /* Init font path */
250
251   glade_gnome_init ();
252
253   view_files = poptGetArgs (ctx);
254   /* Load files */
255   if (view_files) {
256     for (i = 0; view_files[i]; i++) {
257       GString *name = new GString (view_files[i]);
258       if (!name || !loadPDF (name))
259         printf ("Error loading '%s'\n", view_files[i]);
260     }
261   } else {
262     printf ("Need filenames...\n");
263     exit (0);
264   }
265
266   poptFreeContext (ctx);
267
268   gtk_main ();
269
270   freeParams();
271
272   /* Destroy files */
273 }