文字转语音,导出音频mp3

 

用到的是Windows的SAPI,所以只支持Windows。

我测试了一百多个字符转音频导出,速度还挺快的,1秒不到就转好了。

 

#include <sapi.h>
#include "sphelper.h"
#include "atlbase.h"

#pragma comment(lib,"ole32.lib") 
#pragma comment(lib,"sapi.lib") 


// 正式代码

// 初始化
HRESULT hr = CoInitialize(NULL);
if (FAILED(hr))
{
    qDebug() << "init fail";
    return;
}

// 创建 ISpVoice
ISpVoice *pVoice;
hr = CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL, IID_ISpVoice, (void **)&pVoice);
if (FAILED(hr))
{
    qDebug() << "create fail";
    CoUninitialize();
    return;
}


CComPtr<ISpStream> cpWavStream;
CComPtr<ISpStreamFormat> cpOldStream;
CSpStreamFormat OriginalFmt;
pVoice->GetOutputStream( &cpOldStream );
OriginalFmt.AssignFormat(cpOldStream);
hr = SPBindToFile( L"D:\\output.mp3",SPFM_CREATE_ALWAYS, &cpWavStream,&OriginalFmt.FormatId(), OriginalFmt.WaveFormatExPtr() );
if( SUCCEEDED( hr ) )
{
    pVoice->SetOutput(cpWavStream,TRUE);
    QString s = ui.textEdit->toPlainText();
    pVoice->Speak(s.toStdWString().c_str(), SPF_IS_XML, NULL);
    pVoice->Release();
    pVoice = NULL;
}
CoUninitialize();

 

 

 

测试了很多电脑,都是正常可用的,公司里面只有一台电脑出现了崩溃。

这台电脑没有激活,没有声音播放器。定位到的代码是  cpOldStream 为空,然后 AssignFormat 就崩溃了。

后面我在这台电脑上插了个耳机,然后就可以正常使用了。(插上耳机后,电脑会自动安装一个声音播放器的驱动)

现在不确定是因为电脑没激活导致的,还是因为没声音播放器,没驱动导致的。

 

posted @ 2025-02-12 15:24  十一的杂文录  阅读(36)  评论(0)    收藏  举报