2

我们有一个场景,我们在一个 android 应用程序的 webview 中打开一个 URL。问题是没有弹出窗口,就像它们出现在浏览器中一样。加载网页后,有一个按钮,单击该按钮时会在屏幕底部弹出“URL 想要访问位置”,并带有拒绝和允许按钮。此行为如浏览器中所述工作,但当在内部加载相同页面时Webview 没有弹出窗口,活动指示器一直在旋转。

在各种博客中看到这适用于自定义 webchrome 客户端。目前完成的实施如下:-

webview活动中的代码:-

onCreate -

 webView = (WebView) findViewById(R.id.webView_main);
    WebSettings webViewSettings = webView.getSettings();
    webViewSettings.setJavaScriptEnabled(true); // enable java script
    webViewSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    webViewSettings.setBuiltInZoomControls(true);
    webViewSettings.setLoadWithOverviewMode(true);
    webViewSettings.setUseWideViewPort(true);
    webView.setWebChromeClient(new CustomWebChromeClient());

    final String link = "URL to be accessed";
    webView.loadUrl(link);  

自定义 webchrome 客户端的实现是:-

final class CustomWebChromeClient extends WebChromeClient {

    public boolean shouldOverrideUrlLoading(WebView view, String url) {

        Log.i(TAG, "Processing webview url click...");
        if (progressbar.isShowing()) {

        } else {
            progressbar.show();
        }
        view.loadUrl(url);
        return true;
    }

    public void onPageFinished(WebView view, String url) {
        Log.i(TAG, "Finished loading URL: " + url);
        if (progressbar.isShowing()) {
            progressbar.dismiss();
        }

        if (webView.canGoBack()) {
            Log.i(TAG, "button enabled");
            // btnBack.setVisibility(View.VISIBLE);
            // itemBack.setVisible(true);
        } else {
            Log.i(TAG, "button disbaled");
            // btnBack.setVisibility(View.INVISIBLE);
            // itemBack.setVisible(false);
        }
    }

    public void onReceivedError(WebView view, int errorCode,
            String description, String failingUrl) {

        Log.e(TAG, "Error: " + description);
        Toast.makeText(DetailActivity.this, description,
                Toast.LENGTH_SHORT).show();

        if (progressbar.isShowing()) {
            progressbar.dismiss();
        }

        if (webView.canGoBack()) {
            Log.i(TAG, "button enabled");
            // btnBack.setVisibility(View.VISIBLE);
            // itemBack.setVisible(true);
        } else {
            Log.i(TAG, "button disbaled");
            // btnBack.setVisibility(View.INVISIBLE);
            // itemBack.setVisible(false);
        }

    }
    @Override
    public boolean onJsAlert(WebView view, String url, String message,
            JsResult result) {
        super.onJsAlert(view, url, message, result);

        final JsResult finalRes = result;
        new AlertDialog.Builder(view.getContext())
            .setMessage(message)
            .setPositiveButton(android.R.string.ok,
                    new AlertDialog.OnClickListener()
                    {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            finalRes.confirm();  
                        }
                    })
            .setCancelable(false)
            .create()
            .show();

        return true;
    }

    @Override
    public boolean onJsConfirm(WebView view, String url, String message,
            final JsResult result) {

        new AlertDialog.Builder(mContext)
                .setTitle("App Titler")
                .setMessage(message)
                .setPositiveButton(android.R.string.ok,
                        new DialogInterface.OnClickListener() {
                            public void onClick(DialogInterface dialog,
                                    int which) {
                                result.confirm();
                            }
                        })
                .setNegativeButton(android.R.string.cancel,
                        new DialogInterface.OnClickListener() {
                            public void onClick(DialogInterface dialog,
                                    int which) {
                                result.cancel();
                            }
                        }).create().show();

        return true;
    }

    @Override
    public boolean onJsPrompt(WebView view, String url, String message,
        String defaultValue, JsPromptResult result) {
    // TODO Auto-generated method stub
    System.out.println("JS prompt called"); 
    return super.onJsPrompt(view, url, message, defaultValue, result);
    }
}

有什么方法可以像在浏览器中一样在 webview 中具有相同的行为?这与android sdk版本有关吗?如果是,有什么解决方法吗?

PS :- 使用 android SDK 4.4.2 ( API 级别 - 19 )

4

1 回答 1

2

我们能够使用以下代码在 webview 中获取与位置相关的弹出窗口:-

webView.setWebChromeClient(new WebChromeClient()
        {
            public void onGeolocationPermissionsShowPrompt(String origin, android.webkit.GeolocationPermissions.Callback callback) {
                callback.invoke(origin, true, false);
            }
        });
于 2014-09-30T06:39:47.183 回答