| 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 <signal.h> | 5 #include <signal.h> |
| 6 | 6 |
| 7 #include <iostream> // NOLINT | 7 #include <iostream> // NOLINT |
| 8 | 8 |
| 9 #include "base/at_exit.h" | 9 #include "base/at_exit.h" |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| (...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 115 scoped_ptr<media::FilterCollection> collection( | 115 scoped_ptr<media::FilterCollection> collection( |
| 116 new media::FilterCollection()); | 116 new media::FilterCollection()); |
| 117 collection->SetDemuxer(new media::FFmpegDemuxer(message_loop, data_source)); | 117 collection->SetDemuxer(new media::FFmpegDemuxer(message_loop, data_source)); |
| 118 collection->AddAudioDecoder(new media::FFmpegAudioDecoder( | 118 collection->AddAudioDecoder(new media::FFmpegAudioDecoder( |
| 119 base::Bind(&media::MessageLoopFactory::GetMessageLoop, | 119 base::Bind(&media::MessageLoopFactory::GetMessageLoop, |
| 120 base::Unretained(message_loop_factory), | 120 base::Unretained(message_loop_factory), |
| 121 "AudioDecoderThread"))); | 121 "AudioDecoderThread"))); |
| 122 collection->AddVideoDecoder(new media::FFmpegVideoDecoder( | 122 collection->AddVideoDecoder(new media::FFmpegVideoDecoder( |
| 123 base::Bind(&media::MessageLoopFactory::GetMessageLoop, | 123 base::Bind(&media::MessageLoopFactory::GetMessageLoop, |
| 124 base::Unretained(message_loop_factory), | 124 base::Unretained(message_loop_factory), |
| 125 "VideoDecoderThread"))); | 125 "VideoDecoderThread"), |
| 126 NULL)); |
| 126 | 127 |
| 127 // Create our video renderer and save a reference to it for painting. | 128 // Create our video renderer and save a reference to it for painting. |
| 128 g_video_renderer = new media::VideoRendererBase( | 129 g_video_renderer = new media::VideoRendererBase( |
| 129 base::Bind(&Paint, paint_message_loop, paint_cb), | 130 base::Bind(&Paint, paint_message_loop, paint_cb), |
| 130 base::Bind(&SetOpaque), | 131 base::Bind(&SetOpaque), |
| 131 true); | 132 true); |
| 132 collection->AddVideoRenderer(g_video_renderer); | 133 collection->AddVideoRenderer(g_video_renderer); |
| 133 | 134 |
| 134 collection->AddAudioRenderer( | 135 collection->AddAudioRenderer( |
| 135 new media::AudioRendererImpl(new media::NullAudioSink())); | 136 new media::AudioRendererImpl(new media::NullAudioSink())); |
| (...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 303 // Release callback which releases video renderer. Do this before cleaning up | 304 // Release callback which releases video renderer. Do this before cleaning up |
| 304 // X below since the video renderer has some X cleanup duties as well. | 305 // X below since the video renderer has some X cleanup duties as well. |
| 305 paint_cb.Reset(); | 306 paint_cb.Reset(); |
| 306 | 307 |
| 307 XDestroyWindow(g_display, g_window); | 308 XDestroyWindow(g_display, g_window); |
| 308 XCloseDisplay(g_display); | 309 XCloseDisplay(g_display); |
| 309 g_audio_manager = NULL; | 310 g_audio_manager = NULL; |
| 310 | 311 |
| 311 return 0; | 312 return 0; |
| 312 } | 313 } |
| OLD | NEW |