fix: correctly handle Alt+Key shortcuts (#29328)

This commit is contained in:
Cheng Zhao 2021-06-01 10:48:52 +09:00 committed by GitHub
parent 0208e4adad
commit d74ad51826
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 10 deletions

View file

@ -56,6 +56,8 @@ void MenuBar::SetAcceleratorVisibility(bool visible) {
} }
MenuBar::View* MenuBar::FindAccelChild(char16_t key) { MenuBar::View* MenuBar::FindAccelChild(char16_t key) {
if (key == 0)
return nullptr;
for (auto* child : GetChildrenInZOrder()) { for (auto* child : GetChildrenInZOrder()) {
if (static_cast<SubmenuButton*>(child)->accelerator() == key) if (static_cast<SubmenuButton*>(child)->accelerator() == key)
return child; return child;

View file

@ -119,18 +119,18 @@ void RootView::HandleKeyEvent(const content::NativeWebKeyboardEvent& event) {
// Show the submenu when "Alt+Key" is pressed. // Show the submenu when "Alt+Key" is pressed.
if (event.GetType() == blink::WebInputEvent::Type::kRawKeyDown && if (event.GetType() == blink::WebInputEvent::Type::kRawKeyDown &&
!IsAltKey(event) && IsAltModifier(event)) { event.windows_key_code >= ui::VKEY_A &&
if (menu_bar_->HasAccelerator(event.windows_key_code)) { event.windows_key_code <= ui::VKEY_Z && IsAltModifier(event) &&
if (!menu_bar_visible_) { menu_bar_->HasAccelerator(event.windows_key_code)) {
SetMenuBarVisibility(true); if (!menu_bar_visible_) {
SetMenuBarVisibility(true);
View* focused_view = GetFocusManager()->GetFocusedView(); View* focused_view = GetFocusManager()->GetFocusedView();
last_focused_view_tracker_->SetView(focused_view); last_focused_view_tracker_->SetView(focused_view);
menu_bar_->RequestFocus(); menu_bar_->RequestFocus();
}
menu_bar_->ActivateAccelerator(event.windows_key_code);
} }
menu_bar_->ActivateAccelerator(event.windows_key_code);
return; return;
} }