From 35d3d6d0bb16abeeb6aad2fd0398c8e68a40d414 Mon Sep 17 00:00:00 2001 From: John Tytgat Date: Sat, 26 Jul 2008 16:01:59 +0000 Subject: First merge of Adam Blokus' GSoC work from his branch 'branches/adamblokus/netsurf'. Merged revisions 4212-4552,4554-4709,4711-4724 via svnmerge from svn://svn.netsurf-browser.org/branches/adamblokus/netsurf ........ r4212 | adamblokus | 2008-05-26 19:42:31 +0200 (Mon, 26 May 2008) | 4 lines Pdf plotting skeleton pinned on Print Preview in GTK. Just creates a file and draws lines. ........ r4213 | adamblokus | 2008-05-27 00:11:03 +0200 (Tue, 27 May 2008) | 4 lines Pdf plotter - added drawing some graphic primitives. Still with limited functionality, but a snapshot of the currently viewed page can be made and resembles the original. ........ r4214 | adamblokus | 2008-05-27 11:43:31 +0200 (Tue, 27 May 2008) | 2 lines Corrected encoding name ........ r4215 | adamblokus | 2008-05-27 12:47:26 +0200 (Tue, 27 May 2008) | 3 lines Colours and polygons added. ........ r4217 | adamblokus | 2008-05-27 21:39:35 +0200 (Tue, 27 May 2008) | 6 lines Added rectangles, filled boxes and clipping. Taken into consideration joty's comments. Added a todo list for this part. Added some debug stuff and checking boundaries. ........ r4218 | adamblokus | 2008-05-28 12:37:30 +0200 (Wed, 28 May 2008) | 2 lines Added path ploting (not sure if valid argument order for bezier) and dashed/dotted line styles ........ r4221 | adamblokus | 2008-05-28 22:11:05 +0200 (Wed, 28 May 2008) | 3 lines Some more options in graphic primitives and normalizing some parameters. ........ r4235 | adamblokus | 2008-05-31 22:54:56 +0200 (Sat, 31 May 2008) | 4 lines Plotting changed as jmb suggested (is the least invasive one from the possible) Added dummy bitmap plotting - way of plotting an image is determined by its type. ........ r4251 | adamblokus | 2008-06-03 17:12:15 +0200 (Tue, 03 Jun 2008) | 3 lines Added plotting jpg and png images - quite a lot to improve in this code, but it seems to work ;) ........ r4263 | adamblokus | 2008-06-05 14:20:32 +0200 (Thu, 05 Jun 2008) | 3 lines Added hadling images other than png and jpeg - with transparency. ........ r4267 | adamblokus | 2008-06-06 15:36:34 +0200 (Fri, 06 Jun 2008) | 5 lines Added handling NULL-returns from all mallocs. Added plot_bitmap_tile handling. Changed code style a little. ........ r4327 | adamblokus | 2008-06-12 17:46:34 +0200 (Thu, 12 Jun 2008) | 5 lines Added a first prototype of the paged-output organization. Still not sure about naming, file locations etc. Works with the same pdf plotting as before. ........ r4328 | adamblokus | 2008-06-13 13:52:15 +0200 (Fri, 13 Jun 2008) | 4 lines Added primitive width adjustment and outputing the whole website in multiple pages. ........ r4336 | joty | 2008-06-15 15:06:57 +0200 (Sun, 15 Jun 2008) | 1 line Fix RISC OS build failure (change r4235 wasn't complete). ........ r4337 | joty | 2008-06-15 18:15:32 +0200 (Sun, 15 Jun 2008) | 16 lines This enables "Export PDF" in RISC OS build: - Docs/Doxyfile(PREDEFINED): Added WITH_PDF_EXPORT - Makefile.sources(S_PDF): Add to RISC OS target as well. - utils/config.h: Define WITH_PDF_EXPORT which controls if we want to have PDF export functionality or not. - riscos/save_pdf.c,riscos/save_pdf.h(save_as_pdf): Use PDF print API made by Adam Blokus to write a PDF file under RISC OS. - riscos/save.c: Call save_as_pdf added. - riscos/menus.c: Add 'Export->PDF' menu entry. - riscos/menus.h(menu_action): Added BROWSER_EXPORT_PDF. - desktop/gui.h(gui_save_type): Added GUI_SAVE_PDF. - desktop/print.c(print_run): Added return value. - Makefile(CCACHE): Moved closed to the place where CC is set for the first time. (LDFLAGS): Centralised adding all non-pkgconfig libraries and added Haru + PNG libs. ........ r4343 | adamblokus | 2008-06-16 01:08:52 +0200 (Mon, 16 Jun 2008) | 3 lines Added margins and page size adjustment. ........ r4412 | adamblokus | 2008-06-21 20:22:07 +0200 (Sat, 21 Jun 2008) | 4 lines Added 'fuzzy' margins on page bottom. Disabled direct png embedding, because it is too unstable in Haru now. ........ r4421 | adamblokus | 2008-06-22 18:52:28 +0200 (Sun, 22 Jun 2008) | 2 lines Added "Save as.." dialog and Export->PDF menu entry. Print preview still works with default path. ........ r4437 | adamblokus | 2008-06-25 02:44:46 +0200 (Wed, 25 Jun 2008) | 4 lines Added skeleton of applying loose layout. Minor code cleaning-up. ........ r4492 | adamblokus | 2008-07-02 09:02:42 +0200 (Wed, 02 Jul 2008) | 5 lines Implemented the elementar ideas of the loose layout. Added scaling in the printing routine. Added some basic demonstrations. ........ r4493 | adamblokus | 2008-07-02 09:05:55 +0200 (Wed, 02 Jul 2008) | 3 lines Cleaned up the loosing code - commited to much of leftover rubbish code. ........ r4507 | adamblokus | 2008-07-04 14:25:48 +0200 (Fri, 04 Jul 2008) | 4 lines Added duplicating box tree and current content - window flickering during printing solved. Minor error checking after new HPDF_Image_AddSMask call. ........ r4515 | adamblokus | 2008-07-06 22:28:16 +0200 (Sun, 06 Jul 2008) | 2 lines Changes in loosen layout (image resizing). ........ r4517 | adamblokus | 2008-07-06 22:38:23 +0200 (Sun, 06 Jul 2008) | 2 lines Added pdf font handling and rendering functions with the use of Haru functions. ........ r4555 | adamblokus | 2008-07-10 00:59:05 +0200 (Thu, 10 Jul 2008) | 2 lines Added a very basic and still buggy GTK print implementation. ........ r4565 | adamblokus | 2008-07-10 14:50:16 +0200 (Thu, 10 Jul 2008) | 2 lines Added gtk printing one more time - I have forgotten to add the main file. ........ r4566 | adamblokus | 2008-07-10 14:57:02 +0200 (Thu, 10 Jul 2008) | 2 lines removed error with comment ........ r4569 | adamblokus | 2008-07-10 15:52:55 +0200 (Thu, 10 Jul 2008) | 5 lines Major style improvements - added a lot of doxygen comments, followed tlsa's style guide. Added some more error checking, too. ........ r4575 | adamblokus | 2008-07-10 18:48:26 +0200 (Thu, 10 Jul 2008) | 2 lines Cleaned up the code. ........ r4687 | adamblokus | 2008-07-17 14:17:19 +0200 (Thu, 17 Jul 2008) | 2 lines Changed everything according to jmb's review plus some minor bug fixes to gtk_print. ........ r4688 | adamblokus | 2008-07-17 17:16:34 +0200 (Thu, 17 Jul 2008) | 2 lines Solved the netsurf.glade clash from r4421. ........ r4693 | adamblokus | 2008-07-18 18:11:51 +0200 (Fri, 18 Jul 2008) | 2 lines Fixed bug with wrong number of pages in gtk printing. ........ r4695 | adamblokus | 2008-07-18 19:59:24 +0200 (Fri, 18 Jul 2008) | 3 lines - fixed uncommented line from the previous commit - fixed bug with scale bigger than 1.0 (incorretly clipped page) ........ r4696 | adamblokus | 2008-07-18 23:28:00 +0200 (Fri, 18 Jul 2008) | 2 lines Fixed bug in gtk_print_font_paint (and nsfont_paint). ........ r4697 | adamblokus | 2008-07-18 23:35:38 +0200 (Fri, 18 Jul 2008) | 2 lines Bug fix in nsfont_paint. ........ r4711 | adamblokus | 2008-07-19 22:44:15 +0200 (Sat, 19 Jul 2008) | 2 lines Added gtk_selection files. ........ r4712 | adamblokus | 2008-07-20 11:15:06 +0200 (Sun, 20 Jul 2008) | 2 lines Addam missing glade files. ........ r4713 | joty | 2008-07-20 17:13:10 +0200 (Sun, 20 Jul 2008) | 1 line Follow change r4517 for RISC OS and BeOS platforms : Added pdf font handling and rendering functions with the use of Haru functions. ........ r4714 | joty | 2008-07-20 18:19:50 +0200 (Sun, 20 Jul 2008) | 1 line Declare haru_nsfont iso define an instance for each C source including the font_haru.h header. This fixes breakage of PDF export on RISC OS. ........ r4724 | adamblokus | 2008-07-23 03:30:08 +0200 (Wed, 23 Jul 2008) | 6 lines Applied changes according to joty's review. Added checking the dimensions of a plotted image to pdf plotter. Commented out jpg embedding (it seems to cause some problems I'll bring it back when I figure out what's wrong) . Added back some files removed by mistake. ........ svn path=/trunk/netsurf/; revision=4741 --- desktop/browser.c | 11 +- desktop/gui.h | 1 + desktop/history_core.c | 4 +- desktop/knockout.c | 22 ++-- desktop/plotters.h | 6 +- desktop/print.c | 280 +++++++++++++++++++++++++++++++++++++++++++++++++ desktop/print.h | 75 +++++++++++++ desktop/printer.h | 41 ++++++++ desktop/selection.c | 2 +- desktop/textinput.c | 20 ++-- 10 files changed, 434 insertions(+), 28 deletions(-) create mode 100644 desktop/print.c create mode 100644 desktop/print.h create mode 100644 desktop/printer.h (limited to 'desktop') diff --git a/desktop/browser.c b/desktop/browser.c index 155febc50..495cdf9ee 100644 --- a/desktop/browser.c +++ b/desktop/browser.c @@ -1442,7 +1442,7 @@ void browser_window_mouse_action_html(struct browser_window *bw, int pixel_offset; size_t idx; - nsfont_position_in_string(text_box->style, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, x - gadget_box_x - text_box->x, @@ -1483,7 +1483,7 @@ void browser_window_mouse_action_html(struct browser_window *bw, BROWSER_MOUSE_DRAG_2)) selection_init(bw->sel, gadget_box); - nsfont_position_in_string(text_box->style, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, x - gadget_box_x - text_box->x, @@ -1573,7 +1573,7 @@ void browser_window_mouse_action_html(struct browser_window *bw, int pixel_offset; size_t idx; - nsfont_position_in_string(text_box->style, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, x - text_box_x, @@ -1836,8 +1836,7 @@ void browser_window_mouse_track_html(struct browser_window *bw, if (box) { int pixel_offset; size_t idx; - - nsfont_position_in_string(box->style, + nsfont.font_position_in_string(box->style, box->text, box->length, dx, &idx, &pixel_offset); @@ -1917,7 +1916,7 @@ void browser_window_mouse_drag_end(struct browser_window *bw, box = browser_window_pick_text_box(bw, x, y, dir, &dx, &dy); if (box) { - nsfont_position_in_string( + nsfont.font_position_in_string( box->style, box->text, box->length, diff --git a/desktop/gui.h b/desktop/gui.h index 77fd861c3..c6b1b49cb 100644 --- a/desktop/gui.h +++ b/desktop/gui.h @@ -27,6 +27,7 @@ typedef enum { GUI_SAVE_SOURCE, GUI_SAVE_DRAW, + GUI_SAVE_PDF, GUI_SAVE_TEXT, GUI_SAVE_COMPLETE, GUI_SAVE_OBJECT_ORIG, diff --git a/desktop/history_core.c b/desktop/history_core.c index 2081d132d..9fa085d8d 100644 --- a/desktop/history_core.c +++ b/desktop/history_core.c @@ -597,13 +597,13 @@ bool history_redraw_entry(struct history *history, int tailsize = 5; if (!plot.bitmap(entry->x, entry->y, WIDTH, HEIGHT, - entry->bitmap, 0xffffff)) + entry->bitmap, 0xffffff, NULL)) return false; if (!plot.rectangle(entry->x - 1, entry->y - 1, WIDTH + 1, HEIGHT + 1, entry == history->current ? 2 : 1, c, false, false)) return false; - if (!nsfont_position_in_string(&css_base_style, entry->page.title, + if (!nsfont.font_position_in_string(&css_base_style, entry->page.title, strlen(entry->page.title), WIDTH, &char_offset, &actual_x)) return false; diff --git a/desktop/knockout.c b/desktop/knockout.c index f57ae5b54..cbffa3d39 100644 --- a/desktop/knockout.c +++ b/desktop/knockout.c @@ -61,10 +61,10 @@ static bool knockout_plot_disc(int x, int y, int radius, colour colour, bool fil static bool knockout_plot_arc(int x, int y, int radius, int angle1, int angle2, colour c); static bool knockout_plot_bitmap(int x, int y, int width, int height, - struct bitmap *bitmap, colour bg); + struct bitmap *bitmap, colour bg, struct content *content); static bool knockout_plot_bitmap_tile(int x, int y, int width, int height, struct bitmap *bitmap, colour bg, - bool repeat_x, bool repeat_y); + bool repeat_x, bool repeat_y, struct content *content); static bool knockout_plot_group_start(const char *name); static bool knockout_plot_group_end(void); @@ -194,6 +194,7 @@ struct knockout_entry { int height; struct bitmap *bitmap; colour bg; + struct content *content; } bitmap; struct { int x; @@ -204,6 +205,7 @@ struct knockout_entry { colour bg; bool repeat_x; bool repeat_y; + struct content *content; } bitmap_tile; struct { const char *name; @@ -379,7 +381,8 @@ bool knockout_plot_flush(void) knockout_entries[i].data.bitmap.width, knockout_entries[i].data.bitmap.height, knockout_entries[i].data.bitmap.bitmap, - knockout_entries[i].data.bitmap.bg); + knockout_entries[i].data.bitmap.bg, + knockout_entries[i].data.bitmap.content); break; case KNOCKOUT_PLOT_BITMAP_TILE: box = knockout_entries[i].box->child; @@ -403,7 +406,9 @@ bool knockout_plot_flush(void) knockout_entries[i].data. bitmap_tile.repeat_x, knockout_entries[i].data. - bitmap_tile.repeat_y); + bitmap_tile.repeat_y, + knockout_entries[i].data. + bitmap_tile.content); } break; case KNOCKOUT_PLOT_GROUP_START: @@ -608,7 +613,8 @@ bool knockout_plot_bitmap_tile_recursive(struct knockout_box *box, entry->data.bitmap_tile.bitmap, entry->data.bitmap_tile.bg, entry->data.bitmap_tile.repeat_x, - entry->data.bitmap_tile.repeat_y); + entry->data.bitmap_tile.repeat_y, + entry->data.bitmap_tile.content); } } return success; @@ -802,7 +808,7 @@ bool knockout_plot_arc(int x, int y, int radius, int angle1, int angle2, colour } bool knockout_plot_bitmap(int x, int y, int width, int height, - struct bitmap *bitmap, colour bg) + struct bitmap *bitmap, colour bg, struct content *content) { int kx0, ky0, kx1, ky1; @@ -824,6 +830,7 @@ bool knockout_plot_bitmap(int x, int y, int width, int height, knockout_entries[knockout_entry_cur].data.bitmap.height = height; knockout_entries[knockout_entry_cur].data.bitmap.bitmap = bitmap; knockout_entries[knockout_entry_cur].data.bitmap.bg = bg; + knockout_entries[knockout_entry_cur].data.bitmap.content = content; knockout_entries[knockout_entry_cur].type = KNOCKOUT_PLOT_BITMAP; if (++knockout_entry_cur >= KNOCKOUT_ENTRIES) knockout_plot_flush(); @@ -833,7 +840,7 @@ bool knockout_plot_bitmap(int x, int y, int width, int height, bool knockout_plot_bitmap_tile(int x, int y, int width, int height, struct bitmap *bitmap, colour bg, - bool repeat_x, bool repeat_y) + bool repeat_x, bool repeat_y, struct content *content) { int kx0, ky0, kx1, ky1; @@ -879,6 +886,7 @@ bool knockout_plot_bitmap_tile(int x, int y, int width, int height, knockout_entries[knockout_entry_cur].data.bitmap_tile.bg = bg; knockout_entries[knockout_entry_cur].data.bitmap_tile.repeat_x = repeat_x; knockout_entries[knockout_entry_cur].data.bitmap_tile.repeat_y = repeat_y; + knockout_entries[knockout_entry_cur].data.bitmap_tile.content = content; knockout_entries[knockout_entry_cur].type = KNOCKOUT_PLOT_BITMAP_TILE; if ((++knockout_entry_cur >= KNOCKOUT_ENTRIES) || (++knockout_box_cur >= KNOCKOUT_BOXES)) diff --git a/desktop/plotters.h b/desktop/plotters.h index 79eac8170..16e0d47e6 100644 --- a/desktop/plotters.h +++ b/desktop/plotters.h @@ -25,6 +25,7 @@ #include #include "css/css.h" +#include "content/content.h" struct bitmap; @@ -46,10 +47,11 @@ struct plotter_table { bool (*arc)(int x, int y, int radius, int angle1, int angle2, colour c); bool (*bitmap)(int x, int y, int width, int height, - struct bitmap *bitmap, colour bg); + struct bitmap *bitmap, colour bg, + struct content *content); bool (*bitmap_tile)(int x, int y, int width, int height, struct bitmap *bitmap, colour bg, - bool repeat_x, bool repeat_y); + bool repeat_x, bool repeat_y, struct content *content); bool (*group_start)(const char *name); /** optional */ bool (*group_end)(void); /** optional */ bool (*flush)(void); diff --git a/desktop/print.c b/desktop/print.c new file mode 100644 index 000000000..0852fa34c --- /dev/null +++ b/desktop/print.c @@ -0,0 +1,280 @@ +/* + * Copyright 2008 Adam Blokus + * + * This file is part of NetSurf, http://www.netsurf-browser.org/ + * + * NetSurf is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * NetSurf is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +/** \file + * Output-in-pages implementation +*/ + +#include "desktop/print.h" +#include "desktop/printer.h" + +#include "content/content.h" + +#include "utils/log.h" +#include "utils/talloc.h" + +#include "render/loosen.h" +#include "render/box.h" + +#include "pdf/font_haru.h" + +static struct content *print_init(struct content *, struct print_settings *); +static bool print_apply_settings(struct content *, struct print_settings *); + + +/*TODO: should these be passed as parameters in order to allow simultaneous + printings? +*/ +static float page_content_width, page_content_height; +static float text_margin_height; +static struct content *printed_content; +static float done_height; + +/** + * This function calls print setup, prints page after page until the whole + * content is printed calls cleaning up afterwise. + * \param content The content to be printed + * \param printer The printer interface for the printer to be used + * \param settings The settings for printing to use or NULL for DEFAULT + * \return true if successful, false otherwise +*/ +bool print_basic_run(struct content *content, + const struct printer *printer, + struct print_settings *settings) +{ + bool ret = true; + + if (settings == NULL) + settings = print_make_settings(DEFAULT); + + if (!print_set_up(content, printer, settings, NULL)) + ret = false; + + while (ret && (done_height < printed_content->height) ) + ret = print_draw_next_page(printer, settings); + + print_cleanup(content, printer); + + return ret; +} + +/** + * This function prepares the content to be printed. The current browser content + * is duplicated and resized, printer initialization is called. + * \param content The content to be printed + * \param printer The printer interface for the printer to be used + * \param settings The settings for printing to use + * \param height updated to the height of the printed content + * \return true if successful, false otherwise +*/ +bool print_set_up(struct content *content, + const struct printer *printer, struct print_settings *settings, + double *height) +{ + + printed_content = print_init(content, settings); + + if (!printed_content) + return false; + + print_apply_settings(printed_content, settings); + + if (height) + *height = printed_content->height; + + printer->print_begin(settings); + + done_height = 0; + + return true; +} + +/** + * This function draws one page, beginning with the height offset of done_height + * \param printer The printer interface for the printer to be used + * \param settings The settings for printing to use + * \return true if successful, false otherwise + */ +bool print_draw_next_page(const struct printer *printer, + struct print_settings *settings) +{ + + /*TODO:Plotter will have to be duplicated and passed + as an argument - to allow simultaneous screen and + page plotting*/ + plot = *(printer->plotter); + + printer->print_next_page(); + if( !content_redraw(printed_content, + 0, + -done_height, + 0,0, + 0, + 0, + page_content_width * settings->scale, + page_content_height * settings->scale, + settings->scale, 0xffffff)) + return false; + done_height += page_content_height - text_margin_height; + + return true; +} + +/** + * The content passed to the function is duplicated with its boxes, font + * measuring functions are being set. + * \param content The content to be printed + * \param settings The settings for printing to use + * \return true if successful, false otherwise + */ +struct content *print_init(struct content *content, + struct print_settings *settings) +{ + struct content* printed_content; + struct content_user *user_sentinel; + + content_add_user(content, NULL, (intptr_t)print_init, 0); + + printed_content = talloc_memdup(content, content, sizeof *content); + + if (!printed_content) + return NULL; + + printed_content->data.html.bw = 0; + + user_sentinel = talloc(printed_content, struct content_user); + user_sentinel->callback = 0; + user_sentinel->p1 = user_sentinel->p2 = 0; + user_sentinel->next = 0; + printed_content->user_list = user_sentinel; + content_add_user(printed_content, NULL, (intptr_t)print_init, 0); + + printed_content->data.html.layout = + box_duplicate_tree(content->data.html.layout, + printed_content); + + if (!printed_content->data.html.layout) + return NULL; + + if (settings->font_func == NULL) + printed_content->data.html.font_func = &haru_nsfont; + else + printed_content->data.html.font_func = settings->font_func; + + return printed_content; +} + +/** + * The content is resized to fit page width. In case it is to wide, it is + * loosened. + * \param content The content to be printed + * \param settings The settings for printing to use + * \return true if successful, false otherwise + */ +bool print_apply_settings(struct content *content, + struct print_settings *settings) +{ + if (settings == NULL) + return false; + + /*Apply settings - adjust page size etc*/ + + text_margin_height = settings->margins[MARGINTEXT]; + + page_content_width = (settings->page_width - settings->margins[MARGINLEFT] - + settings->margins[MARGINRIGHT]) / settings->scale; + + page_content_height = (settings->page_height - settings->margins[MARGINTOP] - + settings->margins[MARGINBOTTOM]) / settings->scale; + + content_reformat(content, page_content_width, 0); + LOG(("New layout applied.New height = %d ; New width = %d ", + content->height, content->width)); + + if (content->width > page_content_width) + return loosen_document_layout(content, content->data.html.layout, + page_content_width, page_content_height); + + return true; +} + +/** + * Memory allocated during printing is being freed here. + * \param content The original content + * \param printer The printer interface for the printer to be used + * \return true if successful, false otherwise + */ +bool print_cleanup(struct content *content, + const struct printer *printer) +{ + printer->print_end(); + + if (printed_content) { + content_remove_user(printed_content, NULL, (intptr_t)print_init, 0); + talloc_free(printed_content); + } + + content_remove_user(content, NULL, (intptr_t)print_init, 0); + + return true; +} + +/** + * Generates one of the predefined print settings sets. + * \return print_settings in case if successful, NULL if unknown configuration \ + * or lack of memory. + */ +struct print_settings *print_make_settings(print_configuration configuration) +{ + + struct print_settings *settings; + + switch (configuration){ + case DEFAULT: + settings = (struct print_settings*) + malloc(sizeof (struct print_settings) ); + + if (settings == NULL) + return NULL; + + settings->page_width = 595; + settings->page_height = 840; + settings->copies = 1; + /*with 0.7 the pages look the best, the value in + haru_nsfont_apply_style should be kept the same as this + */ + settings->scale = 0.7; + + settings->margins[MARGINLEFT] = 30; + settings->margins[MARGINRIGHT] = 30; + settings->margins[MARGINTOP] = 30; + settings->margins[MARGINBOTTOM] = 30; + + settings->margins[MARGINTEXT] = 10; + + settings->output = "out.pdf"; + settings->font_func = &haru_nsfont; + + break; + + default: + return NULL; + } + + return settings; +} diff --git a/desktop/print.h b/desktop/print.h new file mode 100644 index 000000000..dc4cde642 --- /dev/null +++ b/desktop/print.h @@ -0,0 +1,75 @@ +/* + * Copyright 2008 Adam Blokus + * + * This file is part of NetSurf, http://www.netsurf-browser.org/ + * + * NetSurf is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * NetSurf is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +/** \file + * Conception: + * Generalized output-in-pages. Allows the current content to be 'printed': + * either into a pdf file (any other later?) or to any kind of other output + * destination that divides the website into pages - as a printer. + * The basic usage is calling print_basic_run which sets everything up, + * prints page after page until the whole content is printed and cleans + * everyting up. + * If there are any other, printer specific routines to be performed in the + * meantime - there can be set up any other printing funcion, which can use + * print_set_up, print_draw_next_page and print_cleanup directly. +*/ + +#ifndef NETSURF_DESKTOP_PRINT_H +#define NETSURF_DESKTOP_PRINT_H + +#include + +struct content; +struct printer; + +enum { MARGINLEFT = 0, MARGINRIGHT = 1, MARGINTOP = 2, MARGINBOTTOM = 3, + MARGINTEXT = 4}; + +/** Predefined printing configuration names*/ +typedef enum {DEFAULT} print_configuration; + +/** Settings for a print - filled in by print_make_settings or + * 'manually' by the caller +*/ +struct print_settings{ + /*Standard parameters*/ + float page_width, page_height; + float margins[5]; + + float scale; + + unsigned int copies; + + /*Output destinations - file/printer name*/ + const char *output; + + /*TODO: more options?*/ + const struct font_functions *font_func; +}; + +bool print_basic_run(struct content *, const struct printer *, struct print_settings *); +bool print_set_up(struct content *content, + const struct printer *printer, struct print_settings *settings, + double *height); +bool print_draw_next_page(const struct printer *printer, + struct print_settings *settings); +bool print_cleanup(struct content *, const struct printer *); + +struct print_settings *print_make_settings(print_configuration configuration); + +#endif diff --git a/desktop/printer.h b/desktop/printer.h new file mode 100644 index 000000000..358922379 --- /dev/null +++ b/desktop/printer.h @@ -0,0 +1,41 @@ +/* + * Copyright 2008 Adam Blokus + * + * This file is part of NetSurf, http://www.netsurf-browser.org/ + * + * NetSurf is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * NetSurf is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +/** \file + * Printer interface - contains plotter to use, functions for + * initialization, handling pages and cleaning up. +*/ + +#ifndef NETSURF_DESKTOP_PRINTER_H +#define NETSURF_DESKTOP_PRINTER_H + +#include "desktop/plotters.h" +#include "desktop/print.h" + +/** Printer interface */ +struct printer{ + const struct plotter_table *plotter; + + bool (*print_begin) (struct print_settings*); + + bool (*print_next_page)(void); + + void (*print_end)(void); +}; + +#endif diff --git a/desktop/selection.c b/desktop/selection.c index 2be6853a2..0dc8e493e 100644 --- a/desktop/selection.c +++ b/desktop/selection.c @@ -601,7 +601,7 @@ bool redraw_handler(const char *text, size_t length, struct box *box, height = box->padding[TOP] + box->height + box->padding[BOTTOM]; if (box->type == BOX_TEXT && box->space && - nsfont_width(box->style, " ", 1, &space_width)) + nsfont.font_width(box->style, " ", 1, &space_width)) width += space_width; if (r->inited) { diff --git a/desktop/textinput.c b/desktop/textinput.c index a90919afe..8cfe01050 100644 --- a/desktop/textinput.c +++ b/desktop/textinput.c @@ -181,7 +181,7 @@ struct box *textarea_get_position(struct box *textarea, int x, int y, assert(text_box->type == BOX_TEXT); assert(text_box->text); /** \todo handle errors */ - nsfont_position_in_string(text_box->style, text_box->text, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, (unsigned int)(x - text_box->x), (size_t *) pchar_offset, ppixel_offset); @@ -203,7 +203,7 @@ struct box *textarea_get_position(struct box *textarea, int x, int y, text_box = inline_container->last; assert(text_box->type == BOX_TEXT); assert(text_box->text); - nsfont_position_in_string(text_box->style, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, textarea->width, @@ -223,7 +223,7 @@ struct box *textarea_get_position(struct box *textarea, int x, int y, } assert(text_box->type == BOX_TEXT); assert(text_box->text); - nsfont_position_in_string(text_box->style, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, (unsigned int)(x - text_box->x), @@ -761,7 +761,7 @@ bool browser_window_textarea_callback(struct browser_window *bw, } } - nsfont_width(text_box->style, text_box->text, + nsfont.font_width(text_box->style, text_box->text, char_offset, &pixel_offset); selection_clear(bw->sel, true); @@ -813,7 +813,7 @@ void browser_window_input_click(struct browser_window* bw, int pixel_offset = 0, dx = 0; struct box *text_box = input->children->children; - nsfont_position_in_string(text_box->style, text_box->text, + nsfont.font_position_in_string(text_box->style, text_box->text, text_box->length, x - text_box->x, &char_offset, &pixel_offset); assert(char_offset <= text_box->length); @@ -1375,7 +1375,7 @@ bool browser_window_textarea_paste_text(struct browser_window *bw, textarea->gadget->caret_text_box = text_box; textarea->gadget->caret_box_offset = char_offset; - nsfont_width(text_box->style, text_box->text, + nsfont.font_width(text_box->style, text_box->text, char_offset, &pixel_offset); textarea->gadget->caret_pixel_offset = pixel_offset; @@ -1508,7 +1508,7 @@ void browser_window_textarea_move_caret(struct browser_window *bw, void *p) box_x -= textarea->scroll_x; box_y -= textarea->scroll_y; - nsfont_width(text_box->style, text_box->text, + nsfont.font_width(text_box->style, text_box->text, char_offset, &pixel_offset); browser_window_place_caret(bw, @@ -1541,7 +1541,7 @@ void browser_window_input_move_caret(struct browser_window *bw, void *p) box_coords(input, &box_x, &box_y); - nsfont_width(text_box->style, text_box->text, box_offset, + nsfont.font_width(text_box->style, text_box->text, box_offset, &pixel_offset); browser_window_place_caret(bw, @@ -1576,12 +1576,12 @@ void input_update_display(struct browser_window *bw, struct box *input, int dx; if (redraw) - nsfont_width(text_box->style, text_box->text, text_box->length, + nsfont.font_width(text_box->style, text_box->text, text_box->length, &text_box->width); box_coords(input, &box_x, &box_y); - nsfont_width(text_box->style, text_box->text, box_offset, + nsfont.font_width(text_box->style, text_box->text, box_offset, (int *) &pixel_offset); /* Shift text box horizontally, so caret is visible */ -- cgit v1.2.3