mirror of https://github.com/ossrs/srs.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
90 lines
3.2 KiB
C++
90 lines
3.2 KiB
C++
10 years ago
|
/*
|
||
|
The MIT License (MIT)
|
||
|
|
||
|
Copyright (c) 2013-2015 winlin
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||
|
this software and associated documentation files (the "Software"), to deal in
|
||
|
the Software without restriction, including without limitation the rights to
|
||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||
|
subject to the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be included in all
|
||
|
copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
*/
|
||
|
|
||
|
#ifndef SRS_PROTOCOL_RAW_AVC_HPP
|
||
|
#define SRS_PROTOCOL_RAW_AVC_HPP
|
||
|
|
||
|
/*
|
||
|
#include <srs_raw_avc.hpp>
|
||
|
*/
|
||
|
|
||
|
#include <srs_core.hpp>
|
||
|
|
||
|
#include <string>
|
||
|
|
||
|
class SrsStream;
|
||
|
|
||
|
/**
|
||
|
* the raw h.264 stream, in annexb.
|
||
|
*/
|
||
|
class SrsRawH264Stream
|
||
|
{
|
||
|
public:
|
||
|
SrsRawH264Stream();
|
||
|
virtual ~SrsRawH264Stream();
|
||
|
public:
|
||
|
/**
|
||
|
* demux the stream in annexb format.
|
||
|
* @param stream the input stream bytes.
|
||
|
* @param pframe the output h.264 frame in stream. user should never free it.
|
||
|
* @param pnb_frame the output h.264 frame size.
|
||
|
*/
|
||
|
virtual int annexb_demux(SrsStream* stream, char** pframe, int* pnb_frame);
|
||
|
/**
|
||
|
* whether the frame is sps or pps.
|
||
|
*/
|
||
|
virtual bool is_sps(char* frame, int nb_frame);
|
||
|
virtual bool is_pps(char* frame, int nb_frame);
|
||
|
/**
|
||
|
* demux the sps or pps to string.
|
||
|
* @param sps/pps output the sps/pps.
|
||
|
*/
|
||
|
virtual int sps_demux(char* frame, int nb_frame, std::string& sps);
|
||
|
virtual int pps_demux(char* frame, int nb_frame, std::string& pps);
|
||
|
public:
|
||
|
/**
|
||
|
* h264 raw data to h264 packet, without flv payload header.
|
||
|
* mux the sps/pps to flv sequence header packet.
|
||
|
* @param sh output the sequence header.
|
||
|
*/
|
||
|
virtual int mux_sequence_header(std::string sps, std::string pps, u_int32_t dts, u_int32_t pts, std::string& sh);
|
||
|
/**
|
||
|
* h264 raw data to h264 packet, without flv payload header.
|
||
|
* mux the ibp to flv ibp packet.
|
||
|
* @param ibp output the packet.
|
||
|
* @param frame_type output the frame type.
|
||
|
*/
|
||
|
virtual int mux_ipb_frame(char* frame, int nb_frame, u_int32_t dts, u_int32_t pts, std::string& ibp, int8_t& frame_type);
|
||
|
/**
|
||
|
* mux the avc video packet to flv video packet.
|
||
|
* @param frame_type, SrsCodecVideoAVCFrameKeyFrame or SrsCodecVideoAVCFrameInterFrame.
|
||
|
* @param avc_packet_type, SrsCodecVideoAVCTypeSequenceHeader or SrsCodecVideoAVCTypeNALU.
|
||
|
* @param video the h.264 raw data.
|
||
|
* @param flv output the muxed flv packet.
|
||
|
* @param nb_flv output the muxed flv size.
|
||
|
*/
|
||
|
virtual int mux_avc2flv(std::string video, int8_t frame_type, int8_t avc_packet_type, u_int32_t dts, u_int32_t pts, char** flv, int* nb_flv);
|
||
|
};
|
||
|
|
||
|
#endif
|