JavaScript 通过 WebView 调用 Android Text to Speech API

最近用JAVASCRIPT做了一个英汉译音词典,其中有个朗读单词的功能,在桌面端网页浏览器中可以使用语音合成类实现,JAVASCRIPT代码如下,但是由于想将应用提供给安卓应用用户使用,但是采用Android WebView和JavaScript混合编程时,所显示的网页应用无法直接发音,也无法直接调用类似桌面网页浏览器的TTS功能,所以只好写个接口调用Android的Text to Speech API。


这个是桌面浏览器使用的语音合成程序,该程序不能在安卓WebView内使用。

function speak(textToSpeak) {
    // 创建一个SpeechSynthesisUtterance实例
    var newUtterance = new SpeechSynthesisUtterance();
    // 设置要发音的内容
    newUtterance.text = textToSpeak;
    // 添加在发音队列中
    window.speechSynthesis.speak(newUtterance);
}

要在安卓系统中调用TTS,先写个类:

public class MyTtsTalker implements TextToSpeech.OnInitListener {

        private TextToSpeech tts;
        private boolean ttsOk;

        // The constructor will create a TextToSpeech instance.
        MyTtsTalker(Context context) {
            tts = new Te
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现网页通过 WebView 调用 Android 的图片或文件选择,可以使用以下步骤: 1.在 Android 代码中,为 WebView 设置 WebChromeClient,并重写 onShowFileChooser 方法。 2.在 onShowFileChooser 方法中,调用系统的文件选择器或图库,让用户选择要上传的文件或图片。 3.将用户选择的文件或图片返回给 WebView,并在 JavaScript 中处理上传操作。 下面是实现步骤的示例代码: 1.在 Android 代码中,为 WebView 设置 WebChromeClient,并重写 onShowFileChooser 方法。 ```java webView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { // 在这里调用系统的文件选择器或图库,让用户选择要上传的文件或图片 return true; } }); ``` 2.在 onShowFileChooser 方法中,调用系统的文件选择器或图库,让用户选择要上传的文件或图片。 ```java @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { Intent intent = fileChooserParams.createIntent(); try { startActivityForResult(intent, REQUEST_CODE_UPLOAD_FILE); } catch (ActivityNotFoundException e) { e.printStackTrace(); } } return true; } ``` 3.将用户选择的文件或图片返回给 WebView,并在 JavaScript 中处理上传操作。 ```java @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_CODE_UPLOAD_FILE && resultCode == RESULT_OK) { Uri[] uris = new Uri[1]; uris[0] = data.getData(); if (mFilePathCallback != null) { mFilePathCallback.onReceiveValue(uris); } } } ``` 在 JavaScript 中,可以通过监听 input[type=file] 的 change 事件,获取用户选择的文件或图片。 ```javascript var fileInput = document.createElement('input'); fileInput.type = 'file'; fileInput.onchange = function() { var file = fileInput.files[0]; // 处理上传操作 }; fileInput.click(); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值