一、申请注册科大用户和下载SDK(里面的appid要和自己的一样才可以使用)

详细步骤就不写了,注册网址:http://www.xfyun.cn

二、注册完之后,点击创建应用-选择要使用的平台和选择自己所要实现的功能,点击下载sdk即可。

下载完解压压缩包如下图:

三、把sample里面的demo通过我们的开发工具打开,我用的是androidStudio,所以导入步骤为:

方法一(导入project方式):
打开Android Studio,在菜单栏File—>new—>import project当前解压sdk路径,使用离线服务能力选择导入mscV5PlusDemo,导入成功之后sync编译下,编译无误可连接手机,开启手机USB开发调试模式,直接在Android Studio运行导入的mscV5PlusDemo,最后生成的apk可直接安装在对应的手机上,如果编译时出现“ERROR: Plugin with id ‘com.android.application’ not found.”错误,请在build.gradle文件中添加以下代码。

buildscript {repositories {google()jcenter()}dependencies {//版本号请根据自己的gradle插件版本号自行更改classpath 'com.android.tools.build:gradle:3.4.0'// NOTE: Do not place your application dependencies here; they belong// in the individual module build.gradle files}
}

方法二(导入module方式):
打开Android Studio,在菜单栏File—>new—>import module当前解压sdk路径,使用离线服务能力选择导入mscV5PlusDemo,导入成功之后sync编译下,编译无误可连接手机,开启手机USB开发调试模式,直接在Android Studio运行导入的mscV5PlusDemo,最后生成的apk可直接安装在对应的手机上。

至此利用官方提供的例子我们可以感受一下语言识别的魅力,而下面我们我们可以通过参考官方的例子来进行开发。

自我开发

一、创建一个新工程:

创建一个新的空项目。
二、创建以下目录结构:

将下载好的SDK中 libs 目录下的 Msc.jar包引入到工程中(参见http://blog.csdn.net/highboys/article/details/51549679,此外,因为本Demo中会用到json的东西,所以还得自己去网上下一个Gson的jar包,一并引进去)。之后在main目录下新建一个jniLibs目录,将 SDK中 libs 目录下的armeabi 拷进去:

权限以及所需包:(Manifest文件)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.example.speechprojecta"><uses-permission android:name="android.permission.RECORD_AUDIO" /><uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /><uses-permission android:name="android.permission.READ_PHONE_STATE" /><uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /><uses-permission android:name="android.permission.READ_CONTACTS" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /><applicationandroid:name=".MyApplication"android:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/AppTheme"><activity android:name=".MainActivity"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

LogUtil类:

package com.example.speechprojecta;import android.text.TextUtils;
import android.util.Log;class LogUtil {public static String tagPrefix = "";public static boolean showV = true;public static boolean showD = true;public static boolean showI = true;public static boolean showW = true;public static boolean showE = true;public static boolean showWTF = true;/*** 得到tag(所在类.方法(L:行))* @return*/private static String generateTag() {StackTraceElement stackTraceElement = Thread.currentThread().getStackTrace()[4];String callerClazzName = stackTraceElement.getClassName();callerClazzName = callerClazzName.substring(callerClazzName.lastIndexOf(".") + 1);String tag = "%s.%s(L:%d)";tag = String.format(tag, new Object[]{callerClazzName, stackTraceElement.getMethodName(), Integer.valueOf(stackTraceElement.getLineNumber())});//给tag设置前缀tag = TextUtils.isEmpty(tagPrefix) ? tag : tagPrefix + ":" + tag;return tag;}public static void v(String msg) {if (showV) {String tag = generateTag();Log.v(tag, msg);}}public static void v(String msg, Throwable tr) {if (showV) {String tag = generateTag();Log.v(tag, msg, tr);}}public static void d(String msg) {if (showD) {String tag = generateTag();Log.d(tag, msg);}}public static void d(String msg, Throwable tr) {if (showD) {String tag = generateTag();Log.d(tag, msg, tr);}}public static void i(String msg) {if (showI) {String tag = generateTag();Log.i(tag, msg);}}public static void i(String msg, Throwable tr) {if (showI) {String tag = generateTag();Log.i(tag, msg, tr);}}public static void w(String msg) {if (showW) {String tag = generateTag();Log.w(tag, msg);}}public static void w(String msg, Throwable tr) {if (showW) {String tag = generateTag();Log.w(tag, msg, tr);}}public static void e(String msg) {if (showE) {String tag = generateTag();Log.e(tag, msg);}}public static void e(String msg, Throwable tr) {if (showE) {String tag = generateTag();Log.e(tag, msg, tr);}}public static void wtf(String msg) {if (showWTF) {String tag = generateTag();Log.wtf(tag, msg);}}public static void wtf(String msg, Throwable tr) {if (showWTF) {String tag = generateTag();Log.wtf(tag, msg, tr);}}
}

主activity:

package com.example.speechprojecta;import androidx.appcompat.app.AppCompatActivity;import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;import com.iflytek.cloud.ErrorCode;
import com.iflytek.cloud.InitListener;
import com.iflytek.cloud.RecognizerListener;
import com.iflytek.cloud.RecognizerResult;
import com.iflytek.cloud.SpeechConstant;
import com.iflytek.cloud.SpeechError;
import com.iflytek.cloud.SpeechRecognizer;
import com.iflytek.cloud.ui.RecognizerDialog;
import com.iflytek.cloud.ui.RecognizerDialogListener;import org.json.JSONException;
import org.json.JSONObject;import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;public class MainActivity extends AppCompatActivity {private Context context;//public static final String PREFER_NAME = "com.voice.recognition";public static final String PREFER_NAME = "com.example.speechprojecta";// 语音听写对象private SpeechRecognizer mIat;// 语音听写UIprivate RecognizerDialog mIatDialog;// 用HashMap存储听写结果private HashMap<String, String> mIatResults = new LinkedHashMap<String, String>();private Toast mToast;private Button btStart,btStop,btCancel;private EditText etContent;private SharedPreferences mSharedPreferences;private int ret = 0; // 函数调用返回值// 引擎类型private String mEngineType = SpeechConstant.TYPE_CLOUD;/*** 初始化监听器。*/private InitListener mInitListener = new InitListener() {@Overridepublic void onInit(int code) {LogUtil.v("SpeechRecognizer init() code = " + code);if (code != ErrorCode.SUCCESS) {showTip("初始化失败,错误码:" + code);}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initData();findViewById();setOnclickListener();//按钮点击事件处理}private void setOnclickListener() {//开始监听按钮事件btStart.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {checkSoIsInstallSucceed();etContent.setText(null);// 清空显示内容mIatResults.clear();// 设置参数setParam();boolean isShowDialog = mSharedPreferences.getBoolean(getString(R.string.pref_key_iat_show), true);if (isShowDialog) {// 显示听写对话框mIatDialog.setListener(mRecognizerDialogListener);mIatDialog.show();showTip(getString(R.string.text_begin));} else {// 不显示听写对话框ret = mIat.startListening(mRecognizerListener);if (ret != ErrorCode.SUCCESS) {showTip("听写失败,错误码:" + ret);} else {showTip(getString(R.string.text_begin));}}}});btStop.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {checkSoIsInstallSucceed();}});btCancel.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {checkSoIsInstallSucceed();}});}private void findViewById(){btStart = (Button) findViewById(R.id.btn_start);btStop = (Button) findViewById(R.id.btn_stop);btCancel = (Button) findViewById(R.id.btn_cancel);etContent = (EditText) findViewById(R.id.et_content);}private void initData() {context = MainActivity.this;// 初始化识别无UI识别对象/ 使用SpeechRecognizer对象,可根据回调消息自定义界面;mIat = com.iflytek.cloud.SpeechRecognizer.createRecognizer(context, mInitListener);// 初始化听写Dialog,如果只使用有UI听写功能,无需创建SpeechRecognizer// 使用UI听写功能,请根据sdk文件目录下的notice.txt,放置布局文件和图片资源mIatDialog = new RecognizerDialog(context, mInitListener);mToast = Toast.makeText(this, "", Toast.LENGTH_SHORT);mSharedPreferences = getSharedPreferences(MainActivity.PREFER_NAME,Activity.MODE_PRIVATE);}//检查是否成功创建对象private void checkSoIsInstallSucceed(){if( null == mIat ){// 创建单例失败,与 21001 错误为同样原因,参考 http://bbs.xfyun.cn/forum.php?mod=viewthread&tid=9688this.showTip( "创建对象失败,请确认 libmsc.so 放置正确,且有调用 createUtility 进行初始化" );return;}}private void showTip( final String str) {mToast.setText(str);mToast.show();}//设置参数public void setParam() {mIat.setParameter(SpeechConstant.PARAMS, null); // 清空参数mIat.setParameter(SpeechConstant.ENGINE_TYPE, mEngineType); // 设置听写引擎mIat.setParameter(SpeechConstant.RESULT_TYPE, "json");  // 设置返回结果格式String lag = mSharedPreferences.getString("iat_language_preference","mandarin");if (lag.equals("en_us")) {// 设置语言mIat.setParameter(SpeechConstant.LANGUAGE, "en_us");} else {// 设置语言mIat.setParameter(SpeechConstant.LANGUAGE, "zh_cn");// 设置语言区域mIat.setParameter(SpeechConstant.ACCENT, lag);}// 设置语音前端点:静音超时时间,即用户多长时间不说话则当做超时处理mIat.setParameter(SpeechConstant.VAD_BOS, mSharedPreferences.getString("iat_vadbos_preference", "4000"));// 设置语音后端点:后端点静音检测时间,即用户停止说话多长时间内即认为不再输入, 自动停止录音mIat.setParameter(SpeechConstant.VAD_EOS, mSharedPreferences.getString("iat_vadeos_preference", "1000"));// 设置标点符号,设置为"0"返回结果无标点,设置为"1"返回结果有标点mIat.setParameter(SpeechConstant.ASR_PTT, mSharedPreferences.getString("iat_punc_preference", "1"));// 设置音频保存路径,保存音频格式支持pcm、wav,设置路径为sd卡请注意WRITE_EXTERNAL_STORAGE权限// 注:AUDIO_FORMAT参数语记需要更新版本才能生效mIat.setParameter(SpeechConstant.AUDIO_FORMAT,"wav");mIat.setParameter(SpeechConstant.ASR_AUDIO_PATH, Environment.getExternalStorageDirectory()+"/msc/iat.wav");}//识别回调函数private RecognizerDialogListener mRecognizerDialogListener = new RecognizerDialogListener() {public void onResult(RecognizerResult results, boolean isLast) {printResult(results);String text1 = JsonParser.parseIatResult(results.getResultString());System.out.println(text1);String tt="开灯";// Toast.makeText(context, text1, Toast.LENGTH_LONG).show();if (text1.equals(tt)){Toast.makeText(context,"ninhao",Toast.LENGTH_SHORT).show();}}/*** 识别回调错误.*/public void onError(SpeechError error) {showTip(error.getPlainDescription(true));}};/*** 听写监听器。*/private RecognizerListener mRecognizerListener = new RecognizerListener() {@Overridepublic void onBeginOfSpeech() {// 此回调表示:sdk内部录音机已经准备好了,用户可以开始语音输入showTip("开始说话");}@Overridepublic void onError(SpeechError error) {// Tips:// 错误码:10118(您没有说话),可能是录音机权限被禁,需要提示用户打开应用的录音权限。// 如果使用本地功能(语记)需要提示用户开启语记的录音权限。showTip(error.getPlainDescription(true));}@Overridepublic void onEndOfSpeech() {// 此回调表示:检测到了语音的尾端点,已经进入识别过程,不再接受语音输入showTip("结束说话");}@Overridepublic void onResult(RecognizerResult results, boolean isLast) {LogUtil.v(results.getResultString());printResult(results);if (isLast) {// TODO 最后的结果}}@Overridepublic void onVolumeChanged(int volume, byte[] data) {showTip("当前正在说话,音量大小:" + volume);LogUtil.v("返回音频数据:"+data.length);}@Overridepublic void onEvent(int eventType, int arg1, int arg2, Bundle obj) {// 以下代码用于获取与云端的会话id,当业务出错时将会话id提供给技术支持人员,可用于查询会话日志,定位出错原因// 若使用本地能力,会话id为null// if (SpeechEvent.EVENT_SESSION_ID == eventType) {//        String sid = obj.getString(SpeechEvent.KEY_EVENT_SESSION_ID);//        Log.d(TAG, "session id =" + sid);// }}};//打印听写识别结果private void printResult(RecognizerResult results) {String text = JsonParser.parseIatResult(results.getResultString());String sn = null;// 读取json结果中的sn字段try {JSONObject resultJson = new JSONObject(results.getResultString());sn = resultJson.optString("sn");} catch (JSONException e) {e.printStackTrace();}mIatResults.put(sn, text);StringBuffer resultBuffer = new StringBuffer();for (String key : mIatResults.keySet()) {resultBuffer.append(mIatResults.get(key));}etContent.setText(resultBuffer.toString());etContent.setSelection(etContent.length());}@Overrideprotected void onDestroy() {super.onDestroy();if (null != mIat) {// 退出时释放连接mIat.cancel();mIat.destroy();}}
}

识别效果:

ps:请使用真机测试。测试时要连网,这个是联网识别的。
实现功能:点击按钮识别语音,如果识别到开灯关键字,则出现Toast提示。

android实现调用科大讯飞语音识别功能详细步骤相关推荐

  1. Android studio调用科大讯飞的语音转文字功能

    Android studio调用科大讯飞的语音转文字功能 一.在科大讯飞的官网上注册并下载SDK 二.配置安卓项目 三.运行效果展示 一.在科大讯飞的官网上注册并下载SDK 1.首先去讯飞开放平台申请 ...

  2. 安卓调用系统语音识别功能全解(谷歌语音服务):获取识别结果,使用语音识别进行搜索。

    全栈工程师开发手册 (作者:栾鹏) 安卓教程全解 安卓调用系统语音识别功能全解(谷歌语音服务):获取识别结果,使用语音识别进行搜索. 首先要添加权限 <uses-permission andro ...

  3. VB.net参数化界面调用ANSYS求解的详细步骤及错误提示的解决办法

    VB.net参数化界面调用ANSYS求解的详细步骤及错误提示的解决办法 微软旗下.net平台凭其易操作性.功能强大备受现代码农的喜爱,vb作为一门面向对象的程序语言,有着强大的功能和相对简单的操作,v ...

  4. Java乔晓松-android中调用系统拍照功能并显示拍照的图片

    android中调用系统拍照功能并显示拍照的图片 如果你是拍照完,利用onActivityResult获取data数据,把data数据转换成Bitmap数据,这样获取到的图片,是拍照的照片的缩略图 代 ...

  5. 【Android App】在线语音识别功能实现(使用云知声平台与WebSocket 超详细 附源码)

    需要源码和相关资源请点赞关注收藏后评论区留下QQ~~~ 一.在线语音识别 云知声的语音识别同样采用WebSocket接口,待识别的音频流支持MP3和PCM两种格式,对于在线语音识别来说,云知声使用JS ...

  6. Android简单调用相机Camera功能,实现打开照相功能

    在最开始接触Android相机功能之前,先来体验一下Android调用系统照相功能吧 核心代码 Intent intent = new Intent(); //调用照相机 intent.setActi ...

  7. Android Studio调用科大讯飞关键词提取接口

    1.在讯飞开放平台创建应用 2.下载关键词提取Java代码 2.1 代码解压,将下图3个java文件复制到Android项目的与MainActivity.java同一个目录下 2.2 我把ltp中的m ...

  8. Android集成华为推送功能详细

    1.前言 Android集成推送功能也算是有好几个SDK了,包括极光.个推.小米.百度云推送.但是真心感觉华为的文档写的太差,封装的也不好,别的开发文档看一两遍就能按照文档集成成功,而华为仔细看了几遍 ...

  9. 微信小程序引入广告位功能,详细步骤!!!

    大家碰到过首页加载时一开始出现的广告页面,这种微信官方提供了一个api进行设置,下面我们来详细解释一下. 首先第一步需要小程序累计用户数达到1000即可开通流量主,成功开通流量主之后就可以创建相应的广 ...

最新文章

  1. ExtJs学习笔记(5)_Ajax示例
  2. 2018年终总结之AI领域开源框架汇总
  3. MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK
  4. C++头文件中预编译宏的目的
  5. Expected a default value of type Tensor on parameter residual:
  6. HDU - 2457 DNA repair(AC自动机+dp)
  7. Autokroma AfterCodecs for Mac - 与众不同的特殊编码渲染插件
  8. JS:ES6-11 数值扩展与对象扩展
  9. 在centos x86_64里编译x32的程序
  10. ASP.NET 2.0中合并 GridView 的表头单元格
  11. html+link+点击次数,使用正则表达式,取得点击次数,函数抽离(示例代码)
  12. 如何创建一个基本的魔兽全图外挂 HowTo create a basic Maphack by Chaotic
  13. python爬取双色球2003-2022年所有数据
  14. N点虚拟主机管理系统 企业版稳定亲测
  15. 听云java探针_性能监控工具的配置及使用 - 听云-Server
  16. 快速搭建接口自动化平台
  17. linux ping结果中mdev,ping之mdev值
  18. 英语不好学java好学吗_英语不好能学好java,做程序员吗?
  19. hdu 4417 Super Mario
  20. ic启动器怎么导入模组_晶圆代工产能将紧缺至何时?联电/世界先进/中芯国际/联发科的大佬们怎么看?...

热门文章

  1. iOS UIWebView 缩放
  2. 1503172126-ny-小媛在努力
  3. 芯片到底是怎么制造的?
  4. HPUNIX环境常用查看硬件设备信息命令小结
  5. 前端程序员后来都去干嘛了?我找了几位聊了聊
  6. 5G C-V2X战役一触即发,广和通率先“上车”零碳商用快班车
  7. 雷帝嘎嘎:可以写汉字的洒水三轮车
  8. 健美计步器-开启超智能健康生活
  9. CPU服务器和GPU服务器有什么区别?使用场景有什么不同?
  10. itchat实现微信聊天机器人,定时发送微信消息,消息防撤回,消息监控,自定义回复消息