bindable/disableable root/workspace menus
This commit is contained in:
parent
4128a7252d
commit
ce5313528e
2 changed files with 66 additions and 4 deletions
|
@ -596,6 +596,32 @@ void BScreen::saveRootScrollDirection(int d) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BScreen::saveRootMenuButton(unsigned int b) {
|
||||||
|
resource.root_menu_button = b;
|
||||||
|
const char *but;
|
||||||
|
switch (resource.root_menu_button) {
|
||||||
|
case 0: but = "None"; break;
|
||||||
|
case 1: but = "Left"; break;
|
||||||
|
case 2: but = "Middle"; break;
|
||||||
|
case 3: default: but = "Right"; break;
|
||||||
|
}
|
||||||
|
config->setValue(screenstr + "rootMenuButton", but);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BScreen::saveWorkspaceMenuButton(unsigned int b) {
|
||||||
|
resource.workspace_menu_button = b;
|
||||||
|
const char *but;
|
||||||
|
switch (resource.workspace_menu_button) {
|
||||||
|
case 0: but = "None"; break;
|
||||||
|
case 1: but = "Left"; break;
|
||||||
|
case 2: default: but = "Middle"; break;
|
||||||
|
case 3: but = "Right"; break;
|
||||||
|
}
|
||||||
|
config->setValue(screenstr + "workspaceMenuButton", but);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void BScreen::save_rc(void) {
|
void BScreen::save_rc(void) {
|
||||||
saveSloppyFocus(resource.sloppy_focus);
|
saveSloppyFocus(resource.sloppy_focus);
|
||||||
saveAutoRaise(resource.auto_raise);
|
saveAutoRaise(resource.auto_raise);
|
||||||
|
@ -629,6 +655,8 @@ void BScreen::save_rc(void) {
|
||||||
saveAllowScrollLock(resource.allow_scroll_lock);
|
saveAllowScrollLock(resource.allow_scroll_lock);
|
||||||
saveWorkspaceWarping(resource.workspace_warping);
|
saveWorkspaceWarping(resource.workspace_warping);
|
||||||
saveRootScrollDirection(resource.root_scroll);
|
saveRootScrollDirection(resource.root_scroll);
|
||||||
|
saveRootMenuButton(resource.root_menu_button);
|
||||||
|
saveWorkspaceMenuButton(resource.workspace_menu_button);
|
||||||
|
|
||||||
toolbar->save_rc();
|
toolbar->save_rc();
|
||||||
slit->save_rc();
|
slit->save_rc();
|
||||||
|
@ -804,6 +832,29 @@ void BScreen::load_rc(void) {
|
||||||
else if (s == "Reverse")
|
else if (s == "Reverse")
|
||||||
resource.root_scroll = ReverseScroll;
|
resource.root_scroll = ReverseScroll;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resource.root_menu_button = 3;
|
||||||
|
if (config->getValue(screenstr + "rootMenuButton", s)) {
|
||||||
|
if (s == "None")
|
||||||
|
resource.root_menu_button = 0;
|
||||||
|
else if (s == "Left")
|
||||||
|
resource.root_menu_button = 1;
|
||||||
|
else if (s == "Middle")
|
||||||
|
resource.root_menu_button = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
resource.workspace_menu_button = 2;
|
||||||
|
if (config->getValue(screenstr + "workspaceMenuButton", s)) {
|
||||||
|
if (s == "None")
|
||||||
|
resource.workspace_menu_button = 0;
|
||||||
|
else if (s == "Left")
|
||||||
|
resource.workspace_menu_button = 1;
|
||||||
|
else if (s == "Right")
|
||||||
|
resource.workspace_menu_button = 3;
|
||||||
|
}
|
||||||
|
// cant both be the same
|
||||||
|
if (resource.workspace_menu_button == resource.root_menu_button)
|
||||||
|
resource.workspace_menu_button = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2413,10 +2464,6 @@ void BScreen::buttonPressEvent(const XButtonEvent *xbutton) {
|
||||||
|
|
||||||
if (rootmenu->isVisible())
|
if (rootmenu->isVisible())
|
||||||
rootmenu->hide();
|
rootmenu->hide();
|
||||||
} else if (xbutton->button == 2) {
|
|
||||||
showWorkspaceMenu(xbutton->x_root, xbutton->y_root);
|
|
||||||
} else if (xbutton->button == 3) {
|
|
||||||
showRootMenu(xbutton->x_root, xbutton->y_root);
|
|
||||||
// mouse wheel up
|
// mouse wheel up
|
||||||
} else if ((xbutton->button == 4 && resource.root_scroll == NormalScroll) ||
|
} else if ((xbutton->button == 4 && resource.root_scroll == NormalScroll) ||
|
||||||
(xbutton->button == 5 && resource.root_scroll == ReverseScroll)) {
|
(xbutton->button == 5 && resource.root_scroll == ReverseScroll)) {
|
||||||
|
@ -2432,6 +2479,13 @@ void BScreen::buttonPressEvent(const XButtonEvent *xbutton) {
|
||||||
else
|
else
|
||||||
changeWorkspaceID(getCurrentWorkspaceID() - 1);
|
changeWorkspaceID(getCurrentWorkspaceID() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (resource.root_menu_button > 0 &&
|
||||||
|
xbutton->button == resource.root_menu_button)
|
||||||
|
showRootMenu(xbutton->x_root, xbutton->y_root);
|
||||||
|
else if (resource.workspace_menu_button > 0 &&
|
||||||
|
xbutton->button == resource.workspace_menu_button)
|
||||||
|
showWorkspaceMenu(xbutton->x_root, xbutton->y_root);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -163,6 +163,8 @@ private:
|
||||||
unsigned int handle_width, bevel_width, frame_width, border_width,
|
unsigned int handle_width, bevel_width, frame_width, border_width,
|
||||||
resize_zones;
|
resize_zones;
|
||||||
|
|
||||||
|
unsigned int root_menu_button, workspace_menu_button;
|
||||||
|
|
||||||
#ifdef HAVE_STRFTIME
|
#ifdef HAVE_STRFTIME
|
||||||
std::string strftime_format;
|
std::string strftime_format;
|
||||||
#else // !HAVE_STRFTIME
|
#else // !HAVE_STRFTIME
|
||||||
|
@ -231,6 +233,10 @@ public:
|
||||||
inline bool doWorkspaceWarping(void) const
|
inline bool doWorkspaceWarping(void) const
|
||||||
{ return resource.workspace_warping; }
|
{ return resource.workspace_warping; }
|
||||||
inline int rootScrollDirection(void) const { return resource.root_scroll; }
|
inline int rootScrollDirection(void) const { return resource.root_scroll; }
|
||||||
|
inline unsigned int rootMenuButton(void) const
|
||||||
|
{ return resource.root_menu_button; }
|
||||||
|
inline unsigned int workspaceMenuButton(void) const
|
||||||
|
{ return resource.workspace_menu_button; }
|
||||||
|
|
||||||
inline const GC &getOpGC(void) const { return opGC; }
|
inline const GC &getOpGC(void) const { return opGC; }
|
||||||
|
|
||||||
|
@ -313,6 +319,8 @@ public:
|
||||||
void saveAllowScrollLock(bool a);
|
void saveAllowScrollLock(bool a);
|
||||||
void saveWorkspaceWarping(bool w);
|
void saveWorkspaceWarping(bool w);
|
||||||
void saveRootScrollDirection(int d);
|
void saveRootScrollDirection(int d);
|
||||||
|
void saveRootMenuButton(unsigned int b);
|
||||||
|
void saveWorkspaceMenuButton(unsigned int b);
|
||||||
inline void iconUpdate(void) { iconmenu->update(); }
|
inline void iconUpdate(void) { iconmenu->update(); }
|
||||||
|
|
||||||
#ifdef HAVE_STRFTIME
|
#ifdef HAVE_STRFTIME
|
||||||
|
|
Loading…
Reference in a new issue