ZLMediaKit/src/Common/MediaSink.h

301 lines
8.3 KiB
C++
Raw Normal View History

/*
2023-12-09 16:23:51 +08:00
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
*
2023-12-09 16:23:51 +08:00
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
*
2023-12-09 16:23:51 +08:00
* Use of this source code is governed by MIT-like license that can be found in the
2020-04-04 20:30:09 +08:00
* LICENSE file in the root of the source tree. All contributing project authors
* may be found in the AUTHORS file in the root of the source tree.
*/
#ifndef ZLMEDIAKIT_MEDIASINK_H
#define ZLMEDIAKIT_MEDIASINK_H
#include <mutex>
#include <memory>
2018-11-17 15:25:33 +08:00
#include "Util/TimeTicker.h"
2018-10-30 14:59:42 +08:00
#include "Extension/Frame.h"
#include "Extension/Track.h"
namespace mediakit{
2021-04-20 17:53:43 +08:00
class TrackListener {
2019-12-03 12:32:57 +08:00
public:
2021-04-20 17:53:43 +08:00
virtual ~TrackListener() = default;
2019-12-03 12:32:57 +08:00
/**
* trackTrack的clone方法
* sps pps这些信息 Delegate相关关系
* @param track
* Add track, internally calls the clone method of Track
* Only clones sps pps information, not the Delegate relationship
* @param track
* [AUTO-TRANSLATED:ba6faf58]
2019-12-03 12:32:57 +08:00
*/
virtual bool addTrack(const Track::Ptr & track) = 0;
2019-12-03 12:32:57 +08:00
2020-09-06 17:52:07 +08:00
/**
2021-04-20 17:53:43 +08:00
* track完毕
* Track added
* [AUTO-TRANSLATED:dc70ddea]
2020-09-06 17:52:07 +08:00
*/
2021-04-20 17:53:43 +08:00
virtual void addTrackCompleted() {};
2020-09-06 17:52:07 +08:00
2019-12-03 12:32:57 +08:00
/**
* track
* Reset track
* [AUTO-TRANSLATED:95dc0b4f]
2019-12-03 12:32:57 +08:00
*/
2021-04-20 17:53:43 +08:00
virtual void resetTracks() {};
};
class MediaSinkInterface : public FrameWriterInterface, public TrackListener {
public:
2022-12-02 14:43:06 +08:00
using Ptr = std::shared_ptr<MediaSinkInterface>;
2019-12-03 12:32:57 +08:00
};
/**
* aac静音音频添加器
* AAC mute audio adder
* [AUTO-TRANSLATED:aa154f71]
*/
class MuteAudioMaker : public FrameDispatcher {
public:
2022-12-02 14:43:06 +08:00
using Ptr = std::shared_ptr<MuteAudioMaker>;
bool inputFrame(const Frame::Ptr &frame) override;
private:
2023-12-09 22:34:22 +08:00
int _track_index = -1;
uint64_t _audio_idx = 0;
};
2018-10-27 22:54:16 +08:00
/**
* Track ready()true也就是就绪后再通知派生类进行下一步的操作
* Frame前由Track截取处理下便sps pps aa_cfg
* The role of this class is to wait for Track ready() to return true, that is, ready, and then notify the derived class to perform the next operation.
* The purpose is to intercept and process the input Frame by Track before inputting the Frame, so as to obtain valid information (such as sps pps aa_cfg)
* [AUTO-TRANSLATED:9e4f096b]
2018-10-27 22:54:16 +08:00
*/
2021-04-20 17:53:43 +08:00
class MediaSink : public MediaSinkInterface, public TrackSource{
public:
2022-12-02 14:43:06 +08:00
using Ptr = std::shared_ptr<MediaSink>;
/**
* frame
* @param frame
* Input frame
* @param frame
* [AUTO-TRANSLATED:7aaa5bba]
*/
bool inputFrame(const Frame::Ptr &frame) override;
/**
* trackTrack的clone方法
* sps pps这些信息 Delegate相关关系
* @param track
* Add track, internally calls the clone method of Track
* Only clones sps pps information, not the Delegate relationship
* @param track
* [AUTO-TRANSLATED:ba6faf58]
*/
bool addTrack(const Track::Ptr & track) override;
/**
* Track完毕Track3onAllTrackReady
* Track
*
* Track added, if it is a single Track, it will wait for a maximum of 3 seconds before triggering onAllTrackReady
* This will increase the delay in generating the stream. If you add both audio and video tracks, you can skip this method.
* Otherwise, to reduce the stream registration delay, please call this method manually.
* [AUTO-TRANSLATED:580b6163]
*/
2020-09-06 17:52:07 +08:00
void addTrackCompleted() override;
/**
2023-12-09 22:34:22 +08:00
* track数>=1addTrackCompleted类型
* track时
* Set the maximum number of tracks, the value range is >=1; this method is of the addTrackCompleted type;
* When setting a single track, it can speed up media registration
* [AUTO-TRANSLATED:cd521c6f]
*/
void setMaxTrackCount(size_t i);
/**
* track
* Reset track
* [AUTO-TRANSLATED:95dc0b4f]
*/
2019-12-03 12:32:57 +08:00
void resetTracks() override;
2018-10-28 00:15:27 +08:00
/**
2019-12-03 12:32:57 +08:00
* Track
* @param trackReady Track
* Get all Tracks
* @param trackReady Whether to get the ready Track
* [AUTO-TRANSLATED:32032e47]
2018-10-28 00:15:27 +08:00
*/
std::vector<Track::Ptr> getTracks(bool trackReady = true) const override;
2022-03-12 14:34:48 +08:00
/**
2023-12-09 16:23:51 +08:00
* onAllTrackReady事件
* Determine whether the onAllTrackReady event has been triggered
* [AUTO-TRANSLATED:fb8b4c71]
*/
2022-03-12 14:34:48 +08:00
bool isAllTrackReady() const;
/**
2022-03-12 14:34:48 +08:00
*
* Set whether to enable audio
* [AUTO-TRANSLATED:0e9a3ef0]
*/
2022-03-12 14:34:48 +08:00
void enableAudio(bool flag);
/**
*
* Set single audio
* [AUTO-TRANSLATED:48fc734a]
*/
void setOnlyAudio();
2022-03-12 14:34:48 +08:00
/**
*
* Set whether to enable adding mute audio
* [AUTO-TRANSLATED:49efef10]
2022-03-12 14:34:48 +08:00
*/
void enableMuteAudio(bool flag);
/**
* track
* Whether there is a video track
* [AUTO-TRANSLATED:4c4d651d]
*/
bool haveVideo() const;
protected:
/**
* track已经准备好ready()true
* sps pps等相关信息了
* @param track
* A certain track is ready, its ready() status returns true,
* This means that you can get its related information such as sps pps
* @param track
* [AUTO-TRANSLATED:720dedc1]
*/
virtual bool onTrackReady(const Track::Ptr & track) { return false; };
/**
* Track已经准备好
* All Tracks are ready,
* [AUTO-TRANSLATED:c54d02e2]
*/
virtual void onAllTrackReady() {};
/**
* Track输出frameonAllTrackReady触发后才会调用此方法
* @param frame
* A certain Track outputs a frame, this method will be called only after onAllTrackReady is triggered
* @param frame
* [AUTO-TRANSLATED:debbd247]
*/
virtual bool onTrackFrame(const Frame::Ptr &frame) { return false; };
2021-04-20 17:53:43 +08:00
private:
/**
* onAllTrackReady事件
* Trigger the onAllTrackReady event
* [AUTO-TRANSLATED:068fdb61]
*/
void emitAllTrackReady();
/**
* track是否准备完毕
* Check if the track is ready
* [AUTO-TRANSLATED:12e7c3e6]
*/
void checkTrackIfReady();
void onAllTrackReady_l();
2022-03-12 14:34:48 +08:00
/**
* aac静音轨道
* Add AAC mute track
* [AUTO-TRANSLATED:9ba052b5]
2022-03-12 14:34:48 +08:00
*/
bool addMuteAudioTrack();
2021-04-20 17:53:43 +08:00
private:
2023-12-09 22:34:22 +08:00
bool _audio_add = false;
bool _have_video = false;
2022-03-12 14:34:48 +08:00
bool _enable_audio = true;
bool _only_audio = false;
2022-03-12 14:34:48 +08:00
bool _add_mute_audio = true;
bool _all_track_ready = false;
size_t _max_track_size = 2;
2023-12-09 22:34:22 +08:00
toolkit::Ticker _ticker;
MuteAudioMaker::Ptr _mute_audio_maker;
2023-12-09 22:34:22 +08:00
std::unordered_map<int, toolkit::List<Frame::Ptr> > _frame_unread;
std::unordered_map<int, std::function<void()> > _track_ready_callback;
std::unordered_map<int, std::pair<Track::Ptr, bool/*got frame*/> > _track_map;
};
class MediaSinkDelegate : public MediaSink {
public:
/**
* track监听器
* Set track listener
* [AUTO-TRANSLATED:cedc97d7]
*/
void setTrackListener(TrackListener *listener);
protected:
void resetTracks() override;
bool onTrackReady(const Track::Ptr & track) override;
void onAllTrackReady() override;
private:
TrackListener *_listener = nullptr;
};
class Demuxer : protected TrackListener, public TrackSource {
public:
void setTrackListener(TrackListener *listener, bool wait_track_ready = false);
std::vector<Track::Ptr> getTracks(bool trackReady = true) const override;
protected:
bool addTrack(const Track::Ptr &track) override;
void addTrackCompleted() override;
void resetTracks() override;
private:
MediaSink::Ptr _sink;
TrackListener *_listener = nullptr;
std::vector<Track::Ptr> _origin_track;
};
}//namespace mediakit
#endif //ZLMEDIAKIT_MEDIASINK_H