精简代码2
This commit is contained in:
parent
630b5d75d9
commit
e461cfd882
|
|
@ -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));
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue