diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-08-28 02:10:23 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-08-28 02:10:23 +0000 |
| commit | c34ef4028e504b8ce862b9c2e47b284ab66717dd (patch) | |
| tree | 5abae73563e8b11972a33e7f76867610f85db308 /openbox/menu_render.c | |
| parent | cadab91e522c6426cc79df4f06e7c05232cb0a64 (diff) | |
half way through the changes to new menu code/design. hot shit. static menus work, on to plugins next.
Diffstat (limited to 'openbox/menu_render.c')
| -rw-r--r-- | openbox/menu_render.c | 158 |
1 files changed, 0 insertions, 158 deletions
diff --git a/openbox/menu_render.c b/openbox/menu_render.c deleted file mode 100644 index 1f03459c..00000000 --- a/openbox/menu_render.c +++ /dev/null @@ -1,158 +0,0 @@ -/* Functions for default rendering of menus. Might become pluginnable */ - -#include "debug.h" -#include "menu.h" -#include "openbox.h" -#include "render/theme.h" - -void menu_render(ObMenu *self) { - GList *it; - int items_h = 0; - int nitems = 0; /* each item, only one is used */ - int item_y; - - self->size.width = 1; - self->item_h = 1; - - if (self->a_title == NULL) { - XSetWindowBorderWidth(ob_display, self->frame, ob_rr_theme->bwidth); - XSetWindowBackground(ob_display, self->frame, - RrColorPixel(ob_rr_theme->b_color)); - XSetWindowBorderWidth(ob_display, self->title, ob_rr_theme->bwidth); - XSetWindowBorder(ob_display, self->frame, - RrColorPixel(ob_rr_theme->b_color)); - XSetWindowBorder(ob_display, self->title, - RrColorPixel(ob_rr_theme->b_color)); - - self->a_title = RrAppearanceCopy(ob_rr_theme->a_menu_title); - self->a_items = RrAppearanceCopy(ob_rr_theme->a_menu); - } - - /* set texture data and size them mofos out */ - if (self->label && !(self->parent && self->parent->shown)) { - self->a_title->texture[0].data.text.string = self->label; - RrMinsize(self->a_title, &self->title_min_w, &self->title_h); - self->title_min_w += ob_rr_theme->bevel * 2; - self->title_h += ob_rr_theme->bevel * 2; - self->size.width = MAX(self->size.width, self->title_min_w); - } else - self->title_h = -ob_rr_theme->bwidth; - - for (it = self->entries; it; it = it->next) { - ObMenuEntry *e = it->data; - int h; - - if (e->a_item == NULL) { - e->a_item = RrAppearanceCopy(ob_rr_theme->a_menu_item); - e->a_disabled = RrAppearanceCopy(ob_rr_theme->a_menu_disabled); - e->a_hilite = RrAppearanceCopy(ob_rr_theme->a_menu_hilite); - e->a_submenu = RrAppearanceCopy(ob_rr_theme->a_menu_bullet); - } - - e->a_item->texture[0].data.text.string = e->label; - RrMinsize(e->a_item, &e->min_w, &self->item_h); - self->size.width = MAX(self->size.width, e->min_w); - - e->a_disabled->texture[0].data.text.string = e->label; - RrMinsize(e->a_disabled, &e->min_w, &h); - self->item_h = MAX(self->item_h, h); - self->size.width = MAX(self->size.width, e->min_w); - - e->a_hilite->texture[0].data.text.string = e->label; - RrMinsize(e->a_hilite, &e->min_w, &h); - self->item_h = MAX(self->item_h, h); - self->size.width = MAX(self->size.width, e->min_w); - - e->min_w += ob_rr_theme->bevel * 2; - ++nitems; - } - self->bullet_w = self->item_h + ob_rr_theme->bevel; - self->size.width += 2 * self->bullet_w + 2 * ob_rr_theme->bevel; - self->item_h += ob_rr_theme->bevel * 2; - items_h = self->item_h * MAX(nitems, 1); - - self->size.height = MAX(self->title_h + items_h + ob_rr_theme->bwidth, 1); - XResizeWindow(ob_display, self->frame, self->size.width,self->size.height); - if (self->label && !(self->parent && self->parent->shown)) { - XMoveResizeWindow(ob_display, self->title, -ob_rr_theme->bwidth, - -ob_rr_theme->bwidth, - self->size.width, self->title_h); - XMapWindow(ob_display, self->title); - } else - XUnmapWindow(ob_display, self->title); - - XMoveResizeWindow(ob_display, self->items, 0, - self->title_h + ob_rr_theme->bwidth, self->size.width, - items_h); - - if (self->label && !(self->parent && self->parent->shown)) - RrPaint(self->a_title, self->title, self->size.width, self->title_h); - RrPaint(self->a_items, self->items, self->size.width, items_h); - - item_y = 0; - for (it = self->entries; it; it = it->next) { - ((ObMenuEntry*)it->data)->y = item_y; - menu_entry_render(it->data); - item_y += self->item_h; - } - - self->invalid = FALSE; -} - -void menu_entry_render(ObMenuEntry *self) -{ - ObMenu *menu = self->parent; - RrAppearance *a, *s = NULL; - - switch (self->render_type) { - case OB_MENU_ENTRY_RENDER_TYPE_SUBMENU: - a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item) - : self->a_disabled; - s = self->a_submenu; - break; - case OB_MENU_ENTRY_RENDER_TYPE_BOOLEAN: - /* TODO: boolean check */ - a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item) - : self->a_disabled; - break; - case OB_MENU_ENTRY_RENDER_TYPE_NONE: - a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item ) - : self->a_disabled; - break; - case OB_MENU_ENTRY_RENDER_TYPE_SEPARATOR: - a = self->a_item; - break; - - default: - g_assert_not_reached(); /* unhandled rendering type */ - break; - } - - XMoveResizeWindow(ob_display, self->item, 0, self->y, - menu->size.width, menu->item_h); - if (s) { - XMoveResizeWindow(ob_display, self->submenu_pic, - menu->size.width - - menu->bullet_w + (menu->bullet_w - 8) / 2, - self->y + (menu->item_h - 8) / 2, - 8, 8); - XMapWindow(ob_display, self->submenu_pic); - } else - XUnmapWindow(ob_display, self->submenu_pic); - - a->surface.parent = menu->a_items; - a->surface.parentx = 0; - a->surface.parenty = self->y; - - if (s) { - s->surface.parent = a; - s->surface.parentx = menu->size.width - - menu->bullet_w + (menu->bullet_w - 8) / 2, - s->surface.parenty = (menu->item_h - 8) / 2; - } - - RrPaint(a, self->item, menu->size.width, menu->item_h); - - if (s) - RrPaint(s, self->submenu_pic, 8, 8); -} |
