溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

發(fā)布時(shí)間:2022-03-04 09:10:27 來源:億速云 閱讀:1575 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了Android studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、在科大訊飛的官網(wǎng)上注冊并下載SDK

1.首先去訊飛開放平臺申請一個(gè)賬號(https://www.xfyun.cn/),然后點(diǎn)擊“控制臺”進(jìn)入新的頁面,創(chuàng)建一個(gè)應(yīng)用,找到“語音聽寫”,下載相應(yīng)的SDK。

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

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

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

二、配置安卓項(xiàng)目

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

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

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

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

3.在AndriodManifest.xml中添加以下權(quán)限:

    <!--連接網(wǎng)絡(luò)權(quán)限,用于執(zhí)行云端語音能力 -->
    <uses-permission android:name="android.permission.INTERNET"/>
    <!--獲取手機(jī)錄音機(jī)使用權(quán)限,聽寫、識別、語義理解需要用到此權(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"/>
    <!--外存儲寫權(quán)限,構(gòu)建語法需要用到此權(quán)限 -->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <!--外存儲讀權(quán)限,構(gòu)建語法需要用到此權(quán)限 -->
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
    <!--配置權(quán)限,用來記錄應(yīng)用配置信息 -->
    <uses-permission android:name="android.permission.WRITE_SETTINGS"
        tools:ignore="ProtectedPermissions" />
    <!--手機(jī)定位信息,用來為語義等功能提供定位,提供更精準(zhǔn)的服務(wù)-->
    <!--定位信息是敏感信息,可通過Setting.setLocationEnable(false)關(guān)閉定位請求 -->
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <!--如需使用人臉識別,還要添加:攝像頭權(quán)限,拍照需要用到 -->
    <uses-permission android:name="android.permission.CAMERA" />

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

4.在app目錄下的build.gradle中添加以下代碼:

sourceSets {
        main {
            jniLibs.srcDirs = ['libs']
        }
    }

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

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)擊打開訊飛語音識別"
        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, "請開始說話", 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)目,會出現(xiàn)語音開啟失敗,錯(cuò)誤碼為20006的錯(cuò)誤,出錯(cuò)原因是android系統(tǒng)在非動(dòng)態(tài)申請權(quán)限的情況下,默認(rèn)是把麥克風(fēng)權(quán)限是關(guān)閉了的,因此需要打開權(quán)限,可以在手機(jī)的權(quán)限中自己修改權(quán)限設(shè)置,成功后的界面如下:

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

Android?studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Android studio如何實(shí)現(xiàn)語音轉(zhuǎn)文字功能”這篇文章對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI