openwebrx-clone/csdr/chain/clientaudio.py

41 lines
1.5 KiB
Python
Raw Normal View History

from csdr.chain import Chain
2021-08-12 16:01:03 +00:00
from pycsdr.modules import AudioResampler, Convert, AdpcmEncoder, Limit
from pycsdr.types import Format
class ClientAudioChain(Chain):
2021-07-29 22:06:21 +00:00
def __init__(self, format: Format, inputRate: int, clientRate: int, compression: str):
workers = []
2021-08-23 12:25:28 +00:00
self.inputRate = inputRate
self.clientRate = clientRate
if inputRate != clientRate:
2021-08-12 16:01:03 +00:00
# we only have an audio resampler for float ATM so if we need to resample, we need to convert
if format != Format.FLOAT:
workers += [Convert(format, Format.FLOAT)]
workers += [AudioResampler(inputRate, clientRate), Limit(), Convert(Format.FLOAT, Format.SHORT)]
elif format != Format.SHORT:
workers += [Convert(format, Format.SHORT)]
if compression == "adpcm":
workers += [AdpcmEncoder(sync=True)]
2021-08-23 12:25:28 +00:00
super().__init__(workers)
def setFormat(self, format: Format) -> None:
pass
def setInputRate(self, inputRate: int) -> None:
if inputRate == self.inputRate:
return
def setClientRate(self, clientRate: int) -> None:
if clientRate == self.clientRate:
return
def setAudioCompression(self, compression: str) -> None:
index = self.indexOf(lambda x: isinstance(x, AdpcmEncoder))
if compression == "adpcm":
if index < 0:
self.append(AdpcmEncoder(sync=True))
else:
if index >= 0:
self.remove(index)