| OLD | NEW |
| 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 "media/cast/cast_sender_impl.h" | 5 #include "media/cast/cast_sender_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 98 CHECK(audio_config.use_external_encoder || | 98 CHECK(audio_config.use_external_encoder || |
| 99 cast_environment_->HasAudioThread()); | 99 cast_environment_->HasAudioThread()); |
| 100 | 100 |
| 101 VLOG(1) << "CastSenderImpl@" << this << "::InitializeAudio()"; | 101 VLOG(1) << "CastSenderImpl@" << this << "::InitializeAudio()"; |
| 102 | 102 |
| 103 audio_sender_.reset( | 103 audio_sender_.reset( |
| 104 new AudioSender(cast_environment_, audio_config, transport_sender_)); | 104 new AudioSender(cast_environment_, audio_config, transport_sender_)); |
| 105 | 105 |
| 106 const CastInitializationStatus status = audio_sender_->InitializationResult(); | 106 const CastInitializationStatus status = audio_sender_->InitializationResult(); |
| 107 if (status == STATUS_AUDIO_INITIALIZED) { | 107 if (status == STATUS_AUDIO_INITIALIZED) { |
| 108 ssrc_of_audio_sender_ = audio_config.incoming_feedback_ssrc; | |
| 109 audio_frame_input_ = | 108 audio_frame_input_ = |
| 110 new LocalAudioFrameInput(cast_environment_, audio_sender_->AsWeakPtr()); | 109 new LocalAudioFrameInput(cast_environment_, audio_sender_->AsWeakPtr()); |
| 111 } | 110 } |
| 112 cast_initialization_cb.Run(status); | 111 cast_initialization_cb.Run(status); |
| 113 if (video_sender_) { | 112 if (video_sender_) { |
| 114 DCHECK(audio_sender_->GetTargetPlayoutDelay() == | 113 DCHECK(audio_sender_->GetTargetPlayoutDelay() == |
| 115 video_sender_->GetTargetPlayoutDelay()); | 114 video_sender_->GetTargetPlayoutDelay()); |
| 116 } | 115 } |
| 117 } | 116 } |
| 118 | 117 |
| 119 void CastSenderImpl::InitializeVideo( | 118 void CastSenderImpl::InitializeVideo( |
| 120 const VideoSenderConfig& video_config, | 119 const VideoSenderConfig& video_config, |
| 121 const CastInitializationCallback& cast_initialization_cb, | 120 const CastInitializationCallback& cast_initialization_cb, |
| 122 const CreateVideoEncodeAcceleratorCallback& create_vea_cb, | 121 const CreateVideoEncodeAcceleratorCallback& create_vea_cb, |
| 123 const CreateVideoEncodeMemoryCallback& create_video_encode_mem_cb) { | 122 const CreateVideoEncodeMemoryCallback& create_video_encode_mem_cb) { |
| 124 DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN)); | 123 DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN)); |
| 125 CHECK(video_config.use_external_encoder || | 124 CHECK(video_config.use_external_encoder || |
| 126 cast_environment_->HasVideoThread()); | 125 cast_environment_->HasVideoThread()); |
| 127 | 126 |
| 128 VLOG(1) << "CastSenderImpl@" << this << "::InitializeVideo()"; | 127 VLOG(1) << "CastSenderImpl@" << this << "::InitializeVideo()"; |
| 129 | 128 |
| 130 video_sender_.reset(new VideoSender(cast_environment_, | 129 video_sender_.reset(new VideoSender( |
| 131 video_config, | 130 cast_environment_, |
| 132 create_vea_cb, | 131 video_config, |
| 133 create_video_encode_mem_cb, | 132 base::Bind(&CastSenderImpl::OnVideoInitialized, |
| 134 transport_sender_)); | 133 weak_factory_.GetWeakPtr(), cast_initialization_cb), |
| 135 | 134 create_vea_cb, |
| 136 const CastInitializationStatus status = video_sender_->InitializationResult(); | 135 create_video_encode_mem_cb, |
| 137 if (status == STATUS_VIDEO_INITIALIZED) { | 136 transport_sender_)); |
| 138 ssrc_of_video_sender_ = video_config.incoming_feedback_ssrc; | |
| 139 video_frame_input_ = | |
| 140 new LocalVideoFrameInput(cast_environment_, video_sender_->AsWeakPtr()); | |
| 141 } | |
| 142 cast_initialization_cb.Run(status); | |
| 143 if (audio_sender_) { | 137 if (audio_sender_) { |
| 144 DCHECK(audio_sender_->GetTargetPlayoutDelay() == | 138 DCHECK(audio_sender_->GetTargetPlayoutDelay() == |
| 145 video_sender_->GetTargetPlayoutDelay()); | 139 video_sender_->GetTargetPlayoutDelay()); |
| 146 } | 140 } |
| 147 } | 141 } |
| 148 | 142 |
| 149 CastSenderImpl::~CastSenderImpl() { | 143 CastSenderImpl::~CastSenderImpl() { |
| 150 VLOG(1) << "CastSenderImpl@" << this << "::~CastSenderImpl()"; | 144 VLOG(1) << "CastSenderImpl@" << this << "::~CastSenderImpl()"; |
| 151 } | 145 } |
| 152 | 146 |
| (...skipping 10 matching lines...) Expand all Loading... |
| 163 VLOG(1) << "CastSenderImpl@" << this << "::SetTargetPlayoutDelay(" | 157 VLOG(1) << "CastSenderImpl@" << this << "::SetTargetPlayoutDelay(" |
| 164 << new_target_playout_delay.InMilliseconds() << " ms)"; | 158 << new_target_playout_delay.InMilliseconds() << " ms)"; |
| 165 if (audio_sender_) { | 159 if (audio_sender_) { |
| 166 audio_sender_->SetTargetPlayoutDelay(new_target_playout_delay); | 160 audio_sender_->SetTargetPlayoutDelay(new_target_playout_delay); |
| 167 } | 161 } |
| 168 if (video_sender_) { | 162 if (video_sender_) { |
| 169 video_sender_->SetTargetPlayoutDelay(new_target_playout_delay); | 163 video_sender_->SetTargetPlayoutDelay(new_target_playout_delay); |
| 170 } | 164 } |
| 171 } | 165 } |
| 172 | 166 |
| 167 void CastSenderImpl::OnVideoInitialized( |
| 168 const CastInitializationCallback& initialization_cb, |
| 169 media::cast::CastInitializationStatus result) { |
| 170 DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN)); |
| 171 video_frame_input_ = |
| 172 new LocalVideoFrameInput(cast_environment_, video_sender_->AsWeakPtr()); |
| 173 initialization_cb.Run(result); |
| 174 } |
| 175 |
| 173 } // namespace cast | 176 } // namespace cast |
| 174 } // namespace media | 177 } // namespace media |
| OLD | NEW |