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
3 // found in the LICENSE file.
5 // VideoCaptureHost serves video capture related messages from
6 // VideoCaptureMessageFilter which lives inside the render process.
8 // This class is owned by RenderProcessHostImpl, and instantiated on UI
9 // thread, but all other operations and method calls happen on IO thread.
11 // Here's an example of a typical IPC dialog for video capture:
13 // Renderer VideoCaptureHost
15 // | VideoCaptureHostMsg_Start > |
16 // | < VideoCaptureMsg_StateChanged |
17 // | (VIDEO_CAPTURE_STATE_STARTED) |
18 // | < VideoCaptureMsg_NewBuffer(1) |
19 // | < VideoCaptureMsg_NewBuffer(2) |
20 // | < VideoCaptureMsg_NewBuffer(3) |
22 // | < VideoCaptureMsg_BufferReady(1) |
23 // | < VideoCaptureMsg_BufferReady(2) |
24 // | VideoCaptureHostMsg_BufferReady(1) > |
25 // | < VideoCaptureMsg_BufferReady(3) |
26 // | VideoCaptureHostMsg_BufferReady(2) > |
27 // | < VideoCaptureMsg_BufferReady(1) |
28 // | VideoCaptureHostMsg_BufferReady(3) > |
29 // | < VideoCaptureMsg_BufferReady(2) |
30 // | VideoCaptureHostMsg_BufferReady(1) > |
32 // | < VideoCaptureMsg_BufferReady(3) |
34 // | ... (resolution change) |
35 // | < VideoCaptureMsg_FreeBuffer(1) | Buffers are re-allocated
36 // | < VideoCaptureMsg_NewBuffer(4) | at a larger size, as
37 // | < VideoCaptureMsg_BufferReady(4) | needed.
38 // | VideoCaptureHostMsg_BufferReady(2) > |
39 // | < VideoCaptureMsg_FreeBuffer(2) |
40 // | < VideoCaptureMsg_NewBuffer(5) |
41 // | < VideoCaptureMsg_BufferReady(5) |
44 // | < VideoCaptureMsg_BufferReady |
45 // | VideoCaptureHostMsg_Stop > |
46 // | VideoCaptureHostMsg_BufferReady > |
47 // | < VideoCaptureMsg_StateChanged |
48 // | (VIDEO_CAPTURE_STATE_STOPPED) |
51 #ifndef CONTENT_BROWSER_RENDERER_HOST_MEDIA_VIDEO_CAPTURE_HOST_H_
52 #define CONTENT_BROWSER_RENDERER_HOST_MEDIA_VIDEO_CAPTURE_HOST_H_
56 #include "base/memory/ref_counted.h"
57 #include "base/memory/weak_ptr.h"
58 #include "base/sequenced_task_runner_helpers.h"
59 #include "content/browser/renderer_host/media/video_capture_controller.h"
60 #include "content/common/content_export.h"
61 #include "content/public/browser/browser_message_filter.h"
62 #include "ipc/ipc_message.h"
65 class MediaStreamManager
;
67 class CONTENT_EXPORT VideoCaptureHost
68 : public BrowserMessageFilter
,
69 public VideoCaptureControllerEventHandler
{
71 explicit VideoCaptureHost(MediaStreamManager
* media_stream_manager
);
73 // BrowserMessageFilter implementation.
74 virtual void OnChannelClosing() OVERRIDE
;
75 virtual void OnDestruct() const OVERRIDE
;
76 virtual bool OnMessageReceived(const IPC::Message
& message
) OVERRIDE
;
78 // VideoCaptureControllerEventHandler implementation.
79 virtual void OnError(const VideoCaptureControllerID
& id
) OVERRIDE
;
80 virtual void OnBufferCreated(const VideoCaptureControllerID
& id
,
81 base::SharedMemoryHandle handle
,
83 int buffer_id
) OVERRIDE
;
84 virtual void OnBufferDestroyed(const VideoCaptureControllerID
& id
,
85 int buffer_id
) OVERRIDE
;
86 virtual void OnBufferReady(const VideoCaptureControllerID
& id
,
88 const media::VideoCaptureFormat
& format
,
89 const gfx::Rect
& visible_rect
,
90 base::TimeTicks timestamp
) OVERRIDE
;
91 virtual void OnMailboxBufferReady(const VideoCaptureControllerID
& id
,
93 const gpu::MailboxHolder
& mailbox_holder
,
94 const media::VideoCaptureFormat
& format
,
95 base::TimeTicks timestamp
) OVERRIDE
;
96 virtual void OnEnded(const VideoCaptureControllerID
& id
) OVERRIDE
;
99 friend class BrowserThread
;
100 friend class base::DeleteHelper
<VideoCaptureHost
>;
101 friend class MockVideoCaptureHost
;
102 friend class VideoCaptureHostTest
;
104 virtual ~VideoCaptureHost();
106 // IPC message: Start capture on the VideoCaptureDevice referenced by
107 // |session_id|. |device_id| is an id created by VideoCaptureMessageFilter
108 // to identify a session between a VideoCaptureMessageFilter and a
110 void OnStartCapture(int device_id
,
111 media::VideoCaptureSessionId session_id
,
112 const media::VideoCaptureParams
& params
);
113 void OnControllerAdded(
115 const base::WeakPtr
<VideoCaptureController
>& controller
);
116 void DoControllerAddedOnIOThread(
118 const base::WeakPtr
<VideoCaptureController
>& controller
);
120 // IPC message: Stop capture on device referenced by |device_id|.
121 void OnStopCapture(int device_id
);
123 // IPC message: Pause capture on device referenced by |device_id|.
124 void OnPauseCapture(int device_id
);
126 // IPC message: Receive an empty buffer from renderer. Send it to device
127 // referenced by |device_id|.
128 void OnReceiveEmptyBuffer(int device_id
, int buffer_id
, uint32 sync_point
);
130 // IPC message: Get supported formats referenced by |capture_session_id|.
131 // |device_id| is needed for message back-routing purposes.
132 void OnGetDeviceSupportedFormats(
134 media::VideoCaptureSessionId capture_session_id
);
136 // IPC message: Get a device's currently in use format(s), referenced by
137 // |capture_session_id|. |device_id| is needed for message back-routing
139 void OnGetDeviceFormatsInUse(
141 media::VideoCaptureSessionId capture_session_id
);
143 // Sends a newly created buffer to the VideoCaptureMessageFilter.
144 void DoSendNewBufferOnIOThread(
145 const VideoCaptureControllerID
& controller_id
,
146 base::SharedMemoryHandle handle
,
150 void DoSendFreeBufferOnIOThread(
151 const VideoCaptureControllerID
& controller_id
,
154 // Sends a filled buffer to the VideoCaptureMessageFilter.
155 void DoSendFilledBufferOnIOThread(
156 const VideoCaptureControllerID
& controller_id
,
158 const media::VideoCaptureFormat
& format
,
159 const gfx::Rect
& visible_rect
,
160 base::TimeTicks timestamp
);
162 // Sends a filled texture mailbox buffer to the VideoCaptureMessageFilter.
163 void DoSendFilledMailboxBufferOnIOThread(
164 const VideoCaptureControllerID
& controller_id
,
166 const gpu::MailboxHolder
& mailbox_holder
,
167 const media::VideoCaptureFormat
& format
,
168 base::TimeTicks timestamp
);
170 // Handles error coming from VideoCaptureDevice.
171 void DoHandleErrorOnIOThread(const VideoCaptureControllerID
& controller_id
);
173 void DoEndedOnIOThread(const VideoCaptureControllerID
& controller_id
);
175 // Deletes the controller and notifies the VideoCaptureManager. |on_error| is
176 // true if this is triggered by VideoCaptureControllerEventHandler::OnError.
177 void DeleteVideoCaptureControllerOnIOThread(
178 const VideoCaptureControllerID
& controller_id
, bool on_error
);
180 MediaStreamManager
* media_stream_manager_
;
182 typedef std::map
<VideoCaptureControllerID
,
183 base::WeakPtr
<VideoCaptureController
> > EntryMap
;
185 // A map of VideoCaptureControllerID to the VideoCaptureController to which it
186 // is connected. An entry in this map holds a null controller while it is in
187 // the process of starting.
190 DISALLOW_COPY_AND_ASSIGN(VideoCaptureHost
);
193 } // namespace content
195 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_VIDEO_CAPTURE_HOST_H_