summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-20 19:30:38 -0700
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-20 19:30:38 -0700
commitd8d631aa842a996af518db8e5f2c3721fceb59e3 (patch)
tree0ddbc19f62da79f4e8de4ec076645453c33443a7
parentac80ff1c481ca366cd36abe8620c696bac429f85 (diff)
downloadsubsurface-d8d631aa842a996af518db8e5f2c3721fceb59e3.tar.gz
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 <torvalds@linux-foundation.org>
-rw-r--r--print.c65
1 files changed, 58 insertions, 7 deletions
diff --git a/print.c b/print.c
index 41e090d44..99db33a33 100644
--- a/print.c
+++ b/print.c
@@ -1,10 +1,64 @@
+#include <stdio.h>
+#include <string.h>
+#include <stdarg.h>
#include <gtk/gtk.h>
#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)