summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-08-31 17:04:23 +0000
committerDana Jansens <danakj@orodu.net>2003-08-31 17:04:23 +0000
commita991c07bc1a1f86fd47db0e5442a629f3c39b407 (patch)
tree8995b3f3d9e2a34ba50379216e70bd63b3a7cd86
parentcd75b454eba706f89e82041c3f62ab08998d0397 (diff)
draw menu separators
-rw-r--r--openbox/menuframe.c39
-rw-r--r--openbox/menuframe.h1
2 files changed, 30 insertions, 10 deletions
diff --git a/openbox/menuframe.c b/openbox/menuframe.c
index 2b64aaa8..7052296e 100644
--- a/openbox/menuframe.c
+++ b/openbox/menuframe.c
@@ -7,7 +7,7 @@
#include "render/theme.h"
#define PADDING 2
-#define SEPARATOR_HEIGHT 5
+#define SEPARATOR_HEIGHT 3
#define FRAME_EVENTMASK (ButtonPressMask |ButtonMotionMask | EnterWindowMask |\
LeaveWindowMask)
@@ -105,11 +105,16 @@ static ObMenuEntryFrame* menu_entry_frame_new(ObMenuEntry *entry,
self->a_disabled = RrAppearanceCopy(ob_rr_theme->a_menu_disabled);
self->a_selected = RrAppearanceCopy(ob_rr_theme->a_menu_hilite);
- self->a_icon = RrAppearanceCopy(ob_rr_theme->a_clear_tex);
- self->a_icon->texture[0].type = RR_TEXTURE_RGBA;
- self->a_mask = RrAppearanceCopy(ob_rr_theme->a_clear_tex);
- self->a_mask->texture[0].type = RR_TEXTURE_MASK;
- self->a_bullet = RrAppearanceCopy(ob_rr_theme->a_menu_bullet);
+ if (entry->type == OB_MENU_ENTRY_TYPE_SEPARATOR) {
+ self->a_separator = RrAppearanceCopy(ob_rr_theme->a_clear_tex);
+ self->a_separator->texture[0].type = RR_TEXTURE_LINE_ART;
+ } else {
+ self->a_icon = RrAppearanceCopy(ob_rr_theme->a_clear_tex);
+ self->a_icon->texture[0].type = RR_TEXTURE_RGBA;
+ self->a_mask = RrAppearanceCopy(ob_rr_theme->a_clear_tex);
+ self->a_mask->texture[0].type = RR_TEXTURE_MASK;
+ self->a_bullet = RrAppearanceCopy(ob_rr_theme->a_menu_bullet);
+ }
self->a_text_normal =
RrAppearanceCopy(ob_rr_theme->a_menu_text_item);
@@ -133,6 +138,7 @@ static void menu_entry_frame_free(ObMenuEntryFrame *self)
RrAppearanceFree(self->a_disabled);
RrAppearanceFree(self->a_selected);
+ RrAppearanceFree(self->a_separator);
RrAppearanceFree(self->a_icon);
RrAppearanceFree(self->a_mask);
RrAppearanceFree(self->a_text_normal);
@@ -197,7 +203,7 @@ static void menu_entry_frame_render(ObMenuEntryFrame *self)
th = self->frame->item_h;
break;
case OB_MENU_ENTRY_TYPE_SEPARATOR:
- th = SEPARATOR_HEIGHT;
+ th = SEPARATOR_HEIGHT + 2*PADDING;
break;
}
RECT_SET_SIZE(self->area, self->frame->inner_w, th);
@@ -237,7 +243,6 @@ static void menu_entry_frame_render(ObMenuEntryFrame *self)
text_a->surface.parenty = PADDING;
RrPaint(text_a, self->text, self->frame->text_w,
self->frame->item_h - 2*PADDING);
- XMapWindow(ob_display, self->text);
break;
case OB_MENU_ENTRY_TYPE_SUBMENU:
XMoveResizeWindow(ob_display, self->text,
@@ -249,10 +254,24 @@ static void menu_entry_frame_render(ObMenuEntryFrame *self)
text_a->surface.parenty = PADDING;
RrPaint(text_a, self->text, self->frame->text_w - self->frame->item_h,
self->frame->item_h - 2*PADDING);
- XMapWindow(ob_display, self->text);
break;
case OB_MENU_ENTRY_TYPE_SEPARATOR:
- XUnmapWindow(ob_display, self->text);
+ XMoveResizeWindow(ob_display, self->text,
+ self->frame->text_x, PADDING,
+ self->frame->text_w - 2*PADDING,
+ SEPARATOR_HEIGHT);
+ self->a_separator->surface.parent = item_a;
+ self->a_separator->surface.parentx = self->frame->text_x;
+ self->a_separator->surface.parenty = PADDING;
+ self->a_separator->texture[0].data.lineart.color =
+ text_a->texture[0].data.text.color;
+ self->a_separator->texture[0].data.lineart.x1 = 2*PADDING;
+ self->a_separator->texture[0].data.lineart.y1 = SEPARATOR_HEIGHT / 2;
+ self->a_separator->texture[0].data.lineart.x2 =
+ self->frame->text_w - 6*PADDING;
+ self->a_separator->texture[0].data.lineart.y2 = SEPARATOR_HEIGHT / 2;
+ RrPaint(self->a_separator, self->text,
+ self->frame->text_w - 2*PADDING, SEPARATOR_HEIGHT);
break;
}
diff --git a/openbox/menuframe.h b/openbox/menuframe.h
index 7d2c1f06..92cd8793 100644
--- a/openbox/menuframe.h
+++ b/openbox/menuframe.h
@@ -71,6 +71,7 @@ struct _ObMenuEntryFrame
RrAppearance *a_icon;
RrAppearance *a_mask;
RrAppearance *a_bullet;
+ RrAppearance *a_separator;
RrAppearance *a_text_normal;
RrAppearance *a_text_disabled;
RrAppearance *a_text_selected;