Android实现语音合成与识别功能

时间:2021-05-19

Android语音合成与语音识别,供大家参考,具体内容如下

这里调用科大讯飞语音的API,语音云开放平台介绍

调用科大讯飞语音的API,需要加添库文件Msc.jar,添加libmsc.so文件,还需添加权限,具体步骤可参看SDK里的文档

参看开发的文档写了一个简单的语音合成和识别demo,图示如下

在EditText里输入文字,点击语音合成,可以实现文字转化为语音

点击语音合成,输入语音,识别的文字以提示的形式显示,并且显示在EditText中

主要代码如下,注意appid需要自己申请

package com.example.voice; import java.util.ArrayList; import android.os.Bundle;import android.app.Activity;import android.view.Menu;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.EditText;import android.widget.Toast; import com.iflytek.cloud.speech.*; public class VoiceActivity extends Activity { private static final String APPID = "appid=52cddb99"; private EditText et = null; private Button btn1 = null; private Button btn2 = null; String text = ""; String temp=""; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_voice); et = (EditText) findViewById(R.id.et); btn1 = (Button) findViewById(R.id.btn1); btn1.setOnClickListener(mylistener); btn2 = (Button) findViewById(R.id.btn2); btn2.setOnClickListener(mylistener); } private OnClickListener mylistener = new OnClickListener() { public void onClick(View v) { SpeechUser.getUser().login(VoiceActivity.this, null, null, APPID, loginListener); Button btn = (Button) v; switch (btn.getId()) { case R.id.btn1: SpeechSynthesizer mSpeechSynthesizer = SpeechSynthesizer .createSynthesizer(VoiceActivity.this); mSpeechSynthesizer.setParameter(SpeechConstant.VOICE_NAME, "xiaoyu"); mSpeechSynthesizer.setParameter(SpeechConstant.SPEED, "50"); mSpeechSynthesizer.startSpeaking(et.getText().toString(), mSynListener); break; case R.id.btn2: text = ""; temp=""; SpeechRecognizer recognizer = SpeechRecognizer .createRecognizer(VoiceActivity.this); recognizer.setParameter(SpeechConstant.DOMAIN, "iat"); recognizer.setParameter(SpeechConstant.LANGUAGE, "zh_cn"); recognizer.setParameter(SpeechConstant.ACCENT, "accent"); recognizer.startListening(mRecoListener); break; } } }; private SynthesizerListener mSynListener = new SynthesizerListener() { public void onBufferProgress(int arg0, int arg1, int arg2, String arg3) { } public void onCompleted(SpeechError arg0) { } public void onSpeakBegin() { } public void onSpeakPaused() { } public void onSpeakProgress(int arg0, int arg1, int arg2) { } public void onSpeakResumed() { } }; private RecognizerListener mRecoListener = new RecognizerListener() { public void onBeginOfSpeech() { } public void onEndOfSpeech() { } public void onError(SpeechError error) { } public void onEvent(int arg0, int arg1, int arg2, String arg3) { } public void onVolumeChanged(int arg0) { } public void onResult(RecognizerResult results, boolean isLast) { //将解析后的字符串连在一起 temp=results.getResultString(); JsonParser json = new JsonParser(); text+=json.parseIatResult(temp); if(isLast==true) { et.setText(text, null); Toast.makeText(VoiceActivity.this,text,Toast.LENGTH_LONG).show(); } } }; private SpeechListener loginListener = new SpeechListener() { public void onCompleted(SpeechError arg0) { } public void onData(byte[] arg0) { } public void onEvent(int arg0, Bundle arg1) { } }; public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.voice, menu); return true; }}

布局文件

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".VoiceActivity" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:gravity="center" android:text="VoiceApplication" /> <EditText android:id="@+id/et" android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="top" android:layout_weight="0.32" /> <Button android:id="@+id/btn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="0.03" android:text="语音合成" /> <Button android:id="@+id/btn2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="0.03" android:text="语音识别" /> </TableLayout>

解析Json格式的数据是参照讯飞的文档中的

package com.example.voice; import org.json.JSONArray;import org.json.JSONObject;import org.json.JSONTokener; import android.text.TextUtils; //import com.iflytek.speech.ErrorCode;//import com.iflytek.speech.SpeechError;/** * 对云端返回的Json结果进行解析 * * @author iFlytek * @since 20131211 */public class JsonParser { /** * 听写结果的Json格式解析 * * @param json * @return */ public static String parseIatResult(String json) { if (TextUtils.isEmpty(json)) return ""; StringBuffer ret = new StringBuffer(); try { JSONTokener tokener = new JSONTokener(json); JSONObject joResult = new JSONObject(tokener); JSONArray words = joResult.getJSONArray("ws"); for (int i = 0; i < words.length(); i++) { // 听写结果词,默认使用第一个结果 JSONArray items = words.getJSONObject(i).getJSONArray("cw"); JSONObject obj = items.getJSONObject(0); ret.append(obj.getString("w")); // 如果需要多候选结果,解析数组其他字段 // for(int j = 0; j < items.length(); j++) // { // JSONObject obj = items.getJSONObject(j); // ret.append(obj.getString("w")); // } } } catch (Exception e) { e.printStackTrace(); } return ret.toString(); }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章