[转]WebView使用

在Android手机中内置了一款高性能webkit内核浏览器,在SDK中封装成名为WebView的组件。
WebView使用:
(1)添加权限:AndroidManifest.xml中必须使用许可"android.permission.INTERNET",否则会出Web page not available错误。
(2)在要Activity中生成一个WebView组件:WebView webView = new WebView(this);
(3)设置WebView基本信息:
  webview.getSettings().setJavaScriptEnabled(true);// 设置支持Javascript
  requestFocus();// 触摸焦点起作用
  setScrollBarStyle(SCROLLBARS_OUTSIDE_OVERLAY);// 取消滚动条
(4)设置WevView要显示的网页:
  webView.loadUrl("http://www.google.com");// 互联网
  webView.loadUrl("file:///android_asset/XX.html");// 本地文件,本地文件存放在:assets文件中
(5)如果希望点击链接不打开Android的系统browser中响应,则需要给WebView添加一个事件监听并重写shouldOverrideUrlLoading方法。
  public boolean shouldOverrideUrlLoading(WebView view,String url) {  
    view.loadUrl(url);  
     return true;           
  } 
其它部分可重写的方法:
(1)接收到Http请求的事件
onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host, String realm)
(2)打开链接前的事件
public boolean shouldOverrideUrlLoading(WebView view, String url) {
  view.loadUrl(url);
  return true;
} 
(3)载入页面完成的事件
public void onPageFinished(WebView view, String url) {
 
(4)载入页面开始的事件
public void onPageStarted(WebView view, String url, Bitmap favicon) {
}
这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。    
一、如果用WebView点链接看了很多页以后,如果不做任何处理,点击系统返回(Back)键,整个浏览器会调用finish()方法而结束自身,如果希望浏览的网页回退而不是退出浏览器,需要在当前Activity中处理并消费掉该Back事件。
  覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法。
  public boolean onKeyDown(int keyCode,KeyEvent event){  
    if(webView.canGoBack() && keyCode == KeyEvent.KEYCODE_BACK){ 
      webview.goBack();// goBack()表示返回webView的上一页面 
      return true; 
    } 
    return false; 
  }
二、loadData()和loadDataWithBaseURL()使用的区别

loadData()中的html data中不能包含'#', '%', '\', '?'四中特殊字符,出现这种字符就会出现解析错误,显示找不到网页还有部分html代码。
处理方法:我们需要用UrlEncoder编码为%23, %25, %27, %3f 。 可以使用以下两种代码,data为string类型的html代码 (1)webView.loadData(URLEncoder.encode(data, "utf-8"), "text/html", "utf-8"); (2)webView.loadDataWithBaseURL(null, data, "text/html", "utf-8", null);

WebView相关属性:

(1)设置WebView为透明:

  android:background="#00000000"     

  android:cacheColorHint="#00000000"     

  WebView.setBackgroundColor(0); 

(2)WebView 显示sd卡图片:

webView.loadDataWithBaseURL(null, "", "text/html" , "utf-8", null); 

(3)WebView显示字符串

webView.loadDataWithBaseURL("", "", "text/html", "utf-8", ""); 

(4)设置WebView中显示字体的大小

public static final TextSize[] FONT_SIZES = new TextSize[] {

  TextSize.SMALLER,

  TextSize.NORMAL,

  TextSize.LARGER

};     

private WebSettings wb;     

wb = mWebViewRightContent.getSettings();     

wb.setTextSize(FONT_SIZES[iFontSizeId]); 

字体大小:

public enum TextSize { 

  SMALLEST(50),         

  SMALLER(75),         

  NORMAL(100),         

  LARGER(150),         

  LARGEST(200);         

  TextSize(int size)  {             

    value = size;         

  }         

  int value;     

(5)WebView显示html文件时,若要达到和PC上浏览器显示的效果完全一样,只需对WebView做一下设置即可:

适应全屏 

39 适应竖屏   

57 适应横屏     

mWebView.setInitialScale(39); 

注意的是:html如果字体太小则在Android手机上显示的就很小。一般为6、7号字体。

(6)WebView设置渐变:

android:fadingEdge="vertical"     

android:fadingEdgeLength="20px"  (垂直方向,上下渐变区域为20px)

(7)设置WebView可触摸放大缩小:

mWebView.getSettings().setBuiltInZoomControls(true); 

(8)WebView双击变大,再双击后变小,当手动放大后,双击可以恢复到原始大小,如下设置:

webView.getSettings().setUseWideViewPort(true); 

(9)几种加速WebView加载的方法,提高渲染的优先级

webView.getSettings().setRenderPriority(RenderPriority.HIGH); 

使用webView.getSettings().setBlockNetworkImage,把图片加载放在最后来加载渲染webView.getSettings().setBlockNetworkImage(true); 

(10)将字符串转换成HTML形式的文件显示:

  // 获取的字符串     

  String sDetails = cursor.getString(cursor.getColumnIndex("sChinese"));     

  // 按行截取字符串,将其存放在数组中     

  String[] str = sDetails.split("\n");     

  String s1 = "";     

  // 遍历数组进行判断,如果条件成立,就添加设定的css样式     

  for (int i = 0;i < str.length;i ++) {         

    if (str[i].trim().startsWith("vt.")) {             

      str[i] = "<h3 style=\"font-size:10px; color:#000; background:#FCFCFC; padding:3px 5px;\">" + str[i] + "<h3>" + "\n";         

    } else if (getMark(str[i].trim())) {             

      str[i] = "<h4 style=\"font-size:10px; color:#F60; font-weight:normal;\">" + str[i] + "</h4>" + "\n";         

    } else if (str[i].trim().startsWith("〖")) {             

      str[i] = "<span style=\"color:#333; font-size:10px; color:#F60\">" + str[i] + "</span>" + "\n";         

    } else {             

      str[i] = "<p style=\"line-height:16px; font-size:10px;color:#666;\">" + str[i] + "</p>" + "\n";         

    }

    // 将修改后的字符串拼接起来         

    s1 += str[i];     

  }     

  // 用WebView将字符串以HTML的形式显示出来     

  webView.loadDataWithBaseURL("fake://not/needed", s1, "text/html", "utf-8", ""); 


 
1.  WebView无法缓存(Cache)
   如果页面的Header包含了以下字段就会导致无法缓存(具体可参考CacheManger.parseHeaders()方法):
   Cache-Control:  no-store, no-cache
   Pragma:  no-cache
    需要由服务器更改页面属性解决。
 
2. WebView.getFavIcon()无法获取到页面图标
    必须先执行以下操作(打开图标数据库):
WebIconDatabase. getInstance ().open(getDir( "icons" MODE_PRIVATE ).getPath());
 
3. WebViewClient.shouldOverLoadingUrl()方法有时不会被回调
  我是在访问百度手机版切换为传统版时遇到的,页面 最下面的<传统版>切换:
   <a href="http://video.baidu.com/index.html?fr=video" target="_blank" onmousedown="vdStatic(event, this, 2043)">传统版</a>     
   
   网上搜集到讨论该问题的一些链接:
 
   目前还没法办解决,对于想截获地址并禁止其访问的,可以在WebViewClient.onPageStart()里处理:
   class   MyWebViewClient   extends   WebViewClient {
            
       /**
       * 网页开始加载
       */
       public   void   onPageStarted(WebView view, String url, Bitmap favicon){  
             if IsIgnoreWebsite (url)){
                  view.stopLoading();
                   // 提示网页被屏蔽?
                   return ;
            }
      }
 
  }
 
4.  垂直滚动条总是显示白色轨迹底图(无法消掉)
在xml中给WebView设置一下属性发觉不起一点作用:
android:fadeScrollbars "true"
android:scrollbarStyle "outsideOverlay"
android:scrollbarAlwaysDrawVerticalTrack "false"
 
必须在代码中对WebView进行设置才能奏效:
webview .setScrollbarFadingEnabled( true );
webview .setScrollBarStyle(View. SCROLLBARS_INSIDE_OVERLAY );
 
5.  加载报错(无法创建数据库导致空指针)
这不是必然的。我的情况是,我有两个应用使用到WebView,代码都是一样的,但是其中一个死活报错 
什么都不做,仅仅构造了WebView对象:
sqlite returned: error code = 14, msg = cannot open file at source line 25467
sqlite3_open_v2("/data/data/com.demo.webview/databases/webview.db", &handle, 6, NULL) failed
sqlite returned: error code = 14, msg = cannot open file at source line 25467
sqlite3_open_v2("/data/data/com. demo .webview/databases/webviewCache.db", &handle, 6, NULL) failed
 
使用load加载网页,加载完毕时报错: 
FATAL EXCEPTION: WebViewWorkerThread
java.lang.NullPointerException
     at android.webkit.WebViewDatabase.getCacheTotalSize(WebViewDatabase.java:734)
     at android.webkit.CacheManager.trimCacheIfNeeded(CacheManager.java:548)
     at android.webkit.WebViewWorker.handleMessage(WebViewWorker.java:190)
     at android.os.Handler.dispatchMessage(Handler.java:99)
     at android.os.Looper.loop(Looper.java:123)
     at android.os.HandlerThread.run(HandlerThread.java:60)
 
初步分析:
这是因为底层库打开数据库时失败,导致进一步调用该数据库对象进行操作,抛出空指针错误。
 
目前已尝试的解决方式:
1.捕获抛出的异常 —— 无法捕获到。
 
转自: http://chen2337.blog.163.com/blog/static/3403992020131158655145/
posted @ 2015-08-18 15:30  NoodleUtopia  阅读(293)  评论(0编辑  收藏  举报