Package mekhq.campaign.mission
Class AtBDynamicScenario
java.lang.Object
mekhq.campaign.mission.Scenario
mekhq.campaign.mission.AtBScenario
mekhq.campaign.mission.AtBDynamicScenario
- All Implemented Interfaces:
IAtBScenario
,IPlayerSettings
Data structure intended to hold data relevant to AtB Dynamic Scenarios (AtB 3.0)
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic class
Data relevant to an entity that was swapped out in a "player or fixed unit count" force. -
Field Summary
FieldsFields inherited from class mekhq.campaign.mission.AtBScenario
ACEDUEL, ALLIEDTRAITORS, ALLYRESCUE, AMBUSH, antiRiotWeapons, BASEATTACK, BREAKTHROUGH, CHASE, CIVILIANHELP, CIVILIANRIOT, CONVOYATTACK, CONVOYRESCUE, defaultResourceBundle, DYNAMIC, EXTRACTION, FORCE_AERO, FORCE_BA, FORCE_INFANTRY, FORCE_MEK, FORCE_MIXED, FORCE_NOVA, FORCE_PROTOMEK, FORCE_VEENOVA, FORCE_VEHICLE, forceTypeNames, HIDEANDSEEK, HOLDTHELINE, NO_COMBAT_TEAM, OFFICERDUEL, PIRATEFREEFORALL, PRISONBREAK, PROBE, RECONRAID, STANDUP, STARLEAGUECACHE1, STARLEAGUECACHE2, startPos
Fields inherited from class mekhq.campaign.mission.Scenario
atmosphere, botForces, botForcesStubs, fog, gravity, light, S_DEFAULT_ID, T_ATMOSPHERE, T_GROUND, T_SPACE, weather, wind
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
addBotForce
(BotForce botForce, ScenarioForceTemplate forceTemplate, Campaign c) Adds a bot force to this scenario.void
Add a force to the scenario, explicitly linked to the given template.void
addForces
(int forceID) void
addScenarioModifier
(AtBScenarioModifier modifier) Adds a scenario modifier and any linked modifiers to this scenario, provided that the modifier exists and can be applied to the scenario (e.g.void
boolean
alreadyHasModifier
(AtBScenarioModifier modifier) Check if the modifier list already has a modifier with the given modifier's name.void
clearAllForcesAndPersonnel
(Campaign campaign) getDesc()
int
megamek.common.enums.SkillLevel
double
double
int
int
getLanceCommander
(Campaign campaign) Convenience method that returns the commander of the first force assigned to this scenario.int
getLanceCommanderSkill
(String skillType, Campaign campaign) Convenience method to return the int value of the lance commander's skill in the specified area.int
getMapX()
Horizontal map size.int
getMapY()
Vertical map size.A list of all the force IDs associated with pre-defined scenario templatesint
int
The Board.START_X constant representing the starting zone for the player's primary forceint
getTeamTotalBattleValue
(Campaign campaign, boolean isAllied) Returns the total battle value (BV) either for allied forces or opposing forces in a given contract campaign, as per the parameterisAllied
.boolean
This is used to indicate that player forces have been assigned to this scenario and that AtBDynamicScenarioFactory.finalizeScenario() has been called on this scenario to generate opposing forces and their bots, apply any present scenario modifiers, set up deployment turns, calculate which units belong to which objectives, and many other things.protected void
loadFieldsFromXmlNode
(Node wn, megamek.Version version, Campaign campaign) void
Corrects the enemy (special scenarios) and allies (big battles) as necessary based on player deployments.void
removeBotForce
(int x) Removes a bot force from this dynamic scenario, and its associated template as well.void
removeForce
(int fid) void
removeUnit
(UUID unitID) void
setBotForceTemplates
(Map<BotForce, ScenarioForceTemplate> botForceTemplates) void
setBotUnitTemplates
(Map<UUID, ScenarioForceTemplate> botUnitTemplates) void
setEffectiveOpforQuality
(int qualityLevel) void
setEffectiveOpforSkill
(megamek.common.enums.SkillLevel skillLevel) void
setEffectivePlayerBVMultiplier
(double multiplier) void
setEffectivePlayerUnitCountMultiplier
(double multiplier) void
setFinalized
(boolean finalized) void
setFriendlyDelayedReinforcements
(List<UUID> friendlyDelayedReinforcements) void
setFriendlyReinforcementDelayReduction
(int friendlyReinforcementDelayReduction) void
setHostileReinforcementDelayReduction
(int hostileReinforcementDelayReduction) void
void
setPlayerForceTemplates
(Map<Integer, ScenarioForceTemplate> playerForceTemplates) void
setPlayerUnitSwaps
(Map<UUID, AtBDynamicScenario.BenchedEntityData> playerUnitSwaps) void
setPlayerUnitTemplates
(Map<UUID, ScenarioForceTemplate> playerUnitTemplates) void
setScenarioModifiers
(List<AtBScenarioModifier> scenarioModifiers) void
setTemplate
(ScenarioTemplate template) protected void
writeToXMLEnd
(PrintWriter pw, int indent) Methods inherited from class mekhq.campaign.mission.AtBScenario
addAeroReinforcements, addCivilianUnits, addDropship, addEnemyForce, addEnemyForce, addLance, addLance, addScrubReinforcements, addTransportRelationship, addTurrets, canAddDropShips, canDeploy, canDeploy, canDeployForces, canDeployUnits, canRerollLight, canRerollMap, canRerollMapSize, canRerollTerrain, canRerollWeather, canStartScenario, filterUntransportedUnits, generateStub, getAlliesPlayer, getAlliesPlayerStub, getAllyBotForce, getAttachedUnitIds, getBaseMapX, getBaseMapY, getCombatRole, getCombatTeamById, getCombatTeamId, getContract, getCsvFromList, getDeploymentDelay, getDeploymentInstructions, getEnemyBotForce, getEnemyBotForce, getEnemyHome, getEntity, getEntity, getForceCount, getModifiedTemperature, getNumPlayerMinefields, getRerollsRemaining, getResourceBundle, getSpecialScenarioEnemies, getStratconScenario, getSurvivalBonusIds, getTerrainType, getTransportLinkages, initialize, isAttacker, isBigBattle, isFriendlyUnit, isSpecialScenario, isStandardScenario, setAttacker, setCombatTeam, setDeploymentDelay, setEnemyHome, setExtraScenarioForces, setForceCount, setForces, setLightConditions, setMapFile, setMapFile, setModifiedTemperature, setNumPlayerMinefields, setObjectives, setPlanetaryConditions, setRerolls, setScenarioMap, setTerrain, setTerrainType, setTransportLinkages, setWeatherConditions, useReroll
Methods inherited from class mekhq.campaign.mission.Scenario
addBotForce, addLoot, addPlayerTransportRelationship, addUnit, canWindShiftDirection, canWindShiftStrength, containsPlayerUnit, convertToStub, createPlanetaryConditions, generateInstanceFromXML, getAtmosphere, getBlowingSand, getBoardType, getBoardTypeName, getBotForce, getBotForces, getBotForcesStubs, getDate, getDeploymentLimit, getDescription, getEMI, getEntityStub, getExternalIDLookup, getFog, getForceIDs, getForces, getForceStub, getGravity, getHasTrack, getId, getIndividualUnitIDs, getLight, getLinkedScenario, getLoot, getMap, getMapForDisplay, getMapSizeX, getMapSizeY, getMaxWindStrength, getMinWindStrength, getMissionId, getName, getNumBots, getPlayerTransportLinkages, getReport, getScenarioObjectives, getStartingAnyNWx, getStartingAnyNWy, getStartingAnySEx, getStartingAnySEy, getStartOffset, getStartWidth, getStatus, getStratConScenarioType, getTemperature, getTraitorUnits, getWeather, getWind, hasObjectives, includesRequiredPersonnel, includesRequiredUnits, isAssigned, isCloaked, isTraitor, isTraitor, isUsingFixedMap, readPlanetaryConditions, resetLoot, setAtmosphere, setBlowingSand, setBoardType, setBotForces, setCloaked, setDate, setDeploymentLimit, setDesc, setEMI, setExternalIDLookup, setFog, setGravity, setHasTrack, setId, setLight, setlinkedScenarioID, setMap, setMapSizeX, setMapSizeY, setMaxWindStrength, setMinWindStrength, setMissionId, setName, setReport, setScenarioObjectives, setShiftWindDirection, setShiftWindStrength, setStartingAnyNWx, setStartingAnyNWy, setStartingAnySEx, setStartingAnySEy, setStartingPos, setStartOffset, setStartWidth, setStatus, setStratConScenarioType, setTemperature, setUsingFixedMap, setWeather, setWind, writeToXML, writeToXMLBegin
-
Field Details
-
PRIMARY_PLAYER_FORCE_ID
- See Also:
-
-
Constructor Details
-
AtBDynamicScenario
public AtBDynamicScenario()
-
-
Method Details
-
addForces
public void addForces(int forceID) -
addForce
Add a force to the scenario, explicitly linked to the given template.- Parameters:
forceID
- ID of the force to add.templateName
- Name of the force template.
-
addUnit
-
removeForce
public void removeForce(int fid) - Overrides:
removeForce
in classScenario
-
removeUnit
- Overrides:
removeUnit
in classScenario
-
getStartingPos
public int getStartingPos()The Board.START_X constant representing the starting zone for the player's primary force- Specified by:
getStartingPos
in interfaceIPlayerSettings
- Overrides:
getStartingPos
in classScenario
-
getMapX
public int getMapX()Horizontal map size. Unlike the AtBScenario, we only perform map size calculations once (once all primary forces are committed), so we don't re-calculate the map size each time.- Overrides:
getMapX
in classAtBScenario
-
getMapY
public int getMapY()Vertical map size. Unlike the AtBScenario, we only perform map size calculations once (once all primary forces are committed), so we don't re-calculate the map size each time.- Overrides:
getMapY
in classAtBScenario
-
setMapSize
public void setMapSize()- Overrides:
setMapSize
in classAtBScenario
-
addBotForce
Adds a bot force to this scenario. -
removeBotForce
public void removeBotForce(int x) Removes a bot force from this dynamic scenario, and its associated template as well.- Overrides:
removeBotForce
in classScenario
-
getEffectivePlayerUnitCountMultiplier
public double getEffectivePlayerUnitCountMultiplier() -
setEffectivePlayerUnitCountMultiplier
public void setEffectivePlayerUnitCountMultiplier(double multiplier) -
getEffectivePlayerBVMultiplier
public double getEffectivePlayerBVMultiplier() -
setEffectivePlayerBVMultiplier
public void setEffectivePlayerBVMultiplier(double multiplier) -
getTemplate
-
setTemplate
-
getPlayerForceTemplates
-
setPlayerForceTemplates
-
getPlayerUnitTemplates
-
setPlayerUnitTemplates
-
getBotForceTemplates
-
setBotForceTemplates
-
getBotUnitTemplates
-
setBotUnitTemplates
-
getPlayerUnitSwaps
-
setPlayerUnitSwaps
-
getEffectiveOpforSkill
public megamek.common.enums.SkillLevel getEffectiveOpforSkill() -
setEffectiveOpforSkill
public void setEffectiveOpforSkill(megamek.common.enums.SkillLevel skillLevel) -
getEffectiveOpforQuality
public int getEffectiveOpforQuality() -
setEffectiveOpforQuality
public void setEffectiveOpforQuality(int qualityLevel) -
getFriendlyDelayedReinforcements
-
setFriendlyDelayedReinforcements
-
getFriendlyReinforcementDelayReduction
public int getFriendlyReinforcementDelayReduction() -
setFriendlyReinforcementDelayReduction
public void setFriendlyReinforcementDelayReduction(int friendlyReinforcementDelayReduction) -
getHostileReinforcementDelayReduction
public int getHostileReinforcementDelayReduction() -
setHostileReinforcementDelayReduction
public void setHostileReinforcementDelayReduction(int hostileReinforcementDelayReduction) -
isFinalized
public boolean isFinalized()This is used to indicate that player forces have been assigned to this scenario and that AtBDynamicScenarioFactory.finalizeScenario() has been called on this scenario to generate opposing forces and their bots, apply any present scenario modifiers, set up deployment turns, calculate which units belong to which objectives, and many other things.Further "post-force-generation" modifiers can be applied to this scenario, but calling finalizeScenario() on it again will lead to "unsupported" behavior.
Can be called as a short hand way of telling "is this scenario ready to play".
-
setFinalized
public void setFinalized(boolean finalized) -
getPlayerTemplateForceIDs
A list of all the force IDs associated with pre-defined scenario templates -
getLanceCommander
Convenience method that returns the commander of the first force assigned to this scenario.- Returns:
-
getLanceCommanderSkill
Convenience method to return the int value of the lance commander's skill in the specified area. Encapsulates a fairly obnoxious number of null checks and other safety code.- Parameters:
skillType
- The type of skill to checkcampaign
- The campaign the lance commander is a part of- Returns:
- The skill level. SKILL_NONE (0) if not present.
-
setScenarioModifiers
-
getScenarioModifiers
-
addScenarioModifier
Adds a scenario modifier and any linked modifiers to this scenario, provided that the modifier exists and can be applied to the scenario (e.g. ground units on air map) -
alreadyHasModifier
Check if the modifier list already has a modifier with the given modifier's name. -
getScenarioType
public int getScenarioType() -
getDesc
- Overrides:
getDesc
in classAtBScenario
-
getScenarioTypeDescription
-
getResourceKey
-
writeToXMLEnd
- Overrides:
writeToXMLEnd
in classAtBScenario
-
loadFieldsFromXmlNode
protected void loadFieldsFromXmlNode(Node wn, megamek.Version version, Campaign campaign) throws ParseException - Overrides:
loadFieldsFromXmlNode
in classAtBScenario
- Throws:
ParseException
-
refresh
Description copied from class:AtBScenario
Corrects the enemy (special scenarios) and allies (big battles) as necessary based on player deployments. This ought to be called when the scenario details are displayed or the scenario is started.- Overrides:
refresh
in classAtBScenario
-
clearAllForcesAndPersonnel
- Overrides:
clearAllForcesAndPersonnel
in classScenario
-
getBattlefieldControlDescription
- Overrides:
getBattlefieldControlDescription
in classAtBScenario
-
getTeamTotalBattleValue
Returns the total battle value (BV) either for allied forces or opposing forces in a given contract campaign, as per the parameterisAllied
.If
isAllied
istrue
, the method calculates the total BV for the allied forces inclusive of player forces. IfisAllied
isfalse
, the total BV for opposing forces is calculated.The calculation is done based on Bot forces attributed to each side. In the case of PlanetOwner, the alignment of the owner faction is considered to determine the ownership of Bot forces.
- Parameters:
campaign
- The campaign in which the forces are participating.isAllied
- A boolean value indicating whether to calculate the total BV for allied forces (if true) or opposing forces (if false).- Returns:
- The total battle value (BV) either for the allied forces or opposing forces, as specified by the parameter isAllied.
-