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

Unified Diff: content/renderer/media/media_recorder_handler.cc

Issue 1351473006: WebmMuxer-MediaRecorderHandler: thread hopping and data ownership (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: StringPiece passed by value Created 5 years, 3 months 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 side-by-side diff with in-line comments
Download patch
Index: content/renderer/media/media_recorder_handler.cc
diff --git a/content/renderer/media/media_recorder_handler.cc b/content/renderer/media/media_recorder_handler.cc
index 5934ef9fd11ee121a05e63fa12dcb506736b2ce8..d6ef60c9f080883c500f98216cf5fdfab57a9d85 100644
--- a/content/renderer/media/media_recorder_handler.cc
+++ b/content/renderer/media/media_recorder_handler.cc
@@ -9,6 +9,7 @@
#include "base/logging.h"
#include "content/renderer/media/video_track_recorder.h"
#include "media/base/bind_to_current_loop.h"
+#include "media/base/video_frame.h"
#include "media/capture/webm_muxer.h"
#include "third_party/WebKit/public/platform/WebMediaRecorderHandlerClient.h"
#include "third_party/WebKit/public/platform/WebString.h"
@@ -60,10 +61,10 @@ bool MediaRecorderHandler::start(int timeslice) {
DCHECK(main_render_thread_checker_.CalledOnValidThread());
DCHECK(!recording_);
DCHECK(!media_stream_.isNull());
+ DCHECK(!webm_muxer_);
- webm_muxer_.reset(new media::WebmMuxer(media::BindToCurrentLoop(base::Bind(
- &MediaRecorderHandler::WriteData, weak_factory_.GetWeakPtr()))));
- DCHECK(webm_muxer_);
+ webm_muxer_.reset(new media::WebmMuxer(base::Bind(
+ &MediaRecorderHandler::WriteData, weak_factory_.GetWeakPtr())));
blink::WebVector<blink::WebMediaStreamTrack> video_tracks;
media_stream_.videoTracks(video_tracks);
@@ -84,8 +85,8 @@ bool MediaRecorderHandler::start(int timeslice) {
return false;
const VideoTrackRecorder::OnEncodedVideoCB on_encoded_video_cb =
- base::Bind(&media::WebmMuxer::OnEncodedVideo,
- base::Unretained(webm_muxer_.get()));
+ media::BindToCurrentLoop(base::Bind(&MediaRecorderHandler::OnEncodedVideo,
+ weak_factory_.GetWeakPtr()));
video_recorders_.push_back(new VideoTrackRecorder(video_track,
on_encoded_video_cb));
@@ -100,7 +101,7 @@ void MediaRecorderHandler::stop() {
recording_ = false;
video_recorders_.clear();
- webm_muxer_.reset(NULL);
+ webm_muxer_.reset();
}
void MediaRecorderHandler::pause() {
@@ -117,9 +118,21 @@ void MediaRecorderHandler::resume() {
NOTIMPLEMENTED();
}
-void MediaRecorderHandler::WriteData(const base::StringPiece& data) {
+void MediaRecorderHandler::OnEncodedVideo(
+ const scoped_refptr<media::VideoFrame>& video_frame,
+ scoped_ptr<std::string> encoded_data,
+ base::TimeTicks timestamp,
+ bool is_key_frame) {
DCHECK(main_render_thread_checker_.CalledOnValidThread());
- client_->writeData(data.data(), data.size(), false /* lastInSlice */);
+ if (webm_muxer_) {
+ webm_muxer_->OnEncodedVideo(video_frame, encoded_data.Pass(), timestamp,
+ is_key_frame);
+ }
+}
+
+void MediaRecorderHandler::WriteData(base::StringPiece data) {
+ DCHECK(main_render_thread_checker_.CalledOnValidThread());
+ client_->writeData(data.data(), data.length(), false /* lastInSlice */);
}
void MediaRecorderHandler::OnVideoFrameForTesting(
« no previous file with comments | « content/renderer/media/media_recorder_handler.h ('k') | content/renderer/media/media_recorder_handler_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698