Android中的WebView

来源:互联网 发布:淘宝电商培训骗局 编辑:程序博客网 时间:2024/05/12 22:48

WebView是Android中一个非常实用的组件,它和Safai、Chrome一样都是基于Webkit网页渲染引擎,可以通过加载HTML数据的方式便捷地展现软件的界面。使用WebView开发软件有一下几个优点:
1.可以打开远程URL页面,也可以加载本地HTML数据;
2.可以无缝的在java和javascript之间进行交互操作;
3.高度的定制性,可根据开发者的需要进行多样性定制。
一、WebView的基本使用
(1)访问网页文件
(2)访问本地数据
首先在layout中定义一个基本空间WebView

<WebView        android:id="@+id/wb"        android:layout_width="fill_parent"        android:layout_height="fill_parent"        android:layout_marginTop="10dp" /> 

同时因为要访问网页文件,所以manifest中必须要加uses-permission,有关uses-permission的用法参见网址uses-permission的用法:

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

在Activity中定义一个WebView然后加载文件:

private WebView webView;webView=(WebView) findViewById(R.id.wb);webView.loadUrl("http://www.baidu.com");

这样就可以显示百度的页面了
同时你也可以访问本地文件,比如把百度首先存储到assets目录下命名为example.htm,然后在Activity中用:

webView.loadUrl("file:///android_asset/example.htm");

这样就可以访问这个页面了

二、在WebView中使用JavaScript

//启用支持javascriptWebSettings settings = webView.getSettings();settings.setJavaScriptEnabled(true);

三、点击返回返回上一页而不是退出程序
在第一种使用中,如果进入百度页面再点击其中的链接进入另一个页面,此时点击返回不会返回到百度页面,而是退出程序,这个问题可以这样解决:

 public boolean onKeyDown(int keyCode,KeyEvent event){        if(keyCode==KeyEvent.KEYCODE_BACK){            if(webView.canGoBack()){                webView.goBack();                return true;            }            else{                System.exit(0);            }        }        return super.onKeyDown(keyCode, event);    }

四、在加载网页时,现实进度条
之前的方法加载网页没有进度条,用户体验不好,可以增加进度条,如下:

 webView.setWebChromeClient(new WebChromeClient(){            public void onProgressChanged(WebView view,int newProgress){                if(newProgress==100){                    closeDialog();                }                else                {                    openDialog(newProgress);                }            }            private void openDialog(int newProgress) {                // TODO Auto-generated method stub                if(dialog==null){                    dialog=new ProgressDialog(MainActivity.this);                    dialog.setTitle("正在加载");                    dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);                           dialog.setProgress(newProgress);                    dialog.show();                }                else                {                    dialog.setProgress(newProgress);                }            }            private void closeDialog() {                // TODO Auto-generated method stub                if(dialog!=null&&dialog.isShowing()){                    dialog.dismiss();                    dialog=null;                }            }        });

五、优先使用缓存
为了加快加载网页的速度,可以考虑用缓存

//优先使用缓存settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//不用缓存webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);

查看缓存的方法:在window→show view→file explorer→com.example.http(http是我的工程名)→app_webview→cache就可以看到你的缓存

0 0
原创粉丝点击