用Java实现简单的语音朗读

实验三  利用微软的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();
	    }
	}

}
由于课时以及作为计算机专业大四的课程等原因,这个系列的实验基本上都是体验性的,要写的代码其实不是很多,只是起到一个体验的作用。

  • 9
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 20
    评论
评论 20
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值