windows tts 文字转 wav,生成的wav文件用暴风播放到结尾处(不转文件仅朗读时正常),会出现一下杂音,怎么解决?
就下面这段代码:
void tts_speak_toWavFile(HRESULT hr,ISpVoice* pVoice,const char* text,int rate,int volume,char* outFile)
{
WCHAR* msg;
int len;
len = strlen(text) + 1;
msg = new WCHAR[len];
// convert const char* to WCHAR*
MultiByteToWideChar(CP_ACP,0,text,len,msg,len);
CComPtr<ISpStream> cpWavStream;
CComPtr<ISpStreamFormat> cpOldStream;
CSpStreamFormat OriginalFmt;
pVoice->GetOutputStream(&cpOldStream);
//SPSTREAMFORMAT eFmt = SPSF_48kHz16BitMono;//SPSF_44kHz16BitMono; //SPSF_22kHz 8Bit Stereo
//OriginalFmt.AssignFormat(eFmt) ;
OriginalFmt.AssignFormat(cpOldStream);
hr = SPBindToFile(outFile,SPFM_CREATE_ALWAYS, //把文件绑定到输出流上,
&cpWavStream,&OriginalFmt.FormatId(),
OriginalFmt.WaveFormatExPtr());
if( SUCCEEDED(hr))
{
pVoice->SetOutput(cpWavStream,TRUE); //SetOutput把输出设为绑定文件的流上
pVoice->SetRate(rate);//语速控制
pVoice->SetVolume(volume); //音量
pVoice->Speak(msg, 0, NULL);
}
pVoice->WaitUntilDone( INFINITE );
cpWavStream.Release();
// delete the pointer
delete msg;
}
这个还真不知道,参照这个吧!wav 是CD转的啊, 你把MP3转WAV根本没意义。MP3本身就是有损压缩格式,你转成了WAV, 只是加大了体积,可能有50M以上,音质却不可能更好。
像APE无损音乐,也都是WAV转的,但体积比WAV小一半。
WAV格式是比MP3质量高,不过,你用MP3转成WAV,那个可以说不算 WAV, 已经失去意思的WAV. 真正的WAV就是从CD转的,那种声音才好,你用MP3转的话,不可能使音效变好,反而可能变差.
这些年过去了,我还是遇到你:同样的问题!
发现在声音数据后面跟了一堆额外数据,有 event,有注册表信息,等。用C#生成没这个问题。