blob: bcfcdcbdf9c8a8b32b44760c03755e44be98efbd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
/*
* Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include "pc/video_rtp_track_source.h"
#include <stddef.h>
#include <algorithm>
#include "rtc_base/checks.h"
namespace webrtc {
VideoRtpTrackSource::VideoRtpTrackSource(Callback* callback)
: VideoTrackSource(true /* remote */), callback_(callback) {
worker_sequence_checker_.Detach();
}
void VideoRtpTrackSource::ClearCallback() {
RTC_DCHECK_RUN_ON(&worker_sequence_checker_);
callback_ = nullptr;
}
rtc::VideoSourceInterface<VideoFrame>* VideoRtpTrackSource::source() {
return &broadcaster_;
}
rtc::VideoSinkInterface<VideoFrame>* VideoRtpTrackSource::sink() {
return &broadcaster_;
}
void VideoRtpTrackSource::BroadcastRecordableEncodedFrame(
const RecordableEncodedFrame& frame) const {
MutexLock lock(&mu_);
for (rtc::VideoSinkInterface<RecordableEncodedFrame>* sink : encoded_sinks_) {
sink->OnFrame(frame);
}
}
bool VideoRtpTrackSource::SupportsEncodedOutput() const {
return true;
}
void VideoRtpTrackSource::GenerateKeyFrame() {
RTC_DCHECK_RUN_ON(&worker_sequence_checker_);
if (callback_) {
callback_->OnGenerateKeyFrame();
}
}
void VideoRtpTrackSource::AddEncodedSink(
rtc::VideoSinkInterface<RecordableEncodedFrame>* sink) {
RTC_DCHECK_RUN_ON(&worker_sequence_checker_);
RTC_DCHECK(sink);
size_t size = 0;
{
MutexLock lock(&mu_);
RTC_DCHECK(std::find(encoded_sinks_.begin(), encoded_sinks_.end(), sink) ==
encoded_sinks_.end());
encoded_sinks_.push_back(sink);
size = encoded_sinks_.size();
}
if (size == 1 && callback_) {
callback_->OnEncodedSinkEnabled(true);
}
}
void VideoRtpTrackSource::RemoveEncodedSink(
rtc::VideoSinkInterface<RecordableEncodedFrame>* sink) {
RTC_DCHECK_RUN_ON(&worker_sequence_checker_);
size_t size = 0;
{
MutexLock lock(&mu_);
auto it = std::find(encoded_sinks_.begin(), encoded_sinks_.end(), sink);
if (it != encoded_sinks_.end()) {
encoded_sinks_.erase(it);
}
size = encoded_sinks_.size();
}
if (size == 0 && callback_) {
callback_->OnEncodedSinkEnabled(false);
}
}
} // namespace webrtc
|