| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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_track_recorder.h" | 5 #include "content/renderer/media/video_track_recorder.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 376 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 387 const OnEncodedVideoCB& on_encoded_video_callback, | 387 const OnEncodedVideoCB& on_encoded_video_callback, |
| 388 int32_t bits_per_second) | 388 int32_t bits_per_second) |
| 389 : track_(track), | 389 : track_(track), |
| 390 encoder_( | 390 encoder_( |
| 391 new VpxEncoder(use_vp9, on_encoded_video_callback, bits_per_second)) { | 391 new VpxEncoder(use_vp9, on_encoded_video_callback, bits_per_second)) { |
| 392 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | 392 DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| 393 DCHECK(!track_.isNull()); | 393 DCHECK(!track_.isNull()); |
| 394 DCHECK(track_.getExtraData()); | 394 DCHECK(track_.getExtraData()); |
| 395 | 395 |
| 396 // StartFrameEncode() will be called on Render IO thread. | 396 // StartFrameEncode() will be called on Render IO thread. |
| 397 AddToVideoTrack(this, | 397 MediaStreamVideoSink::ConnectToTrack( |
| 398 base::Bind(&VideoTrackRecorder::VpxEncoder::StartFrameEncode, | 398 track_, |
| 399 encoder_), | 399 base::Bind(&VideoTrackRecorder::VpxEncoder::StartFrameEncode, encoder_)); |
| 400 track_); | |
| 401 } | 400 } |
| 402 | 401 |
| 403 VideoTrackRecorder::~VideoTrackRecorder() { | 402 VideoTrackRecorder::~VideoTrackRecorder() { |
| 404 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | 403 DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| 405 RemoveFromVideoTrack(this, track_); | 404 MediaStreamVideoSink::DisconnectFromTrack(); |
| 406 track_.reset(); | 405 track_.reset(); |
| 407 } | 406 } |
| 408 | 407 |
| 409 void VideoTrackRecorder::Pause() { | 408 void VideoTrackRecorder::Pause() { |
| 410 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | 409 DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| 411 DCHECK(encoder_); | 410 DCHECK(encoder_); |
| 412 encoder_->set_paused(true); | 411 encoder_->set_paused(true); |
| 413 } | 412 } |
| 414 | 413 |
| 415 void VideoTrackRecorder::Resume() { | 414 void VideoTrackRecorder::Resume() { |
| 416 DCHECK(main_render_thread_checker_.CalledOnValidThread()); | 415 DCHECK(main_render_thread_checker_.CalledOnValidThread()); |
| 417 DCHECK(encoder_); | 416 DCHECK(encoder_); |
| 418 encoder_->set_paused(false); | 417 encoder_->set_paused(false); |
| 419 } | 418 } |
| 420 | 419 |
| 421 void VideoTrackRecorder::OnVideoFrameForTesting( | 420 void VideoTrackRecorder::OnVideoFrameForTesting( |
| 422 const scoped_refptr<media::VideoFrame>& frame, | 421 const scoped_refptr<media::VideoFrame>& frame, |
| 423 base::TimeTicks timestamp) { | 422 base::TimeTicks timestamp) { |
| 424 encoder_->StartFrameEncode(frame, timestamp); | 423 encoder_->StartFrameEncode(frame, timestamp); |
| 425 } | 424 } |
| 426 | 425 |
| 427 } // namespace content | 426 } // namespace content |
| OLD | NEW |