mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Merge branch 'print_table' of http://ambre.pingoured.fr/cgit/subsurface
Pull table printing improvements from Pierre-Yves Chibon: "I cleaned up the print options as asked so that we only have the choice between the "pretty-print" and the "table-print". The table layout has been improved." * 'print_table' of http://ambre.pingoured.fr/cgit/subsurface: Remove the pretty-print without dive profile option. Have a nice table formating with choosing the 'Table print' option. Invert the print 'dive profile' option. Deactivate 'Show profiles' if 'table print' is checked.
This commit is contained in:
commit
348afc3f57
2 changed files with 101 additions and 149 deletions
|
@ -28,7 +28,6 @@ extern void attach_tooltip(int x, int y, int w, int h, const char *text);
|
||||||
|
|
||||||
struct options {
|
struct options {
|
||||||
enum { PRETTY, TABLE } type;
|
enum { PRETTY, TABLE } type;
|
||||||
gboolean print_profiles;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern char zoomed_plot;
|
extern char zoomed_plot;
|
||||||
|
|
249
print.c
249
print.c
|
@ -13,14 +13,6 @@
|
||||||
|
|
||||||
static struct options print_options;
|
static struct options print_options;
|
||||||
|
|
||||||
#define PRETTYOPTIONCALLBACK(name, option) \
|
|
||||||
static void name(GtkWidget *w, gpointer data) \
|
|
||||||
{ \
|
|
||||||
option = GTK_TOGGLE_BUTTON(w)->active; \
|
|
||||||
}
|
|
||||||
|
|
||||||
PRETTYOPTIONCALLBACK(print_profiles_toggle, print_options.print_profiles)
|
|
||||||
|
|
||||||
|
|
||||||
static void set_font(PangoLayout *layout, PangoFontDescription *font,
|
static void set_font(PangoLayout *layout, PangoFontDescription *font,
|
||||||
double size, int align)
|
double size, int align)
|
||||||
|
@ -139,29 +131,42 @@ static void show_dive_text(struct dive *dive, cairo_t *cr, double w,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show_table_header(cairo_t *cr, double w, double h,
|
static void show_table_header(cairo_t *cr, double w, double h,
|
||||||
PangoFontDescription *font)
|
PangoFontDescription *font)
|
||||||
{
|
{
|
||||||
int len, width, height, maxwidth, maxheight;
|
int maxwidth, maxheight, colwidth, i, curwidth;
|
||||||
PangoLayout *layout;
|
PangoLayout *layout;
|
||||||
char buffer[160];
|
char headers[7][80]= { "Dive#", "Date", "Depth", "Time", "Master",
|
||||||
|
"Buddy", "Location" };
|
||||||
|
|
||||||
maxwidth = w * PANGO_SCALE;
|
maxwidth = w * PANGO_SCALE;
|
||||||
maxheight = h * PANGO_SCALE * 0.9;
|
maxheight = h * PANGO_SCALE * 0.9;
|
||||||
|
colwidth = maxwidth / 7;
|
||||||
|
|
||||||
layout = pango_cairo_create_layout(cr);
|
layout = pango_cairo_create_layout(cr);
|
||||||
pango_layout_set_width(layout, maxwidth);
|
|
||||||
|
cairo_move_to(cr, 0, 0);
|
||||||
pango_layout_set_height(layout, maxheight);
|
pango_layout_set_height(layout, maxheight);
|
||||||
|
|
||||||
len = snprintf(buffer, sizeof(buffer),
|
|
||||||
"Dive# - Date - Depth - Time - Master"
|
|
||||||
" Buddy -- Location");
|
|
||||||
|
|
||||||
set_font(layout, font, FONT_LARGE, PANGO_ALIGN_LEFT);
|
set_font(layout, font, FONT_LARGE, PANGO_ALIGN_LEFT);
|
||||||
pango_layout_set_text(layout, buffer, len);
|
|
||||||
pango_layout_get_size(layout, &width, &height);
|
|
||||||
|
|
||||||
//cairo_move_to(cr, 0, 0);
|
|
||||||
pango_cairo_show_layout(cr, layout);
|
curwidth = 0;
|
||||||
|
for (i = 0; i < 7; i++) {
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
if (i == 0 || i == 2 || i == 3 ){
|
||||||
|
// Column 0, 2 and 3 (Dive #, Depth and Time) get 1/2 width
|
||||||
|
pango_layout_set_width(layout, colwidth/ (double) 2);
|
||||||
|
curwidth = curwidth + (colwidth / 2);
|
||||||
|
} else {
|
||||||
|
pango_layout_set_width(layout, colwidth);
|
||||||
|
curwidth = curwidth + colwidth;
|
||||||
|
}
|
||||||
|
pango_layout_set_text(layout, headers[i], -1);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
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,
|
static void show_dive_table(struct dive *dive, cairo_t *cr, double w,
|
||||||
|
@ -169,7 +174,7 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w,
|
||||||
{
|
{
|
||||||
double depth;
|
double depth;
|
||||||
const char *unit;
|
const char *unit;
|
||||||
int len, decimals, width, height, maxwidth, maxheight;
|
int len, decimals, maxwidth, maxheight, colwidth, curwidth;
|
||||||
PangoLayout *layout;
|
PangoLayout *layout;
|
||||||
struct tm *tm;
|
struct tm *tm;
|
||||||
char buffer[160], divenr[20];
|
char buffer[160], divenr[20];
|
||||||
|
@ -177,59 +182,86 @@ static void show_dive_table(struct dive *dive, cairo_t *cr, double w,
|
||||||
maxwidth = w * PANGO_SCALE;
|
maxwidth = w * PANGO_SCALE;
|
||||||
maxheight = h * PANGO_SCALE * 0.9;
|
maxheight = h * PANGO_SCALE * 0.9;
|
||||||
|
|
||||||
layout = pango_cairo_create_layout(cr);
|
colwidth = maxwidth / 7;
|
||||||
pango_layout_set_width(layout, maxwidth);
|
|
||||||
pango_layout_set_height(layout, maxheight);
|
|
||||||
|
|
||||||
|
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;
|
||||||
|
|
||||||
|
// Col 1: Dive #
|
||||||
*divenr = 0;
|
*divenr = 0;
|
||||||
if (dive->number)
|
if (dive->number)
|
||||||
snprintf(divenr, sizeof(divenr), "#%d -", dive->number);
|
snprintf(divenr, sizeof(divenr), "#%d", dive->number);
|
||||||
|
pango_layout_set_width(layout, colwidth/ (double) 2);
|
||||||
depth = get_depth_units(dive->maxdepth.mm, &decimals, &unit);
|
pango_layout_set_text(layout, divenr, -1);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + (colwidth / 2);
|
||||||
|
|
||||||
|
// Col 2: Date #
|
||||||
|
pango_layout_set_width(layout, colwidth);
|
||||||
tm = gmtime(&dive->when);
|
tm = gmtime(&dive->when);
|
||||||
len = snprintf(buffer, sizeof(buffer),
|
len = snprintf(buffer, sizeof(buffer),
|
||||||
"%s %s, %s %d, %d %dh%02d - %.*f %s - %d min - %s %s -- %s",
|
"%s, %s %d, %d %dh%02d",
|
||||||
divenr,
|
|
||||||
weekday(tm->tm_wday),
|
weekday(tm->tm_wday),
|
||||||
monthname(tm->tm_mon),
|
monthname(tm->tm_mon),
|
||||||
tm->tm_mday, tm->tm_year + 1900,
|
tm->tm_mday, tm->tm_year + 1900,
|
||||||
tm->tm_hour, tm->tm_min,
|
tm->tm_hour, tm->tm_min
|
||||||
decimals,
|
|
||||||
depth,
|
|
||||||
unit,
|
|
||||||
(dive->duration.seconds+59) / 60,
|
|
||||||
dive->divemaster ? : " ",
|
|
||||||
dive->buddy ? : " ",
|
|
||||||
dive->location ? : " "
|
|
||||||
);
|
);
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
set_font(layout, font, FONT_NORMAL, PANGO_ALIGN_LEFT);
|
|
||||||
pango_layout_set_text(layout, buffer, len);
|
pango_layout_set_text(layout, buffer, len);
|
||||||
pango_layout_get_size(layout, &width, &height);
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + colwidth;
|
||||||
|
|
||||||
cairo_move_to(cr, 0, 0);
|
// Col 3: Depth
|
||||||
|
depth = get_depth_units(dive->maxdepth.mm, &decimals, &unit);
|
||||||
|
len = snprintf(buffer, sizeof(buffer),
|
||||||
|
"%.*f %s", decimals, depth, unit);
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
pango_layout_set_width(layout, colwidth/ (double) 2);
|
||||||
|
pango_layout_set_text(layout, buffer, len);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + (colwidth / 2);
|
||||||
|
|
||||||
|
// Col 4: Time
|
||||||
|
len = snprintf(buffer, sizeof(buffer),
|
||||||
|
"%d min",(dive->duration.seconds+59) / 60);
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
pango_layout_set_width(layout, colwidth/ (double) 2);
|
||||||
|
pango_layout_set_text(layout, buffer, len);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + (colwidth / 2);
|
||||||
|
|
||||||
|
// Col 5: Master
|
||||||
|
pango_layout_set_width(layout, colwidth);
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
pango_layout_set_text(layout, dive->divemaster ? : " ", -1);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + colwidth;
|
||||||
|
|
||||||
|
// Col 6: Buddy
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
pango_layout_set_text(layout, dive->buddy ? : " ", -1);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
curwidth = curwidth + colwidth;
|
||||||
|
|
||||||
|
// Col 7: Location
|
||||||
|
cairo_move_to(cr, curwidth / PANGO_SCALE, 0);
|
||||||
|
pango_layout_set_width(layout, maxwidth - curwidth);
|
||||||
|
pango_layout_set_text(layout, dive->location ? : " ", -1);
|
||||||
|
pango_layout_set_justify(layout, 1);
|
||||||
pango_cairo_show_layout(cr, layout);
|
pango_cairo_show_layout(cr, layout);
|
||||||
|
|
||||||
///*
|
|
||||||
//* Show the dive notes
|
|
||||||
//*/
|
|
||||||
if (dive->notes) {
|
|
||||||
/* Move down by the size of the location (x2) */
|
|
||||||
height = height * 1.3;
|
|
||||||
cairo_translate(cr, 20, height / (double) PANGO_SCALE);
|
|
||||||
maxheight -= height;
|
|
||||||
|
|
||||||
/* Use the full width and remaining height for notes */
|
|
||||||
pango_layout_set_height(layout, maxheight);
|
|
||||||
pango_layout_set_width(layout, maxwidth);
|
|
||||||
pango_layout_set_wrap(layout, PANGO_WRAP_WORD_CHAR);
|
|
||||||
pango_layout_set_justify(layout, 1);
|
|
||||||
pango_layout_set_text(layout, dive->notes, -1);
|
|
||||||
|
|
||||||
cairo_move_to(cr, 0, 0);
|
|
||||||
pango_cairo_show_layout(cr, layout);
|
|
||||||
}
|
|
||||||
g_object_unref(layout);
|
g_object_unref(layout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -275,33 +307,10 @@ static void print(int divenr, cairo_t *cr, double x, double y, double w,
|
||||||
cairo_restore(cr);
|
cairo_restore(cr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_pretty_table(int divenr, cairo_t *cr, double x, double y,
|
|
||||||
double w, double h, PangoFontDescription *font)
|
|
||||||
{
|
|
||||||
struct dive *dive;
|
|
||||||
|
|
||||||
dive = get_dive(divenr);
|
|
||||||
if (!dive)
|
|
||||||
return;
|
|
||||||
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_dive_text(dive, cr, w*2, h*2, font);
|
|
||||||
|
|
||||||
cairo_restore(cr);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void print_table_header(cairo_t *cr, double x, double y,
|
static void print_table_header(cairo_t *cr, double x, double y,
|
||||||
double w, double h, PangoFontDescription *font)
|
double w, double h, PangoFontDescription *font)
|
||||||
{
|
{
|
||||||
cairo_save(cr);
|
cairo_save(cr);
|
||||||
cairo_translate(cr, x, y);
|
cairo_translate(cr, x, y);
|
||||||
|
|
||||||
/* Plus 5% on all sides */
|
/* Plus 5% on all sides */
|
||||||
|
@ -366,31 +375,6 @@ static void draw_page(GtkPrintOperation *operation,
|
||||||
pango_font_description_free(font);
|
pango_font_description_free(font);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void draw_pretty_table(GtkPrintOperation *operation,
|
|
||||||
GtkPrintContext *context,
|
|
||||||
gint page_nr,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
|
||||||
int nr;
|
|
||||||
cairo_t *cr;
|
|
||||||
double w, h;
|
|
||||||
PangoFontDescription *font;
|
|
||||||
|
|
||||||
cr = gtk_print_context_get_cairo_context(context);
|
|
||||||
font = pango_font_description_from_string("Sans");
|
|
||||||
|
|
||||||
w = gtk_print_context_get_width(context);
|
|
||||||
h = gtk_print_context_get_height(context)/15;
|
|
||||||
|
|
||||||
nr = page_nr*15;
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < 15; i++) {
|
|
||||||
print_pretty_table(nr+i, cr, 0, 0+h*i, w, h, font);
|
|
||||||
}
|
|
||||||
|
|
||||||
pango_font_description_free(font);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void draw_table(GtkPrintOperation *operation,
|
static void draw_table(GtkPrintOperation *operation,
|
||||||
GtkPrintContext *context,
|
GtkPrintContext *context,
|
||||||
gint page_nr,
|
gint page_nr,
|
||||||
|
@ -409,7 +393,7 @@ static void draw_table(GtkPrintOperation *operation,
|
||||||
h = gtk_print_context_get_height(context)/(n_dive_per_page+1);
|
h = gtk_print_context_get_height(context)/(n_dive_per_page+1);
|
||||||
|
|
||||||
nr = page_nr*n_dive_per_page;
|
nr = page_nr*n_dive_per_page;
|
||||||
print_table_header(cr, 0, 0+h, w, h, font);
|
print_table_header(cr, 0, 0+h, w, h, font);
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < n_dive_per_page; i++) {
|
for (i = 0; i < n_dive_per_page; i++) {
|
||||||
print_table(nr+i, cr, 0, h*1.5+h*i, w, h, font);
|
print_table(nr+i, cr, 0, h*1.5+h*i, w, h, font);
|
||||||
|
@ -422,11 +406,7 @@ static void begin_print(GtkPrintOperation *operation, gpointer user_data)
|
||||||
{
|
{
|
||||||
int dives_per_page = 1;
|
int dives_per_page = 1;
|
||||||
if (print_options.type == PRETTY) {
|
if (print_options.type == PRETTY) {
|
||||||
if (print_options.print_profiles){
|
dives_per_page = 6;
|
||||||
dives_per_page = 6;
|
|
||||||
} else {
|
|
||||||
dives_per_page = 15;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
dives_per_page = 25;
|
dives_per_page = 25;
|
||||||
}
|
}
|
||||||
|
@ -435,22 +415,12 @@ static void begin_print(GtkPrintOperation *operation, gpointer user_data)
|
||||||
gtk_print_operation_set_n_pages(operation, pages);
|
gtk_print_operation_set_n_pages(operation, pages);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void update_print_window(GtkWidget *w) {
|
|
||||||
if (print_options.type == TABLE) {
|
|
||||||
// type == table - disable the profile option
|
|
||||||
gtk_widget_set_sensitive(w, FALSE);
|
|
||||||
} else {
|
|
||||||
// type == pretty - enable the profile option
|
|
||||||
gtk_widget_set_sensitive(w, TRUE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#define OPTIONCALLBACK(name, type, value) \
|
#define OPTIONCALLBACK(name, type, value) \
|
||||||
static void name(GtkWidget *w, gpointer data) \
|
static void name(GtkWidget *w, gpointer data) \
|
||||||
{\
|
{\
|
||||||
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w))) \
|
if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w))) \
|
||||||
print_options.type = value; \
|
print_options.type = value; \
|
||||||
update_print_window(data); \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
OPTIONCALLBACK(set_pretty, type, PRETTY)
|
OPTIONCALLBACK(set_pretty, type, PRETTY)
|
||||||
|
@ -458,7 +428,7 @@ OPTIONCALLBACK(set_table, type, TABLE)
|
||||||
|
|
||||||
static GtkWidget *print_dialog(GtkPrintOperation *operation, gpointer user_data)
|
static GtkWidget *print_dialog(GtkPrintOperation *operation, gpointer user_data)
|
||||||
{
|
{
|
||||||
GtkWidget *vbox, *button, *radio1, *radio2, *frame, *box;
|
GtkWidget *vbox, *radio1, *radio2, *frame, *box;
|
||||||
gtk_print_operation_set_custom_tab_label(operation, "Dive details");
|
gtk_print_operation_set_custom_tab_label(operation, "Dive details");
|
||||||
|
|
||||||
vbox = gtk_vbox_new(TRUE, 5);
|
vbox = gtk_vbox_new(TRUE, 5);
|
||||||
|
@ -479,20 +449,8 @@ static GtkWidget *print_dialog(GtkPrintOperation *operation, gpointer user_data)
|
||||||
gtk_box_pack_start (GTK_BOX (box), radio1, TRUE, TRUE, 0);
|
gtk_box_pack_start (GTK_BOX (box), radio1, TRUE, TRUE, 0);
|
||||||
gtk_box_pack_start (GTK_BOX (box), radio2, TRUE, TRUE, 0);
|
gtk_box_pack_start (GTK_BOX (box), radio2, TRUE, TRUE, 0);
|
||||||
|
|
||||||
|
g_signal_connect(radio1, "toggled", G_CALLBACK(set_pretty), NULL);
|
||||||
frame = gtk_frame_new("Print options");
|
g_signal_connect(radio2, "toggled", G_CALLBACK(set_table), NULL);
|
||||||
gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 1);
|
|
||||||
|
|
||||||
box = gtk_hbox_new(FALSE, 3);
|
|
||||||
gtk_container_add(GTK_CONTAINER(frame), box);
|
|
||||||
|
|
||||||
button = gtk_check_button_new_with_label("Show profiles");
|
|
||||||
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(button), print_options.print_profiles);
|
|
||||||
gtk_box_pack_start(GTK_BOX(box), button, FALSE, FALSE, 2);
|
|
||||||
g_signal_connect(G_OBJECT(button), "toggled", G_CALLBACK(print_profiles_toggle), NULL);
|
|
||||||
|
|
||||||
g_signal_connect(radio1, "toggled", G_CALLBACK(set_pretty), button);
|
|
||||||
g_signal_connect(radio2, "toggled", G_CALLBACK(set_table), button);
|
|
||||||
|
|
||||||
gtk_widget_show_all(vbox);
|
gtk_widget_show_all(vbox);
|
||||||
return vbox;
|
return vbox;
|
||||||
|
@ -501,13 +459,8 @@ static GtkWidget *print_dialog(GtkPrintOperation *operation, gpointer user_data)
|
||||||
static void print_dialog_apply(GtkPrintOperation *operation, GtkWidget *widget, gpointer user_data)
|
static void print_dialog_apply(GtkPrintOperation *operation, GtkWidget *widget, gpointer user_data)
|
||||||
{
|
{
|
||||||
if (print_options.type == PRETTY) {
|
if (print_options.type == PRETTY) {
|
||||||
if (print_options.print_profiles){
|
g_signal_connect(operation, "draw_page",
|
||||||
g_signal_connect(operation, "draw_page",
|
G_CALLBACK(draw_page), NULL);
|
||||||
G_CALLBACK(draw_page), NULL);
|
|
||||||
} else {
|
|
||||||
g_signal_connect(operation, "draw_page",
|
|
||||||
G_CALLBACK(draw_pretty_table), NULL);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
g_signal_connect(operation, "draw_page",
|
g_signal_connect(operation, "draw_page",
|
||||||
G_CALLBACK(draw_table), NULL);
|
G_CALLBACK(draw_table), NULL);
|
||||||
|
|
Loading…
Add table
Reference in a new issue