Compare commits

..

6 Commits

10 changed files with 61 additions and 18 deletions

View File

@@ -1,4 +1,4 @@
# Trigger
## Dependencies
1. [ToggleState Module](https://git.syntriax.com/Syntriax/ToggleState)
1. [State Module](https://git.syntriax.com/Syntriax/State)

View File

@@ -11,7 +11,7 @@ namespace Syntriax.Modules.Trigger
private void OnDrawGizmosSelected()
{
if (UnityEditor.EditorApplication.isPlaying)
Gizmos.color = previousTriggerCount > 0 ? Color.green : Color.red;
Gizmos.color = previousTriggerCount > 0 && StateEnable.IsEnabled ? Color.green : Color.red;
else
Gizmos.color = TriggerCount > 0 ? Color.green : Color.red;
Gizmos.DrawWireCube(transform.position, transform.lossyScale);

View File

@@ -11,7 +11,7 @@ namespace Syntriax.Modules.Trigger
private void OnDrawGizmosSelected()
{
if (UnityEditor.EditorApplication.isPlaying)
Gizmos.color = previousTriggerCount > 0 ? Color.green : Color.red;
Gizmos.color = previousTriggerCount > 0 && StateEnable.IsEnabled ? Color.green : Color.red;
else
Gizmos.color = TriggerCount > 0 ? Color.green : Color.red;
Gizmos.matrix = transform.localToWorldMatrix;

View File

@@ -11,11 +11,12 @@ namespace Syntriax.Modules.Trigger
private void OnDrawGizmosSelected()
{
if (UnityEditor.EditorApplication.isPlaying)
Gizmos.color = previousTriggerCount > 0 ? Color.green : Color.red;
Gizmos.color = previousTriggerCount > 0 && StateEnable.IsEnabled ? Color.green : Color.red;
else
Gizmos.color = TriggerCount > 0 ? Color.green : Color.red;
Gizmos.DrawWireCube(transform.position, transform.lossyScale);
Gizmos.matrix = transform.localToWorldMatrix;
Gizmos.DrawWireCube(Vector3.zero, Vector3.one);
}
#endif
}

View File

@@ -1,4 +1,4 @@
using Syntriax.Modules.ToggleState;
using Syntriax.Modules.State;
namespace Syntriax.Modules.Trigger
{
@@ -13,7 +13,7 @@ namespace Syntriax.Modules.Trigger
private void FixedUpdate()
{
if (!ToggleStateMember.IsToggledNullChecked())
if (!StateEnable.IsEnabledNullChecked())
return;
IsTrigerred = colliderTrigger.Check();

View File

@@ -45,5 +45,17 @@ namespace Syntriax.Modules.Trigger
return true;
}
#if UNITY_EDITOR
private State.IStateEnable _stateEnable = null;
public State.IStateEnable StateEnable
{
get
{
_stateEnable = _stateEnable ?? GetComponent<State.IStateEnable>() ?? gameObject.AddComponent<State.StateEnableMonoBehaviour>();
return _stateEnable;
}
}
#endif
}
}

View File

@@ -0,0 +1,11 @@
fileFormatVersion: 2
guid: 44c565f53b853aa4a99a307b70f8288f
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -1,14 +1,14 @@
using System;
using Syntriax.Modules.ToggleState;
using Syntriax.Modules.State;
namespace Syntriax.Modules.Trigger
{
public interface ITrigger
{
/// <summary>
/// Member <see cref="IToggleState"/> to switch on or off
/// <see cref="IStateEnable"/> to control the state of the <see cref="ITrigger"/> is on or off
/// </summary>
IToggleState ToggleStateMember { get; }
IStateEnable StateEnable { get; }
/// <summary>
/// Called everytime the IsTrigerred field is changed

View File

@@ -1,22 +1,43 @@
using System;
using Syntriax.Modules.ToggleState;
using Syntriax.Modules.State;
using UnityEngine;
namespace Syntriax.Modules.Trigger
{
public class TriggerBase : MonoBehaviour, ITrigger
{
public IToggleState ToggleStateMember { get; protected set; } = new ToggleStateMember(true);
public Action<bool> OnTriggerStateChanged { get; set; } = null;
private IStateEnable _stateEnable = null;
public IStateEnable StateEnable
{
get
{
if (_stateEnable == null)
{
_stateEnable = GetComponent<IStateEnable>() ?? gameObject.AddComponent<StateEnableMonoBehaviour>();
_stateEnable.OnEnabledChanged += OnEnabledChanged;
}
return _stateEnable;
}
}
private void OnEnabledChanged(bool enabled)
{
if (enabled)
return;
_isTrigerred = false;
OnTriggerStateChanged?.Invoke(false);
}
private bool _isTrigerred = false;
public bool IsTrigerred
{
get => _isTrigerred;
protected set
{
if (value == _isTrigerred || !ToggleStateMember.IsToggledNullChecked())
if (value == _isTrigerred || !StateEnable.IsEnabledNullChecked())
return;
_isTrigerred = value;

View File

@@ -1,12 +1,10 @@
{
"name": "com.syntriax.trigger",
"version": "0.5.1",
"version": "0.3.0",
"displayName": "Trigger Module",
"unity": "2019.1",
"documentationUrl": "https://git.syntriax.com/Syntriax/Trigger.git",
"dependencies": {
"com.syntriax.toggle-state": "0.1.0"
},
"dependencies": {},
"keywords": ["Trigger"],
"author": {
"name": "Syntriax",