X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=engines%2Fopenbox%2Fopenbox.c;h=36e1641169e1836fd0a2311b7840d336a30a8003;hb=9dc2a9171cb4d7c9ff62342808686b1c96735194;hp=fdab22a31a5ecf0d2cc8a8df8a6db787f7f834d6;hpb=f8a47de5ec444c452093371e3db16857eb39a490;p=chaz%2Fopenbox diff --git a/engines/openbox/openbox.c b/engines/openbox/openbox.c index fdab22a3..36e16411 100644 --- a/engines/openbox/openbox.c +++ b/engines/openbox/openbox.c @@ -6,12 +6,14 @@ #include "../../kernel/frame.h" #include "../../render/render.h" #include "../../render/color.h" +#include "../../render/font.h" +#include "../../render/mask.h" #include #include -#define TITLE_HEIGHT (s_font_height + s_bevel * 2) -#define LABEL_HEIGHT (s_font_height) +#define TITLE_HEIGHT (s_winfont_height + s_bevel * 2) +#define LABEL_HEIGHT (s_winfont_height) #define HANDLE_Y(f) (f->innersize.top + f->frame.client->area.height + \ f->cbwidth) #define BUTTON_SIZE (LABEL_HEIGHT - 2) @@ -22,7 +24,6 @@ #define FRAME_EVENTMASK (EnterWindowMask | LeaveWindowMask) /* style settings - geometry */ -int s_font_height; int s_bevel; int s_handle_height; int s_bwidth; @@ -31,6 +32,20 @@ int s_cbwidth; color_rgb *s_b_color; color_rgb *s_cb_focused_color; color_rgb *s_cb_unfocused_color; +color_rgb *s_title_focused_color; +color_rgb *s_title_unfocused_color; +color_rgb *s_titlebut_focused_color; +color_rgb *s_titlebut_unfocused_color; +/* style settings - fonts */ +int s_winfont_height; +int s_winfont_shadow; +int s_winfont_shadow_offset; +ObFont *s_winfont; +/* style settings - masks */ +pixmap_mask *s_max_mask; +pixmap_mask *s_icon_mask; +pixmap_mask *s_desk_mask; +pixmap_mask *s_close_mask; /* global appearances */ Appearance *a_focused_unpressed_max; @@ -127,12 +142,16 @@ gboolean startup() g_quark_from_string("icon"); g_quark_from_string("close"); - s_b_color = s_cb_unfocused_color = s_cb_focused_color = NULL; + s_b_color = s_cb_unfocused_color = s_cb_focused_color = + s_title_unfocused_color = s_title_focused_color = + s_titlebut_unfocused_color = s_titlebut_focused_color = NULL; + s_winfont = NULL; + s_max_mask = s_icon_mask = s_desk_mask = s_close_mask = NULL; - a_focused_unpressed_max = appearance_new(Surface_Planar, 0);//1); - a_focused_pressed_max = appearance_new(Surface_Planar, 0);//1); - a_unfocused_unpressed_max = appearance_new(Surface_Planar, 0);//1); - a_unfocused_pressed_max = appearance_new(Surface_Planar, 0);//1); + a_focused_unpressed_max = appearance_new(Surface_Planar, 1); + a_focused_pressed_max = appearance_new(Surface_Planar, 1); + a_unfocused_unpressed_max = appearance_new(Surface_Planar, 1); + a_unfocused_pressed_max = appearance_new(Surface_Planar, 1); a_focused_unpressed_close = NULL; a_focused_pressed_close = NULL; a_unfocused_unpressed_close = NULL; @@ -149,8 +168,8 @@ gboolean startup() a_unfocused_grip = appearance_new(Surface_Planar, 0); a_focused_title = appearance_new(Surface_Planar, 0); a_unfocused_title = appearance_new(Surface_Planar, 0); - a_focused_label = appearance_new(Surface_Planar, 0);//1); - a_unfocused_label = appearance_new(Surface_Planar, 0);//1); + a_focused_label = appearance_new(Surface_Planar, 1); + a_unfocused_label = appearance_new(Surface_Planar, 1); a_icon = appearance_new(Surface_Planar, 0);//1); a_focused_handle = appearance_new(Surface_Planar, 0); a_unfocused_handle = appearance_new(Surface_Planar, 0); @@ -163,6 +182,19 @@ void shutdown() if (s_b_color != NULL) color_free(s_b_color); if (s_cb_unfocused_color != NULL) color_free(s_cb_unfocused_color); if (s_cb_focused_color != NULL) color_free(s_cb_focused_color); + if (s_title_unfocused_color != NULL) color_free(s_title_unfocused_color); + if (s_title_focused_color != NULL) color_free(s_title_focused_color); + if (s_titlebut_unfocused_color != NULL) + color_free(s_titlebut_unfocused_color); + if (s_titlebut_focused_color != NULL) + color_free(s_titlebut_focused_color); + + if (s_max_mask != NULL) pixmap_mask_free(s_max_mask); + if (s_desk_mask != NULL) pixmap_mask_free(s_desk_mask); + if (s_icon_mask != NULL) pixmap_mask_free(s_icon_mask); + if (s_close_mask != NULL) pixmap_mask_free(s_close_mask); + + if (s_winfont != NULL) font_close(s_winfont); appearance_free(a_focused_unpressed_max); appearance_free(a_focused_pressed_max); @@ -562,28 +594,30 @@ void frame_release_client(ObFrame *self, Client *client) static void layout_title(ObFrame *self) { const char *lc; - int x; + int x, sep; gboolean n, d, i, l, m ,c; + n = d = i = l = m = c = FALSE; + sep = s_bevel + 1; /* figure out whats being shown, and the width of the label */ - self->label_width = self->width - s_bevel * 2; + self->label_width = self->width - sep * 2; for (lc = themerc_titlebar_layout; *lc != '\0'; ++lc) { switch (*lc) { case 'N': if (!(self->frame.client->decorations & Decor_Icon)) break; n = TRUE; - self->label_width -= BUTTON_SIZE + s_bevel; + self->label_width -= BUTTON_SIZE + sep; break; case 'D': if (!(self->frame.client->decorations & Decor_AllDesktops)) break; d = TRUE; - self->label_width -= BUTTON_SIZE + s_bevel; + self->label_width -= BUTTON_SIZE + sep; break; case 'I': if (!(self->frame.client->decorations & Decor_Iconify)) break; i = TRUE; - self->label_width -= BUTTON_SIZE + s_bevel; + self->label_width -= BUTTON_SIZE + sep; break; case 'L': l = TRUE; @@ -591,18 +625,19 @@ static void layout_title(ObFrame *self) case 'M': if (!(self->frame.client->decorations & Decor_Maximize)) break; m = TRUE; - self->label_width -= BUTTON_SIZE + s_bevel; + self->label_width -= BUTTON_SIZE + sep; break; case 'C': if (!(self->frame.client->decorations & Decor_Close)) break; c = TRUE; - self->label_width -= BUTTON_SIZE + s_bevel; + self->label_width -= BUTTON_SIZE + sep; break; } } if (self->label_width < 1) self->label_width = 1; - XResizeWindow(ob_display, self->label, self->label_width, s_font_height); + XResizeWindow(ob_display, self->label, self->label_width, + s_winfont_height); if (!n) { self->frame.client->decorations &= ~Decor_Icon; @@ -634,50 +669,50 @@ static void layout_title(ObFrame *self) self->close_x = -1; } - x = s_bevel; + x = sep; for (lc = themerc_titlebar_layout; *lc != '\0'; ++lc) { switch (*lc) { case 'N': if (!n) break; self->icon_x = x; XMapWindow(ob_display, self->icon); - XMoveWindow(ob_display, self->icon, x, s_bevel + 1); - x += BUTTON_SIZE + s_bevel; + XMoveWindow(ob_display, self->icon, x, sep + 1); + x += BUTTON_SIZE + sep; break; case 'D': if (!d) break; self->desk_x = x; XMapWindow(ob_display, self->desk); XMoveWindow(ob_display, self->desk, x, s_bevel + 1); - x += BUTTON_SIZE + s_bevel; + x += BUTTON_SIZE + sep; break; case 'I': if (!i) break; self->iconify_x = x; XMapWindow(ob_display, self->iconify); XMoveWindow(ob_display, self->iconify, x, s_bevel + 1); - x += BUTTON_SIZE + s_bevel; + x += BUTTON_SIZE + sep; break; case 'L': if (!l) break; self->label_x = x; XMapWindow(ob_display, self->label); XMoveWindow(ob_display, self->label, x, s_bevel); - x += self->label_width + s_bevel; + x += self->label_width + sep; break; case 'M': if (!m) break; self->max_x = x; XMapWindow(ob_display, self->max); XMoveWindow(ob_display, self->max, x, s_bevel + 1); - x += BUTTON_SIZE + s_bevel; + x += BUTTON_SIZE + sep; break; case 'C': if (!c) break; self->close_x = x; XMapWindow(ob_display, self->close); XMoveWindow(ob_display, self->close, x, s_bevel + 1); - x += BUTTON_SIZE + s_bevel; + x += BUTTON_SIZE + sep; break; } } @@ -724,13 +759,17 @@ static void render(ObFrame *self) static void render_label(ObFrame *self) { + Appearance *a; + if (self->label_x < 0) return; - /* XXX set the texture's text! */ - paint(self->label, (self->frame.client->focused ? - self->a_focused_label : - self->a_unfocused_label), - self->label_width, LABEL_HEIGHT); + a = (self->frame.client->focused ? + self->a_focused_label : self->a_focused_label); + + /* set the texture's text! */ + a->texture[0].data.text.string = self->frame.client->title; + + paint(self->label, a, self->label_width, LABEL_HEIGHT); } static void render_icon(ObFrame *self)