Documentation ¶
Overview ¶
Package rtph264 contains a RTP/H264 decoder and encoder.
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ErrMorePacketsNeeded = errors.New("need more packets")
ErrMorePacketsNeeded is returned when more packets are needed.
var ErrNonStartingPacketAndNoPrevious = errors.New(
"received a non-starting fragment without any previous starting fragment")
ErrNonStartingPacketAndNoPrevious is returned when we received a non-starting packet of a fragmented NALU and we didn't received anything before. It's normal to receive this when decoding a stream that has been already running for some time.
Functions ¶
This section is empty.
Types ¶
type Decoder ¶
type Decoder struct { // indicates the packetization mode. PacketizationMode int // contains filtered or unexported fields }
Decoder is a RTP/H264 decoder. Specification: https://datatracker.ietf.org/doc/html/rfc6184
func (*Decoder) DecodeUntilMarker ¶
DecodeUntilMarker decodes NALUs from a RTP packet and puts them in a buffer. When a packet has the marker flag (meaning that all the NALUs with the same PTS have been received), the buffer is returned.
type Encoder ¶
type Encoder struct { // payload type of packets. PayloadType uint8 // SSRC of packets (optional). // It defaults to a random value. SSRC *uint32 // initial sequence number of packets (optional). // It defaults to a random value. InitialSequenceNumber *uint16 // initial timestamp of packets (optional). // It defaults to a random value. InitialTimestamp *uint32 // maximum size of packet payloads (optional). // It defaults to 1460. PayloadMaxSize int PacketizationMode int // contains filtered or unexported fields }
Encoder is a RTP/H264 encoder. Specification: https://datatracker.ietf.org/doc/html/rfc6184