下面介绍下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");//设置编码格式