Index: media/tools/player_x11/player_x11.cc |
diff --git a/media/tools/player_x11/player_x11.cc b/media/tools/player_x11/player_x11.cc |
index a6e5718210360851a83dcbaea16006a349e1ced7..7effec1d7ac72b7ac821e4fe09daf0019bd38d18 100644 |
--- a/media/tools/player_x11/player_x11.cc |
+++ b/media/tools/player_x11/player_x11.cc |
@@ -30,6 +30,8 @@ |
#include "media/filters/ffmpeg_demuxer.h" |
#include "media/filters/ffmpeg_video_decoder.h" |
#include "media/filters/file_data_source.h" |
+#include "media/filters/video_frame_scheduler_impl.h" |
+#include "media/filters/video_frame_scheduler_proxy.h" |
#include "media/filters/video_renderer_impl.h" |
#include "media/tools/player_x11/data_source_logger.h" |
@@ -103,7 +105,7 @@ void InitPipeline( |
media::Pipeline* pipeline, |
const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
media::Demuxer* demuxer, |
- const media::VideoRendererImpl::PaintCB& paint_cb, |
+ scoped_ptr<media::VideoFrameScheduler> scheduler, |
bool /* enable_audio */) { |
// Create our filter factories. |
scoped_ptr<media::FilterCollection> collection( |
@@ -114,10 +116,9 @@ void InitPipeline( |
video_decoders.push_back(new media::FFmpegVideoDecoder(task_runner)); |
scoped_ptr<media::VideoRenderer> video_renderer(new media::VideoRendererImpl( |
task_runner, |
+ scheduler.Pass(), |
video_decoders.Pass(), |
- media::SetDecryptorReadyCB(), |
- paint_cb, |
- true)); |
+ media::SetDecryptorReadyCB())); |
collection->SetVideoRenderer(video_renderer.Pass()); |
ScopedVector<media::AudioDecoder> audio_decoders; |
@@ -265,15 +266,23 @@ int main(int argc, char** argv) { |
base::Thread media_thread("MediaThread"); |
media_thread.Start(); |
- media::VideoRendererImpl::PaintCB paint_cb; |
+ media::VideoFrameSchedulerImpl::DisplayCB display_cb; |
if (command_line->HasSwitch("use-gl")) { |
- paint_cb = media::BindToCurrentLoop(base::Bind( |
- &GlVideoRenderer::Paint, new GlVideoRenderer(g_display, g_window))); |
+ display_cb = base::Bind(&GlVideoRenderer::Paint, |
+ new GlVideoRenderer(g_display, g_window)); |
} else { |
- paint_cb = media::BindToCurrentLoop(base::Bind( |
- &X11VideoRenderer::Paint, new X11VideoRenderer(g_display, g_window))); |
+ display_cb = base::Bind(&X11VideoRenderer::Paint, |
+ new X11VideoRenderer(g_display, g_window)); |
} |
+ scoped_ptr<media::VideoFrameScheduler> scheduler_impl( |
+ new media::VideoFrameSchedulerImpl(message_loop.message_loop_proxy(), |
+ display_cb)); |
+ scoped_ptr<media::VideoFrameScheduler> scheduler_proxy( |
+ new media::VideoFrameSchedulerProxy(media_thread.message_loop_proxy(), |
+ message_loop.message_loop_proxy(), |
+ scheduler_impl.Pass())); |
+ |
scoped_ptr<media::DataSource> data_source(new DataSourceLogger( |
CreateDataSource(filename), command_line->HasSwitch("streaming"))); |
scoped_ptr<media::Demuxer> demuxer(new media::FFmpegDemuxer( |
@@ -283,7 +292,7 @@ int main(int argc, char** argv) { |
media::Pipeline pipeline(media_thread.message_loop_proxy(), |
new media::MediaLog()); |
InitPipeline(&pipeline, media_thread.message_loop_proxy(), demuxer.get(), |
- paint_cb, command_line->HasSwitch("audio")); |
+ scheduler_proxy.Pass(), command_line->HasSwitch("audio")); |
// Main loop of the application. |
g_running = true; |
@@ -297,7 +306,7 @@ int main(int argc, char** argv) { |
// Release callback which releases video renderer. Do this before cleaning up |
// X below since the video renderer has some X cleanup duties as well. |
- paint_cb.Reset(); |
+ display_cb.Reset(); |
XDestroyWindow(g_display, g_window); |
XCloseDisplay(g_display); |