资讯专栏INFORMATION COLUMN

用 C# 开发自己的语音识别程序

zxhaaa / 2011人阅读

摘要:开发工具平台准备工作注册百度账号登录百度开发平台,在控制台点击百度语音服务,点击创建应用,填写必填项,勾选额外接口,点击立即创建获取秘钥。

开发工具:vs 2017

AI 平台:http://ai.baidu.com/

准备工作

1、注册百度账号

2、登录百度 AI 开发平台,http://ai.baidu.com/

3、在控制台点击“百度语音”服务,点击“创建应用”,填写必填项,勾选额外接口,点击立即创建获取秘钥。在应用列表中查看自己的id

用 360 软件管家安装 vs2017

创建自己的项目 1、新建项目

打开 vs2017,点击文件,新建项目,选择 visual C# --> windows 桌面 --> windows 窗体应用,选择自己的项目地址,点击确定

2、添加 baiduai 开发包

点击引用 --> 管理 nuGet 程序包,搜索 baiduai,点击下载

3、UI 设计

直接拖动即可,生成界面如下

4、后台功能实现

选择文件按钮

</>复制代码

  1. private void button1_Click(object sender, EventArgs e)
  2. {
  3. OpenFileDialog fdlg = new OpenFileDialog();
  4. fdlg.Title = "C# Corner Open File Dialog";
  5. //fdlg.InitialDirectory = @"c:/"; //@是取消转义字符的意思
  6. //fdlg.Filter = "All files(*.*)|*.*|All files(*.*)|*.* ";
  7. ///*
  8. // * FilterIndex 属性用于选择了何种文件类型,缺省设置为0,系统取Filter属性设置第一项
  9. // * ,相当于FilterIndex 属性设置为1.如果你编了3个文件类型,当FilterIndex =2时是指第2个.
  10. // */
  11. fdlg.FilterIndex = 2;
  12. ///*
  13. // *如果值为false,那么下一次选择文件的初始目录是上一次你选择的那个目录,
  14. // *不固定;如果值为true,每次打开这个对话框初始目录不随你的选择而改变,是固定的
  15. // */
  16. //fdlg.RestoreDirectory = true;
  17. if (fdlg.ShowDialog() == DialogResult.OK)
  18. {
  19. //textBox1.Text = System.IO.Path.GetFileNameWithoutExtension(fdlg.FileName);
  20. filePath.Text = System.IO.Path.GetFullPath(fdlg.FileName);
  21. }
  22. }

开始识别按钮

</>复制代码

  1. // 语音合成按钮
  2. private void button2_Click(object sender, EventArgs e)
  3. {
  4. string value = this.videoType.Text;
  5. String filePath = this.filePath.Text;
  6. // 设置APPID/AK/SK
  7. String APP_ID = "14433392";
  8. String API_KEY = "C7WMYgLeWv3Wm2yogwv5gD08";
  9. String SECRET_KEY = "xcvwiwikALBDBaIcGisNQ6aQImtj3qua";
  10. var client = new Asr(APP_ID, API_KEY, SECRET_KEY);
  11. client.Timeout = 60000; // 修改超时时间
  12. client.Timeout = 120000; // 若语音较长,建议设置更大的超时时间. ms
  13. FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read);
  14. byte[] buffur = new byte[fs.Length];
  15. try
  16. {
  17. fs.Read(buffur, 0, (int)fs.Length);
  18. }
  19. catch (Exception ex)
  20. {
  21. Console.Write(ex.StackTrace);
  22. }
  23. finally
  24. {
  25. if (fs != null)
  26. {
  27. //关闭资源  
  28. fs.Close();
  29. }
  30. }
  31. var result = client.Recognize(buffur, value, 16000);
  32. Convert.ToString(result);
  33. JToken resultStr = null;
  34. result.TryGetValue("result", out resultStr);
  35. Console.WriteLine("aToken===>"+ resultStr);
  36. voiceResult.Text = Convert.ToString(resultStr);
  37. Console.Write(result);
  38. }

开始合成按钮

调用 api 中 C# SDK 的语音合成 api

https://ai.baidu.com/docs#/AS...

</>复制代码

  1. // 开始合成按钮(语音合成功能)
  2. private void synthesisButton_Click(object sender, EventArgs e)
  3. {
  4. String APP_ID = "14433392";
  5. String API_KEY = "C7WMYgLeWv3Wm2yogwv5gD08";
  6. String SECRET_KEY = "xcvwiwikALBDBaIcGisNQ6aQImtj3qua";
  7. // 获取输入框的值
  8. String value = this.Speech_Synthesis.Text;
  9. // 将 value 转成语音文件存放到本地
  10. var client = new Baidu.Aip.Speech.Tts(API_KEY, SECRET_KEY);
  11. // 可选参数
  12. var option = new Dictionary()
  13. {
  14. {"spd", 5}, // 语速
  15. {"vol", 7}, // 音量
  16. {"per", 3} // 发音人,4:情感度丫丫童声
  17. };
  18. var result = client.Synthesis(value, option);
  19. try {
  20. if (result.ErrorCode == 0) { // 或 result.Success
  21. File.WriteAllBytes("E:/prepared/北航/07_工程实践--AI方向/作业/WindowsFormsApplication1/WindowsFormsApplication1/tmp.mp3", result.Data);
  22. }
  23. } catch (Exception ex) { Console.Write(ex.StackTrace); }
  24. Play();
  25. }

源码地址:https://github.com/zhongsb/vo...

关注微信公众号[ prepared ],后续会更新一系列有深度的 AI 文章。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/19871.html

相关文章

  • 《HelloGitHub》第 66 期

    摘要:功能齐全支持考勤会议管理云盘等,适用于企业协同办公支付工具库,轻松完成支付模块开发。包含训练好的模型和微服务,启动后可直接通过接口调用基于图像识别的自动化框架,支持吃鸡类射击类类等游戏类型。 .markdown-body{word-break:break-word;line-height:1.75;font-weight:400;font-size:15px;overflow-x:hidd...

    番茄西红柿 评论0 收藏2637
  • 10分钟上线 - 利函数计算构建微信小程序Server端

    摘要:本文以开发一个类似语音口令红包小程序为例,向您讲解如何使用阿里云函数计算快速构建微信小程序的服务端。 前言 这篇文章适合所有的想微信小程序开发新手、老鸟以及想准备学习开发微信小程序的程序猿。本文以开发一个类似语音口令红包小程序为例,向您讲解如何使用阿里云函数计算快速构建微信小程序的服务端。通过本文,您将会了解以下内容: demo概览 传统服务器架构 VS Serverless架构 S...

    levinit 评论0 收藏0

发表评论

0条评论

zxhaaa

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<