https://blog.csdn.net/u013113491/article/details/80285181
编码器伪装法
https://blog.csdn.net/foruok/article/details/70237019
众所周知浏览器不支持H265解码,可以在这里进行转码成H264,发送出去
int32_t RegisterEncodeCompleteCallback(webrtc::EncodedImageCallback* callback) override
获取编码完成以后需要调用的函数,
该函数实现了如何发现已经编码好的数据
编码好一帧数据,开始发送给客户端
webrtc::EncodedImageCallback::Result r = callback->OnEncodedImage(encoded, &codec_specific);
CreatePeerConnectionFactory
支持创建自定义的编解码器
码流伪装法
https://blog.csdn.net/u013113491/article/details/80285342
[WEBRTC]自定义视频源 - 简书 (jianshu.com)
监听视频流
video_track->AddOrUpdateSink(&((MediaStream*)local_stream_.get())->videoObserver(), rtc::VideoSinkWants());
分析一下VideoTrackSource和videoTrack的关系
videoTrack实现VideoTrackInterface,有下面三个重要接口:
void AddOrUpdateSink(rtc::VideoSinkInterface* sink,
const rtc::VideoSinkWants& wants) override {}
void RemoveSink(rtc::VideoSinkInterface* sink) override {}
virtual VideoTrackSourceInterface* GetSource() const = 0;
实际上,是通过 GetSource(),找到source,然后在AddOrUpdateSink,RemoveSink时,调用source的对应方法,将数据的消费者注册到source里面
标签:AddOrUpdateSink,自定义,rtc,视频流,blog,source,override,webrtc From: https://blog.51cto.com/fengyuzaitu/6040283