1. 程式人生 > >自然語言交流系統 phxnet團隊 創新實訓 個人博客 (六)

自然語言交流系統 phxnet團隊 創新實訓 個人博客 (六)

app new nbsp onclick ogl 交流 dial end 兩個

訊飛的語音sdk是需要申請的,地址是:http://dev.voicecloud.cn/developer.php?vt=1 。申請一個訊飛的開發者賬號,然後申請一個appid,申請的時候需要填寫開發者信息和你的應用的信息。

申請之後經過審核通過,會得到一個appid,這個是在使用語音服務時需要用到的。(筆者感覺申請還是比較容易通過的,簡單地填寫一下就通過了。速度也很快,我在晚上十一點多申請的,到第二天早上九點多就收到審核通過的郵件。個人感覺這個審核只是為了防止惡意使用,畢竟語音服務是要使用訊飛的服務器資源的。)

申請到appid之後就可以下載SDK了,然後使用語音服務了。

以下我試用的過程,(點擊button,彈出語音框,說完之後將識別的結果顯示在EditText中):

  • 在eclipse裏新建一個android工程
  • 導入訊飛的語音jar包
  • 訊飛的服務是需要一堆權限的,在manifest.xml中加入 [html] view plain copy print?
    1. <uses-permission android:name="android.permission.RECORD_AUDIO" />
    2. <uses-permission android:name="android.permission.INTERNET" />
    3. <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    4. <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    5. <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
    6. <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    分別為:通過麥克風錄音、聯網、獲取網絡信息狀態、獲取wifi狀態、改變網絡狀態如是否能聯網、訪問電話狀態
  • 在main.xml中添加一個EditText和一個Button,如下 [html]
    view plain copy print?
    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="fill_parent"
    4. android:layout_height="fill_parent"
    5. android:orientation="vertical" >
    6. <EditText
    7. android:id="@+id/editText"
    8. android:layout_width="fill_parent"
    9. android:layout_height="300dp"
    10. android:gravity="top"
    11. android:inputType="textMultiLine" >
    12. <requestFocus />
    13. </EditText>
    14. <Button
    15. android:id="@+id/button_start"
    16. android:layout_width="wrap_content"
    17. android:layout_height="wrap_content"
    18. android:text="點擊開始說話" />
    19. </LinearLayout>
  • 然後在MainActivity中編寫代碼實現了

(這裏可以看到在線的文檔:http://dev.voicecloud.cn/developer.php?category=YW5kcm9pZA%3D%3D&column=ZG9jdW1lbnQ%3D&type=d2lkZ2V0)

通過閱讀訊飛給的文檔,可以發現標準的識別控件是RecognizerDialog——是一個Dialog的子類,所以我們是可以在Activity中通過showDialog(int)方法來調用它的。

重寫Activity的方法

[java] view plain copy print?
  1. @Override
  2. protected Dialog onCreateDialog(int id) {}

在其中創建並設置好一個RecognizerDialog即可。

創建RecognizerDialog方法為

[java] view plain copy print?
  1. RecognizerDialog recognizerDialog = new RecognizerDialog(
  2. MainActivity.this, "appid=1234567");// 這裏應該寫從科大訊飛申請到的appid

(其中appid應該寫自己從訊飛申請到的appid,由於協議的問題,我不便把自己申請的id公開,所以這裏用了1234567來代替。根據訊飛的說明,非法的appid是不能使用語音服務的,但是我用隨機數字試驗了一下,居然也是能用的,不知道是不是BUG。)

官方的文檔:

技術分享

然後需要設置識別參數

[java] view plain copy print?
  1. recognizerDialog.setEngine("sms", null, null);

第一個參數“sms”表示為請求的服務為“語音識別”。後兩個參數暫時設為null就好。

官方文檔:

技術分享

最後還需給recognizerDialog設置一個listener,回調接口用以獲取結果,

recognizerDialog.setListener(RecognizerDialogListener listener)的參數為RecognizerDialogListener接口,實現此接口要重寫兩個方法:onResults(ArrayList results,boolean isLast)和onEnd(SpeechError error)。用以獲取和處理結果。

我的實現為直接寫了一個匿名類:

[java] view plain copy print?
  1. recognizerDialog.setListener(new RecognizerDialogListener() {
  2. @Override
  3. public void onResults(ArrayList<RecognizerResult> results,
  4. boolean arg1) {
  5. StringBuffer result = new StringBuffer();
  6. for (RecognizerResult r : results) {
  7. result.append(r.text);
  8. }
  9. editText.setText(result.toString());
  10. }
  11. @Override
  12. public void onEnd(SpeechError arg0) {
  13. }
  14. });

然後將此RecognizerDialog返回即可。

完整的MainActivity代碼:

[java] view plain copy print?
  1. import com.iflytek.speech.RecognizerResult;
  2. import com.iflytek.speech.SpeechError;
  3. import com.iflytek.ui.RecognizerDialog;
  4. import com.iflytek.ui.RecognizerDialogListener;
  5. public class MainActivity extends Activity {
  6. EditText editText = null;
  7. Button startButton = null;
  8. @Override
  9. public void onCreate(Bundle savedInstanceState) {
  10. super.onCreate(savedInstanceState);
  11. setContentView(R.layout.main);
  12. editText = (EditText) findViewById(R.id.editText);
  13. startButton = (Button) findViewById(R.id.button_start);
  14. startButton.setOnClickListener(new OnClickListener() {
  15. @Override
  16. public void onClick(View v) {
  17. showDialog(1);
  18. }
  19. });
  20. }
  21. @Override
  22. protected Dialog onCreateDialog(int id) {
  23. RecognizerDialog recognizerDialog = new RecognizerDialog(
  24. MainActivity.this, "appid=1234567");// 這裏應該寫從科大訊飛申請到的appid
  25. recognizerDialog.setEngine("sms", null, null);
  26. recognizerDialog.setListener(new RecognizerDialogListener() {
  27. @Override
  28. public void onResults(ArrayList<RecognizerResult> results,
  29. boolean arg1) {
  30. StringBuffer result = new StringBuffer();
  31. for (RecognizerResult r : results) {
  32. result.append(r.text);
  33. }
  34. editText.setText(result.toString());
  35. }
  36. @Override
  37. public void onEnd(SpeechError arg0) {
  38. }
  39. });
  40. return recognizerDialog;
  41. }
  42. }


程序在真機運行截圖,經過檢驗,科大訊飛的識別率還是很高的。

技術分享

技術分享

自然語言交流系統 phxnet團隊 創新實訓 個人博客 (六)