詳解Android studio實(shí)現(xiàn)語(yǔ)音轉(zhuǎn)文字功能
一、在科大訊飛的官網(wǎng)上注冊(cè)并下載SDK
1.首先去訊飛開(kāi)放平臺(tái)申請(qǐng)一個(gè)賬號(hào)(https://www.xfyun.cn/),然后點(diǎn)擊“控制臺(tái)”進(jìn)入新的頁(yè)面,創(chuàng)建一個(gè)應(yīng)用,找到“語(yǔ)音聽(tīng)寫”,下載相應(yīng)的SDK。

文件解壓后內(nèi)容如下:

二、配置安卓項(xiàng)目
1.在android studio中新建一個(gè)空項(xiàng)目,將libs文件夾中的內(nèi)容復(fù)制到安卓項(xiàng)目的libs文件夾下,其中msc.jar要右鍵添加Add As Library:

2.將assets文件夾拷貝到項(xiàng)目的main目錄下,并在main目錄下新建一個(gè)名為jniLibs的文件夾,將下載的libs文件夾中的兩個(gè)子文件夾復(fù)制到j(luò)niLibs中:

3.在AndriodManifest.xml中添加以下權(quán)限:
<!--連接網(wǎng)絡(luò)權(quán)限,用于執(zhí)行云端語(yǔ)音能力 -->
<uses-permission android:name="android.permission.INTERNET"/>
<!--獲取手機(jī)錄音機(jī)使用權(quán)限,聽(tīng)寫、識(shí)別、語(yǔ)義理解需要用到此權(quán)限 -->
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
<uses-permission android:name="Manifest.permission.RECORD_AUDIO" />
<!--讀取網(wǎng)絡(luò)信息狀態(tài) -->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<!--獲取當(dāng)前wifi狀態(tài) -->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<!--允許程序改變網(wǎng)絡(luò)連接狀態(tài) -->
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
<!--讀取手機(jī)信息權(quán)限 -->
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<!--讀取聯(lián)系人權(quán)限,上傳聯(lián)系人需要用到此權(quán)限 -->
<uses-permission android:name="android.permission.READ_CONTACTS"/>
<!--外存儲(chǔ)寫權(quán)限,構(gòu)建語(yǔ)法需要用到此權(quán)限 -->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<!--外存儲(chǔ)讀權(quán)限,構(gòu)建語(yǔ)法需要用到此權(quán)限 -->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<!--配置權(quán)限,用來(lái)記錄應(yīng)用配置信息 -->
<uses-permission android:name="android.permission.WRITE_SETTINGS"
tools:ignore="ProtectedPermissions" />
<!--手機(jī)定位信息,用來(lái)為語(yǔ)義等功能提供定位,提供更精準(zhǔn)的服務(wù)-->
<!--定位信息是敏感信息,可通過(guò)Setting.setLocationEnable(false)關(guān)閉定位請(qǐng)求 -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<!--如需使用人臉識(shí)別,還要添加:攝像頭權(quán)限,拍照需要用到 -->
<uses-permission android:name="android.permission.CAMERA" />

4.在app目錄下的build.gradle中添加以下代碼:
sourceSets {
main {
jniLibs.srcDirs = ['libs']
}
}

5.修改布局文件activity_main.xml中的代碼:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<Button
android:id="@+id/btn_click"
android:text="點(diǎn)擊打開(kāi)訊飛語(yǔ)音識(shí)別"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<EditText
android:id="@+id/result"
android:layout_below="@id/btn_click"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="此處顯示你所錄下的內(nèi)容"
/>
</LinearLayout>
6.新建一個(gè)名為XunFeiCallbackListener的接口:
package com.example.myapplication;
import com.iflytek.cloud.RecognizerResult;
public interface XunFeiCallbackListener {
void onFinish(RecognizerResult results);
}
7.新建一個(gè)名為XunFeiUtil的類:
package com.example.myapplication;
import android.content.Context;
import android.widget.Toast;
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;
import org.json.JSONArray;
import org.json.JSONObject;
import org.json.JSONTokener;
public class XunFeiUtil {
public static String appid = "自己的appid";
public static void initXunFei(Context context){
SpeechUtility.createUtility(context, SpeechConstant.APPID +"="+appid);
}
public static void startVoice(Context context, final XunFeiCallbackListener callbackListener) {
RecognizerDialog dialog = new RecognizerDialog(context,null);
dialog.setParameter(SpeechConstant.LANGUAGE, "zh_cn");
dialog.setParameter(SpeechConstant.ACCENT, "mandarin");
dialog.setParameter(SpeechConstant.ASR_PTT, "0");
dialog.setListener(new RecognizerDialogListener() {
@Override
public void onResult(RecognizerResult recognizerResult, boolean b) {
callbackListener.onFinish(recognizerResult);
}
@Override
public void onError(SpeechError speechError) {
}
});
dialog.show();
//Toast.makeText(this, "請(qǐng)開(kāi)始說(shuō)話", Toast.LENGTH_SHORT).show();
}
public static String parseIatResult(String json) {
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++) {
// 轉(zhuǎn)寫結(jié)果詞,默認(rèn)使用第一個(gè)結(jié)果
JSONArray items = words.getJSONObject(i).getJSONArray("cw");
JSONObject obj = items.getJSONObject(0);
ret.append(obj.getString("w"));
}
} catch (Exception e) {
e.printStackTrace();
}
return ret.toString();
}
}
8.修改MainActivity:
package com.example.myapplication;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.iflytek.cloud.RecognizerResult;
import static com.example.myapplication.XunFeiUtil.parseIatResult;
import static com.example.myapplication.XunFeiUtil.*;
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private Button btn_click;
private EditText mResultText;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initXunFei(this);
btn_click = (Button) findViewById(R.id.btn_click);
mResultText = ((EditText) findViewById(R.id.result));
btn_click.setOnClickListener(this);
}
@Override
public void onClick(View v) {
startVoice(this, new XunFeiCallbackListener() {
@Override
public void onFinish(RecognizerResult results) {
String text = parseIatResult(results.getResultString());
// 自動(dòng)填寫地址
mResultText.append(text);
}
});
}
}
三、運(yùn)行效果展示
按照以上操作進(jìn)行修改,完成后運(yùn)行項(xiàng)目,會(huì)出現(xiàn)語(yǔ)音開(kāi)啟失敗,錯(cuò)誤碼為20006的錯(cuò)誤,出錯(cuò)原因是android系統(tǒng)在非動(dòng)態(tài)申請(qǐng)權(quán)限的情況下,默認(rèn)是把麥克風(fēng)權(quán)限是關(guān)閉了的,因此需要打開(kāi)權(quán)限,可以在手機(jī)的權(quán)限中自己修改權(quán)限設(shè)置,成功后的界面如下:


以上就是詳解Android studio實(shí)現(xiàn)語(yǔ)音轉(zhuǎn)文字功能的詳細(xì)內(nèi)容,更多關(guān)于Android studio語(yǔ)音轉(zhuǎn)文字的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android自定義滑動(dòng)刪除效果的實(shí)現(xiàn)代碼
這篇文章將從現(xiàn)有 Android 滑動(dòng)刪除的痛點(diǎn),到搭建好一個(gè)基本的框架,到最終提供一份完整的 Demo為止,爭(zhēng)取為讀者提供最大的可定制化,需要的朋友可以參考下2018-03-03
Android App開(kāi)發(fā)中使用RecyclerView替代ListView的實(shí)踐
RecyclerView是Android L即5.0版本以來(lái)新加入的一個(gè)組件,主要用來(lái)實(shí)現(xiàn)item的瀑布式排列,因而被人們廣泛認(rèn)為用來(lái)替代ListView,這里我們就來(lái)看一下Android App開(kāi)發(fā)中使用RecyclerView替代ListView的實(shí)踐:2016-06-06
Android 中TextView中跑馬燈效果的實(shí)現(xiàn)方法
這篇文章主要介紹了Android 中TextView中跑馬燈效果的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
Android開(kāi)發(fā)中Looper.prepare()和Looper.loop()
Looper用于封裝了android線程中的消息循環(huán),默認(rèn)情況下一個(gè)線程是不存在消息循環(huán)(message loop)的,具體調(diào)用方法大家可以通過(guò)本文學(xué)習(xí)2016-11-11
詳解Android Studio正式簽名進(jìn)行調(diào)試的實(shí)現(xiàn)步驟
這篇文章主要介紹了詳解Android Studio正式簽名進(jìn)行調(diào)試的實(shí)現(xiàn)步驟的相關(guān)資料,需要的朋友可以參考下2017-07-07
Android自定義view 你所需要知道的基本函數(shù)總結(jié)
這篇文章主要介紹了Android自定義view 你所需要知道的基本函數(shù)的相關(guān)資料,需要的朋友可以參考下2017-02-02

