External Dependency Manager for Unity
========
# Overview
The External Dependency Manager for Unity (EDM4U)
(formerly Play Services Resolver / Jar Resolver) is intended to be used by any
Unity plugin that requires:
* Android specific libraries (e.g
[AARs](https://developer.android.com/studio/projects/android-library.html)).
* iOS [CocoaPods](https://cocoapods.org/).
* Version management of transitive dependencies.
* Management of Package Manager (PM) Registries.
Updated releases are available on
[GitHub](https://github.com/googlesamples/unity-jar-resolver)
# Background
Many Unity plugins have dependencies upon Android specific libraries, iOS
CocoaPods, and sometimes have transitive dependencies upon other Unity plugins.
This causes the following problems:
* Integrating platform specific (e.g Android and iOS) libraries within a
Unity project can be complex and a burden on a Unity plugin maintainer.
* The process of resolving conflicting dependencies on platform specific
libraries is pushed to the developer attempting to use a Unity plugin.
The developer trying to use your plugin is very likely to give up when
faced with Android or iOS specific build errors.
* The process of resolving conflicting Unity plugins (due to shared Unity
plugin components) is pushed to the developer attempting to use your Unity
plugin. In an effort to resolve conflicts, the developer will very likely
attempt to resolve problems by deleting random files in your plugin,
report bugs when that doesn't work and finally give up.
EDM provides solutions for each of these problems.
## Android Dependency Management
The *Android Resolver* component of this plugin will download and integrate
Android library dependencies and handle any conflicts between plugins that share
the same dependencies.
Without the Android Resolver, typically Unity plugins bundle their AAR and
JAR dependencies, e.g. a Unity plugin `SomePlugin` that requires the Google
Play Games Android library would redistribute the library and its transitive
dependencies in the folder `SomePlugin/Android/`. When a user imports
`SomeOtherPlugin` that includes the same libraries (potentially at different
versions) in `SomeOtherPlugin/Android/`, the developer using `SomePlugin` and
`SomeOtherPlugin` will see an error when building for Android that can be hard
to interpret.
Using the Android Resolver to manage Android library dependencies:
* Solves Android library conflicts between plugins.
* Handles all of the various processing steps required to use Android
libraries (AARs, JARs) in Unity 4.x and above projects. Almost all
versions of Unity have - at best - partial support for AARs.
* (Experimental) Supports minification of included Java components without
exporting a project.
## iOS Dependency Management
The *iOS Resolver* component of this plugin integrates with
[CocoaPods](https://cocoapods.org/) to download and integrate iOS libraries
and frameworks into the Xcode project Unity generates when building for iOS.
Using CocoaPods allows multiple plugins to utilize shared components without
forcing developers to fix either duplicate or incompatible versions of
libraries included through multiple Unity plugins in their project.
## Package Manager Registry Setup
The [Package Manager](https://docs.unity3d.com/Manual/Packages.html)
(PM) makes use of [NPM](https://www.npmjs.com/) registry servers for package
hosting and provides ways to discover, install, upgrade and uninstall packages.
This makes it easier for developers to manage plugins within their projects.
However, installing additional package registries requires a few manual steps
that can potentially be error prone. The *Package Manager Resolver*
component of this plugin integrates with
[PM](https://docs.unity3d.com/Manual/Packages.html) to provide a way to
auto-install PM package registries when a `.unitypackage` is installed which
allows plugin maintainers to ship a `.unitypackage` that can provide access
to their own PM registry server to make it easier for developers to
manage their plugins.
## Unity Plugin Version Management
Finally, the *Version Handler* component of this plugin simplifies the process
of managing transitive dependencies of Unity plugins and each plugin's upgrade
process.
For example, without the Version Handler plugin, if:
* Unity plugin `SomePlugin` includes `EDM4U` plugin at
version 1.1.
* Unity plugin `SomeOtherPlugin` includes `EDM4U`
plugin at version 1.2.
The version of `EDM4U` included in the developer's project depends upon the
order the developer imports `SomePlugin` or `SomeOtherPlugin`.
This results in:
* `EDM4U` at version 1.2, if `SomePlugin` is imported then `SomeOtherPlugin`
is imported.
* `EDM4U` at version 1.1, if `SomeOtherPlugin` is imported then
`SomePlugin` is imported.
The Version Handler solves the problem of managing transitive dependencies by:
* Specifying a set of packaging requirements that enable a plugin at
different versions to be imported into a Unity project.
* Providing activation logic that selects the latest version of a plugin
within a project.
When using the Version Handler to manage `EDM4U` included in `SomePlugin` and
`SomeOtherPlugin`, from the prior example, version 1.2 will always be the
version activated in a developer's Unity project.
Plugin creators are encouraged to adopt this library to ease integration for
their customers. For more information about integrating EDM4U
into your own plugin, see the [Plugin Redistribution](#plugin-redistribution)
section of this document.
# Analytics
The External Dependency Manager for Unity plugin by default logs usage to Google
Analytics. The purpose of the logging is to quantitatively measure the usage of
functionality, to gather reports on integration failures and to inform future
improvements to the developer experience of the External Dependency Manager
plugin. Note that the analytics collected are limited to the scope of the EDM4U
plugin’s usage.
For details of what is logged, please refer to the usage of
`EditorMeasurement.Report()` in the source code.
# Requirements
The *Android Resolver* and *iOS Resolver* components of the plugin only work
with Unity version 4.6.8 or higher.
The *Version Handler* component only works with Unity 5.x or higher as it
depends upon the `PluginImporter` UnityEditor API.
The *Package Manager Resolver* component only works with
Unity 2018.4 or above, when
[scoped registry](https://docs.unity3d.com/Manual/upm-scoped.html)
support was added to the Package Manager.
# Getting Started
Before you import EDM4U into your plugin project, you first
need to consider whether you intend to *redistribute* `EDM4U`
along with your own plugin.
## Plugin Redistribution
If you're a plugin maintainer, redistributing `EDM4U` inside your own plugin
will ease the integration process for your users, by resolving dependency
conflicts between your plugin and other plugins in a user's project.
If you wish to redistribute `EDM4U` inside your plugin,
you **must** follow these steps when importing the
`external-dependency-manager-*.unitypackage`, and when exporting your own plugin
package:
1. Import the `external-dependency-manager-*.unitypackage` into your plugin
project by
[running Unity from the command line](https://docs.unity3d.com/Manual/CommandLineArguments.html), ensuring that
you add the `-gvh_disable` option.
1. Export your plugin by [running Unity from the command line](https://docs.unity3d.com/Manual/CommandLineArguments.html), ensuring that
you:
- Include the contents of the `Assets/PlayServicesResolver` and
`Assets/ExternalDependencyManager` directory.
- Add the `-gvh_disable` option.
You **must** specify the `-gvh_disable` option in order for the Version
Handler to work correctly!
For example, the following command will
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
Unity 广告SDK Max聚合广告SDK (333个子文件)
AdjustSdk.a 12.17MB
applovin-max-unity-plugin.aar 73KB
MaxSdk.Scripts.Editor.asmdef 222B
MaxSdk.IntegrationManager.Editor.asmdef 189B
MaxSdk.Scripts.asmdef 113B
ProjectSettings.asset 26KB
InputManager.asset 6KB
QualitySettings.asset 5KB
GraphicsSettings.asset 2KB
Physics2DSettings.asset 2KB
PackageManagerSettings.asset 1KB
NavMeshAreas.asset 1KB
DynamicsManager.asset 1KB
AppLovinSettings.asset 959B
UnityConnectSettings.asset 901B
EditorSettings.asset 715B
EditorUserSettings.asset 601B
AdjustSettings.asset 462B
TagManager.asset 378B
AudioManager.asset 360B
EditorBuildSettings.asset 324B
TimeManager.asset 195B
VersionControlSettings.asset 188B
XRSettings.asset 158B
VFXManager.asset 157B
NetworkManager.asset 151B
PresetManager.asset 120B
ClusterInputManager.asset 114B
MaxSdkCallbacks.cs 69KB
MaxSdkiOS.cs 64KB
MaxSdkUnityEditor.cs 63KB
MaxSdkAndroid.cs 56KB
AppLovinIntegrationManagerWindow.cs 47KB
AdjustAndroid.cs 41KB
AppLovinIntegrationManager.cs 35KB
MaxPostProcessBuildiOS.cs 33KB
SimpleJSON.cs 32KB
MaxSdkBase.cs 28KB
AdjustEditor.cs 26KB
Adjust.cs 25KB
AppLovinProcessGradleBuildFile.cs 24KB
HomeScreen.cs 21KB
AdjustiOS.cs 21KB
MaxSdkUtils.cs 21KB
MiniJSON.cs 20KB
AppLovinSettings.cs 18KB
AppLovinInternalSettings.cs 16KB
AdjustWindows.cs 14KB
AdjustUtils.cs 12KB
MaxPostProcessBuildAndroid.cs 12KB
ExampleGUI.cs 10KB
AppLovinAutoUpdater.cs 9KB
AppLovinPreProcessAndroid.cs 9KB
AdjustConfig.cs 9KB
MaxInitialization.cs 6KB
AppLovinPostProcessiOS.cs 4KB
AdjustAttribution.cs 4KB
AdjustEventFailure.cs 3KB
AdjustSettings.cs 3KB
AppLovinCommandLine.cs 3KB
MaxTargetingData.cs 3KB
AdjustEventSuccess.cs 3KB
AdjustSessionFailure.cs 3KB
AppLovinEditorCoroutine.cs 3KB
AdjustSessionSuccess.cs 3KB
AppLovinPostProcessAndroidGradle.cs 2KB
AppLovinDownloadHandler.cs 2KB
MaxSdkLogger.cs 2KB
AdjustEvent.cs 2KB
AdjustAdRevenue.cs 2KB
AdjustLogLevel.cs 2KB
AppLovinMenuItems.cs 2KB
AdjustAppStoreSubscription.cs 2KB
MaxVariableServiceiOS.cs 2KB
AdjustPlayStoreSubscription.cs 2KB
MaxVariableServiceAndroid.cs 1KB
MaxUserServiceUnityEditor.cs 1KB
MaxUserServiceAndroid.cs 1KB
MaxVariableServiceUnityEditor.cs 1KB
AdjustThirdPartySharing.cs 1KB
MaxEventSystemChecker.cs 1016B
MaxUserServiceiOS.cs 988B
MaxEvents.cs 842B
MaxUserSegment.cs 733B
MaxSdk.cs 634B
AdjustEnvironment.cs 595B
Newtonsoft.Json.dll 474KB
Google.JarResolver.dll 342KB
WindowsPcl.dll 125KB
Google.VersionHandlerImpl.dll 116KB
Google.PackageManagerResolver.dll 72KB
Google.IOSResolver.dll 69KB
AdjustUAP10.dll 24KB
AdjustWP81.dll 23KB
AdjustWS.dll 23KB
WindowsUap.dll 18KB
Google.VersionHandler.dll 15KB
Win10Interface.dll 13KB
Win81Interface.dll 12KB
WinWsInterface.dll 12KB
共 333 条
- 1
- 2
- 3
- 4
资源评论
icube3d
- 粉丝: 2
- 资源: 29
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Surfer,线性函数
- MyBatis 的动态 SQL 是其核心特性之一.txt
- 时代的sdddsddsddsd
- 基于哈希链表的简单人员信息管理系统
- 其他类别JdonFramework开源框架 v5.1 Build20071025-jdonframework-5.1.rar
- 2001~2022年上市公司数字赋能指数.dta
- 2001~2022年上市公司数字赋能指数.xlsx
- 信息办公石大在线财务管理系统(含源码)-shidacaiwu.rar
- 信息办公电信计费系统完整代码-netctossconformity.rar
- matlab实现TD-SCDMA中初始同步捕捉DwPTS下行同步导频时隙的仿真.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功