| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "ui/views/controls/combobox/combobox.h" | 5 #include "ui/views/controls/combobox/combobox.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/utf_string_conversions.h" | 8 #include "base/utf_string_conversions.h" |
| 9 #include "ui/base/accessibility/accessible_view_state.h" | 9 #include "ui/base/accessibility/accessible_view_state.h" |
| 10 #include "ui/base/keycodes/keyboard_codes.h" | 10 #include "ui/base/keycodes/keyboard_codes.h" |
| 11 #include "ui/base/models/combobox_model.h" | 11 #include "ui/base/models/combobox_model.h" |
| 12 #include "ui/base/resource/resource_bundle.h" | 12 #include "ui/base/resource/resource_bundle.h" |
| 13 #include "ui/views/controls/combobox/combobox_listener.h" | 13 #include "ui/views/controls/combobox/combobox_listener.h" |
| 14 #include "ui/views/controls/native/native_view_host.h" | 14 #include "ui/views/controls/native/native_view_host.h" |
| 15 #include "ui/views/widget/widget.h" | 15 #include "ui/views/widget/widget.h" |
| 16 | 16 |
| 17 namespace views { | 17 namespace views { |
| 18 | 18 |
| 19 // static | 19 // static |
| 20 const char Combobox::kViewClassName[] = "views/Combobox"; | 20 const char Combobox::kViewClassName[] = "views/Combobox"; |
| 21 | 21 |
| 22 //////////////////////////////////////////////////////////////////////////////// | 22 //////////////////////////////////////////////////////////////////////////////// |
| 23 // Combobox, public: | 23 // Combobox, public: |
| 24 | 24 |
| 25 Combobox::Combobox(ui::ComboboxModel* model) | 25 Combobox::Combobox(ui::ComboboxModel* model) |
| 26 : native_wrapper_(NULL), | 26 : native_wrapper_(NULL), |
| 27 model_(model), | 27 model_(model), |
| 28 listener_(NULL), | 28 listener_(NULL), |
| 29 selected_item_(0) { | 29 selected_index_(0) { |
| 30 DCHECK(model); |
| 30 set_focusable(true); | 31 set_focusable(true); |
| 31 } | 32 } |
| 32 | 33 |
| 33 Combobox::~Combobox() { | 34 Combobox::~Combobox() { |
| 34 } | 35 } |
| 35 | 36 |
| 36 // static | 37 // static |
| 37 const gfx::Font& Combobox::GetFont() { | 38 const gfx::Font& Combobox::GetFont() { |
| 38 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 39 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| 39 return rb.GetFont(ui::ResourceBundle::BaseFont); | 40 return rb.GetFont(ui::ResourceBundle::BaseFont); |
| 40 } | 41 } |
| 41 | 42 |
| 42 void Combobox::ModelChanged() { | 43 void Combobox::ModelChanged() { |
| 43 selected_item_ = std::min(0, model_->GetItemCount()); | 44 selected_index_ = std::min(0, model_->GetItemCount()); |
| 44 if (native_wrapper_) | 45 if (native_wrapper_) |
| 45 native_wrapper_->UpdateFromModel(); | 46 native_wrapper_->UpdateFromModel(); |
| 46 PreferredSizeChanged(); | 47 PreferredSizeChanged(); |
| 47 } | 48 } |
| 48 | 49 |
| 49 void Combobox::SetSelectedItem(int index) { | 50 void Combobox::SetSelectedIndex(int index) { |
| 50 selected_item_ = index; | 51 selected_index_ = index; |
| 51 if (native_wrapper_) | 52 if (native_wrapper_) |
| 52 native_wrapper_->UpdateSelectedItem(); | 53 native_wrapper_->UpdateSelectedIndex(); |
| 53 } | 54 } |
| 54 | 55 |
| 55 void Combobox::SelectionChanged() { | 56 void Combobox::SelectionChanged() { |
| 56 int prev_selected_item = selected_item_; | 57 int prev_selected_index = selected_index_; |
| 57 selected_item_ = native_wrapper_->GetSelectedItem(); | 58 selected_index_ = native_wrapper_->GetSelectedIndex(); |
| 58 if (listener_) | 59 if (listener_) |
| 59 listener_->ItemChanged(this, prev_selected_item, selected_item_); | 60 listener_->ItemChanged(this, prev_selected_index, selected_index_); |
| 60 if (GetWidget()) { | 61 if (GetWidget()) { |
| 61 GetWidget()->NotifyAccessibilityEvent( | 62 GetWidget()->NotifyAccessibilityEvent( |
| 62 this, ui::AccessibilityTypes::EVENT_VALUE_CHANGED, false); | 63 this, ui::AccessibilityTypes::EVENT_VALUE_CHANGED, false); |
| 63 } | 64 } |
| 64 } | 65 } |
| 65 | 66 |
| 66 void Combobox::SetAccessibleName(const string16& name) { | 67 void Combobox::SetAccessibleName(const string16& name) { |
| 67 accessible_name_ = name; | 68 accessible_name_ = name; |
| 68 } | 69 } |
| 69 | 70 |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 122 } | 123 } |
| 123 | 124 |
| 124 void Combobox::OnBlur() { | 125 void Combobox::OnBlur() { |
| 125 if (native_wrapper_) | 126 if (native_wrapper_) |
| 126 native_wrapper_->HandleBlur(); | 127 native_wrapper_->HandleBlur(); |
| 127 } | 128 } |
| 128 | 129 |
| 129 void Combobox::GetAccessibleState(ui::AccessibleViewState* state) { | 130 void Combobox::GetAccessibleState(ui::AccessibleViewState* state) { |
| 130 state->role = ui::AccessibilityTypes::ROLE_COMBOBOX; | 131 state->role = ui::AccessibilityTypes::ROLE_COMBOBOX; |
| 131 state->name = accessible_name_; | 132 state->name = accessible_name_; |
| 132 state->value = model_->GetItemAt(selected_item_); | 133 state->value = model_->GetItemAt(selected_index_); |
| 133 state->index = selected_item(); | 134 state->index = selected_index_; |
| 134 state->count = model()->GetItemCount(); | 135 state->count = model()->GetItemCount(); |
| 135 } | 136 } |
| 136 | 137 |
| 137 void Combobox::ViewHierarchyChanged(bool is_add, View* parent, View* child) { | 138 void Combobox::ViewHierarchyChanged(bool is_add, View* parent, View* child) { |
| 138 if (is_add && !native_wrapper_ && GetWidget()) { | 139 if (is_add && !native_wrapper_ && GetWidget()) { |
| 139 // The native wrapper's lifetime will be managed by the view hierarchy after | 140 // The native wrapper's lifetime will be managed by the view hierarchy after |
| 140 // we call AddChildView. | 141 // we call AddChildView. |
| 141 native_wrapper_ = NativeComboboxWrapper::CreateWrapper(this); | 142 native_wrapper_ = NativeComboboxWrapper::CreateWrapper(this); |
| 142 AddChildView(native_wrapper_->GetView()); | 143 AddChildView(native_wrapper_->GetView()); |
| 143 // The underlying native widget may not be created until the wrapper is | 144 // The underlying native widget may not be created until the wrapper is |
| 144 // parented. For this reason the wrapper is only updated after adding its | 145 // parented. For this reason the wrapper is only updated after adding its |
| 145 // view. | 146 // view. |
| 146 native_wrapper_->UpdateFromModel(); | 147 native_wrapper_->UpdateFromModel(); |
| 147 native_wrapper_->UpdateSelectedItem(); | 148 native_wrapper_->UpdateSelectedIndex(); |
| 148 native_wrapper_->UpdateEnabled(); | 149 native_wrapper_->UpdateEnabled(); |
| 149 } | 150 } |
| 150 } | 151 } |
| 151 | 152 |
| 152 std::string Combobox::GetClassName() const { | 153 std::string Combobox::GetClassName() const { |
| 153 return kViewClassName; | 154 return kViewClassName; |
| 154 } | 155 } |
| 155 | 156 |
| 156 } // namespace views | 157 } // namespace views |
| OLD | NEW |