忽略AUD帧;

This commit is contained in:
Zhou Weimin 2020-09-12 13:45:16 +08:00
parent c75c8f3806
commit 01284323eb
2 changed files with 11 additions and 5 deletions

View File

@ -378,7 +378,7 @@ void MultiMediaSourceMuxer::inputFrame(const Frame::Ptr &frame_in) {
bool MultiMediaSourceMuxer::isEnabled(){ bool MultiMediaSourceMuxer::isEnabled(){
#if defined(ENABLE_RTPPROXY) #if defined(ENABLE_RTPPROXY)
return _muxer->isEnabled() || _ps_rtp_sender return (_muxer->isEnabled() || _ps_rtp_sender);
#endif //ENABLE_RTPPROXY #endif //ENABLE_RTPPROXY
return _muxer->isEnabled(); return _muxer->isEnabled();
} }

View File

@ -30,10 +30,11 @@ public:
typedef std::shared_ptr<H264Frame> Ptr; typedef std::shared_ptr<H264Frame> Ptr;
typedef enum { typedef enum {
NAL_SPS = 7,
NAL_PPS = 8,
NAL_IDR = 5, NAL_IDR = 5,
NAL_SEI = 6, NAL_SEI = 6,
NAL_SPS = 7,
NAL_PPS = 8,
NAL_AUD = 9,
} NalType; } NalType;
H264Frame(){ H264Frame(){
@ -179,7 +180,8 @@ public:
*/ */
void inputFrame(const Frame::Ptr &frame) override{ void inputFrame(const Frame::Ptr &frame) override{
int type = H264_TYPE(*((uint8_t *)frame->data() + frame->prefixSize())); int type = H264_TYPE(*((uint8_t *)frame->data() + frame->prefixSize()));
if(type == H264Frame::NAL_SPS || type == H264Frame::NAL_PPS || type == H264Frame::NAL_SEI){ if(type == H264Frame::NAL_SPS || type == H264Frame::NAL_PPS || type == H264Frame::NAL_SEI ||
type == H264Frame::NAL_AUD){
//有些设备会把SPS PPS IDR帧当做一个帧打包所以我们要split一下 //有些设备会把SPS PPS IDR帧当做一个帧打包所以我们要split一下
splitH264(frame->data(), frame->size(), frame->prefixSize(), [&](const char *ptr, int len, int prefix) { splitH264(frame->data(), frame->size(), frame->prefixSize(), [&](const char *ptr, int len, int prefix) {
H264FrameInternal::Ptr sub_frame = std::make_shared<H264FrameInternal>(frame, (char *)ptr, len, prefix); H264FrameInternal::Ptr sub_frame = std::make_shared<H264FrameInternal>(frame, (char *)ptr, len, prefix);
@ -224,6 +226,10 @@ private:
VideoTrack::inputFrame(frame); VideoTrack::inputFrame(frame);
} }
break; break;
case H264Frame::NAL_AUD:{
//忽略AUD帧;
}
break;
default: default:
VideoTrack::inputFrame(frame); VideoTrack::inputFrame(frame);