mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-26 04:31:37 +08:00
Demuxer: 解复用减少一次MediaSink的数据过滤
This commit is contained in:
parent
2a8a6cac27
commit
e38f2253ff
@ -62,9 +62,32 @@ PlayerBase::PlayerBase() {
|
|||||||
this->mINI::operator[](kBeatIntervalMS) = 5000;
|
this->mINI::operator[](kBeatIntervalMS) = 5000;
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////Demuxer//////////////////////////////
|
///////////////////////////DemuxerSink//////////////////////////////
|
||||||
|
|
||||||
bool Demuxer::addTrack(const Track::Ptr &track) {
|
class DemuxerSink : public MediaSink {
|
||||||
|
public:
|
||||||
|
DemuxerSink() = default;
|
||||||
|
~DemuxerSink() override = default;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置track监听器
|
||||||
|
*/
|
||||||
|
void setTrackListener(TrackListener *listener);
|
||||||
|
vector<Track::Ptr> getTracks(bool ready = true) const override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool addTrack(const Track::Ptr & track) override;
|
||||||
|
void resetTracks() override;
|
||||||
|
bool onTrackReady(const Track::Ptr & track) override;
|
||||||
|
void onAllTrackReady() override;
|
||||||
|
bool onTrackFrame(const Frame::Ptr &frame) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Track::Ptr _tracks[TrackMax];
|
||||||
|
TrackListener *_listener = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
bool DemuxerSink::addTrack(const Track::Ptr &track) {
|
||||||
auto ret = MediaSink::addTrack(track);
|
auto ret = MediaSink::addTrack(track);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
track->addDelegate(std::make_shared<FrameWriterInterfaceHelper>([this](const Frame::Ptr &frame) {
|
track->addDelegate(std::make_shared<FrameWriterInterfaceHelper>([this](const Frame::Ptr &frame) {
|
||||||
@ -74,16 +97,16 @@ bool Demuxer::addTrack(const Track::Ptr &track) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Demuxer::setTrackListener(TrackListener *listener) {
|
void DemuxerSink::setTrackListener(TrackListener *listener) {
|
||||||
_listener = listener;
|
_listener = listener;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Demuxer::onTrackReady(const Track::Ptr &track) {
|
bool DemuxerSink::onTrackReady(const Track::Ptr &track) {
|
||||||
_tracks[track->getTrackType()] = track->clone();
|
_tracks[track->getTrackType()] = track->clone();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Demuxer::onAllTrackReady() {
|
void DemuxerSink::onAllTrackReady() {
|
||||||
if (!_listener) {
|
if (!_listener) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -95,11 +118,11 @@ void Demuxer::onAllTrackReady() {
|
|||||||
_listener->addTrackCompleted();
|
_listener->addTrackCompleted();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Demuxer::onTrackFrame(const Frame::Ptr &frame) {
|
bool DemuxerSink::onTrackFrame(const Frame::Ptr &frame) {
|
||||||
return _tracks[frame->getTrackType()]->inputFrame(frame);
|
return _tracks[frame->getTrackType()]->inputFrame(frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Demuxer::resetTracks() {
|
void DemuxerSink::resetTracks() {
|
||||||
MediaSink::resetTracks();
|
MediaSink::resetTracks();
|
||||||
for (auto &track : _tracks) {
|
for (auto &track : _tracks) {
|
||||||
track = nullptr;
|
track = nullptr;
|
||||||
@ -109,7 +132,7 @@ void Demuxer::resetTracks() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<Track::Ptr> Demuxer::getTracks(bool ready) const {
|
vector<Track::Ptr> DemuxerSink::getTracks(bool ready) const {
|
||||||
vector<Track::Ptr> ret;
|
vector<Track::Ptr> ret;
|
||||||
for (auto &track : _tracks) {
|
for (auto &track : _tracks) {
|
||||||
if (!track || (ready && !track->ready())) {
|
if (!track || (ready && !track->ready())) {
|
||||||
@ -120,4 +143,53 @@ vector<Track::Ptr> Demuxer::getTracks(bool ready) const {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
///////////////////////////Demuxer//////////////////////////////
|
||||||
|
|
||||||
|
void Demuxer::setTrackListener(TrackListener *listener, bool wait_track_ready) {
|
||||||
|
if (wait_track_ready) {
|
||||||
|
auto sink = std::make_shared<DemuxerSink>();
|
||||||
|
sink->setTrackListener(listener);
|
||||||
|
_sink = std::move(sink);
|
||||||
|
}
|
||||||
|
_listener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Demuxer::addTrack(const Track::Ptr &track) {
|
||||||
|
if (!_sink) {
|
||||||
|
_origin_track.emplace_back(track);
|
||||||
|
}
|
||||||
|
return _sink ? _sink->addTrack(track) : (_listener ? _listener->addTrack(track) : false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Demuxer::addTrackCompleted() {
|
||||||
|
if (_sink) {
|
||||||
|
_sink->addTrackCompleted();
|
||||||
|
} else if (_listener) {
|
||||||
|
_listener->addTrackCompleted();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Demuxer::resetTracks() {
|
||||||
|
if (_sink) {
|
||||||
|
_sink->resetTracks();
|
||||||
|
} else if (_listener) {
|
||||||
|
_listener->resetTracks();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
vector<Track::Ptr> Demuxer::getTracks(bool ready) const {
|
||||||
|
if (_sink) {
|
||||||
|
return _sink->getTracks(ready);
|
||||||
|
}
|
||||||
|
|
||||||
|
vector<Track::Ptr> ret;
|
||||||
|
for (auto &track : _origin_track) {
|
||||||
|
if (ready && !track->ready()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
ret.emplace_back(track);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
} /* namespace mediakit */
|
} /* namespace mediakit */
|
||||||
|
@ -238,27 +238,21 @@ protected:
|
|||||||
std::shared_ptr<Delegate> _delegate;
|
std::shared_ptr<Delegate> _delegate;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Demuxer : protected MediaSink {
|
class Demuxer : protected TrackListener, public TrackSource {
|
||||||
public:
|
public:
|
||||||
Demuxer() = default;
|
Demuxer() = default;
|
||||||
~Demuxer() override = default;
|
~Demuxer() override = default;
|
||||||
|
|
||||||
/**
|
void setTrackListener(TrackListener *listener, bool wait_track_ready = false);
|
||||||
* 设置track监听器
|
bool addTrack(const Track::Ptr &track) override;
|
||||||
*/
|
void addTrackCompleted() override;
|
||||||
void setTrackListener(TrackListener *listener);
|
|
||||||
vector<Track::Ptr> getTracks(bool ready = true) const override;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
bool addTrack(const Track::Ptr & track) override;
|
|
||||||
void resetTracks() override;
|
void resetTracks() override;
|
||||||
bool onTrackReady(const Track::Ptr & track) override;
|
vector<Track::Ptr> getTracks(bool trackReady = true) const override;
|
||||||
void onAllTrackReady() override;
|
|
||||||
bool onTrackFrame(const Frame::Ptr &frame) override;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Track::Ptr _tracks[TrackMax];
|
MediaSink::Ptr _sink;
|
||||||
TrackListener *_listener = nullptr;
|
TrackListener *_listener = nullptr;
|
||||||
|
vector<Track::Ptr> _origin_track;
|
||||||
};
|
};
|
||||||
|
|
||||||
} /* namespace mediakit */
|
} /* namespace mediakit */
|
||||||
|
@ -98,7 +98,7 @@ private:
|
|||||||
_rtmp_src->setMetaData(val);
|
_rtmp_src->setMetaData(val);
|
||||||
}
|
}
|
||||||
_demuxer = std::make_shared<RtmpDemuxer>();
|
_demuxer = std::make_shared<RtmpDemuxer>();
|
||||||
_demuxer->setTrackListener(this);
|
_demuxer->setTrackListener(this, true);
|
||||||
_demuxer->loadMetaData(val);
|
_demuxer->loadMetaData(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ private:
|
|||||||
_rtsp_media_src->setSdp(sdp);
|
_rtsp_media_src->setSdp(sdp);
|
||||||
}
|
}
|
||||||
_demuxer = std::make_shared<RtspDemuxer>();
|
_demuxer = std::make_shared<RtspDemuxer>();
|
||||||
_demuxer->setTrackListener(this);
|
_demuxer->setTrackListener(this, true);
|
||||||
_demuxer->loadSdp(sdp);
|
_demuxer->loadSdp(sdp);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user