ZLMediaKit/src/Rtmp/RtmpMuxer.cpp

111 lines
3.0 KiB
C++
Raw Normal View History

2018-10-25 15:30:44 +08:00
/*
2020-04-04 20:30:09 +08:00
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
*
* This file is part of ZLMediaKit(https://github.com/xiongziliang/ZLMediaKit).
*
* Use of this source code is governed by MIT license that can be found in the
* LICENSE file in the root of the source tree. All contributing project authors
* may be found in the AUTHORS file in the root of the source tree.
*/
2018-10-25 15:30:44 +08:00
#include "RtmpMuxer.h"
2019-06-28 17:25:53 +08:00
#include "Extension/Factory.h"
2018-10-25 15:30:44 +08:00
namespace mediakit {
RtmpMuxer::RtmpMuxer(const TitleMeta::Ptr &title) {
if(!title){
_metadata = std::make_shared<TitleMeta>()->getMetadata();
}else{
_metadata = title->getMetadata();
}
2019-12-26 09:43:44 +08:00
_rtmpRing = std::make_shared<RtmpRing::RingType>();
}
2018-10-25 15:30:44 +08:00
2019-12-03 12:32:57 +08:00
void RtmpMuxer::addTrack(const Track::Ptr &track) {
//根据track生产metadata
Metadata::Ptr metadata;
switch (track->getTrackType()){
case TrackVideo:{
metadata = std::make_shared<VideoMeta>(dynamic_pointer_cast<VideoTrack>(track));
2018-10-25 15:30:44 +08:00
}
break;
case TrackAudio:{
metadata = std::make_shared<AudioMeta>(dynamic_pointer_cast<AudioTrack>(track));
2018-10-25 15:30:44 +08:00
}
break;
default:
2019-12-03 12:32:57 +08:00
return;
2018-10-25 15:30:44 +08:00
}
2019-12-03 12:32:57 +08:00
switch (track->getCodecId()){
case CodecG711A:
case CodecG711U:{
auto audio_track = dynamic_pointer_cast<AudioTrack>(track);
if(!audio_track){
return;
}
if (audio_track->getAudioSampleRate() != 8000 ||
audio_track->getAudioChannel() != 1 ||
audio_track->getAudioSampleBit() != 16) {
WarnL << "RTMP只支持8000/1/16规格的G711,目前规格是:"
<< audio_track->getAudioSampleRate() << "/"
<< audio_track->getAudioChannel() << "/"
<< audio_track->getAudioSampleBit()
<< ",该音频已被忽略";
return;
}
break;
}
default : break;
}
2019-12-03 12:32:57 +08:00
auto &encoder = _encoder[track->getTrackType()];
//生成rtmp编码器,克隆该Track防止循环引用
encoder = Factory::getRtmpCodecByTrack(track->clone());
if (!encoder) {
return;
}
//设置rtmp输出环形缓存
encoder->setRtmpRing(_rtmpRing);
//添加其metadata
metadata->getMetadata().object_for_each([&](const std::string &key, const AMFValue &value){
_metadata.set(key,value);
});
2018-10-25 15:30:44 +08:00
}
2019-12-03 12:32:57 +08:00
void RtmpMuxer::inputFrame(const Frame::Ptr &frame) {
auto &encoder = _encoder[frame->getTrackType()];
if(encoder){
encoder->inputFrame(frame);
}
}
2018-10-25 15:30:44 +08:00
void RtmpMuxer::makeConfigPacket(){
for(auto &encoder : _encoder){
if(encoder){
encoder->makeConfigPacket();
}
}
}
const AMFValue &RtmpMuxer::getMetadata() const {
return _metadata;
2018-10-25 15:30:44 +08:00
}
2019-12-26 09:43:44 +08:00
RtmpRing::RingType::Ptr RtmpMuxer::getRtmpRing() const {
2018-10-25 15:30:44 +08:00
return _rtmpRing;
}
2019-12-03 12:32:57 +08:00
void RtmpMuxer::resetTracks() {
_metadata.clear();
for(auto &encoder : _encoder){
encoder = nullptr;
}
}
}/* namespace mediakit */