Skip to content

Skills Misc

Enduriel edited this page Apr 18, 2022 · 9 revisions

Ranged Tooltip

<skill>.getRangedTooltip( _tooltip = null )
_tooltip is an array

MSU provides a very convenient function for automatically generating range and accuracy information for ranged skills in their tooltips. This way, all you have to do is define the following two fields in the skill's m table:

  • AdditionalAccuracy
  • AdditionalHitChance

If _tooltip is passed, the function will return _tooltip with the ranged information added to the array. Otherwise it will create a new array and return a new tooltip array with just the ranged info below.

The tooltip generated then, automatically, has information such as:

  • "has a range of X tiles on even ground, Y if shooting down hill"
  • "has XX% chance to hit and YY% per tile of distance"

X is this.m.MaxRange
Y can be one of the strings "more", "or", "less" depending on if this.m.MaxRangeBonus is >0, ==0, <0 respectively.
XX is this.m.AdditionalAccuracy
YY is this.m.AdditionalHitChance

Example

In your ranged skill, you can generate all the proper info about hit chance and range by doing the following:

function getTooltip()
{
    return this.getRangedTooltip(this.getDefaultTooltip());
}

// or

function getTooltip()
{
    local tooltip = this.getDefaultTooltip();

    // add some more info to tooltip

    // then:
    tooltip.extend(this.getRangedTooltip());

    // then add some more info to tooltip as necessary
    
    return tooltip;
}

Injuries

MSU adds a system to exclude certain sets of injuries from certain entities easily. MSU comes with the following sets of injuries built-in (only include vanilla injuries):

  • Hand
  • Arm
  • Foot
  • Leg
  • Face
  • Head

Create/Expand a Set of Excluded Injuries

::Const.Injury.ExcludedInjuries.add( _name, _injuries, _include = null )
// _name is a string
// _injuries and _include are arrays

_name will become a key in ::Const.Injury.ExcludedInjuries.
_injuries contains skillIDs of injuries to add.
_include contains keys in ::Const.Injury.ExcludedInjuries. If _include is null then it defaults to an empty array.

Creates an entry in the ::Const.Injury.ExcludedInjuries table with _name as key and { Injuries = _injuries, Include = _include } as value. The slots passed in the _include array must already exist.

If the key _name already exists in ::Const.Injury.ExcludedInjuries then its associated Injuries and Include are expanded to include _injuries and _include.

Example

::Const.Injury.ExcludedInjuries.add(
    “Hand”,
    [
        “injury.fractured_hand”,
        “injury.crushed_finger”
    ]
);

::Const.Injury.ExcludedInjuries.add(
    “Arm”, 
    [
        “injury.fractured_elbow”
    ],
    [
        ::Const.Injury.ExcludedInjuries.Hand
    ]
);

Get a Set of Excluded Injuries

::Const.Injury.ExcludedInjuries.get( _injuries )
// _injuries is a key in ::Const.Injury.ExcludedInjuries

Returns an array containing the skill IDs of all the injuries associated with that slot. The array is expanded using the all the sets of injuries defined in the associated Include of that set.

Example

::Const.Injury.ExcludedInjuries.add(
    “Hand”,
    [
        “injury.fractured_hand”,
        “injury.crushed_finger”
    ]
);

::Const.Injury.ExcludedInjuries.add(
    “Arm”, 
    [
        “injury.fractured_elbow”
    ],
    [
        ::Const.Injury.ExcludedInjuries.Hand
    ]
);

local result = ::Const.Injury.ExcludedInjuries.get(::Const.Injury.ExcludedInjuries.Arm);

In this example result will be equal to ["injury.fractured_elbow", “injury.fractured_hand”, “injury.crushed_finger”].

Add Excluded Injuries to Actor

<actor>.addExcludedInjuries( _injuries )
// _injuries is a key in ::Const.Injury.ExcludedInjuries

Adds all the injuries returned from ::Const.Injury.ExcludedInjuries.get(injuries) to the this.m.ExcludedInjuries array of <actor>. Entries already present in this.m.ExcludedInjuries are not duplicated.

Example

In order to prevent Serpents from gaining Arm related injuries, hook the onInit function of serpent and add the following line of code:

this.addExcludedInjuries(::Const.Injury.ExcludedInjuries.Arm);
Clone this wiki locally