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

Side by Side Diff: ui/views/corewm/cursor_manager.h

Issue 12263050: Rework ash::CursorManager into a corewm object, to share code with desktop. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: General patch cleanup. Created 7 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) 2013 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 #ifndef ASH_WM_CURSOR_MANAGER_H_ 5 #ifndef UI_VIEWS_COREWM_CURSOR_MANAGER_H_
6 #define ASH_WM_CURSOR_MANAGER_H_ 6 #define UI_VIEWS_COREWM_CURSOR_MANAGER_H_
7 7
8 #include "ash/ash_export.h"
9 #include "base/basictypes.h" 8 #include "base/basictypes.h"
10 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
11 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
12 #include "ui/aura/client/cursor_client.h" 11 #include "ui/aura/client/cursor_client.h"
13 #include "ui/gfx/native_widget_types.h" 12 #include "ui/gfx/native_widget_types.h"
14 #include "ui/gfx/point.h" 13 #include "ui/gfx/point.h"
14 #include "ui/views/corewm/cursor_manager_delegate.h"
15 #include "ui/views/views_export.h"
15 16
16 namespace ash { 17 namespace views {
18 namespace corewm {
17 19
18 namespace internal { 20 namespace internal {
19 class CursorState; 21 class CursorState;
20 } 22 }
21 23
22 namespace test { 24 class CursorPlatformDelegate;
23 class CursorManagerTestApi;
24 }
25 25
26 class ImageCursors; 26 // This class controls the visibility and the type of the cursor. The cursor
27 27 // type can be locked so that the type stays the same until it's unlocked.
28 // This class controls the visibility and the type of the cursor. 28 class VIEWS_EXPORT CursorManager : public aura::client::CursorClient,
29 // The cursor type can be locked so that the type stays the same 29 public CursorManagerDelegate {
Ben Goodger (Google) 2013/02/22 18:00:06 It is confusing to me that you have a class Cursor
Elliot Glaysher 2013/02/22 18:40:07 In the previous implementation, if you wanted to m
30 // until it's unlocked.
31 class ASH_EXPORT CursorManager : public aura::client::CursorClient {
32 public: 30 public:
33 CursorManager(); 31 CursorManager(scoped_ptr<CursorPlatformDelegate> delegate);
34 virtual ~CursorManager(); 32 virtual ~CursorManager();
35 33
36 bool is_cursor_locked() const { return cursor_lock_count_ > 0; } 34 bool is_cursor_locked() const { return cursor_lock_count_ > 0; }
37 35
38 // Overridden from aura::client::CursorClient: 36 // Overridden from aura::client::CursorClient:
39 virtual void SetCursor(gfx::NativeCursor) OVERRIDE; 37 virtual void SetCursor(gfx::NativeCursor) OVERRIDE;
40 virtual void ShowCursor() OVERRIDE; 38 virtual void ShowCursor() OVERRIDE;
41 virtual void HideCursor() OVERRIDE; 39 virtual void HideCursor() OVERRIDE;
42 virtual bool IsCursorVisible() const OVERRIDE; 40 virtual bool IsCursorVisible() const OVERRIDE;
43 virtual void EnableMouseEvents() OVERRIDE; 41 virtual void EnableMouseEvents() OVERRIDE;
44 virtual void DisableMouseEvents() OVERRIDE; 42 virtual void DisableMouseEvents() OVERRIDE;
45 virtual bool IsMouseEventsEnabled() const OVERRIDE; 43 virtual bool IsMouseEventsEnabled() const OVERRIDE;
46 virtual void SetDeviceScaleFactor(float device_scale_factor) OVERRIDE; 44 virtual void SetDeviceScaleFactor(float device_scale_factor) OVERRIDE;
47 virtual void LockCursor() OVERRIDE; 45 virtual void LockCursor() OVERRIDE;
48 virtual void UnlockCursor() OVERRIDE; 46 virtual void UnlockCursor() OVERRIDE;
49 47
50 private: 48 private:
51 friend class test::CursorManagerTestApi; 49 // Overridden from CursorManagerDelegate:
50 virtual gfx::NativeCursor GetCurrentCursor() const OVERRIDE;
51 virtual bool GetCurrentVisibility() const OVERRIDE;
52 virtual bool GetMouseEventsEnabled() const OVERRIDE;
53 virtual void CommitCursor(gfx::NativeCursor cursor) OVERRIDE;
54 virtual void CommitVisibility(bool visible) OVERRIDE;
55 virtual void CommitMouseEventsEnabled(bool enabled) OVERRIDE;
52 56
53 void SetCursorInternal(gfx::NativeCursor cursor); 57 scoped_ptr<CursorPlatformDelegate> delegate_;
54 void SetCursorVisibility(bool visible);
55 void SetMouseEventsEnabled(bool enabled);
56
57 // Returns the current cursor.
58 gfx::NativeCursor GetCurrentCursor() const;
59 58
60 // Number of times LockCursor() has been invoked without a corresponding 59 // Number of times LockCursor() has been invoked without a corresponding
61 // UnlockCursor(). 60 // UnlockCursor().
62 int cursor_lock_count_; 61 int cursor_lock_count_;
63 62
64 // The cursor location where the cursor was disabled.
65 gfx::Point disabled_cursor_location_;
66
67 // The current state of the cursor. 63 // The current state of the cursor.
68 scoped_ptr<internal::CursorState> current_state_; 64 scoped_ptr<internal::CursorState> current_state_;
69 65
70 // The cursor state to restore when the cursor is unlocked. 66 // The cursor state to restore when the cursor is unlocked.
71 scoped_ptr<internal::CursorState> state_on_unlock_; 67 scoped_ptr<internal::CursorState> state_on_unlock_;
72 68
73 scoped_ptr<ImageCursors> image_cursors_;
74
75 DISALLOW_COPY_AND_ASSIGN(CursorManager); 69 DISALLOW_COPY_AND_ASSIGN(CursorManager);
76 }; 70 };
77 71
78 } // namespace ash 72 } // namespace corewm
73 } // namespace views
79 74
80 #endif // UI_AURA_CURSOR_MANAGER_H_ 75 #endif // UI_VIEWS_COREWM_CURSOR_MANAGER_H_
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.cc ('k') | ui/views/corewm/cursor_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698