electron/atom/browser/ui/views/menu_bar.cc

175 lines
5.1 KiB
C++
Raw Normal View History

// Copyright (c) 2014 GitHub, Inc.
2014-07-16 14:10:10 +00:00
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/browser/ui/views/menu_bar.h"
#if defined(USE_X11)
#include "gtk/gtk.h"
#endif
2014-07-17 06:23:28 +00:00
#include "atom/browser/ui/views/menu_delegate.h"
#include "atom/browser/ui/views/submenu_button.h"
2014-07-17 06:23:28 +00:00
#include "ui/base/models/menu_model.h"
#include "ui/views/background.h"
#include "ui/views/layout/box_layout.h"
2014-07-16 14:10:10 +00:00
2014-07-25 07:20:25 +00:00
#if defined(OS_WIN)
#include "ui/gfx/color_utils.h"
#elif defined(USE_X11)
2017-01-26 10:55:19 +00:00
#include "chrome/browser/ui/libgtkui/skia_utils_gtk.h"
2014-07-25 07:20:25 +00:00
#endif
2014-07-16 14:10:10 +00:00
namespace atom {
namespace {
2015-04-14 08:18:57 +00:00
const char kViewClassName[] = "ElectronMenuBar";
2014-07-16 14:10:10 +00:00
// Default color of the menu bar.
const SkColor kDefaultColor = SkColorSetARGB(255, 233, 233, 233);
#if defined(USE_X11)
void GetMenuBarColor(SkColor* enabled, SkColor* disabled, SkColor* highlight,
SkColor* hover, SkColor* background) {
2015-12-07 21:27:05 +00:00
GtkWidget* menu_bar = gtk_menu_bar_new();
2015-12-07 21:27:05 +00:00
GtkStyle* style = gtk_rc_get_style(menu_bar);
2017-01-26 10:55:19 +00:00
*enabled = libgtkui::GdkColorToSkColor(style->fg[GTK_STATE_NORMAL]);
*disabled = libgtkui::GdkColorToSkColor(style->fg[GTK_STATE_INSENSITIVE]);
*highlight = libgtkui::GdkColorToSkColor(style->fg[GTK_STATE_SELECTED]);
*hover = libgtkui::GdkColorToSkColor(style->fg[GTK_STATE_PRELIGHT]);
*background = libgtkui::GdkColorToSkColor(style->bg[GTK_STATE_NORMAL]);
2015-12-07 21:27:05 +00:00
gtk_widget_destroy(menu_bar);
}
#endif
2014-07-16 14:10:10 +00:00
} // namespace
2016-10-24 02:42:15 +00:00
MenuBar::MenuBar(NativeWindow* window)
: background_color_(kDefaultColor),
2016-10-24 02:42:15 +00:00
menu_model_(NULL),
window_(window) {
UpdateMenuBarColor();
2014-07-17 06:23:28 +00:00
SetLayoutManager(new views::BoxLayout(
views::BoxLayout::kHorizontal, 0, 0, 0));
2014-07-16 14:10:10 +00:00
}
MenuBar::~MenuBar() {
}
void MenuBar::SetMenu(AtomMenuModel* model) {
2014-07-17 06:23:28 +00:00
menu_model_ = model;
RemoveAllChildViews(true);
for (int i = 0; i < model->GetItemCount(); ++i) {
2016-10-03 17:26:18 +00:00
SubmenuButton* button = new SubmenuButton(model->GetLabelAt(i),
this,
background_color_);
2014-07-17 06:23:28 +00:00
button->set_tag(i);
#if defined(USE_X11)
2014-09-01 12:10:14 +00:00
button->SetTextColor(views::Button::STATE_NORMAL, enabled_color_);
button->SetTextColor(views::Button::STATE_DISABLED, disabled_color_);
button->SetTextColor(views::Button::STATE_PRESSED, highlight_color_);
button->SetTextColor(views::Button::STATE_HOVERED, hover_color_);
button->SetUnderlineColor(enabled_color_);
#elif defined(OS_WIN)
button->SetUnderlineColor(color_utils::GetSysSkColor(COLOR_GRAYTEXT));
#endif
2014-07-17 06:23:28 +00:00
AddChildView(button);
}
}
void MenuBar::SetAcceleratorVisibility(bool visible) {
for (int i = 0; i < child_count(); ++i)
static_cast<SubmenuButton*>(child_at(i))->SetAcceleratorVisibility(visible);
}
int MenuBar::GetAcceleratorIndex(base::char16 key) {
for (int i = 0; i < child_count(); ++i) {
SubmenuButton* button = static_cast<SubmenuButton*>(child_at(i));
if (button->accelerator() == key)
return i;
}
return -1;
}
void MenuBar::ActivateAccelerator(base::char16 key) {
int i = GetAcceleratorIndex(key);
if (i != -1)
2016-04-30 23:56:28 +00:00
static_cast<SubmenuButton*>(child_at(i))->Activate(nullptr);
}
2014-07-17 06:23:28 +00:00
int MenuBar::GetItemCount() const {
return menu_model_->GetItemCount();
}
bool MenuBar::GetMenuButtonFromScreenPoint(const gfx::Point& point,
AtomMenuModel** menu_model,
2014-07-17 06:23:28 +00:00
views::MenuButton** button) {
gfx::Point location(point);
views::View::ConvertPointFromScreen(this, &location);
if (location.x() < 0 || location.x() >= width() || location.y() < 0 ||
location.y() >= height())
return false;
for (int i = 0; i < child_count(); ++i) {
views::View* view = child_at(i);
if (view->bounds().Contains(location) &&
2017-04-05 08:34:53 +00:00
(menu_model_->GetTypeAt(i) == AtomMenuModel::Type::SUBMENU)) {
2014-07-17 06:23:28 +00:00
*menu_model = menu_model_->GetSubmenuModelAt(i);
*button = static_cast<views::MenuButton*>(view);
return true;
}
}
return false;
2014-07-16 14:10:10 +00:00
}
const char* MenuBar::GetClassName() const {
return kViewClassName;
}
2016-04-30 23:56:28 +00:00
void MenuBar::OnMenuButtonClicked(views::MenuButton* source,
const gfx::Point& point,
const ui::Event* event) {
// Hide the accelerator when a submenu is activated.
SetAcceleratorVisibility(false);
2014-07-17 06:23:28 +00:00
if (!menu_model_)
return;
2016-10-24 02:42:15 +00:00
if (!window_->IsFocused())
window_->Focus(true);
2016-04-30 23:56:28 +00:00
int id = source->tag();
AtomMenuModel::ItemType type = menu_model_->GetTypeAt(id);
2017-04-05 08:34:53 +00:00
if (type != AtomMenuModel::Type::SUBMENU) {
menu_model_->ActivatedAt(id, 0);
2016-01-05 04:05:27 +00:00
return;
}
2016-01-05 04:05:27 +00:00
MenuDelegate menu_delegate(this);
2016-04-30 23:56:28 +00:00
menu_delegate.RunMenu(menu_model_->GetSubmenuModelAt(id), source);
2014-07-17 06:23:28 +00:00
}
void MenuBar::OnNativeThemeChanged(const ui::NativeTheme* theme) {
UpdateMenuBarColor();
}
void MenuBar::UpdateMenuBarColor() {
#if defined(OS_WIN)
background_color_ = color_utils::GetSysSkColor(COLOR_MENUBAR);
#elif defined(USE_X11)
GetMenuBarColor(&enabled_color_, &disabled_color_, &highlight_color_,
&hover_color_, &background_color_);
#endif
set_background(views::Background::CreateSolidBackground(background_color_));
}
2014-07-16 14:10:10 +00:00
} // namespace atom