a-zlm/webrtc/WebRtcPlayer.h

166 lines
5.3 KiB
C++
Raw Normal View History

2026-01-14 15:38:20 +08:00
/*
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
*
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
*
* Use of this source code is governed by MIT-like license that can be found in the
* 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_WEBRTCPLAYER_H
#define ZLMEDIAKIT_WEBRTCPLAYER_H
#include "WebRtcTransport.h"
#include "Rtsp/RtspMediaSource.h"
namespace mediakit {
/**
* @brief H.264 B
* H.264 RTP B
*/
class H264BFrameFilter {
public:
/**
* ISO_IEC_14496-10-AVC-2012
* Table 7-6 Name association to slice_type
*/
enum H264SliceType {
H264SliceTypeP = 0,
H264SliceTypeB = 1,
H264SliceTypeI = 2,
H264SliceTypeSP = 3,
H264SliceTypeSI = 4,
H264SliceTypeP1 = 5,
H264SliceTypeB1 = 6,
H264SliceTypeI1 = 7,
H264SliceTypeSP1 = 8,
H264SliceTypeSI1 = 9,
};
enum H264NALUType {
NAL_NIDR = 1,
NAL_PARTITION_A = 2,
NAL_PARTITION_B = 3,
NAL_PARTITION_C = 4,
NAL_IDR = 5,
};
H264BFrameFilter();
~H264BFrameFilter() = default;
/**
* @brief RTP B
* @param packet RTP
* @return B nullptr
*/
RtpPacket::Ptr processPacket(const RtpPacket::Ptr &packet);
private:
/**
* @brief RTP H.264 B
* @param packet RTP
* @return B true false
*/
bool isH264BFrame(const RtpPacket::Ptr &packet) const;
/**
* @brief NAL B
* @param nal_type NAL
* @param data NAL NAL
* @param size
* @return B true false
*/
bool isBFrameByNalType(uint8_t nal_type, const uint8_t *data, size_t size) const;
/**
* @brief
* @param data
* @param size
* @param bits_offset
* @return
*/
int decodeExpGolomb(const uint8_t *data, size_t size, size_t &bitPos) const;
/**
* @brief
* @param data
* @param size
* @return 0 1
*/
int getBit(const uint8_t *data, size_t size) const;
/**
* @brief
* @param data
* @param size
* @return
*/
uint8_t extractSliceType(const uint8_t *data, size_t size) const;
/**
* @brief FU-A分片
* @param payload
* @param payload_size
* @return B true false
*/
bool handleFua(const uint8_t *payload, size_t payload_size) const;
/**
* @brief STAP-A
* @param payload
* @param payload_size
* @return B true false
*/
bool handleStapA(const uint8_t *payload, size_t payload_size) const;
private:
uint16_t _last_seq; // 维护输出流的序列号
uint32_t _last_stamp; // 维护输出流的时间戳
bool _first_packet; // 是否是第一个包的标记
};
class WebRtcPlayer : public WebRtcTransportImp {
public:
using Ptr = std::shared_ptr<WebRtcPlayer>;
static Ptr create(const toolkit::EventPoller::Ptr &poller, const RtspMediaSource::Ptr &src, const MediaInfo &info,
WebRtcTransport::Role role, WebRtcTransport::SignalingProtocols signaling_protocols);
MediaInfo getMediaInfo() { return _media_info; }
protected:
///////WebRtcTransportImp override///////
void onStartWebRTC() override;
void onDestory() override;
void onRtcConfigure(RtcConfigure &configure) const override;
private:
WebRtcPlayer(const toolkit::EventPoller::Ptr &poller, const RtspMediaSource::Ptr &src, const MediaInfo &info);
void sendConfigFrames(uint32_t before_seq, uint32_t sample_rate, uint32_t timestamp, uint64_t ntp_timestamp);
private:
// 媒体相关元数据 [AUTO-TRANSLATED:f4cf8045]
// Media related metadata
MediaInfo _media_info;
// 播放的rtsp源 [AUTO-TRANSLATED:9963eed1]
// Playing rtsp source
std::weak_ptr<RtspMediaSource> _play_src;
// rtp 直接转发情况下通常会缺少 sps/pps, 在转发 rtp 前, 先发送一次相关帧信息, 部分情况下是可以播放的 [AUTO-TRANSLATED:65fdf16a]
// In the case of direct RTP forwarding, sps/pps is usually missing. Before forwarding RTP, send the relevant frame information once. In some cases, it can be played.
bool _send_config_frames_once { false };
// 播放rtsp源的reader对象 [AUTO-TRANSLATED:7b305055]
// Reader object for playing rtsp source
RtspMediaSource::RingType::RingReader::Ptr _reader;
bool _is_h264 { false };
bool _bfliter_flag { false };
std::shared_ptr<H264BFrameFilter> _bfilter;
};
}// namespace mediakit
#endif // ZLMEDIAKIT_WEBRTCPLAYER_H