-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
109 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,111 @@ | ||
# UniDI | ||
# MonoInjector | ||
|
||
Fast and easy to use dependency injection library for Unity game engine. | ||
|
||
https://github.com/arty-F/MonoInjector.git?path=Assets/MonoInjector | ||
- **Delegate based reflection hooks** for ultra fast resolving speed. | ||
- **Caching** reflection data for reducing allocations. | ||
- **Small codebase**. | ||
- **Easy to use**. | ||
- **DOES NOT CONTAIN UNNECESSARY FUNCTIONALITY** like other popular di frameworks. | ||
|
||
## Features | ||
|
||
- **Field** injection. | ||
- **Property** injection. | ||
- **Method** injection. | ||
|
||
## Installation | ||
|
||
### Install from git URL | ||
|
||
Requires a version of unity that supports path query parameter for git packages (Unity 2021.3 or later). You can add a reference `https://github.com/arty-F/MonoInjector.git?path=Assets/MonoInjector` to Package Manager. | ||
|
||
![Screenshot_1](https://github.com/arty-F/MonoInjector/assets/49113047/0a65d9e3-89f2-44ed-8232-713660590d6f) | ||
|
||
### Install from .unitypackage | ||
|
||
Download the latest .unitypackage file from [releases](https://github.com/arty-F/MonoInjector/releases) page and import downloaded package into unity. | ||
|
||
![Screenshot_2](https://github.com/arty-F/MonoInjector/assets/49113047/4bb02ea9-bd94-4ab4-8d73-54a64661e2d8) | ||
|
||
## Usage | ||
|
||
1. Add `MonoInjectorContext` component to any `GameObject` on scene (the injected dependencies lifecycle will be associated with this object). | ||
|
||
2. Mark field/property/method into which the dependency should be injected with the `[Inject]` attribute. | ||
```csharp | ||
using MonoInjector; | ||
|
||
public class TestClass | ||
{ | ||
[Inject] private InjectedClass1 _injectedField; | ||
|
||
[Inject] public InjectedClass2 InjectedProperty { get; private set; } | ||
|
||
[Inject] | ||
public void Method(InjectedClass3 p1, InjectedClass4 p2) | ||
{ | ||
_injectedFromMethod1 = p1; | ||
_injectedFromMethod2 = p2; | ||
} | ||
private InjectedClass3 _injectedFromMethod1; | ||
private InjectedClass4 _injectedFromMethod2; | ||
} | ||
``` | ||
|
||
3. Inject instances by invoking `Inject()` method (this is a part of library extension method). | ||
```csharp | ||
var instance1 = new InjectedClass1(); | ||
instance1.Inject(); | ||
|
||
var instance2 = Instantiate(prefab); | ||
instance2.Inject(); | ||
``` | ||
|
||
4. Resolve dependencies of injection consumer classes by invoking `Resolve()` method. | ||
```csharp | ||
var consumer1 = new TestClass(); | ||
consumer1.Resolve(); | ||
|
||
var consumer2 = Instantiate(prefab); | ||
consumer2.Resolve(); | ||
``` | ||
Or you can use `GameObject` extension method to one row instantiating and resolving dependencies (has 9 overloads like original Instantiate method). | ||
```csharp | ||
[SerializeField] GameObject _prefab; | ||
|
||
private void Start() | ||
{ | ||
var object1 = _prefab.InstantiateResolve(); | ||
var object2 = _prefab.InstantiateResolve(position, rotation); | ||
} | ||
``` | ||
|
||
## Performance | ||
|
||
### Field Injection | ||
|
||
four fields in instance, different types | ||
| | Time | GC Alloc | | ||
| ------------- | ------------- | ------------- | | ||
| 1 instance | 13 ms | 46 KB | | ||
| 100 instances | 15 ms | 80 KB | | ||
| 1000 instances | 28 ms | 389 KB | | ||
|
||
### Property Injection | ||
|
||
four properties in instance, different types | ||
| | Time | GC Alloc | | ||
| ------------- | ------------- | ------------- | | ||
| 1 instance | 4 ms | 21 KB | | ||
| 100 instances | 6 ms | 56 KB | | ||
| 1000 instances | 20 ms | 365 KB | | ||
|
||
### Method Injection | ||
|
||
four method parameters, different types | ||
| | Time | GC Alloc | | ||
| ------------- | ------------- | ------------- | | ||
| 1 instance | 3 ms | 19 KB | | ||
| 100 instances | 4 ms | 19 KB | | ||
| 1000 instances | 6 ms | 19 KB | |