当前位置:网站首页 > 更多 > 编程开发 > 正文

[安卓] Android webView打开网页

作者:CC下载站 日期:2020-10-15 00:00:00 浏览:47 分类:编程开发

这个就比较简单了,直接拖一个控件,再加载一下url,记得在AndroidManifest.xml中加一下权限

WebViewwebView=findViewById(R.id.web);
Stringurl="https://www.lanol.cn";
webView.loadUrl(url);
<uses-permissionandroid:name="android.permission.INTERNET"/>

还有下面的就是网上的一些文章,留以记录

Android WebView:https://www.jianshu.com/p/b6f2f1334053

生命周期:

  • onResume():活跃状态,可以正常执行网页的响应。

  • onPause():暂停状态,页面被失去焦点,暂停所有进行中的动作,如:DOM解析、CSS和JavaScript执行等。

  • pauseTimers():全局WebView暂停状态,如:layout、parsing、javascripttimer等。

  • resumeTimers():恢复到pauseTimers()执行前的状态。

  • destroy():销毁状态,释放资源。

  • 注意:使用WebView不当容易引起内存泄漏,所以WebView的生命周期方法应跟随Activity的生命周期的方法来调用。

WebSettings

  • 控件的相关配置

WebSettingswebSettings=webView.getSettings();webSettings.setJavaScriptEnabled(true);->是否开启JS支持
webSettings.setPluginsEnabled(true);->是否开启插件支持
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);->是否允许JS打开新窗口

webSettings.setUseWideViewPort(true);->缩放至屏幕大小
webSettings.setLoadWithOverviewMode(true);->缩放至屏幕大小
webSettings.setSupportZoom(true);->是否支持缩放
webSettings.setBuiltInZoomControls(true);->是否支持缩放变焦,前提是支持缩放
webSettings.setDisplayZoomControls(false);->是否隐藏缩放控件

webSettings.setAllowFileAccess(true);->是否允许访问文件
webSettings.setDomStorageEnabled(true);->是否节点缓存
webSettings.setDatabaseEnabled(true);->是否数据缓存
webSettings.setAppCacheEnabled(true);->是否应用缓存
webSettings.setAppCachePath(uri);->设置缓存路径

webSettings.setMediaPlaybackRequiresUserGesture(false);->是否要手势触发媒体
webSettings.setStandardFontFamily("sans-serif");->设置字体库格式
webSettings.setFixedFontFamily("monospace");->设置字体库格式
webSettings.setSansSerifFontFamily("sans-serif");->设置字体库格式
webSettings.setSerifFontFamily("sans-serif");->设置字体库格式
webSettings.setCursiveFontFamily("cursive");->设置字体库格式
webSettings.setFantasyFontFamily("fantasy");->设置字体库格式
webSettings.setTextZoom(100);->设置文本缩放的百分比
webSettings.setMinimumFontSize(8);->设置文本字体的最小值(1~72)webSettings.setDefaultFontSize(16);->设置文本字体默认的大小

webSettings.setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN);->按规则重新布局
webSettings.setLoadsImagesAutomatically(false);->是否自动加载图片
webSettings.setDefaultTextEncodingName("UTF-8");->设置编码格式
webSettings.setNeedInitialFocus(true);->是否需要获取焦点
webSettings.setGeolocationEnabled(false);->设置开启定位功能
webSettings.setBlockNetworkLoads(false);->是否从网络获取资源

WebViewClient

  • 控件客户端,用于处理各种通知和请求事件。

  • onPageStarted():页面开始加载时调用,这时候可以显示加载进度条,让用户耐心等待页面的加载。

  • onPageFinished():页面完成加载时调用,这时候可以隐藏加载进度条,提醒用户页面已经完成加载。

  • onLoadResource():页面每次加载资源时调用。

  • shouldOverrideUrlLoading():WebView加载url默认会调用系统的浏览器,通过重写该方法,实现在当前应用内完成页面加载。

  • onReceivedError():页面加载发生错误时调用,这时候可以跳转到自定义的错误提醒页面,总比系统默认的错误页面美观,优化用户体验。

  • onReceivedHttpError():页面加载请求时发生错误。

  • onReceivedSslError():页面加载资源时发生错误。

  • shouldOverrideKeyEvent():覆盖按键默认的响应事件,这时候可以根据自身的需求在点击某些按键时加入相应的逻辑。

  • onScaleChanged():页面的缩放比例发生变化时调用,这时候可以根据当前的缩放比例来重新调整WebView中显示的内容,如修改字体大小、图片大小等。

  • shouldInterceptRequest():可以根据请求携带的内容来判断是否需要拦截请求。

WebViewClientwebViewClient=newWebViewClient(){
@Override
publicvoidonPageStarted(WebViewview,Stringurl,Bitmapfavicon){

}

@Override
publicvoidonPageFinished(WebViewview,Stringurl){

}

@Override
publicbooleanonLoadResource(WebViewview,Stringurl){

}

@Override
publicbooleanshouldOverrideUrlLoading(WebViewview,Stringurl){
view.loadUrl(url);
returntrue;->消费事件终止传递}

@Override
publicvoidonReceivedError(WebViewview,interrorCode,
Stringdescription,StringfailingUrl){
view.loadUrl("file:///android_assets/error.html");->assets目录下放置文件}webView.setWebViewClient(webViewClient);

WebChromeClient

  • 浏览器客户端,用于处理网站图标、网站标题、网站弹窗等。

  • onProgressChanged():页面加载进度发生变化时调用,可以通过该方法实时向用户反馈加载情况,如显示进度条等。

  • onReceivedIcon():接收Web页面的图标,可以通过该方法把图标设置在原生的控件上,如Toolbar等。

  • onReceivedTitle():接收Web页面的标题,可以通过该方法把图标设置在原生的控件上,如Toolbar等。

  • onJsAlert():处理JS的Alert对话框。

  • onJsPrompt():处理JS的Prompt对话框。

  • onJsConfirm():处理JS的Confirm对话框。

  • onPermissionRequest():Web页面请求Android权限时调用。

  • onPermissionRequestCanceled():Web页面请求Android权限被取消时调用。

  • onShowFileChooser():Web页面上传文件时调用。

  • getVideoLoadingProgressView():自定义媒体文件播放加载时的进度条。

  • getDefaultVideoPoster():设置媒体文件默认的预览图。

  • onShowCustomView():媒体文件进入全屏时调用。

  • onHideCustomView():媒体文件退出全屏时调用。

WebChromeClientwebChromeClient=newWebChromeClient();

Android调用JS

  • 语法:webView.loadUrl("javascript:method()");

  • 在Web页面中定义两个Js方法,分别是有返回值和无返回值。

letname='';
functionsetter(name){
this.name=name;
}
functiongetter(){
returnthis.name;
}
  • 在Android中通过WebView调用Js方法

Stringsetter="javascript:setter('"+"wjx"+"');";
webView.loadUrl(setter);->调用有参无返回值的函数

webView.evaluateJavascript("getter()",newValueCallback<String>(){
@Override
publicvoidonReceiveValue(Strings){->调用无参有返回值的函数
System.out.println("mynameis"+s);
}});

七、Js调用Android

webView.addJavascriptInterface(this,"bridge");->建立通讯桥梁
webView.removeJavascriptInterface("bridge");->移除通讯桥梁
  • 在Android中定义一个方法,标记为Js接口

@JavascriptInterfacepublicvoidtoast(Stringtoast){
Toast.makeText(MainActivity.this,toast,Toast.LENGTH_SHORT).show();
}
  • 在Web页面中调用Android方法

functiontoast(toast){
javascript:bridge.toast(toast);->通过桥梁调用方法
window.bridge.toast(toast);->通过桥梁调用方法}

Android WebView基本使用:https://blog.csdn.net/lowprofile_coding/article/details/77928614

加载html四种方式

webView.loadUrl("https://pan.lanol.cn/");//加载url

webView.loadUrl("file:///android_asset/test.html");//加载asset文件夹下html

//方式3:加载手机sdcard上的html页面
webView.loadUrl("content://com.ansen.webview/sdcard/test.html");

//方式4使用webview显示html代码
webView.loadDataWithBaseURL(null,"<html><head><title>欢迎您</title></head>"+
"<body><h2>使用webview显示html代码</h2></body></html>","text/html","utf-8",null);

WebViewClient与WebChromeClient区别

使用WebView基本都会使用这两个类,那他们有哪些区别呢?

WebViewClient主要帮助WebView处理各种通知、请求事件的,有以下常用方法:
- onPageFinished 页面请求完成
- onPageStarted 页面开始加载
- shouldOverrideUrlLoading 拦截url
- onReceivedError 访问错误时回调,例如访问网页时报错404,在这个方法回调的时候可以加载错误页面。

WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等,有以下常用方法。
- onJsAlert webview不支持js的alert弹窗,需要自己监听然后通过dialog弹窗
- onReceivedTitle 获取网页标题
- onReceivedIcon 获取网页icon
- onProgressChanged 加载进度回调

简单使用

因为需要加载网页url,所以需要在AndroidManifest.xml中添加访问网络权限。

<uses-permissionandroid:name="android.permission.INTERNET"/>1

布局文件:activity_main.xml

<?xmlversion="1.0"encoding="utf-8"?>
<FrameLayoutxmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

<WebView
android:id="@+id/webview"
android:layout_width="match_parent"
android:layout_height="match_parent"/>

<ProgressBar
android:id="@+id/progressbar"
style="@android:style/Widget.ProgressBar.Horizontal"
android:layout_width="match_parent"
android:layout_height="3dip"
android:max="100"
android:progress="0"
android:visibility="gone"/>
</FrameLayout>

外层FrameLayout,里面有WebView跟ProgressBar,WebView的宽高匹配父类,ProgressBar横向进度条,高度3dip,按照FrameLayout布局规则,ProgressBar会覆盖在WebView之上,默认是隐藏不显示。

MainActivity.java

publicclassMainActivityextendsAppCompatActivity{
privateWebViewwebView;
privateProgressBarprogressBar;

@Override
protectedvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

progressBar=(ProgressBar)findViewById(R.id.progressbar);//进度条

webView=(WebView)findViewById(R.id.webview);
//webView.loadUrl("file:///android_asset/test.html");//加载asset文件夹下html
webView.loadUrl("http://139.196.35.30:8080/OkHttpTest/apppackage/test.html");//加载url

//使用webview显示html代码
//webView.loadDataWithBaseURL(null,"<html><head><title>欢迎您</title></head>"+
//"<body><h2>使用webview显示html代码</h2></body></html>","text/html","utf-8",null);

webView.addJavascriptInterface(this,"android");//添加js监听这样html就能调用客户端
webView.setWebChromeClient(webChromeClient);
webView.setWebViewClient(webViewClient);

WebSettingswebSettings=webView.getSettings();
webSettings.setJavaScriptEnabled(true);//允许使用js

/**
*LOAD_CACHE_ONLY:不使用网络,只读取本地缓存数据
*LOAD_DEFAULT:(默认)根据cache-control决定是否从网络上取数据。
*LOAD_NO_CACHE:不使用缓存,只从网络获取数据.
*LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
*/
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);//不使用缓存,只从网络获取数据.

//支持屏幕缩放
webSettings.setSupportZoom(true);
webSettings.setBuiltInZoomControls(true);

//不显示webview缩放按钮
//webSettings.setDisplayZoomControls(false);
}

//WebViewClient主要帮助WebView处理各种通知、请求事件
privateWebViewClientwebViewClient=newWebViewClient(){
@Override
publicvoidonPageFinished(WebViewview,Stringurl){//页面加载完成
progressBar.setVisibility(View.GONE);
}

@Override
publicvoidonPageStarted(WebViewview,Stringurl,Bitmapfavicon){//页面开始加载
progressBar.setVisibility(View.VISIBLE);
}

@Override
publicbooleanshouldOverrideUrlLoading(WebViewview,Stringurl){
Log.i("ansen","拦截url:"+url);
if(url.equals("http://www.google.com/")){
Toast.makeText(MainActivity.this,"国内不能访问google,拦截该url",Toast.LENGTH_LONG).show();
returntrue;//表示我已经处理过了
}
returnsuper.shouldOverrideUrlLoading(view,url);
}

};

//WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等
privateWebChromeClientwebChromeClient=newWebChromeClient(){
//不支持js的alert弹窗,需要自己监听然后通过dialog弹窗
@Override
publicbooleanonJsAlert(WebViewwebView,Stringurl,Stringmessage,JsResultresult){
AlertDialog.BuilderlocalBuilder=newAlertDialog.Builder(webView.getContext());
localBuilder.setMessage(message).setPositiveButton("确定",null);
localBuilder.setCancelable(false);
localBuilder.create().show();

//注意:
//必须要这一句代码:result.confirm()表示:
//处理结果为确定状态同时唤醒WebCore线程
//否则不能继续点击按钮
result.confirm();
returntrue;
}

//获取网页标题
@Override
publicvoidonReceivedTitle(WebViewview,Stringtitle){
super.onReceivedTitle(view,title);
Log.i("ansen","网页标题:"+title);
}

//加载进度回调
@Override
publicvoidonProgressChanged(WebViewview,intnewProgress){
progressBar.setProgress(newProgress);
}
};

@Override
publicbooleanonKeyDown(intkeyCode,KeyEventevent){
Log.i("ansen","是否有上一个页面:"+webView.canGoBack());
if(webView.canGoBack()&&keyCode==KeyEvent.KEYCODE_BACK){//点击返回按钮的时候判断有没有上一页
webView.goBack();//goBack()表示返回webView的上一页面
returntrue;
}
returnsuper.onKeyDown(keyCode,event);
}

/**
*JS调用android的方法
*@paramstr
*@return
*/
@JavascriptInterface//仍然必不可少
publicvoidgetClient(Stringstr){
Log.i("ansen","html调用客户端:"+str);
}

@Override
protectedvoidonDestroy(){
super.onDestroy();

//释放资源
webView.destroy();
webView=null;
}
}
  • onCreate 查找控件,给webView设置加载url,添加js监听,监听的名称是”android”,设置webChromeClient跟webViewClient回调,通过getSettings方法获取WebSettings对象,设置允许加载js,设置缓存模式,支持缩放。

  • webViewClient 重写了几个方法,onPageFinished页面加载完成隐藏进度条,onPageStarted页面开始加载显示进度条,shouldOverrideUrlLoading拦截url,如果请求url是打开google,不让他请求,因为google在国内不能访问,就算请求也请求不到还不如拦截掉,直接告诉用户不能访问。

  • webChromeClient onJsAlert()因为WebView不支持alert弹窗,在这个方法中用AlertDialog去弹窗。onReceivedTitle获取网页标题。onProgressChanged页面加载进度,把加载进度给progressBar。

  • onKeyDown 如果点击系统自带返回键&&webView有上一级页面,调用goBack返回。否则不处理。什么时候辉有上一级页面呢?就是你从首页跳转到了一个新页面,点击返回的时候会返回首页。如果本来就在首页点击返回的时候会退出app。

  • getClient html页面的JS可以通过这个方法回调原生APP,[email protected],这个是必须的,这个方法有个字符串参数,这个方法跟我们在onCreate中调用addJavascriptInterface传入的name一起使用的。例如html中想要回调这个方法可以这样写:javascript:android.getClient(“传一个字符串给客户端”);

  • onDestroy activity销毁时释放webView资源。


您需要 登录账户 后才能发表评论

取消回复欢迎 发表评论:

关灯