Compare commits
2 commits
5dc10e361b
...
736aec97db
| Author | SHA1 | Date | |
|---|---|---|---|
| 736aec97db | |||
| 0cbd5370f9 |
2 changed files with 82 additions and 32 deletions
|
|
@ -1,4 +1,6 @@
|
||||||
using Sandbox.Game.Entities;
|
using EmptyKeys.UserInterface.Generated.DataTemplatesContracts_Bindings;
|
||||||
|
|
||||||
|
using Sandbox.Game.Entities;
|
||||||
using Sandbox.Game.Entities.Cube;
|
using Sandbox.Game.Entities.Cube;
|
||||||
using Sandbox.Game.EntityComponents;
|
using Sandbox.Game.EntityComponents;
|
||||||
//using Sandbox.ModAPI;
|
//using Sandbox.ModAPI;
|
||||||
|
|
@ -34,8 +36,8 @@ namespace IngameScript
|
||||||
//const string MISSILE_GRID_PREFIX = "[PM]";
|
//const string MISSILE_GRID_PREFIX = "[PM]";
|
||||||
|
|
||||||
const float EPSILON = 0.05f;
|
const float EPSILON = 0.05f;
|
||||||
const double DELAY_BEFORE_TRAVELLING_MODE = 3000; // [ms].
|
const double DELAY_BEFORE_TRAVELLING_MODE = 5000; // [ms] (5 s).
|
||||||
const double AUTO_DESTRUCTION_AFTER = 60000; // [ms] (1 min). Or if the hydrogen tank is empty.
|
const double AUTO_DESTRUCTION_AFTER = 120000; // [ms] (2 min). Or if the hydrogen tank is empty.
|
||||||
|
|
||||||
enum State
|
enum State
|
||||||
{
|
{
|
||||||
|
|
@ -50,10 +52,10 @@ namespace IngameScript
|
||||||
readonly IMyCubeGrid grid;
|
readonly IMyCubeGrid grid;
|
||||||
|
|
||||||
int tickFromStart;
|
int tickFromStart;
|
||||||
IMyThrust forwardThruster;
|
IMyThrust forwardThruster;
|
||||||
|
IEnumerable<IMyThrust> thrusters;
|
||||||
IMyFlightMovementBlock aiMove;
|
IMyFlightMovementBlock aiMove;
|
||||||
IMyOffensiveCombatBlock aiCombat;
|
IMyOffensiveCombatBlock aiCombat;
|
||||||
IMySensorBlock sensor;
|
|
||||||
IEnumerable<IMyWarhead> warheads;
|
IEnumerable<IMyWarhead> warheads;
|
||||||
IMyGasTank gasTank;
|
IMyGasTank gasTank;
|
||||||
IMyLightingBlock light;
|
IMyLightingBlock light;
|
||||||
|
|
@ -71,14 +73,24 @@ namespace IngameScript
|
||||||
this.output.Print("Missile controller system started");
|
this.output.Print("Missile controller system started");
|
||||||
}
|
}
|
||||||
|
|
||||||
void UpdateState10()
|
bool FindElements()
|
||||||
{
|
{
|
||||||
if (this.forwardThruster == null)
|
if (this.forwardThruster == null)
|
||||||
this.forwardThruster = this.GridTerminalSystem.GetBlock<IMyThrust>("[PM] Hydrogen Thruster 01", this.grid);
|
this.forwardThruster = this.GridTerminalSystem.GetBlock<IMyThrust>("[PM] Hydrogen Thruster 01", this.grid);
|
||||||
if (this.forwardThruster == null)
|
if (this.forwardThruster == null)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find forward thruster");
|
this.output.Print("Error: Cannot find forward thruster");
|
||||||
return;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.thrusters == null)
|
||||||
|
{
|
||||||
|
this.thrusters = this.GridTerminalSystem.GetBlocksFromGroup<IMyThrust>("[PM] Thrusters", this.grid);
|
||||||
|
if (this.thrusters.Count() == 0)
|
||||||
|
{
|
||||||
|
this.output.Print("Error: Cannot find thrusters");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.aiMove == null)
|
if (this.aiMove == null)
|
||||||
|
|
@ -86,7 +98,7 @@ namespace IngameScript
|
||||||
if (this.aiMove == null)
|
if (this.aiMove == null)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find AI move");
|
this.output.Print("Error: Cannot find AI move");
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.aiCombat == null)
|
if (this.aiCombat == null)
|
||||||
|
|
@ -94,15 +106,7 @@ namespace IngameScript
|
||||||
if (this.aiCombat == null)
|
if (this.aiCombat == null)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find AI combat");
|
this.output.Print("Error: Cannot find AI combat");
|
||||||
return;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
if (this.sensor == null)
|
|
||||||
this.sensor = this.GridTerminalSystem.GetBlock<IMySensorBlock>("[PM] Sensor", this.grid);
|
|
||||||
if (this.sensor == null)
|
|
||||||
{
|
|
||||||
this.output.Print("Error: Cannot find sensor");
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.warheads == null)
|
if (this.warheads == null)
|
||||||
|
|
@ -110,15 +114,20 @@ namespace IngameScript
|
||||||
if (this.warheads.Count() == 0)
|
if (this.warheads.Count() == 0)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find any warhead");
|
this.output.Print("Error: Cannot find any warhead");
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
// Debug.
|
||||||
|
//else
|
||||||
|
//{
|
||||||
|
// this.output.Print(String.Format("Number of warhead: {0}", this.warheads.Count()));
|
||||||
|
//}
|
||||||
|
|
||||||
if (this.gasTank == null)
|
if (this.gasTank == null)
|
||||||
this.gasTank = this.GridTerminalSystem.GetBlock<IMyGasTank>("[PM] Hydrogen Tank", this.grid);
|
this.gasTank = this.GridTerminalSystem.GetBlock<IMyGasTank>("[PM] Hydrogen Tank", this.grid);
|
||||||
if (this.gasTank == null)
|
if (this.gasTank == null)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find gas tank");
|
this.output.Print("Error: Cannot find gas tank");
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.light == null)
|
if (this.light == null)
|
||||||
|
|
@ -126,20 +135,53 @@ namespace IngameScript
|
||||||
if (this.light == null)
|
if (this.light == null)
|
||||||
{
|
{
|
||||||
this.output.Print("Error: Cannot find light");
|
this.output.Print("Error: Cannot find light");
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool BlinkBeforeBeingAutodestructed()
|
||||||
|
{
|
||||||
|
return this.MsSinceLaunch > AUTO_DESTRUCTION_AFTER - 3000;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool MustBeAutodestructed()
|
||||||
|
{
|
||||||
|
return this.MsSinceLaunch > AUTO_DESTRUCTION_AFTER;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool EnemyAtRange()
|
||||||
|
{
|
||||||
|
return this.aiCombat.SearchEnemyComponent.FoundEnemyId.HasValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
void UpdateState10()
|
||||||
|
{
|
||||||
this.tickFromStart += 10;
|
this.tickFromStart += 10;
|
||||||
|
|
||||||
switch (this.currentState)
|
switch (this.currentState)
|
||||||
{
|
{
|
||||||
case State.LAUNCHING:
|
case State.LAUNCHING:
|
||||||
this.forwardThruster.ThrustOverridePercentage = 1;
|
if (!this.FindElements())
|
||||||
if (this.MsSinceLaunch > DELAY_BEFORE_TRAVELLING_MODE)
|
|
||||||
{
|
{
|
||||||
|
this.output.Print("Cannot find all missile elements, launching aborted");
|
||||||
|
this.currentState = State.NORMAL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.forwardThruster.Enabled = true; // Only one thruster is enabled when launching.
|
||||||
|
this.forwardThruster.ThrustOverridePercentage = 1;
|
||||||
|
if (this.MsSinceLaunch > DELAY_BEFORE_TRAVELLING_MODE && (this.EnemyAtRange() || this.BlinkBeforeBeingAutodestructed()))
|
||||||
|
{
|
||||||
|
foreach (var thruster in this.thrusters)
|
||||||
|
{
|
||||||
|
if (thruster != this.forwardThruster)
|
||||||
|
thruster.Enabled = true;
|
||||||
|
}
|
||||||
|
|
||||||
this.forwardThruster.ThrustOverridePercentage = 0;
|
this.forwardThruster.ThrustOverridePercentage = 0;
|
||||||
this.aiMove.Enabled = true;
|
this.aiMove.Enabled = true;
|
||||||
this.aiCombat.Enabled = true;
|
|
||||||
|
|
||||||
foreach (var warhead in this.warheads)
|
foreach (var warhead in this.warheads)
|
||||||
warhead.IsArmed = true;
|
warhead.IsArmed = true;
|
||||||
|
|
@ -150,12 +192,10 @@ namespace IngameScript
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case State.TRAVELLING:
|
case State.TRAVELLING:
|
||||||
var detectedEntity = this.sensor.LastDetectedEntity;
|
if (this.BlinkBeforeBeingAutodestructed())
|
||||||
|
|
||||||
if (this.MsSinceLaunch > AUTO_DESTRUCTION_AFTER - 3000)
|
|
||||||
this.light.BlinkIntervalSeconds = 0.5f;
|
this.light.BlinkIntervalSeconds = 0.5f;
|
||||||
|
|
||||||
if (this.gasTank.FilledRatio <= EPSILON || detectedEntity.Type != MyDetectedEntityType.None || this.MsSinceLaunch > AUTO_DESTRUCTION_AFTER)
|
if (this.gasTank.FilledRatio <= EPSILON || this.MustBeAutodestructed())
|
||||||
{
|
{
|
||||||
Detonate();
|
Detonate();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -124,13 +124,23 @@ namespace IngameScript
|
||||||
}
|
}
|
||||||
|
|
||||||
IMyProgrammableBlock programmableBlock = this.gridTerminal.GetBlock<IMyProgrammableBlock>("[PM] Programmable Block", missileGrid);
|
IMyProgrammableBlock programmableBlock = this.gridTerminal.GetBlock<IMyProgrammableBlock>("[PM] Programmable Block", missileGrid);
|
||||||
|
|
||||||
if (programmableBlock == null)
|
if (programmableBlock == null)
|
||||||
{
|
{
|
||||||
this.Print("Cannot find the missile programmable block");
|
this.Print("Cannot find the missile programmable block");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IEnumerable<IMyThrust> thrusters = this.gridTerminal.GetBlocksFromGroup<IMyThrust>("[PM] Thrusters", missileGrid);
|
||||||
|
if (thrusters.Count() == 0)
|
||||||
|
{
|
||||||
|
this.Print("Cannot find missile thrusters");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// When launched the missile will enabled itself its thrusters.
|
||||||
|
foreach (var thruster in thrusters)
|
||||||
|
thruster.Enabled = false;
|
||||||
|
|
||||||
tank.Stockpile = true;
|
tank.Stockpile = true;
|
||||||
connector.Connect();
|
connector.Connect();
|
||||||
|
|
||||||
|
|
@ -182,7 +192,7 @@ namespace IngameScript
|
||||||
|
|
||||||
public const string GRID_PREFIX = "[PML]";
|
public const string GRID_PREFIX = "[PML]";
|
||||||
public const string MISSILE_GRID_PREFIX = "[PM]";
|
public const string MISSILE_GRID_PREFIX = "[PM]";
|
||||||
public const double HYDRO_TANK_FILLED_PERCENT = 20;
|
public const double HYDRO_TANK_FILLED_PERCENT = 40;
|
||||||
|
|
||||||
const string LAUNCHER_SMALL_CONNECTOR_NAME = "Connector Launcher"; // Following by a number: "01", "02", etc.
|
const string LAUNCHER_SMALL_CONNECTOR_NAME = "Connector Launcher"; // Following by a number: "01", "02", etc.
|
||||||
const string DOORS_MISSILES_GROUP = "Doors Missiles";
|
const string DOORS_MISSILES_GROUP = "Doors Missiles";
|
||||||
|
|
@ -202,7 +212,7 @@ namespace IngameScript
|
||||||
public Program()
|
public Program()
|
||||||
{
|
{
|
||||||
var output = this.Me.GetSurface(0);
|
var output = this.Me.GetSurface(0);
|
||||||
this.output = new Output(output);
|
this.output = new Output(output, 14);
|
||||||
this.output.Print("Missile launcher system starting...");
|
this.output.Print("Missile launcher system starting...");
|
||||||
|
|
||||||
this.missilesDoors = Utils.GetBlocksFromGroup<IMyDoor>(this.GridTerminalSystem, String.Format("{0} {1}", GRID_PREFIX, DOORS_MISSILES_GROUP));
|
this.missilesDoors = Utils.GetBlocksFromGroup<IMyDoor>(this.GridTerminalSystem, String.Format("{0} {1}", GRID_PREFIX, DOORS_MISSILES_GROUP));
|
||||||
|
|
@ -227,7 +237,7 @@ namespace IngameScript
|
||||||
this.launchers.Add(new Launcher(n, this.GridTerminalSystem, this.output, connector));
|
this.launchers.Add(new Launcher(n, this.GridTerminalSystem, this.output, connector));
|
||||||
}
|
}
|
||||||
|
|
||||||
this.Runtime.UpdateFrequency = UpdateFrequency.Update100;
|
this.Runtime.UpdateFrequency = UpdateFrequency.Update10;
|
||||||
|
|
||||||
this.output.Print($"Missile launcher system started ({this.launchers.Count} launcher(s))");
|
this.output.Print($"Missile launcher system started ({this.launchers.Count} launcher(s))");
|
||||||
}
|
}
|
||||||
|
|
@ -293,7 +303,7 @@ namespace IngameScript
|
||||||
|
|
||||||
public void Main(string argument, UpdateType updateSource)
|
public void Main(string argument, UpdateType updateSource)
|
||||||
{
|
{
|
||||||
if ((updateSource & UpdateType.Update100) != 0)
|
if ((updateSource & UpdateType.Update10) != 0)
|
||||||
{
|
{
|
||||||
this.UpdateState();
|
this.UpdateState();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue