summaryrefslogtreecommitdiffstats
path: root/views
diff options
context:
space:
mode:
authortfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-25 03:35:45 +0000
committertfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-25 03:35:45 +0000
commit17d36074c141f63997b56317bca04d207efbed3e (patch)
tree2903de772ae3a80e2ee6b005aa7735d1ef2144cd /views
parent4b1e10d42edc03ee1ecea2d408ec63f5f7d804b5 (diff)
downloadchromium_src-17d36074c141f63997b56317bca04d207efbed3e.zip
chromium_src-17d36074c141f63997b56317bca04d207efbed3e.tar.gz
chromium_src-17d36074c141f63997b56317bca04d207efbed3e.tar.bz2
views: Move the implementation of MenuExample to the source file.
BUG=None TEST=run out/Debug/views_examples, everything should works as before. Review URL: http://codereview.chromium.org/6548001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@76025 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'views')
-rw-r--r--views/examples/menu_example.cc220
-rw-r--r--views/examples/menu_example.h189
-rw-r--r--views/views.gyp1
3 files changed, 229 insertions, 181 deletions
diff --git a/views/examples/menu_example.cc b/views/examples/menu_example.cc
new file mode 100644
index 0000000..085324e
--- /dev/null
+++ b/views/examples/menu_example.cc
@@ -0,0 +1,220 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "views/examples/menu_example.h"
+
+#include <set>
+
+#include "base/utf_string_conversions.h"
+#include "ui/base/models/simple_menu_model.h"
+#include "views/controls/button/menu_button.h"
+#include "views/controls/menu/menu_2.h"
+#include "views/controls/menu/view_menu_delegate.h"
+#include "views/controls/button/text_button.h"
+#include "views/layout/fill_layout.h"
+#include "views/view.h"
+
+namespace {
+
+class ExampleMenuModel : public ui::SimpleMenuModel,
+ public ui::SimpleMenuModel::Delegate {
+ public:
+ ExampleMenuModel();
+
+ void RunMenuAt(const gfx::Point& point);
+
+ // Overridden from ui::SimpleMenuModel::Delegate:
+ virtual bool IsCommandIdChecked(int command_id) const OVERRIDE;
+ virtual bool IsCommandIdEnabled(int command_id) const OVERRIDE;
+ virtual bool GetAcceleratorForCommandId(
+ int command_id,
+ ui::Accelerator* accelerator) OVERRIDE;
+ virtual void ExecuteCommand(int command_id) OVERRIDE;
+
+ private:
+ enum {
+ kGroupMakeDecision,
+ };
+
+ enum {
+ kCommandDoSomething,
+ kCommandSelectAscii,
+ kCommandSelectUtf8,
+ kCommandSelectUtf16,
+ kCommandCheckApple,
+ kCommandCheckOrange,
+ kCommandCheckKiwi,
+ kCommandGoHome,
+ };
+
+ scoped_ptr<views::Menu2> menu_;
+ scoped_ptr<ui::SimpleMenuModel> submenu_;
+ std::set<int> checked_fruits_;
+ int current_encoding_command_id_;
+
+ DISALLOW_COPY_AND_ASSIGN(ExampleMenuModel);
+};
+
+class ExampleMenuButton : public views::MenuButton,
+ public views::ViewMenuDelegate {
+ public:
+ ExampleMenuButton(const std::wstring& test, bool show_menu_marker);
+ virtual ~ExampleMenuButton();
+
+ private:
+ // Overridden from views::ViewMenuDelegate:
+ virtual void RunMenu(views::View* source, const gfx::Point& point) OVERRIDE;
+
+ scoped_ptr<ExampleMenuModel> menu_model_;
+ DISALLOW_COPY_AND_ASSIGN(ExampleMenuButton);
+};
+
+// ExampleMenuModel ---------------------------------------------------------
+
+ExampleMenuModel::ExampleMenuModel()
+ : ALLOW_THIS_IN_INITIALIZER_LIST(ui::SimpleMenuModel(this)),
+ current_encoding_command_id_(kCommandSelectAscii) {
+ AddItem(kCommandDoSomething, WideToUTF16(L"Do Something"));
+ AddSeparator();
+ AddRadioItem(kCommandSelectAscii,
+ WideToUTF16(L"ASCII"), kGroupMakeDecision);
+ AddRadioItem(kCommandSelectUtf8,
+ WideToUTF16(L"UTF-8"), kGroupMakeDecision);
+ AddRadioItem(kCommandSelectUtf16,
+ WideToUTF16(L"UTF-16"), kGroupMakeDecision);
+ AddSeparator();
+ AddCheckItem(kCommandCheckApple, WideToUTF16(L"Apple"));
+ AddCheckItem(kCommandCheckOrange, WideToUTF16(L"Orange"));
+ AddCheckItem(kCommandCheckKiwi, WideToUTF16(L"Kiwi"));
+ AddSeparator();
+ AddItem(kCommandGoHome, WideToUTF16(L"Go Home"));
+
+ submenu_.reset(new ui::SimpleMenuModel(this));
+ submenu_->AddItem(kCommandDoSomething, WideToUTF16(L"Do Something 2"));
+ AddSubMenu(-1, ASCIIToUTF16("Submenu"), submenu_.get());
+ menu_.reset(new views::Menu2(this));
+}
+
+void ExampleMenuModel::RunMenuAt(const gfx::Point& point) {
+ menu_->RunMenuAt(point, views::Menu2::ALIGN_TOPRIGHT);
+}
+
+bool ExampleMenuModel::IsCommandIdChecked(int command_id) const {
+ // Radio items.
+ if (command_id == current_encoding_command_id_)
+ return true;
+
+ // Check items.
+ if (checked_fruits_.find(command_id) != checked_fruits_.end())
+ return true;
+
+ return false;
+}
+
+bool ExampleMenuModel::IsCommandIdEnabled(int command_id) const {
+ // All commands are enabled except for kCommandGoHome.
+ return command_id != kCommandGoHome;
+}
+
+bool ExampleMenuModel::GetAcceleratorForCommandId(
+ int command_id,
+ ui::Accelerator* accelerator) {
+ // We don't use this in the example.
+ return false;
+}
+
+void ExampleMenuModel::ExecuteCommand(int command_id) {
+ switch (command_id) {
+ case kCommandDoSomething: {
+ LOG(INFO) << "Done something";
+ break;
+ }
+
+ // Radio items.
+ case kCommandSelectAscii: {
+ current_encoding_command_id_ = kCommandSelectAscii;
+ LOG(INFO) << "Selected ASCII";
+ break;
+ }
+ case kCommandSelectUtf8: {
+ current_encoding_command_id_ = kCommandSelectUtf8;
+ LOG(INFO) << "Selected UTF-8";
+ break;
+ }
+ case kCommandSelectUtf16: {
+ current_encoding_command_id_ = kCommandSelectUtf16;
+ LOG(INFO) << "Selected UTF-16";
+ break;
+ }
+
+ // Check items.
+ case kCommandCheckApple:
+ case kCommandCheckOrange:
+ case kCommandCheckKiwi: {
+ // Print what fruit is checked.
+ const char* checked_fruit = "";
+ if (command_id == kCommandCheckApple) {
+ checked_fruit = "Apple";
+ } else if (command_id == kCommandCheckOrange) {
+ checked_fruit = "Orange";
+ } else if (command_id == kCommandCheckKiwi) {
+ checked_fruit = "Kiwi";
+ }
+ LOG(INFO) << "Checked " << checked_fruit;
+
+ // Update the check status.
+ std::set<int>::iterator iter = checked_fruits_.find(command_id);
+ if (iter == checked_fruits_.end())
+ checked_fruits_.insert(command_id);
+ else
+ checked_fruits_.erase(iter);
+ break;
+ }
+ }
+}
+
+// ExampleMenuButton -----------------------------------------------------------
+
+ExampleMenuButton::ExampleMenuButton(const std::wstring& test,
+ bool show_menu_marker)
+ : ALLOW_THIS_IN_INITIALIZER_LIST(
+ views::MenuButton(NULL, test, this, show_menu_marker)) {
+}
+
+ExampleMenuButton::~ExampleMenuButton() {
+}
+
+void ExampleMenuButton::RunMenu(views::View* source, const gfx::Point& point) {
+ if (menu_model_ == NULL) {
+ menu_model_.reset(new ExampleMenuModel);
+ }
+ menu_model_->RunMenuAt(point);
+}
+
+} // namespace
+
+namespace examples {
+
+MenuExample::MenuExample(ExamplesMain* main)
+ : ExampleBase(main) {
+}
+
+MenuExample::~MenuExample() {
+}
+
+std::wstring MenuExample::GetExampleTitle() {
+ return L"Menu";
+}
+
+void MenuExample::CreateExampleView(views::View* container) {
+ // views::Menu2 is not a sub class of View, hence we cannot directly
+ // add to the continer. Instead, we add a button to open a menu.
+ const bool show_menu_marker = true;
+ ExampleMenuButton* menu_button = new ExampleMenuButton(L"Open a menu",
+ show_menu_marker);
+ container->SetLayoutManager(new views::FillLayout);
+ container->AddChildView(menu_button);
+}
+
+} // namespace examples
diff --git a/views/examples/menu_example.h b/views/examples/menu_example.h
index 8a6b749..26f49fe 100644
--- a/views/examples/menu_example.h
+++ b/views/examples/menu_example.h
@@ -6,196 +6,23 @@
#define VIEWS_EXAMPLES_MENU_EXAMPLE_H_
#pragma once
-#include <set>
+#include <string>
-#include "base/utf_string_conversions.h"
-#include "ui/base/models/simple_menu_model.h"
-#include "views/controls/button/menu_button.h"
-#include "views/controls/menu/menu_2.h"
-#include "views/controls/menu/view_menu_delegate.h"
-#include "views/controls/button/text_button.h"
+#include "base/basictypes.h"
+#include "base/compiler_specific.h"
#include "views/examples/example_base.h"
-#include "views/layout/fill_layout.h"
namespace examples {
-class ExampleMenuContents : public ui::SimpleMenuModel,
- public ui::SimpleMenuModel::Delegate {
- enum {
- kGroupMakeDecision,
- };
-
- enum {
- kCommandDoSomething,
- kCommandSelectAscii,
- kCommandSelectUtf8,
- kCommandSelectUtf16,
- kCommandCheckApple,
- kCommandCheckOrange,
- kCommandCheckKiwi,
- kCommandGoHome,
- };
-
- public:
- ExampleMenuContents() :
- ALLOW_THIS_IN_INITIALIZER_LIST(ui::SimpleMenuModel(this)),
- current_encoding_command_id_(kCommandSelectAscii) {
-
- AddItem(kCommandDoSomething, WideToUTF16(L"Do Something"));
- AddSeparator();
- AddRadioItem(kCommandSelectAscii,
- WideToUTF16(L"ASCII"), kGroupMakeDecision);
- AddRadioItem(kCommandSelectUtf8,
- WideToUTF16(L"UTF-8"), kGroupMakeDecision);
- AddRadioItem(kCommandSelectUtf16,
- WideToUTF16(L"UTF-16"), kGroupMakeDecision);
- AddSeparator();
- AddCheckItem(kCommandCheckApple, WideToUTF16(L"Apple"));
- AddCheckItem(kCommandCheckOrange, WideToUTF16(L"Orange"));
- AddCheckItem(kCommandCheckKiwi, WideToUTF16(L"Kiwi"));
- AddSeparator();
- AddItem(kCommandGoHome, WideToUTF16(L"Go Home"));
-
- submenu_.reset(new ui::SimpleMenuModel(this));
- submenu_->AddItem(kCommandDoSomething, WideToUTF16(L"Do Something 2"));
- AddSubMenu(-1, ASCIIToUTF16("Submenu"), submenu_.get());
- menu_.reset(new views::Menu2(this));
- }
-
- void RunMenuAt(const gfx::Point& point) {
- menu_->RunMenuAt(point, views::Menu2::ALIGN_TOPRIGHT);
- }
-
- // ui::SimpleMenuModel::Delegate implementation.
- virtual bool IsCommandIdChecked(int command_id) const {
- // Radio items.
- if (command_id == current_encoding_command_id_) {
- return true;
- }
-
- // Check items.
- if (checked_fruits_.find(command_id) != checked_fruits_.end()) {
- return true;
- }
- return false;
- }
-
- virtual bool IsCommandIdEnabled(int command_id) const {
- // All commands are enabled except for kCommandGoHome.
- return command_id != kCommandGoHome;
- }
-
- virtual bool GetAcceleratorForCommandId(
- int command_id,
- ui::Accelerator* accelerator) {
- // We don't use this in the example.
- return false;
- }
-
- virtual void ExecuteCommand(int command_id) {
- switch (command_id) {
- case kCommandDoSomething: {
- LOG(INFO) << "Done something";
- break;
- }
-
- // Radio items.
- case kCommandSelectAscii: {
- current_encoding_command_id_ = kCommandSelectAscii;
- LOG(INFO) << "Selected ASCII";
- break;
- }
- case kCommandSelectUtf8: {
- current_encoding_command_id_ = kCommandSelectUtf8;
- LOG(INFO) << "Selected UTF-8";
- break;
- }
- case kCommandSelectUtf16: {
- current_encoding_command_id_ = kCommandSelectUtf16;
- LOG(INFO) << "Selected UTF-16";
- break;
- }
-
- // Check items.
- case kCommandCheckApple:
- case kCommandCheckOrange:
- case kCommandCheckKiwi: {
- // Print what fruit is checked.
- const char* checked_fruit = "";
- if (command_id == kCommandCheckApple) {
- checked_fruit = "Apple";
- } else if (command_id == kCommandCheckOrange) {
- checked_fruit = "Orange";
- } else if (command_id == kCommandCheckKiwi) {
- checked_fruit = "Kiwi";
- }
- LOG(INFO) << "Checked " << checked_fruit;
-
- // Update the check status.
- std::set<int>::iterator iter = checked_fruits_.find(command_id);
- if (iter == checked_fruits_.end()) {
- checked_fruits_.insert(command_id);
- } else {
- checked_fruits_.erase(iter);
- }
- break;
- }
- }
- }
-
- private:
- scoped_ptr<views::Menu2> menu_;
- scoped_ptr<ui::SimpleMenuModel> submenu_;
- std::set<int> checked_fruits_;
- int current_encoding_command_id_;
-
- DISALLOW_COPY_AND_ASSIGN(ExampleMenuContents);
-};
-
-class ExampleMenuButton : public views::MenuButton,
- public views::ViewMenuDelegate {
- public:
- ExampleMenuButton(const std::wstring& test,
- bool show_menu_marker)
- : ALLOW_THIS_IN_INITIALIZER_LIST(
- views::MenuButton(NULL, test, this, show_menu_marker)) {
- }
-
- private:
- // views::ViewMenuDelegate implementation.
- virtual void RunMenu(views::View* source, const gfx::Point& point) {
- if (menu_contents_ == NULL) {
- menu_contents_.reset(new ExampleMenuContents);
- }
- menu_contents_->RunMenuAt(point);
- }
-
- scoped_ptr<ExampleMenuContents> menu_contents_;
- DISALLOW_COPY_AND_ASSIGN(ExampleMenuButton);
-};
-
// MenuExample demonstrates how to use the Menu class.
class MenuExample : public ExampleBase {
public:
- explicit MenuExample(ExamplesMain* main)
- : ExampleBase(main) {
- }
-
- virtual ~MenuExample() {}
-
- virtual std::wstring GetExampleTitle() {
- return L"Menu";
- }
+ explicit MenuExample(ExamplesMain* main);
+ virtual ~MenuExample();
- virtual void CreateExampleView(views::View* container) {
- // views::Menu2 is not a sub class of View, hence we cannot directly
- // add to the continer. Instead, we add a button to open a menu.
- const bool show_menu_marker = true;
- ExampleMenuButton* menu_button = new ExampleMenuButton(
- L"Open a menu", show_menu_marker);
- container->SetLayoutManager(new views::FillLayout);
- container->AddChildView(menu_button);
- }
+ // Overridden from ExampleBase:
+ virtual std::wstring GetExampleTitle() OVERRIDE;
+ virtual void CreateExampleView(views::View* container) OVERRIDE;
private:
DISALLOW_COPY_AND_ASSIGN(MenuExample);
diff --git a/views/views.gyp b/views/views.gyp
index 6611d6e..abe63ca 100644
--- a/views/views.gyp
+++ b/views/views.gyp
@@ -550,6 +550,7 @@
'examples/examples_main.h',
'examples/message_box_example.cc',
'examples/message_box_example.h',
+ 'examples/menu_example.cc',
'examples/menu_example.h',
'examples/radio_button_example.cc',
'examples/radio_button_example.h',