0
点赞
收藏
分享

微信扫一扫

webrtc 自定义对接摄像机视频流

​​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里面

举报

相关推荐

0 条评论