真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能-創(chuàng)新互聯(lián)

這篇文章主要講解了“Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能”吧!

創(chuàng)新互聯(lián)建站2013年開創(chuàng)至今,先為武鄉(xiāng)等服務(wù)建站,武鄉(xiāng)等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為武鄉(xiāng)企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

Android提供了自動(dòng)朗讀支持。自動(dòng)朗讀支持可以對指定文本內(nèi)容進(jìn)行朗讀,從而發(fā)生聲音;不僅如此,Android的自動(dòng)朗讀支持還允許把文本對應(yīng)的音頻錄制成音頻文件,方便以后播放。這種自動(dòng)朗讀支持的英文名稱為TextToSpeech,簡稱TTS。

借助于TTS的支持,可以在應(yīng)用程序中動(dòng)態(tài)地增加音頻輸出,從而改善用戶體驗(yàn)。

Android的自動(dòng)朗讀支持主要通過TextTospeech來完成,該累提供了如下一個(gè)構(gòu)造器:

TextTospeech(Context context, TextTospeech.OnInitListenerlistener)

從上面的構(gòu)造器不難看書,當(dāng)創(chuàng)建TextTospeech對象時(shí),必須先提供一個(gè)OnInitListener監(jiān)聽器——該監(jiān)聽器負(fù)責(zé)監(jiān)聽TextTospeech的初始化結(jié)果。

一旦在程序中獲得了TextTospeech對象之后,接下來可以調(diào)用TextTospeech的setLanguage(Localeloc)方法來設(shè)置該TTS發(fā)聲引擎應(yīng)使用的語言、國家選項(xiàng)。

如果調(diào)用setLanguage(Localeloc)的返回值是“TextToSpeech.LANG_COUNTRY_AVAILABLE”說明當(dāng)前TTS系統(tǒng)可以支持所設(shè)置的語言、國家選項(xiàng)。

對TextToSpeech設(shè)置完成后,就可以調(diào)用它的方法來朗讀文本了,具體方法可參考TextToSpeech的API文檔。TextToSpeech類中最常用的方法是如下兩個(gè)。

speak(String text,int queueMode,HashMapparams)
synthesizeToFile(Stringtext,HashMapparams,String filename)

上面兩個(gè)方法都用于把text文字內(nèi)容轉(zhuǎn)換為音頻,區(qū)別只是speak方法是播放轉(zhuǎn)換的音頻,而synthesizeToFile是把轉(zhuǎn)換得到的音頻保存成聲音文件。

上面兩個(gè)方法中的params都用于指定聲音轉(zhuǎn)換時(shí)的參數(shù),speak()方法中的queueMode參數(shù)指定TTS發(fā)音隊(duì)列模式,該參數(shù)支持如下兩個(gè)常量。

TextToSpeech.QUEUE_FLUSH:如果指定該模式,當(dāng)TTS調(diào)用speak方法時(shí), 它會(huì)中斷當(dāng)前實(shí)例正在運(yùn)行的任務(wù)(也可以理解為清楚當(dāng)前語音任務(wù),轉(zhuǎn)而執(zhí)行新的語音任務(wù))

TextToSpeech.QUEUE_ADD:如果指定該模式,當(dāng)TTS調(diào)用speak方法時(shí),會(huì)把新的發(fā)音任務(wù)添加到當(dāng)前發(fā)音任務(wù)列隊(duì)之后——也就是等任務(wù)隊(duì)列中的發(fā)音任務(wù)執(zhí)行完成后再來執(zhí)行speak()方法指定的發(fā)音任務(wù)。

當(dāng)程序用完了TextToSpeech對象之后,可以在Activity的OnDestroy()方法中調(diào)用它的shutdown()來關(guān)閉TextToSpeech、釋放它所占用的資源。

歸納起來,使用TextToSpeech的步驟如下

1、創(chuàng)建TextToSpeech對象,創(chuàng)建時(shí)傳入OnInitListener監(jiān)聽器監(jiān)聽創(chuàng)建是否成功。

2、設(shè)置TextToSpeech所使用語言、國家選項(xiàng),通過返回值判斷TTS是否支持該語言、國家選項(xiàng)。

3、調(diào)用speak()或者synthesizeToFile方法。

4、關(guān)閉TTS,回收資源。

下面的程序示范了如何利用TTS來朗讀用戶所輸入的文本內(nèi)容。

Speech.java:

public class Speech extends Activity
{
  TextToSpeech tts;
  EditText editText;
  Button speech;
  Button record;
  @Override
  public void onCreate(Bundle savedInstanceState)
  {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    // 初始化TextToSpeech對象
    tts = new TextToSpeech(this, new OnInitListener()
    {
      @Override
      public void onInit(int status)
      {
        // 如果裝載TTS引擎成功
        if (status == TextToSpeech.SUCCESS)
        {
          // 設(shè)置使用美式英語朗讀
          int result = tts.setLanguage(Locale.US);
          // 如果不支持所設(shè)置的語言
          if (result != TextToSpeech.LANG_COUNTRY_AVAILABLE
            && result != TextToSpeech.LANG_AVAILABLE)
          {
            Toast.makeText(Speech.this, "TTS暫時(shí)不支持這種語言的朗讀。", 50000)
              .show();
          }
        }
      }
    });
    editText = (EditText) findViewById(R.id.txt);
    speech = (Button) findViewById(R.id.speech);
    record = (Button) findViewById(R.id.record);
    speech.setOnClickListener(new OnClickListener()
    {
      @Override
      public void onClick(View arg0)
      {
        // 執(zhí)行朗讀
        tts.speak(editText.getText().toString(),
          TextToSpeech.QUEUE_ADD, null);
      }
    });
    record.setOnClickListener(new OnClickListener()
    {
      @Override
      public void onClick(View arg0)
      {
        // 將朗讀文本的音頻記錄到指定文件
        tts.synthesizeToFile(editText.getText().toString(), null,  "/mnt/sdcard/sound.wav");
        Toast.makeText(Speech.this, "聲音記錄成功!", 50000).show();
      }
    });
  }
  @Override
  public void onDestroy()
  {
    // 關(guān)閉TextToSpeech對象
    if (tts != null)
    {
      tts.shutdown();
    }
  }
}

上面的程序第一行粗體字代碼設(shè)置創(chuàng)建了一個(gè)TextToSpeech對象,第二行粗體字使用美式英語進(jìn)行英語朗讀。接下來程序分別體統(tǒng)了兩個(gè)按鈕,一個(gè)按鈕用于執(zhí)行朗讀發(fā)生,一個(gè)按鈕用于將文本內(nèi)容朗讀音頻保存成聲音文件,分別通過調(diào)用TextToSpeech對象的兩個(gè)方法完成。

運(yùn)行程序,可以看到下圖界面:

Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能

在界面中,當(dāng)用戶點(diǎn)擊“朗讀”按鈕后,系統(tǒng)將會(huì)調(diào)用TTS的speak()方法來朗讀文本框的內(nèi)容;當(dāng)用戶單擊“記錄聲音”按鈕后,系統(tǒng)會(huì)調(diào)用synthesizeToFile()方法把文本框中的文本對應(yīng)的朗讀音頻記錄到SD卡的聲音文件中——單擊該按鈕后將可以在SD卡的根目錄下生成一個(gè)sound.wav文件,該文件可以被導(dǎo)出,在其他音頻播放軟件中播放。

程序重寫Activity的onDestroy()方法,并在該方法中關(guān)閉了TextToSpeech對象,回收了它的資源。

感謝各位的閱讀,以上就是“Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!


分享題目:Android中如何實(shí)現(xiàn)文本內(nèi)容自動(dòng)朗讀功能-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://weahome.cn/article/cdjcss.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部