关于sapi使用的几个坑

初次使用sapi,由于过于急于求成遇到点问题记录一下。

1.当报错时一般都是函数返回了错误代码,网上查肯定能查到不是com件的引用就是sapi的错误代码

2.com组件一定要分清版本,我是乱捣鼓又搞了个11.0的版本(也就是Microsoft Speech Platform),但是其实电脑上根本没有注册这个com组件,然后由于引用的是11.0的版本的头文件,所以根据头文件给的CLSID和本机(5.3版本)的id到后面就根本搭不着边,所以就算有时候没报错也是有问题的。。。

3.由于自己使用的qt creator写的qt程序,刚开始引用时刚一引用头文件sapi.h就报好多错,关于默认参数值的类型和形参类型不一致(vs的或者用qt(mingw)貌似没有这个问题,因为网上见到谁说过),这个时候是qt creator编译和vs编译参数有些许的不同,可以调默认的字符集,方法是

找到qt安装目录的类似这种路径;F:\Qt\Qt5.8.0\5.8\msvc2015_64\mkspecs\common,找到msvc-base.conf文件(推荐直接搜索)

然后按照自己的vs版本注释如下关于字符集的配置代码


这样编译时就没有关于上述的那个问题了。

4.qt写的话重写下面这个函数(相当于winproc函数,处理窗体消息的,其实是拦截消息)

nativeEvent(const QByteArray &eventType, void *pMsg, long *result)

最后尽量加上下面这句话

return QWidget::nativeEvent(eventType, message, result);

最后,sapi其实代码很好写,就是关于配置和调试的问题。祝大家轻松调用成功编出自己想要的效果。

sapi.spvoice是Windows操作系统中的一个语音合成技术,它可以通过人工智能算法将文本转化为声音,并通过电脑的音频输出设备播放出来。 sapi.spvoice的使用非常简单。首先,我们需要通过COM接口获取sapi.SpVoice对象。然后,我们可以调用该对象的相关方法和属性来实现我们想要的功能。 通过sapi.spvoice,我们可以将文本合成为语音。可以使用Speak方法来实现这一功能,例如: ```python import win32com.client # 获取sapi.SpVoice对象 voice = win32com.client.Dispatch("SAPI.SpVoice") # 将文本合成为语音并播放 text = "你好,欢迎使用sapi.spvoice技术" voice.Speak(text) ``` 此外,sapi.spvoice还支持一些其他的功能。我们可以通过设置voice对象的属性来实现特定的效果,例如设置语速和音量: ```python # 设置语速和音量 voice.Rate = 1 # 语速,范围从-10到10,默认为0 voice.Volume = 100 # 音量,范围从0到100,默认为100 # 合成为语音并播放 text = "你好,欢迎使用sapi.spvoice技术" voice.Speak(text) ``` 除了上述的基本功能之外,sapi.spvoice还支持其他一些高级的功能,例如选择不同的音频输出设备、选择不同的语音合成引擎等等。具体的使用方法可以参考相关的文档或者教程。 总的来说,sapi.spvoice是Windows平台上实现文本合成语音的技术之一,通过简单的调用相关的方法和属性,我们可以实现将文本转化为声音并播放的功能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值