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);
}


}
利用 TensorFlow 训练自己的目标识别器。本文内容来自于我的毕业设计,基于 TensorFlow 1.15.0,其他 TensorFlow 版本运行可能存在问题。.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值