webView

package com.example.day09_webview;


import android.annotation.SuppressLint;
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.KeyEvent;
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.Toast;


public class MainActivity extends Activity {


private WebView webView;


@SuppressLint("NewApi")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);


webView = (WebView) findViewById(R.id.webView);


// 设置webView状态信息
WebSettings settings = webView.getSettings();
// 设置webVIew是否支持js
settings.setJavaScriptEnabled(true);
// 设置webView打开自带的放缩按钮
settings.setBuiltInZoomControls(true);
settings.setSupportZoom(true);


setWebView();


}


// 点击按钮,webView展示网页
public void button(View v) {
String url = "http://www.sohu.com/";
// 访问assets文件夹的html页面
// String url = "file:///android_asset/jstest.html";


// url="<html><title>1409A</title><body><table><tr><td>用户名</td><td><input type='text' name='username'/></td></tr></table></body></html>";


webView.loadUrl(url);
// 加载本地的html代码
// webView.loadDataWithBaseURL("about:blank", url, "text/html", "utf-8",
// null);


// 设置浏览器的处理类,主要处理js的弹出框
webView.setWebChromeClient(new WebChromeClient() {


@Override
// 返回true,客户端处理警告对话框
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);


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
// js的确认框
public boolean onJsConfirm(WebView view, String url,
String message, JsResult result) {
// TODO Auto-generated method stub
return super.onJsConfirm(view, url, message, result);
}


// js的对话框
@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);
}


});
}


/**

*/
private void setWebView() {


// 设置web加载页面的方法
webView.setWebViewClient(new WebViewClient() {


@Override
// 页面开始加载
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);


System.out.println("页面开始加载" + url);
}


@Override
// 页面已完成加载。
public void onPageFinished(WebView view, String url) {
// TODO Auto-generated method stub
super.onPageFinished(view, url);
System.out.println("页面已完成加载。" + url);
}


@Override
// 返回false,当前url交给当前webView处理
public boolean shouldOverrideUrlLoading(WebView view, String url) {
// TODO Auto-generated method stub
return false;
}


});
}



/*//专门监听返回键的方法
@Override
public void onBackPressed() {

super.onBackPressed();
}*/


long exitTime;


@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {



// 如果当前webView可以返回上一页 
if (keyCode == KeyEvent.KEYCODE_BACK &&
webView.canGoBack()) 
{ // webVIew返回上一页 
 
webView.goBack(); 
return true;
}
/* if (keyCode == KeyEvent.KEYCODE_BACK) {
System.out.println(System.currentTimeMillis());
if ((System.currentTimeMillis() - exitTime) > 2000) {


Toast.makeText(MainActivity.this, "再按一次退出程序", 0).show();

exitTime = System.currentTimeMillis();
} else {


System.exit(0);
}
return true;


}*/


return super.onKeyDown(keyCode, event);
}


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值