mirror of
https://gitee.com/xia-chu/ZLMediaKit.git
synced 2026-05-16 23:07:49 +08:00
提高某些国标流注册速度
This commit is contained in:
parent
1e14d296f5
commit
f11467c2a8
@ -125,8 +125,14 @@ void DecoderImp::onDecode(int stream, int codecid, int flags, int64_t pts, int64
|
|||||||
auto frame = Factory::getFrameFromPtr(codec, (char *)data, bytes, dts, pts);
|
auto frame = Factory::getFrameFromPtr(codec, (char *)data, bytes, dts, pts);
|
||||||
if (getTrackType(codec) != TrackVideo) {
|
if (getTrackType(codec) != TrackVideo) {
|
||||||
onFrame(stream, frame);
|
onFrame(stream, frame);
|
||||||
|
if (_last_is_keyframe && _video_merge) {
|
||||||
|
// 上次是关键帧,收到音频后,说明帧收齐了
|
||||||
|
_video_merge->flush();
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
_last_is_keyframe = frame->keyFrame();
|
||||||
|
_video_merge = &ref.second;
|
||||||
ref.second.inputFrame(frame, [this, stream, codec](uint64_t dts, uint64_t pts, const Buffer::Ptr &buffer, bool) {
|
ref.second.inputFrame(frame, [this, stream, codec](uint64_t dts, uint64_t pts, const Buffer::Ptr &buffer, bool) {
|
||||||
onFrame(stream, Factory::getFrameFromBuffer(codec, buffer, dts, pts));
|
onFrame(stream, Factory::getFrameFromBuffer(codec, buffer, dts, pts));
|
||||||
});
|
});
|
||||||
|
|||||||
@ -59,13 +59,14 @@ private:
|
|||||||
private:
|
private:
|
||||||
bool _finished = false;
|
bool _finished = false;
|
||||||
bool _have_video = false;
|
bool _have_video = false;
|
||||||
|
bool _last_is_keyframe = false;
|
||||||
Decoder::Ptr _decoder;
|
Decoder::Ptr _decoder;
|
||||||
MediaSinkInterface *_sink;
|
MediaSinkInterface *_sink;
|
||||||
|
|
||||||
class FrameMergerImp : public FrameMerger {
|
class FrameMergerImp : public FrameMerger {
|
||||||
public:
|
public:
|
||||||
FrameMergerImp() : FrameMerger(FrameMerger::none) {}
|
FrameMergerImp() : FrameMerger(FrameMerger::none) {}
|
||||||
};
|
};
|
||||||
|
FrameMergerImp *_video_merge = nullptr;
|
||||||
std::unordered_map<int, std::pair<Track::Ptr, FrameMergerImp> > _tracks;
|
std::unordered_map<int, std::pair<Track::Ptr, FrameMergerImp> > _tracks;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user