-
Notifications
You must be signed in to change notification settings - Fork 33
ModuleB9PartSwitch
ModuleB9PartSwitch
is the PartModule at the heart of B9PartSwitch. Each ModuleB9PartSwitch
has multiple subtypes which can be switched between. An unlimited number of ModuleB9PartSwitch
modules can exist on the same part, with some restrictions.
-
moduleID
- A unique identifier for this module, which may be blank if there is only oneModuleB9PartSwitch
on the part. Similar toengineID
on engine modules. I recommend that it not contain spaces so that it can accessed easily with ModuleManager. -
baseVolume
- The volume of tanks in this module, in KSP volume units (i.e. units ofLiquidFuel
). Subtypes may modify this volume -
switcherDescription
- A description of the switcher which is used in the part's right click menu in the editor. Default: "Subtype". Other examples: "Tank", "Top Nodes". Should generally be kept short and descriptive as a single control contains this, the subtype title, and the controls to switch subtypes. -
switcherDescriptionPlural
- Describes the switcher/subtypes in the part catalog. Default: "Subtypes", which would become a description of "3 Subtypes" (or whatever number). -
affectDragCubes
- Whether the part's drag cubes should be re-calculated when switching the subtype. Defaults totrue
, however, drag cubes will never be re-calculated if no transforms/models are switched on subtypes. Should be set tofalse
if transforms/models are switched but they do not differ significantly in shape. -
affectFARVoxels
- If FerramAerospaceResearch is installed, this affects whether vessel re-voxelization should be triggered when switching the subtype. Defaults totrue
, however, re-voxelization will never be triggered if no transforms/models are switched on subtypes. Should be set tofalse
if transforms/models are switched but they do not differ significantly in shape. -
parentID
-moduleID
of anotherModuleB9PartSwitch
- subtypes of this module can add volume to the "parent" module viavolumeAddedToParent
-
switchInFlight
- whether you can switch the subtype in flight (default false). NOTE - there are no checks to ensure that you aren't adding of subtracting mass out of nowhere with this. Please use carefully (pay attention to which tank types you use too) -
advancedTweakablesOnly
- whether this switcher is only available if you have advanced tweakables on (default false). Note that this only disables the UI. -
uiGroupName
is the unique identifier of the group (only available for KSP 1.8 and newer). -
uiGroupDisplayName
is the human readable name of the group to show in the UI (only available for KSP 1.8 and newer).
Each node named SUBTYPE
defines a different subtype. Subtypes have the following fields:
-
name
- Unique name for the subtype. Shouldn't contain any spaces for easy ModuleManager access -
title
- Human-readable name for the subtype. Will be filled fromname
if blank. -
primaryColor
- Color to use on the left side of the switching UI button. If not specified, it will use the tank type's primary color. If that isn't specified (or determined based on resources), it will be white. See Valid Color Formats for a list of ways to specify a color. -
secondaryColor
- Color to use on the right side of the switching UI button. If not specified, it will use the tank type's secondary color. If that isn't specified (or determined based on resources), it will use the subtype's primary color (including tank/resource color). If that isn't specified, it will be gray. See Valid Color Formats for a list of ways to specify a color. -
descriptionSummary
- text about the subtype that appears in the tooltip before automatically generated info about resources, mass, cost, etc. Keep it brief. -
descriptionDetail
- text about the subtype that appears in the tooltip after automatically generated info. Go wild with detailed information! -
upgradeRequired
- name of aPARTUPGRADE
that is required to unlock the subtype -
defaultSubtypePriority
- number that determines what the default subtype is based on what's unlocked. The unlocked subtype with the highest priority will be the default. The default value for this is zero. Any number, positive or negative, decimal or whole, is accepted. -
addedMass
- Mass that is added to the part by this subtype (in addition to tank and resource mass). -
addedCost
- Cost that is added to the part by this subtype (in addition to tank and resource cost). -
volumeAdded
- Tank volume added by this subtype (added on top of the module'sbaseVolume
) -
volumeMultiplier
- Multiplier to apply to the module'sbaseVolume
for this subtype. This probably shouldn't be used. -
volumeAddedToParent
- If this module has aparentID
, this subtype will add this much volume to the parent module specified by it -
percentFilled
- If specified (and not overridden on an individual resource), this specifies the percentage that tanks on this subtype should be filled (note - this overridespercentFilled
on the tank type) -
resourcesTweakable
- If specified, this controls whether the resource amounts on this subtype are tweakable (note - this overridesresourcesTweakable
on the tank type) -
tankType
- Name of the tank type that this subtype should use. Tank types are defined by globalB9_TANK_TYPE
nodes. A description of how to define tank types can be found on the Tank Definitions page. -
transform
- Name of Unity transform(s) which should be enabled on this subtype (it will be disabled on all others unless they also have it). Multiple are allowed, so you can havetransform = a
andtransform = b
on separate lines within the same subtype. If multiple transforms have the same name they will all be included. -
node
- Attach node id for stack nodes that should be enabled. NOTE - KSP strips out the node_stack part when creating the node id, sonode_stack_top01
will have a node id oftop01
. More than one can be defined, so you can have e.g.node = bottom01
andnode = top01
on the same subtype. -
maxTemp
- Temperature (in kelvins) to set the part'smaxTemp
to with this subtype. Other subtypes will use the part prefab'smaxTemp
-
skinMaxTemp
- Temperature (in kelvins) to set the part'sskinMaxTemp
to with this subtype. Other subtypes will use the part prefab'sskinMaxTemp
-
attachNode
- If set, will change the part's surface attachment node to this. Only works if the part is already surface attachable. Subtypes that don't have this defined will use the prefab's. Follows the usual node format of position x, y, z, normal x, y, z (the final size parameter is not used) -
crashTolerance
- Maximum speed (in m/s) at which the part can survive a crash. Subtypes which do not have this set will use the part prefab's value. NOTE - There is apparently a bug in KSP where only one collider on a part will be considered for crashes. There is nothing I can do about that. -
CoMOffset
- Part's center of mass offset. Subtypes that don't specify one will use the part's defaultCoMOffset
-
CoPOffset
- Part's center of pressure (aerodynamic force) offset. Subtypes that don't specify one will use the part's defaultCoPOffset
-
CoLOffset
- Part's center of lift offset. Subtypes that don't specify one will use the part's defaultCoLOffset
-
CenterOfBuoyancy
- Part's center of buoyancy. Subtypes that don't specify one will use the part's defaultCenterOfBuoyancy
-
CenterOfDisplacement
- Part's center of displacement. Subtypes that don't specify one will use the part's defaultCenterOfDisplacement
-
allowSwitchInFlight
- Whether this subtype can be changed to in flight (default true). If false, it will be hidden from the available subtype options in flight. Only matters if the module hasswitchInFlight = true
-
stackSymmetry
- The symmetry number to use on this part (affects how parts can be attached to symmetric stack nodes). Any subtypes that don't specify this will use the part's defaultstackSymmetry
Subtypes can also define the following nodes:
-
TEXTURE
- texture switching - this specifies a texture to replace on the part's model-
TEXTURE
nodes take the following fields:-
texture
(required) - path to the texture you want to use, e.g.MyMod/Parts/SomePart/texture
-
currentTexture
(optional) - name of the current texture (just the filename excluding the extension, not the full path). Anything that does not have this as the current texture will be ignored. -
isNormalMap
(optional, default false) - whether the texture is a normal map or not (necessary due to KSP treating normal maps differently when they are loaded) -
shaderProperty
(optional) - name of the shader property that the texture sits on. Default is_MainTex
ifisNormalMap = false
or_BumpMap
ifisNormalMap = true
. For an emissive texture you would want_Emissive
-
transform
(optional, can appear more than once) - names of transforms to apply the texture switch to -
baseTransform
(optional, can appear more than once) - names of transforms where the texture switch should be applied to them and all of their children
-
- If no
transform
orbaseTransform
is specified, it will look for textures to switch on the entire part
-
-
RESOURCE
- Resources can be specified here, or if the resource already exists on the tank type, any fields specified here will override those on the tank type. The allowed fields can be found on the Tank-Definitions page -
NODE
- Allows attach nodes on the part to be moved. If a node is moved on some subtypes but not others, the subtypes that don't specify a position will use the attach node's default position.-
name
- the id of the attach node. If the attach node isnode_stack_top01
you would havename = top01
-
position
- the new position of the attach node, specified as x, y, z coordinates.
-
-
TRANSFORM
- Allows transforms to be modified-
name
- the name of the transform to be modified -
positionOffset
- x, y, z vector to offset the transform's local position by. Any number of modules can modify this on the same transform. -
rotationOffset
- x, y, z rotation vector (in degrees) to offset the transform's local rotation by. Only one module can modify this on a particular transform. -
scaleOffset
- either a scalar or an x, y, z vector to scale the transform's local scale by. A scalar will be applied uniformly to all three axes.
-
-
MODULE
- Allows other modules to be modified- Please note that this feature is highly experimental, please talk to me before trying to use it
-
IDENTIFIER
- node that contains data used to identify the module being modified-
name
- value is required, this is the subtype name - Any other values can be used to identify the module, e.g.
engineID
,experimentID
-
-
DATA
- node containing data to be loaded into the target module -
moduleActive
- if set tofalse
, disable this module when this particular subtype is active
An unlimited number of ModuleB9PartSwitch
modules can exist on the same part with the following restrictions:
- Each must have a unique
moduleID
- If they manage the same transform, it will only enabled if all managing subtypes agree that it should be enabled. A module "manages" a transform if any subtype uses it.
- They cannot manage the same resources. A module "manages" a resource if any subtype has a tank type which uses it.
- If they manage the same stack node, it will only be enabled if all managing subtypes agree that it should be enabled. A module "manages" a stack node if any subtype uses it.
- Only one module can manage the part's
maxTemp
- Only one module can manage the part's
skinMaxTemp
- Only one module can manage the part's surface attachment node
- Only one module can manage the part's
crashTolerance
- Only one module can manage the part's
CoMOffset
- Only one module can manage the part's
CoPOffset
- Only one module can manage the part's
CoLOffset
- Only one module can manage the part's
CenterOfBuoyancy
- Only one module can manage the part's
CenterOfDisplacement
- Only one module can manage the part's
stackSymmetry
-
ModuleB9PartSwitch
will re-render drag cubes as necessary if transforms are switched andaffectDragCubes
is true (it is by default). If transforms are switched but do not change the shape significantly, it is recommended that you setaffectDragCubes = false
andaffectFARVoxels = false
to avoid any performance impact from re-rendering drag cubes. The drag cube re-rendering is compatible with one other module usingIMultipleDragCubes
(for instance,ModuleJettison
orModuleAnimateGeneric
) - if this is the case, all of that module's drag cubes will be re-rendered when switching.
- If the module has
switchInFlight = true
, the option will be made available to change the subtype in flight. If any resources are present that would be removed, a confirmation is presented to the user before switching. After switching, all managed resources will be empty.
Resource switching on ModuleB9PartSwitch will be disabled if any of the following modules are found on the part:
FSfuelSwitch
InterstellarFuelSwitch
ModuleFuelTanks
This is because the way that these modules do resource switching is incompatible with ModuleB9PartSwitch
. Note that when any of these modules are found, the tank type for all subtypes is set to the default Structural
subtype. This means that no subtype will receive any mass or cost from the tank.
A simple module might look something like this:
MODULE
{
name = ModuleB9PartSwitch
moduleID = fuelSwitch
baseVolume = 1000.0
SUBTYPE
{
name = Structural
transform = model_str
}
SUBTYPE
{
name = Structural_Big
title = Structural (Big)
transform = model_str
addedMass = 0.5
addedCost = 100
}
SUBTYPE
{
name = LiquidFuel
title = Fuel Tank
tankType = LiquidFuel
transform = model_lf
transform = model_lf_2
}
}