summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Salvador Cuñat <salvador.cunat@gmail.com>2013-02-15 00:25:22 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-02-15 00:55:44 -0800
commitb4c2fcc802d88fb8721d245e682c99a0237784a0 (patch)
treec023a5b3d90ebc90c0741cf2d8daf35f80211a64
parentb472712162f5c998b9be2e4187151a97360fbedd (diff)
downloadsubsurface-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.c166
1 files changed, 87 insertions, 79 deletions
diff --git a/print.c b/print.c
index a59456ba1..0aed20d2c 100644
--- a/print.c
+++ b/print.c
@@ -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);