安卓WebView的使用

article/2025/9/17 17:04:22

一、WebView简介

        WebView是Android中的原生UI控件,主要用于在app应用中方便地访问远程网页或本地html资源。同时,WebView也在Android中充当Java代码和JS代码之间交互的桥梁。实际上,也可以将WebView看做一个功能最小化的浏览器。

        安卓官方WebView接口文档

二、安卓交互功能封装

        通过Android Studio将WebView相关调用接口封装成AAR包,以供后续Unity调用。

1、新建安卓工程

(1)创建工程

        使用Android Studio创建新工程,选择为Empty Activity。

(2)选项配置

        设置一下Name及Package name,注意一下Language是否选择Java。

 2、创建模块

        创建用于封装AAR包的模块。选中工程名,右键New-->Module。例如本项目创建名为WebView的模块。

        注意,模块包名要与工程的包名一致。

 3、Java类创建

(1)创建方法调用类

        选中WebView模块-->src-->main-->java-->包名(com.xx.xx),右键New-->Java Class,创建名为MainActivity的方法调用Java类,内部写好供Unity调用的方法。写入以下代码。

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;public class MainActivity extends Activity{private Context mContext;private static MainActivity mMainActivity = null;public MainActivity(Context context) {this.mContext = context;}public static MainActivity getInstance(Context context){if (mMainActivity == null) {mMainActivity = new MainActivity(context);}return mMainActivity;}//Unity中会调用这个方法,从而开打WebViewpublic void StartWebView(String url,String label){printLog("Welcome");WebViewActivity.openUrl = url;WebViewActivity.activityLabel = label;Intent intent = new Intent(this.mContext,WebViewActivity.class);this.mContext.startActivity(intent);}public boolean showToast(String content){Toast.makeText(this.mContext,content,Toast.LENGTH_SHORT).show();return true;}private void printLog(String s){//Log.d("vivian",s);showToast(s);}
}

(2)创建WebView调用类

        同样的方式,在MainActivity同级目录里创建名为WebViewActivity的WebView调用类,用于开启WebView。写入以下代码。

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebView;
import android.widget.Button;public class WebViewActivity extends Activity {public static String openUrl;//需要打开的链接public static String activityLabel;//链接对应的Title,显示在WebView的标题栏private WebView webView;private Button close;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setTitle(activityLabel);//设置链接的TitlesetContentView(R.layout.activity_webview);webView = (WebView) findViewById(R.id.WebView);webView.loadUrl(openUrl);webView.getSettings().setJavaScriptEnabled(true);webView.setWebViewClient(new WebViewClient());close = (Button) findViewById(R.id.CloseButton);close.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {WebViewActivity.this.finish();}});}private class WebViewClient extends android.webkit.WebViewClient {@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {WebView.HitTestResult hit = view.getHitTestResult();//hit.getExtra()为null或者hit.getType() == 0都表示即将加载的URL会发生重定向,需要做拦截处理if (TextUtils.isEmpty(hit.getExtra()) || hit.getType() == 0) {//通过判断开头协议就可解决大部分重定向问题了,有另外的需求可以在此判断下操作Log.e("重定向", "重定向: " + hit.getType() + " && EXTRA()" + hit.getExtra() + "------");Log.e("重定向", "GetURL: " + view.getUrl() + "\n" +"getOriginalUrl()"+ view.getOriginalUrl());Log.d("重定向", "URL: " + url);}if (url.startsWith("http://") || url.startsWith("https://")) {//加载的url是http/https协议地址view.loadUrl(url);return false; //返回false表示此url默认由系统处理,url未加载完成,会继续往下走} else { //加载的url是自定义协议地址try {Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));startActivity(intent);} catch (Exception e) {e.printStackTrace();}return true;}}}
}

4、AndroidManifest.xml文件配置

        在AndroidManifest.xml文件里配置创建的Java类及权限。

        模块创建后默认写入了一些内容,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"></manifest>

        在WebView模块-->src-->main下打开AndroidManifest.xml,写入以下内容:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="包名"><applicationandroid:usesCleartextTraffic="true"><activity android:name=".MainActivity"></activity><activity android:name=".WebViewActivity"android:label="@string/activity_name"></activity></application><!-- 连接互联网的权限 --><uses-permission android:name="android.permission.INTERNET" />
</manifest>

5、创建res文件夹

        选中WebView模块-->src-->main,右键New-->Directory,在弹窗里选择res,双击创建。

 

        res文件夹后续用来存储布局文件及一些字符串配置文件。

        创建后的目录层级如下:

 6、创建WebView布局文件

        布局文件用于WebView界面布局设计。选中res文件夹,右键New-->Directory,在弹窗里输入layout,回车创建。

        创建完毕后,选中layout,右键New-->Layout Resource File,在弹窗里输入activity_webview(名字根据自己的上下文自定义),点击OK创建布局文件。

        将界面选择为Code后,写入以下内容:

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><WebViewandroid:id="@+id/WebView"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_weight="1.0"/><Buttonandroid:id="@+id/CloseButton"android:layout_width="match_parent"android:layout_height="wrap_content"android:backgroundTint="#009688"android:text="返回"android:textColor="#FFFFFF"android:textColorHint="#000000" />
</LinearLayout>

7、创建strings.xml文件

         选中res文件夹,右键New-->Directory,在弹窗里输入values,回车创建。

         创建完毕后,选中values,右键New-->File,在弹窗里输入strings.xml后,回车创建。

         创建完毕,打开strings.xml文件,写入以下内容:

<resources><string name="activity_name">B站</string>
</resources>

        strings.xml文件用于设置WebView界面的标题,在WebViewActivity中动态修改其值。

8、修改编译和目标SDK

        在WebView模块中,找到并打开build.gradle文件,将compileSdk和targetSdk修改为31或以上。

         因为后续构建release版本AAR包时,需要31或以上版本的SDK。

9、修改Build变量为release

        点击Build-->Select Build Variant...,在打开的界面中将WebView模块的Build Variant选择为release。

 10、针对AAR包混淆处理

(1)build.gradle修改

        在WebView模块中,找到并打开build.gradle文件,将buildTypes中release块的minifyEnabled修改为true。

 (2)混淆文件修改

        在WebView模块中,找到并打开proguard-rules.pro文件,写入以下内容:

-keep class 包名.MainActivity{public <methods>;}

        此处是为了保持MainActivity中的public方法不被混淆处理,避免供Unity调用的方法混淆。若不加以限制,Unity将无法调用到AAR包里的方法。

11、构建AAR包

        选中WebView模块,点击Build-->Make Module,或者直接Build-->Rebuild Project。

        待编译完成后,在WebView模块-->build-->outputs-->aar里便可找到编译好的AAR包。

 三、Unity调用

1、AAR包放置

        直接将AAR包拖放至Unity的Assets-->Plugins-->Android路径下。

 2、创建C#脚本,调用AAR包

        写入以下内容,用来调用AAR包里的函数接口。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;public class SetWebViewUtils : MonoBehaviour
{private AndroidJavaObject setWebViewUtils;private string activityLabel;//安卓端Activity的Label,即打开的链接在WebView中的标题// Start is called before the first frame updatevoid Start(){AndroidJavaClass UnityPlayer = new AndroidJavaClass("com.unity3d.player.UnityPlayer");AndroidJavaObject currentActivity = UnityPlayer.GetStatic<AndroidJavaObject>("currentActivity");AndroidJavaClass openAppUtilsClass = new AndroidJavaClass("包名.MainActivity");setWebViewUtils = openAppUtilsClass.CallStatic<AndroidJavaObject>("getInstance", currentActivity);}//设置WebView的标题public void SetTitle(string label){activityLabel = label;}//打开WebViewpublic void SetWebView(string url){setWebViewUtils.Call("StartWebView", url, activityLabel);}
}

3、调用测试

        在Unity编辑器里创建三个按钮,用来打开三个不同的链接。

        将SetWebViewUtils脚本挂载至场景物体上。

        三个按钮的调用方式如下,通过传入标题名称及需要打开的链接地址来打开相应的WebView。

 4、切换至安卓平台,打包apk,安装测试便可

四、AAR包资源下载入口

        如果有小伙伴看了以上教程还不知道如何封包,可以直接下载以下AAR包直接使用,里面有插件的包名,替换掉SetWebViewUtils脚本里的“包名”便可。

        AAR包下载入口


http://chatgpt.dhexx.cn/article/JiI3eX1R.shtml

相关文章

安卓WebView(H5)调用原生相机及相册

在开始叙述正文之前笔者先声明一下应用场景&#xff1a;例如在网页上的即时通讯需要能拍照或者从图库选择图片来进行上传,此场景下就可以用到这篇文章的内容 正文 首先&#xff0c;如果你已经把相机以及访问文件夹的权限都加上了并且WebView的基础操作都做完了&#xff0c;就差…

安卓webview和js+html交互利用的addJavascriptInterface和webview.loadUrl(javascript:**);

近期做一个项目需要把一个 服务支持的界面用webview来显示..呀 html白雪了js更是一样啥也不会&#xff0c;相信很多初学屌丝员跟我一样,, html开发工具都不知道怎么写..哈哈哈.....现在把做完的结果分享一下先上图了 ,, 这是从项目中特意分离出来的demo这里之上一些关键代码…

安卓webview和h5交互

先上html的代码&#xff1a; <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <HTML><HEAD><TITLE>安卓和js交互demo</TITLE><meta charset"utf-8"></HEAD><script> function giveAnd…

Android—WebView与JS交互

Html文件&#xff1a; WebView与JS交互方式&#xff1a; 1. 前提&#xff1a; WebSettings webSettings webView.getSettings(); // 设置与Js交互的权限 webSettings.setJavaScriptEnabled(true);webView.setWebChromeClient(new WebChromeClient(){Overridepublic boolean …

【Android】之【WebView】

一、简介 WebView是一种控件&#xff0c;它基于webkit引擎&#xff0c;因此具备渲染Web页面的功能。   基于Webview的混合开发&#xff0c;就是在 Android os(安卓)/I os(苹果)原生APP里&#xff0c;通过WebView控件嵌入Web页面。 你手机里有淘宝软件吧&#xff1f; 就是外…

WebView---Android与js交互实例

Android 中可以通过webview来实现和js的交互&#xff0c;在程序中调用js代码&#xff0c;只需要将webview控件的支持js的属性设置为true Android&#xff08;Java&#xff09;与JavaScript&#xff08;HTML&#xff09;交互有四种情况&#xff1a; 1&#xff09; Android&…

【Android】WebView控件最全使用解析

WebView控件最全使用解析 一、WebView 概述二、WebView使用基础篇2.1添加方式2.2 加载远程网页2.3 加载本地网页2.4 加载HTML片段2.5 WebView 常用方法 三、WebView 进阶篇3.1 WebSettings类3.2 WebViewClient类常见方法使用案例 3.3 WebChromeClient类常用方法使用案例测试网页…

Android:这是一份全面 详细的Webview使用攻略

前言 现在很多App里都内置了Web网页&#xff08;Hybrid App&#xff09;&#xff0c;比如说很多电商平台&#xff0c;淘宝、京东、聚划算等等&#xff0c;如下图 京东首页 那么这种该如何实现呢&#xff1f;其实这是Android里一个叫WebView组件实现 今天&#xff0c;我将献…

数据字典的代码示例

数据字典UI设计&#xff1a; 设计说明&#xff1a; 1. 该数据字典支持多级节点。 2. 左边是数据字典树&#xff1b;右边是编辑框&#xff0c;可以对某个数据字典及其一级子节点进行编辑。 代码&#xff1a;https://github.com/tinazhao1985/spring-cloud-demo/tree/master/di…

关于SQL数据字典的详解

相信在学习数据库的时候很多人在设计表的时候会将一些数据量少的数据放到一个表里面 然后使数据库的表比较多。但是其实呢我们可以见那先数据固定的数据放在同一个表里面&#xff0c;这样就 可以减少很多表的创建&#xff0c;这就是数据字典 数据字典分两个表&#xff1a; 一个…

Java 数据字典的实现

Java数据字典实现 目录概述需求&#xff1a; 设计思路实现思路分析1.从数据库中字典2.获取字典的数值 拓展实现性能参数测试&#xff1a; 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip h…

数据字典功能

1. 什么是数据字典 数据字典存储有关数据的来源、说明、与其他数据的关系、用途和格式等信息&#xff0c;它本身就 是一个数据库&#xff0c;存储“关于数据项的数据”。数据字典是个指南&#xff0c;它为数据库提供了“路线图”&#xff0c; 而不是“原始数据”。换句话说&…

数据字典实现

目录 前言 一、创建springboot的工程&#xff0c;pom文件 二、实体类&#xff0c;mapper层&#xff0c;service层&#xff0c;controller层 1.实体类 2.mapper层 3.service层 4.service实现层简称(serviceImpl) 5.controller层 实现效果&#xff1a; 前言 首先在写数据字典之前…

数据库设计之数据字典的使用与设计

如何使用数据字典 文章目录 如何使用数据字典使用场景 :解决方案 :简单解决&#xff1a;企业级理解&#xff1a;数据字典是什么&#xff1a;使用数据字典的优点&#xff1a; 使用场景 : 在平时开发的过程中&#xff0c;特别是在遇到表单时候&#xff0c;我们经常需要为前端提供…

数据库 - 数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

字典的数据处理与可视化

数据处理与可视化 字典数据处理实现数据可视化字典 首先,我们先简单了解一下字典。字典是一个无序、可变和有索引的集合。在 Python 中,字典用花括号表示,拥有键和值。如:{‘id’:1211,‘colors’:‘aliceblue’} 。而字典中包含有字典,称为嵌套字典。如:{‘id’:1211,‘…

数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

软件工程~数据字典例子解释

软件工程~数据字典&#xff08;个人理解&#xff09; 数据字典&#xff1a;关于数据的信息的集合&#xff0c;也就是对数据流图中包含的所有元素的定义的集合。 如果开发小型软件系统时暂时没有数据字典的处理程序&#xff0c;建议使用卡片形式书写数据字典&#xff0c;这里先看…

java静态内部类单例的好处,你确定你的单例模式真的用对了?

一、什么是单例模式 单例模式是一种常用的软件设计模式&#xff0c;其定义是单例对象的类只能允许一个实例存在。该类负责创建自己的对象&#xff0c;同时确保只有一个对象被创建。一般常用在工具类的实现或创建对象需要消耗资源的业务场景。 单例模式的特点&#xff1a; 1.类构…

Java静态内部类单例模式读取Properties配置文件

在Java开发中&#xff0c;可能需要把一些配置参数写入properties配置文件中&#xff0c;在这里介绍一种通过静态内部类单例模式来读取的properties文件的方式。 1.properties文件配置路径 在resources下新建配置文件test.properties&#xff0c;如果对于Java读取指定资源输入…