Android(安卓)TTS学习——保存对你的喜欢
Android TTS学习——保存对你的喜欢
分类:Google AndroidAndroid TTS 2010-08-14 10:18 1100人阅读 评论(4) 收藏 举报一.简单介绍
在上一篇里
http://blog.csdn.net/ichliebephone/archive/2010/08/13/5810370.aspx
我们介绍了TTS提供的接口OnUtteranceCompletedListener的使用,这个接口的作用是监听语音片段的朗读,并在语音片段朗读结束后调用其定义的回调函数,在回调函数里可以进行需要的操作。
在这一篇里我们介绍一下TTS提供的另一个有用的功能,把合成的语音以音频文件的形式保存在系统里,然后就可以直接用播放音频文件的方式来播放。
这个功能调用的函数为:
publicintsynthesizeToFile(Stringtext,HashMap<String,String>params,Stringfilename)
第一个参数为要进行语音合成的文本;第二个参数我们在上一个Demo中有所介绍,是一个键值对形式的HashMap类型变量,可以设置语音片段的ID等;第三个参数为保存到系统中的文件名。
当你想和朋友分享一份精彩的文本合成语音后的效果时,你可以使用这个功能把它保存为音频文件发送给朋友,这样即使朋友的手机不具备TTS功能,也可以用播放音频的方式分享到;当你要对同一段较长的文本多次进行语音合成时,你可以把这段文本的语音保存为音频文件,然后使用时播放,这样会更省资源,运行速度更快,因为使用TTS是比较费资源的一个过程。因此我们会在某些场合用到这个功能。
下面我们就用这个功能完成一个Demo例子,当你害羞当面向她表白你对她的喜欢时,让Android帮你语音合成你想说的话,然后你就可以向她发送保存了对她喜欢的这个音频文件。
二.实例开发
我们希望做的效果如下:
图1实现效果图
第一个文本框里可以输入需要语音合成的文本,第二个文本框里输入要保存成的音频文件的文件名,点击第一个Speak按钮你可以预听一下TTS语音合成的效果,点击第二个Record按钮,就会以音频文件的形式保存,然后就可以点击第三个Play按钮播放保存的这个音频文件。
创建一个Android工程,工程名为AndroidTTSDemoFourth,其中SDK版本需选择1.6及以上。
其中Main.xml文件很简单,如下所示:
[xhtml] view plain copy- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <EditTextandroid:id="@+id/inputText"
- android:hint="Inputthetexthere!"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content">
- </EditText>
- <Buttonandroid:text="Speak"
- android:id="@+id/speakBtn"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_gravity="center_horizontal"
- android:enabled="false"
- ></Button>
- <TextViewandroid:id="@+id/filenameLabel"
- android:text="Saveas:"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- ></TextView>
- <EditTextandroid:id="@+id/filenameText"
- android:hint="Inputthesavingfilenamehere!"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content">
- ></EditText>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="horizontal"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:gravity="center_horizontal"
- >
- <Buttonandroid:id="@+id/recordBtn"
- android:text="Record"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- ></Button>
- <Buttonandroid:id="@+id/playBtn"
- android:text="Play"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:enabled="false"
- ></Button>
- </LinearLayout>
- </LinearLayout>
Java文件的编写:
有了前面这些Demo的实例开发,这个Demo实现起来就比较简单了,程序的代码如下所示:
[java] view plain copy- publicclassAndroidTTSDemoFourthextendsActivityimplementsOnInitListener{
- //实现初始接口
- /**Calledwhentheactivityisfirstcreated.*/
- //定义变量
- privateEditTextinputText=null;
- privateButtonspeakBtn=null;
- privateEditTextfilenameText=null;
- privateButtonrecordBtn=null;
- privateButtonplayBtn=null;
- privateTextToSpeechmTts;
- privatestaticfinalStringTAG="TTSDemo";
- privatestaticfinalStringloveConfession="jiajia,Iloveyou.";
- privateStringloveFileName=null;
- privateFileloveFile=null;
- privateMediaPlayerplayer=null;
- @Override
- publicvoidonCreate(BundlesavedInstanceState){
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- //创建TextToSpeech实例,初始化完成后会调用OnInitListener(第二个参数)的回调函数
- mTts=newTextToSpeech(this,
- this//TextToSpeech.OnInitListener
- );
- //设置控件
- inputText=(EditText)findViewById(R.id.inputText);
- speakBtn=(Button)findViewById(R.id.speakBtn);
- filenameText=(EditText)findViewById(R.id.filenameText);
- recordBtn=(Button)findViewById(R.id.recordBtn);
- playBtn=(Button)findViewById(R.id.playBtn);
- inputText.setText(loveConfession);
- filenameText.setText("/sdcard/love.wav");
- speakBtn.setOnClickListener(newOnClickListener(){
- publicvoidonClick(Viewv){
- //TODOAuto-generatedmethodstub
- //朗读输入框里的内容
- mTts.speak(inputText.getText().toString(),TextToSpeech.QUEUE_ADD,null);
- }
- });
- recordBtn.setOnClickListener(newOnClickListener(){
- @Override
- publicvoidonClick(Viewv){
- //TODOAuto-generatedmethodstub
- //把TTS语音合成的结果保存为音频文件
- loveFileName=filenameText.getText().toString();
- loveFile=newFile(loveFileName);
- if(loveFile.exists())
- {
- loveFile.delete();
- }
- //把语音合成的结果保存到文件中
- if(TextToSpeech.SUCCESS==mTts.synthesizeToFile(inputText.getText().toString(),null,loveFileName))
- {
- Toast.makeText(getBaseContext(),"soundfilecreated!",Toast.LENGTH_SHORT).show();
- playBtn.setEnabled(true);
- }
- else
- {
- Toast.makeText(getBaseContext(),"failedtocreatesoundfile!",Toast.LENGTH_SHORT).show();
- }
- }
- });
- playBtn.setOnClickListener(newOnClickListener(){
- @Override
- publicvoidonClick(Viewv){
- //TODOAuto-generatedmethodstub
- //播放保存着的音频文件
- try
- {
- player=newMediaPlayer();
- player.setDataSource(loveFileName);
- player.prepare();
- player.start();
- }
- catch(Exceptione){
- //TODO:handleexception
- Toast.makeText(getBaseContext(),"failedtoplaysoundfile!",Toast.LENGTH_SHORT).show();
- e.printStackTrace();
- }
- }
- });
- }
- publicvoidonInit(intstatus){
- //TODOAuto-generatedmethodstub
- //TTSEngine初始化完成
- if(status==TextToSpeech.SUCCESS)
- {
- intresult=mTts.setLanguage(Locale.US);
- //设置发音语言
- if(result==TextToSpeech.LANG_MISSING_DATA||result==TextToSpeech.LANG_NOT_SUPPORTED)
- //判断语言是否可用
- {
- Log.v(TAG,"Languageisnotavailable");
- speakBtn.setEnabled(false);
- }
- else
- {
- speakBtn.setEnabled(true);
- }
- }
- }
- @Override
- protectedvoidonDestroy(){
- //TODOAuto-generatedmethodstub
- //释放TTS的资源
- if(mTts!=null)
- {
- mTts.stop();
- mTts.shutdown();
- }
- super.onDestroy();
- }
- }
和TTS相关的新的部分为recordBtn的onClick事件的处理,先根据指定的文件名创建一个File变量,来判断文件是否已经存在,如果已存在就先删除。然后调用函数
mTts.synthesizeToFile(inputText.getText().toString(),null,loveFileName)
把文本框中的内容语音合成后保存到文件中。
另一个playBtn的onClick事件的处理,主要就是创建一个MediaPlayer实例,播放上一步保存的音频文件。
至此,这个Demo就完成了,但是在运行前,需创建一个带SD卡的AVD,因为要往SD卡上保存文件,如下所示:
图2必须创建带SD卡的AVD
同时还需在AndroidManifest.xml文件中添加写外部存储设备的权限:
<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
接着就可以运行这个Demo了,运行程序后在Eclipse中切换到DDMS视图,接着选择查看File Explorer,我们看到在没有点击程序的Record按钮进行语音合成到文件保存时,sdcard目录下没有额外的文件,如下图所示:
图3原始的SD卡目录
然后我们在程序中点击Record按钮,让TTS把语音合成到文件,合成成功的话会弹出“sound file created!”的提示,并且Play按钮变成可用。点击Play按钮就会播放刚刚保存的音频文件,和点击第一个的Speak按钮朗读的内容是一样的。这时,我们再来查看下SD卡的目录,会发现多了一个文件:love.wav,正是我们设定保存的文件名,如下图所示:
图4语音合成到文件后的SD卡目录
并且,我们还可以使用adb pull命令把这个文件从SD卡上提取出来,在CMD窗口中运行adb pull ./sdcard/love.wav就可以把SD卡上的这个音频文件保存的当前目录下,如下图所示:
图5提取SD卡上保存的音频文件
最后,也可以在电脑上播放记录了你对她的喜欢的这个音频文件了,或者也可以把这个文件发送给你喜欢的她。
注:文章参加“首届Google暑期大学生博客分享大赛——2010 Andriod篇”
更多相关文章
- ubuntu12.04 android studio 安装(装完后再重启系统挂了,请勿参考
- Android学习笔记之cyanogenmod编译篇
- 【Android(安卓)开发教程】PreferenceFragment
- Android设置全局字体大小,实现小中大字体功能
- Android: 缩放图片文件引起的OOM异常
- Android(安卓)gradle 统一依赖库版本
- 记录升级Android(安卓)studio3.0遇到的一些问题和解决方法
- 关于 android 远程控制(pc 控制手机)
- 将Android下的可执行文件以静态库的形式进行编译