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

Side by Side Diff: ash/wm/ash_native_cursor_manager.cc

Issue 145313003: Implement cursor compositing mode on Ash (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Move more stuff into CursorWindowController. Created 6 years, 10 months 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 | Annotate | Revision Log
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 "ash/wm/ash_native_cursor_manager.h" 5 #include "ash/wm/ash_native_cursor_manager.h"
6 6
7 #include "ash/display/cursor_window_controller.h"
7 #include "ash/display/display_controller.h" 8 #include "ash/display/display_controller.h"
8 #include "ash/display/mirror_window_controller.h"
9 #include "ash/shell.h" 9 #include "ash/shell.h"
10 #include "ash/wm/image_cursors.h" 10 #include "ash/wm/image_cursors.h"
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "ui/aura/env.h" 12 #include "ui/aura/env.h"
13 #include "ui/aura/root_window.h" 13 #include "ui/aura/root_window.h"
14 #include "ui/base/cursor/cursor.h" 14 #include "ui/base/cursor/cursor.h"
15 15
16 namespace ash { 16 namespace ash {
17 namespace { 17 namespace {
18 18
19 void SetCursorOnAllRootWindows(gfx::NativeCursor cursor) { 19 void SetCursorOnAllRootWindows(gfx::NativeCursor cursor) {
20 aura::Window::Windows root_windows = 20 aura::Window::Windows root_windows =
21 Shell::GetInstance()->GetAllRootWindows(); 21 Shell::GetInstance()->GetAllRootWindows();
22 for (aura::Window::Windows::iterator iter = root_windows.begin(); 22 for (aura::Window::Windows::iterator iter = root_windows.begin();
23 iter != root_windows.end(); ++iter) 23 iter != root_windows.end(); ++iter)
24 (*iter)->GetDispatcher()->SetCursor(cursor); 24 (*iter)->GetDispatcher()->SetCursor(cursor);
25 #if defined(OS_CHROMEOS) 25 #if defined(OS_CHROMEOS)
26 Shell::GetInstance()->display_controller()-> 26 Shell::GetInstance()->display_controller()->
27 mirror_window_controller()->SetMirroredCursor(cursor); 27 cursor_window_controller()->SetCursor(cursor);
28 #endif 28 #endif
29 } 29 }
30 30
31 void NotifyCursorVisibilityChange(bool visible) { 31 void NotifyCursorVisibilityChange(bool visible) {
32 aura::Window::Windows root_windows = 32 aura::Window::Windows root_windows =
33 Shell::GetInstance()->GetAllRootWindows(); 33 Shell::GetInstance()->GetAllRootWindows();
34 for (aura::Window::Windows::iterator iter = root_windows.begin(); 34 for (aura::Window::Windows::iterator iter = root_windows.begin();
35 iter != root_windows.end(); ++iter) 35 iter != root_windows.end(); ++iter)
36 (*iter)->GetDispatcher()->OnCursorVisibilityChanged(visible); 36 (*iter)->GetDispatcher()->OnCursorVisibilityChanged(visible);
37 #if defined(OS_CHROMEOS) 37 #if defined(OS_CHROMEOS)
38 Shell::GetInstance()->display_controller()->mirror_window_controller()-> 38 Shell::GetInstance()->display_controller()->cursor_window_controller()->
39 SetMirroredCursorVisibility(visible); 39 SetVisibility(visible);
40 #endif 40 #endif
41 } 41 }
42 42
43 void NotifyMouseEventsEnableStateChange(bool enabled) { 43 void NotifyMouseEventsEnableStateChange(bool enabled) {
44 aura::Window::Windows root_windows = 44 aura::Window::Windows root_windows =
45 Shell::GetInstance()->GetAllRootWindows(); 45 Shell::GetInstance()->GetAllRootWindows();
46 for (aura::Window::Windows::iterator iter = root_windows.begin(); 46 for (aura::Window::Windows::iterator iter = root_windows.begin();
47 iter != root_windows.end(); ++iter) 47 iter != root_windows.end(); ++iter)
48 (*iter)->GetDispatcher()->OnMouseEventsEnableStateChanged(enabled); 48 (*iter)->GetDispatcher()->OnMouseEventsEnableStateChanged(enabled);
49 // Mirror window never process events. 49 // Mirror window never process events.
50 } 50 }
51 51
52 } // namespace 52 } // namespace
53 53
54 AshNativeCursorManager::AshNativeCursorManager() 54 AshNativeCursorManager::AshNativeCursorManager()
55 : image_cursors_(new ImageCursors) { 55 : native_cursor_enabled_(true),
56 image_cursors_(new ImageCursors) {
56 } 57 }
57 58
58 AshNativeCursorManager::~AshNativeCursorManager() { 59 AshNativeCursorManager::~AshNativeCursorManager() {
59 } 60 }
60 61
61 void AshNativeCursorManager::SetDisplay( 62 void AshNativeCursorManager::SetDisplay(
62 const gfx::Display& display, 63 const gfx::Display& display,
63 views::corewm::NativeCursorManagerDelegate* delegate) { 64 views::corewm::NativeCursorManagerDelegate* delegate) {
64 if (image_cursors_->SetDisplay(display)) 65 if (image_cursors_->SetDisplay(display))
65 SetCursor(delegate->GetCursor(), delegate); 66 SetCursor(delegate->GetCursor(), delegate);
67 #if defined(OS_CHROMEOS)
68 Shell::GetInstance()->display_controller()->cursor_window_controller()->
69 SetDisplay(display);
70 #endif
66 } 71 }
67 72
68 void AshNativeCursorManager::SetCursor( 73 void AshNativeCursorManager::SetCursor(
69 gfx::NativeCursor cursor, 74 gfx::NativeCursor cursor,
70 views::corewm::NativeCursorManagerDelegate* delegate) { 75 views::corewm::NativeCursorManagerDelegate* delegate) {
71 gfx::NativeCursor new_cursor = cursor; 76 gfx::NativeCursor new_cursor = cursor;
72 image_cursors_->SetPlatformCursor(&new_cursor); 77 if (native_cursor_enabled_) {
78 image_cursors_->SetPlatformCursor(&new_cursor);
79 } else {
80 gfx::NativeCursor invisible_cursor(ui::kCursorNone);
81 image_cursors_->SetPlatformCursor(&invisible_cursor);
82 if (new_cursor == ui::kCursorCustom) {
83 new_cursor = invisible_cursor;
84 } else {
85 new_cursor.SetPlatformCursor(invisible_cursor.platform());
86 }
87 }
73 new_cursor.set_device_scale_factor( 88 new_cursor.set_device_scale_factor(
74 image_cursors_->GetDisplay().device_scale_factor()); 89 image_cursors_->GetDisplay().device_scale_factor());
75 90
76 delegate->CommitCursor(new_cursor); 91 delegate->CommitCursor(new_cursor);
77 92
78 if (delegate->IsCursorVisible()) 93 if (delegate->IsCursorVisible())
79 SetCursorOnAllRootWindows(new_cursor); 94 SetCursorOnAllRootWindows(new_cursor);
80 } 95 }
81 96
82 void AshNativeCursorManager::SetCursorSet( 97 void AshNativeCursorManager::SetCursorSet(
83 ui::CursorSetType cursor_set, 98 ui::CursorSetType cursor_set,
84 views::corewm::NativeCursorManagerDelegate* delegate) { 99 views::corewm::NativeCursorManagerDelegate* delegate) {
85 image_cursors_->SetCursorSet(cursor_set); 100 image_cursors_->SetCursorSet(cursor_set);
86 delegate->CommitCursorSet(cursor_set); 101 delegate->CommitCursorSet(cursor_set);
87 102
88 // Sets the cursor to reflect the scale change immediately. 103 // Sets the cursor to reflect the scale change immediately.
89 if (delegate->IsCursorVisible()) 104 if (delegate->IsCursorVisible())
90 SetCursor(delegate->GetCursor(), delegate); 105 SetCursor(delegate->GetCursor(), delegate);
106
107 #if defined(OS_CHROMEOS)
108 Shell::GetInstance()->display_controller()->cursor_window_controller()->
109 SetCursorSet(cursor_set);
110 #endif
91 } 111 }
92 112
93 void AshNativeCursorManager::SetScale( 113 void AshNativeCursorManager::SetScale(
94 float scale, 114 float scale,
95 views::corewm::NativeCursorManagerDelegate* delegate) { 115 views::corewm::NativeCursorManagerDelegate* delegate) {
96 image_cursors_->SetScale(scale); 116 image_cursors_->SetScale(scale);
97 delegate->CommitScale(scale); 117 delegate->CommitScale(scale);
98 118
99 // Sets the cursor to reflect the scale change immediately. 119 // Sets the cursor to reflect the scale change immediately.
100 SetCursor(delegate->GetCursor(), delegate); 120 SetCursor(delegate->GetCursor(), delegate);
(...skipping 24 matching lines...) Expand all
125 aura::Env::GetInstance()->set_last_mouse_location( 145 aura::Env::GetInstance()->set_last_mouse_location(
126 disabled_cursor_location_); 146 disabled_cursor_location_);
127 } else { 147 } else {
128 disabled_cursor_location_ = aura::Env::GetInstance()->last_mouse_location(); 148 disabled_cursor_location_ = aura::Env::GetInstance()->last_mouse_location();
129 } 149 }
130 150
131 SetVisibility(delegate->IsCursorVisible(), delegate); 151 SetVisibility(delegate->IsCursorVisible(), delegate);
132 NotifyMouseEventsEnableStateChange(enabled); 152 NotifyMouseEventsEnableStateChange(enabled);
133 } 153 }
134 154
155 void AshNativeCursorManager::SetNativeCursorEnabled(
156 bool enabled,
157 views::corewm::NativeCursorManagerDelegate* delegate) {
158 native_cursor_enabled_ = enabled;
159 SetCursor(delegate->GetCursor(), delegate);
160 }
161
135 } // namespace ash 162 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698