diff options
author | Jari Vetoniemi <mailroxas@gmail.com> | 2015-01-18 02:07:30 +0200 |
---|---|---|
committer | Jari Vetoniemi <mailroxas@gmail.com> | 2015-01-18 02:07:30 +0200 |
commit | c2eabf2be13de14e0e57ad6374cceb049b8d03da (patch) | |
tree | e02e3fec7d30285d64824c681ff489eb69afaeea /lib/bemenu.h | |
parent | f2eaf599f6bb585d1a4921f37a073ed09c619de9 (diff) | |
download | bemenu-c2eabf2be13de14e0e57ad6374cceb049b8d03da.tar.gz bemenu-c2eabf2be13de14e0e57ad6374cceb049b8d03da.tar.bz2 bemenu-c2eabf2be13de14e0e57ad6374cceb049b8d03da.zip |
Make scrollbar autohideable
Diffstat (limited to 'lib/bemenu.h')
-rw-r--r-- | lib/bemenu.h | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/lib/bemenu.h b/lib/bemenu.h index b5598d0..4010683 100644 --- a/lib/bemenu.h +++ b/lib/bemenu.h @@ -135,6 +135,23 @@ enum bm_filter_mode { }; /** + * Scrollbar display mode constants for bm_menu instance scrollbar. + * + * - @link ::bm_run_result BM_SCROLLBAR_ALWAYS @endlink means that scrollbar is not displayed. + * - @link ::bm_run_result BM_SCROLLBAR_ALWAYS @endlink means that scrollbar is displayed always. + * - @link ::bm_run_result BM_SCROLLBAR_AUTOHIDE @endlink means that scrollbar is only displayed when there are more items than lines. + * + * @link ::bm_scrollbar_mode BM_SCROLLBAR_LAST @endlink is provided for enumerating scrollbar modes. + * Using it as scrollbar mode however provides exactly same functionality as BM_SCROLLBAR_NONE. + */ +enum bm_scrollbar_mode { + BM_SCROLLBAR_NONE, + BM_SCROLLBAR_ALWAYS, + BM_SCROLLBAR_AUTOHIDE, + BM_SCROLLBAR_LAST, +}; + +/** * Result constants from bm_menu_run_with_key function. * * - @link ::bm_run_result BM_RUN_RESULT_RUNNING @endlink means that menu is running and thus should be still renderer && ran. @@ -389,20 +406,20 @@ bool bm_menu_set_color(struct bm_menu *menu, enum bm_color color, const char *he const char* bm_menu_get_color(const struct bm_menu *menu, enum bm_color color); /** - * Display scrollbar at left side of the menu. + * Set scrollbar display mode. * * @param menu bm_menu instance to set scrollbar for. - * @param scrollbar true for scrollbar, false for no scrollbar. + * @param mode bm_scrollbar_mode constant. */ -void bm_menu_set_scrollbar(struct bm_menu *menu, bool scrollbar); +void bm_menu_set_scrollbar(struct bm_menu *menu, enum bm_scrollbar_mode mode); /** - * Is scrollbar being displayed on the menu? + * Return current scrollbar display mode. * * @param menu bm_menu instance where to get scrollbar display state from. - * @return true if scrollbar displayed, false otherwise. + * @return bm_scrollbar_mode constant. */ -bool bm_menu_get_scrollbar(struct bm_menu *menu); +enum bm_scrollbar_mode bm_menu_get_scrollbar(struct bm_menu *menu); /** * Display menu at bottom of the screen. |