X-Git-Url: https://git.cworth.org/git?p=acre;a=blobdiff_plain;f=acre.c;fp=acre.c;h=9a9851c568a684d3623e6b29b8d9a0b77c32301c;hp=4e00beeee9557e9111d8a21467e1827e93ebc6e7;hb=4bb896b4ca75a5dd908da41455aabd3d6d864dd3;hpb=f38364b3004fb77dd8ebd6c6a37c66873f37e2b2 diff --git a/acre.c b/acre.c index 4e00bee..9a9851c 100644 --- a/acre.c +++ b/acre.c @@ -846,6 +846,48 @@ _draw_data_line (acre_t *acre, acre_data_t *data) cairo_restore (cr); } +#define BARS_WIDTH 0.8 + +/* Draw the given dataset as bars if there is room for that. + * + * Or, if the bars would run into each other, use a line instead. + */ +static void +_draw_data_bars_or_line (acre_t *acre, acre_data_t *data) +{ + unsigned i; + cairo_t *cr = acre->cr; + double ignored, width; + + /* Check device-space width available for inter-bad padding. */ + width = 1.0 - BARS_WIDTH; + ignored = 0.0; + cairo_user_to_device_distance (cr, &width, &ignored); + + /* If padding is less than two pixels, draw with a line instead. */ + if (width < 2.0) { + _draw_data_line (acre, data); + + return; + } + + cairo_save (cr); + + cairo_new_path (cr); + + for (i = 0; i < data->num_points; i++) { + cairo_rectangle (cr, + data->points[i].x - BARS_WIDTH / 2.0, 0.0, + BARS_WIDTH, data->points[i].y); + } + + cairo_identity_matrix (cr); + cairo_set_line_width (cr, 1.0); + cairo_stroke (cr); + + cairo_restore (cr); +} + #define TIMELINE_BAR_HEIGHT 0.6 /* Draw the given dataset as a timeline. Each (X,Y) point (potentially @@ -942,6 +984,9 @@ _draw_data (acre_t *acre) case ACRE_STYLE_LINE: _draw_data_line (acre, data); break; + case ACRE_STYLE_BARS_OR_LINE: + _draw_data_bars_or_line (acre, data); + break; case ACRE_STYLE_TIMELINE: /* Position the timeline bars top-down */ _draw_data_timeline (acre, data, acre->num_data - 1 - i);