下面介绍下WebView的简单使用,加载网址是一个webApp.
1.首先是XML
<WebView android:layout_height="match_parent" android:id="@+id/webview" android:layout_width="match_parent"> </WebView>
2.主要代码块
public class MainActivity extends ActionBarActivity { private WebView webview; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(0x1); setContentView(R.layout.fragment_main); webview = (WebView) findViewById(R.id.webview); webview.loadUrl("http://m.560797.com/"); // 加载本地使用<span style="font-family: Arial, Helvetica, sans-serif;">webview</span><span style="font-family: Arial, Helvetica, sans-serif;">.loadUrl(“file:</span><span style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 128, 0);">//</span><span style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 128, 0);">/android_asset/XX.html“);</span> WebSettings webSettings = webview.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setUseWideViewPort(true); webSettings.setLoadWithOverviewMode(true); webview.setWebViewClient(new MyWebViewClient()); // 点击webAPP 按钮监听 使之都使用内嵌的WebView,而不使用手机流浪器 } private class MyWebViewClient extends WebViewClient { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { String s = Uri.parse(url).getHost(); if (s.equals("m.560797.com")) { // This is my web site, so do not override; let my WebView load // the page return false; } // Otherwise, the link is not for a page on my site, so launch // another Activity that handles URLs Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); startActivity(intent); return true; } } }3.权限
<manifest ... > <uses-permission android:name="android.permission.INTERNET" /> ... </manifest>
4.webView返回事件
/** * 按键响应,在WebView中查看网页时,按返回键的时候按浏览历史退回,如果不做此项处理则整个WebView返回退出 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // Check if the key event was the Back button and if there's history if ((keyCode == KeyEvent.KEYCODE_BACK) && myWebView.canGoBack()) { // 返回键退回 myWebView.goBack(); return true; } // If it wasn't the Back key or there's no web page history, bubble up // to the default // system behavior (probably exit the activity) return super.onKeyDown(keyCode, event); }
5.常用webView方法。
webSettings.setJavaScriptEnabled(true); //支持js //设置自适应屏幕,两者合用 webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小 webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小 webSettings.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。 webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。 //若上面是false,则该WebView不可缩放,这个不管设置什么都不能缩放。 webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件 webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局 webSettings.supportMultipleWindows(); //多窗口 // webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存 webSettings.setAllowFileAccess(true); //设置可以访问文件 webSettings.setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点 webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片 webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式