mirror of
https://github.com/unity-atoms/unity-atoms.git
synced 2025-01-22 08:08:51 -05:00
Improve docs - setup basic structure
This commit is contained in:
parent
327dd87222
commit
eb22ac1626
114
README.md
114
README.md
@ -1,98 +1,62 @@
|
||||
# ⚛️ Unity Atoms
|
||||
*Tiny modular pieces utilizing the power of Scriptable Objects*
|
||||
|
||||
Read [this](https://medium.com/@adamramberg/unity-atoms-tiny-modular-pieces-utilizing-the-power-of-scriptable-objects-e8add1b95201) article on Medium for a great introduction to Unity Atoms.
|
||||
_Tiny modular pieces utilizing the power of Scriptable Objects_
|
||||
|
||||
## Influences
|
||||
|
||||
Unity Atoms is derrived from and a continuation of Ryan Hipple's [talk](https://www.youtube.com/watch?v=raQ3iHhE_Kk&t=2787s) from Unite 2017. The original source code can be found [here](https://github.com/roboryantron/Unite2017).
|
||||
|
||||
[This](https://www.youtube.com/watch?v=6vmRwLYWNRo&t=738s) talk by Richard Fine is a forerunner to Ryan Hipple's talk during Unite 2016.
|
||||
|
||||
## Motivation
|
||||
|
||||
The general approach to building scripts in Unity often generates a code base that is monolithic. This results in that your code is cumbersome to test, non-modular and hard to debug and understand.
|
||||
|
||||
Unity Atoms is an open source library that aims to make your game code:
|
||||
- 📦 Modular *- avoid scripts and systems directly dependent on each other*
|
||||
- ✏️ Editable *- Scriptable Objects makes it possible to make changes to your game at runtime*
|
||||
- 🐞 Debuggable *- modular code is easier to debug than tightly coupled code*
|
||||
Unity Atoms is an open source library that aims to make your game code:
|
||||
|
||||
## Introduction
|
||||
Before you start looking into this library you should watch the video above ☝️ and read [this](https://unity3d.com/how-to/architect-with-scriptable-objects) article on how to architect your game with Scriptable Objects.
|
||||
- 📦 Modular _- avoid scripts and systems directly dependent on each other_
|
||||
- ✏️ Editable _- Scriptable Objects makes it possible to make changes to your game at runtime_
|
||||
- 🐛 Debuggable _- modular code is easier to debug than tightly coupled code_
|
||||
|
||||
## Installation
|
||||
*Prerequisite: Since Unity Atoms is using the Unity Package Manager (UPM) you need to use Unity version 2018.3 >=*
|
||||
|
||||
There are 2 versions you can install, either the stable version (master branch) or the canary version (latest and greatest - canary branch). Be aware that the canary version might sometimes break.
|
||||
_Prerequisite: Since Unity Atoms is using the Unity Package Manager (UPM) you need to use Unity version 2018.3 >=_
|
||||
|
||||
### Stable
|
||||
Go to your projects `Packages/manifest.json` and add this:
|
||||
"dependencies": {
|
||||
Add the following to your `manifest.json`:
|
||||
|
||||
```
|
||||
{
|
||||
"scopedRegistries": [
|
||||
{
|
||||
"name": "NPM Registry",
|
||||
"url": "https://registry.npmjs.org",
|
||||
"scopes": [
|
||||
"com.mambojambostudios.unity-atoms-core",
|
||||
"com.mambojambostudios.unity-atoms-mobile",
|
||||
"com.mambojambostudios.unity-atoms-tags",
|
||||
"com.mambojambostudios.unity-atoms-scene-mgmt",
|
||||
"com.mambojambostudios.unity-atoms-ui"
|
||||
]
|
||||
}
|
||||
],
|
||||
"dependencies": {
|
||||
...
|
||||
"com.mambojambostudios.unity-atoms": "https://github.com/AdamRamberg/unity-atoms.git",
|
||||
"com.mambojambostudios.unity-atoms-core": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-mobile": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-tags": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-scene-mgmt": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-ui": "2.0.0",
|
||||
...
|
||||
}
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
### Canary
|
||||
Go to your projects `Packages/manifest.json` and add this:
|
||||
"dependencies": {
|
||||
...
|
||||
"com.mambojambostudios.unity-atoms": "https://github.com/AdamRamberg/unity-atoms.git#canary",
|
||||
...
|
||||
}
|
||||
Note that the core package is mandatory while the others are optional. If you don't want a subpackage, simply remove it from your `dependencies`.
|
||||
|
||||
## Documentation
|
||||
|
||||
## Usage
|
||||
Unity Atoms is an event based system that encourages the game to be as data-driven as possible. The 4 most fundamental pieces (atoms) of Unity Atoms are:
|
||||
- Variables
|
||||
- (Game) Events
|
||||
- (Game Event) Listeners
|
||||
- Responses
|
||||
The Unity Atoms docs are now published at **https://adamramberg.github.io/unity-atoms**.
|
||||
|
||||
### Variables
|
||||
Variables are data / variables stored as Scriptable Objects. Because Variables are stored as Scriptable Objects they are not part of any scene, but could be instead be seen as part of a global shared game state. Variables are also designed to make it easy to inject (via the Unity Inspector) to your MonoBehaviours.
|
||||
|
||||
It is possible to attach an event to a Variable that gets raised when its updated. This makes it possible to write more data-driven code.
|
||||
|
||||
It is also possible to attach another event to a Variable that also gets raised when a Variable is changed, but that contains both the old and the new value of the Variable.
|
||||
|
||||
Unity Atoms also offer some variations / additions to Variables such as Contants, References and Lists.
|
||||
|
||||
#### Constants
|
||||
Exactly the same as Variables, but can not be changed via script and therefore does not contain the change events that Variables does. The idea is to use Constants for for example tags instead of hard coding tags in your scripts.
|
||||
|
||||
#### References
|
||||
References can be toggled between "use as constant" or "use variable" via the Unity Inspector. When a reference is "used as constant" then it functions exactly like a regular serialized variable in a MonoBehaviour script. However, when it is set to "use variable" it functions exactly like a Variable.
|
||||
|
||||
#### Lists
|
||||
A list is an array of values that is stored as a Scriptable Object. There is the possibility to add Game Events for when the following happens to the list:
|
||||
- An item is added to the list.
|
||||
- An item is removed from the list.
|
||||
- The list is cleared.
|
||||
|
||||
### Game Events
|
||||
A game event is a thing that happens in the game that others could listen / subscribe to. Game events are also Scriptable Objects that lives outside of a specific scene. It is possible to raise a Game Event from the Unity Inspector for debug purposes.
|
||||
|
||||
### Game Event Listeners
|
||||
A listener listens / observes / subscribes to an event and raises / invokes zero to many responses to that event. Game Event Listeners are Monobehaviours and lives in a scene. See below for more information on the type of responses there are.
|
||||
|
||||
### Responses
|
||||
A responses is raised by a listener in response to an event. Responses can live both in the scene as [UnityEvents](https://docs.unity3d.com/ScriptReference/Events.UnityEvent.html) or outside the scene as a Scriptable Object in the shape of a Game Action or a Game Function.
|
||||
|
||||
#### Game Actions
|
||||
A Game Action is a C# function as a Scriptable Object. A Game Function can be used as a response in a Game Event Listener.
|
||||
|
||||
#### Game Functions
|
||||
A Game Function is basically the same as a Game Action, but while a Game Actions does not return something a Game Function does.
|
||||
|
||||
### Mono Hooks
|
||||
Mono Hooks is a way to make it possible to have Unity lifecycle methods as events. The main reason for this is to make this pattern consistent and possible to use in ALL of your code.
|
||||
|
||||
## Further Notes
|
||||
When you start thinking about this pattern you will realize that everything can be explained using the atoms above. The native Unity lifecycle methods can be thought of as variation of the pattern above, where events gets raised and passes a long data (eg. OnTriggerEnter2D) and you write a response to that event.
|
||||
|
||||
## Examples
|
||||
Examples can be found in the UnityAtomsTestsAndExamples folder.
|
||||
|
||||
## Contributing
|
||||
The main purpose of this repository is to evolve Unity Atoms to make it faster and easier to use. Development of this library happens out in the open on Github. It's great to see that many wants to contribute to this project 🙏 Read [here](CONTRIBUTING.md) if you want to contribute to Unity Atoms.
|
||||
## How does it work?
|
||||
|
||||
Read [this](https://medium.com/@adamramberg/unity-atoms-tiny-modular-pieces-utilizing-the-power-of-scriptable-objects-e8add1b95201) article on Medium for a great introduction to Unity Atoms.
|
||||
|
23
docs/README.md
Normal file
23
docs/README.md
Normal file
@ -0,0 +1,23 @@
|
||||
# Table of Contents
|
||||
|
||||
- Introduction
|
||||
- [Quick start: adding Unity Atoms your project](./introduction/quick-start.md)
|
||||
- [Overview and philosopy](./introduction/overview.md)
|
||||
- [Basic tutorial](./introduction/basic-tutorial.md)
|
||||
- [Usage with UniRX](./introduction/unirx.md)
|
||||
- [Level up using the Generator](./introduction/generator.md)
|
||||
- API
|
||||
- [Actions](./api/actions.md)
|
||||
- [Constants](./api/constants.md)
|
||||
- [Events](./api/events.md)
|
||||
- [Functions](./api/functions.md)
|
||||
- [Listeners](./api/listeners.md)
|
||||
- [Lists](./api/lists.md)
|
||||
- [References](./api/references.md)
|
||||
- [Unity Events](./api/unity-events.md)
|
||||
- [Variables](./api/variables.md)
|
||||
- Subpackages
|
||||
- [Mobile](./subpackages/mobile.md)
|
||||
- [SceneMgmt](./subpackages/scene-mgmt.md)
|
||||
- [Tags](./subpackages/tags.md)
|
||||
- [UI](./subpackages/ui.md)
|
3
docs/api/actions.md
Normal file
3
docs/api/actions.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Actions
|
||||
|
||||
[**TODO**]
|
3
docs/api/constants.md
Normal file
3
docs/api/constants.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Constants
|
||||
|
||||
[**TODO**]
|
3
docs/api/events.md
Normal file
3
docs/api/events.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Events
|
||||
|
||||
[**TODO**]
|
3
docs/api/functions.md
Normal file
3
docs/api/functions.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Functions
|
||||
|
||||
[**TODO**]
|
3
docs/api/listeners.md
Normal file
3
docs/api/listeners.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Listeners
|
||||
|
||||
[**TODO**]
|
3
docs/api/lists.md
Normal file
3
docs/api/lists.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Lists
|
||||
|
||||
[**TODO**]
|
3
docs/api/references.md
Normal file
3
docs/api/references.md
Normal file
@ -0,0 +1,3 @@
|
||||
# References
|
||||
|
||||
[**TODO**]
|
3
docs/api/unity-events.md
Normal file
3
docs/api/unity-events.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Unity Events
|
||||
|
||||
[**TODO**]
|
3
docs/api/variables.md
Normal file
3
docs/api/variables.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Variables
|
||||
|
||||
[**TODO**]
|
3
docs/introduction/basic-tutorial.md
Normal file
3
docs/introduction/basic-tutorial.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Basic tutorial
|
||||
|
||||
[**TODO**]
|
3
docs/introduction/generator.md
Normal file
3
docs/introduction/generator.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Generator
|
||||
|
||||
[**TODO**]
|
54
docs/introduction/overview.md
Normal file
54
docs/introduction/overview.md
Normal file
@ -0,0 +1,54 @@
|
||||
# Overview and philosopy
|
||||
|
||||
Unity Atoms is an event based system that encourages the game to be as data-driven as possible. The four most fundamental parts of Unity Atoms are:
|
||||
|
||||
- Variables
|
||||
- Events
|
||||
- Listeners
|
||||
- Responses
|
||||
|
||||
## Variables
|
||||
|
||||
Variables are data / variables stored as Scriptable Objects. Because Variables are stored as Scriptable Objects they are not part of any scene, but could be instead be seen as part of a global shared game state. Variables are also designed to make it easy to inject (via the Unity Inspector) to your MonoBehaviours.
|
||||
|
||||
It is possible to attach an event to a Variable that gets raised when its updated. This makes it possible to write more data-driven code.
|
||||
|
||||
It is also possible to attach another event to a Variable that also gets raised when a Variable is changed, but that contains both the old and the new value of the Variable.
|
||||
|
||||
Unity Atoms also offer some variations / additions to Variables such as Contants, References and Lists.
|
||||
|
||||
### Constants
|
||||
|
||||
Exactly the same as Variables, but can not be changed via script and therefore does not contain the change events that Variables does. The idea is to use Constants for for example tags instead of hard coding tags in your scripts.
|
||||
|
||||
### References
|
||||
|
||||
References can be toggled between `use as constant` or `use variable` via the Unity Inspector. When a reference is `used as constant` then it functions exactly like a regular serialized variable in a MonoBehaviour script. However, when it is set to `use variable` it functions exactly like a Variable.
|
||||
|
||||
#### Lists
|
||||
|
||||
A List is an array of values that is stored as a Scriptable Object. There is the possibility to add Events for when the following happens to the list:
|
||||
|
||||
- An item is added to the List.
|
||||
- An item is removed from the List.
|
||||
- The List is cleared.
|
||||
|
||||
### Events
|
||||
|
||||
An event is a thing that happens in the game that others can listen / subscribe to. Events in Unity Atoms are also Scriptable Objects that lives outside of a specific scene. It is possible to raise an Event from the Unity Inspector for debug purposes.
|
||||
|
||||
### Listeners
|
||||
|
||||
A Listener listens / observes / subscribes to an event and raises / invokes zero to many responses to that event. Listeners are MonoBehaviours and lives in a scene. See below for more information on the type of responses there are.
|
||||
|
||||
### Responses
|
||||
|
||||
A responses is raised by a listener in response to an event. Responses can live both in the scene as [UnityEvents](https://docs.unity3d.com/ScriptReference/Events.UnityEvent.html) or outside the scene as a Scriptable Object in the shape of an Action.
|
||||
|
||||
#### Actions
|
||||
|
||||
An Action in Unity Atoms is a C# function as a Scriptable Object. An Action can be used as a response in a Listener.
|
||||
|
||||
#### Game Functions
|
||||
|
||||
A Function in Unity Atoms is basically the same as an Action, but while an Actions does not return something a Function does.
|
60
docs/introduction/quick-start.md
Normal file
60
docs/introduction/quick-start.md
Normal file
@ -0,0 +1,60 @@
|
||||
# Quick start
|
||||
|
||||
## Installation
|
||||
|
||||
_Prerequisite: Since Unity Atoms is using the Unity Package Manager (UPM) you need to use Unity version 2018.3 >=_
|
||||
|
||||
### NPM (Recommended)
|
||||
|
||||
Add the following to your `manifest.json`:
|
||||
|
||||
```
|
||||
{
|
||||
"scopedRegistries": [
|
||||
{
|
||||
"name": "NPM Registry",
|
||||
"url": "https://registry.npmjs.org",
|
||||
"scopes": [
|
||||
"com.mambojambostudios.unity-atoms-core",
|
||||
"com.mambojambostudios.unity-atoms-mobile",
|
||||
"com.mambojambostudios.unity-atoms-tags",
|
||||
"com.mambojambostudios.unity-atoms-scene-mgmt",
|
||||
"com.mambojambostudios.unity-atoms-ui"
|
||||
]
|
||||
}
|
||||
],
|
||||
"dependencies": {
|
||||
...
|
||||
"com.mambojambostudios.unity-atoms-core": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-mobile": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-tags": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-scene-mgmt": "2.0.0",
|
||||
"com.mambojambostudios.unity-atoms-ui": "2.0.0",
|
||||
...
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
Note that the core package is mandatory while the others are optional. If you don't want a subpackage, simply remove it from your `dependencies`.
|
||||
|
||||
### Github URL
|
||||
|
||||
There is an alternative approach installing Unity Atoms using the Github URL to this repo.
|
||||
|
||||
Add the following to your `manifest.json`:
|
||||
|
||||
```
|
||||
{
|
||||
"dependencies": {
|
||||
...
|
||||
"com.mambojambostudios.unity-atoms": "https://github.com/AdamRamberg/unity-atoms.git",
|
||||
...
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## Create your first Atom
|
||||
|
||||
You are now ready to create your first Atom. Simply right click somewhere in the Project window and go to **Create / Unity Atoms** and pick the Atom of your choice.
|
||||
|
||||
[**TODO: Add image on the right click menu**]
|
3
docs/introduction/unirx.md
Normal file
3
docs/introduction/unirx.md
Normal file
@ -0,0 +1,3 @@
|
||||
# Usage with UniRX
|
||||
|
||||
[**TODO**]
|
7
docs/subpackages/mobile.md
Normal file
7
docs/subpackages/mobile.md
Normal file
@ -0,0 +1,7 @@
|
||||
# Unity Atoms / Mobile
|
||||
|
||||
[**TODO**]
|
||||
|
||||
## What does it do?
|
||||
|
||||
## API
|
7
docs/subpackages/scene-mgmt.md
Normal file
7
docs/subpackages/scene-mgmt.md
Normal file
@ -0,0 +1,7 @@
|
||||
# Unity Atoms / Scene Mgmt
|
||||
|
||||
[**TODO**]
|
||||
|
||||
## What does it do?
|
||||
|
||||
## API
|
7
docs/subpackages/tags.md
Normal file
7
docs/subpackages/tags.md
Normal file
@ -0,0 +1,7 @@
|
||||
# Unity Atoms / Tags
|
||||
|
||||
[**TODO**]
|
||||
|
||||
## What does it do?
|
||||
|
||||
## API
|
7
docs/subpackages/ui.md
Normal file
7
docs/subpackages/ui.md
Normal file
@ -0,0 +1,7 @@
|
||||
# Unity Atoms / UI
|
||||
|
||||
[**TODO**]
|
||||
|
||||
## What does it do?
|
||||
|
||||
## API
|
Loading…
Reference in New Issue
Block a user