]> www.fi.muni.cz Git - evince.git/blob - pdf/xpdf/gpdf.cc
b1c01800a837ff4db31449b778c0ea2d1ba4cbe7
[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 #undef  GString 
19 #include "gtypes.h"
20 #include "GString.h"
21 #include "parseargs.h"
22 #include "gfile.h"
23 #include "gmem.h"
24 #include "Object.h"
25 #include "Stream.h"
26 #include "Array.h"
27 #include "Dict.h"
28 #include "XRef.h"
29 #include "Catalog.h"
30 #include "Page.h"
31 #include "Link.h"
32 #include "PDFDoc.h"
33 #include "GOutputDev.h"
34 #include "PSOutputDev.h"
35 #include "TextOutputDev.h"
36 #include "Params.h"
37 #include "Error.h"
38 #include "config.h"
39
40 GBool printCommands = gFalse;
41 gint  gpdf_debug=1;
42 poptContext ctx;
43
44 #define DOC_KEY "xpdf_doc_key"
45 #define DOC_ROOT_MAGIC 0xad3f556d
46 struct DOC_ROOT {
47   guint32        magic;
48   GString        *title;
49   PDFDoc         *pdf;
50   GtkWidget      *toplevel;
51   GtkWidget      *table;
52   GnomeAppBar    *appbar;
53   GtkDrawingArea *area;
54   GdkPixmap      *pixmap;
55   OutputDev      *out;
56   GdkColor        paper;
57 };
58
59 static void
60 crummy_cmd (GtkWidget *widget, DOC_ROOT *tmp)
61 {
62   printf ("Crummy\n");
63 }
64
65
66 const struct poptOption gpdf_popt_options [] = {
67   { "debug", '\0', POPT_ARG_INT, &gpdf_debug, 0,
68     N_("Enables some debugging functions"), N_("LEVEL") },
69   { NULL, '\0', 0, NULL, 0 }
70 };
71
72
73 static GnomeUIInfo dummy_menu [] = {
74         { GNOME_APP_UI_ITEM, N_("_dummy"),
75           N_("What a dummy!"), crummy_cmd },
76         GNOMEUIINFO_END
77 };
78
79 static GnomeUIInfo main_menu [] = {
80         { GNOME_APP_UI_SUBTREE, N_("_Dummy"), NULL, dummy_menu },
81         GNOMEUIINFO_END
82 };
83
84 //------------------------------------------------------------------------
85 // loadFile / displayPage
86 //------------------------------------------------------------------------
87
88 static gint
89 doc_config_event (GtkWidget *widget, void *ugly)
90 {
91   DOC_ROOT *doc;
92
93   doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
94   
95   g_return_val_if_fail (doc, FALSE);
96   g_return_val_if_fail (doc->magic == DOC_ROOT_MAGIC, FALSE);
97
98   if (doc->pixmap)
99     gdk_pixmap_unref(doc->pixmap);
100
101   doc->pixmap = gdk_pixmap_new(widget->window,
102                                widget->allocation.width,
103                                widget->allocation.height,
104                                -1);
105
106   printf ("Creating pixmap of size %d %d\n",
107           widget->allocation.width, widget->allocation.height);
108   gdk_color_white (gtk_widget_get_default_colormap(), &doc->paper);
109   doc->out    = new GOutputDev (doc->pixmap, doc->paper);
110
111
112   {
113     GdkGCValues gcValues;
114     GdkGC *strokeGC;
115     
116     gdk_color_white (gtk_widget_get_default_colormap (), &gcValues.foreground);
117     gdk_color_black (gtk_widget_get_default_colormap (), &gcValues.background);
118     gcValues.line_width = 1;
119     gcValues.line_style = GDK_LINE_SOLID;
120     strokeGC = gdk_gc_new_with_values (
121       doc->pixmap, &gcValues, 
122       (enum GdkGCValuesMask)(GDK_GC_FOREGROUND | GDK_GC_BACKGROUND | GDK_GC_LINE_WIDTH | GDK_GC_LINE_STYLE));
123
124     gdk_draw_rectangle (doc->pixmap,
125                         strokeGC,
126                         TRUE,
127                         0, 0,
128                         widget->allocation.width,
129                         widget->allocation.height);
130   }
131   return TRUE;
132 }
133
134 GdkGC   *magic_black;
135
136 static gint
137 doc_redraw_event (GtkWidget *widget, GdkEventExpose *event)
138 {
139   DOC_ROOT *doc;
140  
141   g_return_val_if_fail (widget != NULL, FALSE);
142
143   doc = (DOC_ROOT *)gtk_object_get_data (GTK_OBJECT (widget), DOC_KEY);
144
145   g_return_val_if_fail (doc != NULL, FALSE);
146   g_return_val_if_fail (doc->magic == DOC_ROOT_MAGIC, FALSE);
147
148   if (doc->out && doc->pdf) {
149     GtkStyle *style = gtk_widget_get_default_style();
150     printf ("There are %d pages\n", doc->pdf->getNumPages());
151
152     magic_black = widget->style->black_gc;
153
154     doc->pdf->displayPage(doc->out, 1, 86, 0, gTrue);
155     gdk_draw_pixmap(widget->window,
156                     widget->style->fg_gc[GTK_WIDGET_STATE (widget)],
157                     doc->pixmap,
158                     0, 0,
159                     event->area.x, event->area.y,
160                     event->area.width, event->area.height);
161   } else
162     printf ("Null pointer error %p %p\n", doc->out, doc->pdf);
163   
164   return FALSE;
165 }
166
167 static GBool
168 loadFile(GString *fileName)
169 {
170   DOC_ROOT *doc = new DOC_ROOT();
171   char s[20];
172   char *p;
173
174   doc->magic = DOC_ROOT_MAGIC;
175   // open PDF file
176   doc->pdf = new PDFDoc(fileName);
177   if (!doc->pdf->isOk()) {
178     delete doc->pdf;
179     delete doc;
180     return gFalse;
181   }
182
183   g_assert (doc->pdf->getCatalog());
184
185   doc->toplevel = gnome_app_new ("gpdf", "gpdf");
186   gtk_window_set_policy(GTK_WINDOW(doc->toplevel), 1, 1, 0);
187   gtk_window_set_default_size (GTK_WINDOW(doc->toplevel), 600, 400);
188   doc->table  = GTK_WIDGET (gtk_table_new (0, 0, 0));
189   doc->appbar = GNOME_APPBAR (gnome_appbar_new (FALSE, TRUE,
190                                                 GNOME_PREFERENCES_USER));
191   gnome_app_set_statusbar (GNOME_APP (doc->toplevel),
192                            GTK_WIDGET (doc->appbar));
193   gnome_app_set_contents (GNOME_APP (doc->toplevel), doc->table);
194   gnome_app_create_menus_with_data (GNOME_APP (doc->toplevel), main_menu, doc);
195   gnome_app_install_menu_hints(GNOME_APP (doc->toplevel), main_menu);
196
197   doc->pixmap = NULL;
198   doc->area   = GTK_DRAWING_AREA (gtk_drawing_area_new ());
199   gtk_object_set_data (GTK_OBJECT (doc->area), DOC_KEY, doc);
200   gtk_signal_connect  (GTK_OBJECT (doc->area),"configure_event",
201                        (GtkSignalFunc) doc_config_event, doc);
202   gtk_signal_connect  (GTK_OBJECT (doc->area), "expose_event",
203                        (GtkSignalFunc) doc_redraw_event, doc);
204
205   gtk_table_attach (GTK_TABLE (doc->table), GTK_WIDGET (doc->area),
206                     0, 1, 1, 2,
207                     GTK_FILL | GTK_EXPAND, GTK_FILL | GTK_EXPAND,
208                     0, 0);
209
210   gtk_widget_show_all (doc->toplevel);
211
212   return gTrue;
213 }
214
215 /*static void displayPage(int page1, int zoom1, int rotate1) {
216   char s[20];
217
218   // check for document
219   if (!doc)
220     return;
221
222   // busy cursor
223   if (win)
224     win->setBusyCursor(gTrue);
225
226   // new page/zoom/rotate values
227   page = page1;
228   zoom = zoom1;
229   rotate = rotate1;
230
231   // initialize mouse-related stuff
232   linkAction = NULL;
233   win->setDefaultCursor();
234   linkLabel->setText(NULL);
235   selectXMin = selectXMax = 0;
236   selectYMin = selectYMax = 0;
237   lastDragLeft = lastDragTop = gTrue;
238
239   // draw the page
240   doc->displayPage(out, page, zoomDPI[zoom - minZoom], rotate, gTrue);
241   layoutCbk(win);
242
243   // update page number display
244   sprintf(s, "%d", page);
245   pageNumText->setText(s);
246
247   // back to regular cursor
248   win->setBusyCursor(gFalse);
249   }*/
250
251 int
252 main (int argc, char *argv [])
253 {
254   char **view_files = NULL;
255   int lp;
256
257   gnome_init_with_popt_table (
258     "gpdf", "0.1", argc, argv,
259     gpdf_popt_options, 0, &ctx);
260
261   errorInit();
262   
263   initParams (xpdfConfigFile); /* Init font path */
264
265   view_files = poptGetArgs (ctx);
266   /* Load files */
267   if (view_files) {
268     for (lp=0;view_files[lp];lp++) {
269       GString *name = new GString (view_files[lp]);
270       if (!name || !loadFile(name))
271         printf ("Error loading '%s'\n", view_files[lp]);
272     }
273   } else {
274     printf ("Need filenames...\n");
275     exit (0);
276   }
277
278   poptFreeContext (ctx);
279
280   gtk_main ();
281
282   freeParams();
283
284   /* Destroy files */
285 }