Android中使用谷歌api实现语音识别

//注意要实现此功能要下载一个谷歌的语音搜索(软件)

public class MainActivity extends Activity implements android.view.View.OnClickListener, OnInitListener{  

 
    private Button speechBtn; // 按钮控制开始朗读  
    private TextView speechTxt; // 需要朗读的内容  
    private TextToSpeech textToSpeech; // TTS对象  
  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.fragment_main);  
  
        speechBtn = (Button) findViewById(R.id.btn_check);  
        speechBtn.setOnClickListener(this);  
  
        speechTxt = (TextView) findViewById(R.id.et_word);  
        textToSpeech = new TextToSpeech(this, this); // 参数Context,TextToSpeech.OnInitListener  
    }  
      
    /** 
     * 用来初始化TextToSpeech引擎 
     * status:SUCCESS或ERROR这2个值 
     * setLanguage设置语言,帮助文档里面写了有22种 
     * TextToSpeech.LANG_MISSING_DATA:表示语言的数据丢失。 
     * TextToSpeech.LANG_NOT_SUPPORTED:不支持 
     */  
    @Override  
    public void onInit(int status) {  
        if (status == TextToSpeech.SUCCESS) {  
            int result = textToSpeech.setLanguage(Locale.US);  
            if (result == TextToSpeech.LANG_MISSING_DATA  
                    || result == TextToSpeech.LANG_NOT_SUPPORTED) {  
                Toast.makeText(this, "数据丢失或不支持", Toast.LENGTH_SHORT).show();  
            }  
        }  
    }  
  
    @Override  
    public void onClick(View v) {  
        if (textToSpeech != null && !textToSpeech.isSpeaking()) {  
            textToSpeech.setPitch(0.5f);// 设置音调,值越大声音越尖(女生),值越小则变成男声,1.0是常规  
            textToSpeech.speak(speechTxt.getText().toString(),  
                    TextToSpeech.QUEUE_FLUSH, null);  
        }  
    }  
  
    @Override  
    protected void onStop() {  
        super.onStop();  
        textToSpeech.stop(); // 不管是否正在朗读TTS都被打断  
        textToSpeech.shutdown(); // 关闭,释放资源  
    }  

}  

//布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.texttospeach.MainActivity$PlaceholderFragment" >


   <EditText
        android:id="@+id/et_word"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="请输入单词"
        android:textColor="#fff"
/>
    <Button 
        android:id="@+id/btn_check"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="朗读"
        android:textColor="#fff"
        
        
        />
</LinearLayout>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Studio是一款用于开发Android应用程序的集成开发环境。它可以通过各种API和工具来实现各种功能,包括语音识别使用demo来实现语音识别是一种较为简单的方法。下面我将简要介绍如何使用demo实现语音识别。 首先,你需要在Android Studio创建一个新的项目。然后,通过向项目添加必要的权限和依赖项,来启用语音识别功能。具体的权限和依赖项可以通过引入相关的API实现,比如Google Speech to Text APIAndroid自身的语音识别API。 在项目创建一个示例活动(Activity),用于实现语音识别功能。你可以在这个活动添加一个按钮或其他触发事件的UI元素,然后通过点击触发事件来开始语音识别。 在触发事件的方法,你需要调用相关的API实现语音识别。具体的代码可以在API的官方文档找到,并根据自己的需求进行适当的修改。通常,你需要创建一个语音识别Intent,并对返回的结果进行处理。 在处理语音识别结果时,你可以选择将结果显示在界面上,或者执行其他操作,比如存储结果或调用其他API。 最后,通过编译和运行你的应用程序,你就可以在Android设备上测试语音识别功能了。 总结起来,通过在Android Studio使用demo来实现语音识别,你需要创建一个新的项目,添加必要的权限和依赖项,创建一个示例活动,调用相关的API实现语音识别,处理识别结果,并在设备上进行测试。这是一个简单的方法,你可以根据自己的需求进行进一步的定制和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值