gpt4 book ai didi

c# - 使用回调从WCF发送混合声音

转载 作者:行者123 更新时间:2023-12-03 02:07:08 25 4
gpt4 key购买 nike

我想将混合声音从WCF服务器传输到所有连接的客户端。为此使用WCF服务回调。使用naudio库混合声音。

这是服务器端(WCF方法)的小示例:

MixingSampleProvider _mixer = new MixingSampleProvider(sound32.WaveFormat);
SampleToWaveProvider _sampleToWave = new SampleToWaveProvider(_mixer);

// service method
byte[] buffer = new byte[1000];
do{
_sampleToWave.Read(buffer, 0, 1000);
client.Callback.SendBuffer(buffer);
} while (_isPlaying)

和客户端:
BufferedWaveProvider _bufferedWave = new BufferedWaveProvider(sound32.WaveFormat);
// DirectSoundOut _output = new DirectSoundOut();
WaveOut _output = new WaveOut();

_output.Init(_bufferedWave);

// callback event method
if (_output.PlaybackState != PlaybackState.Playing)
_bufferedWave.AddSamples(buffer, 0, 1000);

// now in timer_tick event method
// if(_bufferedWave.BufferedDuration.TotalSeconds > 0.5)
// _output.Play();
// else
// _output.Pause();

我是新手,所以我有几个问题。
这个主意好吗?有没有更简单的选择来解决这个问题?

[EDIT_1]我使用本地两种方法创建了测试应用程序,应该对此进行模拟,然后我发现_bufferedWave.BufferedBytes在播放缓冲声音时不会清除(并且会立即溢出)。有人可以告诉我,为什么?

[EDIT_1]将_output字段的类型从DirectSoundOut更改为WaveOut,这很有帮助。
我所做的第二个更改是,我添加了DispatcherTimer来处理缓冲持续时间大于0.5的情况(根据naudio MP3Streaming示例)。

现在,我在争取缓冲时间。我只能在_timer_Tick事件方法中听到一段时间的声音:
_bufferedWave.BufferedDuration.TotalSeconds > XX // this XX is time I can hear sound

有什么想法或意见吗?

最佳答案

我不确定这是否会按您希望的方式工作。 WCF是基于TCP的,并且TCP不用于广播音频视频或由于需要不断检查数据包而需要速度的任何内容(例如游戏)。

我以前曾使用过naudio通过网络将声音传输到侦听器客户端,但是要使其正常工作,您将需要使用UDP。

如果您想让它在互联网上工作,则需要研究UDP穿孔。

同样,在传输音频之前,您应该使用ALaw或MuLaw解码器/编码器将其从16bit压缩到8bit,然后在接收到音频后再压缩回16bit。

关于c# - 使用回调从WCF发送混合声音,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27101449/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com