讯飞语音

添加静态库
将开发工具包中lib目录下地iflyMSC.framework添加到工程中去。再添加如下图所示的库:
2.png
3)导入头文件

在.pch文件导入如下头文件:
01        #import <iflyMSC/IFlyRecognizerViewDelegate.h>
02        #import <iflyMSC/IFlyRecognizerView.h>
03          
04        #import <iflyMSC/IFlySpeechRecognizerDelegate.h>
05        #import <iflyMSC/IFlySpeechRecognizer.h>
06          
07        #import <iflyMSC/IFlySpeechUnderstander.h>
08          
09        #import <iflyMSC/IFlySpeechSynthesizerDelegate.h>
10        #import <iflyMSC/IFlySpeechSynthesizer.h>
11          
12        #import <iflyMSC/IFlyContact.h>
13        #import <iflyMSC/IFlyDataUploader.h>
14        #import <iflyMSC/IFlyUserWords.h>
15        #import <iflyMSC/IFlySpeechConstant.h>
16        #import <iflyMSC/IFlySpeechUtility.h>

    4)初始化SDK

在AppDelegate.m文件中的- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions里添加如下代码:
1        NSString *appid = @"53be3a59";
2            NSString *initString = [NSString stringWithFormat:@"appid=%@",appid];
3        [IFlySpeechUtility createUtility:initString];

请自行根据自己应用的APPID修改appid字符串内容。

    5)语音转写,带界面
01        //初始化语音识别控件
02            self.iflyRecognizerView = [[IFlyRecognizerView alloc]initWithCenter:self.view.center];
03            self.iflyRecognizerView.delegate = self;
04            [self.iflyRecognizerView setParameter: @"iat" forKey:[IFlySpeechConstant IFLY_DOMAIN]];
05            //asr_audio_path保存录音文件名,默认目录是documents
06            [self.iflyRecognizerView setParameter: @"asrview.pcm" forKey:[IFlySpeechConstant ASR_AUDIO_PATH]];
07                //设置返回的数据格式为默认plain
08            [self.iflyRecognizerView setParameter:@"plain" forKey:[IFlySpeechConstant RESULT_TYPE]];
09        - (void)startListenning:(id)sender{
10            [self.iflyRecognizerView start];
11        NSLog(@"开始识别");}
12        //返回数据处理
13        - (void)onResult:(NSArray *)resultArray isLast:(BOOL)isLast
14        {
15            NSMutableString *result = [NSMutableString new];
16            NSDictionary *dic = [resultArray objectAtIndex:0];
17            NSLog(@"DIC:%@",dic);
18            for (NSString *key in dic) {
19                [result appendFormat:@"%@",key];
20            }
21            self.textView.text = [NSString stringWithFormat:@"%@%@",self.textView.text,result];}
22          
23        - (void)onError:(IFlySpeechError *)error
24        {
25            NSLog(@"RecognizerView error : %@",error.errorDesc);}

    6)上传联系人
01        //创建上传实例
02        self.uploader = [IFlyDataUploader new];
03        //获取联系人
04        IFlyContact *iflyContact = [IFlyContact new];
05        NSString *contact = [iflyContact contact];
06          
07        [self.uploader setParameter:@"uup" forKey:@"subject"];
08        [self.uploader setParameter:@"contact" forKey:@"dtt"];
09        [self.uploader uploadDataWithCompletionHandler:^(NSString *result, IFlySpeechError *error) {
10                NSLog(@"uploader contact error: %d",[error errorCode]);
11                if (![error errorCode]) {
12                    [self.popUpView setText: @"上传成功"];
13                    [self.view addSubview:self.popUpView];
14                }
15                else {
16                    [self.popUpView setText: @"上传失败"];
17                    [self.view addSubview:self.popUpView];
18                }
19            } name:@"contact" data: contact];

    7)上传用户词表
01        [self.uploader setParameter:@"iat" forKey:@"subject"];
02        [self.uploader setParameter:@"userword" forKey:@"dtt"];}
03        IFlyUserWords *iflyUserWords = [[IFlyUserWords alloc] initWithJson:@"{\"userword\":[{\"name\":\"iflytek\",\"words\":[\"DevStore\",\"Steven\",\"清蒸鲈鱼\",\"挪威三文鱼\",\"黄埔军校\",\"横沙牌坊\",\"科大讯飞\"]}]}" ];
04        [self.uploader uploadDataWithCompletionHandler:^(NSString *result, IFlySpeechError *error) {
05                NSLog(@"upload userwords error: %d",[error errorCode]);
06                if (![error errorCode]) {
07                    [self.popUpView setText: @"上传成功"];
08                    [self.view addSubview:self.popUpView];
09                }
10                else {
11                    [self.popUpView setText: @"上传失败"];
12                    [self.view addSubview:self.popUpView];
13                }
14            } name:@"userwords" data:[iflyUserWords toString]];

    8)语义识别
01        self.iflySpeechUnderstander = [IFlySpeechUnderstander sharedInstance];
02        self.iflySpeechUnderstander.delegate = self;
03        [self.iflySpeechUnderstander startListening];
04        - (void)onResults:(NSArray *)results isLast:(BOOL)isLast{
05            NSMutableString *resultString = [[NSMutableString alloc] init];
06            NSDictionary *dic = results [0];
07            for (NSString *key in dic) {
08                [resultString appendFormat:@"%@",key];
09            }
10            NSLog(@"听写结果:%@",resultString);
11        }
12        - (void)onError:(IFlySpeechError *)errorCode{
13            NSString *text ;
14        if (errorCode.errorCode ==0 ) {
15                if (result.length==0) {
16                    text = @"无识别结果";
17                }
18                else
19                {
20                    text = @"识别成功";
21                }
22            }
23            else
24            {
25                text = [NSString stringWithFormat:@"发生错误:%d %@",errorCode.errorCode,errorCode.errorDesc];
26        }
27        NSLog(@"%@",text);
28        }

    9)语音合成
view source
print?
01        //头文件定义
02        @interface SpeechSynViewController : UIViewController <IFlySpeechSynthesizerDelegate>
03        @property (nonatomic,strong)IFlySpeechSynthesizer *iflySpeechSyn;   
04        //.m文件定义
05        #define SPEAKING @"DevStore全球首家开发者服务商店。\
06         
07         
08         "
09        - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
10        {
11            self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
12            if (self) {
13                //创建合成对象
14                self.iflySpeechSyn = [IFlySpeechSynthesizer sharedInstance];
15                self.iflySpeechSyn.delegate = self;
16                //设置语音合成的参数
17                //语速,取值范围 0~100
18                [self.iflySpeechSyn setParameter:@"50" forKey:[IFlySpeechConstant SPEED]];
19                //音量;取值范围 0~100
20                [self.iflySpeechSyn setParameter:@"50" forKey:[IFlySpeechConstant VOLUME]];
21                //发音人,默认为”xiaoyan”;可以设置个性化发音人列表
22                [self.iflySpeechSyn setParameter:@"xiaoyan" forKey:[IFlySpeechConstant VOICE_NAME]];
23                //音频采样率,目前支持的采样率有 16000 和 8000
24                [self.iflySpeechSyn setParameter:@"8000" forKey:[IFlySpeechConstant SAMPLE_RATE]];
25                //asr_audio_path保存录音文件路径,如不再需要,设置value为nil表示取消,默认目录是 documents
26                [self.iflySpeechSyn setParameter:@"tts.pcm" forKey:[IFlySpeechConstant TTS_AUDIO_PATH]];
27        }
28            return self;
29        }
30        //开始播放
31        - (void) onStart:(id) sender
32        {
33        [self.iflySpeechSyn startSpeaking:SPEAKING];
34        }
35        //合成结束,此代理必须要实现
36        - (void) onCompleted:(IFlySpeechError *)error
37        {
38            NSString *text;
39            if (self.isCanceled)
40            {
41                text = @"合成已取消";
42            }
43            else if(error.errorCode == 0)
44            {
45                text = @"合成结束";
46            }
47            else
48            {
49                text = [NSString stringWithFormat:@"发生错误:%d %@",error.errorCode,error.errorDesc];
50                NSLog(@"%@",text);
51            }
52        }
2 预备工作 2.1 创建iOS工程 在XCode中建立你的工程,或者打开已经建立的工程。 2.2 添加静态库 将开发工具包中lib目录下的iflyMSC.framework添加到新建工程中(如下图所示)。 提交 图一 图二 提交 图三 2.3 添加framework 按下图添加SDK所需要的iOS库,请注意libz.dylib,CoreTelephoney.framework不要遗漏。 提交 图四 注:如果使用的是离线识别,还需要增加libc++.dylib。 2.4 确认SDK的路径 提交 图五 请确认上图红色部分的路径能够找到iflyMSC.framework。为了支持多人开发,建议双击红色部分,把路径改为相对路径,例如像下图所示。 提交 图六 注意:请把不必要的路径删除。例如更新了SDK后,新的SDK与旧的SDK不在同一路径,请把旧的路径删除,避免引用到旧的库。对应集成SDK后发现编译失败,提示找不到头文件,请先检查这个路径是否正确。 2.5 导入头文件 在你需要使用MSC服务的文件中导入相应的头文件 例如: C/C++ Code //带界面的语音识别控件 #import “iflyMSC/IFlyRecognizerViewDelegate.h” #import “iflyMSC/IFlyRecognizerView.h” C/C++ Code //不带界面的语音识别控件 #import “iflyMSC/IFlySpeechRecognizerDelegate.h” #import “iflyMSC/IFlySpeechRecognizer.h” C/C++ Code //不带界面的语音合成控件 #import “iflyMSC/IFlySpeechSynthesizerDelegate.h” #import “iflyMSC/IFlySpeechSynthesizer.h” 2.6 集成帮助文档到Xcode 打开终端(termainl或iterm),cd 到压缩包的doc 目录,执行以下命令: 注:不同的xcode版本,对应的docset路径可能有变化,需要根据实际路径来操作。 C/C++ Code cp -R -f -a com.iflytek.documentation.IFlyMSC.docset ~/Library/Developer/Shared/Documentation/DocSets/ 然后执行命令 C/C++ Code open ~/Library/Developer/Shared/Documentation/DocSets/ 请核对文档的版本为最新下载的版本 提交 图七 打开Xcode的帮助文档就可以看到已经集成的文档 提交 图八 2.7 初始化 必须在初始化后才可以使用语音服务,初始化是异步过程,推荐在程序入口处调用。 Appid是应用的身份信息,具有唯一性,初始化时必须要传入Appid。可以从demo的Definition.h APPID_VALUE中查看此信息。Demo和SDK申请地址:http://xfyun.cn C/C++ Code //将“12345678”替换成您申请的APPID。 NSString *initString = [[NSString alloc] initWithFormat:@"appid=%@",@” 12345678”]; [IFlySpeechUtility createUtility:initString]; 3 语音听写 使用示例如下: C/C++ Code //头文件定义 //需要实现IFlyRecognizerViewDelegate,为识别会话的服务代理 @interface RecognizerViewController : UIViewController<IFlyRecognizerViewDelegate> { IFlyRecognizerView *_iflyRecognizerView; } //初始化语音识别控件 _iflyRecognizerView = [[IFlyRecognizerView alloc] initWithCenter:self.view.center]; _iflyRecognizerView.delegate = self; [_iflyRecognizerView setParameter: @"iat" forKey: [IFlySpeechConstant IFLY_DOMAIN]]; //asr_audio_path保存录音文件名,如不再需要,设置value为nil表示取消,默认目录是documents [_iflyRecognizerView setParameter:@"asrview.pcm " forKey:[IFlySpeechConstant ASR_AUDIO_PATH]]; //启动识别服务 [_iflyRecognizerView start]; /*识别结果返回代理 @param resultArray 识别结果 @ param isLast 表示是否最后一次结果 */ - (void)onResult: (NSArray *)resultArray isLast:(BOOL) isLast { } /*识别会话错误返回代理 @ param error 错误码 */ - (void)onError: (IFlySpeechError *) error { } 4 语音识别 4.1 在线语音识别 上传联系人,使用示例如下: C/C++ Code //创建上传对象 _uploader = [[IFlyDataUploader alloc] init]; //获取联系人集合 IFlyContact *iFlyContact = [[IFlyContact alloc] init]; NSString *contactList = [iFlyContact contact]; //设置参数 [_uploader setParameter:@"uup" forKey:@"subject"]; [_uploader setParameter:@"contact" forKey:@"dtt"]; //启动上传 [_uploader uploadDataWithCompletionHandler:^(NSString * grammerID, IFlySpeechError *error) { //接受返回的grammerID和error [self onUploadFinished:grammerID error:error]; }name:@"contact" data: contactList]; 上传用户词表,使用示例如下: C/C++ Code //创建上传对象 _uploader = [[IFlyDataUploader alloc] init]; //生成用户词表对象 //用户词表 #define USERWORDS @"{\"userword\":[{\"name\":\"iflytek\",\"words\":[\"德国盐猪手\",\"1912酒吧街\",\"清蒸鲈鱼\",\"挪威三文鱼\",\"黄埔军校\",\"横沙牌坊\",\"科大\"]}]}" IFlyUserWords *iFlyUserWords = [[IFlyUserWords alloc] initWithJson:USERWORDS ]; #define NAME @"userwords" //设置参数 [_uploader setParameter:@"iat" forKey:@"sub"]; [_uploader setParameter:@"userword" forKey:@"dtt"]; //上传词表 [_uploader uploadDataWithCompletionHandler:^(NSString * grammerID, IFlySpeechError *error) { //接受返回的grammerID和error [self onUploadFinished:grammerID error:error]; } name:NAME data:[iFlyUserWords toString]]; abnf语法上传,示例如下: C/C++ Code // ABNF语法示例,可以说”北京到上海” #define ABNFPARAM @”sub=asr,dtt=abnf” #define ABNFDATA = “#ABNF 1.0 gb2312; language zh-CN; mode voice; root $main; $main = $place1 到$place2 ; $place1 = 北京 | 武汉 | 南京 | 天津 | 天京 | 东京; $place2 = 上海 | 合肥;” //创建上传对象 _uploader = [[IFlyDataUploader alloc] init]; //设置参数 [_uploader setParameter:@"asr" forKey:@"sub"]; [_uploader setParameter:@"abnf" forKey:@"dtt"]; //上传abnf语法 [_uploader uploadDataWithCompletionHandler:^(NSString * grammerID, IFlySpeechError *error) { //接受返回的grammerID和error [self setGrammerId:grammerID]; }name:ABNFNAME data:ABNFDATA]; 4.2 本线语音识别 1) 创建识别对象(注:如果使用的是离线识别,还需要增加libc++.dylib) C/C++ Code //此方法为demo中封装,具体实现请参照demo。 self.iFlySpeechRecognizer = [RecognizerFactory CreateRecognizer:self Domain:@"asr"]; 2)设置参数 C/C++ Code //开启候选结果 [_iflySpeechRecognizer setParameter:@"1" forKey:@"asr_wbest"]; //设置引擎类型,clound或者local [_iflySpeechRecognizer setParameter:@”local” forKey:[IFlySpeechConstant ENGINE_TYPE]]; //设置字符编码为utf-8 [_iflySpeechRecognizer setParameter:@"utf-8" forKey:[IFlySpeechConstant TEXT_ENCODING]]; //语法类型,本地是bnf,在线识别是abnf [_iflySpeechRecognizer setParameter:@”bnf” forKey:[IFlyResourceUtil GRAMMARTYPE]]; //启动asr识别引擎 [[IFlySpeechUtility getUtility] setParameter:@"asr" forKey:[IFlyResourceUtil ENGINE_START]]; //设置服务类型为asr识别 [_iflySpeechRecognizer setParameter:@"asr" forKey:[IFlySpeechConstant IFLY_DOMAIN]]; //设置语法构建路径,该路径为sandbox下的目录,请确保目录存在 [_iflySpeechRecognizer setParameter:_grammBuildPath forKey:[IFlyResourceUtil GRM_BUILD_PATH]]; //设置引擎资源文件路径,如demo中的aitalkResource中的common.mp3 [_iflySpeechRecognizer setParameter:_aitalkResourcePath forKey:[IFlyResourceUtil ASR_RES_PATH]]; 3)编译语法文本
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值