Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/KLab/klab-messagebuses-unity
Message bus library for Unity
https://github.com/KLab/klab-messagebuses-unity
Last synced: about 2 months ago
JSON representation
Message bus library for Unity
- Host: GitHub
- URL: https://github.com/KLab/klab-messagebuses-unity
- Owner: KLab
- License: mit
- Created: 2018-10-22T21:50:34.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-05-09T03:13:15.000Z (over 5 years ago)
- Last Synced: 2024-08-03T19:09:50.434Z (5 months ago)
- Language: C#
- Size: 28.3 KB
- Stars: 40
- Watchers: 23
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-unity-open-source-on-github - klab-messagebuses-unity - Message bus (Message Bus)
README
# *KLab Message Buses for Unity*
While not silver bullets, message buses (or [event buses as *Lumberyard* calls them](https://docs.aws.amazon.com/lumberyard/latest/userguide/ebus-in-depth.html))
can be an effective mechanism for loosen up coupling between systems.
*KLab Message Buses for Unity* provides a simple API
for using buses in *Unity* with low runtime overhead.## Usage
Using a message bus basically consists of 3 steps.
1. You declare a message bus
1. You connect to it (and later disconnect from it)
1. You send messages through the busThe below is a minimal example.
(The example uses *Unity* components for handling connecting and sending,
but you can also use message buses in pure *C#* classes).```cs
using KLab.MessageBuses;
using UnityEngine;public sealed class MyMessageBus : MessageBus {}
public sealed class Sender : MonoBehaviour
{
private const string Message = "Hello, World!";private MyMessageBus Bus { get; set; }
private void Start ()
{
Bus = MessageBus.GetBus();
}private void Update ()
{
Bus.Broadcast(Message);
}
}public sealed class Receiver : MonoBehaviour
{
private void OnMessage(string message)
{
Debug.Log(message);
}private void OnEnable()
{
MessageBus
.GetBus()
.Connect(OnMessage);
}private void OnDisable()
{
MessageBus
.GetBus()
.Disconnect(OnMessage);
}
}
```See [here](./Runtime/KLab/MessageBuses/MessageBus.cs#L90) for bus types available.
### Advanced Usage
#### Setting Initial Container Capacities
You can set initial capacities of the underlying containers used by a bus
by decorating the bus with [options](./Runtime/KLab/MessageBuses/MessageBus.cs#L25).```cs
using KLab.MessageBuses;[MessageBusOptions(connectionsCapacity : 1024)]
public sealed class MyMessageBus : MessageBus {}
```#### Finding All Connection Propertiess For Later Query
See [here](./Examples/KLab/MessageBuses/AdvancedExamples.cs#L32).
#### Finding All Waive Methods For Later Invokation
See [here](./Examples/KLab/MessageBuses/AdvancedExamples.cs#L106).
#### Creating A Non-global Bus
If you want to create a non-global message bus,
simply instantiate the message bus class directly
instead of getting the global singleton through ```MessageBus.GetBus()```.## Unity Import
The library can be imported easily as a Unity package.
It doesn't have any dependencies on other packages.## Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).### [1.1.0] - 2019-05-09
#### Added
- Add options for controlling message bus container capacities
#### Changed
- Rename package from `com.klab.messagebuses` to `com.klab.message-buses`
- Rename runtime *asmdef* from `KLab.MessageBuses` to `KLab.MessageBuses.Runtime`## Feedback
- Request a new feature on GitHub
- File a bug in GitHub Issues## License
Copyright (c) KLab Inc.. All rights reserved.
Licensed under the [MIT](LICENSE) License.