百度语音识别(采集麦克风声音 并自动转为文字)
【实例简介】
【实例截图】
【核心代码】
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
}
}
百度语音识别(采集麦克风声音 并自动转为文字)相关推荐
- 百度语音输入 html5,百度语音识别(采集麦克风声音 并自动转为文字)
资源下载此资源下载价格为2D币,请先登录 资源文件列表 c#实现百度语音识别/NAudio.dll , 506880 c#实现百度语音识别/Newtonsoft.Json.dll , 653824 c ...
- 百度语音识别+百度ERNIE-Gram+pyaudio麦克风录音(NLP自然语言处理)
1.pyaudio安装及通过pyaudio实现录音 pip install pyaudio 在conda环境中安装没有报错 实现录音的代码如下: # -*- coding: utf-8 -*- fro ...
- Win11的两个实用技巧系列之自动开机、麦克风声音设置
Win11电脑如何设置自动开机?Win11定时开机设置教程 有用户会给电脑设置定时开机,那么应该如何操作呢?本文就为大家带来了详细的设置方法,需要的朋友赶紧看看吧 在我们平常电脑的使用中,为了提高办公 ...
- C#采集麦克风话筒声音
在项目中,我们会需要录制麦克风的声音.比如录制QQ聊天时自己说的话.那么如何采集呢?当然是采用SharpCapture!下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第一步:在引用了S ...
- 微信小程序学习实录6(百度经纬度采集、手动调整精度、H5嵌入小程序、百度地图jsAPI、实时定位、H5更新自动刷新)
百度经纬度采集 一.H5页面开发 1.手机端外部JS库 2.地图容器 3.数据表单 4.地图加载 5.回调封装函数+自动定位 二.微信小程序核心代码 1.lnglat.wxml 2.lnglat.js ...
- Ubuntu下ffmpeg 捕获屏幕和采集声卡、摄像头、麦克风声音
转载自:https://blog.csdn.net/encoder1234/article/details/51984779 ffmpeg在Linux下用X11grab进行屏幕录像,在Windows下 ...
- ffmpeg 捕获屏幕和采集声卡、摄像头、麦克风声音
本文转载自: 作者:且行且探索 来源:CSDN 原文:https://blog.csdn.net/encoder1234/article/details/51984779 ------------ ...
- java+百度语音识别(语音助手)
文章目录 项目实施图 java实时录音 java文字转语音 百度AI账号注册 百度AI接口调用 项目中应用 具体实现效果 程序缺点 因为小项目是基于:java学生管理系统(百度人脸识别 + Swing ...
- Python根据语音识别让无字幕视频自动生成字幕!强不强?
问题 各大平台都有长语音转写的服务,但是收费昂贵,而且有次数和时间限制. 因此我想到了一个白嫖的好办法.将长音频根据语句停顿切割得到短音频,使用他们提供的短音频识别服务来识别长音频不是更好吗?粗略计算 ...
最新文章
- 腾讯云:新基建大潮下国产数据库的探索与思考 | 云·创课程实录
- PHP中常见的提示对照表
- 交换机配置——VTP管理交换机的VLAN配置
- (数据库系统概论|王珊)第十章数据库恢复技术:习题
- kettle升级jetty10实验(未完成jaas认证)
- mongodb获取数组中只符合条件的元素
- 如何传输本地文件到服务器,本地传输文件到服务器
- 服务器代码review要点
- windows消息机制
- JavaScript下的setTimeout(fn,0)的作用,涨知识了
- java旋转角度_java – 如何确定旋转图像的最终位置或角度
- vue+elementUI+vue-i18n实现中英文切换。
- 弹簧板(加强) - 计蒜客
- 苹果手机与手表怎么通信_苹果手表是新的入门手机
- elasticsearch7.x+---搜索建议设计与实现
- CPU卡/CPU的分类/CPU卡标准/CPU卡生产流程
- CTF题库—实验吧(密码学)之疑惑的汉字
- 如何卸载 Office
- linux下部署darknet
- 对话:通证(token)是下一代互联网数字经济的关键
热门文章
- Windows之——SECOH-QAD.exe占用CPU太高解决方法
- ​手机远程协助,用RemoteCall网页版轻松实现
- Thinkphp开发的云盘宝网盘赚钱系统源码/仿蓝奏百度网盘限速下载系统/分享赚钱网盘系统
- 雷锋网专访爱库网创始人徐建海
- tsm 识别 Linux7 HP磁带机,可通过FC访问的基于HBA卡target mode的虚拟磁带库(MHVTL+QLogic-FC+SCST+RHEL6.1)安装配置...
- kali 肉鸡的操作
- 动态网站设计与开发总结
- Citrix NetScaler 全局负载均衡解决方案
- 【我的Android进阶之旅】Android的Gson解析库解析报错:class com.xxx.xxx declares multiple JSON fields named xxx
- Ubuntu通过PPA下载指定版本软件