精简代码2

This commit is contained in:
xia-chu 2023-12-09 09:34:59 +08:00
parent 630b5d75d9
commit e461cfd882
8 changed files with 92 additions and 102 deletions

View File

@ -77,10 +77,10 @@ static mk_frame mk_frame_create_complex(int codec_id, uint64_t dts, uint64_t pts
switch (codec_id) { switch (codec_id) {
case CodecH264: case CodecH264:
return (mk_frame)new Frame::Ptr(new H264FrameHelper<FrameFromPtrForC>( return (mk_frame)new Frame::Ptr(new H264FrameHelper<FrameFromPtrForC>(
cb, frame_flags, cb, std::move(user_data), (CodecId)codec_id, data, size, dts, pts, prefix_size)); cb, frame_flags, cb, std::move(user_data), data, size, dts, pts, prefix_size));
case CodecH265: case CodecH265:
return (mk_frame)new Frame::Ptr(new H265FrameHelper<FrameFromPtrForC>( return (mk_frame)new Frame::Ptr(new H265FrameHelper<FrameFromPtrForC>(
cb, frame_flags, cb, std::move(user_data), (CodecId)codec_id, data, size, dts, pts, prefix_size)); cb, frame_flags, cb, std::move(user_data), data, size, dts, pts, prefix_size));
default: default:
return (mk_frame)new Frame::Ptr(new FrameFromPtrForC( return (mk_frame)new Frame::Ptr(new FrameFromPtrForC(
cb, frame_flags, cb, std::move(user_data), (CodecId)codec_id, data, size, dts, pts, prefix_size)); cb, frame_flags, cb, std::move(user_data), (CodecId)codec_id, data, size, dts, pts, prefix_size));

View File

@ -298,14 +298,13 @@ bool AACTrack::inputFrame(const Frame::Ptr &frame) {
if (frame_len == (int)frame->size()) { if (frame_len == (int)frame->size()) {
return inputFrame_l(frame); return inputFrame_l(frame);
} }
auto sub_frame = std::make_shared<FrameInternalBase<FrameFromPtr>>(frame, (char *)ptr, frame_len, ADTS_HEADER_LEN, dts, pts); auto sub_frame = std::make_shared<FrameInternalBase<FrameFromPtr>>(frame, (char *)ptr, frame_len, dts, pts, ADTS_HEADER_LEN);
ptr += frame_len; ptr += frame_len;
if (ptr > end) { if (ptr > end) {
WarnL << "invalid aac length in adts header: " << frame_len WarnL << "invalid aac length in adts header: " << frame_len
<< ", remain data size: " << end - (ptr - frame_len); << ", remain data size: " << end - (ptr - frame_len);
break; break;
} }
sub_frame->setCodecId(CodecAAC);
if (inputFrame_l(sub_frame)) { if (inputFrame_l(sub_frame)) {
ret = true; ret = true;
} }

View File

@ -307,6 +307,7 @@ Frame::Ptr Factory::getFrameFromPtr(CodecId codec, const char *data, size_t byte
switch (codec) { switch (codec) {
case CodecH264: return std::make_shared<H264FrameNoCacheAble>((char *)data, bytes, dts, pts, prefixSize(data, bytes)); case CodecH264: return std::make_shared<H264FrameNoCacheAble>((char *)data, bytes, dts, pts, prefixSize(data, bytes));
case CodecH265: return std::make_shared<H265FrameNoCacheAble>((char *)data, bytes, dts, pts, prefixSize(data, bytes)); case CodecH265: return std::make_shared<H265FrameNoCacheAble>((char *)data, bytes, dts, pts, prefixSize(data, bytes));
case CodecJPEG: return std::make_shared<JPEGFrame<FrameFromPtr>>(0, codec, (char *)data, bytes, dts, pts);
case CodecAAC: return std::make_shared<FrameFromPtr>(codec, (char *)data, bytes, dts, pts, aacPrefixSize(data, bytes)); case CodecAAC: return std::make_shared<FrameFromPtr>(codec, (char *)data, bytes, dts, pts, aacPrefixSize(data, bytes));
case CodecOpus: case CodecOpus:
case CodecG711A: case CodecG711A:
@ -315,17 +316,9 @@ Frame::Ptr Factory::getFrameFromPtr(CodecId codec, const char *data, size_t byte
} }
} }
Frame::Ptr Factory::getFrameFromBuffer(CodecId codec, const Buffer::Ptr &data, uint64_t dts, uint64_t pts) { Frame::Ptr Factory::getFrameFromBuffer(CodecId codec, Buffer::Ptr data, uint64_t dts, uint64_t pts) {
switch (codec) { auto frame = Factory::getFrameFromPtr(codec, data->data(), data->size(), dts, pts);
case CodecH264: return std::make_shared<FrameFromBuffer<H264FrameNoCacheAble>>(data, dts, pts, prefixSize(data->data(), data->size()), 0); return std::make_shared<FrameCacheAble>(frame, false, std::move(data));
case CodecH265: return std::make_shared<FrameFromBuffer<H265FrameNoCacheAble>>(data, dts, pts, prefixSize(data->data(), data->size()), 0);
case CodecJPEG: return std::make_shared<JPEGFrame>(data, dts);
case CodecAAC: return std::make_shared<FrameFromBuffer<FrameFromPtr>>(data, dts, pts, aacPrefixSize(data->data(), data->size()), 0, codec);
case CodecOpus:
case CodecG711A:
case CodecG711U: return std::make_shared<FrameFromBuffer<FrameFromPtr>>(data, dts, pts, 0, 0, codec);
default: return nullptr;
}
} }
}//namespace mediakit }//namespace mediakit

View File

@ -88,7 +88,7 @@ public:
static AMFValue getAmfByCodecId(CodecId codecId); static AMFValue getAmfByCodecId(CodecId codecId);
static Frame::Ptr getFrameFromPtr(CodecId codec, const char *data, size_t size, uint64_t dts, uint64_t pts); static Frame::Ptr getFrameFromPtr(CodecId codec, const char *data, size_t size, uint64_t dts, uint64_t pts);
static Frame::Ptr getFrameFromBuffer(CodecId codec, const toolkit::Buffer::Ptr &data, uint64_t dts, uint64_t pts); static Frame::Ptr getFrameFromBuffer(CodecId codec, toolkit::Buffer::Ptr data, uint64_t dts, uint64_t pts);
}; };
}//namespace mediakit }//namespace mediakit

View File

@ -241,6 +241,54 @@ protected:
FrameImp() = default; FrameImp() = default;
}; };
// 包装一个指针成不可缓存的frame
class FrameFromPtr : public Frame {
public:
using Ptr = std::shared_ptr<FrameFromPtr>;
FrameFromPtr(CodecId codec_id, char *ptr, size_t size, uint64_t dts, uint64_t pts = 0, size_t prefix_size = 0, bool is_key = false)
: FrameFromPtr(ptr, size, dts, pts, prefix_size, is_key) {
_codec_id = codec_id;
}
char *data() const override { return _ptr; }
size_t size() const override { return _size; }
uint64_t dts() const override { return _dts; }
uint64_t pts() const override { return _pts ? _pts : dts(); }
size_t prefixSize() const override { return _prefix_size; }
bool cacheAble() const override { return false; }
bool keyFrame() const override { return _is_key; }
bool configFrame() const override { return false; }
CodecId getCodecId() const override {
if (_codec_id == CodecInvalid) {
throw std::invalid_argument("Invalid codec type of FrameFromPtr");
}
return _codec_id;
}
protected:
FrameFromPtr() = default;
FrameFromPtr(char *ptr, size_t size, uint64_t dts, uint64_t pts = 0, size_t prefix_size = 0, bool is_key = false) {
_ptr = ptr;
_size = size;
_dts = dts;
_pts = pts;
_prefix_size = prefix_size;
_is_key = is_key;
}
protected:
bool _is_key;
char *_ptr;
uint64_t _dts;
uint64_t _pts = 0;
size_t _size;
size_t _prefix_size;
CodecId _codec_id = CodecInvalid;
};
/** /**
* Frame类中可以有多个帧(AAC) * Frame类中可以有多个帧(AAC)
* ZLMediaKit会先把这种复合帧split成单个帧然后再处理 * ZLMediaKit会先把这种复合帧split成单个帧然后再处理
@ -251,10 +299,11 @@ template <typename Parent>
class FrameInternalBase : public Parent { class FrameInternalBase : public Parent {
public: public:
using Ptr = std::shared_ptr<FrameInternalBase>; using Ptr = std::shared_ptr<FrameInternalBase>;
FrameInternalBase(Frame::Ptr parent_frame, char *ptr, size_t size, size_t prefix_size, uint64_t dts, uint64_t pts) FrameInternalBase(Frame::Ptr parent_frame, char *ptr, size_t size, uint64_t dts, uint64_t pts = 0, size_t prefix_size = 0)
: Parent(ptr, size, dts, pts, prefix_size) { : Parent(parent_frame->getCodecId(), ptr, size, dts, pts, prefix_size) {
_parent_frame = std::move(parent_frame); _parent_frame = std::move(parent_frame);
} }
bool cacheAble() const override { return _parent_frame->cacheAble(); } bool cacheAble() const override { return _parent_frame->cacheAble(); }
private: private:
@ -272,56 +321,7 @@ class FrameInternal : public FrameInternalBase<Parent> {
public: public:
using Ptr = std::shared_ptr<FrameInternal>; using Ptr = std::shared_ptr<FrameInternal>;
FrameInternal(const Frame::Ptr &parent_frame, char *ptr, size_t size, size_t prefix_size) FrameInternal(const Frame::Ptr &parent_frame, char *ptr, size_t size, size_t prefix_size)
: FrameInternalBase<Parent>(parent_frame, ptr, size, prefix_size, parent_frame->dts(), parent_frame->pts()) {} : FrameInternalBase<Parent>(parent_frame, ptr, size, parent_frame->dts(), parent_frame->pts(), prefix_size) {}
};
// 包装一个指针成不可缓存的frame
class FrameFromPtr : public Frame {
public:
using Ptr = std::shared_ptr<FrameFromPtr>;
FrameFromPtr(CodecId codec_id, char *ptr, size_t size, uint64_t dts, uint64_t pts = 0, size_t prefix_size = 0, bool is_key = false)
: FrameFromPtr(ptr, size, dts, pts, prefix_size, is_key) {
_codec_id = codec_id;
}
FrameFromPtr(char *ptr, size_t size, uint64_t dts, uint64_t pts = 0, size_t prefix_size = 0, bool is_key = false) {
_ptr = ptr;
_size = size;
_dts = dts;
_pts = pts;
_prefix_size = prefix_size;
_is_key = is_key;
}
char *data() const override { return _ptr; }
size_t size() const override { return _size; }
uint64_t dts() const override { return _dts; }
uint64_t pts() const override { return _pts ? _pts : dts(); }
size_t prefixSize() const override { return _prefix_size; }
bool cacheAble() const override { return false; }
bool keyFrame() const override { return _is_key; }
bool configFrame() const override { return false; }
void setCodecId(CodecId codec_id) { _codec_id = codec_id; }
CodecId getCodecId() const override {
if (_codec_id == CodecInvalid) {
throw std::invalid_argument("Invalid codec type of FrameFromPtr");
}
return _codec_id;
}
protected:
FrameFromPtr() = default;
protected:
bool _is_key;
char *_ptr;
uint64_t _dts;
uint64_t _pts = 0;
size_t _size;
size_t _prefix_size;
CodecId _codec_id = CodecInvalid;
}; };
// 管理一个指针生命周期并生产一个frame // 管理一个指针生命周期并生产一个frame
@ -352,14 +352,18 @@ class FrameCacheAble : public FrameFromPtr {
public: public:
using Ptr = std::shared_ptr<FrameCacheAble>; using Ptr = std::shared_ptr<FrameCacheAble>;
FrameCacheAble(const Frame::Ptr &frame, bool force_key_frame = false) { FrameCacheAble(const Frame::Ptr &frame, bool force_key_frame = false, toolkit::Buffer::Ptr buf = nullptr) {
if (frame->cacheAble()) { if (frame->cacheAble()) {
_frame = frame;
_ptr = frame->data(); _ptr = frame->data();
_buffer = frame;
} else if (buf) {
_ptr = frame->data();
_buffer = std::move(buf);
} else { } else {
_buffer = FrameImp::create(); auto buffer = std::make_shared<toolkit::BufferLikeString>();
_buffer->_buffer.assign(frame->data(), frame->size()); buffer->assign(frame->data(), frame->size());
_ptr = _buffer->data(); _ptr = buffer->data();
_buffer = std::move(buffer);
} }
_size = frame->size(); _size = frame->size();
_dts = frame->dts(); _dts = frame->dts();
@ -386,8 +390,7 @@ private:
bool _config; bool _config;
bool _drop_able; bool _drop_able;
bool _decode_able; bool _decode_able;
Frame::Ptr _frame; toolkit::Buffer::Ptr _buffer;
FrameImp::Ptr _buffer;
}; };
//该类实现frame级别的时间戳覆盖 //该类实现frame级别的时间戳覆盖
@ -429,7 +432,7 @@ public:
* @param prefix * @param prefix
* @param offset buffer有效数据偏移量 * @param offset buffer有效数据偏移量
*/ */
FrameFromBuffer(toolkit::Buffer::Ptr buf, uint64_t dts, uint64_t pts, size_t prefix, size_t offset) FrameFromBuffer(toolkit::Buffer::Ptr buf, uint64_t dts, uint64_t pts, size_t prefix = 0, size_t offset = 0)
: Parent(buf->data() + offset, buf->size() - offset, dts, pts, prefix) { : Parent(buf->data() + offset, buf->size() - offset, dts, pts, prefix) {
_buf = std::move(buf); _buf = std::move(buf);
} }
@ -443,7 +446,7 @@ public:
* @param offset buffer有效数据偏移量 * @param offset buffer有效数据偏移量
* @param codec * @param codec
*/ */
FrameFromBuffer(toolkit::Buffer::Ptr buf, uint64_t dts, uint64_t pts, size_t prefix, size_t offset, CodecId codec) FrameFromBuffer(CodecId codec, toolkit::Buffer::Ptr buf, uint64_t dts, uint64_t pts, size_t prefix = 0, size_t offset = 0)
: Parent(codec, buf->data() + offset, buf->size() - offset, dts, pts, prefix) { : Parent(codec, buf->data() + offset, buf->size() - offset, dts, pts, prefix) {
_buf = std::move(buf); _buf = std::move(buf);
} }

View File

@ -29,40 +29,34 @@ private:
uint64_t _tmp = 0; uint64_t _tmp = 0;
}; };
class JPEGFrame : public Frame { class JPEGFrameType {
public:
virtual ~JPEGFrameType() = default;
virtual uint8_t pixType() const = 0;
};
template <typename Parent>
class JPEGFrame : public Parent, public JPEGFrameType {
public: public:
static constexpr auto kJFIFSize = 20u; static constexpr auto kJFIFSize = 20u;
/** /**
* JPEG/MJPEG帧 * JPEG/MJPEG帧
* @param buffer
* @param dts ,
* @param pix_type pixel format type; AV_PIX_FMT_YUVJ422P || (AVCOL_RANGE_JPEG && AV_PIX_FMT_YUV422P) : 1; AV_PIX_FMT_YUVJ420P || (AVCOL_RANGE_JPEG && AV_PIX_FMT_YUV420P) : 0 * @param pix_type pixel format type; AV_PIX_FMT_YUVJ422P || (AVCOL_RANGE_JPEG && AV_PIX_FMT_YUV422P) : 1; AV_PIX_FMT_YUVJ420P || (AVCOL_RANGE_JPEG && AV_PIX_FMT_YUV420P) : 0
* @param offset buffer有效帧数据偏移量
*/ */
JPEGFrame(toolkit::Buffer::Ptr buffer, uint64_t dts, uint8_t pix_type = 0, size_t offset = 0) { template <typename... ARGS>
_buffer = std::move(buffer); JPEGFrame(uint8_t pix_type, ARGS &&...args) : Parent(std::forward<ARGS>(args)...) {
_dts = dts;
_pix_type = pix_type; _pix_type = pix_type;
_offset = offset;
// JFIF头固定20个字节长度 // JFIF头固定20个字节长度
CHECK(_buffer->size() > _offset + kJFIFSize); CHECK(this->size() > kJFIFSize);
} }
uint64_t dts() const override { return _dts; }
size_t prefixSize() const override { return 0; } size_t prefixSize() const override { return 0; }
bool keyFrame() const override { return true; } bool keyFrame() const override { return true; }
bool configFrame() const override { return false; } bool configFrame() const override { return false; }
CodecId getCodecId() const override { return CodecJPEG; } CodecId getCodecId() const override { return CodecJPEG; }
uint8_t pixType() const override { return _pix_type; }
char *data() const override { return _buffer->data() + _offset; }
size_t size() const override { return _buffer->size() - _offset; }
uint8_t pixType() const { return _pix_type; }
private: private:
uint8_t _pix_type; uint8_t _pix_type;
size_t _offset;
uint64_t _dts;
toolkit::Buffer::Ptr _buffer;
}; };
}//namespace mediakit }//namespace mediakit

View File

@ -788,6 +788,8 @@ JPEGRtpDecoder::JPEGRtpDecoder() {
memset(&_ctx.timestamp, 0, sizeof(_ctx) - offsetof(decltype(_ctx), timestamp)); memset(&_ctx.timestamp, 0, sizeof(_ctx) - offsetof(decltype(_ctx), timestamp));
} }
using JPEGFrameImp = JPEGFrame<FrameFromBuffer<FrameFromPtr> >;
bool JPEGRtpDecoder::inputRtp(const RtpPacket::Ptr &rtp, bool) { bool JPEGRtpDecoder::inputRtp(const RtpPacket::Ptr &rtp, bool) {
auto payload = rtp->getPayload(); auto payload = rtp->getPayload();
auto size = rtp->getPayloadSize(); auto size = rtp->getPayloadSize();
@ -802,8 +804,7 @@ bool JPEGRtpDecoder::inputRtp(const RtpPacket::Ptr &rtp, bool) {
uint8_t type; uint8_t type;
if (0 == jpeg_parse_packet(nullptr, &_ctx, &stamp, payload, size, seq, marker ? RTP_FLAG_MARKER : 0, &type)) { if (0 == jpeg_parse_packet(nullptr, &_ctx, &stamp, payload, size, seq, marker ? RTP_FLAG_MARKER : 0, &type)) {
auto buffer = std::make_shared<toolkit::BufferString>(std::move(_ctx.frame)); auto buffer = std::make_shared<toolkit::BufferString>(std::move(_ctx.frame));
// JFIF头固定20个字节长度 auto frame = std::make_shared<JPEGFrameImp>(type, std::move(buffer), stamp / 90, 0);
auto frame = std::make_shared<JPEGFrame>(std::move(buffer), stamp / 90, type);
_ctx.frame.clear(); _ctx.frame.clear();
RtpCodec::inputFrame(std::move(frame)); RtpCodec::inputFrame(std::move(frame));
} }
@ -815,11 +816,11 @@ bool JPEGRtpDecoder::inputRtp(const RtpPacket::Ptr &rtp, bool) {
bool JPEGRtpEncoder::inputFrame(const Frame::Ptr &frame) { bool JPEGRtpEncoder::inputFrame(const Frame::Ptr &frame) {
// JFIF头固定20个字节长度 // JFIF头固定20个字节长度
auto ptr = (uint8_t *)frame->data() + frame->prefixSize() + JPEGFrame::kJFIFSize; auto ptr = (uint8_t *)frame->data() + frame->prefixSize() + JPEGFrameImp::kJFIFSize;
auto len = frame->size() - frame->prefixSize() - JPEGFrame::kJFIFSize; auto len = frame->size() - frame->prefixSize() - JPEGFrameImp::kJFIFSize;
auto pts = frame->pts(); auto pts = frame->pts();
auto type = 1; auto type = 1;
auto jpeg = dynamic_pointer_cast<JPEGFrame>(frame); auto jpeg = dynamic_pointer_cast<JPEGFrameType>(frame);
if (jpeg) { if (jpeg) {
type = jpeg->pixType(); type = jpeg->pixType();
} }

View File

@ -155,12 +155,12 @@ Frame::Ptr MP4Demuxer::makeFrame(uint32_t track_id, const Buffer::Ptr &buf, int6
memcpy(data + offset, "\x00\x00\x00\x01", 4); memcpy(data + offset, "\x00\x00\x00\x01", 4);
offset += (frame_len + 4); offset += (frame_len + 4);
} }
ret = Factory::getFrameFromBuffer(codec, buf, dts, pts); ret = Factory::getFrameFromBuffer(codec, std::move(buf), dts, pts);
break; break;
} }
default: { default: {
ret = Factory::getFrameFromBuffer(codec, buf, dts, pts); ret = Factory::getFrameFromBuffer(codec, std::move(buf), dts, pts);
break; break;
} }
} }