Merge pull request #1985 from Airblader/bug-1984

Remove support for 32-bit visuals and RGBA colors.
This commit is contained in:
Michael Stapelberg 2015-10-11 01:54:13 -07:00
commit 188a59b5e9
5 changed files with 8 additions and 45 deletions

View File

@ -15,7 +15,6 @@ typedef struct color_t {
double red; double red;
double green; double green;
double blue; double blue;
double alpha;
/* For compatibility, we also store the colorpixel for now. */ /* For compatibility, we also store the colorpixel for now. */
uint32_t colorpixel; uint32_t colorpixel;

View File

@ -51,25 +51,15 @@ void cairo_surface_free(surface_t *surface) {
* *
*/ */
color_t cairo_hex_to_color(const char *color) { color_t cairo_hex_to_color(const char *color) {
char alpha[2]; char groups[3][3] = {
if (strlen(color) == strlen("#rrggbbaa")) {
alpha[0] = color[7];
alpha[1] = color[8];
} else {
alpha[0] = alpha[1] = 'F';
}
char groups[4][3] = {
{color[1], color[2], '\0'}, {color[1], color[2], '\0'},
{color[3], color[4], '\0'}, {color[3], color[4], '\0'},
{color[5], color[6], '\0'}, {color[5], color[6], '\0'}};
{alpha[0], alpha[1], '\0'}};
return (color_t){ return (color_t){
.red = strtol(groups[0], NULL, 16) / 255.0, .red = strtol(groups[0], NULL, 16) / 255.0,
.green = strtol(groups[1], NULL, 16) / 255.0, .green = strtol(groups[1], NULL, 16) / 255.0,
.blue = strtol(groups[2], NULL, 16) / 255.0, .blue = strtol(groups[2], NULL, 16) / 255.0,
.alpha = strtol(groups[3], NULL, 16) / 255.0,
.colorpixel = get_colorpixel(color)}; .colorpixel = get_colorpixel(color)};
} }
@ -78,7 +68,7 @@ color_t cairo_hex_to_color(const char *color) {
* *
*/ */
void cairo_set_source_color(surface_t *surface, color_t 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);
} }
/** /**

View File

@ -1122,21 +1122,7 @@ char *init_xcb_early() {
depth = root_screen->root_depth; depth = root_screen->root_depth;
colormap = root_screen->default_colormap; colormap = root_screen->default_colormap;
visual_type = xcb_aux_find_visual_by_attrs(root_screen, -1, 32); visual_type = get_visualtype(root_screen);
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);
}
/* We draw the statusline to a seperate pixmap, because it looks the same on all bars and /* 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 */ * this way, we can choose to crop it */

View File

@ -29,7 +29,6 @@ static xcb_visualtype_t *root_visual_type;
static double pango_font_red; static double pango_font_red;
static double pango_font_green; static double pango_font_green;
static double pango_font_blue; static double pango_font_blue;
static double pango_font_alpha;
/* Necessary to track whether the dpi changes and trigger a LOG() message, /* Necessary to track whether the dpi changes and trigger a LOG() message,
* which is more easily visible to users. */ * which is more easily visible to users. */
@ -124,8 +123,8 @@ static void draw_text_pango(const char *text, size_t text_len,
pango_layout_set_text(layout, text, text_len); pango_layout_set_text(layout, text, text_len);
/* Do the drawing */ /* 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_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_cairo_update_layout(cr, layout);
pango_layout_get_pixel_size(layout, NULL, &height); pango_layout_get_pixel_size(layout, NULL, &height);
/* Center the piece of text vertically if its height is smaller than the /* Center the piece of text vertically if its height is smaller than the
@ -334,7 +333,6 @@ void set_font_colors(xcb_gcontext_t gc, uint32_t foreground, uint32_t background
pango_font_red = ((foreground >> 16) & 0xff) / 255.0; pango_font_red = ((foreground >> 16) & 0xff) / 255.0;
pango_font_green = ((foreground >> 8) & 0xff) / 255.0; pango_font_green = ((foreground >> 8) & 0xff) / 255.0;
pango_font_blue = (foreground & 0xff) / 255.0; pango_font_blue = (foreground & 0xff) / 255.0;
pango_font_alpha = ((foreground >> 24) & 0xff) / 255.0;
break; break;
#endif #endif
default: default:

View File

@ -26,23 +26,13 @@
* *
*/ */
uint32_t get_colorpixel(const char *hex) { uint32_t get_colorpixel(const char *hex) {
char alpha[2]; char strgroups[3][3] = {
if (strlen(hex) == strlen("#rrggbbaa")) {
alpha[0] = hex[7];
alpha[1] = hex[8];
} else {
alpha[0] = alpha[1] = 'F';
}
char strgroups[4][3] = {
{hex[1], hex[2], '\0'}, {hex[1], hex[2], '\0'},
{hex[3], hex[4], '\0'}, {hex[3], hex[4], '\0'},
{hex[5], hex[6], '\0'}, {hex[5], hex[6], '\0'}};
{alpha[0], alpha[1], '\0'}};
uint8_t r = strtol(strgroups[0], NULL, 16); uint8_t r = strtol(strgroups[0], NULL, 16);
uint8_t g = strtol(strgroups[1], NULL, 16); uint8_t g = strtol(strgroups[1], NULL, 16);
uint8_t b = strtol(strgroups[2], 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);
} }