[安卓] Android webView打开网页
作者:CC下载站 日期:2020-10-15 00:00:00 浏览:62 分类:编程开发
这个就比较简单了,直接拖一个控件,再加载一下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资源。
- 上一篇:[国剧]《重启之极海听雷 第二季》全集
- 下一篇:[美剧]《异星灾变》第一季全
猜你还喜欢
- 03-29 [编程相关] Winform窗体圆角以及描边完美解决方案
- 03-29 [前端问题] has been blocked by CORS policy跨域问题解决
- 03-29 [编程相关] GitHub Actions 入门教程
- 03-29 [编程探讨] CSS Grid 网格布局教程
- 10-12 [编程相关] python实现文件夹所有文件编码从GBK转为UTF8
- 10-11 [编程算法] opencv之霍夫变换:圆
- 10-11 [编程算法] OpenCV Camshift算法+目标跟踪源码
- 10-11 [Python] python 创建 Telnet 客户端
- 10-11 [编程相关] Python 基于 Yolov8 + CPU 实现物体检测
- 03-15 [脚本工具] 使用go语言开发自动化脚本 - 一键定场、抢购、预约、捡漏
- 01-08 [编程技术] 秒杀面试官系列 - Redis zset底层是怎么实现的
- 01-05 [编程技术] 《Redis设计与实现》pdf
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[动画] 迪士尼系列动画139部 国英双语音轨 【蓝光珍藏版440GB】
[电影] 莫妮卡贝鲁奇为艺术献身电影大合集 1080P超清 双语字幕
[电影] DC电影宇宙系列合集18部 4K 高码率 内嵌中英字幕 273G
[音乐] 【坤曲/4坤时】鸡你太美全网最全,385首小黑子战歌,黄昏见证虔诚的信徒,巅峰诞生虚伪的拥护!
[音乐] 用餐背景音乐大合集 [MP3/flac]
[书籍] 彭子益医书合集 [PDF/DOC]
[电影] 《环太平洋两部合集》 4K REMUX原盘 [杜比视界] 国英双语音轨 [内封特效字幕] [133.8G]
[电影] 异人之下 The Traveller 2024✨【影版】【4K正式版/HQ超高码/DDP5.1】✚【1080高码】无水印/无压缩
[动漫] 头文字D 动漫 (1998) S01-S06季 1080P 国粤日音轨 续作 剧场版 电影
[小说] 知轩藏书全站7667册txt小说合集精心校对版
[书籍] 彭子益医书合集 [PDF/DOC]
[游戏] 《黑神话悟空》免安装学习版【全dlc整合完整版】+Steam游戏解锁+游戏修改工具!
[动画] 《名侦探柯南》名侦探柯南百万美元的五菱星 [TC] [MP4]
[电视剧集] [BT下载][黑暗城市- 清扫魔 Dark City: The Cleaner 第一季][全06集][英语无字][MKV][720P/1080P][WEB-RAW]
[涨点姿势] 男性性技宝典:14招实战驭女术——爱抚、按摩、催情、姿势、高潮全攻略
[动画] 2002《火影忍者》720集全【4K典藏版】+11部剧场版+OVA+漫画 内嵌简日字幕
[剧集] 《斯巴达克斯》1-4季合集 无删减版 1080P 内嵌简英特效字幕
[CG剧情] 《黑神话:悟空》158分钟CG完整剧情合集 4K120帧最高画质
[短剧] 被下架·禁播的羞羞短剧·午夜短剧合集
[游戏] 黑神话悟空离线完整版+修改器
[影视] 美国内战 4K蓝光原盘下载+高清MKV版/内战/帝国浩劫:美国内战(台)/美帝崩裂(港) 2024 Civil War 63.86G
[影视] 一命 3D 蓝光高清MKV版/切腹 / 切腹:武士之死 / Hara-Kiri: Death of a Samurai / Ichimei 2011 一命 13.6G
[影视] 爱情我你他 蓝光原盘下载+高清MKV版/你、我、他她他 2005 Me and You and Everyone We Know 23.2G
[影视] 穿越美国 蓝光原盘下载+高清MKV版/窈窕老爸 / 寻找他妈…的故事 2005 Transamerica 20.8G
[电影] 《黄飞鸿》全系列合集
[Android] 开罗游戏 ▎像素风格的模拟经营的游戏厂商安卓游戏大合集
[游戏合集] 要战便战 v0.9.107 免安装绿色中文版
[书籍] 彭子益医书合集 [PDF/DOC]
[资源] 精整2023年知识星球付费文合集136篇【PDF格式】
[系统]【黑果小兵】macOS Big Sur 11.0.1 20B50 正式版 with Clover 5126 黑苹果系统镜像下载
- 最新评论
-
有靳东!嘻嘻奥古斯都.凯撒 评论于:10-28 流星花园是F4处女作也是4人集体搭配的唯一一部!奥古斯都.凯撒 评论于:10-28 找了好久的资源,终于在这里找到了。感谢本站的资源和分享。谢谢AAAAA 评论于:10-26 找了好久的资源,终于在这里找到了。感谢本站的资源和分享。谢谢password63 评论于:10-26 找了好久的资源,终于在这里找齐了!!!!blog001 评论于:10-21 找了好久的资源,终于在这里找齐了!!!!blog001 评论于:10-21 找了好久的资源,终于在这里找到了。感谢本站的资源和分享。谢谢WillKwok 评论于:10-09 感谢分享1234123 评论于:10-07 太好了终于找到了谢谢Tom 评论于:10-07 谢谢分享loonghd 评论于:09-30
- 热门tag