From 9e5babf9db52e64bdae60137be7696e56241fca6 Mon Sep 17 00:00:00 2001 From: xingzilong <xingzilong@454eff88-639b-444f-9e54-f578c98de674> Date: 星期五, 18 八月 2017 18:12:17 +0800 Subject: [PATCH] H264 NALU解析 并在RTSPServer判断 --- RtspFace/PL_H264Encoder.cpp | 44 ++++++++++++++++++++++++++++---------------- 1 files changed, 28 insertions(+), 16 deletions(-) diff --git a/RtspFace/PL_H264Encoder.cpp b/RtspFace/PL_H264Encoder.cpp index 1b3123a..68c502c 100644 --- a/RtspFace/PL_H264Encoder.cpp +++ b/RtspFace/PL_H264Encoder.cpp @@ -9,17 +9,17 @@ #include <libavutil/imgutils.h> #include <libavutil/opt.h> #include <libavformat/avformat.h> - - #include <libyuv.h> } + +#include <libyuv.h> PL_H264Encoder_Config::PL_H264Encoder_Config() : inBufferSize(2*1024*1024), // 2MByte resetPTS(false), bytesBufferImageWidth(0), bytesBufferImageHeight(0), avc_bit_rate(1*1024*1024*8), //1Mbit - avc_fps(25), avc_gop(25), avc_max_b_frames(0), avc_profile(FF_PROFILE_H264_MAIN), - av_opt_preset("superfast"), av_opt_tune("") + avc_fps(25), avc_gop(25), avc_max_b_frames(0), avc_profile(FF_PROFILE_H264_BASELINE), + av_opt_preset("superfast"), av_opt_tune(""), avc_profile_str("") { // av_opt_tune: zerolatency } @@ -47,6 +47,8 @@ ~H264Encoder_Internal() { + delete[] buffer; + buffer = nullptr; } void reset() @@ -67,8 +69,10 @@ pAVFormatContext = nullptr; if (buffer != nullptr) + { delete[] buffer; - buffer = new uint8_t[config.inBufferSize]; + buffer = nullptr; + } } }; @@ -98,6 +102,8 @@ in->config = *config; } + in->buffer = new uint8_t[in->config.inBufferSize]; + return true; } @@ -116,7 +122,7 @@ if (!avCodec) { - LOG_ERROR << "codec not found!"; + LOG_ERROR << "codec not found!" << std::endl; return false; } @@ -129,13 +135,16 @@ in->pAVCodecContext->time_base.den = in->config.avc_fps; in->pAVCodecContext->gop_size = in->config.avc_gop; in->pAVCodecContext->max_b_frames = in->config.avc_max_b_frames; - in->pAVCodecContext->profile = in->config.avc_profile; in->pAVCodecContext->pix_fmt = AV_PIX_FMT_YUV420P; if (!in->config.av_opt_preset.empty()) av_opt_set(in->pAVCodecContext->priv_data, "preset", in->config.av_opt_preset.c_str(), 0); if (!in->config.av_opt_tune.empty()) av_opt_set(in->pAVCodecContext->priv_data, "tune", in->config.av_opt_tune.c_str(), 0); + if (!in->config.avc_profile_str.empty()) + av_opt_set(in->pAVCodecContext->priv_data, "profile", in->config.avc_profile_str.c_str(), 0); + else + in->pAVCodecContext->profile = in->config.avc_profile; if(avcodec_open2(in->pAVCodecContext, avCodec, NULL) >= 0) { @@ -150,13 +159,13 @@ in->pAVCodecContext->pix_fmt, 16); if (ret < 0) { - LOG_ERROR << "av_image_alloc error"; + LOG_ERROR << "av_image_alloc error" << std::endl; return false; } } else { - LOG_ERROR << "avcodec_open2 error"; + LOG_ERROR << "avcodec_open2 error" << std::endl; return false; } @@ -227,7 +236,7 @@ int ret = avcodec_encode_video2(in->pAVCodecContext, &pAVPacket, in->pAVFrame, &gotPacket); if (ret < 0) { - LOG_WARN << "avcodec_encode_video2 (1) error=" << ret; + LOG_WARN << "avcodec_encode_video2 (1) error=" << ret << std::endl; return false; } @@ -235,7 +244,7 @@ { in->frameCount++; LOGP(DEBUG, "Succeed to encode (1) frame=%d, size=%d", in->frameCount, pAVPacket.size); - memcpy(in->buffer, pAVPacket.data, pAVPacket.size); + memcpy(in->buffer, pAVPacket.data, pAVPacket.size);//#todo check inBufferSize in->buffSize = pAVPacket.size; av_free_packet(&pAVPacket); } @@ -321,7 +330,7 @@ bool ret = initH264EncoderEnv(in); if (!ret) { - LOG_ERROR << "initH264EncoderEnv error"; + LOG_ERROR << "initH264EncoderEnv error" << std::endl; return false; } else @@ -330,7 +339,7 @@ if (pm.type != PipeMaterial::PMT_FRAME) { - LOG_ERROR << "Only support PMT_FRAME"; + LOG_ERROR << "Only support PMT_FRAME" << std::endl; return false; } @@ -347,7 +356,7 @@ ret = encodeH264(in, (uint8_t*)(frame->buffer), frame->pts); else { - LOG_ERROR << "Only support MBFT_PTR_AVFRAME / MBFT_YUV420"; + LOG_ERROR << "Only support MBFT_PTR_AVFRAME / MBFT_YUV420" << std::endl; in->payError = true; return false; } @@ -361,8 +370,11 @@ in->lastFrame.buffSize = in->buffSize; in->lastFrame.width = frame->width; in->lastFrame.height = frame->height; - in->lastFrame.pts = frame->pts; - //#todo resetPts + + if (in->config.resetPTS) + gettimeofday(&(in->lastFrame.pts),NULL); + else + in->lastFrame.pts = frame->pts; } return ret; -- Gitblit v1.8.0