texttospeech的使用

发布时间:2025-12-09 16:13:31 浏览次数:4

TextToSpeech的使用

文章目录

    • TextToSpeech的使用
      • 前言
      • 内嵌的类:
      • 常量:
      • 构造方法:
      • 简单比较:
      • 实现:

前言

该文章为粗略讲解,如何使用Android studio自带的类去实现文字转语音的功能,即TextToSpeech(以下简称TTS)
TTS是语音合成应用的一种,它将储存于电脑中的文件,如帮助文件或者网页,转换成自然语音输出。TTS不仅能帮助有视觉障碍的人阅读计算机上的信息,更能增加文本文档的可读性。现在的TTS应用包括语音驱动的邮件以及声音敏感系统,并常与声音识别程序一起使用。TextToSpeech必须再被实例化之后才能使用.实现TextToSpeech.OnInitListener方法来获取实例化结果的提醒。当你已经使用完TextToSpeech实例之后, 应该调用shutdown()方法来释放TextToSpeech所使用的本地资源。

详细摘要可见中国谷歌官网

内嵌的类:

类型名称功能
classTextToSpeech.Engine控制文字转化语音的常亮或者参数名
classTextToSpeech.EngineInfo已安装的语音引擎的信息
interfaceTextToSpeech.OnInitListener定义了语音引擎初始化结果的回调接口
interfaceTextToSpeech.OnUtteranceCompletedListenerAPI level 18被弃用 . 使用UtteranceProgressListener替代

常量:

类型名称功能
StringACTION_TTS_QUEUE_PROCESSING_COMPLETED广播事件,表示TextToSpeech转化器已经转化未所有处于语音队列的文本
intERROR表示一般的操作失败
intERROR_INVALID_REQUEST表示由于无效请求导致的失败
intERROR_NETWORK表示由于网络连接问题导致的失败
intERROR_NETWORK_TIMEOUT表示由于网络连接超时引起的失败
intERROR_NOT_INSTALLED_YET表示由于未完成的语音数据下载导致的错误
intERROR_OUTPUT表示输出产生的失败
intERROR_SERVICE表示由于TTS服务产生的失败
intERROR_SYNTHESIS表示由于引擎的输入转化的输入内容引起的失败
intLANG_AVAILABLE表示本地语言可用,但不是方言或者引申语言(不知道对不对)
intLANG_COUNTRY_AVAILABLE表示本地语音或者方言可用,引申语音不可用
intLANG_COUNTRY_VAR_AVAILABLE表示本地语音可用
intLANG_MISSING_DATA语言包丢失
intLANG_NOT_SUPPORTED表示语音不支持
intQUEUE_ADD新的转化任务添加到队列后面
intQUEUE_FLUSH新的任务替代以前的任务,直接中断以前的任务
intSTOPPED表示由代理要求的停止
intSUCCESS操作成功

构造方法:

//使用默认的引擎TextToSpeech(Context context, TextToSpeech.OnInitListener listener)//使用指定的引擎TextToSpeech(Context context, TextToSpeech.OnInitListener listener, String engine)

简单比较:

应用包名比较
com.svox.pico系统自带不支持中文语音
com.svox.classic搜svox搜到的,和上面类似不支持中文
com.google.android.tts谷歌文字转语音引擎,不支持5.0以下系统,大小17.98M
com.iflytek.speechcloud科大讯飞语音引擎3.0,支持4.0以上系统,大小27.27M
com.iflytek.speechsuite新版科大讯飞语音引擎,2018年开始新版手机一般会内置,如oppo、vivo、华为
com.baidu.duersdk.opensdk度秘语音引擎3.0 不支持5.0以下系统,大小11.95M
com.iflytek.tts科大讯飞语音合成,较老,不支持7.0以上系统,大小9M

实现:

接下去则是通过自己写的一个小例子来展示TTS的使用

首先先设计布局文件,由于是测试,则我选择比较简约的方式,播放按键放在菜单栏也更加方便。
main_activity.xml:

<EditText xmlns:android="http://schemas.android.com/apk/res/android"class="com.example.android.notepad.NoteEditor$LinedEditText"android:id="@+id/note"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@android:color/transparent"android:padding="5dp"android:scrollbars="vertical"android:fadingEdge="vertical"android:gravity="top"android:textSize="22sp"android:capitalize="sentences"/>

menu文件夹下的menu文件:
note_editor.xml:

<?xml version="1.0" encoding="utf-8"?><menu xmlns:android="http://schemas.android.com/apk/res/android"><item android:id="@+id/menu_save"android:icon="@drawable/ic_menu_save"android:alphabeticShortcut='s'android:title="@string/menu_save"android:showAsAction="ifRoom|withText" /><item android:id="@+id/menu_revert"android:icon="@drawable/ic_menu_revert"android:title="@string/menu_revert" /><item android:id="@+id/menu_delete"android:icon="@drawable/ic_menu_delete"android:title="@string/menu_delete"android:showAsAction="ifRoom|withText" /><item android:id="@+id/speech"android:title="Speech"android:showAsAction="ifRoom|withText"/></menu>

设计完布局文件后,接下去就是要修改java代码,首先,我们的java类需要实现View.OnClickListener, TextToSpeech.OnInitListener两个接口

public class NoteEditor extends Activity implements View.OnClickListener, TextToSpeech.OnInitListener{

TextToSpeech必须被实例化之后才能使用.实现TextToSpeech.OnInitListener方法来获取实例化结果的监听。当你已经使用完TextToSpeech实例之后, 应该调用shutdown()方法来释放TextToSpeech所使用的本地资源。
构造方法:

//使用默认的引擎TextToSpeech(Context context, TextToSpeech.OnInitListener listener)//使用指定的引擎TextToSpeech(Context context, TextToSpeech.OnInitListener listener, String engine)

实现接口提供的两个方法:
onInit()为初始化函数,我们将他重写,如果成功就将赋值给result,如果失败则通过toast显示失败。
onClick()为点击事件函数,声明事件触发后索要执行的方法。

public void onInit(int status) {if (status ==TextToSpeech.SUCCESS){int result = mTextToSpeech.setLanguage(Locale.CHINA);// TextToSpeech.LANG_MISSING_DATA:表示语言的数据丢失// TextToSpeech.LANG_NOT_SUPPORTED:不支持if (result == TextToSpeech.LANG_MISSING_DATA|| result == TextToSpeech.LANG_NOT_SUPPORTED) {Toast.makeText(this, "数据丢失或不支持", Toast.LENGTH_SHORT).show();}}}public void onClick(View view) {switch (view.getId()){case R.id.speech:System.out.println("成功");submit();break;default:break;}}

具体执行方法submit():
判定EditText是否为空,为空则通过Toast提示为空,不为空则判定mTextToSpeech不为空,且mTextToSpeech.isSpeaking()不存在,即不在朗读的时候,则进行speak()。mTextToSpeech是一个TextToSpeech类型的变量。

public void submit(){String text = main_text.getText().toString().trim();if (TextUtils.isEmpty(text)){Toast.makeText(this,"日志为空",Toast.LENGTH_SHORT).show();return;}if (mTextToSpeech!=null && !mTextToSpeech.isSpeaking()){mTextToSpeech.speak(text, TextToSpeech.QUEUE_FLUSH, null);}}

接着就是为朗读的声音进行初始化,以及对于朗读内容进行确定:

private void initTextToSpeech(){// 参数Context,TextToSpeech.OnInitListenermTextToSpeech = new TextToSpeech(this, this);// 设置音调,值越大声音越尖(女生),值越小则变成男声,1.0是常规mTextToSpeech.setPitch(1.0f);// 设置语速mTextToSpeech.setSpeechRate(0.5f);}private void initView(){main_text = findViewById(R.id.note);}

对于朗读的停止和资源的释放如下:

@Overrideprotected void onDestroy() {if (mTextToSpeech != null) {mTextToSpeech.stop();mTextToSpeech.shutdown();mTextToSpeech = null;}super.onDestroy();}@Overrideprotected void onStop() {super.onStop();// 不管是否正在朗读TTS都被打断mTextToSpeech.stop();// 关闭,释放资源mTextToSpeech.shutdown();}

最后在onCreate()中调用他们即可:

initView();initTextToSpeech();

​ 作者:吴百春

​ 原文链接:https://blog.csdn.net/qq_44160036/article/details/106720634

需要做网站?需要网络推广?欢迎咨询客户经理 13272073477