undergoing a shift to change movement into another action that a peg can perform and giving pegs a list of actions order by priority
This commit is contained in:
@@ -102,7 +102,6 @@ public partial class Map : TileMapLayer
|
|||||||
PEG._address = ADDRESS;
|
PEG._address = ADDRESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
_addressOccupants[ADDRESS] = PEG;
|
_addressOccupants[ADDRESS] = PEG;
|
||||||
SetCellSolid(ADDRESS);
|
SetCellSolid(ADDRESS);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,49 +7,54 @@ public partial class Peg : HoverableNode
|
|||||||
{
|
{
|
||||||
[Signal]
|
[Signal]
|
||||||
public delegate void DeathEventHandler(Peg THIS);
|
public delegate void DeathEventHandler(Peg THIS);
|
||||||
public int _id, _health = 2, _healthMax = 2, _stamina, _staminaRemaining, _visibility = 4, _movement = 0, _movementCost = 1;
|
public int _id, _health = 2, _healthMax = 2, _stamina, _staminaRemaining, _visibility = 4, _movement = 0;
|
||||||
public Dictionary<string, int> _priorities = new()
|
public Dictionary<string, int> _priorities = new()
|
||||||
{
|
{
|
||||||
{"ball", 1000000}, // 1000000 to 1999999 reserved for ball priorities
|
{"act", 1000000}, // 1000000 to 1999999 reserved for action priorities
|
||||||
{"movement", 0} // 0 to 999999 reserved for movement priorities
|
{"movement", 0} // 0 to 999999 reserved for movement priorities
|
||||||
};
|
};
|
||||||
public Vector2I _address = -Vector2I.One, _range = Vector2I.Up;
|
public Vector2I _address = -Vector2I.One, _range = Vector2I.Up;
|
||||||
public List<Vector2I> _path = new();
|
public List<Vector2I> _path = new();
|
||||||
public PegController _pegController;
|
public PegController _pegController;
|
||||||
public PegAction _action;
|
public List<PegAction> _actions;
|
||||||
|
public int _distanceToGoal
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return GetBestPath().Count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public override void _Ready()
|
public override void _Ready()
|
||||||
{
|
{
|
||||||
base._Ready();
|
base._Ready();
|
||||||
|
ReprioritizeActions();
|
||||||
}
|
}
|
||||||
public virtual void Act()
|
public virtual bool Act(int SUB_STEP)
|
||||||
{
|
{
|
||||||
if (_action == null)
|
PegAction action = null;
|
||||||
|
for (int i = 0; i < _actions.Count; i++)
|
||||||
|
{
|
||||||
|
if (_actions[i].MeetsCriteria(this))
|
||||||
|
{
|
||||||
|
action = _actions[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (action == null)
|
||||||
{
|
{
|
||||||
GD.Print("NO ACTION");
|
GD.Print("NO ACTION");
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
Tween subtween = _action.CreateAnimation(this);
|
Tween subtween = action.CreateAnimation(this);
|
||||||
if (!_pegController._tweenStages.ContainsKey(_action._priority))
|
int key = action._priority + SUB_STEP;
|
||||||
|
if (!_pegController._tweenStages.ContainsKey(key))
|
||||||
{
|
{
|
||||||
_pegController._tweenStages[_action._priority] = new();
|
_pegController._tweenStages[key] = new();
|
||||||
}
|
}
|
||||||
_pegController._tweenStages[_action._priority].Add(subtween);
|
_pegController._tweenStages[key].Add(subtween);
|
||||||
_staminaRemaining = Math.Max(_staminaRemaining - _action._cost, 0);
|
_staminaRemaining -= action._cost;
|
||||||
}
|
return true;
|
||||||
|
|
||||||
public virtual bool CanAct()
|
|
||||||
{
|
|
||||||
return _staminaRemaining > 0
|
|
||||||
&& _address.Y <= _action._range
|
|
||||||
&& _action._usesRemaining > 0
|
|
||||||
&& _staminaRemaining <= _action._cost;
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual bool CanMove()
|
|
||||||
{
|
|
||||||
return _staminaRemaining > 0
|
|
||||||
&& _address.Y > _pegController._playArea._map._firstOpenRow;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void CounterAct(Commander COMMANDER)
|
public virtual void CounterAct(Commander COMMANDER)
|
||||||
@@ -67,8 +72,12 @@ public partial class Peg : HoverableNode
|
|||||||
{
|
{
|
||||||
paths.Add(map.GetPath(_address, goals[i]));
|
paths.Add(map.GetPath(_address, goals[i]));
|
||||||
}
|
}
|
||||||
|
List<List<Vector2I>> pathsOverZeroCount = [.. paths.Where(p => p.Count > 0)];
|
||||||
return paths.Where(p => p.Count > 0).OrderBy(p => p.Count).ToList()[0];
|
if (pathsOverZeroCount.Count == 0)
|
||||||
|
{
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
return pathsOverZeroCount.OrderBy(p => p.Count).ToList()[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual List<Vector2I> GetGoals()
|
public virtual List<Vector2I> GetGoals()
|
||||||
@@ -76,36 +85,27 @@ public partial class Peg : HoverableNode
|
|||||||
Map map = _pegController._playArea._map;
|
Map map = _pegController._playArea._map;
|
||||||
return [.. map._cells.Where(c => c.Y == map._firstOpenRow).Where(c => !map._astar.IsPointSolid(c))];
|
return [.. map._cells.Where(c => c.Y == map._firstOpenRow).Where(c => !map._astar.IsPointSolid(c))];
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void Move(Vector2I PATH_STEP)
|
|
||||||
{
|
|
||||||
_pegController._playArea._map.SetCellPeg(PATH_STEP, this);
|
|
||||||
_path.Add(PATH_STEP);
|
|
||||||
|
|
||||||
Tween subtween = CreateTween();
|
|
||||||
subtween.TweenProperty(this, "global_position", _pegController._playArea._map.GetCellPositionFromAddress(PATH_STEP), 0.25f);
|
|
||||||
int key = _priorities["movement"] + _pegController._actionLoop;
|
|
||||||
|
|
||||||
if (!_pegController._tweenStages.ContainsKey(key))
|
|
||||||
{
|
|
||||||
_pegController._tweenStages[key] = new();
|
|
||||||
}
|
|
||||||
|
|
||||||
_pegController._tweenStages[key].Add(subtween);
|
public Vector2 GetPositionFromAddress()
|
||||||
_staminaRemaining -= _movementCost;
|
{
|
||||||
|
return _pegController._playArea._map.GetCellPositionFromAddress(_address);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ReprioritizeActions()
|
||||||
|
{
|
||||||
|
_actions = [.. GetNode<Node>("Actions").GetChildren().Cast<PegAction>()];
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void StartTurn()
|
public virtual void StartTurn()
|
||||||
{
|
{
|
||||||
_staminaRemaining = _stamina;
|
_staminaRemaining = _stamina;
|
||||||
_action._usesRemaining = _action._usesMax;
|
_actions.ForEach(a => a.Reset());
|
||||||
GD.Print("ACTION ",_action._usesRemaining,", ",_action._usesRemaining);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void ChangeHealth(int DELTA, Commander BALLER)
|
public virtual void ChangeHealth(int DELTA, Commander COMMANDER)
|
||||||
{
|
{
|
||||||
_health += DELTA;
|
_health += DELTA;
|
||||||
CounterAct(BALLER);
|
CounterAct(COMMANDER);
|
||||||
if (_health <= 0)
|
if (_health <= 0)
|
||||||
{
|
{
|
||||||
EmitSignal(SignalName.Death, this);
|
EmitSignal(SignalName.Death, this);
|
||||||
|
|||||||
+16
-52
@@ -10,7 +10,7 @@ using System.Xml;
|
|||||||
|
|
||||||
public partial class PegController : TurnController
|
public partial class PegController : TurnController
|
||||||
{
|
{
|
||||||
public int _actionLoop = 0, _pegsCreated = 0, _pegsDestroyed = 0;
|
public int _pegsCreated = 0, _pegsDestroyed = 0;
|
||||||
public List<PackedScene> _hostilePegScenes;
|
public List<PackedScene> _hostilePegScenes;
|
||||||
public List<Peg> _pegs = new();
|
public List<Peg> _pegs = new();
|
||||||
public PlayerController _playerController;
|
public PlayerController _playerController;
|
||||||
@@ -64,49 +64,30 @@ public partial class PegController : TurnController
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Peg> GetRemainingPegs()
|
|
||||||
{
|
|
||||||
return [.. _pegs.Where(e => e.CanMove() || e.CanAct())];
|
|
||||||
}
|
|
||||||
|
|
||||||
public void HandlePegTurn()
|
public void HandlePegTurn()
|
||||||
{
|
{
|
||||||
_actionLoop = 0;
|
|
||||||
_tweenStages.Clear();
|
_tweenStages.Clear();
|
||||||
Map map = _playArea._map;
|
|
||||||
|
|
||||||
_pegs.ForEach(e => e._path.Clear());
|
int loop = 0;
|
||||||
|
bool noPegsActed = false;
|
||||||
List<Peg> remainingPegs = GetRemainingPegs();
|
while (!noPegsActed)
|
||||||
while (remainingPegs.Count > 0)
|
|
||||||
{
|
{
|
||||||
for (int i = 0; i < remainingPegs.Count; i++)
|
noPegsActed = true;
|
||||||
|
for (int i = 0; i < _pegs.Count; i++)
|
||||||
{
|
{
|
||||||
Peg peg = remainingPegs[i];
|
Peg peg = _pegs[i];
|
||||||
HandlePegPathing(peg);
|
bool pegActed = peg.Act(loop);
|
||||||
HandlePegAction(peg);
|
if (pegActed)
|
||||||
}
|
{
|
||||||
remainingPegs = GetRemainingPegs();
|
noPegsActed = false;
|
||||||
_actionLoop++;
|
}
|
||||||
if (_actionLoop == 10)
|
|
||||||
{
|
|
||||||
Peg peg_ = remainingPegs[0];
|
|
||||||
GD.Print("LOOPMAXEDOUT");
|
|
||||||
}
|
}
|
||||||
|
loop++;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void HandlePegAction(Peg PEG)
|
|
||||||
{
|
|
||||||
if (PEG.CanAct())
|
|
||||||
{
|
|
||||||
PEG.Act();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void HandlePegClick(Node CLICKED_NODE, int CLICK_TYPE)
|
public void HandlePegClick(Node CLICKED_NODE, int CLICK_TYPE)
|
||||||
{
|
{
|
||||||
if (CLICKED_NODE is not Peg peg)
|
if (CLICKED_NODE is not Peg peg)
|
||||||
@@ -133,23 +114,6 @@ public partial class PegController : TurnController
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void HandlePegPathing(Peg PEG)
|
|
||||||
{
|
|
||||||
if (!PEG.CanMove())
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
List<Vector2I> path = PEG.GetBestPath();
|
|
||||||
|
|
||||||
if (path?.Count == 0)
|
|
||||||
{
|
|
||||||
GD.Print(PEG._address, " PATH0");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
PEG.Move(path[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void HandlePegRemoval(Peg PEG_TO_REMOVE)
|
public void HandlePegRemoval(Peg PEG_TO_REMOVE)
|
||||||
{
|
{
|
||||||
_pegs.Remove(PEG_TO_REMOVE);
|
_pegs.Remove(PEG_TO_REMOVE);
|
||||||
@@ -160,7 +124,7 @@ public partial class PegController : TurnController
|
|||||||
|
|
||||||
public void HandlePegSort()
|
public void HandlePegSort()
|
||||||
{
|
{
|
||||||
_pegs = [.. _pegs.OrderBy(e => e._address.Y).ThenBy(e => e._path.Count).ThenBy(e => Math.Abs(e._address.X - _playArea._map._maxX / 2))];
|
_pegs = [.. _pegs.OrderBy(p => p._address.Y).ThenBy(p => p._distanceToGoal).ThenBy(p => Math.Abs(p._address.X - _playArea._map._maxX / 2))];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -174,7 +138,7 @@ public partial class PegController : TurnController
|
|||||||
public void ProcessTween()
|
public void ProcessTween()
|
||||||
{
|
{
|
||||||
_tweenStages = _tweenStages.OrderBy(s => s.Key).ToDictionary();
|
_tweenStages = _tweenStages.OrderBy(s => s.Key).ToDictionary();
|
||||||
GD.Print(string.Join(", ", _tweenStages.Keys));
|
// GD.Print(string.Join(", ", _tweenStages.Keys));
|
||||||
if (_tweenStages.Count <= 0)
|
if (_tweenStages.Count <= 0)
|
||||||
{
|
{
|
||||||
EndTurn();
|
EndTurn();
|
||||||
|
|||||||
@@ -0,0 +1,41 @@
|
|||||||
|
using Godot;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
public partial class BasicMovement : PegAction
|
||||||
|
{
|
||||||
|
public override void _Ready()
|
||||||
|
{
|
||||||
|
base._Ready();
|
||||||
|
_healthChange = 0;
|
||||||
|
_cost = 1;
|
||||||
|
_range = 2^32;
|
||||||
|
_usesMax = 2^32;
|
||||||
|
_usesRemaining = _usesMax;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override Tween CreateAnimation(Peg PEG)
|
||||||
|
{
|
||||||
|
List<Vector2I> path = PEG.GetBestPath();
|
||||||
|
PegController pegController = PEG._pegController;
|
||||||
|
Map map = pegController._playArea._map;
|
||||||
|
if (path?.Count == 0)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
Vector2I cell = path[0];
|
||||||
|
map.SetCellPeg(cell, PEG);
|
||||||
|
PEG._path.Add(cell);
|
||||||
|
|
||||||
|
Tween subtween = CreateTween();
|
||||||
|
subtween.TweenProperty(this, "global_position", map.GetCellPositionFromAddress(cell), 0.25f);
|
||||||
|
|
||||||
|
return subtween;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool MeetsCriteria(Peg PEG)
|
||||||
|
{
|
||||||
|
return base.MeetsCriteria(PEG) && PEG._address.Y > PEG._pegController._playArea._map._firstOpenRow;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
uid://hp5iucbq5brg
|
||||||
@@ -7,13 +7,13 @@ public partial class Shortbow : PegAction
|
|||||||
public override void _Ready()
|
public override void _Ready()
|
||||||
{
|
{
|
||||||
base._Ready();
|
base._Ready();
|
||||||
_priority = 1000;
|
|
||||||
_healthChange = -1;
|
_healthChange = -1;
|
||||||
_cost = 2;
|
_cost = 2;
|
||||||
_range = 1;
|
_range = 1;
|
||||||
_usesMax = 1;
|
_usesMax = 1;
|
||||||
_usesRemaining = _usesMax;
|
_usesRemaining = _usesMax;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Tween CreateAnimation(Peg PEG)
|
public override Tween CreateAnimation(Peg PEG)
|
||||||
{
|
{
|
||||||
Vector2 target = PEG._pegController._playerController._towers.OrderBy(t => (t.GlobalPosition - GlobalPosition).Length()).ToList()[0].GlobalPosition;
|
Vector2 target = PEG._pegController._playerController._towers.OrderBy(t => (t.GlobalPosition - GlobalPosition).Length()).ToList()[0].GlobalPosition;
|
||||||
|
|||||||
@@ -7,19 +7,19 @@ public partial class Shortsword : PegAction
|
|||||||
public override void _Ready()
|
public override void _Ready()
|
||||||
{
|
{
|
||||||
base._Ready();
|
base._Ready();
|
||||||
_priority = 1000;
|
|
||||||
_healthChange = -2;
|
_healthChange = -2;
|
||||||
_cost = 2;
|
_cost = 2;
|
||||||
_range = 0;
|
_range = 0;
|
||||||
_usesMax = 1;
|
_usesMax = 1;
|
||||||
_usesRemaining = _usesMax;
|
_usesRemaining = _usesMax;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Tween CreateAnimation(Peg PEG)
|
public override Tween CreateAnimation(Peg PEG)
|
||||||
{
|
{
|
||||||
Vector2 target = PEG.GlobalPosition + (Vector2.Up * 50);
|
Vector2 target = Vector2.Up * PEG._pegController._playArea._map._cellSize;
|
||||||
Tween subtween = CreateTween();
|
Tween subtween = CreateTween();
|
||||||
subtween.TweenProperty(_image, "visible", true, 0.0f);
|
subtween.TweenProperty(_image, "visible", true, 0.0f);
|
||||||
subtween.TweenProperty(_image, "global_position", target, 0.5f);
|
subtween.TweenProperty(_image, "position", target, 0.5f);
|
||||||
subtween.TweenCallback(Callable.From(() =>
|
subtween.TweenCallback(Callable.From(() =>
|
||||||
{
|
{
|
||||||
PEG._pegController._playerController.ChangeHealth(_healthChange, this);
|
PEG._pegController._playerController.ChangeHealth(_healthChange, this);
|
||||||
|
|||||||
@@ -0,0 +1,9 @@
|
|||||||
|
[gd_scene format=3 uid="uid://bup5oli00p3lg"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" uid="uid://hp5iucbq5brg" path="res://Pegs/Actions/BasicMovement.cs" id="1_u1rld"]
|
||||||
|
|
||||||
|
[node name="BasicMovement" type="Node2D" unique_id=460007250]
|
||||||
|
script = ExtResource("1_u1rld")
|
||||||
|
|
||||||
|
[node name="Image" type="Sprite2D" parent="." unique_id=1133735272]
|
||||||
|
visible = false
|
||||||
@@ -1,8 +1,12 @@
|
|||||||
[gd_scene format=3 uid="uid://duspilwelsiy3"]
|
[gd_scene format=3 uid="uid://duspilwelsiy3"]
|
||||||
|
|
||||||
[ext_resource type="Script" uid="uid://dt7qbvowj1sm4" path="res://Pegs/Actions/Shortbow.cs" id="1_yhiab"]
|
[ext_resource type="Script" uid="uid://dt7qbvowj1sm4" path="res://Pegs/Actions/Shortbow.cs" id="1_yhiab"]
|
||||||
|
[ext_resource type="Texture2D" uid="uid://32m5teus1cjj" path="res://Art/tower.png" id="2_uaien"]
|
||||||
|
|
||||||
[node name="Shortbow" type="Node2D" unique_id=518048625]
|
[node name="Shortbow" type="Node2D" unique_id=518048625]
|
||||||
script = ExtResource("1_yhiab")
|
script = ExtResource("1_yhiab")
|
||||||
|
|
||||||
[node name="Image" type="Sprite2D" parent="." unique_id=944294157]
|
[node name="Image" type="Sprite2D" parent="." unique_id=944294157]
|
||||||
|
visible = false
|
||||||
|
scale = Vector2(0.1, 0.1)
|
||||||
|
texture = ExtResource("2_uaien")
|
||||||
|
|||||||
@@ -7,6 +7,5 @@ public partial class Archer : HostilePeg
|
|||||||
{
|
{
|
||||||
base._Ready();
|
base._Ready();
|
||||||
_stamina = 2;
|
_stamina = 2;
|
||||||
_action = GetNode<Shortbow>("Shortbow");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,6 +7,5 @@ public partial class Infantry : HostilePeg
|
|||||||
{
|
{
|
||||||
base._Ready();
|
base._Ready();
|
||||||
_stamina = 3;
|
_stamina = 3;
|
||||||
_action = GetNode<Shortsword>("Shortsword");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
[ext_resource type="Script" uid="uid://b3a0x3r3yx861" path="res://Pegs/HostilePegs/Archer.cs" id="1_ij48w"]
|
[ext_resource type="Script" uid="uid://b3a0x3r3yx861" path="res://Pegs/HostilePegs/Archer.cs" id="1_ij48w"]
|
||||||
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_j7but"]
|
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_j7but"]
|
||||||
[ext_resource type="PackedScene" uid="uid://duspilwelsiy3" path="res://Pegs/Actions/shortbow.tscn" id="3_c81uf"]
|
[ext_resource type="PackedScene" uid="uid://duspilwelsiy3" path="res://Pegs/Actions/shortbow.tscn" id="3_c81uf"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://bup5oli00p3lg" path="res://Pegs/Actions/basic_movement.tscn" id="3_j7but"]
|
||||||
|
|
||||||
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
||||||
bounce = 0.5
|
bounce = 0.5
|
||||||
@@ -27,7 +28,11 @@ texture_filter = 1
|
|||||||
scale = Vector2(0.5, 0.5)
|
scale = Vector2(0.5, 0.5)
|
||||||
texture = ExtResource("2_j7but")
|
texture = ExtResource("2_j7but")
|
||||||
|
|
||||||
[node name="Shortbow" parent="." unique_id=518048625 instance=ExtResource("3_c81uf")]
|
[node name="Actions" type="Node" parent="." unique_id=614093526]
|
||||||
|
|
||||||
|
[node name="BasicMovement" parent="Actions" unique_id=460007250 instance=ExtResource("3_j7but")]
|
||||||
|
|
||||||
|
[node name="Shortbow" parent="Actions" unique_id=518048625 instance=ExtResource("3_c81uf")]
|
||||||
|
|
||||||
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
[ext_resource type="Script" uid="uid://xlg4cblo1vf1" path="res://Pegs/HostilePegs/Infantry.cs" id="1_wlksp"]
|
[ext_resource type="Script" uid="uid://xlg4cblo1vf1" path="res://Pegs/HostilePegs/Infantry.cs" id="1_wlksp"]
|
||||||
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_b77ka"]
|
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_b77ka"]
|
||||||
[ext_resource type="PackedScene" uid="uid://c6df6ib0qan5g" path="res://Pegs/Actions/shortsword.tscn" id="3_lwlv5"]
|
[ext_resource type="PackedScene" uid="uid://c6df6ib0qan5g" path="res://Pegs/Actions/shortsword.tscn" id="3_lwlv5"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://bup5oli00p3lg" path="res://Pegs/Actions/basic_movement.tscn" id="4_b77ka"]
|
||||||
|
|
||||||
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
||||||
bounce = 0.5
|
bounce = 0.5
|
||||||
@@ -27,7 +28,11 @@ texture_filter = 1
|
|||||||
scale = Vector2(0.5, 0.5)
|
scale = Vector2(0.5, 0.5)
|
||||||
texture = ExtResource("2_b77ka")
|
texture = ExtResource("2_b77ka")
|
||||||
|
|
||||||
[node name="Shortsword" parent="." unique_id=518048625 instance=ExtResource("3_lwlv5")]
|
[node name="Actions" type="Node" parent="." unique_id=2081138574]
|
||||||
|
|
||||||
|
[node name="Shortsword" parent="Actions" unique_id=518048625 instance=ExtResource("3_lwlv5")]
|
||||||
|
|
||||||
|
[node name="BasicMovement" parent="Actions" unique_id=460007250 instance=ExtResource("4_b77ka")]
|
||||||
|
|
||||||
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
||||||
|
|
||||||
|
|||||||
@@ -16,4 +16,16 @@ public partial class PegAction : Node2D
|
|||||||
{
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public virtual bool MeetsCriteria(Peg PEG)
|
||||||
|
{
|
||||||
|
return PEG._staminaRemaining >= _cost
|
||||||
|
&& _usesRemaining > 0
|
||||||
|
&& PEG._address.Y <= _range;
|
||||||
|
}
|
||||||
|
|
||||||
|
public virtual void Reset()
|
||||||
|
{
|
||||||
|
_usesRemaining = _usesMax;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
[ext_resource type="Script" uid="uid://dfba4vq6jv0a6" path="res://Pegs/HostilePeg.cs" id="1_nc8fp"]
|
[ext_resource type="Script" uid="uid://dfba4vq6jv0a6" path="res://Pegs/HostilePeg.cs" id="1_nc8fp"]
|
||||||
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_0icqg"]
|
[ext_resource type="Texture2D" uid="uid://nwj4n7if8kqd" path="res://Art/circle25r.png" id="2_0icqg"]
|
||||||
[ext_resource type="PackedScene" uid="uid://bj2qrn0l01us1" path="res://Pegs/peg_action.tscn" id="3_nc8fp"]
|
|
||||||
|
|
||||||
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
[sub_resource type="PhysicsMaterial" id="PhysicsMaterial_7k104"]
|
||||||
bounce = 0.5
|
bounce = 0.5
|
||||||
@@ -26,7 +25,7 @@ texture_filter = 1
|
|||||||
scale = Vector2(0.5, 0.5)
|
scale = Vector2(0.5, 0.5)
|
||||||
texture = ExtResource("2_0icqg")
|
texture = ExtResource("2_0icqg")
|
||||||
|
|
||||||
[node name="PegAction" parent="." unique_id=637569115 instance=ExtResource("3_nc8fp")]
|
[node name="Actions" type="Node" parent="." unique_id=218609326]
|
||||||
|
|
||||||
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
[node name="HoverBounds" type="Area2D" parent="." unique_id=937525982]
|
||||||
|
|
||||||
|
|||||||
@@ -6,3 +6,4 @@
|
|||||||
script = ExtResource("1_8o8tf")
|
script = ExtResource("1_8o8tf")
|
||||||
|
|
||||||
[node name="Image" type="Sprite2D" parent="." unique_id=1133735272]
|
[node name="Image" type="Sprite2D" parent="." unique_id=1133735272]
|
||||||
|
visible = false
|
||||||
|
|||||||
Reference in New Issue
Block a user