如何在 Android WebView 中加载 html 内容?


本例演示如何在安卓 WebView 中加载 HTML 内容。

步骤 1 − 在 Android Studio 中新建一个项目,转到 File ⇒ New Project 并填写所有必需信息创建新项目。

步骤 2 − 在 res/layout/activity_main.xml 中添加以下代码。

<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:gravity = "center"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity"
   android:orientation = "vertical">
   <WebView
      android:id = "@+id/web_view"
      android:layout_width = "match_parent"
      android:layout_height = "match_parent" />
</LinearLayout>

在以上代码中,我们已获取 WebView 来显示 HTML 内容。

步骤 3 − 在 src/MainActivity.java 中添加以下代码

package com.example.myapplication;
import android.app.ProgressDialog;
import android.os.Build;
import android.os.Bundle;
import android.support.annotation.RequiresApi;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.EditText;
public class MainActivity extends AppCompatActivity {
   @RequiresApi(api = Build.VERSION_CODES.P)
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      final ProgressDialog progressDialog = new ProgressDialog(this);
      progressDialog.setMessage("Loading Data...");
      progressDialog.setCancelable(false);
      WebView web_view = findViewById(R.id.web_view);
      web_view.requestFocus();
      web_view.getSettings().setLightTouchEnabled(true);
      web_view.getSettings().setJavaScriptEnabled(true);
      web_view.getSettings().setGeolocationEnabled(true);
      web_view.setSoundEffectsEnabled(true);
      web_view.loadData("<html><body>Hello, world!</body></html>",
      "text/html", "UTF-8");
      web_view.setWebChromeClient(new WebChromeClient() {
         public void onProgressChanged(WebView view, int progress) {
            if (progress < 100) {
               progressDialog.show();
            }
            if (progress = = 100) {
               progressDialog.dismiss();
            }
         }
      });
   }
}

运行你的程序。我假定你的真机已连接到电脑。要从 Android Studio 运行程序,打开项目中某个 activity 文件,然后单击工具栏上的运行  图标。选择你的移动设备为运行选项,然后查看你的移动设备上显示的默认界面 -

单击 此处 下载项目代码

更新于:2019 年 7 月 30 日

6k+ 次浏览

开启您的 事业

完成课程,获得认证

开始
广告
© . All rights reserved.