如何在 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 中运行应用,打开项目的一个活动文件,然后单击工具栏中的“运行 ”图标。选择你的移动设备作为选项,然后查看会显示默认屏幕的移动设备 −
单击此处 下载项目代码
广告