android开发-百度语音辨认Android SDK的简单利用

海哥  金牌会员 | 2025-2-19 02:01:50 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 975|帖子 975|积分 2925


3.准备开发情况

3.1安装Android studio

Android studio安装教程
3.2创建百度智能云平台应用

百度智能云链接
①登录百度智能云之后点击创建应用开始创建平台应用

②打开左侧导航栏找到语音技能

③进入到概览界面中,点击创建应用

④填写新应用相干信息

⑤点击立即创建后再点击查看应用详情,此处的AppID,AppID,Secret Key与包名都是后续需要利用到的,到时直接复制黏贴即可

3.1下载百度语音辨认SDK

语音辨认Android SDK下载所在。
下载后解压到当地。解压后会发现是个安卓工程,若想要把该工程跑起来可以本身看看其中的README文档。想要深入相识,可看百度语音开放平台Android SDK用户指南。



4.实现语音辨认的简单案例

4.1创建Android工程



4.2导入core模块

①File→New→Import Module

②找到之前解压出的文件中的core文件夹,选择OK→Finish

③此时查看项目目录下的settings.gradle, 可以看见core module已经被加载,同时可以看见core目录的图标,阐明导入成功

4.3配置app依赖core

①右击app目录选择Open Module Settings

②在打开的界面选择Dependencies→app→+号→Module Dependency

③在弹出的界面勾选core后点击OK,然后选择Apply


④此时观察build.gradle(module :app)文件,发现自动添加了如下一行
implementation project(path: ‘:core’)

⑤根据app/build.gradle(module :app)更改core/build.gradle(module :core)部分版本号。因为我用的API Level是29所以我改成29,你的不一定和我一样,以你的app/build.gradle(module :app)文件中内容为准。

⑥在你的core\manifests\AndroidManifest.xml文件里,替换你的appId 丶appKey与secretKey为之前你在百度智能云上创建的应用的对应信息

4.4利用百度语音辨认SDK

①修改布局文件app\res\layout\activity_main.xml,简单写一个界面即可

代码如下:
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android=“http://schemas.android.com/apk/res/android”
xmlns:app=“http://schemas.android.com/apk/res-auto”
xmlns:tools=“http://schemas.android.com/tools”
android:layout_width=“match_parent”
android:layout_height=“match_parent”
tools:context=“.MainActivity”>
<EditText
android:id=“@+id/edittext”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:hint=“请点击开始灌音”
app:layout_constraintEnd_toEndOf=“parent”
app:layout_constraintStart_toStartOf=“parent”
app:layout_constraintTop_toTopOf=“parent” />
<Button
android:id=“@+id/btn_start”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:text=“开始灌音”
app:layout_constraintEnd_toStartOf=“@+id/edittext”
app:layout_constraintTop_toTopOf=“@+id/btn_stop” />
<Button
android:id=“@+id/btn_stop”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_marginTop=“116dp”
android:text=“停止灌音”
app:layout_constraintStart_toEndOf=“@+id/edittext”
app:layout_constraintTop_toTopOf=“parent” />
</androidx.constraintlayout.widget.ConstraintLayout>
试运行看看实际结果

②android 6.0 以上版本权限申请。语音辨认要用到麦克风,这个利用权限是需要动态申请的。
/**


  • android 6.0 以上需要动态申请权限
*/
private void initPermission() {
String permissions[] = {Manifest.permission.RECORD_AUDIO,
Manifest.permission.ACCESS_NETWORK_STATE,
Manifest.permission.INTERNET,
Manifest.permission.WRITE_EXTERNAL_STORAGE
};
ArrayList toApplyList = new ArrayList();
for (String perm : permissions) {
if (PackageManager.PERMISSION_GRANTED != ContextCompat.checkSelfPermission(this, perm)) {
toApplyList.add(perm);
//进入到这里代表没有权限
}
}
String tmpList[] = new String[toApplyList.size()];
if (!toApplyList.isEmpty()) {
ActivityCompat.requestPermissions(this, toApplyList.toArray(tmpList), 123);
}
}
/**


  • 权限申请回调,可以作进一步处理
  • @param requestCode
  • @param permissions
  • @param grantResults
*/
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
// 此处为android 6.0以上动态授权的回调,用户自行实现。
}
③初始化控件与语音辨认的焦点SDK
protected EditText txtResult;//辨认结果
protected Button startBtn;//开始辨认,一连一定时间不语言会自动停止,需要再次打开
protected Button stopBtn;//停止辨认,立即停止,直接输出已经辨认的内容
private EventManager asr;//语音辨认焦点库
/**


  • 初始化控件
*/
private void initView() {
txtResult = (EditText) findViewById(R.id.edittext);
startBtn = (Button) findViewById(R.id.btn_start);
stopBtn = (Button) findViewById(R.id.btn_stop);
startBtn.setOnClickListener(new View.OnClickListener() {//点击开始按钮
@Override
public void onClick(View v) {
asr.send(SpeechConstant.ASR_START, null, null, 0, 0);
}
});
stopBtn.setOnClickListener(new View.OnClickListener() {//点击停止按钮
@Override
public void onClick(View v) {
asr.send(SpeechConstant.ASR_STOP, null, null, 0, 0);
}
});
}
④在onCreate方法中调用
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
initPermission();
//初始化EventManager对象
asr = EventManagerFactory.create(this, “asr”);
//注册本身的输出变乱类
asr.registerListener(this); // EventListener 中 onEvent方法
}
此时会有错误提示,因为我们还没有实现EventListener这个捏词,接下来我们就实现这个接口

⑤实现EventListener接口,要留意这个接口是百度的这个

实现接口的onEvent方法
/**


  • 自界说输出变乱类 EventListener 回调方法
*/
@Override
public void onEvent(String name, String params, byte[] data, int offset, int length) {
if (name.equals(SpeechConstant.CALLBACK_EVENT_ASR_PARTIAL)) {
// 辨认相干的结果都在这里
if (params == null || params.isEmpty()) {
return;
}
if (params.contains(““final_result””)) {
// 一句话的最终辨认结果
String regrex = “\[(.*?),”; //利用正则表达式抽取我们需要的内容
Pattern pattern = Pattern.compile(regrex);
Matcher matcher = pattern.matcher(params);
if (matcher.find()) {
int a = matcher.group(0).indexOf(“[”);
int b = matcher.group(0).indexOf(“,”);

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

海哥

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表