using NodeCanvas.Framework; using ParadoxNotion.Design; using UnityEngine; namespace Reset.Units { [Category("Reset/Movement")] [Description("Set a new direction value for this agent, either additively, absolutely, or relatively.")] public class SetNewDirection : ActionTask { public BBParameter newDirection; [Tooltip("Setting absolute to true will cause the resolved movement direction to snap to the new gravity value. Keeping it false will make it apply additively to the resolved movement direction. Both options use relativty for linear interpolation.")] public BBParameter absolute; [Tooltip("Higher relativity means more of the new value is used. Value of 1 will set it to the value directly, while .5 will blend halfway between.")] [SliderField(0, 1)] public BBParameter relativity; [Tooltip("Setting raw direciton will affect things that read the raw direction like rotation")] public BBParameter setRawAsWell; [Tooltip("This is set as a Vector3 but will be translated into a Vector2 on execute")] public BBParameter relativeTo; //Use for initialization. This is called only once in the lifetime of the task. //Return null if init was successfull. Return an error string otherwise protected override string OnInit() { return null; } //This is called once each time the task is enabled. //Call EndAction() to mark the action as finished, either in success or failure. //EndAction can be called from anywhere. protected override void OnExecute() { agent.SetNewDirection(newDirection.value, relativity.value, absolute.value, relativeTo.value.ToVector2()); if (setRawAsWell.value) { agent.SetNewRawDirection(newDirection.value, relativity.value, absolute.value, relativeTo.value.ToVector2()); } EndAction(true); } //Called once per frame while the action is active. protected override void OnUpdate() { } //Called when the task is disabled. protected override void OnStop() { } //Called when the task is paused. protected override void OnPause() { } } }