mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-21 01:13:37 +08:00
完成MediaSource生成器
This commit is contained in:
parent
84dbe5597d
commit
1ff490d119
@ -1 +1 @@
|
||||
Subproject commit 6e69a082a2f6e6161785b00c7421bf1a811ed34a
|
||||
Subproject commit 3a9c916454897ad02c6ee4cba89f5e370718cd91
|
68
src/Common/MultiMediaSourceMuxer.h
Normal file
68
src/Common/MultiMediaSourceMuxer.h
Normal file
@ -0,0 +1,68 @@
|
||||
/*
|
||||
* MIT License
|
||||
*
|
||||
* Copyright (c) 2016 xiongziliang <771730766@qq.com>
|
||||
*
|
||||
* This file is part of ZLMediaKit(https://github.com/xiongziliang/ZLMediaKit).
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef ZLMEDIAKIT_MULTIMEDIASOURCEMUXER_H
|
||||
#define ZLMEDIAKIT_MULTIMEDIASOURCEMUXER_H
|
||||
|
||||
#include "RtspMuxer/RtspMediaSourceMuxer.h"
|
||||
#include "RtmpMuxer/RtmpMediaSourceMuxer.h"
|
||||
|
||||
class MultiMediaSourceMuxer {
|
||||
public:
|
||||
MultiMediaSourceMuxer(const string &vhost,
|
||||
const string &strApp,
|
||||
const string &strId,
|
||||
float dur_sec = 0.0){
|
||||
_rtmp = std::make_shared<RtmpMediaSourceMuxer>(vhost,strApp,strId,std::make_shared<TitleMete>(dur_sec));
|
||||
_rtsp = std::make_shared<RtspMediaSourceMuxer>(vhost,strApp,strId,std::make_shared<TitleSdp>(dur_sec));
|
||||
}
|
||||
virtual ~MultiMediaSourceMuxer(){}
|
||||
|
||||
|
||||
/**
|
||||
* 添加音视频媒体
|
||||
* @param track 媒体描述
|
||||
*/
|
||||
void addTrack(const Track::Ptr & track,int mtu = 1400) {
|
||||
_rtmp->addTrack(track);
|
||||
_rtsp->addTrack(track,0,mtu);
|
||||
}
|
||||
|
||||
/**
|
||||
* 写入帧数据然后打包rtmp
|
||||
* @param frame 帧数据
|
||||
*/
|
||||
void inputFrame(const Frame::Ptr &frame) {
|
||||
_rtmp->inputFrame(frame);
|
||||
_rtsp->inputFrame(frame);
|
||||
}
|
||||
private:
|
||||
RtmpMediaSourceMuxer::Ptr _rtmp;
|
||||
RtspMediaSourceMuxer::Ptr _rtsp;
|
||||
};
|
||||
|
||||
|
||||
#endif //ZLMEDIAKIT_MULTIMEDIASOURCEMUXER_H
|
@ -48,7 +48,7 @@ using namespace toolkit;
|
||||
|
||||
namespace mediakit {
|
||||
|
||||
class RtmpMediaSource: public MediaSource {
|
||||
class RtmpMediaSource: public MediaSource ,public RingDelegate<RtmpPacket::Ptr> {
|
||||
public:
|
||||
typedef std::shared_ptr<RtmpMediaSource> Ptr;
|
||||
typedef RingBuffer<RtmpPacket::Ptr> RingType;
|
||||
@ -107,6 +107,10 @@ private:
|
||||
lock_guard<recursive_mutex> lock(_mtxMap);
|
||||
return _iCfgFrameSize != -1 && _iCfgFrameSize == _mapCfgFrame.size();
|
||||
}
|
||||
|
||||
void onWrite(const RtmpPacket::Ptr &pkt,bool isKey = true) override {
|
||||
onGetMedia(pkt);
|
||||
}
|
||||
protected:
|
||||
AMFValue _metadata;
|
||||
unordered_map<int, RtmpPacket::Ptr> _mapCfgFrame;
|
||||
|
@ -24,7 +24,43 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "MediaSourceMaker.h"
|
||||
namespace mediakit{
|
||||
#ifndef ZLMEDIAKIT_RTMPMEDIASOURCEMUXER_H
|
||||
#define ZLMEDIAKIT_RTMPMEDIASOURCEMUXER_H
|
||||
|
||||
}
|
||||
#include "RtmpMuxer/RtmpMuxer.h"
|
||||
#include "Rtmp/RtmpMediaSource.h"
|
||||
|
||||
namespace mediakit {
|
||||
|
||||
class RtmpMediaSourceMuxer : public RtmpMuxer {
|
||||
public:
|
||||
typedef std::shared_ptr<RtmpMediaSourceMuxer> Ptr;
|
||||
|
||||
RtmpMediaSourceMuxer(const string &vhost,
|
||||
const string &strApp,
|
||||
const string &strId,
|
||||
const TitleMete::Ptr &title = nullptr) : RtmpMuxer(title){
|
||||
_mediaSouce = std::make_shared<RtmpMediaSource>(vhost,strApp,strId);
|
||||
getRtmpRing()->setDelegate(_mediaSouce);
|
||||
}
|
||||
virtual ~RtmpMediaSourceMuxer(){}
|
||||
|
||||
void setListener(const std::weak_ptr<MediaSourceEvent> &listener){
|
||||
_mediaSouce->setListener(listener);
|
||||
}
|
||||
private:
|
||||
void onInited() override {
|
||||
_mediaSouce->onGetMetaData(getMetedata());
|
||||
}
|
||||
private:
|
||||
RtmpMediaSource::Ptr _mediaSouce;
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}//namespace mediakit
|
||||
#endif //ZLMEDIAKIT_RTMPMEDIASOURCEMUXER_H
|
@ -33,11 +33,17 @@ namespace mediakit{
|
||||
|
||||
class RtmpMuxer{
|
||||
public:
|
||||
typedef std::shared_ptr<RtmpMuxer> Ptr;
|
||||
|
||||
/**
|
||||
* 构造函数
|
||||
*/
|
||||
RtmpMuxer(const TitleMete::Ptr &title = std::make_shared<TitleMete>()) : _metedata(AMF_OBJECT){
|
||||
_metedata = title->getMetedata();
|
||||
RtmpMuxer(const TitleMete::Ptr &title = nullptr) : _metedata(AMF_OBJECT){
|
||||
if(!title){
|
||||
_metedata = std::make_shared<TitleMete>()->getMetedata();
|
||||
}else{
|
||||
_metedata = title->getMetedata();
|
||||
}
|
||||
_rtmpRing = std::make_shared<RtmpRingInterface::RingType>();
|
||||
}
|
||||
virtual ~RtmpMuxer(){}
|
||||
|
@ -49,7 +49,7 @@ using namespace toolkit;
|
||||
|
||||
namespace mediakit {
|
||||
|
||||
class RtspMediaSource: public MediaSource {
|
||||
class RtspMediaSource: public MediaSource , public RingDelegate<RtpPacket::Ptr> {
|
||||
public:
|
||||
typedef ResourcePool<RtpPacket> PoolType;
|
||||
typedef std::shared_ptr<RtspMediaSource> Ptr;
|
||||
@ -93,6 +93,11 @@ public:
|
||||
trackRef.type = rtppt->type;
|
||||
_pRing->write(rtppt,keyPos);
|
||||
}
|
||||
|
||||
private:
|
||||
void onWrite(const RtpPacket::Ptr &rtppt, bool keyPos) override {
|
||||
onGetRTP(rtppt,keyPos);
|
||||
}
|
||||
protected:
|
||||
unordered_map<int, RtspTrack> _mapTracks;
|
||||
string _strSdp; //媒体描述信息
|
||||
|
@ -24,23 +24,38 @@
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef ZLMEDIAKIT_MEDIASOURCEMAKER_H
|
||||
#define ZLMEDIAKIT_MEDIASOURCEMAKER_H
|
||||
#ifndef ZLMEDIAKIT_RTSPMEDIASOURCEMUXER_H
|
||||
#define ZLMEDIAKIT_RTSPMEDIASOURCEMUXER_H
|
||||
|
||||
#include "Player/Track.h"
|
||||
#include "RtspMuxer/RtspMuxer.h"
|
||||
#include "Rtsp/RtspMediaSource.h"
|
||||
#include "Rtmp/RtmpMediaSource.h"
|
||||
|
||||
namespace mediakit {
|
||||
|
||||
class MediaSourceMaker {
|
||||
class RtspMediaSourceMuxer : public RtspMuxer {
|
||||
public:
|
||||
MediaSourceMaker() {}
|
||||
virtual ~MediaSourceMaker() {}
|
||||
typedef std::shared_ptr<RtspMediaSourceMuxer> Ptr;
|
||||
|
||||
RtspMediaSourceMuxer(const string &vhost,
|
||||
const string &strApp,
|
||||
const string &strId,
|
||||
const TitleSdp::Ptr &title = nullptr) : RtspMuxer(title){
|
||||
_mediaSouce = std::make_shared<RtspMediaSource>(vhost,strApp,strId);
|
||||
getRtpRing()->setDelegate(_mediaSouce);
|
||||
}
|
||||
virtual ~RtspMediaSourceMuxer(){}
|
||||
|
||||
void setListener(const std::weak_ptr<MediaSourceEvent> &listener){
|
||||
_mediaSouce->setListener(listener);
|
||||
}
|
||||
private:
|
||||
RtspMediaSource::Ptr _rtspSrc;
|
||||
RtmpMediaSource::Ptr _rtmpSrc;
|
||||
void onInited() override {
|
||||
_mediaSouce->onGetSDP(getSdp());
|
||||
}
|
||||
private:
|
||||
RtspMediaSource::Ptr _mediaSouce;
|
||||
};
|
||||
|
||||
} //namespace mediakit
|
||||
#endif //ZLMEDIAKIT_MEDIASOURCEMAKER_H
|
||||
|
||||
}//namespace mediakit
|
||||
#endif //ZLMEDIAKIT_RTSPMEDIASOURCEMUXER_H
|
@ -35,11 +35,17 @@ namespace mediakit{
|
||||
*/
|
||||
class RtspMuxer{
|
||||
public:
|
||||
typedef std::shared_ptr<RtspMuxer> Ptr;
|
||||
|
||||
/**
|
||||
* 构造函数
|
||||
*/
|
||||
RtspMuxer(const TitleSdp::Ptr &title = std::make_shared<TitleSdp>()){
|
||||
_sdp = title->getSdp();
|
||||
RtspMuxer(const TitleSdp::Ptr &title = nullptr){
|
||||
if(!title){
|
||||
_sdp = std::make_shared<TitleSdp>()->getSdp();
|
||||
} else{
|
||||
_sdp = title->getSdp();
|
||||
}
|
||||
_rtpRing = std::make_shared<RtpRingInterface::RingType>();
|
||||
}
|
||||
virtual ~RtspMuxer(){}
|
||||
|
Loading…
Reference in New Issue
Block a user