blob: 4f88f1c0be7704db3e94e2ad3b849116a92b2b54 [file] [log] [blame]
deadbeef6979b022015-09-24 23:47:531/*
kjellanderb24317b2016-02-10 15:54:432 * Copyright 2015 The WebRTC project authors. All Rights Reserved.
deadbeef6979b022015-09-24 23:47:533 *
kjellanderb24317b2016-02-10 15:54:434 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
deadbeef6979b022015-09-24 23:47:539 */
10
Mirko Bonadei92ea95e2017-09-15 04:47:3111#include "pc/rtpreceiver.h"
deadbeef6979b022015-09-24 23:47:5312
Mirko Bonadei92ea95e2017-09-15 04:47:3113#include "api/mediastreamtrackproxy.h"
14#include "api/videosourceproxy.h"
15#include "pc/audiotrack.h"
16#include "pc/videotrack.h"
17#include "rtc_base/trace_event.h"
deadbeef70ab1a12015-09-28 23:53:5518
19namespace webrtc {
20
deadbeefe814a0d2017-02-26 02:15:0921AudioRtpReceiver::AudioRtpReceiver(const std::string& track_id,
Peter Boström0c4e06b2015-10-07 10:23:2122 uint32_t ssrc,
Taylor Brandstetterba29c6a2016-06-27 23:30:3523 cricket::VoiceChannel* channel)
perkjd61bf802016-03-24 10:16:1924 : id_(track_id),
deadbeef70ab1a12015-09-28 23:53:5525 ssrc_(ssrc),
Taylor Brandstetterba29c6a2016-06-27 23:30:3526 channel_(channel),
perkjd61bf802016-03-24 10:16:1927 track_(AudioTrackProxy::Create(
28 rtc::Thread::Current(),
29 AudioTrack::Create(track_id,
Taylor Brandstetterba29c6a2016-06-27 23:30:3530 RemoteAudioSource::Create(ssrc, channel)))),
perkjd61bf802016-03-24 10:16:1931 cached_track_enabled_(track_->enabled()) {
tommi6eca7e32015-12-15 12:27:1132 RTC_DCHECK(track_->GetSource()->remote());
deadbeef70ab1a12015-09-28 23:53:5533 track_->RegisterObserver(this);
34 track_->GetSource()->RegisterAudioObserver(this);
35 Reconfigure();
Taylor Brandstetterba29c6a2016-06-27 23:30:3536 if (channel_) {
37 channel_->SignalFirstPacketReceived.connect(
38 this, &AudioRtpReceiver::OnFirstPacketReceived);
39 }
deadbeef70ab1a12015-09-28 23:53:5540}
41
42AudioRtpReceiver::~AudioRtpReceiver() {
43 track_->GetSource()->UnregisterAudioObserver(this);
44 track_->UnregisterObserver(this);
45 Stop();
46}
47
48void AudioRtpReceiver::OnChanged() {
49 if (cached_track_enabled_ != track_->enabled()) {
50 cached_track_enabled_ = track_->enabled();
51 Reconfigure();
52 }
53}
54
55void AudioRtpReceiver::OnSetVolume(double volume) {
kwibergee89e782017-08-10 00:22:0156 RTC_DCHECK_GE(volume, 0);
57 RTC_DCHECK_LE(volume, 10);
Taylor Brandstetterba29c6a2016-06-27 23:30:3558 cached_volume_ = volume;
59 if (!channel_) {
60 LOG(LS_ERROR) << "AudioRtpReceiver::OnSetVolume: No audio channel exists.";
61 return;
62 }
deadbeef70ab1a12015-09-28 23:53:5563 // When the track is disabled, the volume of the source, which is the
64 // corresponding WebRtc Voice Engine channel will be 0. So we do not allow
65 // setting the volume to the source when the track is disabled.
Taylor Brandstetterba29c6a2016-06-27 23:30:3566 if (!stopped_ && track_->enabled()) {
67 if (!channel_->SetOutputVolume(ssrc_, cached_volume_)) {
nisseeb4ca4e2017-01-12 10:24:2768 RTC_NOTREACHED();
Taylor Brandstetterba29c6a2016-06-27 23:30:3569 }
70 }
deadbeef70ab1a12015-09-28 23:53:5571}
72
Taylor Brandstetterdb0cd9e2016-05-16 18:40:3073RtpParameters AudioRtpReceiver::GetParameters() const {
Taylor Brandstetterba29c6a2016-06-27 23:30:3574 if (!channel_ || stopped_) {
75 return RtpParameters();
76 }
77 return channel_->GetRtpReceiveParameters(ssrc_);
Taylor Brandstetterdb0cd9e2016-05-16 18:40:3078}
79
80bool AudioRtpReceiver::SetParameters(const RtpParameters& parameters) {
81 TRACE_EVENT0("webrtc", "AudioRtpReceiver::SetParameters");
Taylor Brandstetterba29c6a2016-06-27 23:30:3582 if (!channel_ || stopped_) {
83 return false;
84 }
85 return channel_->SetRtpReceiveParameters(ssrc_, parameters);
Taylor Brandstetterdb0cd9e2016-05-16 18:40:3086}
87
deadbeefa601f5c2016-06-06 21:27:3988void AudioRtpReceiver::Stop() {
89 // TODO(deadbeef): Need to do more here to fully stop receiving packets.
Taylor Brandstetterba29c6a2016-06-27 23:30:3590 if (stopped_) {
deadbeefa601f5c2016-06-06 21:27:3991 return;
92 }
Taylor Brandstetterba29c6a2016-06-27 23:30:3593 if (channel_) {
94 // Allow that SetOutputVolume fail. This is the normal case when the
95 // underlying media channel has already been deleted.
96 channel_->SetOutputVolume(ssrc_, 0);
97 }
98 stopped_ = true;
deadbeefa601f5c2016-06-06 21:27:3999}
100
hbos8d609f62017-04-10 14:39:05101std::vector<RtpSource> AudioRtpReceiver::GetSources() const {
102 return channel_->GetSources(ssrc_);
103}
104
deadbeef70ab1a12015-09-28 23:53:55105void AudioRtpReceiver::Reconfigure() {
Taylor Brandstetterba29c6a2016-06-27 23:30:35106 RTC_DCHECK(!stopped_);
107 if (!channel_) {
108 LOG(LS_ERROR) << "AudioRtpReceiver::Reconfigure: No audio channel exists.";
deadbeef70ab1a12015-09-28 23:53:55109 return;
110 }
Taylor Brandstetterba29c6a2016-06-27 23:30:35111 if (!channel_->SetOutputVolume(ssrc_,
112 track_->enabled() ? cached_volume_ : 0)) {
nisseeb4ca4e2017-01-12 10:24:27113 RTC_NOTREACHED();
Taylor Brandstetterba29c6a2016-06-27 23:30:35114 }
deadbeef70ab1a12015-09-28 23:53:55115}
116
zhihuang184a3fd2016-06-14 18:47:14117void AudioRtpReceiver::SetObserver(RtpReceiverObserverInterface* observer) {
118 observer_ = observer;
Taylor Brandstetterba29c6a2016-06-27 23:30:35119 // Deliver any notifications the observer may have missed by being set late.
zhihuangc4adabf2016-12-07 18:36:40120 if (received_first_packet_ && observer_) {
zhihuang184a3fd2016-06-14 18:47:14121 observer_->OnFirstPacketReceived(media_type());
122 }
123}
124
Taylor Brandstetterba29c6a2016-06-27 23:30:35125void AudioRtpReceiver::SetChannel(cricket::VoiceChannel* channel) {
126 if (channel_) {
127 channel_->SignalFirstPacketReceived.disconnect(this);
128 }
129 channel_ = channel;
130 if (channel_) {
131 channel_->SignalFirstPacketReceived.connect(
132 this, &AudioRtpReceiver::OnFirstPacketReceived);
133 }
134}
135
136void AudioRtpReceiver::OnFirstPacketReceived(cricket::BaseChannel* channel) {
zhihuang184a3fd2016-06-14 18:47:14137 if (observer_) {
138 observer_->OnFirstPacketReceived(media_type());
139 }
140 received_first_packet_ = true;
141}
142
deadbeefe814a0d2017-02-26 02:15:09143VideoRtpReceiver::VideoRtpReceiver(const std::string& track_id,
perkjf0dcfe22016-03-10 17:32:00144 rtc::Thread* worker_thread,
Peter Boström0c4e06b2015-10-07 10:23:21145 uint32_t ssrc,
Taylor Brandstetterba29c6a2016-06-27 23:30:35146 cricket::VideoChannel* channel)
perkjf0dcfe22016-03-10 17:32:00147 : id_(track_id),
148 ssrc_(ssrc),
Taylor Brandstetterba29c6a2016-06-27 23:30:35149 channel_(channel),
perkjf0dcfe22016-03-10 17:32:00150 source_(new RefCountedObject<VideoTrackSource>(&broadcaster_,
perkjf0dcfe22016-03-10 17:32:00151 true /* remote */)),
152 track_(VideoTrackProxy::Create(
153 rtc::Thread::Current(),
nisse5b68ab52016-04-07 14:45:54154 worker_thread,
155 VideoTrack::Create(
156 track_id,
157 VideoTrackSourceProxy::Create(rtc::Thread::Current(),
158 worker_thread,
perkj773be362017-08-01 06:22:01159 source_),
160 worker_thread))) {
perkjf0dcfe22016-03-10 17:32:00161 source_->SetState(MediaSourceInterface::kLive);
Taylor Brandstetterba29c6a2016-06-27 23:30:35162 if (!channel_) {
163 LOG(LS_ERROR)
164 << "VideoRtpReceiver::VideoRtpReceiver: No video channel exists.";
165 } else {
166 if (!channel_->SetSink(ssrc_, &broadcaster_)) {
nisseeb4ca4e2017-01-12 10:24:27167 RTC_NOTREACHED();
Taylor Brandstetterba29c6a2016-06-27 23:30:35168 }
169 }
Taylor Brandstetterba29c6a2016-06-27 23:30:35170 if (channel_) {
171 channel_->SignalFirstPacketReceived.connect(
172 this, &VideoRtpReceiver::OnFirstPacketReceived);
173 }
deadbeef70ab1a12015-09-28 23:53:55174}
175
176VideoRtpReceiver::~VideoRtpReceiver() {
177 // Since cricket::VideoRenderer is not reference counted,
Taylor Brandstetterba29c6a2016-06-27 23:30:35178 // we need to remove it from the channel before we are deleted.
deadbeef70ab1a12015-09-28 23:53:55179 Stop();
180}
181
deadbeefa601f5c2016-06-06 21:27:39182RtpParameters VideoRtpReceiver::GetParameters() const {
Taylor Brandstetterba29c6a2016-06-27 23:30:35183 if (!channel_ || stopped_) {
184 return RtpParameters();
185 }
186 return channel_->GetRtpReceiveParameters(ssrc_);
deadbeefa601f5c2016-06-06 21:27:39187}
188
189bool VideoRtpReceiver::SetParameters(const RtpParameters& parameters) {
190 TRACE_EVENT0("webrtc", "VideoRtpReceiver::SetParameters");
Taylor Brandstetterba29c6a2016-06-27 23:30:35191 if (!channel_ || stopped_) {
192 return false;
193 }
194 return channel_->SetRtpReceiveParameters(ssrc_, parameters);
deadbeefa601f5c2016-06-06 21:27:39195}
196
deadbeef70ab1a12015-09-28 23:53:55197void VideoRtpReceiver::Stop() {
198 // TODO(deadbeef): Need to do more here to fully stop receiving packets.
Taylor Brandstetterba29c6a2016-06-27 23:30:35199 if (stopped_) {
deadbeef70ab1a12015-09-28 23:53:55200 return;
201 }
perkjf0dcfe22016-03-10 17:32:00202 source_->SetState(MediaSourceInterface::kEnded);
203 source_->OnSourceDestroyed();
Taylor Brandstetterba29c6a2016-06-27 23:30:35204 if (!channel_) {
205 LOG(LS_WARNING) << "VideoRtpReceiver::Stop: No video channel exists.";
206 } else {
207 // Allow that SetSink fail. This is the normal case when the underlying
208 // media channel has already been deleted.
209 channel_->SetSink(ssrc_, nullptr);
210 }
211 stopped_ = true;
deadbeef70ab1a12015-09-28 23:53:55212}
213
zhihuang184a3fd2016-06-14 18:47:14214void VideoRtpReceiver::SetObserver(RtpReceiverObserverInterface* observer) {
215 observer_ = observer;
Taylor Brandstetterba29c6a2016-06-27 23:30:35216 // Deliver any notifications the observer may have missed by being set late.
zhihuangc4adabf2016-12-07 18:36:40217 if (received_first_packet_ && observer_) {
zhihuang184a3fd2016-06-14 18:47:14218 observer_->OnFirstPacketReceived(media_type());
219 }
220}
221
Taylor Brandstetterba29c6a2016-06-27 23:30:35222void VideoRtpReceiver::SetChannel(cricket::VideoChannel* channel) {
223 if (channel_) {
224 channel_->SignalFirstPacketReceived.disconnect(this);
225 channel_->SetSink(ssrc_, nullptr);
226 }
227 channel_ = channel;
228 if (channel_) {
229 if (!channel_->SetSink(ssrc_, &broadcaster_)) {
nisseeb4ca4e2017-01-12 10:24:27230 RTC_NOTREACHED();
Taylor Brandstetterba29c6a2016-06-27 23:30:35231 }
232 channel_->SignalFirstPacketReceived.connect(
233 this, &VideoRtpReceiver::OnFirstPacketReceived);
234 }
235}
236
237void VideoRtpReceiver::OnFirstPacketReceived(cricket::BaseChannel* channel) {
zhihuang184a3fd2016-06-14 18:47:14238 if (observer_) {
239 observer_->OnFirstPacketReceived(media_type());
240 }
241 received_first_packet_ = true;
242}
243
deadbeef70ab1a12015-09-28 23:53:55244} // namespace webrtc