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

Side by Side Diff: trunk/src/content/browser/renderer_host/media/video_capture_host.cc

Issue 84393002: Revert 236927 "Reorganize media::VideoCapture* types" (Closed) Base URL: svn://svn.chromium.org/chrome/
Patch Set: Created 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 "content/browser/renderer_host/media/video_capture_host.h" 5 #include "content/browser/renderer_host/media/video_capture_host.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "content/browser/browser_main_loop.h" 9 #include "content/browser/browser_main_loop.h"
10 #include "content/browser/renderer_host/media/media_stream_manager.h" 10 #include "content/browser/renderer_host/media/media_stream_manager.h"
(...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after
157 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_Pause, OnPauseCapture) 157 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_Pause, OnPauseCapture)
158 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_Stop, OnStopCapture) 158 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_Stop, OnStopCapture)
159 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_BufferReady, OnReceiveEmptyBuffer) 159 IPC_MESSAGE_HANDLER(VideoCaptureHostMsg_BufferReady, OnReceiveEmptyBuffer)
160 IPC_MESSAGE_UNHANDLED(handled = false) 160 IPC_MESSAGE_UNHANDLED(handled = false)
161 IPC_END_MESSAGE_MAP_EX() 161 IPC_END_MESSAGE_MAP_EX()
162 162
163 return handled; 163 return handled;
164 } 164 }
165 165
166 void VideoCaptureHost::OnStartCapture(int device_id, 166 void VideoCaptureHost::OnStartCapture(int device_id,
167 media::VideoCaptureSessionId session_id,
168 const media::VideoCaptureParams& params) { 167 const media::VideoCaptureParams& params) {
169 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 168 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
170 DVLOG(1) << "VideoCaptureHost::OnStartCapture:" 169 DVLOG(1) << "VideoCaptureHost::OnStartCapture, device_id " << device_id
171 << " session_id=" << session_id 170 << ", (" << params.requested_format.width
172 << ", device_id=" << device_id 171 << ", " << params.requested_format.height
173 << ", format=" << params.requested_format.frame_size.ToString() 172 << ", " << params.requested_format.frame_rate
174 << "@" << params.requested_format.frame_rate 173 << ", " << params.session_id << ", variable resolution device:"
175 << " (" << (params.allow_resolution_change ? "variable" : "constant") 174 << ((params.requested_format.frame_size_type ==
175 media::VariableResolutionVideoCaptureDevice) ? "yes" : "no")
176 << ")"; 176 << ")";
177 VideoCaptureControllerID controller_id(device_id); 177 VideoCaptureControllerID controller_id(device_id);
178 DCHECK(entries_.find(controller_id) == entries_.end()); 178 DCHECK(entries_.find(controller_id) == entries_.end());
179 179
180 entries_[controller_id] = base::WeakPtr<VideoCaptureController>(); 180 entries_[controller_id] = base::WeakPtr<VideoCaptureController>();
181 media_stream_manager_->video_capture_manager()->StartCaptureForClient( 181 media_stream_manager_->video_capture_manager()->StartCaptureForClient(
182 session_id, 182 params, PeerHandle(), controller_id, this, base::Bind(
183 params, 183 &VideoCaptureHost::OnControllerAdded, this, device_id, params));
184 PeerHandle(),
185 controller_id,
186 this,
187 base::Bind(&VideoCaptureHost::OnControllerAdded, this, device_id));
188 } 184 }
189 185
190 void VideoCaptureHost::OnControllerAdded( 186 void VideoCaptureHost::OnControllerAdded(
191 int device_id, 187 int device_id, const media::VideoCaptureParams& params,
192 const base::WeakPtr<VideoCaptureController>& controller) { 188 const base::WeakPtr<VideoCaptureController>& controller) {
193 BrowserThread::PostTask( 189 BrowserThread::PostTask(
194 BrowserThread::IO, 190 BrowserThread::IO, FROM_HERE,
195 FROM_HERE,
196 base::Bind(&VideoCaptureHost::DoControllerAddedOnIOThread, 191 base::Bind(&VideoCaptureHost::DoControllerAddedOnIOThread,
197 this, 192 this, device_id, params, controller));
198 device_id,
199 controller));
200 } 193 }
201 194
202 void VideoCaptureHost::DoControllerAddedOnIOThread( 195 void VideoCaptureHost::DoControllerAddedOnIOThread(
203 int device_id, 196 int device_id, const media::VideoCaptureParams& params,
204 const base::WeakPtr<VideoCaptureController>& controller) { 197 const base::WeakPtr<VideoCaptureController>& controller) {
205 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 198 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
206 VideoCaptureControllerID controller_id(device_id); 199 VideoCaptureControllerID controller_id(device_id);
207 EntryMap::iterator it = entries_.find(controller_id); 200 EntryMap::iterator it = entries_.find(controller_id);
208 if (it == entries_.end()) { 201 if (it == entries_.end()) {
209 if (controller) { 202 if (controller) {
210 media_stream_manager_->video_capture_manager()->StopCaptureForClient( 203 media_stream_manager_->video_capture_manager()->StopCaptureForClient(
211 controller.get(), controller_id, this); 204 controller.get(), controller_id, this);
212 } 205 }
213 return; 206 return;
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
263 return; 256 return;
264 257
265 if (it->second) { 258 if (it->second) {
266 media_stream_manager_->video_capture_manager()->StopCaptureForClient( 259 media_stream_manager_->video_capture_manager()->StopCaptureForClient(
267 it->second.get(), controller_id, this); 260 it->second.get(), controller_id, this);
268 } 261 }
269 entries_.erase(it); 262 entries_.erase(it);
270 } 263 }
271 264
272 } // namespace content 265 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698