1 /* Functions for default rendering of menus. Might become pluginnable */
5 #include "render/theme.h"
7 void menu_render_full(Menu
*self
);
9 void menu_render(Menu
*self
) {
14 menu_render_full(self
);
20 void menu_render_full(Menu
*self
) {
23 int nitems
= 0; /* each item, only one is used */
29 /* set texture data and size them mofos out */
31 self
->a_title
->texture
[0].data
.text
.string
= self
->label
;
32 RrMinsize(self
->a_title
, &self
->title_min_w
, &self
->title_h
);
33 self
->title_min_w
+= ob_rr_theme
->bevel
* 2;
34 self
->title_h
+= ob_rr_theme
->bevel
* 2;
35 self
->size
.width
= MAX(self
->size
.width
, self
->title_min_w
);
38 for (it
= self
->entries
; it
; it
= it
->next
) {
39 MenuEntry
*e
= it
->data
;
42 e
->a_item
->texture
[0].data
.text
.string
= e
->label
;
43 RrMinsize(e
->a_item
, &e
->min_w
, &self
->item_h
);
44 self
->size
.width
= MAX(self
->size
.width
, e
->min_w
);
46 e
->a_disabled
->texture
[0].data
.text
.string
= e
->label
;
47 RrMinsize(e
->a_disabled
, &e
->min_w
, &h
);
48 self
->item_h
= MAX(self
->item_h
, h
);
49 self
->size
.width
= MAX(self
->size
.width
, e
->min_w
);
51 e
->a_hilite
->texture
[0].data
.text
.string
= e
->label
;
52 RrMinsize(e
->a_hilite
, &e
->min_w
, &h
);
53 self
->item_h
= MAX(self
->item_h
, h
);
54 self
->size
.width
= MAX(self
->size
.width
, e
->min_w
);
56 e
->min_w
+= ob_rr_theme
->bevel
* 2;
59 self
->bullet_w
= self
->item_h
+ ob_rr_theme
->bevel
;
60 self
->size
.width
+= 2 * self
->bullet_w
+ 2 * ob_rr_theme
->bevel
;
61 self
->item_h
+= ob_rr_theme
->bevel
* 2;
62 items_h
= self
->item_h
* MAX(nitems
, 1);
64 XResizeWindow(ob_display
, self
->frame
, self
->size
.width
,
65 MAX(self
->title_h
+ items_h
, 1));
67 XMoveResizeWindow(ob_display
, self
->title
, -ob_rr_theme
->bwidth
,
69 self
->size
.width
, self
->title_h
);
71 XMoveResizeWindow(ob_display
, self
->items
, 0,
72 self
->title_h
+ ob_rr_theme
->bwidth
, self
->size
.width
,
76 RrPaint(self
->a_title
, self
->title
, self
->size
.width
, self
->title_h
);
77 RrPaint(self
->a_items
, self
->items
, self
->size
.width
, items_h
);
80 for (it
= self
->entries
; it
; it
= it
->next
) {
81 ((MenuEntry
*)it
->data
)->y
= item_y
;
82 menu_entry_render(it
->data
);
83 item_y
+= self
->item_h
;
86 self
->size
.height
= item_y
;
87 self
->invalid
= FALSE
;
90 void menu_entry_render(MenuEntry
*self
)
92 Menu
*menu
= self
->parent
;
95 switch (self
->render_type
) {
96 case MenuEntryRenderType_Submenu
:
97 /* TODO: submenu mask */
98 case MenuEntryRenderType_Boolean
:
99 /* TODO: boolean check */
100 a
= self
->enabled
? (self
->hilite
? self
->a_hilite
: self
->a_item
)
103 case MenuEntryRenderType_None
:
104 a
= self
->enabled
? (self
->hilite
? self
->a_hilite
: self
->a_item
)
107 case MenuEntryRenderType_Separator
:
112 g_message("unhandled render_type");
113 a
= !self
->enabled
? self
->a_disabled
:
115 (self
->action
|| self
->render_type
== MenuEntryRenderType_Submenu
) ?
116 self
->a_hilite
: self
->a_item
);
120 XMoveResizeWindow(ob_display
, self
->item
, 0, self
->y
,
121 menu
->size
.width
, menu
->item_h
);
123 a
->surface
.parent
= menu
->a_items
;
124 a
->surface
.parentx
= 0;
125 a
->surface
.parenty
= self
->y
;
127 RrPaint(a
, self
->item
, menu
->size
.width
, menu
->item_h
);