12

我尝试捕捉 webview longclicks 以显示上下文菜单。(见下面的代码)当长按图像时,我总是得到额外的图像 URL(对于带有 IMAGE_TYPE 的未链接图像和带有 SRC_IMAGE_ANCHOR_TYPE 的链接图像)。但是如何获取带有超链接的图像的链接 URL(而不是图像 URL)?

最好的,塞巴斯蒂安

        mywebview.setOnLongClickListener(new OnLongClickListener() {
            public boolean onLongClick(View v) {

                final WebView webview = (WebView) v;
                final WebView.HitTestResult result = webview.getHitTestResult();

                if (result.getType() == SRC_ANCHOR_TYPE) {
                    return true;
                }

                if (result.getType() == SRC_IMAGE_ANCHOR_TYPE) {
                    return true;
                }

                if (result.getType() == IMAGE_TYPE) {
                    return true;
                }

                return false;
            }
        });
4

5 回答 5

22

以上解决方案均不适用于 Android 4.2.2。所以我查看了默认 android web 浏览器的源代码。我为这个确切的问题提取了解决方案 - 从图像链接中获取链接 URL。

来源: https ://github.com/android/platform_packages_apps_browser/blob/master/src/com/android/browser/Controller.java

提取解决方案:

LongClick 监听器:

...
mWebview.setOnLongClickListener(new OnLongClickListener() {

    @Override
    public boolean onLongClick(View v) {
        HitTestResult result = mWebview.getHitTestResult();
        if (result.getType() == HitTestResult.SRC_IMAGE_ANCHOR_TYPE) {
            Message msg = mHandler.obtainMessage();
            mWebview.requestFocusNodeHref(msg);
        }
    }
});
...

获取 URL 的处理程序:

private Handler mHandler = new Handler() {

    @Override
        public void handleMessage(Message msg) {
            // Get link-URL.
            String url = (String) msg.getData().get("url");

            // Do something with it.
            if (url != null) ...
        }
    };
于 2013-07-26T12:49:27.780 回答
9

我知道这是一个老问题,但我最近遇到了这个问题。基于Perry_ml的回答,我使用以下 Kotlin 代码来解决它:

webView.setOnLongClickListener {
    val result = webView.hitTestResult
    if (result.type == WebView.HitTestResult.SRC_IMAGE_ANCHOR_TYPE) {
        val handler = Handler()
        val message = handler.obtainMessage()

        webView.requestFocusNodeHref(message)
        val url = message.data.getString("url")

        // Do something with url, return true as touch has been handled
        true
    } else {
        false
    }
}

我在这里发布了一些关于它的信息。

于 2019-03-22T12:39:17.620 回答
6

我检查了 WebView 的源代码,似乎图像 uri 是您可以获得的 SRC_IMAGE_ANCHOR_TYPE 的唯一额外数据。但是不要在这里生气,我有一个快速而肮脏的解决方法给你:

    webview.setOnLongClickListener(new OnLongClickListener() {
        @Override
        public boolean onLongClick(View v) {
            final WebView webview = (WebView) v;
            final HitTestResult result = webview.getHitTestResult();
            if(result.getType()==HitTestResult.SRC_IMAGE_ANCHOR_TYPE) {
                webview.setWebViewClient(new WebViewClient(){
                    @Override
                    public boolean shouldOverrideUrlLoading(WebView view, String url) {
                        // 2. and here we get the url (remember to remove the WebView client and return true so that the hyperlink will not be really triggered)
                        mUrl = url; // mUrl is a member variant of the activity
                        view.setWebViewClient(null);
                        return true;
                    }
                });
                // 1. the picture must be focused, so we simulate a DPAD enter event to trigger the hyperlink
                KeyEvent event1 = new KeyEvent(KeyEvent.ACTION_DOWN, KeyEvent.KEYCODE_DPAD_CENTER);
                webview.dispatchKeyEvent(event1);
                KeyEvent event2 = new KeyEvent(KeyEvent.ACTION_UP, KeyEvent.KEYCODE_DPAD_CENTER);
                webview.dispatchKeyEvent(event2);
                // 3. now you can do something with the anchor url (and then clear the mUrl for future usage)
                String url = mUrl;
                if (url!=null) {
                    Toast.makeText(webview.getContext(), url, Toast.LENGTH_SHORT).show();
                }

                mUrl = null;
            }
            return false;
        }
    });

我在低端 Android 2.1 设备和高端 Android 4.0 设备上尝试了该代码,两者都像魅力一样工作。

问候

陈子腾

于 2012-08-29T10:10:23.803 回答
1

Ziteng Chen 解决方案适用于 Android 4.0(API 级别 15),但由于某种原因,KeyEvent down & up 在 API LEVEL 16+(Android 4.1+ JELLY_BEAN)中不起作用。它不会触发 WebView 的 loadUrl。所以我不得不用dispatchTouchEvent替换dispatchKeyEvent。这是代码:

...
MotionEvent touchDown = MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_DOWN, touchX, touchY, 0);
webView.dispatchTouchEvent(touchDown);
touchDown.recycle();

MotionEvent touchUp = MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_UP, touchX, touchY, 0);
webView.dispatchTouchEvent(touchUp);
touchUp.recycle();

String url = mUrl;
...

您可能必须等待(使用 AsyncTask)才能在较慢的设备中获取 mUrl,在触发 dispatchTouchEvents 后它立即为空

希望能帮助到你。

于 2013-06-30T08:00:41.407 回答
-1

不要调用这个函数myWebView.requestFocusNodeHref(msg);,而是尝试调用这个函数myWebView.requestImageRef(msg);

于 2014-10-02T20:58:34.570 回答