Android语音播报、后台播报、语音识别

Android语音播报、后台播报、语音识别

本文介绍使用讯飞语音实现语音播报、语音识别功能。

讯飞开放平台:http://www.xfyun.cn/index.php/default/index

程序效果图:

简单的XML布局

<?xml version="1.0" encoding="utf-8"?

>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <EditText
        android:id="@+id/et"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:editable="true" />

    <Button
        android:id="@+id/bt_recognize"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="识别" />

    <Button
        android:id="@+id/bt_speek"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="Speek" />

    <Button
        android:id="@+id/bt_speek_bg"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="后台Speek" />

    <TextView
        android:textColor="@android:color/white"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="语音控制开关" />

    <ToggleButton
        android:id="@+id/tb"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</LinearLayout>

识别

case R.id.bt_recognize:
                    // 这是语言识别部分。最重要的实例化一个
                    // RecognizerDialog并把你在官方站点申请的appid填入进去。非法id不能进行识别
                    RecognizerDialog isrDialog = new RecognizerDialog(Voice1Activity.this, APPID);

                    /*
                     * 设置引擎眼下支持五种 ”sms”:普通文本转写 “poi”:地名搜索 ”vsearch”:热词搜索
                     * ”video”:视频音乐搜索 ”asr”:命令词识别
                     */
                    isrDialog.setEngine("sms", null, null);
                    isrDialog.setListener(recoListener);
                    isrDialog.show();
                    break;
// 语言识别监听器。有两个方法
    RecognizerDialogListener recoListener = new RecognizerDialogListener() {

        @Override
        public void onResults(ArrayList<RecognizerResult> results,
                boolean isLast) {
            // 新添加了一个ToggleButton tb,首先检查tb是否被按下,假设被按下才进行语言控制,没被按下就进行文字识别
            if (tb.isChecked()) {
                // doVoice方法就是进行识别
                doVoice(results);
            } else {
                // server识别完毕后会返回集合,我们这里就仅仅得到最匹配的那一项
                text += results.get(0).text;
                System.out.println(text);
            }

        }

        // 首先迭代结果,然后获取每一个结果。并进行对照。假设包括有特定字符串。那么就运行对应Intent跳转。

// 注意 凡是Intent能办到的(发邮件,跳到已安装应用。拨号,发短信,发彩信,浏览网页,播放多媒体)。它就都能办到。
        private void doVoice(ArrayList<RecognizerResult> results) {
            Intent i = new Intent();
            for (RecognizerResult result : results) {
                if (result.text.contains("天气")) {
                    // 天气界面的跳转
                    i.setClass(Voice1Activity.this, Weather.class);
                    startActivity(i);
                } else if (result.text.contains("新闻")) {
                    // 新闻界面的跳转
                    i.setClass(Voice1Activity.this, News.class);
                    startActivity(i);
                } else if (result.text.contains("短信")) {
                    // 短信界面的跳转
                    i.setAction(Intent.ACTION_VIEW);
                    i.setType("vnd.android-dir/mms-sms");
                    startActivity(i);
                } else {
                    // 假设没有对应指令就用Toast提示用户
                    Toast.makeText(Voice1Activity.this, "无法识别",Toast.LENGTH_SHORT).show();
                }
            }

        }

        @Override
        public void onEnd(SpeechError error) {
            if (error == null) {
                // 完毕后就把结果显示在EditText上
                et.setText(text);
            }
        }
    };

Speek

case R.id.bt_speek:
                    // 这是语言合成部分 相同须要实例化一个SynthesizerDialog ,并输入appid
                    SynthesizerDialog syn = new SynthesizerDialog(Voice1Activity.this, APPID);
                    syn.setListener(new SynthesizerDialogListener() {

                        @Override
                        public void onEnd(SpeechError arg0) {

                        }
                    });
                    // 依据EditText里的内容实现语音合成
                    syn.setText(et.getText().toString(), null);
                    syn.show();
                    break;

后台Speek

 case R.id.bt_speek_bg:
                    //这是后台朗读,实例化一个SynthesizerPlayer
                    SynthesizerPlayer player = SynthesizerPlayer.createSynthesizerPlayer(Voice1Activity.this, APPID);
                    //设置语音朗读者,能够依据须要设置男女朗读。详细请看api文档和官方论坛
                    player.setVoiceName("vivixiaoyan");//在此设置语音播报的人选比如:vivixiaoyan、vivixiaomei、vivixiaoqi
                    player.playText(et.getText().toString(), "ent=vivi21,bft=5",null);

                    break;

源代码下载:http://download.csdn.net/download/gao_chun/8775975

转载请注明.

时间: 2024-10-08 00:56:03

Android语音播报、后台播报、语音识别的相关文章

3D语音天气球——在Unity中使用Android语音服务

转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 开篇废话: 这个项目准备分四部分介绍: 一:创建可旋转的"3D球":3D语音天气球(源码分享)--创建可旋转的3D球 二:通过天气服务,从网络获取时实天气信息并动态生成"3D球":3D语音天气球(源码分享)--通过天气服务动态创建3D球 三:Android语音服务和Unity的消息传递 四:Unity3D端和Android端的结合 前两篇文章已经介绍了如何创

如何处理android程序变为后台程序,系统回收资源,再次打开时,程序因为null指针等崩溃

home键等原因,程序会变为后台程序,系统会更具需要,可能回收资源,再打开时候,就会因为资源回收,再调用oncreate,没有Intent参数而导致程序崩溃.   这种情况,我们可以处理的方式有两种,一是用: @Override     protected void onSaveInstanceState(Bundle outState) {      // TODO Auto-generated method stub      super.onSaveInstanceState(outSta

Android 静默安装/后台安装&amp; Root permission

Android 静默安装/后台安装& Root permission 静默安装其实很简单,今天在网上找资料找半天都说的很复杂,什么需要系统安装权限.调用系统隐藏的api.需要系统环境下编译.需要跟systemUI同进程什么的.我不知道他们真的实现了静默安装实现方式,亲测效果跟豌豆荚一样,并且实现起来非常简单: 1.支持静默安装的机器必须Root,这个不需要我多讲了. 2.使用pm指令安装即可.     3.特别注意 PM指令不支持中文,也就说路径中有中文会导致安装失败! 关键代码如下: exec

android + eclipse + 后台静默安装(一看就会)

首先要说到三个类. [java] view plaincopy import android.content.pm.IPackageInstallObserver; import android.content.pm.IPackageInstallObserver$Stub; import android.content.pm.PackageManager; 其中,IPackageInstallObserver和IPackageInstallObserver$Stub 这两个类,在android

android语音朗读功能demo实现

简单的文本语音朗读功能实现 实现这个功能主要用一个类,是TextToSpeech,废话不都少,直接上代码.总的来说效果一般,短语的停顿节奏不是很好. 界面很简单,一个Button ,一个EditView,就不贴代码了 public class ActivityResumptionArticle extends BaseActivity{    private TextToSpeech mSpeech = null;   private Button btn = null;   private E

微信app支付(android端+java后台)

本文讲解使用微信支付接口完成在android开发的原生态app中完成微信支付功能, 文章具体讲解了前端android如何集成微信支付功能以及后台如何组装前端需要支付信息, 话不多话, 具体看文章内容吧00:00 / 07:03正常 本实例项目运行条件: 开发环境: [Android Studio] 到微信开放平台注册帐号并且创建移动应用 https://open.weixin.qq.com/cgi-bin/frame?t=home/app_tmpl&lang=zh_CN Column 1 Col

高仿QQ源码下载 (android前端+JAVA后台+spark&lt;windows版聊天&gt;)方便集成到自己系统

 A openfire (XMPP+开源源码); B android前端源码(仿QQ高大上UI); C JAVA后台源码(UI高大上HTML5);  Dspark(windows版);  系统主要实现为:JAVA后台(springmvc+mybaits)+openfire(xmpp推送)+android(asmark+ActiveAndroid+async-http+universal-image-loader)+spark(windows版);  android前端 1.集成Activie

语音中的关于语音识别的一些知识

以下内容都是抄的,哈哈哈 1.mel频率: 是模拟人耳对不同频率语音的感知. 人类对不同频率语音有不同的感知能力:对1kHz以下,与频率成线性关系,对1kHz以上,与频率成对数关系.频率越高,感知能力就越差了.因此,在应用中常常只使用低频MFCC,而丢弃中高频MFCC. 在Mel频域内,人对音调的感知能力为线性关系,如果两段语音的Mel频率差两倍,则人在感知上也差两倍. 转换公式:B(f)=1125ln(1+f/700) 其中f为频率,B为Mel-频率. 2.倒谱: 同态处理的结果,分为复数和实

Android 实现Activity后台运行

有时需要让activity在后台运行,具体实现方法如下: 在AndroidManifest.xml中,activity属性中增加: android:theme="@style/BackgroundOnly"                                    android:configChanges="orientation|keyboardHidden" 增加后如下所示: <activity android:name="Acti