Android 实现语音

本文介绍了一种自定义文本转语音服务的实现方法,通过继承TextToSpeech.OnInitListener接口并实现OnInit方法来初始化TTS引擎。文章详细展示了如何设置语音语言、处理消息队列及语音播放流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class MyTextToSpeech implements TextToSpeech.OnInitListener {
    /**
     * 语音
     */
    private TextToSpeech mTextToSpeech;//TTS对象
    private ConcurrentLinkedQueue mBufferedMessages;//消息队列
    private boolean mIsReady;//标识符
    private Context context;
    private String text;

    public MyTextToSpeech(Context context, String text) {
        mBufferedMessages = new ConcurrentLinkedQueue();//实例化队列
        mTextToSpeech = new TextToSpeech(context, this);//实例化TTS
        this.context = context;
        this.text = text;
    }

    @Override
    public void onInit(int status) {
        Log.i("TextToSpeechDemo", String.valueOf(status));
        if (status == TextToSpeech.SUCCESS) {
            int result = this.mTextToSpeech.setLanguage(Locale.CHINA);//设置识别语音为中文
            if (result == TextToSpeech.LANG_MISSING_DATA
                    || result == TextToSpeech.LANG_NOT_SUPPORTED) {
                Vibrator vibrator = (Vibrator) context.getSystemService(Context.VIBRATOR_SERVICE);
                long l[] = {100, 500, 100, 500};
                vibrator.vibrate(l, -1);
                Toast.makeText(context, "数据丢失或不支持", Toast.LENGTH_SHORT).show();
            }
            synchronized (this) {
                this.mIsReady = true;//设置标识符为true
//                for (String bufferedMessage : this.mBufferedMessages) {
//                    speakText(bufferedMessage);//读语音
//                }
                speakText(text);//读语音
                this.mBufferedMessages.clear();//读完后清空队列
            }
        }
    }

    //释放资源
    public void release() {
        synchronized (this) {
            this.mTextToSpeech.shutdown();
            this.mIsReady = false;
        }
    }

    //更新消息队列,或者读语音
    public void notifyNewMessage(String lanaugh) {
        String message = lanaugh;
        synchronized (this) {
            if (this.mIsReady) {
                speakText(message);
            } else {
                this.mBufferedMessages.add(message);
            }
        }
    }

    //读语音处理
    private void speakText(String message) {
        Log.i("BloodPressureBluetooth1", message);
        HashMap params = new HashMap();
        params.put(TextToSpeech.Engine.KEY_PARAM_STREAM, "STREAM_NOTIFICATION");//设置播放类型(音频流类型)
        this.mTextToSpeech.speak(message, TextToSpeech.QUEUE_ADD, params);//将这个发音任务添加当前任务之后
        this.mTextToSpeech.playSilence(100, TextToSpeech.QUEUE_ADD, params);//间隔多长时间
    }
}
Android实现语音识别可以使用Android提供的SpeechRecognizer类。下面是一个基本的示例代码: 1. 添加权限 在AndroidManifest.xml文件中添加以下权限: ```xml <uses-permission android:name="android.permission.RECORD_AUDIO" /> <uses-permission android:name="android.permission.INTERNET" /> ``` 2. 实现语音识别 在需要实现语音识别的Activity中,实例化SpeechRecognizer类,并调用startListening()方法开启语音识别: ```java public class MainActivity extends AppCompatActivity { private SpeechRecognizer speechRecognizer; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); speechRecognizer = SpeechRecognizer.createSpeechRecognizer(this); speechRecognizer.setRecognitionListener(new RecognitionListener() { @Override public void onReadyForSpeech(Bundle params) { } @Override public void onBeginningOfSpeech() { } @Override public void onRmsChanged(float rmsdB) { } @Override public void onBufferReceived(byte[] buffer) { } @Override public void onEndOfSpeech() { } @Override public void onError(int error) { } @Override public void onResults(Bundle results) { ArrayList<String> matches = results.getStringArrayList(SpeechRecognizer.RESULTS_RECOGNITION); if (matches != null) { String result = matches.get(0); Toast.makeText(MainActivity.this, result, Toast.LENGTH_SHORT).show(); } } @Override public void onPartialResults(Bundle partialResults) { } @Override public void onEvent(int eventType, Bundle params) { } }); Intent intent = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH); intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL, RecognizerIntent.LANGUAGE_MODEL_FREE_FORM); intent.putExtra(RecognizerIntent.EXTRA_LANGUAGE, Locale.getDefault()); intent.putExtra(RecognizerIntent.EXTRA_PROMPT, "Say something"); speechRecognizer.startListening(intent); } @Override protected void onDestroy() { super.onDestroy(); if (speechRecognizer != null) { speechRecognizer.destroy(); } } } ``` 在上面的代码中,我们首先实例化SpeechRecognizer类,并设置RecognitionListener监听器。在onResults()方法中,我们可以获取到语音识别的结果,并将其显示在Toast中。最后,我们使用Intent启动语音识别,并在startListening()方法中传入intent参数。 需要注意的是,在Activity销毁时,应该调用speechRecognizer.destroy()方法,以释放资源。 以上是一个基本的语音识别示例,你可以根据实际需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值