summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--dive.c31
-rw-r--r--dive.h2
-rw-r--r--print.c166
-rw-r--r--save-xml.c17
4 files changed, 111 insertions, 105 deletions
diff --git a/dive.c b/dive.c
index 35f1c3f46..e1c564dfb 100644
--- a/dive.c
+++ b/dive.c
@@ -484,34 +484,35 @@ static void fixup_watertemp(struct dive *dive)
dive->watertemp.mkelvin = (sum + nr / 2) / nr;
}
-void fixup_airtemp(struct dive *dive)
+/*
+ * What do the dive computers say the air temperature is?
+ */
+unsigned int dc_airtemp(struct divecomputer *dc)
{
- struct divecomputer *dc;
int sum = 0, nr = 0;
- if (dive->airtemp.mkelvin)
- return;
- for_each_dc(dive, dc) {
+ do {
if (dc->airtemp.mkelvin) {
sum += dc->airtemp.mkelvin;
nr++;
}
- }
- if (nr)
- dive->airtemp.mkelvin = (sum + nr / 2) / nr;
+ } while ((dc = dc->next) != NULL);
+ if (!nr)
+ return 0;
+ return (sum + nr / 2) / nr;
+}
+
+static void fixup_airtemp(struct dive *dive)
+{
+ if (!dive->airtemp.mkelvin)
+ dive->airtemp.mkelvin = dc_airtemp(&dive->dc);
}
/* zero out the airtemp in the dive structure if it was just created by
* running fixup on the dive. keep it if it had been edited by hand */
static void un_fixup_airtemp(struct dive *a)
{
- temperature_t temp;
- temp.mkelvin = a->airtemp.mkelvin;
- a->airtemp.mkelvin = 0;
- fixup_airtemp(a);
- if (a->airtemp.mkelvin && a->airtemp.mkelvin != temp.mkelvin)
- a->airtemp.mkelvin = temp.mkelvin;
- else
+ if (a->airtemp.mkelvin && a->airtemp.mkelvin == dc_airtemp(&a->dc))
a->airtemp.mkelvin = 0;
}
diff --git a/dive.h b/dive.h
index fdeac977a..8e68c9dab 100644
--- a/dive.h
+++ b/dive.h
@@ -561,7 +561,7 @@ extern void finish_sample(struct divecomputer *dc);
extern void sort_table(struct dive_table *table);
extern void report_dives(gboolean imported, gboolean prefer_imported);
extern struct dive *fixup_dive(struct dive *dive);
-extern void fixup_airtemp(struct dive *dive);
+extern unsigned int dc_airtemp(struct divecomputer *dc);
extern struct dive *merge_dives(struct dive *a, struct dive *b, int offset, gboolean prefer_downloaded);
extern struct dive *try_to_merge(struct dive *a, struct dive *b, gboolean prefer_downloaded);
extern void renumber_dives(int nr);
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);
diff --git a/save-xml.c b/save-xml.c
index c0af41c4c..b3bf9701d 100644
--- a/save-xml.c
+++ b/save-xml.c
@@ -152,17 +152,14 @@ static void save_depths(FILE *f, struct divecomputer *dc)
static void save_dive_temperature(FILE *f, struct dive *dive)
{
- temperature_t temp;
- temp.mkelvin = dive->airtemp.mkelvin;
- dive->airtemp.mkelvin = 0;
- fixup_airtemp(dive);
- if (dive->airtemp.mkelvin && temp.mkelvin != dive->airtemp.mkelvin) {
- fputs(" <divetemperature", f);
- show_temperature(f, temp, " air='", "'");
- fputs(" />\n", f);
- }
- dive->airtemp.mkelvin = temp.mkelvin;
+ if (!dive->airtemp.mkelvin)
+ return;
+ if (dive->airtemp.mkelvin == dc_airtemp(&dive->dc))
+ return;
+ fputs(" <divetemperature", f);
+ show_temperature(f, dive->airtemp, " air='", "'");
+ fputs("/>\n", f);
}
static void save_temperatures(FILE *f, struct divecomputer *dc)