diff options
author | Salvador Cuñat <salvador.cunat@gmail.com> | 2013-02-15 00:25:22 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-02-15 00:55:44 -0800 |
commit | b4c2fcc802d88fb8721d245e682c99a0237784a0 (patch) | |
tree | c023a5b3d90ebc90c0741cf2d8daf35f80211a64 | |
parent | b472712162f5c998b9be2e4187151a97360fbedd (diff) | |
download | subsurface-b4c2fcc802d88fb8721d245e682c99a0237784a0.tar.gz |
Modify table print for using pango_layout_get_extents()
1.- On draw_table() we now set the layout, make the scaling *0.5, and the
make traslations row by row.
2.- Wipe out print_table_header and print_table as they now don't make
anything but call show_table which now we can call directly from
draw_table.
3.- Modify show_table to get account of the height of the higher column
and return it.
4.- The frame is now plot with an auxiliar func. directly from draw_table.
With this changes we have a variable height pattern which lets us have
complete the more sensible info (date, time, location, ...) without
wrapping it to fit in the predefined width of the layout.
The printout is tighter than old one so we can print 35 dives in a page,
leaving enough room at the bottom to fit some extra-large (three lines or
more) dives' info. Have increased *1.2 the size of the fonts as they got
too little with the change in DPI. Wrap the header strings to limit the
impact of different string sizes in the different supported languages.
Signed-off-by: Salvador Cuñat <salvador.cunat@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | print.c | 166 |
1 files changed, 87 insertions, 79 deletions
@@ -477,25 +477,17 @@ static void show_dive_tanks(struct dive *dive, cairo_t *cr, double w, g_object_unref (layout); } -static void show_table_header(cairo_t *cr, double w, double h, - PangoFontDescription *font) +static void show_table_header(cairo_t *cr, PangoLayout *layout, double w) { int i; - double maxwidth, maxheight, colwidth, curwidth; - PangoLayout *layout; + double maxwidth, colwidth, curwidth; char headers[7][80]= { N_("Dive#"), N_("Date"), N_("Depth"), N_("Duration"), N_("Master"), N_("Buddy"), N_("Location") }; maxwidth = w * PANGO_SCALE; - maxheight = h * PANGO_SCALE * 0.9; colwidth = maxwidth / 7; - layout = pango_cairo_create_layout(cr); - cairo_move_to(cr, 0, 0); - pango_layout_set_height(layout, maxheight); - set_font(layout, font, FONT_LARGE, PANGO_ALIGN_LEFT); - curwidth = 0; for (i = 0; i < 7; i++) { @@ -512,35 +504,25 @@ static void show_table_header(cairo_t *cr, double w, double h, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); } - cairo_move_to(cr, 0, 0); - g_object_unref(layout); } -static void show_dive_table(struct dive *dive, cairo_t *cr, double w, - double h, PangoFontDescription *font) +static int show_dive_table(struct dive *dive, cairo_t *cr, PangoLayout *layout, double w) { double depth; const char *unit; int len, decimals; - double maxwidth, maxheight, colwidth, curwidth; - PangoLayout *layout; + double maxwidth, colwidth, curwidth; struct tm tm; - char buffer[160], divenr[40]; + char buffer[160], divenr[20]; + PangoRectangle logic_ext; maxwidth = w * PANGO_SCALE; - maxheight = h * PANGO_SCALE * 0.9; - colwidth = maxwidth / 7; - layout = pango_cairo_create_layout(cr); - - cairo_move_to(cr, 0, 0); - pango_layout_set_width(layout, colwidth); - pango_layout_set_height(layout, maxheight); - set_font(layout, font, FONT_NORMAL, PANGO_ALIGN_LEFT); cairo_move_to(cr, 0, 0); curwidth = 0; + int height_count = 0; // Col 1: Dive # *divenr = 0; @@ -551,6 +533,9 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + (colwidth / 2); + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; // Col 2: Date # pango_layout_set_width(layout, colwidth); @@ -568,6 +553,10 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + colwidth; + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; + // Col 3: Depth depth = get_depth_units(dive->maxdepth.mm, &decimals, &unit); @@ -579,6 +568,10 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + (colwidth / 2); + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; + // Col 4: Time len = snprintf(buffer, sizeof(buffer), @@ -589,6 +582,10 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + (colwidth / 2); + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; + // Col 5: Master pango_layout_set_width(layout, colwidth); @@ -597,6 +594,10 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + colwidth; + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; + // Col 6: Buddy cairo_move_to(cr, curwidth / PANGO_SCALE, 0); @@ -604,15 +605,26 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w, pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); curwidth = curwidth + colwidth; + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; + // Col 7: Location cairo_move_to(cr, curwidth / PANGO_SCALE, 0); - pango_layout_set_width(layout, maxwidth - curwidth); + pango_layout_set_width(layout, (maxwidth*0.90) - curwidth); pango_layout_set_text(layout, dive->location ? : " ", -1); pango_layout_set_justify(layout, 0); pango_cairo_show_layout(cr, layout); + pango_layout_get_extents(layout, NULL, &logic_ext); + if (logic_ext.height > height_count) + height_count = logic_ext.height; - g_object_unref(layout); + /* + * Return the bigger column height, will be used to plot the frame and + * and translate the next row + */ + return (height_count); } static void show_dive_profile(struct dive *dive, cairo_t *cr, double w, @@ -668,47 +680,22 @@ static void print(int divenr, cairo_t *cr, double x, double y, double w, cairo_restore(cr); } -static void print_table_header(cairo_t *cr, double x, double y, - double w, double h, PangoFontDescription *font) +/* Plot a grid por each dive */ +static void print_table_frame(cairo_t *cr, double x, double y, double w, double h) { - cairo_save(cr); - cairo_translate(cr, x, y); - - /* Plus 5% on all sides */ - cairo_translate(cr, w/20, h/20); - w *= 0.9; h *= 0.9; - - /* We actually want to scale the text and the lines now */ - cairo_scale(cr, 0.5, 0.5); - - show_table_header(cr, w*2, h*2, font); - - cairo_restore(cr); -} - -static void print_table(int divenr, cairo_t *cr, double x, double y, - double w, double h, PangoFontDescription *font) -{ - struct dive *dive; - double maxwidth, curwidth; + double curwidth, maxwidth; int i; - dive = get_dive_for_printing(divenr); - if (!dive) - return; - cairo_save(cr); - - /*Create a frame for each print x,y are provided in draw_page()*/ - maxwidth = w * 0.90; - curwidth = w * 0.045; - cairo_rectangle(cr, curwidth, y, maxwidth, h); + maxwidth = w*2; + curwidth = x; + cairo_rectangle(cr, x, y, maxwidth*0.90, h); cairo_set_line_width(cr, 0.01); cairo_set_line_join(cr, CAIRO_LINE_JOIN_MITER); cairo_stroke(cr); for (i = 0; i < 6; i++) { if (i == 0 || i == 2 || i == 3){ // Column 0, 2 and 3 (Dive #, Depth and Time) get 1/2 width - curwidth = curwidth + (maxwidth/7/2); + curwidth = curwidth + (maxwidth/14); } else { curwidth = curwidth + (maxwidth/7); } @@ -717,19 +704,6 @@ static void print_table(int divenr, cairo_t *cr, double x, double y, cairo_set_line_width (cr, 0.01); cairo_stroke(cr); } - - cairo_translate(cr, x, y); - - /* Plus 5% on all sides */ - cairo_translate(cr, w/20, h/20); - w *= 0.9; h *= 0.9; - - /* We actually want to scale the text and the lines now */ - cairo_scale(cr, 0.5, 0.5); - - show_dive_table(dive, cr, w*2, h*2, font); - - cairo_restore(cr); } /* Positioning factor for height 0,0,1,1,2 ... */ @@ -816,25 +790,59 @@ static void draw_table(GtkPrintOperation *operation, gint page_nr, gpointer user_data) { - int i, nr; - int n_dive_per_page = 25; + int i, nr, maxwidth, maxheight; + int n_dive_per_page = 35; cairo_t *cr; - double w, h; + double w, h, max_ext; + struct dive *dive; PangoFontDescription *font; + PangoLayout *layout; + PangoRectangle logic_ext; cr = gtk_print_context_get_cairo_context(context); font = pango_font_description_from_string("Sans"); + cairo_save(cr); w = gtk_print_context_get_width(context); h = gtk_print_context_get_height(context)/(n_dive_per_page+1); + maxwidth = w * PANGO_SCALE; + maxheight = h * PANGO_SCALE * 0.9; + + layout = pango_cairo_create_layout(cr); + pango_layout_set_height(layout, maxheight); + pango_layout_set_width (layout, maxwidth); + pango_layout_set_wrap(layout, PANGO_WRAP_WORD_CHAR); + set_font(layout, font, FONT_LARGE*1.2, PANGO_ALIGN_LEFT); + + /* We actually want to scale the text and the lines now */ + cairo_scale(cr, 0.5, 0.5); nr = page_nr*n_dive_per_page; - print_table_header(cr, 0, 0+h, w, h, font); + pango_layout_get_extents(layout, NULL, &logic_ext); + cairo_translate (cr, w/10, 2 * logic_ext.height / (double) PANGO_SCALE); + show_table_header(cr, layout, w*2); + set_font(layout, font, FONT_NORMAL*1.2, PANGO_ALIGN_LEFT); + /* We wanted the header ellipsized but not the data */ + pango_layout_set_ellipsize (layout, PANGO_ELLIPSIZE_NONE); + + /* Get the height for an only line but move two down */ + pango_layout_get_extents(layout, NULL, &logic_ext); + cairo_translate (cr, 0, (2 * logic_ext.height) / (double) PANGO_SCALE); + for (i = 0; i < n_dive_per_page; i++) { - print_table(nr+i, cr, 0, h*1.5+h*i, w, h, font); + dive = get_dive_for_printing(nr+i); + if (!dive) + return; + /* Write the dive data and get the max. height of the row */ + max_ext = show_dive_table(dive, cr, layout, w*2); + /* Draw a frame for each row */ + print_table_frame (cr, -0.05, -0.02, w, max_ext / (double) PANGO_SCALE); + /* and move down by the max. height of it */ + cairo_translate (cr, 0, max_ext / (double) PANGO_SCALE); } - + cairo_restore (cr); pango_font_description_free(font); + g_object_unref (layout); } static int nr_selected_dives(void) @@ -862,7 +870,7 @@ static void begin_print(GtkPrintOperation *operation, gpointer user_data) } else if (print_options.type == TWOPERPAGE) { dives_per_page = 2; } else { - dives_per_page = 25; + dives_per_page = 35; } pages = (dives + dives_per_page - 1) / dives_per_page; gtk_print_operation_set_n_pages(operation, pages); |