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

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

Powered by Google App Engine
This is Rietveld 408576698