| Index: ui/views/widget/desktop_aura/desktop_native_cursor_manager.cc
|
| diff --git a/ui/views/widget/desktop_aura/desktop_native_cursor_manager.cc b/ui/views/widget/desktop_aura/desktop_native_cursor_manager.cc
|
| index 911f775336103d76db481e872e126052bd718649..71bfeca0a3cd1250d13894b4d021d6e3b1d4a701 100644
|
| --- a/ui/views/widget/desktop_aura/desktop_native_cursor_manager.cc
|
| +++ b/ui/views/widget/desktop_aura/desktop_native_cursor_manager.cc
|
| @@ -11,13 +11,11 @@
|
| namespace views {
|
|
|
| DesktopNativeCursorManager::DesktopNativeCursorManager(
|
| - aura::RootWindow* window,
|
| scoped_ptr<DesktopCursorLoaderUpdater> cursor_loader_updater)
|
| - : root_window_(window),
|
| - cursor_loader_updater_(cursor_loader_updater.Pass()),
|
| + : cursor_loader_updater_(cursor_loader_updater.Pass()),
|
| cursor_loader_(ui::CursorLoader::Create()) {
|
| if (cursor_loader_updater_.get())
|
| - cursor_loader_updater_->OnCreate(root_window_, cursor_loader_.get());
|
| + cursor_loader_updater_->OnCreate(1.0f, cursor_loader_.get());
|
| }
|
|
|
| DesktopNativeCursorManager::~DesktopNativeCursorManager() {
|
| @@ -29,6 +27,15 @@ gfx::NativeCursor DesktopNativeCursorManager::GetInitializedCursor(int type) {
|
| return cursor;
|
| }
|
|
|
| +void DesktopNativeCursorManager::AddRootWindow(aura::RootWindow* root_window) {
|
| + root_windows_.insert(root_window);
|
| +}
|
| +
|
| +void DesktopNativeCursorManager::RemoveRootWindow(
|
| + aura::RootWindow* root_window) {
|
| + root_windows_.erase(root_window);
|
| +}
|
| +
|
| void DesktopNativeCursorManager::SetDisplay(
|
| const gfx::Display& display,
|
| views::corewm::NativeCursorManagerDelegate* delegate) {
|
| @@ -48,8 +55,13 @@ void DesktopNativeCursorManager::SetCursor(
|
| cursor_loader_->SetPlatformCursor(&new_cursor);
|
| delegate->CommitCursor(new_cursor);
|
|
|
| - if (delegate->IsCursorVisible())
|
| - root_window_->SetCursor(new_cursor);
|
| + if (delegate->IsCursorVisible()) {
|
| + for (RootWindows::const_iterator i = root_windows_.begin();
|
| + i != root_windows_.end();
|
| + ++i) {
|
| + (*i)->SetCursor(new_cursor);
|
| + }
|
| + }
|
| }
|
|
|
| void DesktopNativeCursorManager::SetVisibility(
|
| @@ -62,10 +74,18 @@ void DesktopNativeCursorManager::SetVisibility(
|
| } else {
|
| gfx::NativeCursor invisible_cursor(ui::kCursorNone);
|
| cursor_loader_->SetPlatformCursor(&invisible_cursor);
|
| - root_window_->SetCursor(invisible_cursor);
|
| + for (RootWindows::const_iterator i = root_windows_.begin();
|
| + i != root_windows_.end();
|
| + ++i) {
|
| + (*i)->SetCursor(invisible_cursor);
|
| + }
|
| }
|
|
|
| - root_window_->OnCursorVisibilityChanged(visible);
|
| + for (RootWindows::const_iterator i = root_windows_.begin();
|
| + i != root_windows_.end();
|
| + ++i) {
|
| + (*i)->OnCursorVisibilityChanged(visible);
|
| + }
|
| }
|
|
|
| void DesktopNativeCursorManager::SetCursorSet(
|
| @@ -90,7 +110,11 @@ void DesktopNativeCursorManager::SetMouseEventsEnabled(
|
|
|
| SetVisibility(delegate->IsCursorVisible(), delegate);
|
|
|
| - root_window_->OnMouseEventsEnableStateChanged(enabled);
|
| + for (RootWindows::const_iterator i = root_windows_.begin();
|
| + i != root_windows_.end();
|
| + ++i) {
|
| + (*i)->OnMouseEventsEnableStateChanged(enabled);
|
| + }
|
| }
|
|
|
| } // namespace views
|
|
|