zoukankan      html  css  js  c++  java
  • 有关live555

        Source和Sink:可以把source理解为发送端的流,sink理解为接受端。MediaSink是各种类型的Sink的基类,MediaSource是各种类型Source的基类,各种类型的流媒体格式和编码的支持即是通过对这两个类的派生实现的。Source和Sink通过RTP子会话(MediaSubSession)联系在一起。

       FramedSource 派生自MediaSource, 一帧码流的实现。私有unsigned char* fTo; // in  是指向发送的码流的指针。

    重要的函数有 getNextFrame

    void FramedSource::getNextFrame(unsigned char* to, unsigned maxSize,
    				afterGettingFunc* afterGettingFunc,
    				void* afterGettingClientData,
    				onCloseFunc* onCloseFunc,
    				void* onCloseClientData) {
      // Make sure we're not already being read:
      if (fIsCurrentlyAwaitingData) {
        envir() << "FramedSource[" << this << "]::getNextFrame(): attempting to read more than once at the same time!\n";
        envir().internalError();
      }
    
      fTo = to;
      fMaxSize = maxSize;
      fNumTruncatedBytes = 0; // by default; could be changed by doGetNextFrame()
      fDurationInMicroseconds = 0; // by default; could be changed by doGetNextFrame()
      fAfterGettingFunc = afterGettingFunc;
      fAfterGettingClientData = afterGettingClientData;
      fOnCloseFunc = onCloseFunc;
      fOnCloseClientData = onCloseClientData;
      fIsCurrentlyAwaitingData = True;
    
      doGetNextFrame();
    }
    

      

    doGetNextFrame(); 是一个虚函数,具体各种编码模式,我们可以根据自己的码流类型定义一个派生自FramedSource的类, 重新再定义doGetNextFrame如何获得下一帧的码流。在自己重定义的doGetNextFrame() 中将fTo指向要发送的缓存。


    我们可以通过doGetNextFrame() 是fTo重定向我们要发送的流,而不是从文件中读取。(搞定了source)之后就是要如何让fTo与发送会话连接起来,OnDemandServerMediaSubsession由 ServerMediaSubsession 派生而来,其有一个新的私有函数 virtual FramedSource* createNewStreamSource,我们又可以重新定义一个派生自OnDemandServerMediaSubsession 的类,重新定义createNewStreamSource 将fTo 与 ServerMedia联系起来。
    如下live555中的例子

    FramedSource* H264VideoFileServerMediaSubsession::createNewStreamSource(unsigned /*clientSessionId*/, unsigned& estBitrate) {
      estBitrate = 500; // kbps, estimate
    
      // Create the video source:
      ByteStreamFileSource* fileSource = ByteStreamFileSource::createNew(envir(), fFileName);
      if (fileSource == NULL) return NULL;
      fFileSize = fileSource->fileSize();
    
      // Create a framer for the Video Elementary Stream:
      return H264VideoStreamFramer::createNew(envir(), fileSource);
    }
    ByteStreamFileSource说到底还是继承自FramedSource,定义了从文件获取source的方法,而这个函数又将ServerMedia 与source联系了起来,
    ServerMedia 就知道该发送什么东东了。  return H264VideoStreamFramer::createNew(envir(), fileSource); 给 ServerMedia  返回了一个 FramedSource 。
    不过,如果自己定义的ServerMedia直接从 OnDemandServerMediaSubsession 继承的话,有很多纯虚函数需要自己去实现,比较麻烦,所以可以直接从
    H264VideoFileServerMediaSubsession 继承,它实现了这些纯虚函数,我们只需重定义createNewStreamSource 就ok了。



  • 相关阅读:
    Electron+Vue开发跨平台桌面应用
    vue-cli3.0 脚手架搭建项目的过程详解
    dart-sass与node-sass介绍
    创建vue-cli4项目,报错 ERROR command failed: yarn
    CSS Grid 网格布局教程
    总结5种自适应方式
    前端实战:electron+vue3+ts开发桌面端便签应用
    SDK 和 API 的区别是什么?
    Pinia 快速入门
    返回数组中最大的三个数
  • 原文地址:https://www.cnblogs.com/mlj318/p/2871952.html
Copyright © 2011-2022 走看看