-
初始化
-
语音识别函数
-
语音解析
-
语音封装
-
运行
====================================================================
时代一直进步,现在很多技术也越来越新颖,语音技术的出现更是很大的释放了我们的双手,即便你有的字不会写但是会说,又或者你开车没法打字,当然我建议开车肯定不能玩手机,你都可以用语音识别功能进行语音识别,翻译成文字。
===============================================================
现在各个公司平台技术都相当成熟,提供了各种sdk等,像谷歌,百度,讯飞等,一开始我是打算使用谷歌平台,但是我们访问他的话速度会比较慢也可能访问不了,所以我选择了国内的平台–讯飞跟百度,两个做使用,这里我做讯飞的介绍,当然你选择谷歌其他的都是ok的。
=================================================================
首先我们需要登录 讯飞的网站进行注册登录,注册登录完之后创建我的应用,应用名称分类其他的都填一下
接着可以查看刚刚创建的应用,里面有APPID,APISecret,APIKey这些都是后面需要用到的的
下载语音识别需要的SDK,这里我选择的是Android msc
将下载的文件解压得到了如下所示的文件
在andstudio里新建一个工程,将解压文件的libs底下的MSC.jar包复制到工程的libs,然后在点击jar包,右键add as Libary,然后就可以使用了,否则你是用不了的。
接着这是一步很重要的步骤,你需要在工程底下新建一个jniLibs,然后将解压文件里的libs除jar包文件外的其他文件复制到jniLibs底下,这个坑是困扰了我好久,看讯飞的文档里写的是将.so文件放在lib底下就可以,但是就得做修改,否则会遇到21002这个错误,找不到.so
这一步很多我看到的博客上都没有提到,可能老手本身比较熟悉,对于小白来说,没加这个插件很难发现,比如我,我是看视频解析的时候看到的,你想使用.so文件必须装 ,那就是得配置NDK,NDK可以直接在编译器里在线下载
布局代码很简单,就一个按钮跟一个TextView控件,按钮是用来启动语音识别功能的,TextView是用来显示语音翻译出的文字在这里插入代码片
<TextView
android:id=“@+id/textview_context”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
app:layout_constraintBottom_toBottomOf=“parent”
app:layout_constraintLeft_toLeftOf=“parent”
app:layout_constraintRight_toRightOf=“parent”
app:layout_constraintTop_toTopOf=“parent” />
<Button
android:id=“@+id/button_input”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:text=“语音输入”
app:layout_constraintBottom_toBottomOf=“parent”
app:layout_constraintEnd_toEndOf=“parent”
app:layout_constraintStart_toStartOf=“parent”
android:onClick=“startSpeechClick”/>
首先先初始化,*****填你应用的APPID,这里强调一下,每个应该的SDK都有相对应的APPID,所以有可能你用别人的SDK,在用自己的APPID用不了
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//初始化
SpeechUtility.createUtility(this, SpeechConstant.APPID+“=5ed0cc97”);
}
接下来写了一个函数来实现语音识别,这里我用的是RecognizerDialog,当然也可以使用SpeechRecognizer,讯飞语音识别可以支持英语,普通话,粤语等,看你需要什么,有开通什么
public void startSpeechClick(View view){
RecognizerDialog mDialog = new RecognizerDialog(this, null);
//2.设置accent、language等参数
mDialog.setParameter(SpeechConstant.LANGUAGE, “zh_cn”);
mDialog.setParameter(SpeechConstant.ACCENT, “mandarin”);
mDialog.setListener(new RecognizerDialogListener() {
@Override
public void onResult(RecognizerResult recognizerResult, boolean isLast) {
if (!isLast) {
//解析语音
//返回的result为识别后的汉字,直接赋值到TextView上即可
String result = parseVoice(recognizerResult.getResultString());
textview_context.setText(result);
}
}
@Override
public void onError(SpeechError speechError) {
}
});
//4.显示dialog,接收语音输入
mDialog.show();
}
----------------------------------------------------------
接下来写的是语音解析,语音的解析使用的是json,因为我们需要在gradle里面加入 implementation ‘com.google.code.gson:gson:2.2.4’
public String parseVoice(String resultString) {
Gson gson = new Gson();
Voice voiceBean = gson.fromJson(resultString, Voice.class);
StringBuffer sb = new StringBuffer();
ArrayList<Voice.WSBean> ws = voiceBean.ws;
for (Voice.WSBean wsBean : ws) {
String word = wsBean.cw.get(0).w;
sb.append(word);
}
return sb.toString();
}
最后写的是语音的封装,用ArrayList进行收集
最后
小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
资料⬅专栏获取
最后
小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
[外链图片转存中…(img-uYfcu4hw-1719113861005)]一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人
都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
资料⬅专栏获取