X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Foutput%2Fcairo.c;h=72cf51c3660eaaf006d2298c0d6636db355dc20c;hb=107d72f63db8639c509f8cd92ac29b4641e5fbbc;hp=8602e7794672de9b5cfab720feaf3a5623f02f1a;hpb=f6ef1f7d246330feda72eaeb331fdf94a3940dad;p=pspp diff --git a/src/output/cairo.c b/src/output/cairo.c index 8602e77946..72cf51c366 100644 --- a/src/output/cairo.c +++ b/src/output/cairo.c @@ -131,6 +131,9 @@ struct xr_driver int line_space; /* Space between lines. */ int line_width; /* Width of lines. */ + double bg_red, bg_green, bg_blue; /* Background color */ + double fg_red, fg_green, fg_blue; /* Foreground color */ + /* Internal state. */ struct render_params *params; int char_width, char_height; @@ -177,6 +180,35 @@ opt (struct output_driver *d, struct string_map *options, const char *key, return driver_option_get (d, options, key, default_value); } +/* Parse color information specified by KEY into {RED,GREEN,BLUE}. + Currently, the input string must be of the form "#RRRRGGGGBBBB" + Future implementations might allow things like "yellow" and + "sky-blue-ultra-brown" + */ +static void +parse_color (struct output_driver *d, struct string_map *options, + const char *key, const char *default_value, + double *dred, double *dgreen, double *dblue) +{ + int red, green, blue; + char *string = parse_string (opt (d, options, key, default_value)); + + if (3 != sscanf (string, "#%04x%04x%04x", &red, &green, &blue)) + { + /* If the parsed option string fails, then try the default value */ + if ( 3 != sscanf (default_value, "#%04x%04x%04x", &red, &green, &blue)) + { + /* ... and if that fails set everything to zero */ + red = green = blue = 0; + } + } + + /* Convert 16 bit ints to float */ + *dred = red / (double) 0xFFFF; + *dgreen = green / (double) 0xFFFF; + *dblue = blue / (double) 0xFFFF; +} + static PangoFontDescription * parse_font (struct output_driver *d, struct string_map *options, const char *key, const char *default_value, @@ -234,6 +266,9 @@ xr_allocate (const char *name, int device_type, struct string_map *o) xr->line_width = XR_POINT / 2; xr->page_number = 0; + parse_color (d, o, "background-color", "#FFFFFFFFFFFF", &xr->bg_red, &xr->bg_green, &xr->bg_blue); + parse_color (d, o, "foreground-color", "#000000000000", &xr->fg_red, &xr->fg_green, &xr->fg_blue); + parse_paper_size (opt (d, o, "paper-size", ""), &paper_width, &paper_length); xr->left_margin = parse_dimension (opt (d, o, "left-margin", ".5in")); xr->right_margin = parse_dimension (opt (d, o, "right-margin", ".5in")); @@ -323,6 +358,8 @@ xr_set_cairo (struct xr_driver *xr, cairo_t *cairo) } } + cairo_set_source_rgb (xr->cairo, xr->fg_red, xr->fg_green, xr->fg_blue); + return true; } @@ -523,9 +560,17 @@ void xr_driver_next_page (struct xr_driver *xr, cairo_t *cairo) { if (cairo != NULL) - cairo_translate (cairo, - xr_to_pt (xr->left_margin), - xr_to_pt (xr->top_margin)); + { + cairo_save (cairo); + cairo_set_source_rgb (cairo, xr->bg_red, xr->bg_green, xr->bg_blue); + cairo_rectangle (cairo, 0, 0, xr->width, xr->length); + cairo_fill (cairo); + cairo_restore (cairo); + + cairo_translate (cairo, + xr_to_pt (xr->left_margin), + xr_to_pt (xr->top_margin)); + } xr->page_number++; xr->cairo = cairo; @@ -919,7 +964,7 @@ xr_rendering_create_text (struct xr_driver *xr, const char *text, cairo_t *cr) struct table_item *table_item; struct xr_rendering *r; - table_item = table_item_create (table_from_string (0, text), NULL); + table_item = table_item_create (table_from_string (TAB_LEFT, text), NULL); r = xr_rendering_create (xr, &table_item->output_item, cr); table_item_unref (table_item); @@ -978,6 +1023,9 @@ xr_rendering_measure (struct xr_rendering *r, int *w, int *h) } } +static void xr_draw_chart (const struct chart_item *, cairo_t *, + double x, double y, double width, double height); + /* Draws onto CR at least the region of R that is enclosed in (X,Y)-(X+W,Y+H), and possibly some additional parts. */ void @@ -1006,7 +1054,7 @@ xr_rendering_draw (struct xr_rendering *r, cairo_t *cr, 0, 0, CHART_WIDTH, CHART_HEIGHT); } -void +static void xr_draw_chart (const struct chart_item *chart_item, cairo_t *cr, double x, double y, double width, double height) { @@ -1058,12 +1106,6 @@ xr_draw_png_chart (const struct chart_item *item, surface = cairo_image_surface_create (CAIRO_FORMAT_RGB24, width, length); cr = cairo_create (surface); - cairo_save (cr); - cairo_set_source_rgb (cr, 1.0, 1.0, 1.0); - cairo_rectangle (cr, 0, 0, width, length); - cairo_fill (cr); - cairo_restore (cr); - cairo_set_source_rgb (cr, 0.0, 0.0, 0.0); xr_draw_chart (item, cr, 0.0, 0.0, width, length);