Android中的WebView进行直接加载网页

来源:互联网 发布:如何备考司法考试知乎 编辑:程序博客网 时间:2024/06/06 00:52
我们都知道Android的网络功能很不错,当然Android中WebView组件也挺不错,可以直接进行加载网页,我们可以把这个看做一个小型的浏览器\


【注】以下的一些内容我翻译了一下文档,可能有些翻译不太准确,就算自己当做一次学习英文的机会了,请大家稍微见谅一下哈

首先我们看下文档中对于WebView的解释:


WebView是进行web网页显示的,我们使用这个类为基础进行开发推出自己的Web浏览器,或者我们可以直接在当前的Activity中显示在线的内容。

WebView使用WebKit进行渲染来显示网页,通过于此,我们可以进行实现网页后退,前进,放大,缩小或者搜索或者更多功能;


【注意】使用WebView,,因为用处到了网络,所以我们必须在AndroidManifset.xml文件中进行权限设置
<uses-permission android:name="android.permission.INTERNET" />


接下来去实现WebView,需要下面一些步骤

一:要在布局文件那边声明WebView组件

二:在Activity中进行实例化

三:调用WebView的loadUrl()方法来实现。加载指定的URL地址的网页

Demo源代码:

[java] view plaincopyprint?
  1. package com.android_jiangqq.iweibo.ui;
  2. /**
  3. * @author jiangqq
  4. *
  5. */
  6. import com.android_jiangqq.iweibo.R;
  7. import android.app.Activity;
  8. import android.os.Bundle;
  9. import android.view.Window;
  10. import android.view.WindowManager;
  11. import android.webkit.WebView;
  12. public class WebView_Testextends Activity {
  13. private WebView webView;
  14. private staticfinal String URL = "http://www.google.com";
  15. @Override
  16. protected void onCreate(Bundle savedInstanceState) {
  17. // TODO Auto-generated method stub
  18. super.onCreate(savedInstanceState);
  19. // 取消标题
  20. this.requestWindowFeature(Window.FEATURE_NO_TITLE);
  21. // 进行全屏
  22. this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
  23. WindowManager.LayoutParams.FLAG_FULLSCREEN);
  24. setContentView(R.layout.webview);
  25. // 实例化WebView
  26. webView = (WebView) this.findViewById(R.id.wv_oauth);
  27. /**
  28. * 调用loadUrl()方法进行加载内容
  29. */
  30. webView.loadUrl(URL);
  31. /**
  32. * 设置WebView的属性,此时可以去执行JavaScript脚本
  33. */
  34. webView.getSettings().setJavaScriptEnabled(true);
  35. }
  36. }

XML文件的定义:

[html] view plaincopyprint?
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. ;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical">
  6. <WebView
  7. android:id="@+id/wv_oauth"
  8. android:layout_width="fill_parent"
  9. android:layout_height="fill_parent"/>
  10. ;/LinearLayout>
效果截图:




①:有时候我们我们需要WebView能够实现超链接的功能。我们可以调用setWebViewClient()方法试着WebView的客户端,

此时我们只要重写一下WebViewClient类下的public boolean shouldOverrideKeyEvent (WebView view, KeyEvent event)就可以了

源代码如下:

[java] view plaincopyprint?
  1. private class myWebViewClientextends WebViewClient {
  2. @Override
  3. public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {
  4. webView.loadUrl(URL);
  5. return true;
  6. }
  7. }

②:考虑到网页的加载速度,我们可以调用setWebChromeClient()方法

我们此时只要重写一下 WebChromeClient类中的

public void onProgressChanged (WebView view, int newProgress)来显示页面的加载进度,实例代码如下:

[java] view plaincopyprint?
  1. webview.setWebChromeClient(new WebChromeClient() {
  2. @Override
  3. public void onProgressChanged(WebView view,int newProgress) {
  4. if (newProgress == 100) {
  5. handler.sendEmptyMessage(CLOSE_DIA);
  6. }
  7. super.onProgressChanged(view, newProgress);
  8. }
  9. });

代码中我用到了handlr, 此时如果加载进度=100的时候,发个消息给handler 然后进行处理\


webView还可以直接加载HTML代码

例子程序如下:

[java] view plaincopyprint?
  1. package com.android;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.webkit.WebView;
  5. public class Demo_WebViewextends Activity {
  6. /** Called when the activity is first created. */
  7. @Override
  8. public void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.main);
  11. WebView wView = (WebView) this.findViewById(R.id.wv);
  12. String html = " ";
  13. html += "<head>";
  14. html += "<body><a href=http://www.google.com>google home</a></body>";
  15. html += "</head>";
  16. wView.loadData(html, "text/html","utf-8");
  17. }
  18. }

截图如下: