X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenuframe.h;h=f6a7b30eb89adf147db6bac11d5246275adb4e0c;hb=501943b53d68821a752ceda3fbd9b64bbcae4a4c;hp=1d7cb542a168050dc5baeea85eeec96f9fbd0d55;hpb=19b480058e869a588ea20be5e29017ae2052e967;p=chaz%2Fopenbox diff --git a/openbox/menuframe.h b/openbox/menuframe.h index 1d7cb542..f6a7b30e 100644 --- a/openbox/menuframe.h +++ b/openbox/menuframe.h @@ -2,7 +2,7 @@ menuframe.h for the Openbox window manager Copyright (c) 2006 Mikael Magnusson - Copyright (c) 2003 Ben Jansens + Copyright (c) 2003-2007 Dana Jansens This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -38,7 +38,7 @@ extern GList *menu_frame_visible; struct _ObMenuFrame { /* stuff to be an ObWindow */ - Window_InternalType type; + ObWindow obwin; Window window; struct _ObMenu *menu; @@ -48,30 +48,41 @@ struct _ObMenuFrame struct _ObClient *client; ObMenuFrame *parent; + ObMenuEntryFrame *parent_entry; ObMenuFrame *child; GList *entries; ObMenuEntryFrame *selected; + /* if a submenu was selected, then this holds the entry for that submenu + until it is closed */ + ObMenuEntryFrame *open_submenu; - /* If a titlebar is displayed for the menu or not (for top-level menus) */ - gboolean show_title; + /* show entries from the menu starting at this index */ + guint show_from; + + /* If the submenus are being drawn to the right or the left */ + gboolean direction_right; /* On-screen area (including borders!) */ Rect area; Strut item_margin; gint inner_w; /* inside the borders */ - gint title_h; /* includes the bwidth below it */ gint item_h; /* height of all normal items */ gint text_x; /* offset at which the text appears in the items */ gint text_w; /* width of the text area in the items */ + gint text_h; /* height of the items */ gint monitor; /* monitor on which to show the menu in xinerama */ - Window title; - Window items; - - RrAppearance *a_title; + /* We make a copy of this for each menu, so that we don't have to re-render + the background of the entire menu each time we render an item inside it. + */ RrAppearance *a_items; + + gboolean got_press; /* don't allow a KeyRelease event to run things in the + menu until it has seen a KeyPress. this is to + avoid having the keybinding used to show the menu + end up running something inside the menu */ }; struct _ObMenuEntryFrame @@ -79,40 +90,43 @@ struct _ObMenuEntryFrame struct _ObMenuEntry *entry; ObMenuFrame *frame; + guint ignore_enters; + Rect area; + gint border; Window window; Window icon; Window text; Window bullet; - - RrAppearance *a_normal; - RrAppearance *a_disabled; - RrAppearance *a_selected; - - RrAppearance *a_icon; - RrAppearance *a_mask; - RrAppearance *a_bullet_normal; - RrAppearance *a_bullet_selected; - RrAppearance *a_separator; - RrAppearance *a_text_normal; - RrAppearance *a_text_disabled; - RrAppearance *a_text_selected; }; -ObMenuFrame* menu_frame_new(struct _ObMenu *menu, struct _ObClient *client); +extern GHashTable *menu_frame_map; + +void menu_frame_startup(gboolean reconfig); +void menu_frame_shutdown(gboolean reconfig); + +ObMenuFrame* menu_frame_new(struct _ObMenu *menu, + guint show_from, + struct _ObClient *client); void menu_frame_free(ObMenuFrame *self); void menu_frame_move(ObMenuFrame *self, gint x, gint y); -void menu_frame_move_on_screen(ObMenuFrame *self); +void menu_frame_move_on_screen(ObMenuFrame *self, gint x, gint y, + gint *dx, gint *dy); -gboolean menu_frame_show(ObMenuFrame *self, ObMenuFrame *parent); -void menu_frame_hide(ObMenuFrame *self); +gboolean menu_frame_show_topmenu(ObMenuFrame *self, gint x, gint y, + gint button); +gboolean menu_frame_show_submenu(ObMenuFrame *self, ObMenuFrame *parent, + ObMenuEntryFrame *parent_entry); -void menu_frame_hide_all(); +void menu_frame_hide_all(void); void menu_frame_hide_all_client(struct _ObClient *client); -void menu_frame_select(ObMenuFrame *self, ObMenuEntryFrame *entry); +void menu_frame_render(ObMenuFrame *self); + +void menu_frame_select(ObMenuFrame *self, ObMenuEntryFrame *entry, + gboolean immediate); void menu_frame_select_previous(ObMenuFrame *self); void menu_frame_select_next(ObMenuFrame *self); @@ -121,6 +135,6 @@ ObMenuEntryFrame* menu_entry_frame_under(gint x, gint y); void menu_entry_frame_show_submenu(ObMenuEntryFrame *self); -void menu_entry_frame_execute(ObMenuEntryFrame *self, guint state, Time time); +void menu_entry_frame_execute(ObMenuEntryFrame *self, guint state); #endif