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