Android 4.4.2(api level = 19)Webview问题

时间:2014-09-29 09:16:52

标签: android android-webview android-4.4-kitkat android-websettings

我们有一个场景,我们在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版本有关,若有,是否有任何解决方法?

P.S: - 使用android SDK 4.4.2(API级别 - 19)

1 个答案:

答案 0 :(得分:2)

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

webView.setWebChromeClient(new WebChromeClient()
        {
            public void onGeolocationPermissionsShowPrompt(String origin, android.webkit.GeolocationPermissions.Callback callback) {
                callback.invoke(origin, true, false);
            }
        });