当前位置:   article > 正文

Unity自动化打包Android APK

buildpipeline.buildplayer自动打设置

零. 前言

最近在做Unity开发,有个任务是通过Jenkins实现自动化打包Unity游戏成Android APK的需求,所以在完成任务后,梳理成了一个最简单的教学,也把遇到的坑和大家分享。

若需要Jenkins打包,指需要通过Jenkins调用下面的命令即可实现基础需求。


一. 原理

打开Unity程序 → 打开指定工程 → 调用Unity的BuildPipeline类进行打包


二. 打包命令

Mac样例:

/Users/Ben/Application/Unity.app/Contents/MacOS/Unity -projectPath /Users/Ben/UnityBuildAndroid -executeMethod ProjectBuild.BuildForAndroid project-projectName -quit

Windows样例:

D:\Unity\Editor\Unity -projectPath D:\UnityBuildAndroid -executeMethod ProjectBuild.BuildForAndroid
project-projectName -quit

格式说明:
Unity打包APK
  1. Unity编辑器路径:非UnityHub路径,可以在UnityHub → 安装 → 具体Unity版本 → 右上角更多信息 → 在Finder中显示(在资源管理器中显示) 可以找到对应Unity应用的路径
  2. 编译的工程路径:需要打包APK的项目路径根目录
  3. 执行的方法:编译APK运行的脚步
  4. 参数(project-projectName):样例中,projectName为工程名,用于命名APK。"project-projectName"整个不写,则会自动读取工程名。读者可以根据自己项目需求,传递需要的参数进入,然后自行解析处理。
  5. -quit:在运行结束后关闭UnityHub,建议在前期未完全调通之前,不要添加该命令,否则打包失败报错时,无法通过Unity日志窗口查看具体原因。

三. 执行步骤

下面以全新Unity空工程来引入自动化打包

1.引入打包工具类,将下面的代码拷贝到工程Assets/Editor目录下
  1. using System.Collections;
  2. using System.IO;
  3. using UnityEditor;
  4. using UnityEngine;
  5. using System.Collections.Generic;
  6. using System;
  7. class ProjectBuild : Editor
  8. {
  9. //在这里找出你当前工程所有的场景文件,假设你只想把部分的scene文件打包 那么这里可以写你的条件判断 总之返回一个字符串数组。
  10. static string[] GetBuildScenes()
  11. {
  12. List<string> names = new List<string>();
  13. foreach (EditorBuildSettingsScene e in EditorBuildSettings.scenes)
  14. {
  15. if (e == null)
  16. continue;
  17. if (e.enabled)
  18. names.Add(e.path);
  19. }
  20. return names.ToArray();
  21. }
  22. /// <summary>
  23. /// 自定义工程名:"project-"作为工程名的前缀参数
  24. /// </summary>
  25. public static string projectName
  26. {
  27. get
  28. {
  29. foreach (string arg in System.Environment.GetCommandLineArgs())
  30. {
  31. if (arg.StartsWith("project"))
  32. {
  33. return arg.Split("-"[0])[1];
  34. }
  35. }
  36. return Application.productName;
  37. }
  38. }
  39. /// <summary>
  40. /// 打包Android应用
  41. /// </summary>
  42. static void BuildForAndroid()
  43. {
  44. // 签名文件配置,若不配置,则使用Unity默认签名
  45. PlayerSettings.Android.keyaliasName = "BenheroGithub";
  46. PlayerSettings.Android.keyaliasPass = "BenheroGithub";
  47. PlayerSettings.Android.keystoreName = Application.dataPath.Replace("/Assets", "") + "/BenheroGithub.jks";
  48. PlayerSettings.Android.keystorePass = "BenheroGithub";
  49. // APK路径、名字配置
  50. string apkName = DateTime.Now.ToString("yyyyMMdd_HHmmss");
  51. string path = Application.dataPath.Replace("/Assets", "") + "/APK/" + projectName + "_" + apkName + ".apk";
  52. BuildPipeline.BuildPlayer(GetBuildScenes(), path, BuildTarget.Android, BuildOptions.None);
  53. }
  54. }

这个类中3个方法比较清晰简单,读者可以根据需求进行拓展。

2. 引入签名文件到工程的根目录下
3. 配置Android应用包名

若不配置会报错:
UnityException: Package Name has not been set up correctly
Please set the Package Name in the Player Settings. The value must follow the convention

解决方法:

  1. File/Build Settings切换Android平台
  2. Player Settings → Other Settings → Identification → Package Name输入APK包名
4. 在命令行窗口执行打包命令
5. APK生成在工程根目录中的APK文件夹下

四.工程案例

本教程中案例,已上传到GitHub上,读者可以下载尝试运行。或者可用于与自己的配置进行校验。

GitHub工程地址:https://github.com/benhero/UnityBuildAndroid

参考教程

雨松MOMO

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/119169?site
推荐阅读
相关标签
  

闽ICP备14008679号