first working version of the skynetiads plugin

This commit is contained in:
David Pierron
2020-10-22 18:39:54 +02:00
parent fd969020af
commit e024da277b
18 changed files with 10042 additions and 35 deletions

View File

@@ -0,0 +1,21 @@
import random
from dcs.vehicles import AirDefence
from game import db
from gen.sam.group_generator import GroupGenerator
class GenericSamGroupGenerator(GroupGenerator):
"""
This is the base for all SAM group generators
"""
def getGroupNamePrefix(self, faction):
if not faction:
return ""
# prefix the SAM site for use with the Skynet IADS plugin
prefix = "BLUE SAM "
if db.FACTIONS[faction]["side"] == "red":
prefix = "RED SAM "
return prefix

View File

@@ -8,16 +8,23 @@ from dcs.unit import Vehicle
class GroupGenerator():
def __init__(self, game, ground_object):
def __init__(self, game, ground_object, faction = None):
self.game = game
self.go = ground_object
self.position = ground_object.position
self.heading = random.randint(0, 359)
self.vg = unitgroup.VehicleGroup(self.game.next_group_id(), self.go.group_identifier)
groupNamePrefix = self.getGroupNamePrefix(faction)
self.vg = unitgroup.VehicleGroup(self.game.next_group_id(), groupNamePrefix + self.go.group_identifier)
wp = self.vg.add_waypoint(self.position, PointAction.OffRoad, 0)
wp.ETA_locked = True
def getGroupNamePrefix(self, faction):
if not faction:
return ""
return ""
def generate(self):
raise NotImplementedError

View File

@@ -117,7 +117,6 @@ def get_faction_possible_sams_generator(faction: str) -> List[UnitType]:
"""
return [SAM_MAP[u] for u in get_faction_possible_sams_units(faction)]
def generate_anti_air_group(game, parent_cp, ground_object, faction:str):
"""
This generate a SAM group
@@ -129,7 +128,7 @@ def generate_anti_air_group(game, parent_cp, ground_object, faction:str):
possible_sams = get_faction_possible_sams_units(faction)
if len(possible_sams) > 0:
sam = random.choice(possible_sams)
generator = SAM_MAP[sam](game, ground_object)
generator = SAM_MAP[sam](game, ground_object, faction)
generator.generate()
return generator.get_generated_group()
return None
@@ -149,5 +148,3 @@ def generate_shorad_group(game, parent_cp, ground_object, faction:str):

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class HawkGenerator(GroupGenerator):
class HawkGenerator(GenericSamGroupGenerator):
"""
This generate an HAWK group
"""
@@ -14,8 +14,8 @@ class HawkGenerator(GroupGenerator):
price = 115
def generate(self):
self.add_unit(AirDefence.SAM_Hawk_PCP, "PCP", self.position.x, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Hawk_SR_AN_MPQ_50, "SR", self.position.x + 20, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Hawk_PCP, "PCP", self.position.x, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Hawk_TR_AN_MPQ_46, "TR", self.position.x + 40, self.position.y, self.heading)
# Triple A for close range defense

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class HQ7Generator(GroupGenerator):
class HQ7Generator(GenericSamGroupGenerator):
"""
This generate an HQ7 group
"""

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class PatriotGenerator(GroupGenerator):
class PatriotGenerator(GenericSamGroupGenerator):
"""
This generate a Patriot group
"""
@@ -15,11 +15,11 @@ class PatriotGenerator(GroupGenerator):
def generate(self):
# Command Post
self.add_unit(AirDefence.SAM_Patriot_STR_AN_MPQ_53, "ICC", self.position.x + 30, self.position.y + 30, self.heading)
self.add_unit(AirDefence.SAM_Patriot_AMG_AN_MRC_137, "MRC", self.position.x, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Patriot_ECS_AN_MSQ_104, "MSQ", self.position.x + 30, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Patriot_ICC, "ICC", self.position.x + 60, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Patriot_EPP_III, "EPP", self.position.x, self.position.y + 30, self.heading)
self.add_unit(AirDefence.SAM_Patriot_STR_AN_MPQ_53, "ICC", self.position.x + 30, self.position.y + 30, self.heading)
num_launchers = random.randint(3, 4)
positions = self.get_circular_position(num_launchers, launcher_distance=120, coverage=360)
@@ -30,4 +30,4 @@ class PatriotGenerator(GroupGenerator):
num_launchers = random.randint(3, 4)
positions = self.get_circular_position(num_launchers, launcher_distance=300, coverage=360)
for i, position in enumerate(positions):
self.add_unit(AirDefence.AAA_Vulcan_M163, "SPAAA#" + str(i), position[0], position[1], position[2])
self.add_unit(AirDefence.AAA_Vulcan_M163, "SPAAA#" + str(i), position[0], position[1], position[2])

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class RapierGenerator(GroupGenerator):
class RapierGenerator(GenericSamGroupGenerator):
"""
This generate a Rapier Group
"""

View File

@@ -1,9 +1,9 @@
from dcs.vehicles import AirDefence, Unarmed
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class RolandGenerator(GroupGenerator):
class RolandGenerator(GenericSamGroupGenerator):
"""
This generate a Roland group
"""
@@ -12,7 +12,7 @@ class RolandGenerator(GroupGenerator):
price = 40
def generate(self):
self.add_unit(AirDefence.SAM_Roland_ADS, "ADS", self.position.x, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Roland_EWR, "EWR", self.position.x + 40, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_Roland_ADS, "ADS", self.position.x, self.position.y, self.heading)
self.add_unit(Unarmed.Transport_M818, "TRUCK", self.position.x + 80, self.position.y, self.heading)

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class SA10Generator(GroupGenerator):
class SA10Generator(GenericSamGroupGenerator):
"""
This generate a SA-10 group
"""
@@ -14,15 +14,15 @@ class SA10Generator(GroupGenerator):
price = 450
def generate(self):
# Command Post
self.add_unit(AirDefence.SAM_SA_10_S_300PS_CP_54K6, "CP", self.position.x, self.position.y, self.heading)
# Search Radar
self.add_unit(AirDefence.SAM_SA_10_S_300PS_SR_5N66M, "SR1", self.position.x, self.position.y + 40, self.heading)
# Search radar for missiles (optionnal)
self.add_unit(AirDefence.SAM_SA_10_S_300PS_SR_64H6E, "SR2", self.position.x - 40, self.position.y, self.heading)
# Command Post
self.add_unit(AirDefence.SAM_SA_10_S_300PS_CP_54K6, "CP", self.position.x, self.position.y, self.heading)
# 2 Tracking radars
self.add_unit(AirDefence.SAM_SA_10_S_300PS_TR_30N6, "TR1", self.position.x - 40, self.position.y - 40, self.heading)

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class SA11Generator(GroupGenerator):
class SA11Generator(GenericSamGroupGenerator):
"""
This generate a SA-11 group
"""
@@ -14,8 +14,8 @@ class SA11Generator(GroupGenerator):
price = 180
def generate(self):
self.add_unit(AirDefence.SAM_SA_11_Buk_CC_9S470M1, "CC", self.position.x, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_SA_11_Buk_SR_9S18M1, "SR", self.position.x+20, self.position.y, self.heading)
self.add_unit(AirDefence.SAM_SA_11_Buk_CC_9S470M1, "CC", self.position.x, self.position.y, self.heading)
num_launchers = random.randint(2, 4)
positions = self.get_circular_position(num_launchers, launcher_distance=140, coverage=180)

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class SA2Generator(GroupGenerator):
class SA2Generator(GenericSamGroupGenerator):
"""
This generate a SA-2 group
"""

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class SA3Generator(GroupGenerator):
class SA3Generator(GenericSamGroupGenerator):
"""
This generate a SA-3 group
"""

View File

@@ -2,10 +2,10 @@ import random
from dcs.vehicles import AirDefence
from gen.sam.group_generator import GroupGenerator
from gen.sam.genericsam_group_generator import GenericSamGroupGenerator
class SA6Generator(GroupGenerator):
class SA6Generator(GenericSamGroupGenerator):
"""
This generate a SA-6 group
"""