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

Side by Side Diff: content/renderer/media/media_stream_video_track.cc

Issue 287313002: Pass a TimeTicks along video capture pipeline to represent capture time (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/media_stream_video_track.h" 5 #include "content/renderer/media/media_stream_video_track.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "content/renderer/media/video_frame_deliverer.h" 8 #include "content/renderer/media/video_frame_deliverer.h"
9 #include "media/base/bind_to_current_loop.h" 9 #include "media/base/bind_to_current_loop.h"
10 10
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
46 void SetEnabled(bool enabled) { 46 void SetEnabled(bool enabled) {
47 DCHECK(thread_checker().CalledOnValidThread()); 47 DCHECK(thread_checker().CalledOnValidThread());
48 io_message_loop()->PostTask( 48 io_message_loop()->PostTask(
49 FROM_HERE, 49 FROM_HERE,
50 base::Bind(&MediaStreamVideoTrack::FrameDeliverer::SetEnabledOnIO, 50 base::Bind(&MediaStreamVideoTrack::FrameDeliverer::SetEnabledOnIO,
51 this, enabled)); 51 this, enabled));
52 } 52 }
53 53
54 virtual void DeliverFrameOnIO( 54 virtual void DeliverFrameOnIO(
55 const scoped_refptr<media::VideoFrame>& frame, 55 const scoped_refptr<media::VideoFrame>& frame,
56 const media::VideoCaptureFormat& format) OVERRIDE { 56 const media::VideoCaptureFormat& format,
57 const base::TimeTicks& start_ticks) OVERRIDE {
57 DCHECK(io_message_loop()->BelongsToCurrentThread()); 58 DCHECK(io_message_loop()->BelongsToCurrentThread());
58 if (!enabled_) 59 if (!enabled_)
59 return; 60 return;
60 VideoFrameDeliverer::DeliverFrameOnIO(frame, format); 61 VideoFrameDeliverer::DeliverFrameOnIO(frame, format, start_ticks);
61 } 62 }
62 63
63 const std::vector<MediaStreamVideoSink*>& sinks() const { return sinks_; } 64 const std::vector<MediaStreamVideoSink*>& sinks() const { return sinks_; }
64 65
65 protected: 66 protected:
66 virtual ~FrameDeliverer() { 67 virtual ~FrameDeliverer() {
67 DCHECK(sinks_.empty()); 68 DCHECK(sinks_.empty());
68 } 69 }
69 70
70 void SetEnabledOnIO(bool enabled) { 71 void SetEnabledOnIO(bool enabled) {
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after
163 blink::WebMediaStreamSource::ReadyState state) { 164 blink::WebMediaStreamSource::ReadyState state) {
164 DCHECK(thread_checker_.CalledOnValidThread()); 165 DCHECK(thread_checker_.CalledOnValidThread());
165 const std::vector<MediaStreamVideoSink*>& sinks = frame_deliverer_->sinks(); 166 const std::vector<MediaStreamVideoSink*>& sinks = frame_deliverer_->sinks();
166 for (std::vector<MediaStreamVideoSink*>::const_iterator it = sinks.begin(); 167 for (std::vector<MediaStreamVideoSink*>::const_iterator it = sinks.begin();
167 it != sinks.end(); ++it) { 168 it != sinks.end(); ++it) {
168 (*it)->OnReadyStateChanged(state); 169 (*it)->OnReadyStateChanged(state);
169 } 170 }
170 } 171 }
171 172
172 } // namespace content 173 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698