From d8d631aa842a996af518db8e5f2c3721fceb59e3 Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Tue, 20 Sep 2011 19:30:38 -0700 Subject: [PATCH] Add completely BS dive text printing The layout is crap, the handling of long lines in notes (or location) is wrong, the dive number handling is wrong. The thing is just a toy. But it's a toy that kind of works, and gives a much better idea of what a real dive log printout might look like. With the right kind of dive notes, it looks fine. Signed-off-by: Linus Torvalds --- print.c | 65 ++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 58 insertions(+), 7 deletions(-) diff --git a/print.c b/print.c index 41e090d..99db33a 100644 --- a/print.c +++ b/print.c @@ -1,10 +1,64 @@ +#include +#include +#include #include #include "dive.h" #include "display.h" #include "display-gtk.h" -static void show_one_dive(struct dive *dive, cairo_t *cr, double w, double h) +static void show_text(cairo_t *cr, int size, double x, double y, const char *fmt, ...) +{ + va_list args; + char buffer[256], *p; + + va_start(args, fmt); + vsnprintf(buffer, sizeof(buffer), fmt, args); + va_end(args); + + cairo_set_font_size(cr, size); + + p = buffer; + do { + char *n = strchr(p, '\n'); + if (n) + *n++ = 0; + cairo_move_to(cr, x, y); + cairo_show_text(cr, p); + p = n; + y += size; + } while (p); +} + +/* + * You know what? Maybe somebody can do a real Pango layout thing. + * + * I'm going to do this with the cairo engine instead. I can only learn so + * many new interfaces. + */ +static void show_dive_text(struct dive *dive, cairo_t *cr, double w, double h) +{ + struct tm *tm; + + tm = gmtime(&dive->when); + show_text(cr, 16, 0, 2, "Dive #%d - %s, %s %d, %d %d:%02d", + dive->number, + weekday(tm->tm_wday), + monthname(tm->tm_mon), + tm->tm_mday, tm->tm_year + 1900, + tm->tm_hour, tm->tm_min); + + show_text(cr, 10, w*0.6, 0, + "Max depth: %d ft\nDuration: %d:%02d", + to_feet(dive->maxdepth), + dive->duration.seconds / 60, + dive->duration.seconds % 60); + + show_text(cr, 10, 0, 20, "%s", dive->location ?: ""); + show_text(cr, 10, 0, 30, "%s", dive->notes ?: ""); +} + +static void show_dive_profile(struct dive *dive, cairo_t *cr, double w, double h) { struct graphics_context gc = { .printer = 1, @@ -27,9 +81,11 @@ static void print(int divenr, cairo_t *cr, double x, double y, double w, double cairo_scale(cr, 0.5, 0.5); /* Dive plot in the upper 75% - note the scaling */ - show_one_dive(dive, cr, w*2, h*1.5); + show_dive_profile(dive, cr, w*2, h*1.5); /* Dive information in the lower 25% */ + cairo_translate(cr, 0, h*1.5); + show_dive_text(dive, cr, w*2, h*0.5); cairo_restore(cr); } @@ -41,11 +97,9 @@ static void draw_page(GtkPrintOperation *operation, { int nr; cairo_t *cr; - PangoLayout *layout; double w, h; cr = gtk_print_context_get_cairo_context(context); - layout=gtk_print_context_create_pango_layout(context); w = gtk_print_context_get_width(context)/2; h = gtk_print_context_get_height(context)/3; @@ -57,9 +111,6 @@ static void draw_page(GtkPrintOperation *operation, print(nr+3, cr, w, h, w, h); print(nr+2, cr, 0, 2*h, w, h); print(nr+3, cr, w, 2*h, w, h); - - pango_cairo_show_layout(cr,layout); - g_object_unref(layout); } static void begin_print(GtkPrintOperation *operation, gpointer user_data) -- 2.45.2