Focus window on menu bar click

This commit is contained in:
Kevin Sawicki 2016-10-24 11:42:15 +09:00
parent 93464b8100
commit 98387e50cc
4 changed files with 10 additions and 8 deletions

View file

@ -846,7 +846,7 @@ void NativeWindowViews::SetMenu(AtomMenuModel* menu_model) {
if (!menu_bar_) { if (!menu_bar_) {
gfx::Size content_size = GetContentSize(); gfx::Size content_size = GetContentSize();
menu_bar_.reset(new MenuBar); menu_bar_.reset(new MenuBar(this));
menu_bar_->set_owned_by_client(); menu_bar_->set_owned_by_client();
if (!menu_bar_autohide_) { if (!menu_bar_autohide_) {

View file

@ -47,9 +47,10 @@ void GetMenuBarColor(SkColor* enabled, SkColor* disabled, SkColor* highlight,
} // namespace } // namespace
MenuBar::MenuBar() MenuBar::MenuBar(NativeWindow* window)
: background_color_(kDefaultColor), : background_color_(kDefaultColor),
menu_model_(NULL) { menu_model_(NULL),
window_(window) {
UpdateMenuBarColor(); UpdateMenuBarColor();
SetLayoutManager(new views::BoxLayout( SetLayoutManager(new views::BoxLayout(
views::BoxLayout::kHorizontal, 0, 0, 0)); views::BoxLayout::kHorizontal, 0, 0, 0));
@ -142,6 +143,9 @@ void MenuBar::OnMenuButtonClicked(views::MenuButton* source,
if (!menu_model_) if (!menu_model_)
return; return;
if (!window_->IsFocused())
window_->Focus(true);
int id = source->tag(); int id = source->tag();
AtomMenuModel::ItemType type = menu_model_->GetTypeAt(id); AtomMenuModel::ItemType type = menu_model_->GetTypeAt(id);
if (type != AtomMenuModel::TYPE_SUBMENU) { if (type != AtomMenuModel::TYPE_SUBMENU) {

View file

@ -5,6 +5,7 @@
#ifndef ATOM_BROWSER_UI_VIEWS_MENU_BAR_H_ #ifndef ATOM_BROWSER_UI_VIEWS_MENU_BAR_H_
#define ATOM_BROWSER_UI_VIEWS_MENU_BAR_H_ #define ATOM_BROWSER_UI_VIEWS_MENU_BAR_H_
#include "atom/browser/native_window.h"
#include "atom/browser/ui/atom_menu_model.h" #include "atom/browser/ui/atom_menu_model.h"
#include "ui/views/controls/button/menu_button_listener.h" #include "ui/views/controls/button/menu_button_listener.h"
#include "ui/views/view.h" #include "ui/views/view.h"
@ -20,7 +21,7 @@ class MenuDelegate;
class MenuBar : public views::View, class MenuBar : public views::View,
public views::MenuButtonListener { public views::MenuButtonListener {
public: public:
MenuBar(); explicit MenuBar(NativeWindow* window);
virtual ~MenuBar(); virtual ~MenuBar();
// Replaces current menu with a new one. // Replaces current menu with a new one.
@ -66,6 +67,7 @@ class MenuBar : public views::View,
SkColor hover_color_; SkColor hover_color_;
#endif #endif
NativeWindow* window_;
AtomMenuModel* menu_model_; AtomMenuModel* menu_model_;
DISALLOW_COPY_AND_ASSIGN(MenuBar); DISALLOW_COPY_AND_ASSIGN(MenuBar);

View file

@ -52,10 +52,6 @@ SubmenuButton::SubmenuButton(const base::string16& title,
SetHasInkDrop(true); SetHasInkDrop(true);
set_ink_drop_base_color( set_ink_drop_base_color(
color_utils::BlendTowardOppositeLuma(background_color_, 0x61)); color_utils::BlendTowardOppositeLuma(background_color_, 0x61));
set_request_focus_on_press(true);
SetFocusForPlatform();
SetFocusPainter(nullptr);
} }
SubmenuButton::~SubmenuButton() { SubmenuButton::~SubmenuButton() {