double red;
double green;
double blue;
- double alpha;
/* For compatibility, we also store the colorpixel for now. */
uint32_t colorpixel;
*
*/
color_t cairo_hex_to_color(const char *color) {
- char alpha[2];
- if (strlen(color) == strlen("#rrggbbaa")) {
- alpha[0] = color[7];
- alpha[1] = color[8];
- } else {
- alpha[0] = alpha[1] = 'F';
- }
-
- char groups[4][3] = {
+ char groups[3][3] = {
{color[1], color[2], '\0'},
{color[3], color[4], '\0'},
- {color[5], color[6], '\0'},
- {alpha[0], alpha[1], '\0'}};
+ {color[5], color[6], '\0'}};
return (color_t){
.red = strtol(groups[0], NULL, 16) / 255.0,
.green = strtol(groups[1], NULL, 16) / 255.0,
.blue = strtol(groups[2], NULL, 16) / 255.0,
- .alpha = strtol(groups[3], NULL, 16) / 255.0,
.colorpixel = get_colorpixel(color)};
}
*
*/
void cairo_set_source_color(surface_t *surface, color_t color) {
- cairo_set_source_rgba(surface->cr, color.red, color.green, color.blue, color.alpha);
+ cairo_set_source_rgb(surface->cr, color.red, color.green, color.blue);
}
/**
depth = root_screen->root_depth;
colormap = root_screen->default_colormap;
- visual_type = xcb_aux_find_visual_by_attrs(root_screen, -1, 32);
- if (visual_type) {
- depth = xcb_aux_get_depth_of_visual(root_screen, visual_type->visual_id);
- colormap = xcb_generate_id(xcb_connection);
- xcb_void_cookie_t cm_cookie = xcb_create_colormap_checked(xcb_connection,
- XCB_COLORMAP_ALLOC_NONE,
- colormap,
- xcb_root,
- visual_type->visual_id);
- if (xcb_request_failed(cm_cookie, "Could not allocate colormap")) {
- exit(EXIT_FAILURE);
- }
- } else {
- visual_type = get_visualtype(root_screen);
- }
+ visual_type = get_visualtype(root_screen);
/* We draw the statusline to a seperate pixmap, because it looks the same on all bars and
* this way, we can choose to crop it */
static double pango_font_red;
static double pango_font_green;
static double pango_font_blue;
-static double pango_font_alpha;
/* Necessary to track whether the dpi changes and trigger a LOG() message,
* which is more easily visible to users. */
pango_layout_set_text(layout, text, text_len);
/* Do the drawing */
- cairo_set_source_rgba(cr, pango_font_red, pango_font_green, pango_font_blue, pango_font_alpha);
cairo_set_operator(cr, CAIRO_OPERATOR_SOURCE);
+ cairo_set_source_rgb(cr, pango_font_red, pango_font_green, pango_font_blue);
pango_cairo_update_layout(cr, layout);
pango_layout_get_pixel_size(layout, NULL, &height);
/* Center the piece of text vertically if its height is smaller than the
pango_font_red = ((foreground >> 16) & 0xff) / 255.0;
pango_font_green = ((foreground >> 8) & 0xff) / 255.0;
pango_font_blue = (foreground & 0xff) / 255.0;
- pango_font_alpha = ((foreground >> 24) & 0xff) / 255.0;
break;
#endif
default:
*
*/
uint32_t get_colorpixel(const char *hex) {
- char alpha[2];
- if (strlen(hex) == strlen("#rrggbbaa")) {
- alpha[0] = hex[7];
- alpha[1] = hex[8];
- } else {
- alpha[0] = alpha[1] = 'F';
- }
-
- char strgroups[4][3] = {
+ char strgroups[3][3] = {
{hex[1], hex[2], '\0'},
{hex[3], hex[4], '\0'},
- {hex[5], hex[6], '\0'},
- {alpha[0], alpha[1], '\0'}};
+ {hex[5], hex[6], '\0'}};
uint8_t r = strtol(strgroups[0], NULL, 16);
uint8_t g = strtol(strgroups[1], NULL, 16);
uint8_t b = strtol(strgroups[2], NULL, 16);
- uint8_t a = strtol(strgroups[3], NULL, 16);
- return (a << 24) | (r << 16 | g << 8 | b);
+ return (0xFF << 24) | (r << 16 | g << 8 | b);
}