#include "G711Rtp.h" namespace mediakit { G711RtpEncoder::G711RtpEncoder(int sample_rate, int channels, int sample_bit) { _sample_rate = sample_rate; _channels = channels; _sample_bit = sample_bit; } void G711RtpEncoder::setOpt(int opt, const toolkit::Any ¶m) { if (opt == RTP_ENCODER_PKT_DUR_MS) { if (param.is()) { auto dur = param.get(); if (dur < 20 || dur > 180) { WarnL << "set g711 rtp encoder duration ms failed for " << dur; return; } // 向上 20ms 取整 [AUTO-TRANSLATED:b8a9e39e] // Round up to the nearest 20ms _pkt_dur_ms = (dur + 19) / 20 * 20; } } } bool G711RtpEncoder::inputFrame(const Frame::Ptr &frame) { auto ptr = frame->data() + frame->prefixSize(); auto size = frame->size() - frame->prefixSize(); _buffer.append(ptr, size); _in_size += size; _in_pts = frame->pts(); if (!_pkt_bytes) { // G711压缩率固定是2倍 _pkt_bytes = _pkt_dur_ms * _channels * (_sample_bit / 8) * _sample_rate / 1000 / 2; } while (_buffer.size() >= _pkt_bytes) { _out_size += _pkt_bytes; auto pts = _in_pts - (_in_size - _out_size) * (_pkt_dur_ms / (float)_pkt_bytes); RtpCodec::inputRtp(getRtpInfo().makeRtp(TrackAudio, _buffer.data(), _pkt_bytes, false, pts), false); _buffer.erase(0, _pkt_bytes); } return true; } } // namespace mediakit