【实例简介】

【实例截图】

【核心代码】

using System;

using System.Windows.Forms;

using System.Collections.Generic;

using System.ComponentModel;

using System.IO;

using System.Net;

using System.Text;

using System.Runtime.InteropServices;

using System.Drawing;

using BATT.AudioModule;

namespace BATT

{

public partial class Form1 : Form

{

private BackgroundWorker backgroundWorker = new BackgroundWorker();

private string resultStr;

private bool isRecord = false;

private string accessToken = null;

private SpeechModel speechModel = new SpeechModel();

private AutomaticSpeechRecognition testASR;

private string tempStr = ""; // 存储转换后的音频文件的临时目录

private ISpeechRecorder recorder = new NAudioRecorder();

private bool switchRecord = true;

private string str = null;

public Form1()

{

InitializeComponent();

testASR = new AutomaticSpeechRecognition(speechModel);

// 绑定拖放事件

richTextBoxResult.AllowDrop = true;

}

private void Form1_Load(object sender, EventArgs e)

{

// 向comboBox添加数据

List> listItems = new List>();

listItems.Add(new KeyValuePair("中文", "zh"));

listItems.Add(new KeyValuePair("英语", "en"));

listItems.Add(new KeyValuePair("粤语", "ct"));

comboBoxLan.DataSource = listItems;

comboBoxLan.DisplayMember = "Key";

comboBoxLan.ValueMember = "Value";

comboBoxLan.SelectedIndex = 0;

// 绑定事件以实现异步化

backgroundWorker.DoWork = new DoWorkEventHandler(backgroundWorker_DoWork);

backgroundWorker.RunWorkerCompleted = new RunWorkerCompletedEventHandler(backgroundWorker_RunWorkerCompleted);

// 从文件中获取令牌,避免远程服务器上的请求过多

if (!File.Exists(@". oken.dat"))

{

accessToken = testASR.GetStrAccess(); // 令牌文件不存在,发送请求

}

else

{

string[] tokenInfo = File.ReadAllLines(@". oken.dat");

// 检查令牌是否过期

if (Convert.ToInt32(tokenInfo[1]) > ClassUtils.CurrentTime2Second())

{

accessToken = tokenInfo[0];

}

else

{

accessToken = testASR.GetStrAccess(); // 过期,再次请求刷新

}

}

speechModel.APIAccessToken = accessToken; // 更新 模式中的令牌

#region 鼠标悬停时显示提示

ToolTip toolTip = new ToolTip();

toolTip.SetToolTip(buttonRecord, "录音/停止录音");

toolTip.SetToolTip(comboBoxLan, "选择识别语言");

toolTip.SetToolTip(richTextBoxResult, "识别语音的内容");

#endregion

}

///

/// 开始录音/停止录音

///

///

///

private void buttonRecord_Click(object sender, EventArgs e)

{

if (switchRecord)

{

switchRecord = false; // 切换录音状态

buttonRecord.BackgroundImage = (Bitmap)Properties.Resources.ResourceManager.GetObject("采集结束");

if (recorder == null)

{

recorder = new NAudioRecorder();

}

recorder.SetFileName("record.wav");

recorder.StartRec();

labelInfo.ForeColor = Color.SpringGreen;

labelInfo.Text = "记录:正在采集.";

}

else

{

switchRecord = true;

buttonRecord.BackgroundImage = (Bitmap)Properties.Resources.ResourceManager.GetObject("正在采集");

if (recorder == null)

{

return;

}

isRecord = true;

recorder.StopRec();

recorder = null;

string filePath = Environment.CurrentDirectory @" ecord.wav";

StartRecognize(filePath);

}

}

private void button1_Click(object sender, EventArgs e)

{

richTextBoxResult.Clear();

}

private void StartRecognize(string apiRecord)

{

WavInfo wav = ClassUtils.GetWavInfo(apiRecord);

//数据量 = (采样频率 × 采样位数 × 声道数 × 时间) / 8

//if ((double)(wav.datasize * 8) / (wav.dwsamplespersec * wav.wbitspersample * wav.wchannels) > 60)

//{

// labelInfo.ForeColor = Color.HotPink;

// labelInfo.Text = "Error: The audio file is too large!";

//}

// 非8k/16k, 16bit 位深, 单声道的,进行格式转换

if (apiRecord.EndsWith(".mp3", StringComparison.CurrentCultureIgnoreCase)

|| int.Parse(wav.dwsamplespersec.ToString()) != 16000

|| int.Parse(wav.wbitspersample.ToString()) != 16

|| int.Parse(wav.wchannels.ToString()) != 1)

{

apiRecord = ClassUtils.Convert2Wav(apiRecord); // 音频文件转换为16k,16bit wav

tempStr = apiRecord;

}

labelInfo.ForeColor = Color.SpringGreen;

labelInfo.Text = "正在采集...";

KeyValuePair keyVal = (KeyValuePair)comboBoxLan.SelectedItem;

speechModel.APILanguage = keyVal.Value; // 在组合框中获取值

if (backgroundWorker.IsBusy != true)

{

this.backgroundWorker.RunWorkerAsync(); // 做耗时的任务

}

}

#region 异步工作

private void backgroundWorker_DoWork(object sender, DoWorkEventArgs e)

{

// 表示这是录制的音频

if (isRecord)

{

speechModel.APIRecord = System.Environment.CurrentDirectory @" ecord.wav";

isRecord = false;

}

// 表示转换工作已经完成

if (tempStr != "")

{

speechModel.APIRecord = tempStr;

}

resultStr = testASR.GetStrText() " ";

}

private void backgroundWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)

{

this.richTextBoxResult.Text = resultStr;

labelInfo.ForeColor = Color.SpringGreen;

labelInfo.Text = "识别完成!";

// 完成识别,删除临时目录

if (tempStr != "")

{

Directory.Delete(Path.GetDirectoryName(tempStr), true); // 递归删除目录或子目录

}

}

#endregion

}

}

百度语音识别(采集麦克风声音 并自动转为文字)相关推荐

  1. 百度语音输入 html5,百度语音识别(采集麦克风声音 并自动转为文字)

    资源下载此资源下载价格为2D币,请先登录 资源文件列表 c#实现百度语音识别/NAudio.dll , 506880 c#实现百度语音识别/Newtonsoft.Json.dll , 653824 c ...

  2. 百度语音识别+百度ERNIE-Gram+pyaudio麦克风录音(NLP自然语言处理)

    1.pyaudio安装及通过pyaudio实现录音 pip install pyaudio 在conda环境中安装没有报错 实现录音的代码如下: # -*- coding: utf-8 -*- fro ...

  3. Win11的两个实用技巧系列之自动开机、麦克风声音设置

    Win11电脑如何设置自动开机?Win11定时开机设置教程 有用户会给电脑设置定时开机,那么应该如何操作呢?本文就为大家带来了详细的设置方法,需要的朋友赶紧看看吧 在我们平常电脑的使用中,为了提高办公 ...

  4. C#采集麦克风话筒声音

    在项目中,我们会需要录制麦克风的声音.比如录制QQ聊天时自己说的话.那么如何采集呢?当然是采用SharpCapture!下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第一步:在引用了S ...

  5. 微信小程序学习实录6(百度经纬度采集、手动调整精度、H5嵌入小程序、百度地图jsAPI、实时定位、H5更新自动刷新)

    百度经纬度采集 一.H5页面开发 1.手机端外部JS库 2.地图容器 3.数据表单 4.地图加载 5.回调封装函数+自动定位 二.微信小程序核心代码 1.lnglat.wxml 2.lnglat.js ...

  6. Ubuntu下ffmpeg 捕获屏幕和采集声卡、摄像头、麦克风声音

    转载自:https://blog.csdn.net/encoder1234/article/details/51984779 ffmpeg在Linux下用X11grab进行屏幕录像,在Windows下 ...

  7. ffmpeg 捕获屏幕和采集声卡、摄像头、麦克风声音

    本文转载自: 作者:且行且探索  来源:CSDN  原文:https://blog.csdn.net/encoder1234/article/details/51984779 ------------ ...

  8. java+百度语音识别(语音助手)

    文章目录 项目实施图 java实时录音 java文字转语音 百度AI账号注册 百度AI接口调用 项目中应用 具体实现效果 程序缺点 因为小项目是基于:java学生管理系统(百度人脸识别 + Swing ...

  9. Python根据语音识别让无字幕视频自动生成字幕!强不强?

    问题 各大平台都有长语音转写的服务,但是收费昂贵,而且有次数和时间限制. 因此我想到了一个白嫖的好办法.将长音频根据语句停顿切割得到短音频,使用他们提供的短音频识别服务来识别长音频不是更好吗?粗略计算 ...

最新文章

  1. 腾讯云:新基建大潮下国产数据库的探索与思考 | 云·创课程实录
  2. PHP中常见的提示对照表
  3. 交换机配置——VTP管理交换机的VLAN配置
  4. (数据库系统概论|王珊)第十章数据库恢复技术:习题
  5. kettle升级jetty10实验(未完成jaas认证)
  6. mongodb获取数组中只符合条件的元素
  7. 如何传输本地文件到服务器,本地传输文件到服务器
  8. 服务器代码review要点
  9. windows消息机制
  10. JavaScript下的setTimeout(fn,0)的作用,涨知识了
  11. java旋转角度_java – 如何确定旋转图像的最终位置或角度
  12. vue+elementUI+vue-i18n实现中英文切换。
  13. 弹簧板(加强) - 计蒜客
  14. 苹果手机与手表怎么通信_苹果手表是新的入门手机
  15. elasticsearch7.x+---搜索建议设计与实现
  16. CPU卡/CPU的分类/CPU卡标准/CPU卡生产流程
  17. CTF题库—实验吧(密码学)之疑惑的汉字
  18. 如何卸载 Office
  19. linux下部署darknet
  20. 对话:通证(token)是下一代互联网数字经济的关键

热门文章

  1. Windows之——SECOH-QAD.exe占用CPU太高解决方法
  2. ​手机远程协助,用RemoteCall网页版轻松实现
  3. Thinkphp开发的云盘宝网盘赚钱系统源码/仿蓝奏百度网盘限速下载系统/分享赚钱网盘系统
  4. 雷锋网专访爱库网创始人徐建海
  5. tsm 识别 Linux7 HP磁带机,可通过FC访问的基于HBA卡target mode的虚拟磁带库(MHVTL+QLogic-FC+SCST+RHEL6.1)安装配置...
  6. kali 肉鸡的操作
  7. 动态网站设计与开发总结
  8. Citrix NetScaler 全局负载均衡解决方案
  9. 【我的Android进阶之旅】Android的Gson解析库解析报错:class com.xxx.xxx declares multiple JSON fields named xxx
  10. Ubuntu通过PPA下载指定版本软件