文字转语音,导出音频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();
复制代码

 

posted @   十一的杂文录  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示