Add sub-menu support
This commit is contained in:
parent
4778258364
commit
101c9fcc74
|
@ -1,4 +1,10 @@
|
||||||
2015-11-12 Markus Gans <guru.mail@muenster.de>
|
2015-11-22 Markus Gans <guru.mail@muenster.de>
|
||||||
|
* Add sub-menu support
|
||||||
|
|
||||||
|
2015-11-19 Markus Gans <guru.mail@muenster.de>
|
||||||
|
* Add the missing resetXTermHighlightBackground method
|
||||||
|
|
||||||
|
2015-11-15 Markus Gans <guru.mail@muenster.de>
|
||||||
* Add two new classes FCheckMenuItem and FRadioMenuItem
|
* Add two new classes FCheckMenuItem and FRadioMenuItem
|
||||||
for menu check marks and menu option marks (bullets)
|
for menu check marks and menu option marks (bullets)
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,7 @@ static uInt character[][fc::NUM_OF_ENCODINGS] =
|
||||||
{0x2260, '|', 0xd8, '!'}, // ≠ - NotEqualTo
|
{0x2260, '|', 0xd8, '!'}, // ≠ - NotEqualTo
|
||||||
{0x00b1, 'g', 0xf1, '#'}, // ± - PlusMinus
|
{0x00b1, 'g', 0xf1, '#'}, // ± - PlusMinus
|
||||||
{0x00f7, '/', 0xf6, '/'}, // ÷ - Division sign
|
{0x00f7, '/', 0xf6, '/'}, // ÷ - Division sign
|
||||||
{0x00d7, '*', '*', '*'}, // × - Multiplication sign
|
{0x00d7, 'x', 'x', 'x'}, // × - Multiplication sign
|
||||||
{0x02e3, '~', 0xfc, '~'}, // ˣ - Modifier letter small x
|
{0x02e3, '~', 0xfc, '~'}, // ˣ - Modifier letter small x
|
||||||
{0x00b0, 'f', 0xb0, 'o'}, // ° - Degree
|
{0x00b0, 'f', 0xb0, 'o'}, // ° - Degree
|
||||||
{0x2022, '`', 0x04, '*'}, // • - Bullet
|
{0x2022, '`', 0x04, '*'}, // • - Bullet
|
||||||
|
@ -108,7 +108,8 @@ static uInt character[][fc::NUM_OF_ENCODINGS] =
|
||||||
{0x1af4, 0, 0xf4, 0}, // ] - NF_rev_menu_button3
|
{0x1af4, 0, 0xf4, 0}, // ] - NF_rev_menu_button3
|
||||||
{0x1af5, 0, 0xf5, 0}, // ] - NF_shadow_box_right
|
{0x1af5, 0, 0xf5, 0}, // ] - NF_shadow_box_right
|
||||||
{0x1afb, 0, 0xfb, 0}, // ✓ - NF_check_mark
|
{0x1afb, 0, 0xfb, 0}, // ✓ - NF_check_mark
|
||||||
{0x221a, 0, 0xfb, 'x'} // √ - square root
|
{0x221a, 0, 0xfb, 'x'}, // √ - square root
|
||||||
|
{0x25cf, '`', 0x04, '*'} // ● - black circle
|
||||||
};
|
};
|
||||||
|
|
||||||
const int lastCharItem = int(sizeof(character) / sizeof(character[0])) - 1;
|
const int lastCharItem = int(sizeof(character) / sizeof(character[0])) - 1;
|
||||||
|
|
|
@ -69,7 +69,7 @@ void FCheckBox::drawCheckButton()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
print ('[');
|
print ('[');
|
||||||
print ('x');
|
print (fc::Times); // Times ×
|
||||||
print (']');
|
print (']');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,6 +87,7 @@ class fc
|
||||||
LessThanOrEqualTo = 0x2264, // ≤
|
LessThanOrEqualTo = 0x2264, // ≤
|
||||||
NotEqualTo = 0x2260, // ≠
|
NotEqualTo = 0x2260, // ≠
|
||||||
PlusMinus = 0x00b1, // ±
|
PlusMinus = 0x00b1, // ±
|
||||||
|
Times = 0x00d7, // ×
|
||||||
Degree = 0x00b0, // °
|
Degree = 0x00b0, // °
|
||||||
BlackVerticalRectangle = 0x25ae, // ▮
|
BlackVerticalRectangle = 0x25ae, // ▮
|
||||||
SmallBullet = 0x00b7, // ·
|
SmallBullet = 0x00b7, // ·
|
||||||
|
@ -166,7 +167,8 @@ class fc
|
||||||
NF_rev_menu_button3 = 0x1af4, // ]
|
NF_rev_menu_button3 = 0x1af4, // ]
|
||||||
NF_shadow_box_right = 0x1af5, // ]
|
NF_shadow_box_right = 0x1af5, // ]
|
||||||
NF_check_mark = 0x1afb, // ✓
|
NF_check_mark = 0x1afb, // ✓
|
||||||
SquareRoot = 0x221a // √
|
SquareRoot = 0x221a, // √
|
||||||
|
BlackCircle = 0x25CF // ●
|
||||||
};
|
};
|
||||||
|
|
||||||
// keyboard - single keys
|
// keyboard - single keys
|
||||||
|
|
212
src/fmenu.cpp
212
src/fmenu.cpp
|
@ -15,6 +15,7 @@ FMenu::FMenu(FWidget* parent)
|
||||||
: FWindow(parent)
|
: FWindow(parent)
|
||||||
, item(0)
|
, item(0)
|
||||||
, super_menu(0)
|
, super_menu(0)
|
||||||
|
, open_sub_menu(0)
|
||||||
, maxItemWidth(0)
|
, maxItemWidth(0)
|
||||||
, mouse_down(false)
|
, mouse_down(false)
|
||||||
, has_checkable_items(false)
|
, has_checkable_items(false)
|
||||||
|
@ -27,6 +28,7 @@ FMenu::FMenu (FString& txt, FWidget* parent)
|
||||||
: FWindow(parent)
|
: FWindow(parent)
|
||||||
, item(0)
|
, item(0)
|
||||||
, super_menu(0)
|
, super_menu(0)
|
||||||
|
, open_sub_menu(0)
|
||||||
, maxItemWidth(0)
|
, maxItemWidth(0)
|
||||||
, mouse_down(false)
|
, mouse_down(false)
|
||||||
, has_checkable_items(false)
|
, has_checkable_items(false)
|
||||||
|
@ -40,6 +42,7 @@ FMenu::FMenu (const std::string& txt, FWidget* parent)
|
||||||
: FWindow(parent)
|
: FWindow(parent)
|
||||||
, item(0)
|
, item(0)
|
||||||
, super_menu(0)
|
, super_menu(0)
|
||||||
|
, open_sub_menu(0)
|
||||||
, maxItemWidth(0)
|
, maxItemWidth(0)
|
||||||
, mouse_down(false)
|
, mouse_down(false)
|
||||||
, has_checkable_items(false)
|
, has_checkable_items(false)
|
||||||
|
@ -53,6 +56,7 @@ FMenu::FMenu (const char* txt, FWidget* parent)
|
||||||
: FWindow(parent)
|
: FWindow(parent)
|
||||||
, item(0)
|
, item(0)
|
||||||
, super_menu(0)
|
, super_menu(0)
|
||||||
|
, open_sub_menu(0)
|
||||||
, maxItemWidth(0)
|
, maxItemWidth(0)
|
||||||
, mouse_down(false)
|
, mouse_down(false)
|
||||||
, has_checkable_items(false)
|
, has_checkable_items(false)
|
||||||
|
@ -138,8 +142,13 @@ void FMenu::menu_dimension()
|
||||||
{
|
{
|
||||||
uInt item_width = (*iter)->getTextLength() + 2;
|
uInt item_width = (*iter)->getTextLength() + 2;
|
||||||
int accel_key = (*iter)->accel_key;
|
int accel_key = (*iter)->accel_key;
|
||||||
|
bool has_menu = (*iter)->hasMenu();
|
||||||
|
|
||||||
if ( accel_key )
|
if ( has_menu )
|
||||||
|
{
|
||||||
|
item_width += 3;
|
||||||
|
}
|
||||||
|
else if ( accel_key )
|
||||||
{
|
{
|
||||||
uInt accel_len = getKeyName(accel_key).getLength();
|
uInt accel_len = getKeyName(accel_key).getLength();
|
||||||
item_width += accel_len + 2;
|
item_width += accel_len + 2;
|
||||||
|
@ -165,6 +174,14 @@ void FMenu::menu_dimension()
|
||||||
while ( iter != end )
|
while ( iter != end )
|
||||||
{
|
{
|
||||||
(*iter)->setGeometry (item_X, item_Y, int(maxItemWidth), 1);
|
(*iter)->setGeometry (item_X, item_Y, int(maxItemWidth), 1);
|
||||||
|
|
||||||
|
if ( (*iter)->hasMenu() )
|
||||||
|
{
|
||||||
|
int menu_X = (*iter)->getX() + int(maxItemWidth) + 1;
|
||||||
|
int menu_Y = (*iter)->getY();
|
||||||
|
// set sub-menu position
|
||||||
|
(*iter)->getMenu()->setPos (menu_X, menu_Y, false);
|
||||||
|
}
|
||||||
item_Y++;
|
item_Y++;
|
||||||
|
|
||||||
++iter;
|
++iter;
|
||||||
|
@ -192,21 +209,52 @@ bool FMenu::isRadioMenuItem (FWidget* w) const
|
||||||
, const_cast<char*>("FRadioMenuItem") ) == 0 );
|
, const_cast<char*>("FRadioMenuItem") ) == 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
bool FMenu::isSubMenu() const
|
||||||
|
{
|
||||||
|
FWidget* super = getSuperMenu();
|
||||||
|
if ( super && isMenu(super) )
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
void FMenu::openSubMenu (FMenu* sub_menu)
|
||||||
|
{
|
||||||
|
if ( sub_menu->isVisible() )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// open sub menu
|
||||||
|
sub_menu->selectFirstItem();
|
||||||
|
sub_menu->getSelectedItem()->setFocus();
|
||||||
|
sub_menu->setVisible();
|
||||||
|
sub_menu->show();
|
||||||
|
open_sub_menu = sub_menu;
|
||||||
|
raiseWindow (sub_menu);
|
||||||
|
sub_menu->redraw();
|
||||||
|
if ( statusBar() )
|
||||||
|
statusBar()->drawMessage();
|
||||||
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void FMenu::hideSubMenus()
|
void FMenu::hideSubMenus()
|
||||||
{
|
{
|
||||||
|
if ( ! hasSelectedItem() )
|
||||||
|
return;
|
||||||
|
|
||||||
// hide all sub-menus
|
// hide all sub-menus
|
||||||
if ( hasSelectedItem() )
|
|
||||||
{
|
|
||||||
if ( getSelectedItem()->hasMenu() )
|
if ( getSelectedItem()->hasMenu() )
|
||||||
{
|
{
|
||||||
FMenu* m = getSelectedItem()->getMenu();
|
FMenu* m = getSelectedItem()->getMenu();
|
||||||
m->hideSubMenus();
|
m->hideSubMenus();
|
||||||
m->hide();
|
m->hide();
|
||||||
|
open_sub_menu = 0;
|
||||||
}
|
}
|
||||||
unselectItem();
|
unselectItem();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void FMenu::hideSuperMenus()
|
void FMenu::hideSuperMenus()
|
||||||
|
@ -277,10 +325,12 @@ bool FMenu::selectNextItem()
|
||||||
unselectItem();
|
unselectItem();
|
||||||
next->setSelected();
|
next->setSelected();
|
||||||
setSelectedItem(next);
|
setSelectedItem(next);
|
||||||
|
redraw();
|
||||||
next->setFocus();
|
next->setFocus();
|
||||||
if ( statusBar() )
|
if ( statusBar() )
|
||||||
statusBar()->drawMessage();
|
statusBar()->drawMessage();
|
||||||
redraw();
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
++iter;
|
++iter;
|
||||||
|
@ -323,6 +373,8 @@ bool FMenu::selectPrevItem()
|
||||||
if ( statusBar() )
|
if ( statusBar() )
|
||||||
statusBar()->drawMessage();
|
statusBar()->drawMessage();
|
||||||
redraw();
|
redraw();
|
||||||
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} while ( iter != begin );
|
} while ( iter != begin );
|
||||||
|
@ -507,6 +559,7 @@ void FMenu::drawItems()
|
||||||
uInt txt_length;
|
uInt txt_length;
|
||||||
int hotkeypos, to_char;
|
int hotkeypos, to_char;
|
||||||
int accel_key = (*iter)->accel_key;
|
int accel_key = (*iter)->accel_key;
|
||||||
|
bool has_menu = (*iter)->hasMenu();
|
||||||
bool is_enabled = (*iter)->isEnabled();
|
bool is_enabled = (*iter)->isEnabled();
|
||||||
bool is_checked = (*iter)->isChecked();
|
bool is_checked = (*iter)->isChecked();
|
||||||
bool is_checkable = (*iter)->checkable;
|
bool is_checkable = (*iter)->checkable;
|
||||||
|
@ -555,7 +608,7 @@ void FMenu::drawItems()
|
||||||
{
|
{
|
||||||
if ( is_radio_btn )
|
if ( is_radio_btn )
|
||||||
{
|
{
|
||||||
print (fc::Bullet);
|
print (fc::BlackCircle); // BlackCircle ●
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -623,8 +676,17 @@ void FMenu::drawItems()
|
||||||
else
|
else
|
||||||
print (item_text[z]);
|
print (item_text[z]);
|
||||||
}
|
}
|
||||||
|
if ( has_menu )
|
||||||
if ( accel_key )
|
{
|
||||||
|
int len = int(maxItemWidth) - (to_char + c + 3);
|
||||||
|
if ( len > 0 )
|
||||||
|
{
|
||||||
|
FString spaces (len, wchar_t(' '));
|
||||||
|
print (spaces + wchar_t(fc::BlackRightPointingPointer));
|
||||||
|
to_char = int(maxItemWidth) - (c + 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( accel_key )
|
||||||
{
|
{
|
||||||
FString accel_name (getKeyName(accel_key));
|
FString accel_name (getKeyName(accel_key));
|
||||||
int accel_len = int(accel_name.getLength());
|
int accel_len = int(accel_name.getLength());
|
||||||
|
@ -710,11 +772,17 @@ void FMenu::onKeyPress (FKeyEvent* ev)
|
||||||
if ( hasSelectedItem() )
|
if ( hasSelectedItem() )
|
||||||
{
|
{
|
||||||
FMenuItem* sel_item = getSelectedItem();
|
FMenuItem* sel_item = getSelectedItem();
|
||||||
|
|
||||||
|
if ( sel_item->hasMenu() )
|
||||||
|
openSubMenu (sel_item->getMenu());
|
||||||
|
else
|
||||||
|
{
|
||||||
unselectItem();
|
unselectItem();
|
||||||
hide();
|
hide();
|
||||||
hideSuperMenus();
|
hideSuperMenus();
|
||||||
sel_item->processClicked();
|
sel_item->processClicked();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
ev->accept();
|
ev->accept();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -729,38 +797,35 @@ void FMenu::onKeyPress (FKeyEvent* ev)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case fc::Fkey_left:
|
case fc::Fkey_left:
|
||||||
if ( hasSelectedItem() && getSelectedItem()->hasMenu() )
|
if ( isSubMenu() )
|
||||||
{
|
{
|
||||||
FMenu* sub_menu = getSelectedItem()->getMenu();
|
FMenu* smenu = reinterpret_cast<FMenu*>(getSuperMenu());
|
||||||
if ( sub_menu->isVisible() )
|
|
||||||
hideSubMenus();
|
hideSubMenus();
|
||||||
else
|
hide();
|
||||||
keypressMenuBar(ev); // select previous menu
|
smenu->getSelectedItem()->setFocus();
|
||||||
ev->accept();
|
smenu->redraw();
|
||||||
|
if ( statusBar() )
|
||||||
|
statusBar()->drawMessage();
|
||||||
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
keypressMenuBar(ev); // select previous menu
|
keypressMenuBar(ev); // select previous menu
|
||||||
|
ev->accept();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case fc::Fkey_right:
|
case fc::Fkey_right:
|
||||||
if ( hasSelectedItem() && getSelectedItem()->hasMenu() )
|
if ( hasSelectedItem() && getSelectedItem()->hasMenu() )
|
||||||
{
|
{
|
||||||
FMenu* sub_menu = getSelectedItem()->getMenu();
|
FMenu* sub_menu = getSelectedItem()->getMenu();
|
||||||
|
|
||||||
if ( ! sub_menu->isVisible() )
|
if ( ! sub_menu->isVisible() )
|
||||||
{
|
{
|
||||||
// open sub menu
|
openSubMenu (sub_menu);
|
||||||
sub_menu->selectFirstItem();
|
ev->accept();
|
||||||
sub_menu->getSelectedItem()->setFocus();;
|
|
||||||
sub_menu->setVisible();
|
|
||||||
sub_menu->show();
|
|
||||||
raiseWindow (sub_menu);
|
|
||||||
sub_menu->redraw();
|
|
||||||
updateTerminal();
|
|
||||||
flush_out();
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
keypressMenuBar(ev); // select next menu
|
keypressMenuBar(ev); // select next menu
|
||||||
ev->accept();
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
keypressMenuBar(ev); // select next menu
|
keypressMenuBar(ev); // select next menu
|
||||||
|
@ -769,12 +834,21 @@ void FMenu::onKeyPress (FKeyEvent* ev)
|
||||||
case fc::Fkey_escape:
|
case fc::Fkey_escape:
|
||||||
case fc::Fkey_escape_mintty:
|
case fc::Fkey_escape_mintty:
|
||||||
unselectItem();
|
unselectItem();
|
||||||
hide();
|
|
||||||
hideSubMenus();
|
hideSubMenus();
|
||||||
|
hide();
|
||||||
|
if ( isSubMenu() )
|
||||||
|
{
|
||||||
|
FMenu* smenu = reinterpret_cast<FMenu*>(getSuperMenu());
|
||||||
|
smenu->getSelectedItem()->setFocus();
|
||||||
|
smenu->redraw();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
hideSuperMenus();
|
hideSuperMenus();
|
||||||
activatePrevWindow();
|
activatePrevWindow();
|
||||||
getActiveWindow()->getFocusWidget()->setFocus();
|
getActiveWindow()->getFocusWidget()->setFocus();
|
||||||
getActiveWindow()->redraw();
|
getActiveWindow()->redraw();
|
||||||
|
}
|
||||||
if ( statusBar() )
|
if ( statusBar() )
|
||||||
statusBar()->drawMessage();
|
statusBar()->drawMessage();
|
||||||
updateTerminal();
|
updateTerminal();
|
||||||
|
@ -827,6 +901,7 @@ void FMenu::onMouseDown (FMouseEvent* ev)
|
||||||
&& mouse_y == y
|
&& mouse_y == y
|
||||||
&& ! (*iter)->isSelected() )
|
&& ! (*iter)->isSelected() )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
FWidget* focused_widget = getFocusWidget();
|
FWidget* focused_widget = getFocusWidget();
|
||||||
FFocusEvent out (FocusOut_Event);
|
FFocusEvent out (FocusOut_Event);
|
||||||
FApplication::queueEvent(focused_widget, &out);
|
FApplication::queueEvent(focused_widget, &out);
|
||||||
|
@ -884,6 +959,7 @@ void FMenu::onMouseUp (FMouseEvent* ev)
|
||||||
&& mouse_x <= x2
|
&& mouse_x <= x2
|
||||||
&& mouse_y == y )
|
&& mouse_y == y )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
unselectItem();
|
unselectItem();
|
||||||
hide();
|
hide();
|
||||||
hideSuperMenus();
|
hideSuperMenus();
|
||||||
|
@ -913,6 +989,9 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
{
|
{
|
||||||
std::vector<FMenuItem*>::const_iterator iter, end;
|
std::vector<FMenuItem*>::const_iterator iter, end;
|
||||||
bool focus_changed = false;
|
bool focus_changed = false;
|
||||||
|
bool mouse_over_submenu = false;
|
||||||
|
bool hide_sub_menu = false;
|
||||||
|
FMenu* show_sub_menu = 0;
|
||||||
FPoint mouse_pos;
|
FPoint mouse_pos;
|
||||||
|
|
||||||
iter = itemlist.begin();
|
iter = itemlist.begin();
|
||||||
|
@ -920,6 +999,13 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
mouse_pos = ev->getPos();
|
mouse_pos = ev->getPos();
|
||||||
mouse_pos -= FPoint(getRightPadding(),getTopPadding());
|
mouse_pos -= FPoint(getRightPadding(),getTopPadding());
|
||||||
|
|
||||||
|
if ( open_sub_menu )
|
||||||
|
{
|
||||||
|
const FRect& submenu_geometry = open_sub_menu->getGeometryGlobal();
|
||||||
|
if ( submenu_geometry.contains(ev->getGlobalPos()) )
|
||||||
|
mouse_over_submenu = true;
|
||||||
|
}
|
||||||
|
|
||||||
while ( iter != end )
|
while ( iter != end )
|
||||||
{
|
{
|
||||||
int x1, x2, y, mouse_x, mouse_y;
|
int x1, x2, y, mouse_x, mouse_y;
|
||||||
|
@ -938,6 +1024,7 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
&& ! (*iter)->isSelected()
|
&& ! (*iter)->isSelected()
|
||||||
&& ! (*iter)->isSeparator() )
|
&& ! (*iter)->isSeparator() )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
FWidget* focused_widget = getFocusWidget();
|
FWidget* focused_widget = getFocusWidget();
|
||||||
FFocusEvent out (FocusOut_Event);
|
FFocusEvent out (FocusOut_Event);
|
||||||
FApplication::queueEvent(focused_widget, &out);
|
FApplication::queueEvent(focused_widget, &out);
|
||||||
|
@ -948,6 +1035,14 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
focused_widget->redraw();
|
focused_widget->redraw();
|
||||||
if ( statusBar() )
|
if ( statusBar() )
|
||||||
statusBar()->drawMessage();
|
statusBar()->drawMessage();
|
||||||
|
if ( (*iter)->hasMenu() )
|
||||||
|
{
|
||||||
|
FMenu* sub_menu = (*iter)->getMenu();
|
||||||
|
if ( ! sub_menu->isVisible() )
|
||||||
|
show_sub_menu = sub_menu;
|
||||||
|
}
|
||||||
|
else if ( open_sub_menu )
|
||||||
|
hide_sub_menu = true;
|
||||||
focus_changed = true;
|
focus_changed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -955,8 +1050,10 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
{
|
{
|
||||||
if ( getGeometryGlobal().contains(ev->getGlobalPos())
|
if ( getGeometryGlobal().contains(ev->getGlobalPos())
|
||||||
&& (*iter)->isEnabled()
|
&& (*iter)->isEnabled()
|
||||||
&& (*iter)->isSelected() )
|
&& (*iter)->isSelected()
|
||||||
|
&& ! mouse_over_submenu )
|
||||||
{
|
{
|
||||||
|
// Unselect selected item without mouse focus
|
||||||
(*iter)->unsetSelected();
|
(*iter)->unsetSelected();
|
||||||
if ( getSelectedItem() == *iter )
|
if ( getSelectedItem() == *iter )
|
||||||
setSelectedItem(0);
|
setSelectedItem(0);
|
||||||
|
@ -966,10 +1063,21 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
++iter;
|
++iter;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mouse is over border or separator
|
if ( mouse_over_submenu )
|
||||||
if ( ! hasSelectedItem() && statusBar()
|
{
|
||||||
|
// Mouse event handover to sub-menu
|
||||||
|
const FPoint& g = ev->getGlobalPos();
|
||||||
|
const FPoint& p = open_sub_menu->globalToLocalPos(g);
|
||||||
|
int b = ev->getButton();
|
||||||
|
ev = new FMouseEvent (MouseMove_Event, p, g, b);
|
||||||
|
open_sub_menu->mouse_down = true;
|
||||||
|
setClickedWidget(open_sub_menu);
|
||||||
|
open_sub_menu->onMouseMove(ev);
|
||||||
|
}
|
||||||
|
else if ( ! hasSelectedItem() && statusBar()
|
||||||
&& getGeometryGlobal().contains(ev->getGlobalPos()) )
|
&& getGeometryGlobal().contains(ev->getGlobalPos()) )
|
||||||
{
|
{
|
||||||
|
// Mouse is over border or separator
|
||||||
FString msg = getStatusbarMessage();
|
FString msg = getStatusbarMessage();
|
||||||
FString curMsg = statusBar()->getMessage();
|
FString curMsg = statusBar()->getMessage();
|
||||||
if ( curMsg != msg )
|
if ( curMsg != msg )
|
||||||
|
@ -977,6 +1085,8 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
statusBar()->setMessage(msg);
|
statusBar()->setMessage(msg);
|
||||||
statusBar()->drawMessage();
|
statusBar()->drawMessage();
|
||||||
}
|
}
|
||||||
|
if ( open_sub_menu )
|
||||||
|
hide_sub_menu = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mouse event handover to the menu bar
|
// Mouse event handover to the menu bar
|
||||||
|
@ -998,6 +1108,26 @@ void FMenu::onMouseMove (FMouseEvent* ev)
|
||||||
|
|
||||||
if ( focus_changed )
|
if ( focus_changed )
|
||||||
redraw();
|
redraw();
|
||||||
|
|
||||||
|
if ( show_sub_menu )
|
||||||
|
{
|
||||||
|
// open sub menu
|
||||||
|
show_sub_menu->setVisible();
|
||||||
|
show_sub_menu->show();
|
||||||
|
open_sub_menu = show_sub_menu;
|
||||||
|
raiseWindow (show_sub_menu);
|
||||||
|
show_sub_menu->redraw();
|
||||||
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
|
}
|
||||||
|
else if ( hide_sub_menu )
|
||||||
|
{
|
||||||
|
open_sub_menu->hideSubMenus();
|
||||||
|
open_sub_menu->hide();
|
||||||
|
open_sub_menu = 0;
|
||||||
|
updateTerminal();
|
||||||
|
flush_out();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1031,10 +1161,13 @@ void FMenu::hide()
|
||||||
updateTerminal();
|
updateTerminal();
|
||||||
flush_out();
|
flush_out();
|
||||||
|
|
||||||
|
if ( ! isSubMenu() )
|
||||||
|
{
|
||||||
FMenu* open_menu = static_cast<FMenu*>(getOpenMenu());
|
FMenu* open_menu = static_cast<FMenu*>(getOpenMenu());
|
||||||
if ( open_menu && open_menu != this )
|
if ( open_menu && open_menu != this )
|
||||||
open_menu->hide();
|
open_menu->hide();
|
||||||
setOpenMenu(0);
|
setOpenMenu(0);
|
||||||
|
}
|
||||||
mouse_down = false;
|
mouse_down = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1058,30 +1191,9 @@ void FMenu::setStatusbarMessage(FString msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void FMenu::cb_menuitem_activated (FWidget* widget, void*)
|
void FMenu::cb_menuitem_activated (FWidget*, void*)
|
||||||
{
|
{
|
||||||
FMenuItem* menuitem = static_cast<FMenuItem*>(widget);
|
|
||||||
|
|
||||||
if ( menuitem->hasMenu() )
|
|
||||||
{
|
|
||||||
FMenu* menu = menuitem->getMenu();
|
|
||||||
if ( ! menu->isVisible() )
|
|
||||||
{
|
|
||||||
FMenu* open_menu = static_cast<FMenu*>(getOpenMenu());
|
|
||||||
if ( open_menu && open_menu != menu )
|
|
||||||
open_menu->hide();
|
|
||||||
setOpenMenu(menu);
|
|
||||||
|
|
||||||
menu->setVisible();
|
|
||||||
menu->show();
|
|
||||||
raiseWindow (menu);
|
|
||||||
menu->redraw();
|
|
||||||
updateTerminal();
|
|
||||||
flush_out();
|
|
||||||
if ( ! isMenu(getSuperMenu()) )
|
|
||||||
setOpenMenu(menu);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
|
|
|
@ -48,6 +48,7 @@ class FMenu : public FWindow, public FMenuList
|
||||||
private:
|
private:
|
||||||
FMenuItem* item;
|
FMenuItem* item;
|
||||||
FWidget* super_menu;
|
FWidget* super_menu;
|
||||||
|
FMenu* open_sub_menu;
|
||||||
uInt maxItemWidth;
|
uInt maxItemWidth;
|
||||||
bool mouse_down;
|
bool mouse_down;
|
||||||
bool has_checkable_items;
|
bool has_checkable_items;
|
||||||
|
@ -62,6 +63,8 @@ class FMenu : public FWindow, public FMenuList
|
||||||
bool isRadioMenuItem (FWidget*) const;
|
bool isRadioMenuItem (FWidget*) const;
|
||||||
FWidget* getSuperMenu() const;
|
FWidget* getSuperMenu() const;
|
||||||
void setSuperMenu (FWidget*);
|
void setSuperMenu (FWidget*);
|
||||||
|
bool isSubMenu() const;
|
||||||
|
void openSubMenu (FMenu*);
|
||||||
void hideSubMenus();
|
void hideSubMenus();
|
||||||
void hideSuperMenus();
|
void hideSuperMenus();
|
||||||
bool containsMenuStructure (const FPoint&) const;
|
bool containsMenuStructure (const FPoint&) const;
|
||||||
|
|
|
@ -558,6 +558,7 @@ void FMenuBar::onMouseDown (FMouseEvent* ev)
|
||||||
&& mouse_x <= x2
|
&& mouse_x <= x2
|
||||||
&& mouse_y == 1 )
|
&& mouse_y == 1 )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
if ( (*iter)->isEnabled() && ! (*iter)->isSelected() )
|
if ( (*iter)->isEnabled() && ! (*iter)->isSelected() )
|
||||||
{
|
{
|
||||||
FWidget* focused_widget = getFocusWidget();
|
FWidget* focused_widget = getFocusWidget();
|
||||||
|
@ -636,6 +637,7 @@ void FMenuBar::onMouseUp (FMouseEvent* ev)
|
||||||
&& (*iter)->isEnabled()
|
&& (*iter)->isEnabled()
|
||||||
&& (*iter)->isSelected() )
|
&& (*iter)->isSelected() )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
if ( (*iter)->hasMenu() )
|
if ( (*iter)->hasMenu() )
|
||||||
{
|
{
|
||||||
FMenu* menu = (*iter)->getMenu();
|
FMenu* menu = (*iter)->getMenu();
|
||||||
|
@ -714,6 +716,7 @@ void FMenuBar::onMouseMove (FMouseEvent* ev)
|
||||||
&& mouse_x <= x2
|
&& mouse_x <= x2
|
||||||
&& mouse_y == 1 )
|
&& mouse_y == 1 )
|
||||||
{
|
{
|
||||||
|
// Mouse pointer over item
|
||||||
if ( (*iter)->isEnabled() && ! (*iter)->isSelected() )
|
if ( (*iter)->isEnabled() && ! (*iter)->isSelected() )
|
||||||
{
|
{
|
||||||
FWidget* focused_widget = getFocusWidget();
|
FWidget* focused_widget = getFocusWidget();
|
||||||
|
@ -747,6 +750,7 @@ void FMenuBar::onMouseMove (FMouseEvent* ev)
|
||||||
&& (*iter)->isEnabled()
|
&& (*iter)->isEnabled()
|
||||||
&& (*iter)->isSelected() )
|
&& (*iter)->isSelected() )
|
||||||
{
|
{
|
||||||
|
// Unselect selected item without mouse focus
|
||||||
(*iter)->unsetSelected();
|
(*iter)->unsetSelected();
|
||||||
if ( getSelectedItem() == *iter )
|
if ( getSelectedItem() == *iter )
|
||||||
setSelectedItem(0);
|
setSelectedItem(0);
|
||||||
|
|
|
@ -67,25 +67,6 @@ void FMenuList::unselectItem()
|
||||||
setSelectedItem(0);
|
setSelectedItem(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
bool FMenuList::hasSelectedItem()
|
|
||||||
{
|
|
||||||
if ( ! itemlist.empty() )
|
|
||||||
{
|
|
||||||
std::vector<FMenuItem*>::const_iterator iter, end;
|
|
||||||
iter = itemlist.begin();
|
|
||||||
end = itemlist.end();
|
|
||||||
|
|
||||||
while ( iter != end )
|
|
||||||
{
|
|
||||||
if ( (*iter)->isSelected() )
|
|
||||||
return true;
|
|
||||||
++iter;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void FMenuList::insert (FMenuItem* i)
|
void FMenuList::insert (FMenuItem* i)
|
||||||
{
|
{
|
||||||
|
|
|
@ -52,7 +52,6 @@ class FMenuList
|
||||||
bool isSelected (int) const;
|
bool isSelected (int) const;
|
||||||
void selectFirstItem();
|
void selectFirstItem();
|
||||||
void unselectItem();
|
void unselectItem();
|
||||||
bool hasSelectedItem();
|
|
||||||
FMenuItem* getSelectedItem() const;
|
FMenuItem* getSelectedItem() const;
|
||||||
void setSelectedItem (FMenuItem*);
|
void setSelectedItem (FMenuItem*);
|
||||||
bool hasSelectedItem() const;
|
bool hasSelectedItem() const;
|
||||||
|
|
|
@ -70,7 +70,7 @@ void FRadioButton::drawRadioButton()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
print ('(');
|
print ('(');
|
||||||
print (fc::Bullet); // Bullet •
|
print (fc::BlackCircle); // BlackCircle ●
|
||||||
print (')');
|
print (')');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1505,7 +1505,7 @@ void FTerm::init()
|
||||||
// mintty can't reset these settings
|
// mintty can't reset these settings
|
||||||
setXTermBackground("rgb:8080/a4a4/ecec");
|
setXTermBackground("rgb:8080/a4a4/ecec");
|
||||||
setXTermForeground("rgb:0000/0000/0000");
|
setXTermForeground("rgb:0000/0000/0000");
|
||||||
setXTermHighlightBackground("rgb:b1b1/b1b1/b1b1");
|
setXTermHighlightBackground("rgb:4a4a/9090/d9d9");
|
||||||
}
|
}
|
||||||
|
|
||||||
setRawMode();
|
setRawMode();
|
||||||
|
@ -1606,6 +1606,7 @@ void FTerm::finish()
|
||||||
resetXTermCursorColor();
|
resetXTermCursorColor();
|
||||||
resetXTermForeground();
|
resetXTermForeground();
|
||||||
resetXTermBackground();
|
resetXTermBackground();
|
||||||
|
resetXTermHighlightBackground();
|
||||||
setXTermCursorStyle(fc::steady_block);
|
setXTermCursorStyle(fc::steady_block);
|
||||||
|
|
||||||
if ( max_color >= 16 && ! kde_konsole && ! tera_terminal )
|
if ( max_color >= 16 && ! kde_konsole && ! tera_terminal )
|
||||||
|
@ -2893,6 +2894,17 @@ void FTerm::resetXTermMouseBackground()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------
|
||||||
|
void FTerm::resetXTermHighlightBackground()
|
||||||
|
{
|
||||||
|
// Reset the highlight background color
|
||||||
|
if ( xterm || urxvt_terminal )
|
||||||
|
{
|
||||||
|
putstringf ("\033]117\07");
|
||||||
|
fflush(stdout);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
void FTerm::saveColorMap()
|
void FTerm::saveColorMap()
|
||||||
{
|
{
|
||||||
|
|
|
@ -325,6 +325,7 @@ class FTerm
|
||||||
static void resetXTermCursorColor();
|
static void resetXTermCursorColor();
|
||||||
static void resetXTermMouseForeground();
|
static void resetXTermMouseForeground();
|
||||||
static void resetXTermMouseBackground();
|
static void resetXTermMouseBackground();
|
||||||
|
static void resetXTermHighlightBackground();
|
||||||
static void saveColorMap();
|
static void saveColorMap();
|
||||||
static void resetColorMap();
|
static void resetColorMap();
|
||||||
static void setPalette (int, int, int, int);
|
static void setPalette (int, int, int, int);
|
||||||
|
|
Loading…
Reference in New Issue