OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "ash/system/ime_menu/ime_menu_tray.h" | 5 #include "ash/system/ime_menu/ime_menu_tray.h" |
6 | 6 |
7 #include "ash/accessibility_delegate.h" | 7 #include "ash/accessibility_delegate.h" |
8 #include "ash/ash_constants.h" | 8 #include "ash/ash_constants.h" |
9 #include "ash/public/cpp/shell_window_ids.h" | |
10 #include "ash/resources/grit/ash_resources.h" | 9 #include "ash/resources/grit/ash_resources.h" |
11 #include "ash/root_window_controller.h" | 10 #include "ash/root_window_controller.h" |
12 #include "ash/session/session_controller.h" | 11 #include "ash/session/session_controller.h" |
13 #include "ash/shelf/shelf.h" | 12 #include "ash/shelf/shelf.h" |
14 #include "ash/shell.h" | 13 #include "ash/shell.h" |
15 #include "ash/shell_port.h" | 14 #include "ash/shell_port.h" |
16 #include "ash/strings/grit/ash_strings.h" | 15 #include "ash/strings/grit/ash_strings.h" |
17 #include "ash/system/ime_menu/ime_list_view.h" | 16 #include "ash/system/ime_menu/ime_list_view.h" |
18 #include "ash/system/tray/system_menu_button.h" | 17 #include "ash/system/tray/system_menu_button.h" |
19 #include "ash/system/tray/system_tray_controller.h" | 18 #include "ash/system/tray/system_tray_controller.h" |
(...skipping 296 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
316 show_bubble_after_keyboard_hidden_ = true; | 315 show_bubble_after_keyboard_hidden_ = true; |
317 keyboard_controller->AddObserver(this); | 316 keyboard_controller->AddObserver(this); |
318 keyboard_controller->HideKeyboard( | 317 keyboard_controller->HideKeyboard( |
319 keyboard::KeyboardController::HIDE_REASON_AUTOMATIC); | 318 keyboard::KeyboardController::HIDE_REASON_AUTOMATIC); |
320 } else { | 319 } else { |
321 ShowImeMenuBubbleInternal(); | 320 ShowImeMenuBubbleInternal(); |
322 } | 321 } |
323 } | 322 } |
324 | 323 |
325 void ImeMenuTray::ShowImeMenuBubbleInternal() { | 324 void ImeMenuTray::ShowImeMenuBubbleInternal() { |
326 views::TrayBubbleView::InitParams init_params( | 325 views::TrayBubbleView::InitParams init_params; |
327 GetAnchorAlignment(), kTrayMenuMinimumWidth, kTrayMenuMinimumWidth); | 326 init_params.delegate = this; |
| 327 init_params.parent_window = GetBubbleWindowContainer(); |
| 328 init_params.anchor_view = GetBubbleAnchor(); |
| 329 init_params.anchor_alignment = GetAnchorAlignment(); |
| 330 init_params.min_width = kTrayMenuMinimumWidth; |
| 331 init_params.max_width = kTrayMenuMinimumWidth; |
328 init_params.can_activate = true; | 332 init_params.can_activate = true; |
329 init_params.close_on_deactivate = true; | 333 init_params.close_on_deactivate = true; |
330 | 334 |
331 views::TrayBubbleView* bubble_view = | 335 views::TrayBubbleView* bubble_view = new views::TrayBubbleView(init_params); |
332 views::TrayBubbleView::Create(GetBubbleAnchor(), this, &init_params); | |
333 bubble_view->set_anchor_view_insets(GetBubbleAnchorInsets()); | 336 bubble_view->set_anchor_view_insets(GetBubbleAnchorInsets()); |
334 | 337 |
335 // Add a title item with a separator on the top of the IME menu. | 338 // Add a title item with a separator on the top of the IME menu. |
336 bubble_view->AddChildView( | 339 bubble_view->AddChildView( |
337 new ImeTitleView(!ShouldShowEmojiHandwritingVoiceButtons())); | 340 new ImeTitleView(!ShouldShowEmojiHandwritingVoiceButtons())); |
338 | 341 |
339 // Adds IME list to the bubble. | 342 // Adds IME list to the bubble. |
340 ime_list_view_ = new ImeMenuListView(nullptr); | 343 ime_list_view_ = new ImeMenuListView(nullptr); |
341 ime_list_view_->Init(ShouldShowKeyboardToggle(), | 344 ime_list_view_->Init(ShouldShowKeyboardToggle(), |
342 ImeListView::SHOW_SINGLE_IME); | 345 ImeListView::SHOW_SINGLE_IME); |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
464 } | 467 } |
465 | 468 |
466 void ImeMenuTray::OnMouseEnteredView() {} | 469 void ImeMenuTray::OnMouseEnteredView() {} |
467 | 470 |
468 void ImeMenuTray::OnMouseExitedView() {} | 471 void ImeMenuTray::OnMouseExitedView() {} |
469 | 472 |
470 base::string16 ImeMenuTray::GetAccessibleNameForBubble() { | 473 base::string16 ImeMenuTray::GetAccessibleNameForBubble() { |
471 return l10n_util::GetStringUTF16(IDS_ASH_IME_MENU_ACCESSIBLE_NAME); | 474 return l10n_util::GetStringUTF16(IDS_ASH_IME_MENU_ACCESSIBLE_NAME); |
472 } | 475 } |
473 | 476 |
474 void ImeMenuTray::OnBeforeBubbleWidgetInit( | |
475 views::Widget* anchor_widget, | |
476 views::Widget* bubble_widget, | |
477 views::Widget::InitParams* params) const { | |
478 // Place the bubble in the same root window as |anchor_widget|. | |
479 RootWindowController::ForWindow(anchor_widget->GetNativeWindow()) | |
480 ->ConfigureWidgetInitParamsForContainer( | |
481 bubble_widget, kShellWindowId_SettingBubbleContainer, params); | |
482 } | |
483 | |
484 void ImeMenuTray::HideBubble(const views::TrayBubbleView* bubble_view) { | 477 void ImeMenuTray::HideBubble(const views::TrayBubbleView* bubble_view) { |
485 HideBubbleWithView(bubble_view); | 478 HideBubbleWithView(bubble_view); |
486 } | 479 } |
487 | 480 |
488 void ImeMenuTray::OnKeyboardBoundsChanging(const gfx::Rect& new_bounds) {} | 481 void ImeMenuTray::OnKeyboardBoundsChanging(const gfx::Rect& new_bounds) {} |
489 | 482 |
490 void ImeMenuTray::OnKeyboardClosed() { | 483 void ImeMenuTray::OnKeyboardClosed() { |
491 if (InputMethodManager::Get()) | 484 if (InputMethodManager::Get()) |
492 InputMethodManager::Get()->OverrideKeyboardUrlRef(std::string()); | 485 InputMethodManager::Get()->OverrideKeyboardUrlRef(std::string()); |
493 keyboard::KeyboardController* keyboard_controller = | 486 keyboard::KeyboardController* keyboard_controller = |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
551 else | 544 else |
552 label_->SetText(current_ime_.short_name); | 545 label_->SetText(current_ime_.short_name); |
553 } | 546 } |
554 | 547 |
555 void ImeMenuTray::DisableVirtualKeyboard() { | 548 void ImeMenuTray::DisableVirtualKeyboard() { |
556 Shell::Get()->accessibility_delegate()->SetVirtualKeyboardEnabled(false); | 549 Shell::Get()->accessibility_delegate()->SetVirtualKeyboardEnabled(false); |
557 force_show_keyboard_ = false; | 550 force_show_keyboard_ = false; |
558 } | 551 } |
559 | 552 |
560 } // namespace ash | 553 } // namespace ash |
OLD | NEW |