在实际开发中经常会使用WebView加载一些服务器上或本地的web页,现在大大小小的app多多少少都会用到WebView,所以在以后的app 开发中WebView的使用会越来越多,下面就介绍一下在开发中可能会用的WebView功能的实现。
注:WebView 中Java与JS交互在下一篇Android基础——WebView使用(二)Java与JS交互 中进行了介绍。
获取WebSettings
WebSettings webSettings = mWebView.getSettings();
setJavaScriptEnabled(true); //支持js
setPluginsEnabled(true); //支持插件
setUseWideViewPort(false); //将图片调整到适合webview的大小
setSupportZoom(true); //支持缩放
setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局
supportMultipleWindows(); //多窗口
setCacheMode(WebSettings.LOADCACHEELSE_NETWORK); //关闭webview中缓存
setAllowFileAccess(true); //设置可以访问文件
setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点
webview webSettings.setBuiltInZoomControls(true); //设置支持缩放
setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
setLoadWithOverviewMode(true); // 缩放至屏幕的大小
setLoadsImagesAutomatically(true); //支持自动加载图片
rootLayout.removeView(webView);webView.destroy();
WebView 事件回调,有两个 setWebViewClient(WebViewClient client)和 setWebViewClient (WebViewClient client) 。
setWebViewClient(WebViewClient client)
//主要通知客户端app加载当前网页时的各种时机状态,onPageStart,onPageFinish,onReceiveError等事件。
常用方法
1、 onPageStarted(WebView view, String url, Bitmap favicon)
该方法在加载Web页面开始时调用
参数说明:
view: 该view可以获取title , URL 等,里面方法很多,在开发时候自己看吧。
url : 网络请求的url。
favicon : 加载网页的logo 图片的bitmap.2、 shouldOverrideUrlLoading(WebView view, String url)
对网页中超链接按钮的响应,在该方法中调用view.loadUrl(url); 即在当前的webview中跳转到新的url。
参数说明:
view: 同上
url : 网络请求的url。3、 onPageFinished(WebView view, String url)
web 页面加载结束后调用该方法
参数说明:
view: 同上
url : 网络请求的url。实例代码
mWebView.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView view, int newProgress) { mProgressBar.setProgress(newProgress); } @Override public void onReceivedTitle(WebView view, String title) { } });
setWebChromeClient (WebChromeClient client)
//主要通知客户端app加载当前网页的 title,Favicon,progress,javascript dialog等事件,通知客户端处理这些相应的事件。
常用方法
1、onProgressChanged(WebView view, int newProgress)
改方法在加载web页的同时被调用,加载完成停止调用,在该方法中一般多是设置web页面加载的进度条,progressBar 的进度。参数newProgress 的范围在 0 到 100。
2、onReceivedTitle(WebView view, String title)
重新获取title,参数不再解释,都是一样的。
注意:在小米3的手机上,当通过webview.goBack()回退的时候,并没有触发onReceiveTitle(),这样会导致标题仍然是之前子页面的标题,没有切换回来.
实例代码
mWebView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { mImageView.setImageBitmap(favicon); Log.e("PageStarted", "url--->" + url); Log.e("PageStarted", "view--getTitle->" + view.getTitle()); Log.e("PageStarted", "view--->" + view.getUrl()); } @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { mWebView.loadUrl(url); Log.e("OverrideUrlLoad", "url--->" + url); Log.e("OverrideUrlLoad", "view--getTitle->" + view.getTitle()); Log.e("OverrideUrlLoad", "view--->" + view.getUrl()); return true; } @Override public void onPageFinished(WebView view, String url) { Log.e("PageFinished", "url--->" + url); Log.e("PageFinished", "view--getTitle->" + view.getTitle()); Log.e("PageFinished", "view--->" + view.getUrl()); } });
setOnLongClickListener(@Nullable OnLongClickListener l) //长按屏幕事件,return false 时长按时会出现复制功能,return true 时长按时不会出现复制
实例代码:
/** * 长按屏幕事件,return false 时长按时会出现复制功能,return true 时长按时不会出现复制 */ mWebView.setOnLongClickListener(new View.OnLongClickListener() { @Override public boolean onLongClick(View v) { return false; } });
按返回键时, 不退出程序而是返回上一浏览页面:
public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) { mWebView.goBack(); return true; } return super.onKeyDown(keyCode, event); }
打开页面时,自适应屏幕:
WebSettings webSettings = mWebView.getSettings(); webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放 webSettings.setLoadWithOverviewMode(true);
便页面支持缩放:
WebSettings webSettings = mWebView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setBuiltInZoomControls(true); webSettings.setSupportZoom(true);
如果webView中需要用户手动输入用户名、密码或其他,则webview必须设置支持获取手势焦点。
mWebView.requestFocusFromTouch();
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <RelativeLayout android:layout_width="match_parent" android:layout_height="50dp"> <Button android:text="Back" android:id="@+id/back_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <ImageView android:src="@mipmap/ic_launcher" android:layout_centerHorizontal="true" android:id="@+id/icon_img" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <Button android:layout_alignParentRight="true" android:text="Next" android:id="@+id/next_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </RelativeLayout> <ProgressBar style="?android:attr/progressBarStyleHorizontal" android:id="@+id/webview_pro_bar" android:layout_width="match_parent" android:layout_height="wrap_content" /> <WebView android:id="@+id/my_webview" android:layout_width="match_parent" android:layout_height="match_parent"/> </LinearLayout>
public class MyWebViewActivity extends Activity implements View.OnClickListener { private ProgressBar mProgressBar; private WebView mWebView; private ImageView mImageView; private Button mBtnBack, mBtnNext; private String url; private boolean flag_get_deviceid = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_webview); Intent intent = getIntent(); url = intent.getStringExtra("url"); initView(); } private void initView() { mProgressBar = (ProgressBar) findViewById(R.id.webview_pro_bar); mProgressBar.setMax(100); mBtnBack = (Button) findViewById(R.id.back_btn); mBtnNext = (Button) findViewById(R.id.next_btn); mBtnBack.setOnClickListener(this); mBtnNext.setOnClickListener(this); mImageView = (ImageView) findViewById(R.id.icon_img); mWebView = (WebView) findViewById(R.id.my_webview); mWebView.loadUrl(url); //获取手势焦点 mWebView.requestFocusFromTouch(); /** *对webView的设置要先调用getSettings()方法获取WebSettings */ WebSettings webSettings = mWebView.getSettings(); webSettings.setJavaScriptEnabled(true);//设置JavaScript可用,false 不可用 webSettings.setSupportZoom(true);//是否支持缩放,true 支持,false 不支持 //设置自适应屏幕 webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放 webSettings.setLoadWithOverviewMode(true); //页面支持缩放 webSettings.setJavaScriptEnabled(true); webSettings.setBuiltInZoomControls(true); webSettings.setSupportZoom(true); mWebView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { mImageView.setImageBitmap(favicon); Log.e("PageStarted", "url--->" + url); Log.e("PageStarted", "view--getTitle->" + view.getTitle()); Log.e("PageStarted", "view--->" + view.getUrl()); } @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { mWebView.loadUrl(url); Log.e("OverrideUrlLoad", "url--->" + url); Log.e("OverrideUrlLoad", "view--getTitle->" + view.getTitle()); Log.e("OverrideUrlLoad", "view--->" + view.getUrl()); return true; } @Override public void onPageFinished(WebView view, String url) { Log.e("PageFinished", "url--->" + url); Log.e("PageFinished", "view--getTitle->" + view.getTitle()); Log.e("PageFinished", "view--->" + view.getUrl()); } }); mWebView.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView view, int newProgress) { mProgressBar.setProgress(newProgress); } @Override public void onReceivedTitle(WebView view, String title) { } }); /** * 长按屏幕事件,return false 时长按时会出现复制功能,return true 时长按时不会出现复制 */ mWebView.setOnLongClickListener(new View.OnLongClickListener() { @Override public boolean onLongClick(View v) { return false; } }); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.back_btn: mWebView.goBack();//后退 break; case R.id.next_btn: mWebView.goForward();//前进 break; } } public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) { mWebView.goBack(); return true; } return super.onKeyDown(keyCode, event); } }
Demo 下载地址:http://download.csdn.net/detail/u013501637/9458173