AddToFaction - Actor

Revision as of 03:55, 5 November 2016 by imported>Lisselli (→‎Examples: Added a nice little example code for changing reactions to multiple factions using an array.)

Member of: Actor Script

Adds the Actor to a specified faction at rank 0. If the Actor is already in the faction, this function does nothing.

Syntax

Function AddToFaction(Faction akFaction)

Parameters

  • akFaction: The faction to which the Actor should be added.

Return Value

None.

Examples

; Add Hrothgar to the Dark Brotherhood 
Hrothgar.AddToFaction(DBFaction)

;Adding the player to the Falmer Faction wont make the Falmers friendly. So change their reaction.
Actor property PlayerRef auto

Faction property FalmerFaction auto
Faction property PlayerFaction auto

PlayerRef.AddToFaction(FalmerFaction)
PlayerFaction.SetReaction(FalmerFaction, 3)


Faction property PlayerFaction auto
Faction[] property EnemyFactions auto
; BanditFaction, CreatureFaction, FalmerFaction, as examples in the array.

Function SetFactionReactions(Faction akFaction, Faction[] akFactionReactionToChange, Int iReaction=0)
Int iIndex = akFactionReactionToChange.Length

While iIndex
   iIndex -= 1
   akFaction.SetReaction(akFactionReactionToChange[iIndex], iReaction)
EndWhile

EndFunction

; Use this like so:
SetFactionReactions(PlayerFaction, EnemyFactions, 3)

Notes

  • For faction members of factions normally an enemy to the player, simply adding the player to the faction will not make them friendly to the player if their Aggression level is "Very Aggressive". Therefore when you add the player to such factions, you must also change their reaction accordingly through SetReaction - Faction and make them a "friend".
  • Additionally, some actors are part of more than one enemy faction, and you must take account for this by also using SetRaction() on any other factions they are part of.

See Also