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

Unified Diff: content/browser/media/capture/cursor_renderer.h

Issue 2553763002: Fix cursor missing in tabCapture on OSX Sierra (Closed)
Patch Set: implement CursorRenderer Created 4 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: content/browser/media/capture/cursor_renderer.h
diff --git a/content/browser/media/capture/cursor_renderer.h b/content/browser/media/capture/cursor_renderer.h
index 9ac912e68febe2ab1d7a938d3c66f022f67647de..d5dbb718857956fee5f2d63f0a6553455b8fef80 100644
--- a/content/browser/media/capture/cursor_renderer.h
+++ b/content/browser/media/capture/cursor_renderer.h
@@ -8,12 +8,23 @@
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "base/memory/weak_ptr.h"
+#include "base/time/default_tick_clock.h"
+#include "base/time/tick_clock.h"
#include "content/common/content_export.h"
#include "media/base/video_frame.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+#include "ui/base/cursor/cursor.h"
#include "ui/gfx/native_widget_types.h"
namespace content {
+// Setting to control cursor display based on either mouse movement or always
+// forced to be enabled.
+enum CursorDisplaySetting {
+ kCursorAlwaysEnabled,
+ kCursorEnabledOnMouseMovement
+};
+
// CursorRenderer is an interface that can be implememented to do cursor
miu 2016/12/27 23:21:03 This class comment needs to be updated, since this
braveyao 2017/01/04 01:57:49 Done.
// rendering on a video frame.
//
@@ -23,33 +34,87 @@ class CONTENT_EXPORT CursorRenderer {
public:
static std::unique_ptr<CursorRenderer> Create(gfx::NativeView view);
- virtual ~CursorRenderer() {}
+ CursorRenderer(gfx::NativeView captured_view,
+ CursorDisplaySetting cursor_display);
+
+ virtual ~CursorRenderer();
// Clears the cursor state being tracked. Called when there is a need to
// reset the state.
- virtual void Clear() = 0;
+ void Clear();
// Takes a snapshot of the current cursor state and determines whether
// the cursor will be rendered, which cursor image to render, and at what
// location within |region_in_frame| to render it. Returns true if cursor
// needs to be rendered.
- virtual bool SnapshotCursorState(const gfx::Rect& region_in_frame) = 0;
+ bool SnapshotCursorState(const gfx::Rect& region_in_frame);
// Renders cursor on the |target| video frame.
- virtual void RenderOnVideoFrame(
- const scoped_refptr<media::VideoFrame>& target) const = 0;
+ void RenderOnVideoFrame(const scoped_refptr<media::VideoFrame>& target) const;
miu 2016/12/27 23:21:03 style nit (per smart pointer guidelines): The old
braveyao 2017/01/04 01:57:49 Done.
// Returns a weak pointer.
- virtual base::WeakPtr<CursorRenderer> GetWeakPtr() = 0;
+ base::WeakPtr<CursorRenderer> GetWeakPtr();
protected:
enum {
// Minium movement before cursor is rendered on frame.
MIN_MOVEMENT_PIXELS = 15,
- // Maximum idle time allowed before we stop rendering the cursor
- // on frame.
+ // Maximum idle time allowed before we stop rendering the cursor on frame.
MAX_IDLE_TIME_SECONDS = 2
};
+
+ // Returns true if the captured view is a part of an active application
+ // window.
+ virtual bool IsCapturedViewActive() = 0;
+
+ // Returns the size of the captured view (view coordinates).
+ virtual gfx::Size GetCapturedViewSize() = 0;
+
+ // Returns the cursor's position within the captured view (view coordinates).
+ virtual gfx::Point GetCursorPositionInView() = 0;
+
+ // Returns the last-known mouse cursor.
+ virtual gfx::NativeCursor GetLastKnownCursor() = 0;
+
+ // Returns the image of the last-known mouse cursor.
+ virtual SkBitmap GetLastKnownCursorImage() = 0;
+
+ // Returns the hot point (in the cursor image) of the last-known mouse cursor.
+ virtual gfx::Point GetLastKnownCursorHotPoint() = 0;
+
+ // Called by subclasses to report mouse events within the captured view.
+ void OnMouseMoved(const gfx::Point& location, base::TimeTicks timestamp);
+ void OnMouseClicked(const gfx::Point& location, base::TimeTicks timestamp);
+
+ private:
+ friend class CursorRendererAuraTest;
+
+ gfx::NativeView captured_view_;
miu 2016/12/27 23:21:03 nit: Use const since this member doesn't change af
braveyao 2017/01/04 01:57:49 Done.
+
+ // Snapshot of cursor, source size, position, and cursor bitmap; as of the
+ // last call to SnapshotCursorState.
+ gfx::NativeCursor last_cursor_;
+ gfx::Point cursor_position_in_frame_;
+ gfx::Point last_cursor_hot_point_;
+ gfx::Size window_size_when_cursor_last_updated_;
miu 2016/12/27 23:21:03 naming nit: How about |view_size_when_cursor_last_
braveyao 2017/01/04 01:57:49 Done.
+ SkBitmap scaled_cursor_bitmap_;
+
+ // Updated in mouse event listener and used to make a decision on
+ // when the cursor is rendered.
+ base::TimeTicks last_mouse_movement_timestamp_;
+ float last_mouse_position_x_;
+ float last_mouse_position_y_;
+ bool cursor_displayed_;
+
+ // Controls whether cursor is displayed based on active mouse movement.
+ CursorDisplaySetting cursor_display_setting_;
+
+ // Allows tests to replace the clock.
+ base::DefaultTickClock default_tick_clock_;
+ base::TickClock* tick_clock_;
+
+ base::WeakPtrFactory<CursorRenderer> weak_factory_;
+ DISALLOW_COPY_AND_ASSIGN(CursorRenderer);
miu 2016/12/27 23:21:03 nit: Please add a blank line above this line.
braveyao 2017/01/04 01:57:49 Done.
};
} // namespace content

Powered by Google App Engine
This is Rietveld 408576698