在 webView 中从 JavaScript 调用 Android 共享意图

问题描述

我正在尝试使用本文的代码从 webView 中的 JavaScript 启动我的 Android 应用程序 (kotlin) 的共享意图。这是我用来启动的代码

class MainActivity : AppCompatActivity() {  object AndroidJSInterface {
    @JavascriptInterface
    fun onClicked() {
      Log.d("HelpButton","Help button clicked")
    }
  }  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)    val webViewClient = object : WebViewClient() {
      override fun onPageFinished(view: WebView,url: String) {
        loadJs(view)
      }
    }    val webView = WebView(this)
    webView.webViewClient = webViewClient
    webView.settings.javaScriptEnabled = true
    webView.addJavascriptInterface(AndroidJSInterface,"Android")    setContentView(webView)
    webView.loadUrl("https://vuetifyjs.com/en/getting-started/quick-start")
  }  private fun loadJs(webView: WebView) {
    webView.loadUrl(
      """javascript:(function f() {
        var btns = document.getElementsByTagName('button');
        for (var i = 0,n = btns.length; i < n; i++) {
          if (btns[i].getAttribute('aria-label') === 'Support') {
            btns[i].setAttribute('onclick','Android.onClicked()');
          }
        }
      })()"""
    )
  }
}

我像这样修改了AndroidJSInterface中的函数

    @JavascriptInterface
    fun shareUrl(url: String? = "") {
        Log.d("JavaScript","shareUrl: " + url)
        if( !url.isNullOrEmpty() )
        {
            val intent= Intent()
            intent.action=Intent.ACTION_SEND
            intent.putExtra(Intent.EXTRA_TEXT,url)
            intent.type="text/plain"
            startActivity(Intent.createChooser(intent,"Share To:"))
        }
    }

我遇到的问题是,此处无法识别 startActivity(我收到“未解析的引用:startActivity”)。如何从我的这部分代码访问 startActivity?

感谢您的帮助,

克里斯托夫

解决方法

public abstract void startActivity(@RequiresPermission Intent intent);

此方法最初在 Context 类中可用,然后在 ActivityContextWrapper 中可用,因为它们是 Context 类的子级。

AndroidJSInterface 是一个简单的对象,不是 Context 的直接或间接子对象,因此 startActivity 在该块中不被识别,因为该方法中的 this 指的是instance 属于 AndroidJSInterface 类型,它不是 Context 的子代。 所以要在 this 方法中引用 instanceMainActivityshareUrl

你可以这样做 在科特林

this@MainActivity.startActivity(Intent.createChooser(intent,"Share To:"))

或在 Java 中

MainActivity.this.startActivity(Intent.createChooser(intent,"Share To:"));
,

我找到了一个解决方案,虽然我不太明白为什么会这样:

我替换了:

@JavascriptInterface
fun shareUrl(url: String? = "") {
    Log.d("JavaScript","shareUrl: " + url)
    if( !url.isNullOrEmpty() )
    {
        val intent= Intent()
        intent.action=Intent.ACTION_SEND
        intent.putExtra(Intent.EXTRA_TEXT,url)
        intent.type="text/plain"
        startActivity(Intent.createChooser(intent,"Share To:"))
    }
}

作者:

private inner class JavascriptInterface
{
    @android.webkit.JavascriptInterface
    fun shareUrl(url: String? = "") {
        Log.d("JavaScript","shareUrl: " + url)
        // TODO: debug startActivity to launch Android sharing screen
        if( !url.isNullOrEmpty() )
        {
            val intent= Intent()
            intent.action=Intent.ACTION_SEND
            intent.putExtra(Intent.EXTRA_TEXT,url)
            intent.type="text/plain"
            this@WebActivity.startActivity(Intent.createChooser(intent,"Share To:"))
        }
    }
}