HTTP-FMP4: 修复http-fmp4直播秒开问题
This commit is contained in:
parent
4291c31493
commit
120879df0f
|
|
@ -64,9 +64,7 @@ public:
|
||||||
*/
|
*/
|
||||||
void setInitSegment(string str) {
|
void setInitSegment(string str) {
|
||||||
_init_segment = std::move(str);
|
_init_segment = std::move(str);
|
||||||
if (_ring) {
|
createRing();
|
||||||
regist();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -72,7 +72,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void onSegmentData(const string &string, uint32_t stamp, bool key_frame) override {
|
void onSegmentData(string string, uint32_t stamp, bool key_frame) override {
|
||||||
if (string.empty()) {
|
if (string.empty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -9,9 +9,11 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef ENABLE_MP4
|
#ifdef ENABLE_MP4
|
||||||
|
|
||||||
#include "MP4Muxer.h"
|
#include "MP4Muxer.h"
|
||||||
#include "Util/File.h"
|
#include "Util/File.h"
|
||||||
#include "Extension/H264.h"
|
#include "Extension/H264.h"
|
||||||
|
|
||||||
namespace mediakit {
|
namespace mediakit {
|
||||||
|
|
||||||
MP4Muxer::MP4Muxer() {}
|
MP4Muxer::MP4Muxer() {}
|
||||||
|
|
@ -84,7 +86,6 @@ bool MP4MuxerInterface::inputFrame(const Frame::Ptr &frame) {
|
||||||
//mp4文件时间戳需要从0开始
|
//mp4文件时间戳需要从0开始
|
||||||
auto &track_info = it->second;
|
auto &track_info = it->second;
|
||||||
int64_t dts_out, pts_out;
|
int64_t dts_out, pts_out;
|
||||||
|
|
||||||
switch (frame->getCodecId()) {
|
switch (frame->getCodecId()) {
|
||||||
case CodecH264:
|
case CodecH264:
|
||||||
case CodecH265: {
|
case CodecH265: {
|
||||||
|
|
@ -319,22 +320,24 @@ bool MP4MuxerMemory::inputFrame(const Frame::Ptr &frame){
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto key_frame = frame->keyFrame();
|
bool key_frame = frame->keyFrame();
|
||||||
auto data = _memory_file->getAndClearMemory();
|
|
||||||
if (!data.empty()) {
|
|
||||||
//flush切片
|
//flush切片
|
||||||
saveSegment();
|
saveSegment();
|
||||||
|
|
||||||
|
auto data = _memory_file->getAndClearMemory();
|
||||||
|
if (!data.empty()) {
|
||||||
//输出切片数据
|
//输出切片数据
|
||||||
onSegmentData(data, frame->dts(), _key_frame);
|
onSegmentData(std::move(data), frame->dts(), _key_frame);
|
||||||
_key_frame = false;
|
_key_frame = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key_frame) {
|
if (key_frame) {
|
||||||
_key_frame = true;
|
_key_frame = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return MP4MuxerInterface::inputFrame(frame);
|
return MP4MuxerInterface::inputFrame(frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}//namespace mediakit
|
}//namespace mediakit
|
||||||
#endif//#ifdef ENABLE_MP4
|
#endif//#ifdef ENABLE_MP4
|
||||||
|
|
|
||||||
|
|
@ -134,7 +134,7 @@ protected:
|
||||||
* @param stamp 切片末尾时间戳
|
* @param stamp 切片末尾时间戳
|
||||||
* @param key_frame 是否有关键帧
|
* @param key_frame 是否有关键帧
|
||||||
*/
|
*/
|
||||||
virtual void onSegmentData(const string &string, uint32_t stamp, bool key_frame) = 0;
|
virtual void onSegmentData(string string, uint32_t stamp, bool key_frame) = 0;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
MP4FileIO::Writer createWriter() override;
|
MP4FileIO::Writer createWriter() override;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue