实验三 利用微软的speech sdk或Java speech api(jsapi)等实现简单的语音(中英文均可)朗读,最好能够实现简单的识别(6学时)
基本要求: 实现简单的语音朗读
bonus: 实现简单的识别
硬件:耳机(音箱);麦克风(识别)
软件:microsoft speechsdk或实现Java speechapi(jsapi)的工具包如freetts(http://freetts.sourceforge.net/)或sphinx4(http://cmusphinx.sourceforge.net/sphinx4/)
这个实验在实际实现时用到了jacob包,下载地址为
https://sourceforge.net/projects/jacob-project/?source=typ_redirect
需要将jacob-1.18-x64.dll文件或jacob-1.18-x86.dll文件(具体视操作系统而定)复制到Java安装目录中的bin文件夹下。
运行结果如下所示
输入文字,回车即可实现朗读。
代码如下
package 多媒体实验3;
import java.util.*;
import java.io.*;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
ActiveXComponent sap = new ActiveXComponent("Sapi.SpVoice");
Dispatch sapo = sap.getObject();
try {
// 音量 0-100
sap.setProperty("Volume", new Variant(100));
// 语音朗读速度 -10 到 +10
sap.setProperty("Rate", new Variant(2));
System.out.println("请输入要朗读的内容:");
Scanner scan=new Scanner(System.in);
String str=scan.next();
// 执行朗读
Dispatch.call(sapo, "Speak", new Variant(str));
} catch (Exception e) {
e.printStackTrace();
} finally {
sapo.safeRelease();
sap.safeRelease();
}
}
}
由于课时以及作为计算机专业大四的课程等原因,这个系列的实验基本上都是体验性的,要写的代码其实不是很多,只是起到一个体验的作用。