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

Unified Diff: ash/wm/cursor_manager.h

Issue 11412315: Make the cursor have separate mode for disabled mouse events and invisible. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address comments Created 8 years 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 side-by-side diff with in-line comments
Download patch
Index: ash/wm/cursor_manager.h
diff --git a/ash/wm/cursor_manager.h b/ash/wm/cursor_manager.h
index 2eb2c68e3347294ef1107c4de1a65cdc05a6b16d..13b6893ec7b0dbf8bae359198b902597fc6c4965 100644
--- a/ash/wm/cursor_manager.h
+++ b/ash/wm/cursor_manager.h
@@ -11,9 +11,14 @@
#include "base/memory/scoped_ptr.h"
#include "ui/aura/client/cursor_client.h"
#include "ui/gfx/native_widget_types.h"
+#include "ui/gfx/point.h"
namespace ash {
+namespace internal {
+class CursorState;
+}
+
namespace test {
class CursorManagerTestApi;
}
@@ -34,6 +39,7 @@ class ASH_EXPORT CursorManager : public aura::client::CursorClient {
virtual void SetCursor(gfx::NativeCursor) OVERRIDE;
virtual void ShowCursor(bool show) OVERRIDE;
virtual bool IsCursorVisible() const OVERRIDE;
+ virtual void EnableCursor(bool enabled) OVERRIDE;
virtual void SetDeviceScaleFactor(float device_scale_factor) OVERRIDE;
virtual void LockCursor() OVERRIDE;
virtual void UnlockCursor() OVERRIDE;
@@ -43,31 +49,27 @@ class ASH_EXPORT CursorManager : public aura::client::CursorClient {
void SetCursorInternal(gfx::NativeCursor cursor);
void ShowCursorInternal(bool show);
+ void EnableCursorInternal(bool enabled);
// Number of times LockCursor() has been invoked without a corresponding
// UnlockCursor().
int cursor_lock_count_;
- // Set to true if SetCursor() is invoked while |cursor_lock_count_| == 0.
- bool did_cursor_change_;
-
- // Cursor to set once |cursor_lock_count_| is set to 0. Only valid if
- // |did_cursor_change_| is true.
- gfx::NativeCursor cursor_to_set_on_unlock_;
-
- // Set to true if ShowCursor() is invoked while |cursor_lock_count_| == 0.
- bool did_visibility_change_;
-
- // The visibility to set once |cursor_lock_count_| is set to 0. Only valid if
- // |did_visibility_change_| is true.
- bool show_on_unlock_;
-
// Is cursor visible?
bool cursor_visible_;
+ // Is cursor enabled?
+ bool cursor_enabled_;
+
+ // The cursor location where the cursor was disabled.
+ gfx::Point disabled_cursor_location_;
+
// The cursor currently set.
gfx::NativeCursor current_cursor_;
+ // The cursor state to set when the cursor is unlocked.
+ scoped_ptr<internal::CursorState> state_on_unlock_;
+
scoped_ptr<ImageCursors> image_cursors_;
DISALLOW_COPY_AND_ASSIGN(CursorManager);

Powered by Google App Engine
This is Rietveld 408576698