OLD | NEW |
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 "remoting/host/ipc_video_frame_capturer.h" | 5 #include "remoting/host/ipc_video_frame_capturer.h" |
6 | 6 |
7 #include "media/video/capture/screen/mouse_cursor_shape.h" | 7 #include "media/video/capture/screen/mouse_cursor_shape.h" |
8 #include "media/video/capture/screen/screen_capture_data.h" | |
9 #include "remoting/host/desktop_session_proxy.h" | 8 #include "remoting/host/desktop_session_proxy.h" |
| 9 #include "third_party/webrtc/modules/desktop_capture/desktop_frame.h" |
10 | 10 |
11 namespace remoting { | 11 namespace remoting { |
12 | 12 |
13 IpcVideoFrameCapturer::IpcVideoFrameCapturer( | 13 IpcVideoFrameCapturer::IpcVideoFrameCapturer( |
14 scoped_refptr<DesktopSessionProxy> desktop_session_proxy) | 14 scoped_refptr<DesktopSessionProxy> desktop_session_proxy) |
15 : delegate_(NULL), | 15 : callback_(NULL), |
| 16 mouse_shape_observer_(NULL), |
16 desktop_session_proxy_(desktop_session_proxy), | 17 desktop_session_proxy_(desktop_session_proxy), |
17 weak_factory_(this) { | 18 weak_factory_(this) { |
18 } | 19 } |
19 | 20 |
20 IpcVideoFrameCapturer::~IpcVideoFrameCapturer() { | 21 IpcVideoFrameCapturer::~IpcVideoFrameCapturer() { |
21 } | 22 } |
22 | 23 |
23 void IpcVideoFrameCapturer::Start(Delegate* delegate) { | 24 void IpcVideoFrameCapturer::Start(Callback* callback) { |
24 delegate_ = delegate; | 25 DCHECK(!callback_); |
| 26 DCHECK(callback); |
| 27 callback_ = callback; |
25 desktop_session_proxy_->SetVideoCapturer(weak_factory_.GetWeakPtr()); | 28 desktop_session_proxy_->SetVideoCapturer(weak_factory_.GetWeakPtr()); |
26 } | 29 } |
27 | 30 |
28 void IpcVideoFrameCapturer::CaptureFrame() { | 31 void IpcVideoFrameCapturer::SetMouseShapeObserver( |
| 32 MouseShapeObserver* mouse_shape_observer) { |
| 33 DCHECK(!mouse_shape_observer_); |
| 34 DCHECK(mouse_shape_observer); |
| 35 mouse_shape_observer_ = mouse_shape_observer; |
| 36 } |
| 37 |
| 38 void IpcVideoFrameCapturer::Capture(const webrtc::DesktopRegion& region) { |
29 desktop_session_proxy_->CaptureFrame(); | 39 desktop_session_proxy_->CaptureFrame(); |
30 } | 40 } |
31 | 41 |
32 void IpcVideoFrameCapturer::OnCaptureCompleted( | 42 void IpcVideoFrameCapturer::OnCaptureCompleted( |
33 scoped_refptr<media::ScreenCaptureData> capture_data) { | 43 scoped_ptr<webrtc::DesktopFrame> frame) { |
34 if (delegate_) | 44 callback_->OnCaptureCompleted(frame.release()); |
35 delegate_->OnCaptureCompleted(capture_data); | |
36 } | 45 } |
37 | 46 |
38 void IpcVideoFrameCapturer::OnCursorShapeChanged( | 47 void IpcVideoFrameCapturer::OnCursorShapeChanged( |
39 scoped_ptr<media::MouseCursorShape> cursor_shape) { | 48 scoped_ptr<media::MouseCursorShape> cursor_shape) { |
40 if (delegate_) | 49 if (mouse_shape_observer_) |
41 delegate_->OnCursorShapeChanged(cursor_shape.Pass()); | 50 mouse_shape_observer_->OnCursorShapeChanged(cursor_shape.Pass()); |
42 } | 51 } |
43 | 52 |
44 } // namespace remoting | 53 } // namespace remoting |
OLD | NEW |