Android中TextToSpeech的使用

举报
计蒙不吃鱼 发表于 2025/06/09 01:05:33 2025/06/09
【摘要】 本文介绍了在Android开发中使用TextToSpeech(TTS)实现语音合成的功能。通过实例代码展示了TTS的初始化、语言设置、语音播放及队列模式的选择,并提供了将语音保存为音频文件的方法。项目中包含一个简单的按钮触发朗读功能,适合初学者学习和实践。代码示例完整,涵盖Activity生命周期管理与XML布局设计。

系列文章目录

Android中TextToSpeech的使用

前言

在一年前,和朋友一起码了一个英语APP,仿照某APP实现了单词的功能,最开始就是借助的TextToSpeech,后面感觉声音不够好听,于是使用了第三方

APP初稿如图:

实现

1.初始化语音。这是一个异步操作。初始化完成后调用oninitListener(第二个参数)。

TextToSpeech mTts = new TextToSpeech(this, this);

2.实现TextToSpeech.OnInitListener

注意:语言可能不可用。

 // 实现TextToSpeech.OnInitListener.
     public void onInit(int status) {
         if (status == TextToSpeech.SUCCESS) {
             //设置首选语言为中文,注意,语言可能是不可用的,结果将指示此
             int result = mTts.setLanguage(Locale.CHINA);
             if (result == TextToSpeech.LANG_MISSING_DATA ||
                 result == TextToSpeech.LANG_NOT_SUPPORTED) {
                 //语言数据丢失或不支持该语言。
                 Log.e(TAG, "语言数据丢失或不支持该语言");
             } else {
                 //检查文档中其他可能的结果代码。
                 // 例如,语言可能对区域设置可用,但对指定的国家和变体不可用
                 // TTS引擎已成功初始化。
                 // 允许用户按下按钮让应用程序再次发言。
                 mAgainButton.setEnabled(true);
             }
         } else {
             // 初始化失败
             Log.e(TAG, "初始化失败");
         }
     }

3.写一个朗读方法,在需要的时候触发(如:点击事件)

TextToSpeech的speak方法有两个重载。

  • 执行朗读的方法
speak(CharSequence text,int queueMode,Bundle params,String utteranceId);

第二个参数queueMode用于指定发音队列模式,两种模式选择。
(1)TextToSpeech.QUEUE_FLUSH:该模式下在有新任务时候会清除当前语音任务,执行新的语音任务
(2)TextToSpeech.QUEUE_ADD:该模式下会把新的语音任务放到语音任务之后,等前面的语音任务执行完了才会执行新的语音任务。

  • 将朗读的的声音记录成音频文件
synthesizeToFile(CharSequence text,Bundle params,File file,String utteranceId);
     private void sayHello() {
         String hello ="Hellow";
         //TextToSpeech的speak方法有两个重载。
         // 执行朗读的方法
         //speak(CharSequence text,int queueMode,Bundle params,String utteranceId);
         // 将朗读的的声音记录成音频文件
         //synthesizeToFile(CharSequence text,Bundle params,File file,String utteranceId);
         //第二个参数queueMode用于指定发音队列模式,两种模式选择
         //(1)TextToSpeech.QUEUE_FLUSH:该模式下在有新任务时候会清除当前语音任务,执行新的语音任务
         //(2)TextToSpeech.QUEUE_ADD:该模式下会把新的语音任务放到语音任务之后,
         //等前面的语音任务执行完了才会执行新的语音任务

         mTts.speak(hello,
             TextToSpeech.QUEUE_FLUSH,
             null);
     }

4.记得利用Activity的生命周期中将其关闭

     @Override
     public void onDestroy() {
         // 生命周期中结束
         if (mTts != null) {
             mTts.stop();
             mTts.shutdown();
         }

         super.onDestroy();
     }

源码

SpeechActivity.java

public class SpeechActivity extends Activity implements TextToSpeech.OnInitListener {

     private static final String TAG = "SpeechDemo";

     private TextToSpeech mTts;
     private Button mButton;

     @Override
     public void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.text_to_speech);

         //初始化语音。这是一个异步操作。初始化完成后调用oninitListener(第二个参数)。
         mTts = new TextToSpeech(this, this);

         mButton = (Button) findViewById(R.id.again_button);
        //触发
         mButton.setOnClickListener(new View.OnClickListener() {
             public void onClick(View v) {
                 sayHello();
             }
         });
     }

     @Override
     public void onDestroy() {
         // 生命周期中结束
         if (mTts != null) {
             mTts.stop();
             mTts.shutdown();
         }

         super.onDestroy();
     }

     // 实现TextToSpeech.OnInitListener.
     public void onInit(int status) {
         if (status == TextToSpeech.SUCCESS) {
             //设置首选语言为中文,注意,语言可能是不可用的,结果将指示此
             int result = mTts.setLanguage(Locale.CHINA);
             if (result == TextToSpeech.LANG_MISSING_DATA ||
                 result == TextToSpeech.LANG_NOT_SUPPORTED) {
                 //语言数据丢失或不支持该语言。
                 Log.e(TAG, "语言数据丢失或不支持该语言");
             } else {
                 //检查文档中其他可能的结果代码。
                 // 例如,语言可能对区域设置可用,但对指定的国家和变体不可用
                 // TTS引擎已成功初始化。
                 // 允许用户按下按钮让应用程序再次发言。
                 mAgainButton.setEnabled(true);
             }
         } else {
             // 初始化失败
             Log.e(TAG, "初始化失败");
         }
     }

     private void sayHello() {
         String hello ="计蒙不吃鱼";
         //TextToSpeech的speak方法有两个重载。
         // 执行朗读的方法
         //speak(CharSequence text,int queueMode,Bundle params,String utteranceId);
         // 将朗读的的声音记录成音频文件
         //synthesizeToFile(CharSequence text,Bundle params,File file,String utteranceId);
         //第二个参数queueMode用于指定发音队列模式,两种模式选择
         //(1)TextToSpeech.QUEUE_FLUSH:该模式下在有新任务时候会清除当前语音任务,执行新的语音任务
         //(2)TextToSpeech.QUEUE_ADD:该模式下会把新的语音任务放到语音任务之后,
         //等前面的语音任务执行完了才会执行新的语音任务

         mTts.speak(hello,
             TextToSpeech.QUEUE_FLUSH,
             null);
     }

 }

text_to_speech.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >
    <Button android:id="@+id/again_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:enabled="false" />
</LinearLayout>
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。