Difference between revisions of "Starward Rogue:XML - EntitySystem Definitions"
Jump to navigation
Jump to search
Line 162: | Line 162: | ||
**if a shot from this system collides with a hostile shot, it deflects that shot back on the opposite angle of its current travel | **if a shot from this system collides with a hostile shot, it deflects that shot back on the opposite angle of its current travel | ||
**a shot cannot be deflected twice | **a shot cannot be deflected twice | ||
− | deflects_shots_as_friendly_fire (bool, optional) | + | *deflects_shots_as_friendly_fire (bool, optional) |
− | same deal, but also makes those shots be able to hit targets friendly to it | + | **same deal, but also makes those shots be able to hit targets friendly to it |
− | shots_knockback (int, optional) | + | *shots_knockback (int, optional) |
− | ships hit by this are knocked back X distance units (if that would put them in a wall they don't go that far) | + | **ships hit by this are knocked back X distance units (if that would put them in a wall they don't go that far) |
− | shots_knockback_on_firing_ship_to_target_ship_angle and shots_knockback_on_shot_to_target_ship_angle" to system (both bool, optional) | + | *shots_knockback_on_firing_ship_to_target_ship_angle and shots_knockback_on_shot_to_target_ship_angle" to system (both bool, optional) |
− | overrides the default logic of "shots_knockback pushes back on the angle the shot is travelling in" | + | **overrides the default logic of "shots_knockback pushes back on the angle the shot is travelling in" |
− | disabled_if_zero_of_item (InventoryItemType, optional) | + | *disabled_if_zero_of_item (InventoryItemType, optional) |
− | if you've got none of that resource left, the system is considered disabled | + | **if you've got none of that resource left, the system is considered disabled |
− | shots_spawn_at_reticule (bool, optional) | + | *shots_spawn_at_reticule (bool, optional) |
− | makes the shot spawn at CalculateReticulePointForPlayerRightNow | + | **makes the shot spawn at CalculateReticulePointForPlayerRightNow |
− | if that's outside the room or in an indestructible within-room wall it tries to walk it back towards the player | + | **if that's outside the room or in an indestructible within-room wall it tries to walk it back towards the player |
− | targets_entity_that_last_damaged_my_entity (bool, optional) | + | *targets_entity_that_last_damaged_my_entity (bool, optional) |
− | after it fires a salvo, the remembered last-damaged-by is cleared | + | **after it fires a salvo, the remembered last-damaged-by is cleared |
− | shots_instantly_hit_all_enemies, shots_instantly_hit_all_non_boss_enemies (both bool, optional) | + | *shots_instantly_hit_all_enemies, shots_instantly_hit_all_non_boss_enemies (both bool, optional) |
− | both cause the shots emitted by that system to instantly hit all enemies and disappear (so the shots will generally not ever be seen); they apply all the normal on-hit logic, modifier transfer, etc | + | **both cause the shots emitted by that system to instantly hit all enemies and disappear (so the shots will generally not ever be seen); they apply all the normal on-hit logic, modifier transfer, etc |
− | the second excludes any enemy where BossType != None | + | **the second excludes any enemy where BossType != None |
− | shots_do_portion_of_current_health_as_damage (float, optional) | + | *shots_do_portion_of_current_health_as_damage (float, optional) |
− | does X * the current hull health of the ship in damage, where X is between 0 and 1 (not 0 and 100; this is a multiplier, not a percent) | + | **does X * the current hull health of the ship in damage, where X is between 0 and 1 (not 0 and 100; this is a multiplier, not a percent) |
− | do_parallel_salvo_with_spacing (int, optional) | + | *do_parallel_salvo_with_spacing (int, optional) |
− | only meaningful if shots_per_salvo > 1 | + | **only meaningful if shots_per_salvo > 1 |
− | puts the first shot in the center like normal | + | **puts the first shot in the center like normal |
− | puts the second shot at the specified distance to one side | + | **puts the second shot at the specified distance to one side |
− | puts the third shot at the specified distance to the other side | + | **puts the third shot at the specified distance to the other side |
− | puts the fourth shot at twice the specified distance to the first side, and so on | + | **puts the fourth shot at twice the specified distance to the first side, and so on |
− | salvo_angle_difference (int, optional) | + | *salvo_angle_difference (int, optional) |
− | only meaningful if shots_per_salvo > 1 | + | **only meaningful if shots_per_salvo > 1 |
− | the first shot has no change | + | **the first shot has no change |
− | the second shot gets angle + the specified amount (in degrees) | + | **the second shot gets angle + the specified amount (in degrees) |
− | the third shot gets angle - the specified amount | + | **the third shot gets angle - the specified amount |
− | the fourth shot gets angle + twice the specified amount, and so on | + | **the fourth shot gets angle + twice the specified amount, and so on |
− | shots_follow_the_reticule (bool, optional) | + | *shots_follow_the_reticule (bool, optional) |
− | shots emitted this system are basically glued to the cursor/reticule, moving instantly to that location even if it goes into a wall | + | **shots emitted this system are basically glued to the cursor/reticule, moving instantly to that location even if it goes into a wall |
− | shot_movement_particle (particle_pattern, optional) | + | *shot_movement_particle (particle_pattern, optional) |
− | shots emitted from this system emit this particle while moving | + | **shots emitted from this system emit this particle while moving |
− | inaccuracy_spread (int, optional) | + | *inaccuracy_spread (int, optional) |
− | makes each shot emitted from the system get a random angle offset from -x to +x degrees | + | **makes each shot emitted from the system get a random angle offset from -x to +x degrees |
− | inaccuracy_is_by_salvo (bool, optional) | + | *inaccuracy_is_by_salvo (bool, optional) |
− | makes the previous apply to the salvo as a whole, not the individual shots | + | **makes the previous apply to the salvo as a whole, not the individual shots |
− | miss_penalty_percent (int, optional) | + | *miss_penalty_percent (int, optional) |
− | if a shot expires without hitting any entity, it does this percent (expressed as 0 to 100) of its normal damage (whatever it would have done to an enemy at that time) to the ship which fired it | + | **if a shot expires without hitting any entity, it does this percent (expressed as 0 to 100) of its normal damage (whatever it would have done to an enemy at that time) to the ship which fired it |
− | spawns_entity (entity, optional) | + | *spawns_entity (entity, optional) |
− | when the system is triggered, an entity of this type is spawned at the location of the system | + | **when the system is triggered, an entity of this type is spawned at the location of the system |
− | energy_shield_damage_portion, energy_shield_conversion_multiplier (both float, optional) | + | *energy_shield_damage_portion, energy_shield_conversion_multiplier (both float, optional) |
− | the first is the percent of damage done to the parent entity that the conversion will try to apply to | + | **the first is the percent of damage done to the parent entity that the conversion will try to apply to |
− | the second is the cost in energy of each point of damage prevented, thus determining the max amount of damage that can actually be converted | + | **the second is the cost in energy of each point of damage prevented, thus determining the max amount of damage that can actually be converted |
− | shot_disintegration_speed_mult (float, optional). | + | *shot_disintegration_speed_mult (float, optional). |
− | Normally shots decay and shrink down in both size and damage dealt when they pass the end of their range or lifespan. This gives them a nice fade-out, but also increases the range somewhat based on the speed of the shot. | + | **Normally shots decay and shrink down in both size and damage dealt when they pass the end of their range or lifespan. This gives them a nice fade-out, but also increases the range somewhat based on the speed of the shot. |
− | This multiplier lets you make this process of decay happen faster (>1) or slower (<1). A multiplier of 6 or more will make it almost instant, but without jolting out of existing unprofessionally. Default 1. | + | **This multiplier lets you make this process of decay happen faster (>1) or slower (<1). A multiplier of 6 or more will make it almost instant, but without jolting out of existing unprofessionally. Default 1. |
− | is_destroyed_after_finite_uses (int, optional) | + | *is_destroyed_after_finite_uses (int, optional) |
− | if a number > 0, then the system is gone after triggering that many times. Default 0. | + | **if a number > 0, then the system is gone after triggering that many times. Default 0. |
− | hull_health_siphon_portion (float, optional) | + | *hull_health_siphon_portion (float, optional) |
− | whenever shots emitted by this system do damage, X% (expressed as 0 to 1) of the damage done is also applied as healing to the firing ship's hull | + | **whenever shots emitted by this system do damage, X% (expressed as 0 to 1) of the damage done is also applied as healing to the firing ship's hull |
− | shots_teleport_to_target_point (bool, optional) | + | *shots_teleport_to_target_point (bool, optional) |
− | whenever this system emits shots, those shots instantly teleport to the target point (whatever that is based on the system's targeting_logic and context) | + | **whenever this system emits shots, those shots instantly teleport to the target point (whatever that is based on the system's targeting_logic and context) |
− | revives_parent_entity_with_hull_health_portion (float, optional) | + | *revives_parent_entity_with_hull_health_portion (float, optional) |
− | whenever the parent system of this ship would normally die, its hull health is immediately set to X% (expressed as 0 to 1) of its max hull health | + | **whenever the parent system of this ship would normally die, its hull health is immediately set to X% (expressed as 0 to 1) of its max hull health |
− | screen_flash_seconds_on_use, screen_flash_seconds_on_shot_detonation (both bools, optional) | + | *screen_flash_seconds_on_use, screen_flash_seconds_on_shot_detonation (both bools, optional) |
− | makes the screen go white instantly on use or shot detonation (respectively), then fade to normal over X seconds | + | **makes the screen go white instantly on use or shot detonation (respectively), then fade to normal over X seconds |
− | consumes_all_required_item_on_use (bool, optional) | + | *consumes_all_required_item_on_use (bool, optional) |
− | only works in conjunction with requires_item_type | + | **only works in conjunction with requires_item_type |
− | after this system is used, all of that item is removed from the player's inventory (after whatever normal cost is associated) | + | **after this system is used, all of that item is removed from the player's inventory (after whatever normal cost is associated) |
− | beam_particle (particle, optional) and beam_particle_distance_interval (int, optional) | + | *beam_particle (particle, optional) and beam_particle_distance_interval (int, optional) |
− | makes the beam emit that particle at points X distance apart along its length | + | **makes the beam emit that particle at points X distance apart along its length |
− | shot_gravity_pull_per_second, shot_gravity_falloff_per_unit_distance (both floats, optional) | + | *shot_gravity_pull_per_second, shot_gravity_falloff_per_unit_distance (both floats, optional) |
− | so if you had values of 100 and 0.2, then it would exert a pull on something up to 500 units away, where that pull is 20 at 400 distance, 40 at 300, 60 at 200, 80 at 100, etc | + | **so if you had values of 100 and 0.2, then it would exert a pull on something up to 500 units away, where that pull is 20 at 400 distance, 40 at 300, 60 at 200, 80 at 100, etc |
− | shot_gravity_affects_shots, shot_gravity_affects_friendlies (both bools, optional) | + | *shot_gravity_affects_shots, shot_gravity_affects_friendlies (both bools, optional) |
− | normally it only affects enemy ships; these change that | + | **normally it only affects enemy ships; these change that |
− | shot_gravity_has_repelling_effect (bool, optional) | + | *shot_gravity_has_repelling_effect (bool, optional) |
− | makes the shot's gravity pull do a repulsion instead | + | **makes the shot's gravity pull do a repulsion instead |
− | drones_are_finite (bool), drones_are_guards (bool) | + | *drones_are_finite (bool), drones_are_guards (bool) |
− | if has drones and fire_rate > 0, then every (fire_rate) seconds it picks a drone from this system's drone nodes | + | **if has drones and fire_rate > 0, then every (fire_rate) seconds it picks a drone from this system's drone nodes |
− | if finite, that "ball" is not returned to the random bag from which the drone type is picked; if there are no more items it just doesn't spawn more | + | **if finite, that "ball" is not returned to the random bag from which the drone type is picked; if there are no more items it just doesn't spawn more |
− | if guards, the drones are spawned with FlockBehaviorType.Buddy and AIRelatedEntityID set to this system's parent ship | + | **if guards, the drones are spawned with FlockBehaviorType.Buddy and AIRelatedEntityID set to this system's parent ship |
− | shots_hitting_player_warp_responsible_entity_to_parent_entity (bool) | + | *shots_hitting_player_warp_responsible_entity_to_parent_entity (bool) |
− | if a shot from this system hits the player, then the parent entity of this system is destroyed and the entity which spawned that parent entity (if any) instantly teleports to its location | + | **if a shot from this system hits the player, then the parent entity of this system is destroyed and the entity which spawned that parent entity (if any) instantly teleports to its location |
− | shots_steal_credits (float), credit_drop_on_death_portion (float) | + | *shots_steal_credits (float), credit_drop_on_death_portion (float) |
− | if a shot from this system hits the player, the player loses (shots_steal_credits) credits | + | **if a shot from this system hits the player, the player loses (shots_steal_credits) credits |
− | if the parent entity of this system dies, then (credit_drop_on_death_portion ) * the credits stolen by this system are dropped on the ground | + | **if the parent entity of this system dies, then (credit_drop_on_death_portion ) * the credits stolen by this system are dropped on the ground |
− | shots_die_instantly_at_boundary_direction (FourDirection), shots_die_instantly_at_boundary_distance_from_wall (int) | + | *shots_die_instantly_at_boundary_direction (FourDirection), shots_die_instantly_at_boundary_distance_from_wall (int) |
− | when shots from this system get within (distance) of the (direction) external room wall they instantly are removed from the game | + | **when shots from this system get within (distance) of the (direction) external room wall they instantly are removed from the game |
− | spawns_entity_ship_category (ShipCategory) | + | *spawns_entity_ship_category (ShipCategory) |
− | similar to spawns_entity, but randomly picks from entity types with a matching ship_category | + | **similar to spawns_entity, but randomly picks from entity types with a matching ship_category |
− | only_enabled_if_player_needs_missiles (bool) | + | *only_enabled_if_player_needs_missiles (bool) |
− | if the player has any missiles, this system is disabled | + | **if the player has any missiles, this system is disabled |
− | if there are any missile pickups in the room, this system is disabled | + | **if there are any missile pickups in the room, this system is disabled |
− | if there are any enemies spawned by this system in the room, this system is disabled | + | **if there are any enemies spawned by this system in the room, this system is disabled |
− | if the room has already been won, this system is disabled | + | **if the room has already been won, this system is disabled |
− | entities_spawned_by_this_always_drop (entity) | + | *entities_spawned_by_this_always_drop (entity) |
− | any entities spawned by this system will always drop the specified entity type on death | + | **any entities spawned by this system will always drop the specified entity type on death |
− | portion_attack_power_gain_per_my_portion_health_lost (float) | + | *portion_attack_power_gain_per_my_portion_health_lost (float) |
− | when this system emits a shos, the attack power of the shot is multiplied by 1 + (the portion of the system's parent entity health lost * this field) | + | **when this system emits a shos, the attack power of the shot is multiplied by 1 + (the portion of the system's parent entity health lost * this field) |
− | so if this is 1, then as the parent entity's health approaches zero the attack power of newly emitted shots will approach twice what it would otherwise be | + | **so if this is 1, then as the parent entity's health approaches zero the attack power of newly emitted shots will approach twice what it would otherwise be |
− | spawns_familiars (List<GameEntityTypeData>) | + | *spawns_familiars (List<GameEntityTypeData>) |
− | when this system is triggered, it spawns each of the listed entity types as familiars for the system's parent entity (works for players or enemies; the player ones will normally persist between rooms) | + | **when this system is triggered, it spawns each of the listed entity types as familiars for the system's parent entity (works for players or enemies; the player ones will normally persist between rooms) |
− | instant_hit_all_includes_shootable_obstacles (bool) | + | *instant_hit_all_includes_shootable_obstacles (bool) |
− | works with shots_instantly_hit_all_enemies to also hit all shootable obstacles | + | **works with shots_instantly_hit_all_enemies to also hit all shootable obstacles |
− | reveals_entire_map (bool) | + | *reveals_entire_map (bool) |
− | when this system is triggered, the map of the current floor is fully revealed | + | **when this system is triggered, the map of the current floor is fully revealed |
− | reveals_room_types (List<RoomType>) | + | *reveals_room_types (List<RoomType>) |
− | when this system is triggered, all rooms on the current floor of the specified types are revealed | + | **when this system is triggered, all rooms on the current floor of the specified types are revealed |
− | + | *teleports_player_to_boss_room (bool) | |
− | teleports_player_to_boss_room (bool) | + | **when this system is triggered, if the player is not in the boss room, the player is teleported to a random door (not the one to the next floor) in the boss room. |
− | when this system is triggered, if the player is not in the boss room, the player is teleported to a random door (not the one to the next floor) in the boss room. | + | *teleports_player_to_unvisited_room_of_type (RoomType), teleports_player_to_any_unvisited_room (bool) |
− | teleports_player_to_unvisited_room_of_type (RoomType), teleports_player_to_any_unvisited_room (bool) | + | **when this system is triggered, if the current floor has any unrevealed rooms of this type (or any type, for the second field), the player is teleported to one (if none found, there's a chat log message) |
− | when this system is triggered, if the current floor has any unrevealed rooms of this type (or any type, for the second field), the player is teleported to one (if none found, there's a chat log message) | + | **if the new room is a secret room, any secret doors bordering the room are revealed |
− | if the new room is a secret room, any secret doors bordering the room are revealed | + | **any locked doors bordering the room are unlocked |
− | any locked doors bordering the room are unlocked | + | *teleports_player_to_next_floor (bool) |
− | teleports_player_to_next_floor (bool) | + | **when this system is triggered, the player is teleported to the next floor |
− | when this system is triggered, the player is teleported to the next floor | + | *scraps_and_regenerates_current_floor (bool) |
− | scraps_and_regenerates_current_floor (bool) | + | **when this system is triggered, the dungeon generates a new floor and replaces the current floor with it, then teleports the player to the beginning of the new floor |
− | when this system is triggered, the dungeon generates a new floor and replaces the current floor with it, then teleports the player to the beginning of the new floor | + | *converts_from_item_type (InventoryItemType), converts_to_item_type (InventoryItemType), item_conversion_ratio (float) |
− | converts_from_item_type (InventoryItemType), converts_to_item_type (InventoryItemType), item_conversion_ratio (float) | + | **when this system is triggered, it converts the player's (from) inventory to (to), at (ratio), until either the from supply is exhausted or the to inventory is full |
− | when this system is triggered, it converts the player's (from) inventory to (to), at (ratio), until either the from supply is exhausted or the to inventory is full | + | *makes_next_purchase_free (bool) |
− | makes_next_purchase_free (bool) | + | **when this system is triggered, it sets a flag (which persists until dungeon exit or until you use it) that makes the next store purchase free |
− | when this system is triggered, it sets a flag (which persists until dungeon exit or until you use it) that makes the next store purchase free | + | *creates_x_item_pickups_nearby (int) |
− | creates_x_item_pickups_nearby (int) | + | **when this system is triggered, it spawns that many entities from ItemPool.RegularEnemyDrop near the player |
− | when this system is triggered, it spawns that many entities from ItemPool.RegularEnemyDrop near the player | + | *item_refund_chance (int), item_refund_portion (float), item_refund_cooldown (float), item_refund_requires_kill (bool) |
− | item_refund_chance (int), item_refund_portion (float), item_refund_cooldown (float), item_refund_requires_kill (bool) | + | **when a shot emitted from this system hits (or kills) a ship, there's a % (chance, 1 to 100) that (portion, 0 to 1) of the required_item_type cost is refunded to the player inventory |
− | when a shot emitted from this system hits (or kills) a ship, there's a % (chance, 1 to 100) that (portion, 0 to 1) of the required_item_type cost is refunded to the player inventory | + | **cannot happen more often than (cooldown, default 0.3), tracked independently per system |
− | cannot happen more often than (cooldown, default 0.3), tracked independently per system | + | **portion can be negative, in which case it actually charges you extra on-hit or on-kill, which might be useful for something that's supposed to have a low cost to try but a higher cost to succeed |
− | portion can be negative, in which case it actually charges you extra on-hit or on-kill, which might be useful for something that's supposed to have a low cost to try but a higher cost to succeed | + | **this is mainly for weapons with required_item_type=Energy, but Credits could work too, for a kind of very short-lived mercenary attack |
− | this is mainly for weapons with required_item_type=Energy, but Credits could work too, for a kind of very short-lived mercenary attack | + | *shots_drift_towards_hostile_ships_range (int), shots_drift_towards_hostile_ships_speed (int) |
− | shots_drift_towards_hostile_ships_range (int), shots_drift_towards_hostile_ships_speed (int) | + | **shots fired by this system will move at (speed) towards hostile ships in (range), in addition to their normal movement |
− | shots fired by this system will move at (speed) towards hostile ships in (range), in addition to their normal movement | + | **so not really homing, just kind of "magnetic"; whether it generates a collision depends a lot on the shot's speed and the magnetism strength |
− | so not really homing, just kind of "magnetic"; whether it generates a collision depends a lot on the shot's speed and the magnetism strength | + | *authorizes_when_parent_hit_by_enemy (bool, default true), authorizes_when_parent_hit_by_friend (bool) |
− | authorizes_when_parent_hit_by_enemy (bool, default true), authorizes_when_parent_hit_by_friend (bool) | + | **works with firing_timing=WhenParentEntityHit and hitbox.on_hit_triggers_systems_of_type; if the entity triggering the authorization does not pass these flags it doesn't actually authorize the activation |
− | works with firing_timing=WhenParentEntityHit and hitbox.on_hit_triggers_systems_of_type; if the entity triggering the authorization does not pass these flags it doesn't actually authorize the activation | + | *attack_power_against_player |
− | attack_power_against_player | + | **if a shot from this system hits the player instead, it acts as if this were the base attack power instead of the normal attribute |
− | if a shot from this system hits the player instead, it acts as if this were the base attack power instead of the normal attribute | + | **defaults to whatever attack_power is |
− | defaults to whatever attack_power is | + | **this is internally implemented as a multiplier, since the base attack power of a shot is factored into the computation before the shot hits, and thus before it knows whether or not it will hit the player; but for the purpose of editing the xml this is in the same units as attack_power, rather than a percent or multiplier |
− | this is internally implemented as a multiplier, since the base attack power of a shot is factored into the computation before the shot hits, and thus before it knows whether or not it will hit the player; but for the purpose of editing the xml this is in the same units as attack_power, rather than a percent or multiplier | + | *shots_hit_friendlies_that_have_just_been_knocked_back (bool) |
− | shots_hit_friendlies_that_have_just_been_knocked_back (bool) | + | **shots emitted by this system can hit friendlies that were knocked back in the past tenth of a second or so |
− | shots emitted by this system can hit friendlies that were knocked back in the past tenth of a second or so | + | *distance_threshold_modifiers_applied_to_nearby_entities (int) |
− | distance_threshold_modifiers_applied_to_nearby_entities (int) | + | **only works in conjunction with modifiers with target=NearbyEntities |
− | only works in conjunction with modifiers with target=NearbyEntities | + | **each sim-step, this entity checks for other entities within (distance) and copies these modifiers to those entities |
− | each sim-step, this entity checks for other entities within (distance) and copies these modifiers to those entities | + | **because of the frequency of copying, all these modifiers should probably have do_not_stack |
− | because of the frequency of copying, all these modifiers should probably have do_not_stack | + | **combined with a short duration (say, half a second), this imitates an effect (like movement slowing) that only lasts while this entity is in range and for a short time after |
− | combined with a short duration (say, half a second), this imitates an effect (like movement slowing) that only lasts while this entity is in range and for a short time after | + | *modifiers_applied_to_nearby_entities_can_target_allies (bool), modifiers_applied_to_nearby_entities_can_target_enemies (bool), modifiers_applied_to_nearby_entities_max_simultaneous_affected (int) |
− | modifiers_applied_to_nearby_entities_can_target_allies (bool), modifiers_applied_to_nearby_entities_can_target_enemies (bool), modifiers_applied_to_nearby_entities_max_simultaneous_affected (int) | + | **works in conjunction with target=NearbyEntities modifiers, targeting (allies|enemies), and if (max) > 0 it obeys that as well (preferring to keep affecting the ones it affected the previous check) |
− | works in conjunction with target=NearbyEntities modifiers, targeting (allies|enemies), and if (max) > 0 it obeys that as well (preferring to keep affecting the ones it affected the previous check) | ||
== Sub-Nodes == | == Sub-Nodes == |
Revision as of 18:58, 21 November 2015
Overview
These are not ships -- they're just guns or whatever. They're how a ship actually does something like shoot or trigger an ability, generally.
An example
<system name="PlayerDirected_Minigun" category="PlayerDirectedWeapon" is_player_main_weapon="true" shot_type="BulletPointedBlue" damage_type="Ballistic" attack_power="14" fire_rate="0.4" range_actual="500" shots_per_salvo="1" shot_speed="1200" flagship_ability_type="DirectFireWeapon" targeting_logic="Direct" image_name="MantaGun" quality_tier="0" > </system>
Attributes
- category (EntitySystemCategory)
- ammo (int, optional)
- how many shots until the system cannot fire anymore. Right now only used for consumables, with a max ammo of 1.
- shots_per_salvo (int)
- how many shots the system fires at once. If used with a BulletPattern, generates that pattern that many times.
- one_shot_per_target (bool, optional)
- if true, and shots_per_salvo > 1, will spread out its shots (not firing more than one at any target)
- attack_power (float)
- how much damage this system's shots do
- fire_rate (float)
- how many seconds it takes the system to reload after firing a salvo before it can fire again
- range_actual (int, required unless there's a BulletPattern)
- how far this system's shots can fly until they disappear
- range_do_not_fire_until (int, optional)
- how close the system has to be to consider firing on a target
- range_chases_until_within (int, optional)
- how close the AI of the system's parent entity will try to get (generally it only checks the first system for this)
- forced_angle_offsets (comma-delimited list of floats, optional)
- the angles each shot in the salvo will travel at, relative to the angle to the target; useful for bursts without resorting to an all-up BulletPattern
- you can use this with single-shot salvos, but if the angle is more than a degree or so that's basically "a gun that always misses"
- hits_all_intersecting_targets (bool, optional)
- beam-weapon only (that is, the shot type has the insta_fire flag). Makes this system's shots apply their full damage to everything on the line.
- shot_destroys_other_shots (bool, optional)
- this system's shots destroy enemy shots they touch during flight, but the system will not specifically try to target enemy shots
- intercepts_other_shots (bool, optional)
- similar to shot_destroys_other_shots, but the system will intentionally target enemy shots
- shot_sticks_after_intercepting_another_shot (bool), shot_dies_after_intercepting_another_shot (bool)
- normally intercepting a shot leaves the interceptor intact unless the other shot also destroys shots
- with (sticks) the interceptor will remain, but will cease all normal movement
- with (dies) the interceptor instantly dies, along with the thing it intercepted
- damage_type (DamageType)
- range_to_live_mult (float, optional)
- this system's shots live this much longer or shorter than its range implies. Only current usage is making the mine's self destruct "system" shots not go anywhere, via mult=0
- time_to_live (float, optional, default 10)
- this system's shots expire after this long regardless of range or whatever. Does not apply to BulletPattern stuff
- fires_from_any_range (bool, optional)
- this system will consider targets out of range, and even fire at them
- fires_salvos_sequentially (bool, optional)
- this system will fire each shot in its salvo a short delay after the previous shot. Useful for strings of bullets without resorting to an all-up BulletPattern
- shot_area_of_effect (int, optional)
- this system's shots will damage everything (for full normal damage) within this distance of them when they're removed from the game
- aoe_hits_friendly_targets (bool, optional, defaults TRUE)
- this system's shots will damage even friendly targets with aoe
- destroys_firing_entity (bool, optional)
- makes the entity that fired it go boom
- only_targets_damaged_ships (bool, optional)
- only targets entities that have already been damaged
- flagship_ability_type (PlayerFlagshipAbilityType, optional)
- basically this should either be DirectFireWeapon for player guns/abilities or left out
- only_targets_nearest_ship (bool, optional)
- only targets the nearest eligible target; probably only meaningful for a player familiar
- shot_is_not_stopped_by_hitting (bool, optional)
- this shot passes through enemy ships, damaging them only once (even if they encounter them again later somehow), but able to damage more than one ship overall
- only_fires_on_death (bool, optional)
- used for self-destruct explosion "systems" like on the mines
- shot_speed (int, optional, default 350)
- how fast this system's shots go
- salvo_spread_responds_to_player_direction (bool, optional)
- this system's shots fan out like the old TLF "spreadfire" weapon; targeting the angle to the cursor and fanning out more or less depending on range to the cursor
- targeting_logic (TargetingLogic)
- firing_timing (FiringTiming, required if Category == Weapon)
- fires_one_shot_from_each_other_player_directed_system (bool, optional)
- when this system fires, it actually fires one salvo per each of the player's main guns. This is used for the player's missile ability.
- only_fires_on_keybind_release (KeyBind, optional)
- the system only fires when the player presses and then releases this key; there's a ton of KeyBind values but the only one intended for this currently is ***HoldAndReleaseToFireMissile
- only_fires_on_keybind (KeyBind, optional)
- the system only fires when the player presses this key (doesn't wait for release); the only KeyBind values intended for this currently are:
- UseEnergyBasedSystem
- UseConsumableSystem
- the system only fires when the player presses this key (doesn't wait for release); the only KeyBind values intended for this currently are:
- requires_item_type (InventoryItemType, optional)
- the system cannot fire unless the player has a certain amount (requires_item_amount) of this item type (Missile, etc)
- requires_item_amount (float, optional)
- the amount required by the previous flag's logic
- you'll generally want to use int costs, but sometimes partial is necessary
- requires_line_of_sight_of_player_to_fire (bool, optional)
- this system has to be able to see the player (not going through obstacles) to be able to fire
- line_of_sight_recalculation_interval (float, optional, default 0.2)
- the most often (in seconds) this system will recompute l-o-s for the previous flag's logic
- cue_time (float, optional, default 0.5)
- the number of seconds this system (or the entity, if this is the only cue-time system on it) puts out a little yellow pulse "cue" before it actually fires
- ship_system_group (string, optional)
- does nothing by itself, but is used by pickup definitions to determine what systems they can "contain" as loot
- is_toggleable (bool, optional), defaults_toggle_off (bool, optional, defaults true)
- only for player energy-use systems, really; pressing the related only_fires_on_keybind (or release) keybind toggles the system on and off (if toggled off, the modifiers it applies to the parent entity, if any, no longer have effect)
- display_name (string, optional)
- what the player sees when the game tries to tell them the name of this system
- description (string, optional)
- similar to display_name, not necessarily used in all contexts that display_name is
- is_player_main_weapon (bool, optional)
- use this if this is a "the player's two main guns" weapon; like the starting miniguns (or whatever) or ones that the player can pick up along the way. This is so the game can properly swap them in and out on pickup.
- shot_type (GameEntity name)
- the name of the GameEntity data that should be used for the system's actual shots
- special_bullet_patterns (comma-delimited list of bullet_pattern names, optional)
- the names of the BulletPattern(s) this system can generate; if there's more than one a pattern is picked randomly from the list each time it needs one
- image_folder (string, optional)
- same deal as with GameEntity
- image_name (string, optional)
- same deal as with GameEntity
- related_item (string, optional)
- This is required on any systems that can be dropped by the player (ammo items and consumables, basically). This tells what icon to show in the bottom of the screen, as well as what system to actually drop.
- sounds_on_shot_fired (comma-delimited strings list)
- If this system fires a shot, or a shot pattern, then one of the sounds in the list will be played at random. Default "Shot_QuietTwoPart1,Shot_QuietTwoPart2".
- min_ms_between_shot_fired_sounds (int, optional)
- Some systems fire salvos of shots rather frequently, and so normally a 50ms delay between invocations of their sound effects is imposed. For some shots you may want a larger delay, though (seriously that’s a rapid-fire shot, then), or in other cases you may wish for silence, in which case you can put -1 (since sounds_on_shot_fired has a default value). Default 50.
- shots_are_homing (bool, optional)
- this system's shots will curve around to fly towards the target point/ship
- shot_proximity_detonation_range (int, optional)
- makes the ship die when a ship it could gets within X of a normal collision (so basically it's a collision check with X as an extra added into the range checks)
- does not necessarily do on-hit logic to the thing triggering it; but it will check for aoe and only_fires_on_death systems
- system_to_attach_to_shot (system, optional)
- whenever this system emits a shot, that shot spawns with one of the specified systems (allowing shots that fire other shots, or have on-death explosions that create bullet patterns, or whatever)
- shots_do_friendly_fire_after_time (float, optional)
- so after one of its shots have been alive for X seconds, it can hit friendly stuff, and its aoe can hit friendly stuff (even if it doesn't have the friendly-fire aoe flag)
- shot_damage_per_second_from_touching (float, optional)
- creates an implicit melee-range system that is added to any shots systems of that type fire
- copies the EntitiesMyShotsHit modifiers (if any) from this system-type to that implicit melee system-type
- shots_rubber_band_to_starting_point (bool, optional)
- now when the shot reaches the end of its range-to-live it doesn't scale out, it sets its destination point back to where it came from. When it reaches that point it then scales out
- shots_rubber_band_to_firing_system (bool, optional)
- similar, but rubber-bands back to the current location of the firing system (even as that system moves)
- charge_per_second, charge_cap, and charge_add_to_multiply_per_point (all float, optional)
- only works in conjunction with only_fires_on_keybind (not the on_release version, since this is inherently on-release)
- only works in conjunction with requires_item_type, as that tells it what resource to pull it from (presumably energy, but you could use missiles or credits if you wanted)
- as you hold down the key, the system charges by that amount per second, up to the cap or how much you've got (whichever is less)
- when you release the key, if the total charge < 1, it just doesn't fire or cost you any of the resource
- when you release the key, if the total charge >= 1, it fires normally but with the attack power of all the shots will be multiplied by 1f + (charge * charge_add_to_multiply_per_point)
- range_damage_scaling_floor, range_damage_scaling_ceiling (both float, optional) and range_damage_scaling_optimal_range (int, optional)
- if the shot has travelled zero distance before the hit, it gets the floor multiplier
- if the shot has travelled exactly the optimal distance when it hits, it gets the ceiling multiplier
- if the shot has travelled >= 2 * optimal before the hit, it gets the floor multiplier
- in the other cases, it linearly interpolates between the floor and ceiling
- the multiplier is applied to the shot's attack power at the time it hits
- range_speed_scaling_floor, range_speed_scaling_ceiling (both float, optional), and range_speed_scaling_optimal_range (int, optional)
- same deal, except it multiplies the shot's speed at each sim-step according to the range travelled thus far
- deflects_shots (bool, optional)
- if a shot from this system collides with a hostile shot, it deflects that shot back on the opposite angle of its current travel
- a shot cannot be deflected twice
- deflects_shots_as_friendly_fire (bool, optional)
- same deal, but also makes those shots be able to hit targets friendly to it
- shots_knockback (int, optional)
- ships hit by this are knocked back X distance units (if that would put them in a wall they don't go that far)
- shots_knockback_on_firing_ship_to_target_ship_angle and shots_knockback_on_shot_to_target_ship_angle" to system (both bool, optional)
- overrides the default logic of "shots_knockback pushes back on the angle the shot is travelling in"
- disabled_if_zero_of_item (InventoryItemType, optional)
- if you've got none of that resource left, the system is considered disabled
- shots_spawn_at_reticule (bool, optional)
- makes the shot spawn at CalculateReticulePointForPlayerRightNow
- if that's outside the room or in an indestructible within-room wall it tries to walk it back towards the player
- targets_entity_that_last_damaged_my_entity (bool, optional)
- after it fires a salvo, the remembered last-damaged-by is cleared
- shots_instantly_hit_all_enemies, shots_instantly_hit_all_non_boss_enemies (both bool, optional)
- both cause the shots emitted by that system to instantly hit all enemies and disappear (so the shots will generally not ever be seen); they apply all the normal on-hit logic, modifier transfer, etc
- the second excludes any enemy where BossType != None
- shots_do_portion_of_current_health_as_damage (float, optional)
- does X * the current hull health of the ship in damage, where X is between 0 and 1 (not 0 and 100; this is a multiplier, not a percent)
- do_parallel_salvo_with_spacing (int, optional)
- only meaningful if shots_per_salvo > 1
- puts the first shot in the center like normal
- puts the second shot at the specified distance to one side
- puts the third shot at the specified distance to the other side
- puts the fourth shot at twice the specified distance to the first side, and so on
- salvo_angle_difference (int, optional)
- only meaningful if shots_per_salvo > 1
- the first shot has no change
- the second shot gets angle + the specified amount (in degrees)
- the third shot gets angle - the specified amount
- the fourth shot gets angle + twice the specified amount, and so on
- shots_follow_the_reticule (bool, optional)
- shots emitted this system are basically glued to the cursor/reticule, moving instantly to that location even if it goes into a wall
- shot_movement_particle (particle_pattern, optional)
- shots emitted from this system emit this particle while moving
- inaccuracy_spread (int, optional)
- makes each shot emitted from the system get a random angle offset from -x to +x degrees
- inaccuracy_is_by_salvo (bool, optional)
- makes the previous apply to the salvo as a whole, not the individual shots
- miss_penalty_percent (int, optional)
- if a shot expires without hitting any entity, it does this percent (expressed as 0 to 100) of its normal damage (whatever it would have done to an enemy at that time) to the ship which fired it
- spawns_entity (entity, optional)
- when the system is triggered, an entity of this type is spawned at the location of the system
- energy_shield_damage_portion, energy_shield_conversion_multiplier (both float, optional)
- the first is the percent of damage done to the parent entity that the conversion will try to apply to
- the second is the cost in energy of each point of damage prevented, thus determining the max amount of damage that can actually be converted
- shot_disintegration_speed_mult (float, optional).
- Normally shots decay and shrink down in both size and damage dealt when they pass the end of their range or lifespan. This gives them a nice fade-out, but also increases the range somewhat based on the speed of the shot.
- This multiplier lets you make this process of decay happen faster (>1) or slower (<1). A multiplier of 6 or more will make it almost instant, but without jolting out of existing unprofessionally. Default 1.
- is_destroyed_after_finite_uses (int, optional)
- if a number > 0, then the system is gone after triggering that many times. Default 0.
- hull_health_siphon_portion (float, optional)
- whenever shots emitted by this system do damage, X% (expressed as 0 to 1) of the damage done is also applied as healing to the firing ship's hull
- shots_teleport_to_target_point (bool, optional)
- whenever this system emits shots, those shots instantly teleport to the target point (whatever that is based on the system's targeting_logic and context)
- revives_parent_entity_with_hull_health_portion (float, optional)
- whenever the parent system of this ship would normally die, its hull health is immediately set to X% (expressed as 0 to 1) of its max hull health
- screen_flash_seconds_on_use, screen_flash_seconds_on_shot_detonation (both bools, optional)
- makes the screen go white instantly on use or shot detonation (respectively), then fade to normal over X seconds
- consumes_all_required_item_on_use (bool, optional)
- only works in conjunction with requires_item_type
- after this system is used, all of that item is removed from the player's inventory (after whatever normal cost is associated)
- beam_particle (particle, optional) and beam_particle_distance_interval (int, optional)
- makes the beam emit that particle at points X distance apart along its length
- shot_gravity_pull_per_second, shot_gravity_falloff_per_unit_distance (both floats, optional)
- so if you had values of 100 and 0.2, then it would exert a pull on something up to 500 units away, where that pull is 20 at 400 distance, 40 at 300, 60 at 200, 80 at 100, etc
- shot_gravity_affects_shots, shot_gravity_affects_friendlies (both bools, optional)
- normally it only affects enemy ships; these change that
- shot_gravity_has_repelling_effect (bool, optional)
- makes the shot's gravity pull do a repulsion instead
- drones_are_finite (bool), drones_are_guards (bool)
- if has drones and fire_rate > 0, then every (fire_rate) seconds it picks a drone from this system's drone nodes
- if finite, that "ball" is not returned to the random bag from which the drone type is picked; if there are no more items it just doesn't spawn more
- if guards, the drones are spawned with FlockBehaviorType.Buddy and AIRelatedEntityID set to this system's parent ship
- shots_hitting_player_warp_responsible_entity_to_parent_entity (bool)
- if a shot from this system hits the player, then the parent entity of this system is destroyed and the entity which spawned that parent entity (if any) instantly teleports to its location
- shots_steal_credits (float), credit_drop_on_death_portion (float)
- if a shot from this system hits the player, the player loses (shots_steal_credits) credits
- if the parent entity of this system dies, then (credit_drop_on_death_portion ) * the credits stolen by this system are dropped on the ground
- shots_die_instantly_at_boundary_direction (FourDirection), shots_die_instantly_at_boundary_distance_from_wall (int)
- when shots from this system get within (distance) of the (direction) external room wall they instantly are removed from the game
- spawns_entity_ship_category (ShipCategory)
- similar to spawns_entity, but randomly picks from entity types with a matching ship_category
- only_enabled_if_player_needs_missiles (bool)
- if the player has any missiles, this system is disabled
- if there are any missile pickups in the room, this system is disabled
- if there are any enemies spawned by this system in the room, this system is disabled
- if the room has already been won, this system is disabled
- entities_spawned_by_this_always_drop (entity)
- any entities spawned by this system will always drop the specified entity type on death
- portion_attack_power_gain_per_my_portion_health_lost (float)
- when this system emits a shos, the attack power of the shot is multiplied by 1 + (the portion of the system's parent entity health lost * this field)
- so if this is 1, then as the parent entity's health approaches zero the attack power of newly emitted shots will approach twice what it would otherwise be
- spawns_familiars (List<GameEntityTypeData>)
- when this system is triggered, it spawns each of the listed entity types as familiars for the system's parent entity (works for players or enemies; the player ones will normally persist between rooms)
- instant_hit_all_includes_shootable_obstacles (bool)
- works with shots_instantly_hit_all_enemies to also hit all shootable obstacles
- reveals_entire_map (bool)
- when this system is triggered, the map of the current floor is fully revealed
- reveals_room_types (List<RoomType>)
- when this system is triggered, all rooms on the current floor of the specified types are revealed
- teleports_player_to_boss_room (bool)
- when this system is triggered, if the player is not in the boss room, the player is teleported to a random door (not the one to the next floor) in the boss room.
- teleports_player_to_unvisited_room_of_type (RoomType), teleports_player_to_any_unvisited_room (bool)
- when this system is triggered, if the current floor has any unrevealed rooms of this type (or any type, for the second field), the player is teleported to one (if none found, there's a chat log message)
- if the new room is a secret room, any secret doors bordering the room are revealed
- any locked doors bordering the room are unlocked
- teleports_player_to_next_floor (bool)
- when this system is triggered, the player is teleported to the next floor
- scraps_and_regenerates_current_floor (bool)
- when this system is triggered, the dungeon generates a new floor and replaces the current floor with it, then teleports the player to the beginning of the new floor
- converts_from_item_type (InventoryItemType), converts_to_item_type (InventoryItemType), item_conversion_ratio (float)
- when this system is triggered, it converts the player's (from) inventory to (to), at (ratio), until either the from supply is exhausted or the to inventory is full
- makes_next_purchase_free (bool)
- when this system is triggered, it sets a flag (which persists until dungeon exit or until you use it) that makes the next store purchase free
- creates_x_item_pickups_nearby (int)
- when this system is triggered, it spawns that many entities from ItemPool.RegularEnemyDrop near the player
- item_refund_chance (int), item_refund_portion (float), item_refund_cooldown (float), item_refund_requires_kill (bool)
- when a shot emitted from this system hits (or kills) a ship, there's a % (chance, 1 to 100) that (portion, 0 to 1) of the required_item_type cost is refunded to the player inventory
- cannot happen more often than (cooldown, default 0.3), tracked independently per system
- portion can be negative, in which case it actually charges you extra on-hit or on-kill, which might be useful for something that's supposed to have a low cost to try but a higher cost to succeed
- this is mainly for weapons with required_item_type=Energy, but Credits could work too, for a kind of very short-lived mercenary attack
- shots_drift_towards_hostile_ships_range (int), shots_drift_towards_hostile_ships_speed (int)
- shots fired by this system will move at (speed) towards hostile ships in (range), in addition to their normal movement
- so not really homing, just kind of "magnetic"; whether it generates a collision depends a lot on the shot's speed and the magnetism strength
- authorizes_when_parent_hit_by_enemy (bool, default true), authorizes_when_parent_hit_by_friend (bool)
- works with firing_timing=WhenParentEntityHit and hitbox.on_hit_triggers_systems_of_type; if the entity triggering the authorization does not pass these flags it doesn't actually authorize the activation
- attack_power_against_player
- if a shot from this system hits the player instead, it acts as if this were the base attack power instead of the normal attribute
- defaults to whatever attack_power is
- this is internally implemented as a multiplier, since the base attack power of a shot is factored into the computation before the shot hits, and thus before it knows whether or not it will hit the player; but for the purpose of editing the xml this is in the same units as attack_power, rather than a percent or multiplier
- shots_hit_friendlies_that_have_just_been_knocked_back (bool)
- shots emitted by this system can hit friendlies that were knocked back in the past tenth of a second or so
- distance_threshold_modifiers_applied_to_nearby_entities (int)
- only works in conjunction with modifiers with target=NearbyEntities
- each sim-step, this entity checks for other entities within (distance) and copies these modifiers to those entities
- because of the frequency of copying, all these modifiers should probably have do_not_stack
- combined with a short duration (say, half a second), this imitates an effect (like movement slowing) that only lasts while this entity is in range and for a short time after
- modifiers_applied_to_nearby_entities_can_target_allies (bool), modifiers_applied_to_nearby_entities_can_target_enemies (bool), modifiers_applied_to_nearby_entities_max_simultaneous_affected (int)
- works in conjunction with target=NearbyEntities modifiers, targeting (allies|enemies), and if (max) > 0 it obeys that as well (preferring to keep affecting the ones it affected the previous check)
Sub-Nodes
drone
specifies the entities that can spawn from this system; see drones_are_finite and drones_are_guards
Attributes:
- type (entity)
- the type of entity to spawn
- count (int)
- if drones are finite, this is the number of this type of entity that can be spawned from this system. Otherwise this is just the relative frequency at which this type of entity will be spawned from this system.