jittr
1.0.0
Esta implementación está diseñada para combatir la fluctuación de la red y crear flujos de medios confiables a través de paquetes udp. Los paquetes desordenados y los retrasos variables de la red son uno de los mayores problemas cuando se intenta transmitir constantemente, por ejemplo, audio a través de udp (y probablemente rtp). Esta estructura de datos almacena en búfer los paquetes y los reordena introduciendo el menor retraso posible.
Reproduzca paquetes opus desde una secuencia udp/rtp a través del jitter buffer:
use async_std :: stream :: interval ;
use std :: time :: Duration ;
use jittr :: { JitterBuffer , Packet } ;
let mut rtp_stream = /* your rtp stream */ ;
/// Your Packet implementation
struct Opus { .. }
impl Packet for Opus { .. }
/// Create a jitter buffer for Opus packets
/// It can hold up to 10 packets before it starts to discard old packets
let mut jitter = JitterBuffer :: < Opus , 10 > :: new ( ) ;
/// Create an interval for packet playback
/// A typical length for audio packets is between 10 and 20ms
let mut playback = interval ( Duration :: from_millis ( 20 ) ) ;
loop {
futures :: select! {
_ = playback . next ( ) . fuse ( ) => {
let packet = jittr . pop ( ) ;
let pcm = /* Opus decodes audio if present or infers if none */
// Write pcm to speaker
} ,
rtp = rtp_stream . next ( ) . fuse ( ) => {
let opus : Opus = rtp . unwrap ( ) ;
jittr . push ( opus ) ;
} ,
}
}