基于讯飞开放平台的安卓语音开发——语音听写(语音→文本)
2017-07-10 23:14
751 查看
最近闲来无事,想学学安卓的语音开发,所以从网上找一样开源API,最后找到了讯飞(讯飞开放平台网址:http://www.xfyun.cn/)感觉非常好用,使用起来也比较简单。
其中提供了Android的SDK,SDK主要包括了各种Demo以及资源、jar包等;当然其中的服务也必须自己创建相应的应用才能使用。
②然后再点击左侧菜单栏中的“创建新应用”,在填写应用的基本资料时除了应用平台选择Android,其他可随意;
③创建完应用会回到控制台界面,然后点击刚才创建的应用下面的“立即开通”选在第一个“语音听写”后确定。注意创建的应用的名称后面有个Appid,在代码中需要使用。
assets:资源
doc:文档
libs:jar包
sample:示例代码
②将资源与jar包复制到项目中,项目结构如下:
②在前台添加一个按钮及输入框,用来触发语音听写功能与显示结果,代码略
③具体代码如下:
以上代码是我从讯飞提供的Demo中摘取出来的
其中提供了Android的SDK,SDK主要包括了各种Demo以及资源、jar包等;当然其中的服务也必须自己创建相应的应用才能使用。
1.资源准备阶段—在讯飞开放平台创建应用与服务
①访问讯飞官网(http://www.xfyun.cn/)点击标题栏中的“控制台”;②然后再点击左侧菜单栏中的“创建新应用”,在填写应用的基本资料时除了应用平台选择Android,其他可随意;
③创建完应用会回到控制台界面,然后点击刚才创建的应用下面的“立即开通”选在第一个“语音听写”后确定。注意创建的应用的名称后面有个Appid,在代码中需要使用。
2.代码准备阶段—下载SDK及项目准备
①访问讯飞官网(http://www.xfyun.cn/)点击标题栏中的“SDK下载”并以此选择服务、平台和应用即可下载。SDK目录如下:assets:资源
doc:文档
libs:jar包
sample:示例代码
②将资源与jar包复制到项目中,项目结构如下:
3. 撸代码阶段
①项目中添加代码权限,如下:②在前台添加一个按钮及输入框,用来触发语音听写功能与显示结果,代码略
③具体代码如下:
package com.example.tingxietest; import java.util.HashMap; import java.util.LinkedHashMap; import org.json.JSONException; import org.json.JSONObject; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.EditText; import android.widget.Toast; import com.example.util.JsonParser; import com.iflytek.cloud.ErrorCode; import com.iflytek.cloud.InitListener; import com.iflytek.cloud.RecognizerResult; import com.iflytek.cloud.SpeechConstant; import com.iflytek.cloud.SpeechError; import com.iflytek.cloud.SpeechUtility; import com.iflytek.cloud.ui.RecognizerDialog; import com.iflytek.cloud.ui.RecognizerDialogListener; public class MainActivity extends Activity { // 语音听写UI private RecognizerDialog mIatDialog; private EditText mResultText; // 用HashMap存储听写结果 private HashMap<String, String> mIatResults = new LinkedHashMap<String, String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //初始化即创建语音配置对象,只有初始化后才可以使用MSC的各项服务, //将XXXXX改成自己应用的AppID,如果不知道AppId在哪,请看第1步中第③小步 SpeechUtility.createUtility(MainActivity.this, SpeechConstant.APPID + "=XXXXX"); //用来显示识别后的文本 mResultText = (EditText) findViewById(R.id.tv); // 初始化听写Dialog mIatDialog = new RecognizerDialog(MainActivity.this, mInitListener); //添加点击监听,即点击后执行语音听写操作 findViewById(R.id.bt).setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { mIatDialog.setListener(mRecognizerDialogListener); mIatDialog.show(); } }); } //打印结果 private void printResult(RecognizerResult results) { String text = JsonParser.parseIatResult(results.getResultString()); String sn = null; 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)); } mResultText.setText(resultBuffer.toString()); mResultText.setSelection(mResultText.length()); } private RecognizerDialogListener mRecognizerDialogListener = new RecognizerDialogListener() { public void onResult(RecognizerResult results, boolean isLast) { printResult(results); } /** * 识别回调错误. */ public void onError(SpeechError error) { } }; /** * 初始化监听器。 */ private InitListener mInitListener = new InitListener() { @Override public void onInit(int code) { if (code != ErrorCode.SUCCESS) { Toast.makeText(MainActivity.this, "初始化失败,错误码:" + code, Toast.LENGTH_LONG).show(); } } }; }
以上代码是我从讯飞提供的Demo中摘取出来的
相关文章推荐
- 基于讯飞开放平台的安卓语音开发——语音合成(文本→语音)
- 基于讯飞开放平台的安卓语音开发——语音合成(文本→语音)
- 基于讯飞开放平台的安卓语音开发——语音听写(语音→文本)
- 语音识别开发---基于科大讯飞开放平台
- 基于Web开放平台的应用的开发的一些研究
- 基于Web开放平台的应用的开发的一些研究
- Express 基于 Node.js 平台,快速、开放、极简的 web 开发框架。
- 讯飞、思必驰、Google Assistant、Amazon Alexa等语音开放平台说明
- 基于Web开放平台的应用的开发的一些研究
- 基于科大讯飞语音云windows平台开发
- 基于全志A33的LED驱动开发,安卓6.0.1平台
- 基于Android客户端的人人网开放平台开发系列教程 (有源码哦)
- 初探科大讯飞-讯飞开放平台之语音合成
- 基于 Node.js 平台,快速、开放、极简的 web 开发框架。
- 基于Android客户端的人人网开放平台开发系列教程
- 基于科大讯飞语音云windows平台开发
- 基于科大讯飞语音云windows平台开发
- 科大讯飞开放平台——语音听写接口的使用
- 通过语音AI开放平台开发一个语音AI营销机器人
- express(基于 Node.js 平台,快速、开放、极简的 web 开发框架)