summaryrefslogtreecommitdiffstats
path: root/app/menus
diff options
context:
space:
mode:
authorerg@chromium.org <erg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-25 17:26:18 +0000
committererg@chromium.org <erg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-25 17:26:18 +0000
commit564a9026f2f0c9baf0c12b6e72a959ffc8beb985 (patch)
treef51454a79ae8aee7f0d6edc29b40ff95fa148964 /app/menus
parent49857a356c68f5915ed73452cfc162c18576fedd (diff)
downloadchromium_src-564a9026f2f0c9baf0c12b6e72a959ffc8beb985.zip
chromium_src-564a9026f2f0c9baf0c12b6e72a959ffc8beb985.tar.gz
chromium_src-564a9026f2f0c9baf0c12b6e72a959ffc8beb985.tar.bz2
GTK: First draft of the unified cut/copy/paste and +/-/Fullscreen menu items.
Adds special menu item types that allow shoving buttons into them, along with tracking which button is selected. We now are halfway to the mocks that the chrome-ui-leads sent out. BUG=45757 TEST=none Review URL: http://codereview.chromium.org/2800015 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@50859 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'app/menus')
-rw-r--r--app/menus/button_menu_item_model.cc65
-rw-r--r--app/menus/button_menu_item_model.h103
-rw-r--r--app/menus/menu_model.h5
-rw-r--r--app/menus/simple_menu_model.cc33
-rw-r--r--app/menus/simple_menu_model.h7
5 files changed, 203 insertions, 10 deletions
diff --git a/app/menus/button_menu_item_model.cc b/app/menus/button_menu_item_model.cc
new file mode 100644
index 0000000..c5064fb
--- /dev/null
+++ b/app/menus/button_menu_item_model.cc
@@ -0,0 +1,65 @@
+// Copyright (c) 2010 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 "app/menus/button_menu_item_model.h"
+
+#include "app/l10n_util.h"
+
+namespace menus {
+
+ButtonMenuItemModel::ButtonMenuItemModel(
+ int string_id,
+ ButtonMenuItemModel::Delegate* delegate)
+ : item_label_(l10n_util::GetStringUTF16(string_id)),
+ delegate_(delegate) {
+}
+
+void ButtonMenuItemModel::AddItemWithStringId(int command_id, int string_id) {
+ Item item = { command_id, TYPE_BUTTON, l10n_util::GetStringUTF16(string_id),
+ SIDE_BOTH, -1 };
+ items_.push_back(item);
+}
+
+void ButtonMenuItemModel::AddItemWithImage(int command_id,
+ int icon_idr) {
+ Item item = { command_id, TYPE_BUTTON, string16(), SIDE_BOTH, icon_idr };
+ items_.push_back(item);
+}
+
+void ButtonMenuItemModel::AddSpace() {
+ Item item = { 0, TYPE_SPACE, string16(), SIDE_NONE, -1 };
+ items_.push_back(item);
+}
+
+int ButtonMenuItemModel::GetItemCount() const {
+ return static_cast<int>(items_.size());
+}
+
+ButtonMenuItemModel::ButtonType ButtonMenuItemModel::GetTypeAt(
+ int index) const {
+ return items_[index].type;
+}
+
+int ButtonMenuItemModel::GetCommandIdAt(int index) const {
+ return items_[index].command_id;
+}
+
+const string16& ButtonMenuItemModel::GetLabelAt(int index) const {
+ return items_[index].label;
+}
+
+bool ButtonMenuItemModel::GetIconAt(int index, int* icon_idr) const {
+ if (items_[index].icon_idr == -1)
+ return false;
+
+ *icon_idr = items_[index].icon_idr;
+ return true;
+}
+
+void ButtonMenuItemModel::ActivatedCommand(int command_id) {
+ if (delegate_)
+ delegate_->ExecuteCommand(command_id);
+}
+
+} // namespace menus
diff --git a/app/menus/button_menu_item_model.h b/app/menus/button_menu_item_model.h
new file mode 100644
index 0000000..b8418d1
--- /dev/null
+++ b/app/menus/button_menu_item_model.h
@@ -0,0 +1,103 @@
+// Copyright (c) 2010 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.
+
+#ifndef APP_MENUS_BUTTON_MENU_ITEM_MODEL_H_
+#define APP_MENUS_BUTTON_MENU_ITEM_MODEL_H_
+
+#include <vector>
+
+#include "base/string16.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+
+namespace menus {
+
+// A model representing the rows of buttons that should be inserted in a button
+// containing menu item.
+//
+// TODO(erg): There are still two major pieces missing from this model. It
+// needs to be able to group buttons together so they all have the same
+// width. ButtonSides needs to be used to communicate how buttons are squashed
+// together.
+class ButtonMenuItemModel {
+ public:
+ // Types of buttons.
+ enum ButtonType {
+ TYPE_SPACE,
+ TYPE_BUTTON
+ };
+
+ // Which sides of the button are visible.
+ enum ButtonSides {
+ SIDE_NONE = 0,
+ SIDE_LEFT = 1 << 0,
+ SIDE_RIGHT = 1 << 1,
+ SIDE_BOTH = SIDE_LEFT | SIDE_RIGHT
+ };
+
+ class Delegate {
+ public:
+ // Some command ids have labels that change over time.
+ virtual bool IsLabelForCommandIdDynamic(int command_id) const {
+ return false;
+ }
+ virtual string16 GetLabelForCommandId(int command_id) const {
+ return string16();
+ }
+
+ // Performs the action associated with the specified command id.
+ virtual void ExecuteCommand(int command_id) = 0;
+ };
+
+ ButtonMenuItemModel(int string_id, ButtonMenuItemModel::Delegate* delegate);
+
+ // Adds a button that will emit |command_id|.
+ void AddItemWithStringId(int command_id, int string_id);
+
+ // Adds a button that has an icon instead of a label.
+ void AddItemWithImage(int command_id, int icon_idr);
+
+ // Adds a small horizontal space.
+ void AddSpace();
+
+ // Returns the number of items for iteration.
+ int GetItemCount() const;
+
+ // Returns what kind of item is at |index|.
+ ButtonType GetTypeAt(int index) const;
+
+ // Changes a position into a command ID.
+ int GetCommandIdAt(int index) const;
+
+ const string16& GetLabelAt(int index) const;
+
+ // If the button at |index| should have an icon instead, returns true and
+ // sets the IDR |icon|.
+ bool GetIconAt(int index, int* icon) const;
+
+ // Called from implementations.
+ void ActivatedCommand(int command_id);
+
+ const string16& label() const { return item_label_; }
+
+ private:
+ // The non-clickable label to the left of the buttons.
+ string16 item_label_;
+
+ struct Item {
+ int command_id;
+ ButtonType type;
+ string16 label;
+ int sides;
+ int icon_idr;
+ };
+ std::vector<Item> items_;
+
+ Delegate* delegate_;
+
+ DISALLOW_COPY_AND_ASSIGN(ButtonMenuItemModel);
+};
+
+} // namespace menus
+
+#endif // APP_MENUS_BUTTON_MENU_ITEM_MODEL_H_
diff --git a/app/menus/menu_model.h b/app/menus/menu_model.h
index 50f2e54..f14c8b5 100644
--- a/app/menus/menu_model.h
+++ b/app/menus/menu_model.h
@@ -20,6 +20,7 @@ class Font;
namespace menus {
class Accelerator;
+class ButtonMenuItemModel;
// An interface implemented by an object that provides the content of a menu.
class MenuModel {
@@ -32,6 +33,7 @@ class MenuModel {
TYPE_CHECK,
TYPE_RADIO,
TYPE_SEPARATOR,
+ TYPE_BUTTON_ITEM,
TYPE_SUBMENU
};
@@ -85,6 +87,9 @@ class MenuModel {
// is an icon, false otherwise.
virtual bool GetIconAt(int index, SkBitmap* icon) const = 0;
+ // Returns the model for a menu item with a line of buttons at |index|.
+ virtual ButtonMenuItemModel* GetButtonMenuItemAt(int index) const = 0;
+
// Returns the enabled state of the item at the specified index.
virtual bool IsEnabledAt(int index) const = 0;
diff --git a/app/menus/simple_menu_model.cc b/app/menus/simple_menu_model.cc
index 8631666..3e51986 100644
--- a/app/menus/simple_menu_model.cc
+++ b/app/menus/simple_menu_model.cc
@@ -20,7 +20,7 @@ SimpleMenuModel::~SimpleMenuModel() {
}
void SimpleMenuModel::AddItem(int command_id, const string16& label) {
- Item item = { command_id, label, SkBitmap(), TYPE_COMMAND, -1, NULL };
+ Item item = { command_id, label, SkBitmap(), TYPE_COMMAND, -1, NULL, NULL };
AppendItem(item);
}
@@ -30,7 +30,7 @@ void SimpleMenuModel::AddItemWithStringId(int command_id, int string_id) {
void SimpleMenuModel::AddSeparator() {
Item item = { kSeparatorId, string16(), SkBitmap(), TYPE_SEPARATOR, -1,
- NULL };
+ NULL, NULL };
AppendItem(item);
}
@@ -45,7 +45,8 @@ void SimpleMenuModel::AddCheckItemWithStringId(int command_id, int string_id) {
void SimpleMenuModel::AddRadioItem(int command_id, const string16& label,
int group_id) {
- Item item = { command_id, label, SkBitmap(), TYPE_RADIO, group_id, NULL };
+ Item item = { command_id, label, SkBitmap(), TYPE_RADIO, group_id, NULL,
+ NULL };
AppendItem(item);
}
@@ -54,9 +55,15 @@ void SimpleMenuModel::AddRadioItemWithStringId(int command_id, int string_id,
AddRadioItem(command_id, l10n_util::GetStringUTF16(string_id), group_id);
}
+void SimpleMenuModel::AddButtonItem(int command_id,
+ ButtonMenuItemModel* model) {
+ Item item = { 0, string16(), SkBitmap(), TYPE_BUTTON_ITEM, -1, NULL, model };
+ AppendItem(item);
+}
+
void SimpleMenuModel::AddSubMenu(int command_id, const string16& label,
MenuModel* model) {
- Item item = { command_id, label, SkBitmap(), TYPE_SUBMENU, -1, model };
+ Item item = { command_id, label, SkBitmap(), TYPE_SUBMENU, -1, model, NULL };
AppendItem(item);
}
@@ -67,7 +74,7 @@ void SimpleMenuModel::AddSubMenuWithStringId(int command_id,
void SimpleMenuModel::InsertItemAt(
int index, int command_id, const string16& label) {
- Item item = { command_id, label, SkBitmap(), TYPE_COMMAND, -1, NULL };
+ Item item = { command_id, label, SkBitmap(), TYPE_COMMAND, -1, NULL, NULL };
InsertItemAtIndex(item, index);
}
@@ -78,13 +85,13 @@ void SimpleMenuModel::InsertItemWithStringIdAt(
void SimpleMenuModel::InsertSeparatorAt(int index) {
Item item = { kSeparatorId, string16(), SkBitmap(), TYPE_SEPARATOR, -1,
- NULL };
+ NULL, NULL };
InsertItemAtIndex(item, index);
}
void SimpleMenuModel::InsertCheckItemAt(
int index, int command_id, const string16& label) {
- Item item = { command_id, label, SkBitmap(), TYPE_CHECK, -1, NULL };
+ Item item = { command_id, label, SkBitmap(), TYPE_CHECK, -1, NULL, NULL };
InsertItemAtIndex(item, index);
}
@@ -96,7 +103,8 @@ void SimpleMenuModel::InsertCheckItemWithStringIdAt(
void SimpleMenuModel::InsertRadioItemAt(
int index, int command_id, const string16& label, int group_id) {
- Item item = { command_id, label, SkBitmap(), TYPE_RADIO, group_id, NULL };
+ Item item = { command_id, label, SkBitmap(), TYPE_RADIO, group_id, NULL,
+ NULL };
InsertItemAtIndex(item, index);
}
@@ -108,7 +116,7 @@ void SimpleMenuModel::InsertRadioItemWithStringIdAt(
void SimpleMenuModel::InsertSubMenuAt(
int index, int command_id, const string16& label, MenuModel* model) {
- Item item = { command_id, label, SkBitmap(), TYPE_SUBMENU, -1, model };
+ Item item = { command_id, label, SkBitmap(), TYPE_SUBMENU, -1, model, NULL };
InsertItemAtIndex(item, index);
}
@@ -199,9 +207,14 @@ bool SimpleMenuModel::GetIconAt(int index, SkBitmap* icon) const {
return true;
}
+ButtonMenuItemModel* SimpleMenuModel::GetButtonMenuItemAt(int index) const {
+ return items_.at(FlipIndex(index)).button_model;
+}
+
bool SimpleMenuModel::IsEnabledAt(int index) const {
int command_id = GetCommandIdAt(index);
- if (!delegate_ || command_id == kSeparatorId)
+ if (!delegate_ || command_id == kSeparatorId ||
+ items_.at(FlipIndex(index)).button_model)
return true;
return delegate_->IsCommandIdEnabled(command_id);
}
diff --git a/app/menus/simple_menu_model.h b/app/menus/simple_menu_model.h
index 8dd6c64..79b2f8a 100644
--- a/app/menus/simple_menu_model.h
+++ b/app/menus/simple_menu_model.h
@@ -8,6 +8,7 @@
#include <vector>
#include "base/string16.h"
+#include "app/menus/button_menu_item_model.h"
#include "app/menus/menu_model.h"
#include "third_party/skia/include/core/SkBitmap.h"
@@ -60,6 +61,10 @@ class SimpleMenuModel : public MenuModel {
void AddCheckItemWithStringId(int command_id, int string_id);
void AddRadioItem(int command_id, const string16& label, int group_id);
void AddRadioItemWithStringId(int command_id, int string_id, int group_id);
+
+ // These three methods take pointers to various sub-models. These models
+ // should be owned by the same owner of this SimpleMenuModel.
+ void AddButtonItem(int command_id, ButtonMenuItemModel* model);
void AddSubMenu(int command_id, const string16& label, MenuModel* model);
void AddSubMenuWithStringId(int command_id, int string_id, MenuModel* model);
@@ -102,6 +107,7 @@ class SimpleMenuModel : public MenuModel {
virtual bool IsItemCheckedAt(int index) const;
virtual int GetGroupIdAt(int index) const;
virtual bool GetIconAt(int index, SkBitmap* icon) const;
+ virtual ButtonMenuItemModel* GetButtonMenuItemAt(int index) const;
virtual bool IsEnabledAt(int index) const;
virtual void HighlightChangedTo(int index);
virtual void ActivatedAt(int index);
@@ -125,6 +131,7 @@ class SimpleMenuModel : public MenuModel {
ItemType type;
int group_id;
MenuModel* submenu;
+ ButtonMenuItemModel* button_model;
};
std::vector<Item> items_;