我们有一个场景,我们在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)
答案 0 :(得分:2)
我们可以使用以下代码在webview中获取与位置相关的弹出窗口: -
webView.setWebChromeClient(new WebChromeClient()
{
public void onGeolocationPermissionsShowPrompt(String origin, android.webkit.GeolocationPermissions.Callback callback) {
callback.invoke(origin, true, false);
}
});