- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
public boolean playing=false;
private void prepareTTSEngine() {
try {
synthesis = SpeechSynthesis.getInstance(this);
synthesis.setSpeechSynthesisEvent(new SpeechSynthesisEvent() {
public void onPlaySuccessful() {
Log.i(TAG, "onPlaySuccessful");
playing=true;
}
public void onPlayStopped() {
Log.i(TAG, "onPlayStopped");
playing=false;
}
public void onPlayFailed(Exception e) {
Log.e(TAG, "onPlayFailed");
e.printStackTrace();
playing=false;
}
public void onPlayStart() {
Log.i(TAG, "onPlayStart");
//playing=true;
}
@Override
public void onPlayCanceled() {
Log.i(TAG, "onPlayCanceled");
playing=false;
}
});
//synthesis.setVoiceType("usenglishfemale1"); // All the values available to you can be found in the developer portal under your account
} catch (InvalidApiKeyException e) {
Log.e(TAG, "Invalid API key\n" + e.getStackTrace());
Toast.makeText(_context, "ERROR: Invalid API key", Toast.LENGTH_LONG).show();
}
}
prepareTTSEngine();
String speech= MapLocationOverlay.mSelectedMapLocation.getShortDesc();
synthesis.setVoiceType("usenglishfemale");
BreakIterator iterator = BreakIterator.getSentenceInstance(Locale.US);
iterator.setText(speech);
int start = iterator.first();
for (int end = iterator.next();end != BreakIterator.DONE; start = end, end = iterator.next()) {
if(speech !=null && speech.substring(start,end).compareTo("")!=0)
{
String sentence_next=speech.substring(start,end);
//set ready flag to true (so isReady returns true)
while(playing==true)
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
synthesis.speak(sentence_next);
} catch (BusyException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoNetworkException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
enter code here
}
}
}
I'm using [the iSpeech library's
语音合成 class](http://www.ispeech.org/androidsdkdoc/com/ispeech/SpeechSynthesis.html). When I call the
说话 method in a
for`循环,一次传递一个句子,所有句子同时开始。我想这是因为该方法是非阻塞的。它不是开源的,所以我看不到它是如何工作的。我怎样才能让它在前一句话完成之前不开始一个句子?
最佳答案
通常对于这些类型的库,代码不会等待声音停止播放(有充分的理由)。
来自documentation of your library ,看来您应该在阅读下一句之前用 PLAY_SUCCESSFUL
监听 SpeechSynthesisEvent
。
如果它适合您的需求,javax.speech.synthesis
有一个相当简单的机制来等待演讲完成,请查看:http://java.sun.com/products/java-media/speech/forDevelopers/jsapi-guide/Synthesis.html
关于java - 如何阻止 SpeechSynthesis.speak(String) ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9750455/
我有一个在for循环中涉及System.speech程序集的代码,但是从我所看到的来看,抛出给我的错误非常奇怪。 我有一个代码,该代码生成10个随机字母和/或数字,然后将它们存储在一个数组中,该数组将
我有以下正则表达式: /(?<=\w\sspeaks\s)(?!,|\s|\.)([\w]+)/gmi 字符串是: Example Person speaks ExampleLanguage1, Ex
我正在使用一个简单的代码来使用文本转语音: package ch.yourclick.kitt.fragments; import android.os.Bundle; import androidx
我尝试用 javascript 实现一个小网页,允许从两个 mp3 之间的文本播放 specchsynthesis 部分。 至于无论出于何种原因,口语部分的 onend 语句不起作用,我想创建一个递归
我最近一直在玩 SPEAK 对话。到目前为止,我喜欢它,但偶然发现了一个问题。我在 url 参数中传递了一个 itemID,我想在列表控件中显示该项目的子项。 我的方法是创建一个 SearchData
我目前正在使用 speak.js:http://www.syntensity.com/static/espeak.html 显然脚本只允许执行一个语音命令,如果我这样做的话: speak("1");
我写了这个应用程序,实际上我想提供说话功能。但是在添加这个之后,要说的文字就不起作用了。我在 speech.speak(text, TextToSpeech.QUEUE_FLUSH, null); 处
我正在学习使用 eclipse 和 ADT 插件在 Android 上开发应用。 根据android SDK 文档中的这篇文章http://androidappdocs.appspot.com/res
我们将 speak.js 库用于文本到语音的目的。我们需要在这方面实现本地化的女声。我们将其说话功能称为 meSpeak.speak('Hello Thomas"); 但我们无法使其以女声运行。我们观
我正在尝试构建 Super Mario Bros. 第一关的克隆,但我在让我的类(class)相互“交谈”时遇到了一些麻烦。截至目前,我有两个 Controller 类(键盘、游戏 handle )和
我迷路了。我希望能够调节说话音量。无论我做什么,我都无法增加它的音量。如何将其设置为与 Android 设置中的声音一样大(如下所示)? 系统设置 -> 语音输入和输出 -> 文字转语音设置 -> 听
我有一个单页网站,想实现以下目标: 后退按钮就像普通网站一样工作 而不是说, www.mysite.com/index.php?p=#this-is-a-great-product 我想要这个网址 w
我有一个使用 Microsoft.Speech for TTS 的应用程序。如果流在完成之前被 d/c'ed,我的 TTS 就会出现问题。 public void SpeakTest() { Pr
我找了又找,没有结果。至少从我发现的情况来看,没有关于此 API 的明确文档。我想创建一个自定义对象,它可以保存此函数的属性并能够运行它 console.log(window.speechSynthe
我在提交 Android Auto 应用时收到以下反馈: Your app does not support all of the required voice commands. Volume do
我正在尝试编写我的第一个简单的 Sitecore Speak 组件。 没什么特别的,我只需要开始。因此,我在 Visual Studio 中创建了 Speak 组件,并在 Sitecore 中创建了指
public boolean playing=false; private void prepareTTSEngine() { try { synthesi
我自己找不到问题!感谢您的帮助,当我将空结构传递给 getPets() 这是一个接口(interface)接收器时,我期待结构返回的空引用,但我得到了这个错误 **dog 没有实现宠物(说话的类型错误
我正在尝试复制此 video series 中显示的内容通过雅各布: 除自定义 Javascript 部分外,我能够使所有内容正常工作。 define(["sitecore"], function (
这就是我想要的: var elite = document.getElementById("elite"), leet = document.getElementById("leet"), a
我是一名优秀的程序员,十分优秀!