BREAKING CHANGE: Toggle 0.2.0
This commit is contained in:
parent
d11aab596d
commit
25be6929f2
@ -99,7 +99,7 @@ namespace Syntriax.Modules.Movement.Editor
|
|||||||
movementDefinition.MonoBehaviours = new string[]
|
movementDefinition.MonoBehaviours = new string[]
|
||||||
{
|
{
|
||||||
typeof(MovementController).FullName,
|
typeof(MovementController).FullName,
|
||||||
typeof(ToggleState.ToggleStateMonoBehaviour).FullName
|
typeof(State.StateEnableMonoBehaviour).FullName
|
||||||
};
|
};
|
||||||
|
|
||||||
UpdateSerializedObject();
|
UpdateSerializedObject();
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# Movement (Work In Progress)
|
# Movement (Work In Progress)
|
||||||
|
|
||||||
## Dependencies
|
## Dependencies
|
||||||
1. [ToggleState Module](https://git.syntriax.com/Syntriax/ToggleState)
|
1. [State Module](https://git.syntriax.com/Syntriax/State)
|
||||||
2. [Trigger Module](https://git.syntriax.com/Syntriax/Trigger)
|
2. [Trigger Module](https://git.syntriax.com/Syntriax/Trigger)
|
||||||
3. [Factory Module](https://git.syntriax.com/Syntriax/Factory)
|
3. [Factory Module](https://git.syntriax.com/Syntriax/Factory)
|
||||||
|
|
||||||
@ -32,7 +32,7 @@ Make sure to separately clone these modules along with this one too.
|
|||||||
#### Longer
|
#### Longer
|
||||||
|
|
||||||
1. Clone the module to a folder in your Assets folder
|
1. Clone the module to a folder in your Assets folder
|
||||||
2. Add `ToggleStateMonoBehaviour` component to your Player `GameObject`
|
2. Add `StateEnableMonoBehaviour` component to your Player `GameObject`
|
||||||
3. Add `MovementController` component to your Player `GameObject`
|
3. Add `MovementController` component to your Player `GameObject`
|
||||||
4. Add `AirMovement1D` component to your Player `GameObject`
|
4. Add `AirMovement1D` component to your Player `GameObject`
|
||||||
5. Add `GroundMovement1D` component to your Player `GameObject` (make sure it's bellow `AirMovement1D`)
|
5. Add `GroundMovement1D` component to your Player `GameObject` (make sure it's bellow `AirMovement1D`)
|
||||||
@ -42,7 +42,7 @@ Make sure to separately clone these modules along with this one too.
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
This should give you a movement where you can disable the controller through the `IToggleState`, and you should be able to see a the movement changes when the character is not touching the ground.
|
This should give you a movement where you can disable the controller through the `IStateEnable`, and you should be able to see a the movement changes when the character is not touching the ground.
|
||||||
|
|
||||||
You can add your own movement implementations with bases under the `Bases` folder, or straight up from the `IMovement` interface.
|
You can add your own movement implementations with bases under the `Bases` folder, or straight up from the `IMovement` interface.
|
||||||
|
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
using System;
|
using System;
|
||||||
using Syntriax.Modules.ToggleState;
|
using Syntriax.Modules.State;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
|
||||||
namespace Syntriax.Modules.Movement
|
namespace Syntriax.Modules.Movement
|
||||||
{
|
{
|
||||||
public abstract class MovementBase : MonoBehaviour, IMovement
|
public abstract class MovementBase : MonoBehaviour, IMovement
|
||||||
{
|
{
|
||||||
protected IToggleState toggleState = null;
|
protected IStateEnable stateEnable = null;
|
||||||
protected IMovementController movementController = null;
|
protected IMovementController movementController = null;
|
||||||
|
|
||||||
public float BaseSpeed { get; set; } = 1f;
|
public float BaseSpeed { get; set; } = 1f;
|
||||||
@ -27,8 +27,6 @@ namespace Syntriax.Modules.Movement
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public IToggleState ToggleState { get; protected set; } = null;
|
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
public abstract void ApplyMovement();
|
public abstract void ApplyMovement();
|
||||||
|
|
||||||
@ -46,7 +44,7 @@ namespace Syntriax.Modules.Movement
|
|||||||
|
|
||||||
protected virtual void Start()
|
protected virtual void Start()
|
||||||
{
|
{
|
||||||
toggleState = GetComponent<IToggleState>();
|
stateEnable = GetComponent<IStateEnable>();
|
||||||
movementController = GetComponent<IMovementController>();
|
movementController = GetComponent<IMovementController>();
|
||||||
|
|
||||||
movementController.OnMovementActivated += OnActivated;
|
movementController.OnMovementActivated += OnActivated;
|
||||||
|
@ -1,15 +1,15 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Syntriax.Modules.ToggleState;
|
using Syntriax.Modules.State;
|
||||||
|
|
||||||
namespace Syntriax.Modules.Movement
|
namespace Syntriax.Modules.Movement
|
||||||
{
|
{
|
||||||
public interface IMovementController
|
public interface IMovementController
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Member <see cref="IToggleState"/> to switch on or off
|
/// Member <see cref="IStateEnable"/> to switch on or off
|
||||||
/// </summary>
|
/// </summary>
|
||||||
IToggleState ToggleStateMember { get; }
|
IStateEnable StateEnableMember { get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Currently active <see cref="IMovement"/>
|
/// Currently active <see cref="IMovement"/>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using Syntriax.Modules.ToggleState;
|
using Syntriax.Modules.State;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
|
||||||
namespace Syntriax.Modules.Movement
|
namespace Syntriax.Modules.Movement
|
||||||
@ -31,13 +31,13 @@ namespace Syntriax.Modules.Movement
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool areBothToggleStatesToggled => ToggleStateMember.IsToggledNullChecked() && toggleStateOnGameObject.IsToggledNullChecked();
|
private bool areBothStateEnablesToggled => StateEnableMember.IsEnabledNullChecked() && stateEnableOnGameObject.IsEnabledNullChecked();
|
||||||
|
|
||||||
public List<IMovement> Movements { get; protected set; } = new List<IMovement>(32);
|
public List<IMovement> Movements { get; protected set; } = new List<IMovement>(32);
|
||||||
|
|
||||||
public IToggleState ToggleStateMember { get; protected set; } = new ToggleStateMember(true);
|
public IStateEnable StateEnableMember { get; protected set; } = new StateEnableMember(true);
|
||||||
|
|
||||||
protected IToggleState toggleStateOnGameObject = null;
|
protected IStateEnable stateEnableOnGameObject = null;
|
||||||
|
|
||||||
protected virtual void Start()
|
protected virtual void Start()
|
||||||
{
|
{
|
||||||
@ -45,16 +45,16 @@ namespace Syntriax.Modules.Movement
|
|||||||
gameObject.AddComponent<DefaultMovement>();
|
gameObject.AddComponent<DefaultMovement>();
|
||||||
|
|
||||||
RecacheMovements();
|
RecacheMovements();
|
||||||
toggleStateOnGameObject = GetComponent<IToggleState>();
|
stateEnableOnGameObject = GetComponent<IStateEnable>();
|
||||||
|
|
||||||
toggleStateOnGameObject.OnToggleStateChanged += (_) => InvokeOnMoveAction();
|
stateEnableOnGameObject.OnEnabledChanged += (_) => InvokeOnMoveAction();
|
||||||
ToggleStateMember.OnToggleStateChanged += (_) => InvokeOnMoveAction();
|
StateEnableMember.OnEnabledChanged += (_) => InvokeOnMoveAction();
|
||||||
OnMovementActivated += (newMovement) => newMovement.Move(lastMove);
|
OnMovementActivated += (newMovement) => newMovement.Move(lastMove);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected virtual void FixedUpdate()
|
protected virtual void FixedUpdate()
|
||||||
{
|
{
|
||||||
if (!areBothToggleStatesToggled)
|
if (!areBothStateEnablesToggled)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ActiveMovement?.ApplyMovement();
|
ActiveMovement?.ApplyMovement();
|
||||||
@ -96,7 +96,7 @@ namespace Syntriax.Modules.Movement
|
|||||||
|
|
||||||
private void InvokeOnMoveAction()
|
private void InvokeOnMoveAction()
|
||||||
{
|
{
|
||||||
if (!areBothToggleStatesToggled)
|
if (!areBothStateEnablesToggled)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OnMoveCalled?.Invoke(lastMove.x, lastMove.y, lastMove.z);
|
OnMoveCalled?.Invoke(lastMove.x, lastMove.y, lastMove.z);
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
{
|
{
|
||||||
"name": "com.syntriax.movement",
|
"name": "com.syntriax.movement",
|
||||||
"version": "0.1.4",
|
"version": "0.2.0",
|
||||||
"displayName": "Movement Module",
|
"displayName": "Movement Module",
|
||||||
"description": "Dependends On:\nhttps://git.syntriax.com/Syntriax/ToggleState.git\nhttps://git.syntriax.com/Syntriax/Trigger.git\nhttps://git.syntriax.com/Syntriax/Factory.git",
|
"description": "Dependends On:\nhttps://git.syntriax.com/Syntriax/State.git\nhttps://git.syntriax.com/Syntriax/Trigger.git\nhttps://git.syntriax.com/Syntriax/Factory.git",
|
||||||
"unity": "2019.1",
|
"unity": "2019.1",
|
||||||
"documentationUrl": "https://git.syntriax.com/Syntriax/Movement.git",
|
"documentationUrl": "https://git.syntriax.com/Syntriax/Movement.git",
|
||||||
"keywords": ["Movement"],
|
"keywords": ["Movement"],
|
||||||
|
Loading…
x
Reference in New Issue
Block a user