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 "ash/wm/app_list_controller.h" | 5 #include "ash/wm/app_list_controller.h" |
6 | 6 |
7 #include "ash/ash_switches.h" | 7 #include "ash/ash_switches.h" |
8 #include "ash/root_window_controller.h" | 8 #include "ash/root_window_controller.h" |
9 #include "ash/screen_ash.h" | 9 #include "ash/screen_util.h" |
10 #include "ash/shelf/shelf.h" | 10 #include "ash/shelf/shelf.h" |
11 #include "ash/shelf/shelf_layout_manager.h" | 11 #include "ash/shelf/shelf_layout_manager.h" |
12 #include "ash/shell.h" | 12 #include "ash/shell.h" |
13 #include "ash/shell_delegate.h" | 13 #include "ash/shell_delegate.h" |
14 #include "ash/shell_window_ids.h" | 14 #include "ash/shell_window_ids.h" |
15 #include "base/command_line.h" | 15 #include "base/command_line.h" |
16 #include "ui/app_list/app_list_constants.h" | 16 #include "ui/app_list/app_list_constants.h" |
17 #include "ui/app_list/pagination_model.h" | 17 #include "ui/app_list/pagination_model.h" |
18 #include "ui/app_list/views/app_list_view.h" | 18 #include "ui/app_list/views/app_list_view.h" |
19 #include "ui/aura/client/focus_client.h" | 19 #include "ui/aura/client/focus_client.h" |
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 // will be released with AppListView on close. | 163 // will be released with AppListView on close. |
164 app_list::AppListView* view = new app_list::AppListView( | 164 app_list::AppListView* view = new app_list::AppListView( |
165 Shell::GetInstance()->delegate()->CreateAppListViewDelegate()); | 165 Shell::GetInstance()->delegate()->CreateAppListViewDelegate()); |
166 aura::Window* root_window = window->GetRootWindow(); | 166 aura::Window* root_window = window->GetRootWindow(); |
167 aura::Window* container = GetRootWindowController(root_window)-> | 167 aura::Window* container = GetRootWindowController(root_window)-> |
168 GetContainer(kShellWindowId_AppListContainer); | 168 GetContainer(kShellWindowId_AppListContainer); |
169 if (ash::switches::UseAlternateShelfLayout()) { | 169 if (ash::switches::UseAlternateShelfLayout()) { |
170 gfx::Rect applist_button_bounds = Shelf::ForWindow(container)-> | 170 gfx::Rect applist_button_bounds = Shelf::ForWindow(container)-> |
171 GetAppListButtonView()->GetBoundsInScreen(); | 171 GetAppListButtonView()->GetBoundsInScreen(); |
172 // We need the location of the button within the local screen. | 172 // We need the location of the button within the local screen. |
173 applist_button_bounds = ash::ScreenAsh::ConvertRectFromScreen( | 173 applist_button_bounds = ScreenUtil::ConvertRectFromScreen( |
174 root_window, | 174 root_window, |
175 applist_button_bounds); | 175 applist_button_bounds); |
176 view->InitAsBubbleAttachedToAnchor( | 176 view->InitAsBubbleAttachedToAnchor( |
177 container, | 177 container, |
178 pagination_model_.get(), | 178 pagination_model_.get(), |
179 Shelf::ForWindow(container)->GetAppListButtonView(), | 179 Shelf::ForWindow(container)->GetAppListButtonView(), |
180 GetAnchorPositionOffsetToShelf(applist_button_bounds, | 180 GetAnchorPositionOffsetToShelf(applist_button_bounds, |
181 Shelf::ForWindow(container)->GetAppListButtonView()-> | 181 Shelf::ForWindow(container)->GetAppListButtonView()-> |
182 GetWidget()), | 182 GetWidget()), |
183 GetBubbleArrow(container), | 183 GetBubbleArrow(container), |
184 true /* border_accepts_events */); | 184 true /* border_accepts_events */); |
185 view->SetArrowPaintType(views::BubbleBorder::PAINT_NONE); | 185 view->SetArrowPaintType(views::BubbleBorder::PAINT_NONE); |
186 } else { | 186 } else { |
187 view->InitAsBubbleAttachedToAnchor( | 187 view->InitAsBubbleAttachedToAnchor( |
188 container, | 188 container, |
189 pagination_model_.get(), | 189 pagination_model_.get(), |
190 Shelf::ForWindow(container)->GetAppListButtonView(), | 190 Shelf::ForWindow(container)->GetAppListButtonView(), |
191 gfx::Vector2d(), | 191 gfx::Vector2d(), |
192 GetBubbleArrow(container), | 192 GetBubbleArrow(container), |
193 true /* border_accepts_events */); | 193 true /* border_accepts_events */); |
194 } | 194 } |
195 SetView(view); | 195 SetView(view); |
196 // By setting us as DnD recipient, the app list knows that we can | 196 // By setting us as DnD recipient, the app list knows that we can |
197 // handle items. | 197 // handle items. |
198 if (!CommandLine::ForCurrentProcess()->HasSwitch( | 198 if (!CommandLine::ForCurrentProcess()->HasSwitch( |
199 ash::switches::kAshDisableDragAndDropAppListToLauncher)) { | 199 switches::kAshDisableDragAndDropAppListToLauncher)) { |
200 SetDragAndDropHostOfCurrentAppList( | 200 SetDragAndDropHostOfCurrentAppList( |
201 Shelf::ForWindow(window)->GetDragAndDropHostForAppList()); | 201 Shelf::ForWindow(window)->GetDragAndDropHostForAppList()); |
202 } | 202 } |
203 } | 203 } |
204 // Update applist button status when app list visibility is changed. | 204 // Update applist button status when app list visibility is changed. |
205 Shelf::ForWindow(window)->GetAppListButtonView()->SchedulePaint(); | 205 Shelf::ForWindow(window)->GetAppListButtonView()->SchedulePaint(); |
206 } | 206 } |
207 | 207 |
208 bool AppListController::IsVisible() const { | 208 bool AppListController::IsVisible() const { |
209 return view_ && view_->GetWidget()->IsVisible(); | 209 return view_ && view_->GetWidget()->IsVisible(); |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
280 | 280 |
281 void AppListController::ProcessLocatedEvent(ui::LocatedEvent* event) { | 281 void AppListController::ProcessLocatedEvent(ui::LocatedEvent* event) { |
282 // If the event happened on a menu, then the event should not close the app | 282 // If the event happened on a menu, then the event should not close the app |
283 // list. | 283 // list. |
284 aura::Window* target = static_cast<aura::Window*>(event->target()); | 284 aura::Window* target = static_cast<aura::Window*>(event->target()); |
285 if (target) { | 285 if (target) { |
286 RootWindowController* root_controller = | 286 RootWindowController* root_controller = |
287 GetRootWindowController(target->GetRootWindow()); | 287 GetRootWindowController(target->GetRootWindow()); |
288 if (root_controller) { | 288 if (root_controller) { |
289 aura::Window* menu_container = root_controller->GetContainer( | 289 aura::Window* menu_container = root_controller->GetContainer( |
290 ash::internal::kShellWindowId_MenuContainer); | 290 internal::kShellWindowId_MenuContainer); |
291 if (menu_container->Contains(target)) | 291 if (menu_container->Contains(target)) |
292 return; | 292 return; |
293 aura::Window* keyboard_container = root_controller->GetContainer( | 293 aura::Window* keyboard_container = root_controller->GetContainer( |
294 ash::internal::kShellWindowId_VirtualKeyboardContainer); | 294 internal::kShellWindowId_VirtualKeyboardContainer); |
295 if (keyboard_container->Contains(target)) | 295 if (keyboard_container->Contains(target)) |
296 return; | 296 return; |
297 } | 297 } |
298 } | 298 } |
299 | 299 |
300 if (view_ && is_visible_) { | 300 if (view_ && is_visible_) { |
301 aura::Window* window = view_->GetWidget()->GetNativeView(); | 301 aura::Window* window = view_->GetWidget()->GetNativeView(); |
302 gfx::Point window_local_point(event->root_location()); | 302 gfx::Point window_local_point(event->root_location()); |
303 aura::Window::ConvertPointToTarget(window->GetRootWindow(), | 303 aura::Window::ConvertPointToTarget(window->GetRootWindow(), |
304 window, | 304 window, |
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
430 should_snap_back_ = false; | 430 should_snap_back_ = false; |
431 ui::ScopedLayerAnimationSettings animation(widget_animator); | 431 ui::ScopedLayerAnimationSettings animation(widget_animator); |
432 animation.SetTransitionDuration(base::TimeDelta::FromMilliseconds( | 432 animation.SetTransitionDuration(base::TimeDelta::FromMilliseconds( |
433 app_list::kOverscrollPageTransitionDurationMs)); | 433 app_list::kOverscrollPageTransitionDurationMs)); |
434 widget->SetBounds(view_bounds_); | 434 widget->SetBounds(view_bounds_); |
435 } | 435 } |
436 } | 436 } |
437 | 437 |
438 } // namespace internal | 438 } // namespace internal |
439 } // namespace ash | 439 } // namespace ash |
OLD | NEW |