该文章为粗略讲解,如何使用Android studio自带的类去实现文字转语音的功SEO靠我能,即TextToSpeech(以下简称TTS)
TTS是语音合成应用的一种,它将储存于电脑中的文件,如帮助文件或者网页,转换成自然语音输出。TTS不仅能帮助有视觉障碍的人阅读计算机上的信息,更能增加文SEO靠我本文档的可读性。现在的TTS应用包括语音驱动的邮件以及声音敏感系统,并常与声音识别程序一起使用。TextToSpeech必须再被实例化之后才能使用.实现TextToSpeech.OnInitListeSEO靠我ner方法来获取实例化结果的提醒。当你已经使用完TextToSpeech实例之后, 应该调用shutdown()方法来释放TextToSpeech所使用的本地资源。详细摘要可见中国谷歌官网
接下去则是SEO靠我通过自己写的一个小例子来展示TTS的使用
首先先设计布局文件,由于是测试,则我选择比较简约的方式,播放按键放在菜单栏也更加方便。
main_activity.xml:<EditText xmlns:andSEO靠我roid="http://schemas.android.com/apk/res/android"class="com.example.android.notepad.NoteEditor$LinedSEO靠我EditText"android:id="@+id/note"android:layout_width="match_parent"android:layout_height="match_parenSEO靠我t"android:background="@android:color/transparent"android:padding="5dp"android:scrollbars="vertical"aSEO靠我ndroid:fadingEdge="vertical"android:gravity="top"android:textSize="22sp"android:capitalize="sentenceSEO靠我s" />menu文件夹下的menu文件:
note_editor.xml:<?xml version="1.0" encoding="utf-8"?> <menu xmSEO靠我lns:android="http://schemas.android.com/apk/res/android"><item android:id="@+id/menu_save"android:icSEO靠我on="@drawable/ic_menu_save"android:alphabeticShortcut=sandroid:title="@string/menu_save"android:showSEO靠我AsAction="ifRoom|withText" /><item android:id="@+id/menu_revert"android:icon="@drawable/ic_menu_reveSEO靠我rt"android:title="@string/menu_revert" /><item android:id="@+id/menu_delete"android:icon="@drawable/SEO靠我ic_menu_delete"android:title="@string/menu_delete"android:showAsAction="ifRoom|withText" /><item andSEO靠我roid:id="@+id/speech"android:title="Speech"android:showAsAction="ifRoom|withText"/> </menu>设SEO靠我计完布局文件后,接下去就是要修改java代码,首先,我们的java类需要实现View.OnClickListener, TextToSpeech.OnInitListener两个接口
public clSEO靠我ass NoteEditor extends Activity implements View.OnClickListener, TextToSpeech.OnInitListener{TextToSSEO靠我peech必须被实例化之后才能使用.实现TextToSpeech.OnInitListener方法来获取实例化结果的监听。当你已经使用完TextToSpeech实例之后, 应该调用shutdown()SEO靠我方法来释放TextToSpeech所使用的本地资源。
构造方法://使用默认的引擎 TextToSpeech(Context context, TextToSpeech.OnInitLiSEO靠我stener listener)//使用指定的引擎 TextToSpeech(Context context, TextToSpeech.OnInitListener listenerSEO靠我, String engine)实现接口提供的两个方法:
onInit()为初始化函数,我们将他重写,如果成功就将赋值给result,如果失败则通过toast显示失败。
onClick()为点击事件函数,SEO靠我声明事件触发后索要执行的方法。public void onInit(int status) {if (status ==TextToSpeech.SUCCESS){int result = mTextSEO靠我ToSpeech.setLanguage(Locale.CHINA);// TextToSpeech.LANG_MISSING_DATA:表示语言的数据丢失// TextToSpeech.LANG_NSEO靠我OT_SUPPORTED:不支持if (result == TextToSpeech.LANG_MISSING_DATA|| result == TextToSpeech.LANG_NOT_SUPPOSEO靠我RTED) {Toast.makeText(this, "数据丢失或不支持", Toast.LENGTH_SHORT).show();}}}public void onClick(View view)SEO靠我 {switch (view.getId()){case R.id.speech:System.out.println("成功");submit();break;default:break;}}具体执SEO靠我行方法submit():
判定EditText是否为空,为空则通过Toast提示为空,不为空则判定mTextToSpeech不为空,且mTextToSpeech.isSpeaking()不存在,即不在朗SEO靠我读的时候,则进行speak()。mTextToSpeech是一个TextToSpeech类型的变量。public void submit(){String text = main_text.getTeSEO靠我xt().toString().trim();if (TextUtils.isEmpty(text)){Toast.makeText(this,"日志为空",Toast.LENGTH_SHORT).sSEO靠我how();return;}if (mTextToSpeech!=null && !mTextToSpeech.isSpeaking()){mTextToSpeech.speak(text, TextSEO靠我ToSpeech.QUEUE_FLUSH, null);}}接着就是为朗读的声音进行初始化,以及对于朗读内容进行确定:
private void initTextToSpeech(){// 参数ContSEO靠我ext,TextToSpeech.OnInitListenermTextToSpeech = new TextToSpeech(this, this);// 设置音调,值越大声音越尖(女生),值越小则SEO靠我变成男声,1.0是常规mTextToSpeech.setPitch(1.0f);// 设置语速mTextToSpeech.setSpeechRate(0.5f);}private void initVSEO靠我iew(){main_text = findViewById(R.id.note);}对于朗读的停止和资源的释放如下:
@Overrideprotected void onDestroy() {if (SEO靠我mTextToSpeech != null) {mTextToSpeech.stop();mTextToSpeech.shutdown();mTextToSpeech = null;}super.onSEO靠我Destroy();}@Overrideprotected void onStop() {super.onStop();// 不管是否正在朗读TTS都被打断mTextToSpeech.stop();/SEO靠我/ 关闭,释放资源mTextToSpeech.shutdown();}最后在onCreate()中调用他们即可:
initView(); initTextToSpeech(); 作者:SEO靠我吴百春
原文链接:https://blog.csdn.net/qq_44160036/article/details/106720634
网站备案号:浙ICP备17034767号-2