我正在开发一个使用第三方 tts 的应用程序,名为 flite。我正在做类似 tts 说一句话的事情。我想突出显示每个单词。为此,我设法从 tts 获得了单词级别的回调。 工作流程是这样的——按下“说出文本”按钮。它启动了 tt s服务,然后将文本发送到C语言的flite tts,并与应用程序结合在一起。 现在,在 C 代码中,在每个单词之后我都会对两个不同的 Java Activity 进行两次回调: 一个到 tts 服务来说话 第二个是我的测试java activity来突出这个词。 我在我的测试 Activity 中成功获得了单词级别的回调,但之后我无法进行任何 UI 工作。
以下是我收到回调时执行的代码: 这是从 C 代码调用的函数。
private void WordCallback(int isword) {// from
// callback
if (isword == -1) {
Log.d(LOG_TAG, "its not a word");
} else if (isword == -2) {
Log.d(LOG_TAG, "yeah..its the end");
} else {
Log.d(LOG_TAG, "its word no " + isword);
int word = isword;
Log.d(LOG_TAG, "highlightwords");
highlightwords(isword);
if (isword == 4) {
Log.d(LOG_TAG, "in if");
new Thread(new Runnable() {
@Override
public void run() {
Log.d(LOG_TAG, "thread started");
try {
Flitetest.this.runOnUiThread(new Runnable() {
@Override
public void run() {
Log.d(LOG_TAG, "run on ui");
textview.setText("#" + isword);
}
});
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}
}
FliteTest 是 Activity 的名称。 日志打印到“线程启动”,但 runonuithread() 中的代码从未执行,也没有错误。
此外,如果在没有线程和 runonuithread() 的情况下编写 textview.settext("something")
,它会给出错误:
致命信号 11(sigsegv) 位于 0x6fc64e87(code=1),线程 20292(SynthThread)
。
这种行为的原因是什么?
最佳答案
在 Android ICS (4.0+)
上,如果您的 AndroidManifest.xml
中有 android:anyDensity=false
,并且 您已在 ICS 手机上强制启用 GPU 渲染。这也是 native Android 应用程序的问题。
您的选择是不使用 android:anyDensity=false
选项,或者禁用手机上的强制 GPU 渲染。由于您无法在其他人的手机上真正控制后者,因此前者似乎是最佳解决方案。请记住在所有维度
上使用“dp
”后缀。
关于android runonuithread() 函数不执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17525179/