package com.example.day09_webview;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.View;
import android.webkit.JsPromptResult;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity implements android.view.View.OnClickListener{
//获得控件
WebView webView;
Button btn;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn = (Button) findViewById(R.id.button1);
webView = (WebView) findViewById(R.id.webView1);
// 设置webview
initWebView();
// 设置监听
btn.setOnClickListener(this);
}
private void initWebView() {
// 1,设置webview的支持类型
WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);//是否支持jsp
settings.setBuiltInZoomControls(true);//是否支持缩放功能 内置缩放控制
settings.setSupportZoom(true);// 是否直至缩放
// 2,设置加载页面的方法
webView.setWebViewClient(new WebViewClient(){
// 页面开始加载
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
System.out.println("页面开始加载");
super.onPageStarted(view, url, favicon);
}
// 页面结束加载
@Override
public void onPageFinished(WebView view, String url) {
System.out.println("页面结束加载");
super.onPageFinished(view, url);
}
// 设置是否需要调用自带浏览器 true调用,false用webview
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
// return super.shouldOverrideUrlLoading(view, url);//原有信息
return false;
}
});
}
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.button1:
// 点击开始加载页面
// 访问assets文件夹的html页面
String url = "file:///android_asset/jstest.html";
webView.loadUrl(url);
// 弹窗的处理方式
webView.setWebChromeClient(new WebChromeClient(){
//返回true,客户端处理警告对话框
@Override
public boolean onJsAlert(WebView view, String url,
String message, final JsResult result) {
Toast.makeText(MainActivity.this, " " + message, 0).show();
// 自行设置对话框
AlertDialog.Builder builder=new Builder(MainActivity.this);
builder.setMessage(message);
// 注意这里的onClickListener的包
builder.setNegativeButton("确定", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
result.confirm();
}
});
builder.setPositiveButton("取消", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
result.cancel();
}
});
builder.show();
return true;
}
@Override
public boolean onJsConfirm(WebView view, String url,
String message, JsResult result) {
// TODO Auto-generated method stub
return super.onJsConfirm(view, url, message, result);
}
@Override
public boolean onJsPrompt(WebView view, String url,
String message, String defaultValue,
JsPromptResult result) {
// TODO Auto-generated method stub
return super.onJsPrompt(view, url, message, defaultValue, result);
}
});
break;
default:
break;
}
}
}
WebView使用(设置解析方法和弹窗应对)
最新推荐文章于 2023-10-12 14:14:39 发布