Unity2019使用Gradle命令行(编译)出安卓包

本文为作者原创,转载请注明出处:https://www.cnblogs.com/zhaoqingqing/p/14968513.html



在我所经历的项目组中有这几种方法来生成APK

  1. 直接在Unity生成APK,可以接入SDK

  2. 使用Unity导出Android Studio工程手动生成APK

  3. 使用Unity导出Android Studio工程命令行离线生成APK

这里记录一下我在项目组使用Android Studio出包的笔记。

使用Unity导出Android Studio工程前建议查看我之前的文章《Unity2019及Unity2020打包android的环境配置》,主要介绍替换或修改Unity安装目录下的baseProjectTemplate.gradle,把链接指向国内能加快速度。

说明:我把Android Studio简称为AS,AS生成APK使用gradle来构建。

Gradle简介#

Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。Gradle 构建脚本使用的是 Groovy 或 Kotlin 的特定领域语言来编写的,而不是传统的XML。

当前官方支持的语言为Java、Groovy、Scala、C++、Swift、JavaScript等以及Spring框架。

使用 Gradle 的优势

  1. 自动处理包相依关系 - 取自 Maven Repos 的概念
  2. 自动处理布署问题 - 取自 Ant 的概念
  3. 条件判断写法直觉 - 使用 Groovy 语言

过去 Java 开发者常用 Maven 和 Ant 等工具进行封装布署的自动化,或是两者兼用,不过这两个包彼此有优缺点,如果频繁改变相依包版本,使用 Ant 相当麻烦,如果琐碎工作很多,Maven 功能不足,而且两者都使用 XML 描述,相当不利于设计 if、switch 等判断式,即使写了可读性也不佳,而 Gradle 改良了过去 Maven、Ant 带给开发者的问题,至今也成为 Android Studio 内置的封装布署工具。

下载和配置#

Gradle下载:https://gradle.org/releases/

配置方法:需要把gradle解压后的bin路径配置到环境变量的Path中,示例:D:\gradle-7.1\bin

Unity导出AS工程文档:https://docs.unity3d.com/Manual/android-gradle-overview.html

我打包使用的软件环境:

准备知识:#

命令行生成APK#

在开始生成APK前需要做一些准备工作:在 AS 的 Terminal 中使用命令 gradlew --warning-mode all 可以打印出当前 gradle 存在的所有警告信息

检查签名信息#

检查AndroidStuiod工程根目录下的build.gradle文件中的keystore,alias,密码配置是否正确:

Copy
signingConfigs{ release{ keyAlias 'xxxxxx' keyPassword 'xxxxxx' storeFile file('D:/android_sdk/android.keystore') storePassword 'xxxxxx' v2SigningEnabled true } debug{ keyAlias 'xxxxxx' keyPassword 'xxxxxx' storeFile file('D:/android_sdk/android.keystore') storePassword 'xxxxxx' v2SigningEnabled true } }

运行命令#

在CMD中进入到AS工程的根目录,然后在命令行输入:gradle assembleRelease,就会生成APK。

可以生成release和debug两种APK,命令如下:

Copy
radle clean gradle assembleRelease
  1. gradle clean 下载Gradle的一些依赖
  2. gradle assembleDebug 在build\Output中生成debug签名的apk
  3. gradle assembleRelease 在build\Output中生成Release签名的apk
  4. 当CMD中出现BUILD SUCCESSFUl恭喜你!Gradle打包成功啦!

如果在CMD中build失败,可以尝试在AS的命令行窗口中,输入:gradle assembleRelease

PS. 下面这个方法过时了,在android 的官网上已经去掉此部分了

​ 在AS2.3及更高版本且minsdkVersion>21时,AS会使用新版的dex打包,速度更快

​ 在命令行也调用新版本的打包:./gradlew -Pandroid.injected.build.api=26 assembleDevDebug

离线生成apk#

在项目的根目录下有gradlew.bat文件,执行命令如下:

Copy
cd %~dp0 gradlew.bat clean gradlew.bat assembleRelease --offline

遇到问题#

build出错#

首次出包时未安装好依赖,会报依赖找不到的问题,日志如下:

解决办法:通过Android Stuio打开项目,AS会自动下载依赖,下载完依赖之后,使用命令行还是报一样的错误,现在是使用AS手动操作来出包。

Copy
PS E:\AndroidExport\resTestTtzg001_20210621v000\resTestTtzg001> gradle assembleRelease FAILURE: Build failed with an exception. * What went wrong: A problem occurred configuring root project 'resTestTtzg001'. > Could not resolve all dependencies for configuration ':classpath'. > Using insecure protocols with repositories, without explicit opt-in, is unsupported. Switch Maven repository 'maven2(http://maven.aliyun.com/nexus/content/repositories/jcenter)' to redirect to a secure protocol (like HTTPS) or allow insecure protocols. See https://docs.gradle.org/7.1/dsl/org.gradle.api.artifacts.repositories.UrlArtifactRepository.html#org.gradle.api.artifacts.repositories.UrlArtifactRepository:allowInsecureProtocol for more details.

不支持在存储库中使用不安全的协议,没有显式的选择。

重定向到安全协议(如HTTPS)或允许不安全协议

allowInsecureProtocol:指定是否可以接受通过不安全的HTTP连接与存储库通信

两种办法解决:

  1. 在build.gradle 中添加这行配置即可
Copy
repositories { ... maven { url = uri("http://example.com") allowInsecureProtocol = true ... } }
  1. 把上述出问题的阿里云链接可以把http改成https也一样可以访问。

AS无法访问host#

Unknown host 'mirrors.opencas.cn'. You may need to adjust the proxy settings in Gradle

  1. 在AS中将Settings 下的Http Proxy 设置为 No Proxy 记得Apply

  2. 打开用户目录下的:C:\Users\qing.gradle\gradle.properties,删除里面配置的mirrors.opencas.cn

gradlew 和 gradle命令的区别#

gradlew:gradle wrapper的简写,在Android studio的指定是在gradle/wrapper/gradle-wrapper.properties 中

gradle:对于系统gradle其存放在 ~/.gradle 下面

作者:赵青青   一名在【网易游戏】做游戏开发的程序员,擅长Unity3D,游戏开发,.NET等领域。
本文版权归作者和博客园共有,欢迎转载,转载之后请务必在文章明显位置标出原文链接和作者,谢谢。
如果本文对您有帮助,请点击【推荐】您的赞赏将鼓励我继续创作!想跟我一起进步么?那就【关注】我吧。
posted @   赵青青  阅读(2094)  评论(3编辑  收藏  举报
编辑推荐:
· golang自带的死锁检测并非银弹
· 如何做好软件架构师
· 记录一次线上服务OOM排查
· Linux实时系统Xenomai宕机问题的深度定位过程
· 记一次 .NET某汗液测试机系统 崩溃分析
阅读排行:
· SQL优化的这15招,真香!
· 将 EasySQLite 从 .NET 8 升级到 .NET 9
· [.NET] API网关选择:YARP还是Ocelot?
· [.NET] 单位转换实践:深入解析 Units.NET
· C#+ WPF 实现蓝牙转WIFI计步上位机
历史上的今天:
2016-07-04 微软极品工具箱-Sysinternals Suite
2015-07-04 社交化分享SDK for Unity
2015-07-04 Windows 批处理(bat)语法大全
CONTENTS
点击右上角即可分享
微信分享提示