OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "views/controls/menu/native_menu_gtk.h" | 5 #include "views/controls/menu/native_menu_gtk.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <map> | 8 #include <map> |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "base/i18n/rtl.h" | 12 #include "base/i18n/rtl.h" |
13 #include "base/message_loop.h" | 13 #include "base/message_loop.h" |
14 #include "base/time.h" | 14 #include "base/time.h" |
15 #include "base/utf_string_conversions.h" | 15 #include "base/utf_string_conversions.h" |
16 #include "third_party/skia/include/core/SkBitmap.h" | 16 #include "third_party/skia/include/core/SkBitmap.h" |
17 #include "ui/base/keycodes/keyboard_code_conversion_gtk.h" | 17 #include "ui/base/keycodes/keyboard_code_conversion_gtk.h" |
18 #include "ui/base/keycodes/keyboard_codes.h" | 18 #include "ui/base/keycodes/keyboard_codes.h" |
| 19 #include "ui/base/models/accelerator.h" |
19 #include "ui/base/models/menu_model.h" | 20 #include "ui/base/models/menu_model.h" |
20 #include "ui/gfx/font.h" | 21 #include "ui/gfx/font.h" |
21 #include "ui/gfx/gtk_util.h" | 22 #include "ui/gfx/gtk_util.h" |
22 #include "views/accelerator.h" | |
23 #include "views/controls/menu/menu_2.h" | 23 #include "views/controls/menu/menu_2.h" |
24 #include "views/controls/menu/menu_listener.h" | 24 #include "views/controls/menu/menu_listener.h" |
25 #include "views/controls/menu/nested_dispatcher_gtk.h" | 25 #include "views/controls/menu/nested_dispatcher_gtk.h" |
26 #include "views/views_delegate.h" | 26 #include "views/views_delegate.h" |
27 #include "views/widget/native_widget_gtk.h" | 27 #include "views/widget/native_widget_gtk.h" |
28 | 28 |
29 namespace { | 29 namespace { |
30 | 30 |
31 const char kPositionString[] = "position"; | 31 const char kPositionString[] = "position"; |
32 const char kAccelGroupString[] = "accel_group"; | 32 const char kAccelGroupString[] = "accel_group"; |
(...skipping 380 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
413 if (type == ui::MenuModel::TYPE_SUBMENU) { | 413 if (type == ui::MenuModel::TYPE_SUBMENU) { |
414 Menu2* submenu = new Menu2(model_->GetSubmenuModelAt(index)); | 414 Menu2* submenu = new Menu2(model_->GetSubmenuModelAt(index)); |
415 static_cast<NativeMenuGtk*>(submenu->wrapper_.get())->set_parent(this); | 415 static_cast<NativeMenuGtk*>(submenu->wrapper_.get())->set_parent(this); |
416 g_object_set_data(G_OBJECT(menu_item), "submenu", submenu); | 416 g_object_set_data(G_OBJECT(menu_item), "submenu", submenu); |
417 gtk_menu_item_set_submenu(GTK_MENU_ITEM(menu_item), | 417 gtk_menu_item_set_submenu(GTK_MENU_ITEM(menu_item), |
418 submenu->GetNativeMenu()); | 418 submenu->GetNativeMenu()); |
419 g_signal_connect(submenu->GetNativeMenu(), "move-current", | 419 g_signal_connect(submenu->GetNativeMenu(), "move-current", |
420 G_CALLBACK(OnMenuMoveCurrentThunk), this); | 420 G_CALLBACK(OnMenuMoveCurrentThunk), this); |
421 } | 421 } |
422 | 422 |
423 views::Accelerator accelerator(ui::VKEY_UNKNOWN, false, false, false); | 423 ui::Accelerator accelerator(ui::VKEY_UNKNOWN, false, false, false); |
424 if (accel_group && model_->GetAcceleratorAt(index, &accelerator)) { | 424 if (accel_group && model_->GetAcceleratorAt(index, &accelerator)) { |
425 int gdk_modifiers = 0; | 425 int gdk_modifiers = 0; |
426 if (accelerator.IsShiftDown()) | 426 if (accelerator.IsShiftDown()) |
427 gdk_modifiers |= GDK_SHIFT_MASK; | 427 gdk_modifiers |= GDK_SHIFT_MASK; |
428 if (accelerator.IsCtrlDown()) | 428 if (accelerator.IsCtrlDown()) |
429 gdk_modifiers |= GDK_CONTROL_MASK; | 429 gdk_modifiers |= GDK_CONTROL_MASK; |
430 if (accelerator.IsAltDown()) | 430 if (accelerator.IsAltDown()) |
431 gdk_modifiers |= GDK_MOD1_MASK; | 431 gdk_modifiers |= GDK_MOD1_MASK; |
432 gtk_widget_add_accelerator(menu_item, "activate", accel_group, | 432 gtk_widget_add_accelerator(menu_item, "activate", accel_group, |
433 ui::GdkKeyCodeForWindowsKeyCode(accelerator.key_code(), false), | 433 ui::GdkKeyCodeForWindowsKeyCode(accelerator.key_code(), false), |
(...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
619 | 619 |
620 //////////////////////////////////////////////////////////////////////////////// | 620 //////////////////////////////////////////////////////////////////////////////// |
621 // MenuWrapper, public: | 621 // MenuWrapper, public: |
622 | 622 |
623 // static | 623 // static |
624 MenuWrapper* MenuWrapper::CreateWrapper(Menu2* menu) { | 624 MenuWrapper* MenuWrapper::CreateWrapper(Menu2* menu) { |
625 return new NativeMenuGtk(menu); | 625 return new NativeMenuGtk(menu); |
626 } | 626 } |
627 | 627 |
628 } // namespace views | 628 } // namespace views |
OLD | NEW |