苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 27519|回复: 3

[IPHONE] 在iPhone项目中使用讯飞语音SDK实现语音识别和语音合成

[复制链接]
发表于 2013-4-19 11:34:20 | 显示全部楼层 |阅读模式
本帖最后由 Koson 于 2013-4-19 11:35 编辑

     现在很多手机应用中都出现了语音功能,比如:QQ音乐的语音输入进行搜素、google的语音、最近中国移动联合讯飞发布的《灵犀》手机应用,都有集成语音的功能,而且识别率也是非常的不错,比如《灵犀》中的可以通过语音实现发送短信、拨打电话功能(离线可使用),自己使用了一下,还是比较的方便,而对于一些更高级的功能却会需要在联网的情况下才能使用(查询天气、查询股票、上网搜索、听新闻、地图导航、翻译以及聊天等等功能)。大致介绍了一些,就进入正题,下面讲一讲如何使用讯飞的语音SDK加入到你的iPhone应用中吧!

1.首先请先到讯飞官方网站的开发者专区http://open.voicecloud.cn/developer.php)。如果你还没有注册,那么需要先注册一个开发者账号的。点击网站顶部的“免费注册”即可,使用你的自己的手机号码注册一个账号。

2.仅仅注册了一个开发者账号还可以使用SDK,因为还需要申请Appid。登陆之后到自己的个人中心创建一个应用填写好相关信息,然后等待审核通过,因为只有审核通过之后,你才可以下载讯飞语音的SDK。如下:

下载专区

下载专区



3.如果你的应用已经审核通过,点击SDK下载,并且选择对应平台的SDK,比如现在选择iphone平台SDK下载。

4.下载好了之后,你会看到一个压缩包,解压出来有四个文件,

解压之后文件

解压之后文件


其中sample就是讯飞提供的DEMO了,打开项目,你会看到这样的目录结构:

DEMO目录结构

DEMO目录结构


直接运行,并没有错误,只有几个警告,运行界面如下:

运行界面

运行界面

听写界面

听写界面


5.那么怎么在自己的项目中使用呢?其实还是非常简单的。讯飞也有提供相关的开发文档,还是比较详细。在开发者专区和下载专区都有文档可供下载。

6.新建一个iPhone 项目吧。新建好了之后,需要先导入需要的lib,如下:

lib

lib

其中需要说明的是,iflyMSC.framework这个lib就在你下载的SDK解压文件下的lib文件夹下。在添加lib的界面选择Add Others...,并且选择你下载的lib。点击Open,就能正确添加。

选择iflyMSC.framework

选择iflyMSC.framework


7.一些函数和配置的说明:

在你需要使用SDK的头文件中导入文件:
  1. #import "iFlyMSC/IFlyRecognizeControl.h"
  2. #import "iFlyMSC/IFlysynthesizerControl.h"
复制代码
创建一个识别控件或者合成控件:
  1. IFlyRecognizeControl    *_iFlyRecognizeController;    //識別控件
  2. IFlySynthesizerControl  *_iFlySynthesizerControl;     //合成控件
复制代码
在实现文件初始化控件:
  1. //初始化語音識別控件
  2.     _iFlyRecognizeController = [[IFlyRecognizeControl alloc] initWithOrigin:CGPointMake(20, 70) initParam:initPara];
  3.     [self.view addSubview:_iFlyRecognizeController];
  4.    
  5.     //Configure
  6.     [_iFlyRecognizeController setEngine:@"sms" engineParam:nil grammarID:nil];
  7.     [_iFlyRecognizeController setSampleRate:16000];
  8.     [_iFlyRecognizeController setDelegate:self];
  9.     [_iFlyRecognizeController setShowLog:NO];
  10.    
  11.     //註冊unActive事件
  12.     [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(resignActive) name:UIApplicationWillResignActiveNotification object:nil];
  13.    
  14.     //初始化語音合成控件
  15.     _iFlySynthesizerControl = [[IFlySynthesizerControl alloc] initWithOrigin:CGPointMake(20, 70) initParam:initPara];
  16.    
  17.     //Configure
  18.     [_iFlySynthesizerControl setDelegate:self];
  19.     [_iFlySynthesizerControl setVoiceName:@"vixm"];  //發音人(中英文粵語)
  20.     [self.view addSubview:_iFlySynthesizerControl];
  21.    
  22.     //show UI
  23.     [_iFlySynthesizerControl setShowUI:YES];
  24.    
  25.     //show log
  26.     [_iFlySynthesizerControl setShowLog:NO];
  27.    
  28.     //註冊unActive事件
  29.     [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(resignactiveOfSynthesizer) name:UIApplicationWillResignActiveNotification object:nil];
复制代码
一些回调函数和方法:
  1. //識別結束回調函數-會話過程結束調用此函數
  2. - (void)onRecognizeEnd:(IFlyRecognizeControl *)iFlyRecognizeControl theError:(int)error
  3. {
  4.     [_recognizeButton setEnabled:YES];
  5.     [_synthesizerButton setEnabled:YES];
  6.     NSLog(@"識別結束");
  7.     NSLog(@"上傳流量:%d,下載流量:%d",[iFlyRecognizeControl getUpflow:FALSE],[iFlyRecognizeControl getDownflow:FALSE]);
  8. }

  9. //識別結果回調函數
  10. - (void)onResult:(IFlyRecognizeControl *)iFlyRecognizeControl theResult:(NSArray *)resultArray
  11. {
  12.     NSString *strResult = [[resultArray objectAtIndex:0] objectForKey:@"NAME"];
  13.     NSLog(@"識別的結果是:%@",strResult);
  14. }

  15. //開始語音識別
  16. - (void)onButtonRecognize
  17. {
  18.     if ([_iFlyRecognizeController start]) {
  19.         [_recognizeButton setEnabled:NO];
  20.         [_synthesizerButton setEnabled:NO];
  21.     }
  22. }

  23. //不支持後台模式則在unActive事件時執行cancel
  24. - (void)resignActive
  25. {
  26.     [_iFlyRecognizeController cancel];
  27. }

  28. //合成回調函數,執行cancel函數整個會話結束調用此函數
  29. - (void)onSynthesizerEnd:(IFlySynthesizerControl *)iFlySynthesizerControl theError:(int)error
  30. {
  31.     [_synthesizerButton setEnabled:YES];
  32.     [_recognizeButton setEnabled:YES];
  33.     NSLog(@"結束");
  34.     NSLog(@"上傳流量:%d,下載流量:%d",[iFlySynthesizerControl getUpflow:FALSE],[iFlySynthesizerControl getDownflow:FALSE]);
  35. }

  36. //獲取播放器緩衝進度
  37. - (void)onSynthesizerBufferProgress:(float)bufferProgress
  38. {
  39.     NSLog(@"當前緩衝進度:%f",bufferProgress);
  40. }

  41. //獲取播放器播放進度
  42. - (void)onSynthesizerPlayProgress:(float)playProgress
  43. {
  44.     NSLog(@"當前播放進度:%f",playProgress);
  45. }

  46. //開始語音合成
  47. - (void)onButtonSynthesizer
  48. {
  49.     [_iFlySynthesizerControl setText:@"哈哈,这仅仅是一个测试合成功能的例子而已,你不用太紧张会发生什么特别的事情。谢谢" params:nil];
  50.     if ([_iFlySynthesizerControl start]) {
  51.         [_recognizeButton setEnabled:NO];
  52.         [_synthesizerButton setEnabled:NO];
  53.     } else {
  54.         NSLog(@"I'm sorry,start error. ");
  55.     }
  56. }

  57. //不支持後台模式則unActive事件時執行cancel
  58. - (void)resignactiveOfSynthesizer
  59. {
  60.     NSLog(@"resignActive");
  61.     [_iFlySynthesizerControl cancel];
  62. }
复制代码
其中下列方法可以在自己需要开始使用语音功能的地方调用,比如:
  1. _recognizeButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
  2.     _synthesizerButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
  3.     [_recognizeButton setFrame:CGRectMake(70, 100, 180, 60)];
  4.     [_synthesizerButton setFrame:CGRectMake(70, 200, 180, 60)];
  5.     [_recognizeButton setTitle:@"開始語音識別" forState:UIControlStateNormal];
  6.     [_synthesizerButton setTitle:@"開始語音合成" forState:UIControlStateNormal];
  7.    
  8.     [_recognizeButton addTarget:self action:@selector(onButtonRecognize) forControlEvents:UIControlEventTouchDown];
  9.     [_synthesizerButton addTarget:self action:@selector(onButtonSynthesizer) forControlEvents:UIControlEventTouchDown];
  10.    
  11.     [self.view addSubview:_recognizeButton];
  12.     [self.view addSubview:_synthesizerButton];

  13. //開始語音識別
  14. - (void)onButtonRecognize
  15. {
  16.     if ([_iFlyRecognizeController start]) {
  17.         [_recognizeButton setEnabled:NO];
  18.         [_synthesizerButton setEnabled:NO];
  19.     }
  20. }

  21. //開始語音合成
  22. - (void)onButtonSynthesizer
  23. {
  24.     [_iFlySynthesizerControl setText:@"这仅仅是一个测试合成功能的例子,你不用太紧张会发生什么" params:nil];
  25.     if ([_iFlySynthesizerControl start]) {
  26.         [_recognizeButton setEnabled:NO];
  27.         [_synthesizerButton setEnabled:NO];
  28.     } else {
  29.         NSLog(@"I'm sorry,start error. ");
  30.     }
  31. }
复制代码
8.到这里已经可以使用语音识别和合成功能了。如下:

最终效果

最终效果

语音识别

语音识别

语音合成

语音合成





1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2013-4-19 11:48:29 | 显示全部楼层
你现在是不是主要搞Iphone的开发呀
 楼主| 发表于 2013-4-19 11:53:16 | 显示全部楼层
站长苏飞 发表于 2013-4-19 11:48
你现在是不是主要搞Iphone的开发呀

飞哥看我发的就大致可以明白了,iPhone要做,web也要做。哈哈,最近完成了web估计很快就有ios的Project了。
发表于 2013-4-19 12:19:21 | 显示全部楼层
Iphone的我不懂,只知道怎么动态打包,呵呵
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2025-1-19 16:21

© 2014-2021

快速回复 返回顶部 返回列表