Chromium Code Reviews| 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 "content/renderer/media/video_capture_impl.h" | 5 #include "content/renderer/media/video_capture_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 9 #include "content/child/child_process.h" | 9 #include "content/child/child_process.h" |
| 10 #include "content/common/media/video_capture_messages.h" | 10 #include "content/common/media/video_capture_messages.h" |
| (...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 203 | 203 |
| 204 ClientBufferMap::iterator iter = client_buffers_.find(buffer_id); | 204 ClientBufferMap::iterator iter = client_buffers_.find(buffer_id); |
| 205 if (iter == client_buffers_.end()) | 205 if (iter == client_buffers_.end()) |
| 206 return; | 206 return; |
| 207 | 207 |
| 208 DCHECK(!iter->second || iter->second->HasOneRef()) | 208 DCHECK(!iter->second || iter->second->HasOneRef()) |
| 209 << "Instructed to delete buffer we are still using."; | 209 << "Instructed to delete buffer we are still using."; |
| 210 client_buffers_.erase(iter); | 210 client_buffers_.erase(iter); |
| 211 } | 211 } |
| 212 | 212 |
| 213 void VideoCaptureImpl::OnBufferReceived( | 213 void VideoCaptureImpl::OnBufferReceived(int buffer_id, |
| 214 int buffer_id, | 214 const media::VideoCaptureFormat& format, |
| 215 base::TimeTicks timestamp, | 215 base::TimeTicks timestamp) { |
| 216 const media::VideoCaptureFormat& format) { | |
| 217 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); | 216 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); |
| 218 | 217 |
| 218 // The capture pipeline supports only I420 for now. | |
| 219 DCHECK_EQ(format.pixel_format, media::PIXEL_FORMAT_I420); | |
|
mcasas
2014/01/21 14:34:02
Yes! (But unfortunately :( )
| |
| 220 | |
| 219 if (state_ != VIDEO_CAPTURE_STATE_STARTED || suspended_) { | 221 if (state_ != VIDEO_CAPTURE_STATE_STARTED || suspended_) { |
| 220 Send(new VideoCaptureHostMsg_BufferReady(device_id_, buffer_id)); | 222 Send(new VideoCaptureHostMsg_BufferReady(device_id_, buffer_id, 0)); |
| 221 return; | 223 return; |
| 222 } | 224 } |
| 223 | 225 |
| 224 last_frame_format_ = format; | 226 last_frame_format_ = format; |
| 225 if (first_frame_timestamp_.is_null()) | 227 if (first_frame_timestamp_.is_null()) |
| 226 first_frame_timestamp_ = timestamp; | 228 first_frame_timestamp_ = timestamp; |
| 227 | 229 |
| 228 ClientBufferMap::iterator iter = client_buffers_.find(buffer_id); | 230 ClientBufferMap::iterator iter = client_buffers_.find(buffer_id); |
| 229 DCHECK(iter != client_buffers_.end()); | 231 DCHECK(iter != client_buffers_.end()); |
| 230 scoped_refptr<ClientBuffer> buffer = iter->second; | 232 scoped_refptr<ClientBuffer> buffer = iter->second; |
| 231 scoped_refptr<media::VideoFrame> frame = | 233 scoped_refptr<media::VideoFrame> frame = |
| 232 media::VideoFrame::WrapExternalPackedMemory( | 234 media::VideoFrame::WrapExternalPackedMemory( |
| 233 media::VideoFrame::I420, | 235 media::VideoFrame::I420, |
| 234 last_frame_format_.frame_size, | 236 last_frame_format_.frame_size, |
| 235 gfx::Rect(last_frame_format_.frame_size), | 237 gfx::Rect(last_frame_format_.frame_size), |
| 236 last_frame_format_.frame_size, | 238 last_frame_format_.frame_size, |
| 237 reinterpret_cast<uint8*>(buffer->buffer->memory()), | 239 reinterpret_cast<uint8*>(buffer->buffer->memory()), |
| 238 buffer->buffer_size, | 240 buffer->buffer_size, |
| 239 buffer->buffer->handle(), | 241 buffer->buffer->handle(), |
| 240 timestamp - first_frame_timestamp_, | 242 timestamp - first_frame_timestamp_, |
| 241 media::BindToCurrentLoop( | 243 media::BindToCurrentLoop(base::Bind( |
| 242 base::Bind( | 244 &VideoCaptureImpl::OnClientBufferFinished, |
| 243 &VideoCaptureImpl::OnClientBufferFinished, | 245 weak_this_factory_.GetWeakPtr(), |
| 244 weak_this_factory_.GetWeakPtr(), | 246 buffer_id, |
| 245 buffer_id, | 247 buffer, |
| 246 buffer))); | 248 base::Unretained(static_cast<gpu::MailboxHolder*>(NULL))))); |
| 247 | 249 |
| 248 for (ClientInfo::iterator it = clients_.begin(); it != clients_.end(); ++it) | 250 for (ClientInfo::iterator it = clients_.begin(); it != clients_.end(); ++it) |
| 249 it->first->OnFrameReady(this, frame); | 251 it->first->OnFrameReady(this, frame); |
| 252 } | |
| 253 | |
| 254 static void NullReadPixelsCB(const SkBitmap& bitmap) { NOTIMPLEMENTED(); } | |
| 255 | |
| 256 void VideoCaptureImpl::OnMailboxBufferReceived( | |
| 257 int buffer_id, | |
| 258 const gpu::MailboxHolder& mailbox_holder, | |
| 259 const media::VideoCaptureFormat& format, | |
| 260 base::TimeTicks timestamp) { | |
| 261 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); | |
| 262 | |
| 263 if (state_ != VIDEO_CAPTURE_STATE_STARTED || suspended_) { | |
| 264 Send(new VideoCaptureHostMsg_BufferReady( | |
| 265 device_id_, buffer_id, mailbox_holder.sync_point)); | |
| 266 return; | |
| 267 } | |
| 268 | |
| 269 last_frame_format_ = format; | |
| 270 if (first_frame_timestamp_.is_null()) | |
| 271 first_frame_timestamp_ = timestamp; | |
| 272 | |
| 273 scoped_refptr<media::VideoFrame> frame = media::VideoFrame::WrapNativeTexture( | |
| 274 make_scoped_ptr(new gpu::MailboxHolder(mailbox_holder)), | |
| 275 media::BindToCurrentLoop( | |
| 276 base::Bind(&VideoCaptureImpl::OnClientBufferFinished, | |
| 277 weak_this_factory_.GetWeakPtr(), | |
| 278 buffer_id, | |
| 279 scoped_refptr<ClientBuffer>())), | |
| 280 last_frame_format_.frame_size, | |
| 281 gfx::Rect(last_frame_format_.frame_size), | |
| 282 last_frame_format_.frame_size, | |
| 283 timestamp - first_frame_timestamp_, | |
| 284 base::Bind(&NullReadPixelsCB)); | |
| 285 | |
| 286 for (ClientInfo::iterator it = clients_.begin(); it != clients_.end(); ++it) | |
| 287 it->first->OnFrameReady(this, frame); | |
| 250 } | 288 } |
| 251 | 289 |
| 252 void VideoCaptureImpl::OnClientBufferFinished( | 290 void VideoCaptureImpl::OnClientBufferFinished( |
| 253 int buffer_id, | 291 int buffer_id, |
| 254 const scoped_refptr<ClientBuffer>& buffer) { | 292 const scoped_refptr<ClientBuffer>& /* ignored_buffer */, |
| 293 const gpu::MailboxHolder* mailbox_holder) { | |
| 255 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); | 294 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); |
| 256 Send(new VideoCaptureHostMsg_BufferReady(device_id_, buffer_id)); | 295 uint32 sync_point = 0; |
|
mcasas
2014/01/21 14:34:02
uint32 sync_point = mailbox_holder ? mailbox_holde
sheu
2014/01/29 01:19:20
Done.
| |
| 296 if (mailbox_holder) | |
| 297 sync_point = mailbox_holder->sync_point; | |
| 298 Send(new VideoCaptureHostMsg_BufferReady(device_id_, buffer_id, sync_point)); | |
| 257 } | 299 } |
| 258 | 300 |
| 259 void VideoCaptureImpl::OnStateChanged(VideoCaptureState state) { | 301 void VideoCaptureImpl::OnStateChanged(VideoCaptureState state) { |
| 260 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); | 302 DCHECK(io_message_loop_proxy_->BelongsToCurrentThread()); |
| 261 | 303 |
| 262 switch (state) { | 304 switch (state) { |
| 263 case VIDEO_CAPTURE_STATE_STARTED: | 305 case VIDEO_CAPTURE_STATE_STARTED: |
| 264 break; | 306 break; |
| 265 case VIDEO_CAPTURE_STATE_STOPPED: | 307 case VIDEO_CAPTURE_STATE_STOPPED: |
| 266 state_ = VIDEO_CAPTURE_STATE_STOPPED; | 308 state_ = VIDEO_CAPTURE_STATE_STOPPED; |
| (...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 373 if (it != clients->end()) { | 415 if (it != clients->end()) { |
| 374 handler->OnStopped(this); | 416 handler->OnStopped(this); |
| 375 handler->OnRemoved(this); | 417 handler->OnRemoved(this); |
| 376 clients->erase(it); | 418 clients->erase(it); |
| 377 found = true; | 419 found = true; |
| 378 } | 420 } |
| 379 return found; | 421 return found; |
| 380 } | 422 } |
| 381 | 423 |
| 382 } // namespace content | 424 } // namespace content |
| OLD | NEW |