Depends On Abilifier v1.4.1.0 or higher!,
Versions 3.1.2.4 and higher depend on CBTBehaviorsEnhanced 2.3.5 or higher
Versions 3.1.0.0 and higher requires modtek v3 or higher
This mod enables, fixes, and expands the unused vanilla Command Abilities. There are two main "types" of abilities, Strafes and Spawns.
settings in the mod.json:
"enableLogging": true,
"enableTrace": false,
"flareResourceID": "vfxPrfPrtl_fireTerrain_smLoop",
"showStrafeCamera": false,
"strafeEndsActivation": true,
"spawnTurretEndsActivation": true,
"deployProtection": 8,
"strafeTargetsFriendliesChance": 1.0,
"strafeObjectiveBuildingsChance": 0.1,
"strafeNeutralBuildingsChance": 0.2,
"strafeSensorFactor": 4.0,
"strafeVelocityDefault": 150.0,
"strafeAltitudeMin": 75.0,
"strafeAltitudeMax": 250.0,
"strafePreDistanceMult": 15.0,
"strafeMinDistanceToEnd": 10.0,
"timeBetweenAttacks": 0.35,
"commandUseCostsMulti": 1.0,
"deploymentBeaconEquipment": [
"Item.UpgradeDef.Gear_TurretBeacon_Cicada",
"Item.UpgradeDef.Gear_TurretBeacon_Cicada2",
"Item.UpgradeDef.Gear_TurretBeacon_kanazuchi",
"Item.UpgradeDef.Gear_TurretBeacon_hvac",
"Item.UpgradeDef.Gear_TurretBeacon_lgr",
"Item.UpgradeDef.Gear_TurretBeacon_Schiltron",
"Item.UpgradeDef.Gear_TurretBeacon_Schiltron2"
],
"customSpawnReticleAsset": "select_spawn_reticle",
"customSpawnReticleColor": {
"r": 255,
"g": 16,
"b": 240
},
"MountIndicatorAsset": "Target",
"MountIndicatorColor": {
"r": 0,
"g": 187,
"b": 255
},
"strafeAAFailThreshold": 0.75
"strafeWaves": 3,
"commandAbilities_AI": [
{
"ContractBlacklist": [
"DuoDuel",
"CaptureBase_AbandonedFactory"
],
"AbilityDefID": "AbilityDefCMD_Strafe_AI",
"FactionIDs": [
"ClanGhostBear",
"ClanWolf"
],
"AddChance": 0.0,
"DiffMod": 0.0,
"MaxUsersAddedPerContract": 0,
"AvailableBeacons": [
{
"UnitDefID": "vehicledef_MECHBUSTER_AERO",
"Weight": 10,
"StrafeWaves": 3
}
]
}
],
"AI_SpawnBehavior": [
{
"Tag": "ProtoMech",
"Behavior": "AMBUSH",
"MinRange": "5"
}
],
"BattleArmorMountAndSwarmID": "AbilityDefBattleArmorMount",
"BattleArmorDeSwarmRoll": "AbilityDefDeSwarmerRoll",
"BattleArmorDeSwarmSwat": "AbilityDefDeSwarmerSwat",
"ArmActuatorCategoryIDs": [
"ArmShoulder",
"ArmUpperActuator",
"ArmLowerActuator",
"OmniLowerActuator",
"ArmHandActuator",
"OmniHandActuator"
],
"DeswarmConfigs": {
"AbilityDefDeSwarmerRoll": {
"BaseSuccessChance": 0.55,
"MaxSuccessChance": 0.95,
"PilotingSuccessFactor": 0.05,
"TotalDamage": 150,
"Clusters": 5,
"InitPenalty": 2
},
"AbilityDefDeSwarmerSwat": {
"BaseSuccessChance": 0.33,
"MaxSuccessChance": 0.95,
"PilotingSuccessFactor": 0.05,
"TotalDamage": 75,
"Clusters": 3,
"InitPenalty": 1
}
},
"DeswarmMovementConfig": {
"AbilityDefID": "AbilityDefDeSwarmerMovement",
"BaseSuccessChance": 0.35,
"MaxSuccessChance": 0.95,
"EvasivePipsFactor": 0.1,
"JumpMovementModifier": 1.2,
"UseDFADamage": true,
"LocationDamageOverride": 0,
"PilotingDamageReductionFactor": 0.1
},
"BPodComponentIDs": [
"Gear_B_Pod"
],
"BPodsAutoActivate": true,
"BATargetEffects": [
{
"ID": "BA_AccurateFire",
"TargetEffectType": "SWARM",
"Name": "Battle Armor - SwarmingAccuracy",
"description": "Battle Armor has greatly increased accuracy against the unit it is swarming.",
"effectDataJO": [
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_EasyTargetingPassive",
"Name": "Easy shots",
"Details": "Battle Armor has increased accuracy while swarming.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Set",
"modValue": "-9001",
"modType": "System.Single"
}
},
{
"durationData": {
"duration": -1,
"stackLimit": -1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator"
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_CALLED_SHOT",
"Name": "BA Called Shot",
"Details": "Called Shots twice as reliable when swarming",
"Icon": "uixSvgIcon_ability_mastertactician"
},
"statisticData": {
"statName": "CalledShotBonusMultiplier",
"operation": "Float_Multiply",
"modValue": "9001.0",
"modType": "System.Single"
}
},
{
"durationData": {
"duration": -1,
"stackLimit": -1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInTargetPreview": false,
"showInStatusPanel": false
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_FocusFireCluster",
"Name": "BA ClusterFuck",
"Details": "Better clustering for BA while swarming.",
"Icon": "UixSvgIcon_specialEquip_System"
},
"statisticData": {
"statName": "ClusteringModifier",
"operation": "Float_Add",
"modValue": "9001",
"modType": "System.Single",
"targetCollection": "Weapon"
},
"nature": "Buff"
}
]
},
{
"ID": "BA_MountedFireDebuff",
"TargetEffectType": "MOUNT_INT",
"Name": "Battle Armor - Mounted Debuff",
"description": "Battle Armor has decreased accuracy when firing while mounted.",
"effectDataJO": [
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_EasyTargetingPassive",
"Name": "Easy shots",
"Details": "Battle Armor has decreased accuracy while mounted.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Set",
"modValue": "8",
"modType": "System.Single"
}
}
]
},
{
"ID": "BA_MountedFireDebuff",
"TargetEffectType": "MOUNT_EXT",
"Name": "Battle Armor - Mounted Debuff",
"description": "Battle Armor has decreased accuracy when firing while mounted.",
"effectDataJO": [
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_EasyTargetingPassive",
"Name": "Easy shots",
"Details": "Battle Armor has decreased accuracy while mounted.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Set",
"modValue": "8",
"modType": "System.Single"
}
}
]
},
{
"ID": "BA_GarrisonDefense",
"TargetEffectType": "GARRISON",
"Name": "Battle Armor - Garrisoned Defensive Bonuses",
"Description": "Garrisoned units have Defensive bosnuses.",
"effectDataJO": [
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_GartrisonDamageResistance",
"Name": "AOE Immune",
"Details": "arrisoned units have 30% additional damage resist.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "DamageReductionMultiplierAll",
"operation": "Float_Add",
"modValue": "-0.3",
"modType": "System.Single"
}
},
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "BA_GartrisonDamageResistance",
"Name": "AOE Immune",
"Details": "arrisoned units have 30% additional damage resist.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "ToHitThisActor",
"operation": "Float_Add",
"modValue": "5.0",
"modType": "System.Single"
}
}
]
}
],
"AirliftTargetEffects": [
{
"ID": "Airlift_Accuracy",
"FriendlyAirlift": true,
"Name": "Airlift Airlift_Accuracy",
"Description": "Airlifted Units get extra accuracy because t-bone needed to test something.",
"effectDataJO": [
{
"durationData": {},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "Airlift_Accuracy_Bonus",
"Name": "Easy shots",
"Details": "Airlift_Accuracy has increased accuracy while airlift.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Set",
"modValue": "-9001",
"modType": "System.Single"
}
}
]
}
],
"OnGarrisonCollapseEffects": [
{
"ID": "GarrisonCollapseAccuracy",
"TargetEffectType": "GARRISON",
"Name": "Accuracy Penalty",
"Description": "Accuracy Penalty when building collapse",
"effectDataJO": [
{
"durationData": {
"duration": 2,
"stackLimit": 1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "Garrison_Collapse_accuracy",
"Name": "hard shots",
"Details": "Garrison_Collapse_accuracy has worse accuracy after collpase.",
"Icon": "allied-star"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Float_Add",
"modValue": "10",
"modType": "System.Single"
}
}
]
}
],
"BattleArmorFactionAssociations": [
{
"FactionIDs": [
"ClanGhostBear",
"ClanWolf"
],
"SpawnChanceBase": 0.3,
"SpawnChanceDiffMod": 0.05,
"MaxSquadsPerContract": 4,
"InternalBattleArmorWeight": {
"mechdef_ba_is_standard": 5,
"mechdef_ba_marauder": 2
},
"MountedBattleArmorWeight": {
"mechdef_ba_is_standard": 5,
"mechdef_ba_infiltratormkii": 2,
"BA_EMPTY": 3
},
"HandsyBattleArmorWeight": {
"mechdef_ba_marauder": 1,
"BA_EMPTY": 2
}
}
],
"AttackOnSwarmSuccess": true,
"AI_BattleArmorExcludedContractTypes": [
"DuoDuel",
"SoloDuel"
],
"AI_BattleArmorExcludedContractIDs": [],
"BeaconExclusionConfig": {
"DuoDuel": {
"ExcludedPlayerSpawn": true,
"ExcludedPlayerStrafe": true,
"ExcludedAISpawn": true,
"ExcludedAIStrafe": true
},
"CaptureBase_AbandonedFactory": {
"ExcludedPlayerSpawn": false,
"ExcludedPlayerStrafe": true,
"ExcludedAISpawn": false,
"ExcludedAIStrafe": false
}
},
"BeaconExcludedContractIDs": [],
"DisableGarrisons": false,
"GarrisonBuildingArmorFactor": 0.5,
"UsingMechAffinityForSwarmBreach": true,
"AirliftAbilityID": "AbilityDefAirliftActivate",
"AirliftCapacityByTonnage": false,
"CanDropOffAfterMoving": true,
"AirliftImmuneTags": [
"unit_vtol",
"unit_turret"
],
"ResupplyConfig": {
"ResupplyIndicatorAsset": "Target",
"ResupplyIndicatorColor": {
"r": 255,
"g": 0,
"b": 255
},
"ResupplyIndicatorInRangeAsset": "Target",
"ResupplyIndicatorInRangeColor": {
"r": 255,
"g": 255,
"b": 0
},
"ResupplyAbilityID": "AbilityDefResupply",
"ResupplyUnitTag": "RedBatHatesFunnyTagsSoThisIsAnUnfunnyTag",
"SPAMMYAmmoDefId": "Ammunition_SPAMMY",
"SPAMMYBlackList": [],
"InternalSPAMMYDefId": "Ammunition_IntSPAMMY",
"InternalSPAMMYBlackList": [
"Weapon_Medium_Recoilless_BA"
],
"ArmorSupplyAmmoDefId": "Ammunition_ARMORAMMO",
"ArmorRepairMax": 0.9,
"BasePhasesToResupply": 30.0,
"ResupplyPhasesPerAmmoTonnage": 30,
"ResupplyPhasesPerArmorPoint": 30,
"UnitTagFactor": {
"omni_resupply": 0.1
},
"ShowAmmoInVehicleTooltips": true,
"EnforceIFFForAmmoTooltips": false,
"EnableQuickReserve": true,
"SBI_HesitationMultiplier": 0,
"EquipmentButtonsHotkey": "N",
"PlayerControlBeacons": true,
"PlayerControlSpawnAbilities": [],
"PlayerControlSpawnAbilitiesBlacklist": [],
"DisableAISwarmTag": "AI_DISABLE_SWARM",
"crewOrCockpitCustomID": [
"CrewCompartment",
"Cockpit"
],
"BAMountPairColors": [
{
"r": 255,
"g": 0,
"b": 0
},
{
"r": 255,
"g": 0,
"b": 255
},
{
"r": 0,
"g": 0,
"b": 255
},
{
"r": 0,
"g": 255,
"b": 255
},
{
"r": 0,
"g": 255,
"b": 0
},
{
"r": 255,
"g": 255,
"b": 0
},
{
"r": 255,
"g": 255,
"b": 255
}
],
"BAMountReminderText": "Shift-click unit in drop slot to set carrier",
"MeleeOnSwarmAttacks": true
enableLogging
- bool, enable logging
enableTrace
- bool, enable verbose logging
flareResourceID
- string, name of vFX resource used for flares denoting strafe/spawn positions
showStrafeCamera
- bool, if true, camera will show 1st person view of strafing unit as it flies in (but view returns to normal before it starts shooting).
strafeEndsActivation
- bool, do strafes automatically end the turn of the unit using them?
spawnTurretEndsActivation
- bool, does spawn unit automatically end the turn of the unit using them?
deployProtection
- int, number of evasion pips added to deployed units at spawn (IRTweaks/MC spawn protection dont work on these)
strafeTargetsFriendliesChance
- float, probability that strafing targets friendly units
strafeNeutralBuildingsChance
- float, probability that strafing targets non-objective buildings (friendly buildings are covered by strafeTargetsFriendliesChance
)
strafeObjectiveBuildingsChance
- float, probability that strafing targets mission objective buildings
strafeSensorFactor
- float, multiplier of strafing units base sensor range for revealing sensor blips of hostiles as it flies over them.
strafeVelocityDefault
- float, default velocity of strafing unit while strafing. The faster the unit moves, the fewer targets it will be able to hit during a strafe. If MaxSpeed is > 0 in the strafing unit, then that speed will override this value.
strafeAltitudeMin
and strafeAltitudeMax
- float. The altitide of the strafing unit is the maximum weapon range of the strafing unit divided by 4, but is clamped between these two values.
strafePreDistanceMult
- float, controls the distance at which the strafing unit is instantiated from the point of strafing start; influences the length of the "fly-in" sequence.
strafeMinDistanceToEnd
- float, distance from the strafing unit to the endpoint of the strafe at which the strafe is considered to be "complete" and no more targets will be attacked.
timeBetweenAttacks
- float. minimum amount of time that must elapse before strafing unit can instantiate another attack. 0.35 is HBS' default, can probably go as low as 0.1 without strange things happening. really only a minor tweak if you think the strafing units arent attacking "enough", but velocity and elevation are likely more important.
commandUseCostsMulti
- float, multiplier governing costs of using command abilities. if >0, the cost of the unit being used (as defined in the unit def) is multiplied by this value to obtain a per-use cost of using the ability. should probably only be used if beacons are not set to be consumed, or at least set to some low value. this cost will stack with any manually defined costs in the AbilityDef using Abilifier
deploymentBeaconEquipment
- List, list of component IDs that are considered "deployment beacons" to give options for the specific unit that gets deployed/strafes during combat.
customSpawnReticleColor
- new type, defines custom color of reticle used for spawns. fields r, g, b, are RGB values, 0-255.
customSpawnReticleAsset
string. name of custom .DDS asset that will be used for Spawn reticle (needs to be one that is added to manifest via modtek)
MountIndicatorAsset
- string. name of custom .DDS asset that will be used for Mount indicator when using Battle Armor (needs to be one that is added to manifest via modtek)
MountIndicatorColor
- as customSpawnReticleColor
, defines custom color of reticle used for Mount indicator. fields r, g, b, are RGB values, 0-255.
strafeAAFailThreshold
- float, if chance to have strafe cancelled due to AA factor is greater than this, AI will not attempt to strafe
strafeWaves
- int, default number of units (same unit copied multiple times) that will perform a strafe. e.g., if set to 3 and strafe calls a Lightning Aerospace fighter, 3 Lightnings will strafe the target area in succession. They tend to target exactly the same units (unless of course one of the targeted units gets destroyed by one of the previous strafing units). Overriden by mechcomponent tags in beacons where tag is "StrafeWaves_X" where X is the number of waves. E.g. a beacon with tag StrafeWaves_5
would strafe with 5 units.
"AI_FactionBeacons" deprecated in 2.0.2.8: essentially functions the same as
deploymentBeaconEquipment`, but restricts factions listed to the corresponding equipment. if a faction is not listed in here, it will use only the "default" unit listed in a given command ability.
commandAbilities_AI
- Format Change in v2.0.2.8 - Changed to similar format as BattleArmorFactionAssociations
. Can be used to give AI strafe and spawn (Beacon) abilities. Obviously the StrafeWaves field only applies to strafes, and will do nothing for beacons. MaxUsersAddedPerContract limit is based on only this ability, and is separate per faction. I.e, in a 3-way contract with you, ClanGhostBear and ClanWolf, both Ghost Bear and Wolf could get 3 units each with AbilityDefCMD_Strafe_AI.
new in v3.1.1.0 "ContractBlacklist" defines contract types and/or individual contract IDs for which this specific ability cannot be added to the AI
"commandAbilities_AI": [
{
"ContractBlacklist": [
"DuoDuel",
"CaptureBase_AbandonedFactory"
],
"AbilityDefID": "AbilityDefCMD_Strafe_AI",
"FactionIDs": [
"ClanGhostBear",
"ClanWolf"
],
"AddChance": 0.0,
"DiffMod": 0.0,
"MaxUsersAddedPerContract": 0,
"AvailableBeacons": [
{
"UnitDefID": "vehicledef_MECHBUSTER_AERO",
"Weight": 10,
"StrafeWaves": 3
}
]
}
]
AI_SpawnBehavior
- list of "spawn behavior" for AI to use if they recieve a "spawn" type ability. Largely affects spawn positioning. "Tag" corresponds to a MechDef tag on the unit being spawned that will use the Behavior and MinRange defined in the setting. If the unit has multiple tags matching a behavior setting, it will simply use the behavior matching the first tag with a behavior defined. Options for behavior are: "AMBUSH" which will attempt to spawn the unit as close as possible to the nearest enemy, "BRAWLER" which will attempt to spawn the unit at an approximate centroid of all detected enemies, and "REINFORCE" which will attempt to spawn at the approximate centroid of all friendlies. MinRange simply sets a minimum spawn distance from any actor. Example setting:
{
"Tag": "ProtoMech",
"Behavior": "AMBUSH",
"MinRange": "5"
}
BattleArmorMountAndSwarmID
- string, ability ID of component ability that will allow Battle Armor to mount/swarm units (same ability is used for both). Ability will need to be added to BA specific component (something all BA, but only BA will have, such as cockpit. Should be one of the "hidden" single components so there are not duplicates).
BattleArmorDeSwarmRoll
- string, ability ID of pilot ability that allows mech to "roll" (forced self-knockdown) in order to dislodge swarming battle armor. Chance of success is 50% + (Piloting skill x 5%), capped at 95%. On a success, there is a 30% chance to smush the Battle Armor in the process. Ability is automatically granted to Mechs at contract start (e.g. does not need to be added manually to pilot).
BattleArmorDeSwarmSwat
- string, ability ID of pilot ability that allows mech to "swat" swarming battle armor (remove using arms). Chance of success is 30% + (Piloting skill x 5%) - 5% for each "missing" arm actuator. An arm actuator is considered "missing" if it is destroyed, or was never mounted in the first place. Shoulder, Upper Arm, Lower Arm, and Hand for both left and right arms; thus a mech missing both arms would suffer a 40% penalty (8 x 5%). Ability is automatically granted to Mechs at contract start (e.g. does not need to be added manually to pilot).
BattleArmorDeSwarmMovement
- support for new ability giving units a chance to deswarm BA from movement. See below for details.
ArmActuatorCategoryIDs
- list of strings, Custom Category IDs identifying actuators that will be considered in BattleArmorDeSwarmSwat
calculations. E.g, if ArmActuator is listed here and an actuator has the following, it would be counted:
{
"Custom": {
"Category" : [
{"CategoryID": "ArmActuator"},
{"CategoryID": "NonQuad"}
],
new/changed in 3.0.0.0
DeswarmConfigs
: dictionary - configurations for Deswarm abilities used by mechs; variables previously set in the AbilityDef are now controlled here:
- dictionary "key" is the abilityDef ID (i.e AbilityDefDeSwarmerRoll)
- BaseSuccessChance and MaxSuccessChance control the min and maximum success chance
- Piloting success factor is modifier for piloting skill added to success chance (swat ability also still uses # of intact actuators as before)
- TotalDamage total amount of damage dealt to suit on successful roll
- Clusters - TotalDamage is divided into this man clusters, and dealt randomly to the squad
- InitPenalty - int penalty
DeswarmMovementConfig
: config for movement-based deswarming (erratic maneuvers)
- AbilityDefID - ability def ID of the ability
- BaseSuccessChance and MaxSuccessChance as above
- EvasivePipsFactor success factor added based on evasive pips generated by the move
- JumpMovementModifier added if move is a jump
- UseDFADamage bool, if true will use chassis dfa damage to deal damage on success (for jump moves)
- LocationDamageOverride- damage to be dealt if UseDFADamage = false
- PilotingDamageReductionFactor = damage will be reduced by (this value x piloting)%. So setting to 0.1 and a unit with Piloting 6 would only take 40% ("60% less") damage.
BPodComponentIDs
- List of string componenet IDs for CAE gear that, when activated, will function as B-Pods, detonating and damaging only Battle Armor.
BPodsAutoActivate
- bool, if true BPod Components will auto-activate when the unit carrying them gets swarmed. If false, only BPods mounted on AI-controlled units will auto-activate (players must manually activate BPods using CAE activation).
new/changed in 3.0.3.2
BATargetEffects
- Effects which will be applied to Battle Armor or target unit while swarming or mounting, depending on value of TargetEffectType
field. Can be GARRISON, SWARM, MOUNT_INT, MOUNT_EXT, or BOTH for effects targeting the battle armor squad. TargetEffectType
can also be MOUNTTARGET, SWARMTARGET, or BOTHTARGET for effects targeting the unit being mounted, swarmed, or both. Intended use is to improve accuracy and clustering of swarming BA so they always (usually, mostly) hit the same location on the unit they're swarming, and give mounted BA a debuff to accuracy when firing from mount. Of course you can add whatever else you want here. MOUNT_INT will take effect only when mounted internally, while MOUNT_EXT will take effect only when mounted externally. SWARM will only take effect when swarming, and BOTH will always take effect. GARRISON will take effect only when units are occupying a building. Effects applied here will be cancelled when the swarm/mount is stopped (so infinite duration makes sense to use here).
new/changed in 3.0.0.0
AirliftTargetEffects
- effects that will take effect when a unit is airlifted. If FriendlyAirlift = true, will only take effect when being airlifted by firendly unit. If FriendlyAirlift = false, will only take effect when being airlifted by hostile unit. Effects applied here will be cancelled when the swarm/mount is stopped (so infinite duration makes sense to use here).
new/changed in 3.0.0.0
OnGarrisonCollapseEffects
- effects that will effect squad when a garrisoned building collapses. intended for debuffs, etc. You should probably set a duration for these so they expire eventually.
DEPRECATED, IMPLEMENTED IN BattleArmorFactionAssociationsAI_BattleArmorSpawnChance
- float, base probability that AI units that can mount Battle Armor, either mounted externally or internally, will get Battle Armor at contract start. Note that any added Battle Armor is independent of any "support lance" or "extra lance" settings in Mission Control or other mods. Added to AI_BattleArmorSpawnDiffMod for total chance.
AI_BattleArmorSpawnDiffMod - float, contract difficulty is multiplied by this value and added to AI_BattleArmorSpawnChance to determine probability of AI units spawning BA. DEPRECATED, IMPLEMENTED IN BattleArmorFactionAssociations
BattleArmorFactionAssociations
- Faction information for AI battle armor spawning. This has been revamped in v2.0.1.8.
FactionIDs is a list of faction IDs for which this particular config will be applied. If a faction is not present in any configs, it will not spawn Battle Armor. If a faction is present in multiple configs, only the first config in the list will be used for that faction.
Using the following settings, ClanGhostBear and ClanWolf have baseline 30% chance to spawn Battle Armor, + 5% per difficulty level, with rolls against that occurring separately for internal mounting space (i.e. APCs), external mounts (i.e. Omnimechs), and for conventional (non-omni) mechs pulling from HandsyBattleArmorWeight
. For units with internal mounting space, each internal slot is rolled separately. For all "mounting types", an entry BA_EMPTY
can be used to further tweak the spawn %; if BA_EMTPY is chosen, no BA will spawn for that "mounting type." For example using the below settings a unit without internal storage or BA mounts would have only 0.33 x base%+difficulty%
calculated chance to actually spawn mechdef_ba_marauder
, while a unit with BA mounts would have 0.7 x base%+difficulty%
calculated chance to spawn battle armor. Lastly, MaxSquadsPerContract
defines an upper limit for the # of BA squads a given faction can spawn during a contract.
"BattleArmorFactionAssociations": [
{
"FactionIDs": [
"ClanGhostBear",
"ClanWolf"
],
"SpawnChanceBase": 0.3,
"SpawnChanceDiffMod": 0.05,
"MaxSquadsPerContract": 4,
"InternalBattleArmorWeight": {
"mechdef_ba_is_standard": 5,
"mechdef_ba_marauder": 2
},
"MountedBattleArmorWeight": {
"mechdef_ba_is_standard": 5,
"mechdef_ba_infiltratormkii": 2,
"BA_EMPTY": 3
},
"HandsyBattleArmorWeight": {
"mechdef_ba_marauder": 1,
"BA_EMPTY": 2
}
}
],
AttackOnSwarmSuccess
- bool, if true BA will initiate an attack sequence on a successful swarming attempt (rather than needing to wait until the subsequence activation)
AI_BattleArmorExcludedContractTypes
- List of ContractTypes where AI is not allowed to spawn mounted Battle Armor
AI_BattleArmorExcludedContractIDs
- List of contract IDs where AI is not allowed to spawn mounted Battle Armor
deprecated v3.1.1.0, replaced by BeaconExclusionConfig
BeaconExcludedContractTypes
- List of ContractTypes where deployment or strafing beacons are not allowed to be used
BeaconExcludedContractIDs
- List of contract IDs where deployment or strafing beacons are not allowed to be used
BeaconExclusionConfig
- Dictionary of form <string, config>, where the key refers to either a ContractType name or specific contract ID. See below for example. Note that this configuration works in conjunction with commandAbilities_AI
exclusions described later. Those exclusions simply prevent those specific abilities being added to AI procedurally at contract start. This setting will prevent such abilities from being used even if added. It is also necessary to prevent AI usage of abilities granted via equipment or pilots.
"BeaconExclusionConfig": {
"DuoDuel": {
"ExcludedPlayerSpawn": true,
"ExcludedPlayerStrafe": true,
"ExcludedAISpawn": true,
"ExcludedAIStrafe": true
},
"CaptureBase_AbandonedFactory": {
"ExcludedPlayerSpawn": false,
"ExcludedPlayerStrafe": true,
"ExcludedAISpawn": false,
"ExcludedAIStrafe": false
}
},
new/changed in 3.0.0.0
DisableGarrisons
- bool, if true BA cannot garrison buildings
GarrisonBuildingArmorFactor
- float, multiplier of BA squad armor+structure to be added to buildings they are garrisoning
UsingMechAffinityForSwarmBreach
- use MechAffinity implementation to give BA swarms breaching shot (if using MechAffinity, need to have BATargetEffect on swarm that sets the appropriate stat to true).
AirliftAbilityID
- abilityDef ID for airlift ability
AirliftCapacityByTonnage
- if true, airlift capacity will be determined by tonnage rather than absolute # of units
CanDropOffAfterMoving
- if true, airlift units can move and then drop their airlifted units at final location. if false, airlifted units must drop units before moving that round.
AirliftImmuneTags
- list of unit def tags that render that unit immune to airlifting. use for vtols and turrets, stuff like that. although airlifting turrets is pretty amusing
ResupplyConfig
- config options for resupply abilities. see Resupply section
ShowAmmoInVehicleTooltips
- if true, ammo counter will be shown in vehicle paperdoll (like what AIM does for mechs)
EnforceIFFForAmmoTooltips
- if true, above ammo counter will only be shown for friendly vehicles
EnableQuickReserve
- if true, Shift-minus
(Shift-click the "Done" button) will reserve the current unit all the way to the last phase of the round.
SBI_HesitationMultiplier
- float, if EnableQuickReserve is enabled, this value will integrate with SkillBasedInitiative (if found). Using the "quick reserve" function will result in a final "hesitation" value calculated by: final hesitation = SBI_HesitationMultiplier x phasesMoved + SBI_MOD_HESITATION (from the unit, since i saw its a thing in SBI) + currentHesitation
EquipmentButtonsHotkey
- This button will cycle through activating any equipment abilities the unit has. Abilities (with a button), NOT CAE component functions like LAM transformation. Think how the alpha 1 through 0 hotkeys work for fire, walk, sprint, etc. It won't actually activate the ability, it will just bring it up for confirmation/selection. Probably don't set this to something that has an existing keybinding in-game.
PlayerControlSpawns
- bool. if true, friendly mechs and vehicles (not turrets) deployed via beacons will be placed under normal player control rather than an AI-controlled friendly team. Their pilots are still defined by either CMDPilotOverride in the spawn ability, or by pilot overrides in the unit beacon as normal. Overrides all other player-control factors described below.
PlayerControlSpawnAbilities
- list, string. List of AbilityDef IDs which will always allow player control spawns regardless of all other factors.
PlayerControlSpawnAbilitiesBlacklist
- list, string. List of AbilityDef IDs which will never allow player control spawns regardless of all other factors.
DisableAISwarmTag
- string, AI units with unit def tag are unable to swarm regardless of equipment
crewOrCockpitCustomID
- List - define cockpit/crew compartment Custom Category IDs. used to ensure AI strafe/spawn abilities are associated with correct component. use same values as similar setting in TisButAScratch; defaults are "CrewCompartment"
and "Cockpit"
, but the setting is provided in case more IDs are needed or desired. AI strafe/spawn ability will be added to the first component that has a matching category ID.
BAMountPairColors
- list of color configs (same format as MountIndicatorColor
setting) that defines possible overlay colors for pre-mission squad and carrier assignments.
BAMountReminderText
- controls reminder text for shift-click to assign squads to carriers, which is displayed below the mech widget in the lance config screen
MeleeOnSwarmAttacks
- if true, BA will initiate a melee weapon attack when swarming (and when attacking during an ongoing swarm).
Spawns are basically what they sound like: spawning reinforcement units at the selected location. These units may be either freindly AI-controlled (including all turrets), or can be player-controlled depending on settings. If PlayerControlSpawns
, all friendly vehicles, mechs, BA spawns are player-controlled. If PlayerControlSpawns
is false, the following applies, in this order:
- If a spawnable unit beacon item (described further below) contains the tag
StratOps_player_control_enable
, the player will control the unit, regardless of any other factors. - If a spawnable unit beacon item (described further below) contains the tag
StratOps_player_control_disable
, the player will never control the unit, regardless of any other factors.
If neither of the above applies:
- If the ability doing the spawning is listed in mod.json setting
PlayerControlSpawnAbilities
, the player will control the unit. - If the ability doing the spawning is listed in mod.json setting
PlayerControlSpawnAbilitiesBlacklist
, the player will not control the unit.
If none of the above applies:
- If the player has the company statistic
StratOps_ControlSpawns
set to true, the player will control the unit.
Exactly what unit gets deployed depends on a few things.
-
The "type" of the unit noted in
ActorResource
defines the type of unit that can be deployed by that ability. If it starts with "mechdef_", then mechs can be deployed. If it starts with "vehicledef_", then vehicles can be deployed. If it starts with "turretdef_" then turrets can be deployed. -
Holding shift while activating the ability will bring up a popup with any available units to select for deployment (in addition to the default assigned in
ActorResource
). The player can obtain these "alternative" units by acquiring "deployment beacon" items. Deployment beacons can be of any upgrade type, but must have two things in their ComponentTags: they must have the tag "CanSpawnTurret", and they must have a tag with the ID of the unit they will enable for deployment, e.g. "mechdef_cicada_CDA-4G". The number of "probes" in the player inventory is the number of that unit that can be deployed in a given mission (within any restrictions also defined in the AbilityDef); i.e if you have 2 probes for mechdef_cicada_CDA-4G, you could deploy up to two of those Cicadas, and subsequent deployments would be limited to whatever unit is defined in the ability ActorResource. -
If the "beacon" item contains the string "ConsumeOnUse" in its component tags, the beacon item will be actually consumed on use; the player inventory in simgame will be decremented.
-
If the "beacon" item contains a component tag that starts with "StratOpsPilot_", the remainder of that tag should be the PilotDef ID of the pilot that will pilot the unit (overrides anything set by CMDPilotOverride below)
To ensure that all resources used by these abilities load properly, all spawn abilities should start with the AbilityDefCMD_
prefix.
Spawn ability json structure:
{
"Description" : {
"Id" : "AbilityDefCMD_UrbDrop",
"Name" : "UrbDrop",
"Details" : "DEPLOY MOBILE TURRET",
"Icon" : "uixSvgIcon_genericDiamond"
},
"CMDPilotOverride" : "pilot_sim_dekker",
"ActivationTime" : "CommandAbility",
"Resource" : "CommandAbility",
"ActivationCooldown" : -1,
"NumberOfUses" : 1,
"specialRules" : "SpawnTurret",
"Targeting" : "CommandSpawnPosition",
"ActorResource" : "mechdef_urbanmech_UM-R50",
"StringParam1" : "Deployment Unavailable",
"StringParam2" : "unit_urb",
"IntParam2" : 250
}
The configurable parameters of the above:
CMDPilotOverride
- string. if present and not "", lists ID of pilotDef for pilot that will use this unit.
Description
- as any other Ability Description
ActivationCooldown
- int, turn cooldown to use the ability again
NumberOfUses
- int, number of times the ability can be used in a given contract (set to -1 or remove for unlimited uses)
ActivationETA
- int, number of turns before the unit will be deployed.
ActorResource
- string, the default "def" ID of the unit to be deployed.
IntParam2
- int, the maximum distance from the initiating actor at which a unit can be deployed.
StringParam2
- string, tag that "beacons" componentDefs are required to have in order to be used by this ability.
FloatParam1
and FloatParam2
are not used in spawns (although FloatParam1
will control the size of the little green "ring" that shows up when deploying the ability, cosmetic only. Suggest setting both to 50 and forgetting about them.
Strafes are also mostly what they sound like: a flying unit strafing the battlefield. Valid targets for a strafe are calculated within an AOE around a line drawn between two points (the "strafing run"), and can be either units or Objective buildings. Friendly units within the AOE can and will be hit by the strafing run!
A unique feature of strafes is that the strafing unit will reveal the locations (minimal sensor blip) of hostile units it detects as it flies in to do the actual strafing. These sensor blips are removed/return to hidden at the start of the following round.
Similarly to Spawns, the actual unit doing the strafing depends on the following:
1) Only vehicles can be used for strafing.
-
Holding shift while activating the ability will bring up a popup with any available units to select for strafing (in addition to the default assigned in
ActorResource
). The player can obtain these "alternative" units by acquiring "deployment beacon" items. Deployment beacons for strafing can be of any upgrade type, but must have two things in their ComponentTags: they must have the tag "CanStrafe", and they must have a tag with the ID of the unit they will enable for strafing, e.g. "vehicledef_ALACORN_IIC". The number of "probes" in the player inventory is the number of times that unit can strafe in a given mission (within any restrictions also defined in the AbilityDef); i.e if you have 2 probes for vehicledef_ALACORN_IIC, you could strafe using that Alacorn twice, and subsequent strafes would be limited to whatever unit is defined in the ability ActorResource. -
If the "beacon" item contains the string "ConsumeOnUse" in its component tags, the beacon item will be actually consumed on use; the player inventory in simgame will be decremented.
-
If the "beacon" item contains a component tag that starts with "StratOpsPilot_", the remainder of that tag should be the PilotDef ID of the pilot that will pilot the unit (overrides anything set by CMDPilotOverride below)
-
If the "beacon" item contains a component tag that starts with "StrafeWaves_", the remainder of that tag should be the number (integer) of "waves" or copies of the unit that will do the strafing. E.g. StrafeWaves_3 would strafe with 3 of whatever the unit is.
To ensure that all resources used by these abilities load properly, all strafe abilities should start with the AbilityDefCMD_
prefix.
Updated in v3.0.3.3: AA factor
Now units can be given an "AA Factor". When a strafe is attempted, the cumulative AA Factor for all units on the target team and any of their allies is totalled up, and then divided by the total number of units on the target team and their allies. This value is the chance for any given unit in the target area to NOT be targeted. For example, lets say you are facing 3 units. One has anti air factor of 2.0, one has anti-air factor of 0.5, and the third has anti-air factors of 0. The final AA Factor would 83% ((2.0 + 0.5 + 0) / 3
), meaning that on average only 17% of the units in the target area would actually be targeted.
For AI, if the chance to be cancelled is greater than strafeAAFailThreshold
, they will not attempt it. For the player, the chance of success (not being cancelled) is displayed as part of the "Confirm" button before the strafe is actually confirmed.
Unit AA factor is now defined by two statistics. First, the bool statistic UseAAAFactor
must be true; if it is, then the float statistic on the unitdef or equipment, AAAFactor
. This allows for example, equipment that changes "UseAAAFactor" to turn "AA Mode" on or off, and then have the actual value of the AAAFactor determined by what weapons the unit has. e.g:
{
"durationData": {
"duration": -1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInTargetPreview": false,
"showInStatusPanel": false
},
"effectType": "StatisticEffect",
"Description": {
"Id": "AAAFactorForUnitOmni",
"Name": "AAAFactorForUnit Orientation",
"Details": "AAAFactorForUnit.",
"Icon": "uixSvgIcon_equipment_Gyro"
},
"statisticData": {
"statName": "AAAFactor",
"operation": "Float_Add",
"modValue": "0.5",
"modType": "System.Single"
},
"nature": "Buff"
}
The json structure of a strafe ability follows:
"Description" : {
"Id" : "AbilityDefCMD_Strafe",
"Name" : "STRAFE",
"Details" : "CALLS IN A STRAFING RUN BY YOUR AEROSPACE SUPPORT UNIT.",
"Icon" : "uixSvgIcon_genericDiamond"
},
"CMDPilotOverride" : "pilot_sim_dekker",
"ActivationTime" : "CommandAbility",
"Resource" : "CommandAbility",
"ActivationCooldown" : 1,
"NumberOfUses" : 1,
"ActivationETA" : 1,
"specialRules" : "Strafe",
"Targeting" : "CommandTargetTwoPoints",
"FloatParam1" : 100.0,
"FloatParam2" : 250.0,
"ActorResource" : "vehicledef_SCHREK",
"StringParam1" : "Strafe Unavailable",
"StringParam2" : "unit_urb",
"IntParam1" : 5,
"IntParam2" : 500
The configurable parameters of the above:
Description
- as any other Ability Description
CMDPilotOverride
- string. if present and not "", lists ID of pilotDef for pilot that will use this unit.
ActivationCooldown
- int, turn cooldown to use the ability again
NumberOfUses
- int, number of times the ability can be used in a given contract (set to -1 or remove for unlimited uses)
ActivationETA
- int, number of turns before the actual incoming strafe will occur.
FloatParam1
- float, the AOE radius in which a unit can be a valid target along the strafing run.
FloatParam2
- float, the maximum length of the strafing run.
ActorResource
- string, the default "def" ID of the unit doing the strafing.
IntParam1
- int, number of "flares" that pop up to show the strafing effect area.
IntParam2
- int, the maximum distance from the initiating actor at which a strafing run can be initialized OR ended! so you can't start a run at IntParam2
and still go FloatParam2
past it.
StringParam2
- string, tag that "beacons" componentDefs are required to have in order to be used by this ability.
Starting in 2.0.0.0, the AI can be given command abilities (spawn and strafe) just like the player. To reiterate, the following setting controls when/if the AI will be given a command ability. Any given AI unit can only receive a single command ability (i.e, a spawn or a strafe, but not both).
commandAbilities_AI
- Format Change in v2.0.2.8 - Changed to similar format as BattleArmorFactionAssociations
. Can be used to give AI strafe and spawn (Beacon) abilities. Obviously the StrafeWaves field only applies to strafes, and will do nothing for beacons. MaxUsersAddedPerContract limit is based on only this ability, and is separate per faction. I.e, in a 3-way contract with you, ClanGhostBear and ClanWolf, both Ghost Bear and Wolf could get 3 units each with AbilityDefCMD_Strafe_AI.
new in v3.1.1.0 "ContractBlacklist" defines contract types and/or individual contract IDs for which this specific ability cannot be added to the AI
"commandAbilities_AI": [
{
"ContractBlacklist": [
"DuoDuel",
"CaptureBase_AbandonedFactory"
],
"AbilityDefID": "AbilityDefCMD_Strafe_AI",
"FactionIDs": [
"ClanGhostBear",
"ClanWolf"
],
"AddChance": 0.0,
"DiffMod": 0.0,
"MaxUsersAddedPerContract": 0,
"AvailableBeacons": [
{
"UnitDefID": "vehicledef_MECHBUSTER_AERO",
"Weight": 10,
"StrafeWaves": 3
}
]
}
]
Generally speaking, if the AI can use a command ability, it will use a command ability. Because of this, I strongly suggest creating separate command abilities for AI use that a much higher cooldown and/or fewer uses than the command abilities available to the player. Unless you want to get spammed by strafes every round.
To reiterate, the following setting controls spawn behavior:
AI_SpawnBehavior
- list of "spawn behavior" for AI to use if they recieve a "spawn" type ability. Largely affects spawn positioning. "Tag" corresponds to a MechDef tag on the unit being spawned that will use the Behavior and MinRange defined in the setting. If the unit has multiple tags matching a behavior setting, it will simply use the behavior matching the first tag with a behavior defined. Options for behavior are: "AMBUSH" which will attempt to spawn the unit as close as possible to the nearest enemy, "BRAWLER" which will attempt to spawn the unit at an approximate centroid of all detected enemies, and "REINFORCE" which will attempt to spawn at the approximate centroid of all friendlies. MinRange simply sets a minimum spawn distance from any actor. Example setting:
{
"Tag": "ProtoMech",
"Behavior": "AMBUSH",
"MinRange": "5"
}
Strafes for the AI function largely in the same way as they do for the player. The AI will attempt to use strafes in a way that has the most enemy targets in the affected area, but will ignore friendly units in their calculations (given two options, one of which would hit 3 of your units and 3 of theirs versus another that would hit 2 of your units and none of theirs, they'll choose the 3 + 3). That said, the calculation isn't very smart, and the "start point" of a strafing run will always be the nearest target unit even if there is another orientation that would hit more enemies. I didn't want to iterate through every single possible start position and orientation because it became computationally expensive. Because of the logic involved this also means that if multiple enemies have a strafe available they'll tend to stack multiple strafes in the exact same orientation (assuming no units moved/nothing else changed between enemy A and enemy B activating).
Buckle up buttercup, there's a lot happening here.
Battle Armor can now mount/be carried by friendly units, as well as initiate true swarming attacks against enemies. Likewise, BattleMechs can attempt to dislodge swarming Battle Armor.
In order to mount/be carried, the battle armor must have a component ability such as the following:
{
"Description": {
"Id": "AbilityDefBattleArmorMount",
"Name": "Mount Up",
"Details": "ACTION: Battle armor will mount/dismount selected unit",
"Icon": "uixSvgIcon_skullAtlas"
},
"DisplayParams": "ShowInMWTRay",
"ActivationTime": "ConsumedByMovement",
"ActivationCooldown": -1,
"Targeting": "ActorTarget",
"ResolveCost": 0,
"TargetFriendlyUnit": "BOTH",
"EffectData": [
{
"durationData": {
"duration": -1,
"stackLimit": -1
},
"targetingData": {
"effectTriggerType": "OnActivation",
"effectTargetType": "SingleTarget",
"showInStatusPanel": false
},
"effectType": "StatisticEffect",
"Description": {
"Id": "StatusEffect-MountUnit",
"Name": "Battle Armor Mount",
"Details": "mount",
"Icon": "uixSvgIcon_ability_precisionstrike"
},
"nature": "Buff",
"statisticData": {
"statName": "BattleArmorMount",
"operation": "Set",
"modValue": "true",
"modType": "System.Boolean"
}
}
]
}
The important parts are "Targeting": "ActorTarget",
, "TargetFriendlyUnit": "BOTH",
, targetingData be OnActivation
and SingleTarget
, and the effect itself must set BattleArmorMount
to True.
By default, the above ability will only allow the Battle Armor to mount friendly units. In order to be able to swarm hostile units, the Battle Armor must also have a stat effect from equipment that sets a stat CanSwarm
to True, e.g. the following:
{
"durationData": {
"duration": -1,
"stackLimit": -1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInTargetPreview": true,
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "CanSwarmStat",
"Name": "This Battle Armor can make swarm attacks.",
"Details": "This Battle Armor can make swarm attacks."
},
"statisticData": {
"statName": "CanSwarm",
"operation": "Set",
"modValue": "true",
"modType": "System.Boolean"
}
},
In order to have Battle Armor mounted to it, a unit must have either stat effect that sets bool HasBattleArmorMounts
to true OR must have the integer stat InternalBattleArmorSquadCap
set to the # of Battle Armor squads that can be carried internally (for APCs and such). For AI units, those are the two stats that further dictate whether BA can be spawned.
- Battle Armor with AbstractActor statistic bool BattleArmorInternalMountsOnly
can only mount internally (i.e. inside vehicles) and cannot use conventional Battle Armor omni mounts.
On the player-facing side, an additional bool stat, IsBattleArmorHandsy
can be added to Battle Armor that would allow BA to mount friendly units regardless of HasBattleArmorMounts
.
This was added to allow Battle Armor such as the Marauder BA that canonically have Magnetic Clamps to allow them to ride on any friendly unit.
- Units with AbstractActor statistic
IsUnmountableBattleArmor
set true are never mountable, even by BA withIsBattleArmorHandsy
. - Units with AbstractActor statistic
IsUnswarmableBattleArmor
set true are never swarmable (i.e, LAMs in LAM mode, or VTOLs)
For example, this may be added to the statusEffects
section of the omnimech gyro:
{
"durationData": {
"duration": -1
},
"targetingData": {
"effectTriggerType": "Passive",
"effectTargetType": "Creator",
"showInTargetPreview": false,
"showInStatusPanel": false
},
"effectType": "StatisticEffect",
"Description": {
"Id": "StatusEffect-getHasBattleArmorMounts",
"Name": "getHasBattleArmorMounts",
"Details": "getHasBattleArmorMounts",
"Icon": "uixSvgIcon_ability_precisionstrike"
},
"nature": "Buff",
"statisticData": {
"statName": "HasBattleArmorMounts",
"operation": "Set",
"modValue": "true",
"modType": "System.Boolean"
}
}
In order to mount or swarm, activate the appropriate component ability, then select either a friendly (to mount) or enemy (to swarm) within range. By default the range within which you can mount/swarm is equal to the longest of walk/sprint/jump distance. Likewise, in order to dismount or stop swarming, activate the same component ability and then select the unit the BA is mounted to/currently swarming. Dismounting must be done at the start of the BA activation, and once dismounted the BA can move/attack as normal.
Selecting the Mount/Swarm ability when the unit is already mounted/swarming will auto-select the unit you are mounted to; now just click Confirm to dismount/stop swarming. Selecting the Mount/Swarm ability when not mounted/swarming will display indicators showing valid targets for mounting and swarming. Swarm targets will all display the standard "melee target" indicator. Mount targets will get an icon defined in the MountIndicatorAsset
setting, using the color defined in MountIndicatorColor
Attempts to mount a friendly unit are always successful. Attempts to swarm an enemy unit make a simplified melee roll to determine success. If unsuccessful, the BA will be deposited in the same hex as the unit they attempted to swarm. On both a swarm success and failure, a floatie will be generated indicating success or failure. Attempts to mount or swarm always end the BA activation, and must be conducted before the BA attempts to move.
BA that is either swarming or mounted is noted in the "carrier" unit's armor paperdoll, as well as the current armor/structure of the BA mounted to a specific location. The individual suits of the BA squad are always distributed "evenly" across a mech in the following order: CT, CT-R, RT, RT-R, LT, LT-R for mounts (only a single squad can be mounted), and CT, CT-R, RT, RT-R, LT, LT-R, LA, RA, LL, RL, HD for swarms. Multiple squads can swarm a mech simultaneously, and will double-up on locations as needed. For vehicles the order is Front, Rear, Left, Right, Turret for both swarms and mounts. Incoming attacks targeting the "carrier" have a 33% chance of impacting the BA suit mounted to that location instead of the "carrier", with excess damaging transfering through the BA to the carrier.
If the mech chassis location where BA is mounted is destroyed, any BA mounted to that location has a 33% chance of also being destroyed except when the swarming BA is responsible for destroying that location. If the entire unit to which BA is mounted is destroyed, any BA mounted to that unit has a 33% chance of also being destroyed except when the swarming BA is responsible for destroying the unit.
Once BA is swarming an enemy, they cannot do any other actions on their activation. The only options are to either activate the mount/swarm ability again (and thus stop swarming the enemy), or to end their activation ("Done" button). If you choose "Done", the BA will fire all active weapons at the unit they are swarming automatically.
The AI will also attempt to use Swarm against you. If an AI unit has BA (dictated by AI_BattleArmorSpawnChance
, BattleArmorFactionAssociations
and the unit has either HasBattleArmorMounts or InternalBattleArmorSquadCap > 0), some very ugly AI behavior patches should try to get the AI to move closer to your units. Once within a certain range, the AI BA will dismount from its carrier and attempt to swarm you if you're within range. If not, it'll just attack like a normal unit. Units with mechdef tag defined in DisableAISwarmTag
will not swarm, regardless of equipment.
As of v3.1.2.0 you can now pre-assign battle armor squads to be mounted to specific carriers before a mission starts (well, technically right when the first round starts but shut up). All units should be present in drop slots and have pilots assigned before attempting to match squads to carriers. In order to assign squads to carriers, shift-click a squad. Both it and all potential carriers will show a dark gray overlay. Next, shift-click the desired carriers. Both the squads and carriers will both change their overlay color to one of the colors defined in the BAMountPairColors
setting. If a carriers can carry multiple squads, all squads assigned to that carriers will share the same overlay color. To "reset" an assignment, simply remove the squad and carrier from their dropslots, and then add them back to their drop slots if desired. Backing out of the contract screen will likewise reset all pairings. I really shouldn't need to say this, but if you are reloading a pre-mission autosave, you will need to reassign all squads to their carriers.
If you are using CustomUnits' manual drops feature, it doeesn't matter where you assign the squads to deploy, they will magically teleport to their assigned carriers.
When a squad is selected in the lance config screen, a reminder text for shift-click to assign is displayed below the mech widget. The specific text can be set using the BAMountReminderText
setting.
As of 3.1.2.7, the above system has been replaced by a very nice UI created by kmission. The old pre-mission mounting system can still be used if desired, by setting UseOriginalBAMountInterface
to true in settings (defaults to false and using the new UI).
Carrier units with actor bool statistic HasFiringPorts
set to true will allow mounted BA to fire at enemies within range while they are mounted. Units so mounted will have the same LOF level as the carrier unit.
BA can now occupy buildings. Each building can only hold a single squad of BA because reasons. Because getting the AI to shoot at the damn building is a pain in the ass, I've chosen to allow the AI to target the BA squads directly; however BA squads garrisoned in buildings get incoming damage redirected to the building. If such damage is sufficient to destroy the building, overflow damage does not impact the BA squad. Likewise, when garrisoned the building itself will recieve bonus structure points in the form of (squad.Structure + squad.Armor) x GarrisonBuildingArmorFactor. If the building is destroyed with the BA still occupying it, they take their chassis DFA self-damage to each location, and receive any effects defined in OnGarrisonCollapseEffects
. If players choose to voluntarily exit the garrisoned building, they will exfil to the last position they occupied before entering the building (usually an adjacent hex, but it depends what the pathfinding did when they moved to occupy). Holding ctrl while clicking "dismount" from garrison will make the squad exfil to the roof of the building! I make no guarantees that they will be able to move or do anything once there, since not all roofs are flat!
I am not planning on giving the AI the ability to garrison buildings at this time; this is strictly a player gimmick.
B-Pods Added in v2.0.2.0
Any CAE equipment whose ID is found in BPodComponentIDs
will function as a B-Pod; when activated it will automatically hit all Battle Armor within the radius defined by the "Range" field within the "Explosion" section of the "ActivatableComponent" portion of the equipment, i.e
"ActivatableComponent": {
"Explosion": {
"Range": 150,
"Damage": 100,
All battle armor squads within 150m would then take 100 damage, divided randomly amongst the suits in the squad, and any enemy battle armor squads within that radius that are currently swarming will be forcibly dismounted.
In addition, to B-Pods, all mechs can be given one or two abilities in order to attempt to dislodge swarming BA, using the following settings. The AI will also attempt to dislodge player BA when swarming.
note changes in settings rundown earlier in this document; behavior is now controlled by values in DeswarmConfigs
BattleArmorDeSwarmRoll
- string, ability ID of pilot ability that allows mech to "roll" (forced self-knockdown) in order to dislodge swarming battle armor. On a success, there is a 30% chance to deal cluster damage to the Battle Armor squad in the process, as defined in the DeswarmConfig settings. Ability is automatically granted to Mechs at contract start (e.g. does not need to be added manually to pilot).
BattleArmorDeSwarmSwat
- string, ability ID of pilot ability that allows mech to "swat" swarming battle armor (remove using arms). In addition to base chance and piloting mopifier, swat chance gets -5% for each "missing" arm actuator. An arm actuator is considered "missing" if it is destroyed, or was never mounted in the first place. Shoulder, Upper Arm, Lower Arm, and Hand for both left and right arms; thus a mech missing both arms would suffer a 40% penalty (8 x 5%). Ability is automatically granted to Mechs at contract start (e.g. does not need to be added manually to pilot).
The swat ability can deal damage directly to the swarming battle armor if a 2nd successful toll is made, iOn activating a swat, a roll against BaseChance + (Piloting skill x 5%) - 5% for each "missing" arm actuator
is made determine a successful swat. Then a 2nd roll against BaseChance + (Piloting skill x 5%) - 5% for each "missing" arm actuator
is made to determine if the specified damage is dealt.
The two abilities must have at least the following (StratOps release contains these), although additional effects can certainly be added if developers wish to give Buffs/Debuffs when the ability is activated. new in v3.0.0.0, no effectData are necessary in these abilities
For rolls
{
"Description": {
"Id": "AbilityDefDeSwarmerRoll",
"Name": "Roll",
"Details": "ACTION: Unit will roll (self-knockdown) to remove swarming Battle Armor",
"Icon": "rolling-energy"
},
"ActivationTime": "ConsumedByFiring",
"Resource": "ConsumesActivation",
"ActivationCooldown": -1,
"Targeting": "ActorSelf",
"ResolveCost": 0,
"EffectData": []
}
and for swats
{
"Description": {
"Id": "AbilityDefDeSwarmerSwat",
"Name": "Swat",
"Details": "ACTION: Unit will attempt to remove swarming Battle Armor with hands/limbs",
"Icon": "hand"
},
"ActivationTime": "ConsumedByFiring",
"Resource": "ConsumesActivation",
"ActivationCooldown": -1,
"Targeting": "ActorSelf",
"ResolveCost": 0,
"EffectData": []
}
New in 2.0.3.1 **updated in v3.0.0.0
Deswarm by movement behavior is controlled by the DeswarmMovementConfig
setting, rather than statistics in the abilityDef.
AbilityDefID
- string, ability def ID for new ability giving units a chance to deswarm BA from movement. Usable by mechs AND vehicles.
BaseSuccessChance
- Minimum (or starting) % to successfully deswarm on movement.
MaxSuccessChance
- Maximum % to successfully deswarm on movement.
EvasivePipsFactor
- Value set here is multiplied by # of evasive pips gained from movement and added to MinChance
JumpMovementModifier
- Value here is multiplier on chance from above if the movement was a jump (do a barrel roll!)
UseDFADamage
bool, if true will use chassis dfa damage to deal damage on success (for jump moves)
LocationDamageOverride
- damage to be dealt if UseDFADamage = false
PilotingDamageReductionFactor
damage will be reduced by (this value x piloting)%. So setting to 0.1 and a unit with Piloting 6 would only take 40% ("60% less") damage.
After unit movement is complete, roll processes to determine if de-swarm occurs. IF so, the swarming BA is deposited randomly along the movement path. If move was a jump, the swarming BA will also take damage as defined above to each suit in the squad.
{
"Description": {
"Id": "AbilityDefDeSwarmerMovement",
"Name": "Erratic Maneuvering",
"Details": "ACTION: Do fancy footworks and barrel rolls to get rid of little grabby bois. But it's hard to shoot straight.",
"Icon": "uixSvgIcon_skullAtlas"
},
"ActivationTime": "ConsumedByFiring",
"ActivationCooldown": -1,
"Targeting": "ActorSelf",
"ResolveCost": 0,
"EffectData": [
{
"durationData": {
"duration": 1,
"stackLimit": 1
},
"targetingData": {
"effectTriggerType": "OnActivation",
"effectTargetType": "Creator",
"showInStatusPanel": true
},
"effectType": "StatisticEffect",
"Description": {
"Id": "StatusEffect-BattlemasterAccuracy",
"Name": "Overcharged Targeting",
"Details": "-6 Accuracy",
"Icon": "uixSvgIcon_skullAtlas"
},
"nature": "Buff",
"statisticData": {
"statName": "AccuracyModifier",
"operation": "Float_Add",
"modValue": "6",
"modType": "System.Single",
"additionalRules": "NotSet",
"targetCollection": "Weapon",
"targetWeaponCategory": "NotSet",
"targetWeaponType": "NotSet",
"targetAmmoCategory": "NotSet",
"targetWeaponSubType": "NotSet"
}
}
],
"Priority": 0
}
(but also just ground transport I guess. I jhust refer to it as airlift throughout, but it could also be a ground-based unit doing so)
New in v3.0.0.0, units (not just BA but mechs and vehicles!) can be picked up and redeployed by other units. Unlike the mount/swarm mechanic with BA, this ability rests on the carrying unit, and is NOT incorporated into the AI decision-making at all. It is strictly a player gimmick, and will remain so for the forseeable future. The basic usage is very similar to mount/swarm in that the carrier presses the appropriate component ability button, then selects the unit they want to pick up. Viable targets and range are indicated in the same way as mount/swarm targets for BA. The carrier will then move to that units position and pick it up, ending its activation. Setting the unit down is the same, with the caveat that if the setting CanDropOffAfterMoving
is true, the carrier can move to a position AND drop off a unit in the same activation. Dropping off does not end the activation, and the carrying unit can still shoot, etc.
In order for a unit to be airlift, it needs to NOT have any of the tags listed in AirliftImmuneTags
. Likewise, the carrier must a) have the ability from AirliftAbilityID
and b) have one or both of InternalLiftCapacity
and ExternalLiftCapacity
set to some non-zero value. Internal lift capacity functions similarly to internal mounted BA, in that the unitreps are shrunk so as to be basically invisible, and the units themselves are not directly targetable and cannot shoot. Externally airlifted units ARE targetable and CAN shoot. For carriers with both internal and external capacity, internal "spots" will be filled first, then external.
If the global setting AirliftCapacityByTonnage
is set true, airlift capacity will be determined by the sum tonnage of units being airlifted. If false, it will be dictated by absolute number of units (which is how BA mount capacity works).
New in 3.0.2.1, the actor bool stat OverrideGlobalCapacity
will, if true, "flip" the airlift capacity calculation function set in the global AirliftCapacityByTonnage setting. So if you had "AirliftCapacityByTonnage": false
in mod.json, units that have OverrideGlobalCapacity
set true would use Tonnage calculation, and vice versa.
When dropping off units, a popup will display allowing the player to select which currently airlifted unit is to be dropped off.
Hostile units can be airlifted provided the carrier unit has the unit stat CanAirliftHostiles
set to true; hostile units are only mounted externally, and are not prevented from shooting or using abilities; hostile AI likewise relies on properly setting the irbtmu_immobile_unit stat to true under AirliftTargetEffects
to keep them immobile while airlifting (the effect will be canceled when they are dropped).
Speaking of dropping, hostile airlifted units are literally dropped from the VTOL's height when the airlift is halted, dealing appropriate DFA self-damage as if they'd fallen from a building. In the case of turrets and vehicles the damage is equal to their tonnage, while mechs recieve the DFA selfdamage listed in their chassisdef. It is up to modpack authors to config properly so as to not allow ground-based units to transport hostiles, since such units would still recieve damage when being "dropped" even though theyre already on the ground.
New in 3.0.1.0
Units can now be designated as "resupply" units. If such a unit is found, all units friendly to that unit will be given a "resupply" ability. When those units are within range of the resupply unit, they can then initiate a resupply. To be clear, the unit that does the resupplying is not the unit that activates the abilit; rather the unit to be resupplied activates the resupply ability. In theory, the AI should also try to use the resupply ability if they have a weapon thats run out of ammo.
On activating the "resupply" ability, all friendly resupply units within 1000m will be indicated using the color/assets from ResupplyIndicatorAsset
and ResupplyIndicatorColor
, while all friendly resupply units within resupply range will be indicated using the color/assets from ResupplyIndicatorInRangeAsset
and ResupplyIndicatorInRangeColor
.
In the below image, both Unnsvin carriers are potential resupply units. The purple indicator is currently out of range, while the gold indicator is within range. The shaded circle radius indicates the max move distance of the unit (so players can judge whether they could potentially move to within range of a resupply).
The range at which they can initiate resupply is defined by IntParam2
in the appropriate ability def.
On initiating the resupply, both the unit being resupplied and the unit doing the resupplying will shut down, and remain shut down for the # of phases (rounded to integer) from BasePhasesToResupply
, ResupplyPhasesPerAmmoTonnage
, ResupplyPhasesPerArmorPoint
, and modified by UnitTagFactor
.
For example:
BasePhasesToResupply": 30.0,
"ResupplyPhasesPerAmmoTonnage": 30,
"ResupplyPhasesPerArmorPoint": 30,
"UnitTagFactor": {
"easy_resupply": 0.1,
"superheavy_resupply": 2.0
}
Given the above settings, a unit with both the above tags, getting 1 ton of ammo and 5 points of armor resupplied would take:
`[30 (base) + 30 (ammo) + 150 (5x30, armor)] x 0.2 (0.1 x 2.0, tags) = 42 phases`
The way actual resupplying works is thus: if a unit being resupplied has ammunition bins that are not full, it will 1st attempt to search the Resupply unit for bins with matching ammo type. If found, the ammo will be transfered 1:1 until either the unit being supplied has refilled bins, or the Resupply unit runs out of that ammo type. If no matching ammo type is found, or the bins are unable to be filled using "real" ammo, then we will search for SPAMMY (SPAce Magic Modular by Yang) ammo. SPAMMY ammo works by finding the tonnage-per-shot of the "real" ammo, and then consuming the appropriate amount of SPAMMY ammo to be roughly equivalent tonnage. Due to floating point errors and lack-of-fucks given by yours truly, you'll often end up with 1 fewer shots in the "real" bin than you'd expect (i.e. 1 ton of SPAMMY gets you 119 LRMs instead of 120). No one ever said transmogrification was perfect.
Armor repair works somewhat similarly to SPAMMY ammo, in that a special "ammo" type for repairing armor must be defined. The number of "shots" in bins of this ammo is equivalent to the number of armor "points" that can be restored to units being resupplied. The amount of armor that canb be "restored" to a given location is a function of the ArmorRepairMax
value and the initial armor for that location. ie, if ArmorRepairMax: 0.9, armor can only be restored up to 90% of the initial assigned armor for that location. Destroyed or missing locations can (obviously) not have armor restored.
Mod authors should probably use CAC to define new AmmoCategories for these "Ammos" so nothing else can use them, i.e
{
"ID": 6109,
"Name": "SPAMMY",
"FriendlyName": "SPAMMY",
"IsBallistic": false,
"IsMissile": true,
"IsEnergy": false,
"IsSupport": false,
"UsesInternalAmmo": false,
"UIColorRef": "Missile",
"FallbackUIColor": null,
"Icon": "MissileHardpointIcon",
"OutOfAmmoAudioVOEvent": "AmmoDepleted_LRM"
},
{
"ID": 6110,
"Name": "ARMORAMMO",
"FriendlyName": "ARMORAMMO",
"IsBallistic": false,
"IsMissile": true,
"IsEnergy": false,
"IsSupport": false,
"UsesInternalAmmo": false,
"UIColorRef": "Missile",
"FallbackUIColor": null,
"Icon": "MissileHardpointIcon",
"OutOfAmmoAudioVOEvent": "AmmoDepleted_LRM"
}
In mod.json, config consists of the following:
"ResupplyConfig": {
"ResupplyIndicatorAsset": "Target",
"ResupplyIndicatorColor": {
"r": 255,
"g": 0,
"b": 255
},
"ResupplyIndicatorInRangeAsset": "Target",
"ResupplyIndicatorInRangeColor": {
"r": 255,
"g": 255,
"b": 0
},
"ResupplyAbilityID": "AbilityDefResupply",
"ResupplyUnitTag": "RedBatHatesFunnyTagsSoThisIsAnUnfunnyTag",
"SPAMMYAmmoDefId": "Ammunition_SPAMMY",
"SPAMMYBlackList": [],
"InternalSPAMMYDefId": "Ammunition_IntSPAMMY",
"InternalSPAMMYBlackList": [
"Weapon_Medium_Recoilless_BA"
],
"ArmorSupplyAmmoDefId": "Ammunition_ARMORAMMO",
"ArmorRepairMax": 0.9,
"BasePhasesToResupply": 30.0,
"ResupplyPhasesPerAmmoTonnage": 30,
"ResupplyPhasesPerArmorPoint": 30,
"UnitTagFactor": {
"easy_resupply": 0.1,
"superheavy_resupply": 2.0
},
ResupplyIndicatorAsset
and ResupplyIndicatorColor
- much like the spawn and mount indicators, these define the Texture2D asset and color used to indicate Resupply units. This indicator will show all resupply units within a large (1000) radius of the activating unit. These units are not necessarily within current resupply range!
ResupplyIndicatorInRangeAsset
and ResupplyIndicatorInRangeColor
- these define the Texture2D and color used to indicate Resupply units within resupply range of the activating unit
ResupplyAbilityID
- abilityDef ID of the resupply ability; A sample is shipped with the release. Necessary settings are "Targeting": "ActorTarget",
, "TargetFriendlyUnit": "FRIENDLY",
, and "IntParam2": 120,
(defines resupply range, actual value can be whatever)
ResupplyUnitTag
- unitDef (i.e mechdef) tag that indicates a unit that can Resupply other units.
SPAMMYAmmoDefId
- AmmunitionDef ID of SPAMMY (SPAce Magic Modular by Yang ammo) that can be used to universally resupply ammunition.
SPAMMYBlackList
- AmmunitionDef IDs here will not be replenished by SPAMMY ammo; WeaponDef IDs (for internal ammo weapons) will also not be replenished.
InternalSPAMMYDefId
- AmmunitionDef ID of SPAMMY that can only be used to resupply internal ammunition (regular SPAMMY will also resupply internal).
InternalSPAMMYBlackList
- WeaponDef IDs here will not be replenished by InternalSPAMMYDefId ammo.
ArmorSupplyAmmoDefId
- AmmunitionDef ID of ARMOR AMMO; "shots" in bin are considered to be "points" of armor available to be used in restoring other unit armor.
ArmorRepairMax
- decimal proportion to which armor can be restored for a given ArmorLocation on unit. i.e, if 0.9, armor can only be restored up to 90% of the initial assigned armor for that location. Destroyed or missing locations can (obviously) not have armor restored.
Renamed PhasesToResupply
BasePhasesToResupply
in v3.0.1.2- float, number of phases both Resupply and unit being resupplied will be shut down ( will "round" to rounds since unit cant restart until its activation). Multiple units can attempt to resupply from the same Resupply simultaneously, and will result in the Resupply unit shutdown period being extended for each.
ResupplyPhasesPerAmmoTonnage
- float, number of phases units will be shut down per ton of ammmo being resupplied
ResupplyPhasesPerArmorPoint
- float number of phases unit will be shut down per point of armor being replenished
UnitTagFactor
- Dictionary<string, float> - multiplier for total phases resupply will take based on matching tag (if any) found. If multiple matching tags are found, all multipliers will be multiplied together before applying to total phases.
Weapons with internal ammo should have at least the following Custom (from CustomComponents) defined:
"Custom": {
"InternalAmmoTonnage": {
"InternalAmmoTons": 0.15
}
},
InternalAmmoTons
is the actual tonnage value of the internal ammo for that weapon, and will be used to calculate how much SPAMMY ammo to consume for the resupply
In v2.0.3.0, I have implemented the following Weapon statistics that will interact with CustomAmmoCategories TAC framework. These are intended for use with on-swarm Effects, but generalized for any status effect to use them:
APArmorShardsModWeaponMultiplier
- Multiplier on final product of CAC APArmorShardsMod (from weapon, mode, ammo)
APMaxArmorThicknessWeaponMultiplier
- Multiplier on final product of CAC APMaxArmorThickness (from weapon, mode, ammo)
APCriticalChanceMultiplierWeaponMultiplier
- Multiplier on final product of CAC APCriticalChanceMultiplier (from weapon, mode, ammo, and evasivePipsMod)