如何在 Android 中支持多屏幕 WebView?


本示例演示如何在 Android 中支持多个屏幕的 WebView。

步骤 1 − 在 Android Studio 中创建新的项目,转到“文件 ⇒ 新项目”,并填写所有必需的详细信息以创建新项目。

步骤 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>

在上述代码中,我们采用了 Web 视图来显示 tutorialspoint.com。

步骤 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().setJavaScriptEnabled(true);
      // How to support webview with multiple screens in android
      web_view.getSettings().setSupportMultipleWindows(true);
      web_view.loadUrl("https://tutorialspoint.com/");
      web_view.setWebChromeClient(new WebChromeClient() {
         public void onProgressChanged(WebView view, int progress) {
            if (progress < 100) {
               progressDialog.show();
            }
            if (progress = = 100) {
               progressDialog.dismiss();
            }
         }
      });
   }
}

步骤 4 − 在 AndroidManifest.xml 中添加以下代码

<?xml version = "1.0" encoding = "utf-8"?>
<manifest xmlns:android = "http://schemas.android.com/apk/res/android"
   package = "com.example.myapplication">
   <uses-permission android:name = "android.permission.INTERNET"/>
   <application
      android:allowBackup = "true"
      android:icon = "@mipmap/ic_launcher"
      android:label = "@string/app_name"
      android:roundIcon = "@mipmap/ic_launcher_round"
      android:supportsRtl = "true"
      android:theme = "@style/AppTheme">
      <activity android:name = ".MainActivity">
         <intent-filter>
            <action android:name = "android.intent.action.MAIN" />
            <category android:name = "android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
   </application>
</manifest>

我们运行一下你的应用吧。我假设你已经将真实的 Android 移动设备连接到了电脑上。要在 Android Studio 中运行应用,打开项目的一个活动文件,然后单击工具栏中的“运行  ”图标。选择你的移动设备作为选项,然后查看会显示默认屏幕的移动设备 −

单击此处 下载项目代码

更新于: 30-Jul-2019

813 查看

启动你的 职业

完成课程以获得认证

开始
广告