Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3)

Side by Side Diff: ui/views/controls/menu/menu_runner.cc

Issue 59383003: Add the button style for combobox (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: sky's review (5) Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/menu/menu_runner.h" 5 #include "ui/views/controls/menu/menu_runner.h"
6 6
7 #include <set> 7 #include <set>
8 8
9 #include "base/memory/weak_ptr.h" 9 #include "base/memory/weak_ptr.h"
10 #include "ui/base/models/menu_model.h" 10 #include "ui/base/models/menu_model.h"
11 #include "ui/views/controls/button/menu_button.h" 11 #include "ui/views/controls/button/menu_button.h"
12 #include "ui/views/controls/menu/menu_controller.h" 12 #include "ui/views/controls/menu/menu_controller.h"
13 #include "ui/views/controls/menu/menu_controller_delegate.h" 13 #include "ui/views/controls/menu/menu_controller_delegate.h"
14 #include "ui/views/controls/menu/menu_delegate.h" 14 #include "ui/views/controls/menu/menu_delegate.h"
15 #include "ui/views/controls/menu/menu_model_adapter.h" 15 #include "ui/views/controls/menu/menu_model_adapter.h"
16 #include "ui/views/controls/menu/menu_runner_core.h"
16 #include "ui/views/widget/widget.h" 17 #include "ui/views/widget/widget.h"
17 18
18 #if defined(OS_WIN) 19 #if defined(OS_WIN)
19 #include "base/win/win_util.h" 20 #include "base/win/win_util.h"
20 #endif 21 #endif
21 22
22 namespace views { 23 namespace views {
23 24
24 namespace internal { 25 namespace internal {
25 26
(...skipping 258 matching lines...) Expand 10 before | Expand all | Expand 10 after
284 DisplayChangeListener* DisplayChangeListener::Create(Widget* widget, 285 DisplayChangeListener* DisplayChangeListener::Create(Widget* widget,
285 MenuRunner* runner) { 286 MenuRunner* runner) {
286 return NULL; 287 return NULL;
287 } 288 }
288 #endif 289 #endif
289 290
290 } // namespace internal 291 } // namespace internal
291 292
292 MenuRunner::MenuRunner(ui::MenuModel* menu_model) 293 MenuRunner::MenuRunner(ui::MenuModel* menu_model)
293 : menu_model_adapter_(new MenuModelAdapter(menu_model)), 294 : menu_model_adapter_(new MenuModelAdapter(menu_model)),
294 holder_(new internal::MenuRunnerImpl(menu_model_adapter_->CreateMenu())) { 295 holder_(new internal::MenuRunnerImpl(menu_model_adapter_->CreateMenu())),
296 runner_core_(NULL) {
295 } 297 }
296 298
297 MenuRunner::MenuRunner(MenuItemView* menu) 299 MenuRunner::MenuRunner(MenuItemView* menu)
298 : holder_(new internal::MenuRunnerImpl(menu)) { 300 : holder_(new internal::MenuRunnerImpl(menu)),
301 runner_core_(NULL) {
299 } 302 }
300 303
301 MenuRunner::~MenuRunner() { 304 MenuRunner::~MenuRunner() {
302 holder_->Release(); 305 holder_->Release();
303 } 306 }
304 307
305 MenuItemView* MenuRunner::GetMenu() { 308 MenuItemView* MenuRunner::GetMenu() {
306 return holder_->menu(); 309 return holder_->menu();
307 } 310 }
308 311
309 MenuRunner::RunResult MenuRunner::RunMenuAt(Widget* parent, 312 MenuRunner::RunResult MenuRunner::RunMenuAt(Widget* parent,
310 MenuButton* button, 313 MenuButton* button,
311 const gfx::Rect& bounds, 314 const gfx::Rect& bounds,
312 MenuItemView::AnchorPosition anchor, 315 MenuItemView::AnchorPosition anchor,
313 ui::MenuSourceType source_type, 316 ui::MenuSourceType source_type,
314 int32 types) { 317 int32 types) {
318 if (runner_core_) {
319 return runner_core_->RunMenuAt(parent, button, bounds, anchor, source_type,
320 types);
321 }
322
315 // The parent of the nested menu will have created a DisplayChangeListener, so 323 // The parent of the nested menu will have created a DisplayChangeListener, so
316 // we avoid creating a DisplayChangeListener if nested. Drop menus are 324 // we avoid creating a DisplayChangeListener if nested. Drop menus are
317 // transient, so we don't cancel in that case. 325 // transient, so we don't cancel in that case.
318 if ((types & (IS_NESTED | FOR_DROP)) == 0 && parent) { 326 if ((types & (IS_NESTED | FOR_DROP)) == 0 && parent) {
319 display_change_listener_.reset( 327 display_change_listener_.reset(
320 internal::DisplayChangeListener::Create(parent, this)); 328 internal::DisplayChangeListener::Create(parent, this));
321 } 329 }
322 330
323 if (types & CONTEXT_MENU) { 331 if (types & CONTEXT_MENU) {
324 switch (source_type) { 332 switch (source_type) {
(...skipping 20 matching lines...) Expand all
345 353
346 void MenuRunner::Cancel() { 354 void MenuRunner::Cancel() {
347 holder_->Cancel(); 355 holder_->Cancel();
348 } 356 }
349 357
350 base::TimeDelta MenuRunner::closing_event_time() const { 358 base::TimeDelta MenuRunner::closing_event_time() const {
351 return holder_->closing_event_time(); 359 return holder_->closing_event_time();
352 } 360 }
353 361
354 } // namespace views 362 } // namespace views
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698