Scripting:Ore Collector Control
From STNE Wiki
STNE is a Strategy and Role Play Game. You can play here.
| Contents | STNE | Colonies | Buildings | Goods | Items | NPC | Ships | Stellar Cartography | Research | Trade | Combat | Settler | Alliances | Index |
|---|
| Main | Syntax | Operators | Interfaces | FAQ | Contents | API Reference | Index |
|---|
Ore Collector Control
Upon entering the portal, all ore collectors in the sector (the sector that the ship is in on which the portal is set up) will use maximum energy to collect Iridium Ore. It will then report how much ore each ship collected.
If a tanker is docked, it will first undock and dock again after collecting iridium.
The portal will only do anything if the owner of the ship is the person using the portal.
Script created by Glest Durnham (6609)
Script Code
#UseInterface Web, ShipPortal;
Var scriptName As String = "GC_Miner_Control";
If(GuestUser.UserID = MyShip.UserID)
{
Var curShip As CShip;
Var curMyShip As CMyShip;
Var dockedTo As Integer = - 1;
Var oldQuantity As Integer = 0;
// Loop all ships in the sector
For (Each curShip In MyShip.SRS)
{
// Make sure we own it
If (curShip.UserID = MyShip.UserID)
{
// Make sure it's an ore collector.
If (curShip.TypName = "Antares" OR curShip.TypName = "Andorra" OR curShip.TypName = "Antares prototype"
OR curShip.TypName = "Capo" OR curShip.TypName = "Gathering Station" OR curShip.TypeName = "Atria"")
{
// Save initial information
curMyShip = New CMyShip(curShip.ShipID);
dockedTo = - 1;
oldQuantity = curMyShip.Lager.Menge(EWarenTyp.Erz);
// Save docking information and undock
If (curMyShip.Angedockt)
{
dockedTo = curMyShip.AngedocktAnID;
curMyShip.Aktion.Abdocken();
}
// Perform the action
curMyShip.Aktion.ErzSammeln(1000);
// Calculate the result
Var collected As Integer = curMyShip.Lager.Menge(EWarenTyp.Erz) - oldQuantity;
// Re-dock
If (dockedTo > - 1)
{
curMyShip.Aktion.AndockenAn(dockedTo);
}
// Output result
Response.Add(curMyShip.Name & " (NCC " & curMyShip.ShipID & ") collected " & collected & " Iridium ore.");
Response.Add(New CHtmlBreak());
}
}
}
}
Note: Feature pack is required to be able to use this script.