• WebView


    WebView 主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL。

         1、LoadUrl        直接加载网页、图片并显示。(本地或是网络上的网页、图片、gif)

         2、LoadData     显示文字与图片内容 (模拟器1.5、1.6)

         3、LoadDataWithBase  显示文字与图片内容(支持多个模拟器版本)

    下面来看看代码片段:

    package com.webviewdemo;

    import java.net.URLEncoder;
    import android.app.Activity;
    import android.os.Bundle;
    import android.webkit.WebView;

    public class WebViewDemo extends Activity {

      private WebView     MyWebView;
      static final String mimeType = "text/html";
      static final String encoding = "utf-8";

      /** Called when the activity is first created. */
      @Override
      public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //
        MyWebView = (WebView) findViewById(R.id.MyWebview);
        // this.webHtml();
        // this.webImage();
        // this.localHtmlZh();
        // this.localImage();
        // this.localHtml();
        this.localHtmlImage();
      }

      /**
       * 直接网页显示
       */
      private void webHtml() {

        try {
          MyWebView.loadUrl("http://www.google.com");
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

      /**
       * 直接网络图片显示
       */
      private void webImage() {
        try {
          MyWebView .loadUrl("http://www.google.com.hk/intl/zh-CN/images/logo_cn.gif");
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

      /**
       * 中文显示
       */
      private void localHtmlZh() {
        try {
          String data = "<html>在模拟器 2.1 上测试</html>";
          // utf-8编码处理(在SDK1.5模拟器和真实设备上都将出现乱码,SDK1.6上能正常显示)
          // MyWebView.loadData(data, mimeType, encoding);
          // 对数据进行编码处理(SDK1.5版本)
          MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);
          // MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);

        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

      /**
       * 显示本地图片文件
       */
      private void localImage() {
        try {
          // 本地文件处理
          String str = "file:///android_asset/icon.png";
          MyWebView.loadUrl(str);
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

      /**
       * 显示本地网页文件
       */
      private void localHtml() {
        try {
          // 本地文件处理(如果文件名中有空格需要用+来替代)
          MyWebView.loadUrl("file:///android_asset/test.html");
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

      /**
       * 显示本地图片和文字混合的Html内容
       */
      private void localHtmlImage() {
        try {
          String data = "<HTML>在模拟器 2.1 上测试,这是<IMG src=\"APK'>file:///android_asset/igg.jpg\"/>APK里的图片";
          // SDK1.5本地文件处理(不能显示图片)
          //MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);
          // SDK1.6及以后版本
          //MyWebView.loadData(data, mimeType, encoding);
          // 本地文件处理(能显示图片)
          MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }

    }

    运行 localHtmlImage(...) 这个方法的结果:
     

    在上面的所有方法中,模拟器2.1下 调用 LoadData 方法总是出现乱码。我想应该是2.1已经不在用它了吧。直接用

    LoadDataWithBaseURL 方法最简单,不再牵涉编码的转换。记住:显示本地文件时 必须使用 APK'>file:/// 作为前缀。

  • 相关阅读:
    LeetCode20 有效的括号
    函数的多个参数
    定义一个函数的基本语法 函数的参数
    函数
    金字塔
    水仙花数
    百鸡百钱
    循环demo
    while适用于不确定循环次数
    浏览器打断点
  • 原文地址:https://www.cnblogs.com/wzh206/p/1723581.html
Copyright © 2020-2023  润新知