Faction Creation – Arma Reforger
|  (added links) | Lou Montana (talk | contribs)  m (Text replacement - "\{\{GameCategory\|armaR\|Modding\|(Guidelines|Tutorials)\|([^=↵]*)\}\}" to "{{GameCategory|armaR|Modding|$2|$1}}") | ||
| (34 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
| {{TOC|side}} | {{TOC|side}} | ||
| == Goals of this tutorial == | |||
| In this tutorial you will learn about: | In this tutorial you will learn about: | ||
| Line 7: | Line 7: | ||
| * Preparation of units groups | * Preparation of units groups | ||
| * Creation of new factions | * Creation of new factions | ||
| * Integration of new faction into  | * Integration of new faction into [[Arma_Reforger:Game_Master|Game Master]] | ||
| * Integration of new faction into Conflict game mode | * Integration of new faction into [[Arma_Reforger:Conflict|Conflict game mode]] | ||
| {{Feature|informative|This tutorial touches quite a lot of topics and it is recommended to familiarise yourself with [[Arma_Reforger:Weapon_Modding|'''modded weapon''' ]] and [[Arma_Reforger:Car_Modding|'''modded car''' ]] tutorials.}} | |||
| {{Messagebox|Sources files for this tutorial can be found on | |||
| [https://github.com/BohemiaInteractive/Arma-Reforger-Samples/tree/main/SampleMod_NewFaction '''Arma Reforger Samples Github repository''']|📥|orange}} | |||
| == Introduction == | == Introduction == | ||
| In this tutorial, process of creating new faction is explained and as an example'' | |||
| In this tutorial, process of creating new faction is explained and as an example''''', secrets of preparing '''Sample Faction - REDFOR'' will be unveiled'''.''' | |||
| This page goes through topics like '''preparing new characters''', '''tweaking their configuration''', '''creating new groups''', preparing general '''faction configs''' & finally, '''integration into''' both '''in-game editor''' & '''Conflict''' game mode. | This page goes through topics like '''preparing new characters''', '''tweaking their configuration''', '''creating new groups''', preparing general '''faction configs''' & finally, '''integration into''' both '''in-game editor''' & '''Conflict''' game mode. | ||
| Line 23: | Line 29: | ||
| === File structure === | === File structure === | ||
| [[ | New faction requires quite elaborate structure (''based on [[Arma_Reforger:Directory_Structure]] page'') and below there is tear down of it: | ||
| [[File:armareforger-new-faction-file-structure.png|800px]] | |||
| == Character configuration == | == Character configuration == | ||
| === Retexturing existing equipment === | === Retexturing existing equipment === | ||
| * ''' | One of the first steps of creating a retextured piece of equipment is actually creating a new prefab. In this tutorial, a new '''red''' variant of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Footwear/CombatBoots_Soviet_01.et|CombatBoots_Soviet_01.et}} prefab will be created. This can be done either through: | ||
| * By dropping instance of prefab to '''World Editor''' & then making a new prefab by grabbing that instance back selected folder in '''Resource Browser''' | |||
| * '''[[Arma Reforger:Prefabs Basics#Using Inherit Prefab option|Inherit]]''' option in '''Resource Browser''' | |||
| * [[Arma Reforger:Prefabs Basics#Drag and drop method|By dropping instance of prefab to '''World Editor''' & then making a new prefab by grabbing that instance back selected folder in '''Resource Browser''']] | |||
| {{Feature|informative|In this article, '''Enfusion links''' are used. With those links it is possible to open specific resource just by simply clicking on that link. Enfusion links '''has to be manually activated in Workbench options''' (Workbench -> Options -> Workbench -> Register "enfusion://" protocol) before it can be used]}} | {{Feature|informative|In this article, [[Arma_Reforger:Resource_Manager:_Options#Register_.22enfusion:.2F.2F.22_protocol|'''Enfusion links''']] are used. With those links it is possible to open specific resource just by simply clicking on that link. Enfusion links '''has to be manually activated in Workbench options''' (Workbench -> Options -> Workbench -> Register "enfusion://" protocol) before it can be used]}} | ||
| In both cases, goal is to create  | In both cases, goal is to create '''CombatBoots_Soviet_01_red.et''' prefab inside Sample New Faction addon structure. | ||
| In comparison to other assets, character equipment is bit more complicated to retexture.  | In comparison to other assets, character equipment is bit more complicated to retexture. '''MeshObject''' component of wearable equipment is actually not being used for showing the object and instead, visuals are controlled through '''Worn Model''' & '''Item Model''' properties. One of them define model which is visible when character is '''wearing given object''' ''('''Worn Model''' property)'' and the other one is used when item is lying on a ground as an prop which can be picked up by other characters ''('''Item Model''' property).'' | ||
| Those two parameters accept both '''XOB''' models and '''prefabs''' as well.  | Those two parameters accept both '''XOB''' models and '''prefabs''' as well. In both cases, '''new materials''' can be created by for instance '''[[Arma Reforger:Data Modding Basics#Using .22Duplicate to....22 function|duplicating existing materials]]'''. In this case, {{Link|enfusion://ResourceManager/~ArmaReforger:Assets/Characters/Footwear/CombatBoots_Soviet_01/Data/CombatBoots_Soviet_01.emat|CombatBoots_Soviet_01.emat}} was duplicated to SampleMod_NewFaction addon as ''CombatBoots_Soviet_01_red.emat'' and then color was changed by simply editing '''Color''' property in that new material.{{Messagebox|'''Recommended read:''' More details about creating new material creation & some practical example can be found in [[Arma_Reforger:Weapon_Modding#New_Materials|'''Weapon Modding''']] tutorial. Keep in mind that in a lot of cases it might be necessary to use MatPBRMulti shadder, so usage of MatPBRCamo might not be an option.|📖|lightgrey}}Before proceeding further, prepare new materials | ||
| === Creating retextures using prefabs === | === Creating retextures using prefabs === | ||
| Creating '''prefabs''' for retextures is quite easy since process process is exactly same as for regular items. | Creating '''prefabs''' for retextures is quite easy since process process is exactly same as for regular items. | ||
| [[ | [[File:armareforger-new-faction-equipment-prefabs-1.png|600px]][[File:armareforger-new-faction-equipment-prefabs-2.png|600px]] | ||
| Those new prefabs should be as simple as possible and they can be created by simply dragging XOB model to '''World Editor''' view port. As a result of that action, a new '''Generic Entity''' instance with '''MeshObject''' component is created and there, assigned materials can be changed as on any other entity. Once assigned '''materials''' are adjusted, this entity can be transformed to prefab by grabbing it from '''Hierarchy''' list to desired folder in '''Resource Browser''' window. | Those new prefabs should be as simple as possible and they can be created by simply dragging XOB model to '''World Editor''' view port. As a result of that action, a new '''Generic Entity''' instance with '''MeshObject''' component is created and there, assigned materials can be changed as on any other entity. Once assigned '''materials''' are adjusted, this entity can be transformed to prefab by grabbing it from '''Hierarchy''' list to desired folder in '''Resource Browser''' window. | ||
| [[ | [[File:armareforger-new-faction-equipment-new-variant.mp4|1600px]] | ||
| === Creating retextures using overrides === | === Creating retextures using overrides === | ||
| [[ | [[File:armareforger-new-faction-overrides.png|left]] | ||
| Alternatively, as mentioned before, it is also possible to use '''Materials Override''' parameters which are located under '''Worn & Item Model parameters.''' | Alternatively, as mentioned before, it is also possible to use '''Materials Override''' parameters which are located under '''Worn & Item Model parameters.''' | ||
| In this case, it is necessary to add new element in '''Materials Override''' list and after that '''assign desired material''' to that property. If everything is done correctly, Workbench view port should show changed materials. | In this case, it is necessary to add new element in '''Materials Override''' list and after that '''assign desired material''' to that property. If everything is done correctly, Workbench view port should show changed materials. | ||
| Under the hood, engine is remaping all materials assigned to this asset in order  | Under the hood, engine is remaping all materials assigned to this asset in order specified by '''Materials Override''' list, therefore caution is recommended since it might happen that order of materials changes after some data tweak. In this case responsibility falls into user hands and '''order of the materials has to be adjusted manually by the author of mod'''! | ||
| {{Clear}} | {{Clear}} | ||
| Those steps need to be performed for '''both Worn & Item Models'''. After that is completed, those new prefabs can be assigned to those two respective fields in  | Those steps need to be performed for '''both Worn & Item Models'''. After that is completed, those new prefabs can be assigned to those two respective fields in '''BaseLoadoutClothComponent'''. | ||
| Additionally, it might be also worth to adjust '''Preview Model''' in '''SCR_UniveralInventoryStorageComponent''' > Custom Attributes > PreviewRenderAttributes, which controls how equipment is visible in inventory menu. Please note that right now this entry doesn't support material overrides and only prefabs with custom materials can be used. | Additionally, it might be also worth to adjust '''Preview Model''' in '''SCR_UniveralInventoryStorageComponent''' > Custom Attributes > PreviewRenderAttributes, which controls how equipment is visible in inventory menu. Please note that right now this entry doesn't support material overrides and only prefabs with custom materials can be used. | ||
| Line 67: | Line 77: | ||
| In this tutorial, following prefabs (''with respective item & worn variants'') were created for '''REDFOR''' faction: | In this tutorial, following prefabs (''with respective item & worn variants'') were created for '''REDFOR''' faction: | ||
| * '''CombatBoots_Soviet_01_red'''.et + ( ''CombatBoots_Soviet_01_item_red.et &  | * '''CombatBoots_Soviet_01_red'''.et + (''CombatBoots_Soviet_01_item_red.et & CombatBoots_Soviet_01_wear_red.et'') - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Footwear/CombatBoots_Soviet_01.et}} | ||
| * '''Helmet_SSh68_01_red.'''et '''+''' ( ''Helmet_SSh68_01_item_red.et &  | * '''Helmet_SSh68_01_red.'''et '''+''' (''Helmet_SSh68_01_item_red.et & Helmet_SSh68_01_wear_red.et'' ''')''' - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/HeadGear/Helmet_SSh68_01/Helmet_SSh68_01.et}} | ||
| * '''Jacket_M88_red.'''et '''+'''  | * '''Jacket_M88_red.'''et '''+''' ''(Jacket_M88_item_red.et & Jacket_M88_wear_red.et)'' - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Uniforms/Jacket_M88.et}} | ||
| * '''Pants_M88_red.'''et + ( ''Pants_M88_item_red.et &  | * '''Pants_M88_red.'''et + (''Pants_M88_item_red.et & Pants_M88_wear_red.et'') - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Uniforms/Pants_M88.et}} | ||
| * '''Vest_Lifchik_red.'''et '''+'''  | * '''Vest_Lifchik_red.'''et '''+''' ''(Vest_Lifchik_item_red.et & Vest_Lifchik_wear_red.et)'' - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Vests/Vest_Lifchik/Vest_Lifchik.et}} | ||
| * '''Vest_Lifchik_GL_red'''.et + ( ''Vest_Lifchik_GrenadeBelt_item_red.et &  | * '''Vest_Lifchik_GL_red'''.et + (''Vest_Lifchik_GrenadeBelt_item_red.et & Vest_Lifchik_GrenadeBelt_wear_red.et '') - retexture of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Vests/Vest_Lifchik/Vest_Lifchik_GL.et}} | ||
| This set should be enough to have truly red faction. | This set should be enough to have truly red faction. | ||
| {{Feature|warning|'''Materials Override''' tend to be less reliable than prefab method so its recommend to use '''Prefabs''' for retextures.}} | |||
| == Creating new characters prefabs == | == Creating new characters prefabs == | ||
| === Preparing base character === | === Preparing base character === | ||
| Before proceeding with creating specific characters types like rifleman, medic or driver, it is generally a good practice to establish a base prefab, which will be used through the faction. Such prefab can contain common configuration like: | Before proceeding with creating specific characters types like rifleman, medic or driver, it is generally a good practice to establish a base prefab, which will be used through the faction. Such prefab can contain common configuration like: | ||
| Line 86: | Line 100: | ||
| * Common parts of equipment (jacket, pants, boots and accessories) | * Common parts of equipment (jacket, pants, boots and accessories) | ||
| In this example,  | In this example, {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Core/Character_Base.et}} prefab is used to create '''Character_SampleFactionREDFOR_Base'''.et - a base for all REDFOR faction characters. Inheriting from {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Core/Character_Base.et}} prefab should provide a solid base with all necessary components in a state, where only minor adjustments are necessary. | ||
| === Configuring new characters === | === Configuring new characters === | ||
| Below there is a table with most essential components which will be adjusted in further steps | Below there is a table with most essential components which will be adjusted in further steps | ||
| {| class="wikitable" | {| class="wikitable" | ||
| | '''SCR_CommunicationSoundComponent'''   | | '''SCR_CommunicationSoundComponent''' | ||
| |Defines '''radio protocol''' which will be used by this character | | Defines '''radio protocol''' which will be used by this character | ||
| |- | |- | ||
| |  | | '''SCR_CharacterInventoryStorageComponent''' | ||
| |Main component which controls character inventory   | | Main component which controls character inventory | ||
| |- | |- | ||
| | '''CharacterIdentityComponent'''   | | '''CharacterIdentityComponent''' | ||
| |This component holds information about identity of  | | This component holds information about identity of character like '''head''', '''base body''' & '''voice type''' | ||
| |- | |- | ||
| | '''BaseWeaponManagerComponent''' | |||
| | This component controls which weapon is equipped by default | |||
| |- | |- | ||
| | '''BaseLoadoutManagerComponent'''   | | '''BaseLoadoutManagerComponent''' | ||
| |Defines character '''loadout''' like '''uniform, vest or harness, headgear, etc''' | | Defines character '''loadout''' like '''uniform, vest or harness, headgear, etc''' | ||
| |- | |- | ||
| | '''FactionAffiliationComponent'''   | | '''FactionAffiliationComponent''' | ||
| |Defines to which '''faction''' this unit belongs to. | | Defines to which '''faction''' this unit belongs to. | ||
| |- | |- | ||
| | '''SCR_EditableCharacterComponent'''   | | '''SCR_EditableCharacterComponent''' | ||
| |This component contains in-game related configuration like '''preview pictures, attributes, display name or budget''' | | This component contains in-game related configuration like '''preview pictures, attributes, display name or budget''' | ||
| |- | |- | ||
| | '''SCR_InventoryStorageManagerComponent'''   | | '''SCR_InventoryStorageManagerComponent''' | ||
| |This components controls what items are preassigned to character & in which part of equipment they should be stored in | | This components controls what items are preassigned to character & in which part of equipment they should be stored in | ||
| |- | |- | ||
| | '''CharacterWeaponSlotComponent''' | |||
| | Those components are used to control how many weapons (& what types of weapons) can have, | |||
| |- | |- | ||
| | '''CharacterGrenadeSlotComponent''' | |||
| | This slot controls hand grenade logic | |||
| |} | |} | ||
| ==== Changing used radio protocol ==== | ==== Changing used radio protocol ==== | ||
| [[File:armareforger-new-faction-character-protocol.png|right]] | |||
| Starting with '''SCR_CommunicationSoundComponent''', a default radio protocol will be changed by adjusting assigned '''audio configuration project files''' in '''Filenames''' property''''''. In this tutorial, default, English radio protocol will be replaced with Russian variant, which uses '''_RU suffix.''' | |||
| {{Clear}} | {{Clear}} | ||
| ==== Changing character identity ==== | ==== Changing character identity ==== | ||
| [[ | [[File:armareforger-new-faction-character-identity.png|right]] | ||
| Identity of character defines their '''voice variant'''  | Identity of character defines their '''voice variant''' ''(Voice parameter)'', visual '''appearance''' (''Head & Body parameters'') & '''name -''' all that configuration is stored in '''CharacterIdentityComponent'''. Unless working with custom model, there is no need to touch '''Body Meshes Config''', since default values provide optimal configuration for wounded & healthy character materials. | ||
| By default, '''character identity will be randomly generated using parameters stored in faction config''' (this described later on that page) and values used in this component will be used only if '''Override''' property is checked. | By default, '''character identity will be randomly generated using parameters stored in faction config''' (this described later on that page) and values used in this component will be used only if '''Override''' property is checked. | ||
| {{Clear}} | {{Clear}} | ||
| ==== Changing character faction ==== | ==== Changing character faction ==== | ||
| [[ | [[File:armareforger-new-faction-character-faction.png|right]] | ||
| Character faction affiliation determines faction to which unit belongs to. Unlike in previous Arma titles made on Real Virtuality engine, characters in Reforger are no longer divided into few hardcoded sides but instead, faction system is used. In this setup, it is possible to setup alliances between factions in more flexible way depending on the mission creator needs. | Character faction affiliation determines faction to which unit belongs to. Unlike in previous Arma titles made on Real Virtuality engine, characters in Reforger are no longer divided into few hardcoded sides but instead, faction system is used. In this setup, it is possible to setup alliances between factions in more flexible way depending on the mission creator needs. | ||
| Faction affiliation property is stored in  | Faction affiliation property is stored in '''FactionAffiliationComponent'''. This is fairly simple component which accepts name of faction provided as string in '''Faction affiliation''' parameter. Even without faction config ready (which creation process will be described in later part of this document), it is possible to write name of desired faction - in this case it is '''SampleFactionREDFOR -''' and create rest of configuration later. | ||
| {{Clear} | |||
| {{Clear}} | |||
| ==== Changing character outfit ==== | ==== Changing character outfit ==== | ||
| Main character equipment configuration is stored in  | Main character equipment configuration is stored in '''BaseLoadoutManagerComponent'''. In this component, it is possible to add '''slots''', which determine what kind of prefabs are attached to the character, their type (''used by inventory system)'' and what part of base body should be hidden when selected piece of equipment is worn - both to save performance and avoid mesh clipping. | ||
| '''Character_Base'''  | '''Character_Base''' prefab contains six major slots which are currently handled by inventory system and in most cases there is no need to add more of them. Below is list of all currently supported slots: | ||
| * '''Helmet''' | * '''Helmet''' | ||
| Line 153: | Line 170: | ||
| Slots inherited from '''Character_Base''' contain properly defined '''Name, Area & Meshes To Hide''' properties so in this case, only thing to do is changing '''prefab''' (''through '''Prefab''' property'' ''')''' which is used on selected slots. | Slots inherited from '''Character_Base''' contain properly defined '''Name, Area & Meshes To Hide''' properties so in this case, only thing to do is changing '''prefab''' (''through '''Prefab''' property'' ''')''' which is used on selected slots. | ||
| In this tutorial all '''REDFOR''' faction characters are using same '''Helmet''', '''Jacket''', '''Pants''' & '''Boots | In this tutorial all '''REDFOR''' faction characters are using same '''Helmet''', '''Jacket''', '''Pants''' & '''Boots''', so it's safe to proceed further and assign previously created '''Helmet_SSh68_01_red.et''', '''Jacket_M88_red.et''', '''Pants_M88_red.et''', '''CombatBoots_Soviet_01_red.et''' to their respective slots in '''SampleFactionREDFOR_Base''' prefab. '''Vest & backpack''' will be assigned in later part of this tutorial to appropriate character classes. | ||
| [[ | [[File:armareforger-new-faction-character-overview.png]][[File:armareforger-new-faction-character-overview-components.png|500px]] | ||
| ==== Adding items to character storage ==== | ==== Adding items to character storage ==== | ||
| [[ | [[File:armareforger-new-faction-character-storage-items.png|right]] | ||
| Once character have basic clothing assigned, it is possible to start linking some key items to REDFOR faction base prefab. Items are linked via '''SCR_InventoryStorageManagerComponent''' and with this component it is possible to precisely select where given items are stored. | Once character have basic clothing assigned, it is possible to start linking some key items to REDFOR faction base prefab. Items are linked via '''SCR_InventoryStorageManagerComponent''' and with this component it is possible to precisely select where given items are stored. | ||
| Goal here would be equipping '''Character_SampleFactionREDFOR_Base ''' with single '''first aid kit to jacket''' & few other elementary items like '''compass, map & radio''' to character '''pants'''. | Goal here would be equipping '''Character_SampleFactionREDFOR_Base ''' with single '''first aid kit to jacket''' & few other elementary items like '''compass, map & radio''' to character '''pants'''. | ||
| By default, '''Initial Inventory Items''' array is empty and new elements have to be added via '''plus button'''  | By default, '''Initial Inventory Items''' array is empty and new elements have to be added via '''plus button''' . Each element in the array represents a single container which is linked through '''Target Storage''' property to one of the prefabs attached to character. Jacket & pants are two separate containers so two new '''ItemsInitConfigurationItem''' elements have to be created in '''Initial Inventory Items''' array. | ||
| Once that is done, it is possible to change  | Once that is done, it is possible to change '''Target Storage''' of those newly created '''Initial Inventory Items''' elements. Starting with first element, '''Prefabs/Characters/Uniforms/Jacket_M88_red.et''' was selected from '''Target Storage''' drop-down menu of first entry of '''Initial Inventory Items''' array. This mean that '''Jacket_M88_red''' that all prefabs listed in '''Prefabs to Spawn''' array will be created in this container. New elements in '''Prefabs To Spawn''' array can be added via '''plus button''' and in this case only single new entry has to be added. After that is complete, '''first aid kit''' ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Medicine/FieldDressing_USSR_01.et}}) prefab can be assigned to that newly created slot. | ||
| Exactly same procedure can be used to add map (  | Exactly same procedure can be used to add map ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Equipment/Maps/PaperMap_01_folded.et}}), compass ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Equipment/Compass/Compass_Adrianov.et}}), flash light ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Equipment/Flashlights/Flashlight_Soviet_01.et}}) & radio ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Equipment/Radios/Radio_R148.et}}) to pants. In this case '''Prefabs/Characters/Uniforms/Jacket_M88_red.et''' should be used as '''Target Storage''' and '''Prefabs To Spawn''' array should consist from 3 elements. | ||
| {{Clear} | {{Clear}} | ||
| === Creating character variants === | === Creating character variants === | ||
| ==== Creating inherited variants ==== | ==== Creating inherited variants ==== | ||
| [[ | [[File:armareforger-new-faction-character-equipment-in.png|thumb|200px|right]] | ||
| With base character ready, it is time to create actual units which can be used in various game modes or in-game editor. Using  ''' | With base character ready, it is time to create actual units which can be used in various game modes or in-game editor. Using  '''Inherit''' option in '''Resource Browser''', following new prefabs were prepared: | ||
| * '''Unarmed''' - ''Character_SampleFactionREDFOR_Unarmed.et'' | * '''Unarmed''' - ''Character_SampleFactionREDFOR_Unarmed.et'' | ||
| Line 181: | Line 198: | ||
| * '''Medic''' - ''Character_SampleFactionREDFOR_Medic.et'' | * '''Medic''' - ''Character_SampleFactionREDFOR_Medic.et'' | ||
| * '''Machine Gunner''' - ''Character_SampleFactionREDFOR_MG.et'' | * '''Machine Gunner''' - ''Character_SampleFactionREDFOR_MG.et'' | ||
| * '''Squad Leader''' - ''Character_SampleFactionREDFOR_SL.et''   | * '''Squad Leader''' - ''Character_SampleFactionREDFOR_SL.et'' | ||
| At this point, all those prefabs have identical equipment and their individual equipment can be tweaked. In case of '''Unarmed''' character, it can be left as it is, since equipment from base class should fit that role. Rest of the classes require some additional work and in this tutorial whole process of adding weapon & additional equipment to character will be explained on '''Machine Gunner''' character. | At this point, all those prefabs have identical equipment and their individual equipment can be tweaked. In case of '''Unarmed''' character, it can be left as it is, since equipment from base class should fit that role. Rest of the classes require some additional work and in this tutorial whole process of adding weapon & additional equipment to character will be explained on '''Machine Gunner''' character. | ||
| First thing in that process is adding additional equipment - in this case it is harness with pouch for machine gun magazine & backpack. Machine gunner harness (  | First thing in that process is adding additional equipment - in this case it is harness with pouch for machine gun magazine & backpack. Machine gunner harness ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Vests/Vest_SovietHarness/Variants/Vest_SovietHarness_MG.et}}) has to be assigned to '''Vest''' slot & backpack for extra magazines ({{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Items/Equipment/Backpacks/Backpack_Veshmeshok.et}}) has to be assigned to '''Backpack''' slot. | ||
| {{Clear}} | {{Clear}} | ||
| ==== Changing weapons ==== | ==== Changing weapons ==== | ||
| [[ | [[File:armareforger-new-faction-character-weapons.png|left]] | ||
| Characters inheriting from  | Characters inheriting from {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Core/Character_Base.et}} are using '''4 weapon slots'''. | ||
| Three of them are using '''CharacterWeaponSlotComponent''', where two of those are used '''for primary weapons''' like rifles or launchers, one is used for '''secondary armament''' like handguns and single '''CharacterGrenadeSlotComponent''' is used, as name would suggest, for throw able items like '''hand grenades'''. | |||
| '''Machine Gunner''' class prepared in this tutorial is supposed to have following loadout: | '''Machine Gunner''' class prepared in this tutorial is supposed to have following loadout: | ||
| * PKM machine gun on first primary slot (  | * PKM machine gun on first primary slot ('''MG_PKM.et''') | ||
| * Makarov handgun on secondary slot (  | * Makarov handgun on secondary slot ('''Handgun_Makarov.et''') | ||
| * RGD-5 grenade on grenade slot (  | * RGD-5 grenade on grenade slot ('''Grenade_RGD5.et)''' | ||
| Starting with '''PKM machine gun''', first thing to do is locating correct  | Starting with '''PKM machine gun''', first thing to do is locating correct '''CharacterWeaponSlotComponent'''. Since goal is to have that PKM machine gun in first primary slot, values of '''Weapon Slot Type & Weapon Slot Index''' has to be verified. In this case, component with '''Weapon Slot Type''' should have value " '''''primary'''"'' and '''Weapon Slot Index''' should be set to '''0.''' | ||
| Once that component is located, the only thing left to do is changing assigned prefab in '''Weapon Template''' by either clicking on '''select button''' or by dragging & dropping  | Once that component is located, the only thing left to do is changing assigned prefab in '''Weapon Template''' by either clicking on '''select button''' or by dragging & dropping {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Weapons/MachineGuns/PKM/MG_PKM.et}} prefab on '''Weapon Template''' property. | ||
| Next on the list is '''PM handgun | Next on the list is '''PM handgun''', which should be assigned to '''CharacterWeaponSlotComponent''' with '''Weapon Slot Type''' set to " '''''secondary'''"'' and '''Weapon Slot Index''' set to '''2'''. | ||
| Same as with PKM machine gun, '''Weapon Template''' property has to be modified so {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Weapons/Handguns/PM/Handgun_PM.et}} is assigned to that field. | |||
| Grenades follow exactly same logic and in this case its even bit easier, since there is only one '''CharacterGrenadeSlotComponent '''. After locating that component, Grenade_RGD5.et prefab can be assigned to '''Weapon Template''' property. | |||
| {{Clear}} | {{Clear}} | ||
| ==== Adding magazines to loadout ==== | ==== Adding magazines to loadout ==== | ||
| [[ | [[File:armareforger-new-faction-character-loadout.png|right]] | ||
| In principle, procedure of adding magazines to loadout is same as for items. In case of '''machine gunner''', additional complication is fact that there are more prefabs to choose from due to additional loadout elements like harness and backpack. Equipment prefabs can consist of multiple child prefabs and in case of  | In principle, procedure of adding magazines to loadout is same as for items. In case of '''machine gunner''', additional complication is fact that there are more prefabs to choose from due to additional loadout elements like harness and backpack. Equipment prefabs can consist of multiple child prefabs and in case of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Vests/Vest_SovietHarness/Variants/Vest_SovietHarness_MG.et}}, magazine pouch is a separate item attached to the harness itself. | ||
| In this example, one magazine is added to '''Prefabs/Items/Equipment/Accessories/Pouch_Soviet_100rnd_PKM/Pouch_Soviet_100rnd_PKM.et -''' which is part of {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Characters/Vests/Vest_SovietHarness/Variants/Vest_SovietHarness_MG.et}} prefab - and two magazines goes to backpack '''Prefabs/Items/Equipment/Backpacks/Backpack_Veshmeshok.et'''. Additionally, one smoke grenade was added to backpack | |||
| {{Clear}} | {{Clear}} | ||
| == Vehicle configuration == | == Vehicle configuration == | ||
| === Creating vehicle variants === | === Creating vehicle variants === | ||
| Creating vehicle variants is fairly simple as it can be done in two steps: | Creating vehicle variants is fairly simple as it can be done in two steps: | ||
| # Creating inherited variant ( either through  | # Creating inherited variant (either through ''' [[Arma Reforger:Data Modding Basics#Using .22Inherit in....22 function|Inherit in]]''' action in '''Resource Browser''' in '''World Editor''' view port itself) of selected vehicle prefab in target addon | ||
| # Changing '''Faction affiliation''' parameter in  | # Changing '''Faction affiliation''' parameter in '''FactionAffiliationComponent''' | ||
| [[ | [[File:armareforger-new-faction-vehicle-faction.png]] | ||
| Even if materials of vehicles are not changed, changing faction affiliation is quite important for AI systems and some of the game modes, so those extra faction specific prefabs are sort of mandatory if its planned to equip new faction with some vehicles. | Even if materials of vehicles are not changed, changing faction affiliation is quite important for AI systems and some of the game modes, so those extra faction specific prefabs are sort of mandatory if its planned to equip new faction with some vehicles. | ||
| {{Feature|informative|Please note that this page is not describing how to create vehicle retextures itself. For more information go to [[Arma_Reforger:Vehicle_Modding#Changing_Multi_Material_base_color|Vehicle Modding]] page.}} | {{Feature|informative|Please note that this page is not describing how to create vehicle retextures itself. For more information go to [[Arma_Reforger:Vehicle_Modding#Changing_Multi_Material_base_color|Vehicle Modding]] page.}} | ||
| == Groups == | == Groups == | ||
| === Creating groups === | === Creating groups === | ||
| Similar as with characters, when preparing set of new groups for a faction, it is also good habit to create base prefab for all groups so the first step here will be creating  | It is recommended to create new groups by inheriting from {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/AI/Groups/Group_Base.et}} prefab which has all necessary components already in place. Procedure for it is same as for any other prefabs and it is possible to either use '''[[Arma Reforger:Data Modding Basics#Using .22Inherit in....22 function|Inherit in Addon]]''' option in '''Resource Browser''' or go through [[Arma Reforger:Prefabs Basics#Drag and drop method|'''World Editor''' view port flow]]. | ||
| Similar as with characters, when preparing set of new groups for a faction, it is also good habit to create base prefab for all groups so the first step here will be creating '''Group_SampleFactionREDFOR_Base'''.et which is inheriting from '''Group_Base'''.et . After that, rest of the groups can be created using previously prepared '''Group_SampleFactionREDFOR_Base'''.et prefab as base. In this tutorial, following small unit rooster is prepared: | |||
| * '''Group_SampleFactionREDFOR_RifleSquad'''.et | * '''Group_SampleFactionREDFOR_RifleSquad'''.et | ||
| Line 238: | Line 263: | ||
| '''Basic group setup''' | '''Basic group setup''' | ||
| Starting with adjusting  | Starting with adjusting '''Group_SampleFactionREDFOR_Base.et''', adjustment has to be performed in properties located directly in entity configuration. | ||
| First step towards having a working group prefab will be modifying '''Faction''' property located in '''Groups''' tab & filling into that property name of target faction - '''SampleFactionREDFOR''' in this case. | First step towards having a working group prefab will be modifying '''Faction''' property located in '''Groups''' tab & filling into that property name of target faction - '''SampleFactionREDFOR''' in this case. | ||
| [[ | [[File:armareforger-new-faction-group-composition.png]] | ||
| Next on the list is adjusting of  | Next on the list is adjusting of '''SCR_GroupIdentityComponent''' and setting there '''identity''' used by all '''SampleFactionREDFOR''' unit. This component is purely used for UI representation of group in game and it affects what kind of icon is used in both 3D interface and on 2D map. Changing '''Identity''' property to '''OPFOR''' will be result in hostile forces markers according to NATO APP-6 specification. Rest of those parameters like '''Icons''' or '''Amplifiers''' can be changed per specific group and is described in detail in later part of this tutorial. | ||
| '''Changing group composition''' | '''Changing group composition''' | ||
| After basics are done, it is time to move forward and start editing actual composition of groups. Composition of groups is set directly in entity properties and is controlled through '''Unit Prefab Slot''' parameter in '''Group Members''' tab. Over there it is possible to simple add new groups slots via '''plus button'''  | After basics are done, it is time to move forward and start editing actual composition of groups. Composition of groups is set directly in entity properties and is controlled through '''Unit Prefab Slot''' parameter in '''Group Members''' tab. Over there it is possible to simple add new groups slots via '''plus button''' and then assign character prefabs to them. | ||
| [[File:armareforger-new-faction-group-overview.png]] | |||
| == Factions == | == Factions == | ||
| Line 257: | Line 283: | ||
| ==== Basic configuration ==== | ==== Basic configuration ==== | ||
| New faction configs can be only created either by '''duplicating''' (via  | New faction configs can be only created either by '''duplicating''' (via '''''Dup[[Arma Reforger:Data Modding Basics#Using .22Duplicate to....22 function|licate in "addon name"]]''''' ''option'') one of the existing configs one or by '''inheriting from existing faction''' through''' ''' '''[[Arma Reforger:Data Modding Basics#Using .22Inherit in....22 function|Inherit in "''addon name"'']]''' option. | ||
| [[ | [[File:armareforger-new-faction-inherit-config.png|600px]] | ||
| First of all, it is necessary to get configs which we want to duplicate or inherit from in the addon itself. To do so, first we navigate to Configs→ Factions folder and there, it is possible to use  | First of all, it is necessary to get configs which we want to duplicate or inherit from in the addon itself. To do so, first we navigate to Configs→ Factions folder and there, it is possible to use '''[[Arma Reforger:Data Modding Basics#Using .22Override in....22 function|Override in]]''' [[Arma Reforger:Data Modding Basics#Using .22Override in....22 function|'''addon''']] functionality located in context menu of '''Resource Browser'''. '''OPFOR.conf''' (both of them are located in Configs/Faction folder) can be used for inheritance and '''USSR.conf''' for duplication. | ||
| Retail version of game has packed data and its content locked - that's why such workaround has to applied. In all other cases this step can be skipped | Retail version of game has packed data and its content locked - that's why such workaround has to applied. In all other cases this step can be skipped | ||
| Next step is creating either inherited config (in case  | Next step is creating either inherited config (in case '''OPFOR.conf''' was copied) through '''''' '''Inherit''' option or creating duplicated file via '''Duplicate''' option if '''USSR.conf''' was transferred to addon. In both cases, a new config will be ready to be filled with actual data relevant to new faction. | ||
| {| class="wikitable" | {| class="wikitable" | ||
| |'''Faction Key''' | | '''Faction Key''' | ||
| |Unique identifier of the faction that was filled in i.e.  | | Unique identifier of the faction that was filled in i.e. '''FactionAffiliationComponent''' | ||
| |''SampleFactionREDFOR'' | | ''SampleFactionREDFOR'' | ||
| |- | |||
| | '''Faction Color''' | |||
| | This option determines which color will be used to represent this faction in various UIs like in-game editor or game modes | |||
| | ''244,5,6,255'' | |||
| |- | |||
| | '''Name''' | |||
| | Display name of faction | |||
| | ''Sample Faction - REDFOR'' | |||
| |- | |||
| | '''Description''' | |||
| | Description to be displayed in players UI | |||
| | | |||
| |- | |||
| | '''Icon''' | |||
| | Icon representing this faction in players UI. Recommended size: 128x128px | |||
| | ''flag_red_ca.edds'' | |||
| |- | |||
| | '''Name Upper''' | |||
| | Display name of faction in upper case | |||
| | ''SAMPLE NEW FACTION - REDFOR'' | |||
| |- | |||
| | '''Identity of soldiers''' | |||
| | | |||
| | {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Identities/FactionIdentity_USSR.conf}} | |||
| |- | |- | ||
| |''' | | '''Is Playable''' | ||
| | | | Controls if the faction will appear in players respawn menu | ||
| | | | True | ||
| |- | |- | ||
| |''' | | '''Faction Flag''' | ||
| | | | Flag representing this faction in players UI. Recommended size: 800x400px. Same texture as for '''Icon''' can be used | ||
| |'' | | ''flag_red_ca.edds'' | ||
| |- | |- | ||
| | '''Faction Flag Material''' | |||
| |  | | Faction flag material - used on flag poles in f.e. Conflict | ||
| | | |||
| |- | |- | ||
| |''' | | '''Faction Label''' | ||
| | | | Default faction loadout - this option is currently used (& defined) in Conflict only | ||
| | | | | ||
| |- | |- | ||
| |''' | | '''Friendly To Self''' | ||
| | | | Are units in this faction friendly to itself? Used in Death Match scenarios | ||
| | | | | ||
| |- | |- | ||
| | '''Friendly Factions Ids''' | |||
| |  | | List of friendly Faction Keys | ||
| |  | | | ||
| |- | |- | ||
| | '''Callsign Info''' | |||
| |  | | This class controls group callsigns available to this faction. Used in Conflict & in-game editor | ||
| |  | | {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Callsigns/Callsigns_USSR.conf}} | ||
| |- | |- | ||
| |''' | | '''Ranks''' | ||
| | | | Military ranks available to given faction. Can be used to give custom, localised titles per faction | ||
| | | | | ||
| |- | |- | ||
| | '''Entity Catalogs''' | |||
| |  | | List of [[Arma Reforger:Entity Catalog|'''Entity Catalogs''']] used by this faction. Determines what is i.e. available in Arsenal crates of selected faction | ||
| | | |||
| |- | |- | ||
| | '''Group Flags''' | |||
| |  | | Flag icon for group | ||
| |  | | | ||
| |- | |- | ||
| |  | | '''Group Flags Image Set''' | ||
| |  | | Flag imageset for groups of this faction | ||
| |  | | | ||
| |}   | |- | ||
| | '''Flag Names''' | |||
| | Markers names available in Group Flags Image Set | |||
| | | |||
| |- | |||
| | '''Base Callsigns''' | |||
| | Call signs of bases. Used i.e. in Conflict for randomised bases names. | |||
| | | |||
| |} | |||
| [[ | [[File:armareforger-new-faction-config-faction.png]] | ||
| {{Feature|warning|Respawn system requires [[Arma_Reforger:Mod_Localisation|localised string ]] in '''Name''' field - without that you will be greeted with message stating that are no spawn points available. }} | |||
| ==== Faction identity ==== | ==== Faction identity ==== | ||
| In case of '''Identity of soldiers'''  | In case of '''Identity of soldiers''' and '''Callsign Info''', it is possible to use already existing configs, which can serve as a templates. Here, '''SampleFactionREDFOR''' is going to use {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Identities/FactionIdentity_USSR.conf}} and {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Callsigns/Callsigns_USSR.conf}}. This can be achieved by '''drag & dropping those config files''' on respective fields: | ||
| *  | * {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Identities/FactionIdentity_USSR.conf}} (''Configs/Identities'') is assigned to '''Identity of soldiers''' parameter | ||
| *  | * {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Callsigns/Callsigns_USSR.conf}} (''Configs/Callsigns'') is assigned to '''Callsign Info''' property | ||
| [[File:armareforger-new-faction-assign-identity.gif]] | |||
| == Integration with in-game editor == | == Integration with in-game editor == | ||
| Line 332: | Line 393: | ||
| ==== Adding new faction label ==== | ==== Adding new faction label ==== | ||
| All labels usable by in-game editor are defined in '''EEditableEntityLabel''' enumerator. New entries can be added to it by using '''modded''' keyword. To do so, a new script file have to be created and in this tutorial  | All labels usable by in-game editor are defined in '''EEditableEntityLabel''' enumerator. New entries can be added to it by using '''[[Arma Reforger:Scripting: Keywords#modded|modded]]''' keyword. To do so, a '''new script''' '''file''' '''with''' '''unique name''' (you can use [[Scripting Tags|mod tag]] as prefix) have to be created and in this tutorial '''EEditableEntityLabel.c''' file was created in ''Scripts\Game\Editor\Enums\Modded'' folder. Afterwards, adding new labels is as simple as adding new '''all caps entry''' & assigning to it a '''number.''' | ||
| < | <enforce> | ||
| modded enum EEditableEntityLabel | modded enum EEditableEntityLabel | ||
| { | { | ||
| 	FACTION_REDFOR =  | 	FACTION_REDFOR = 1653989487, | ||
| 	FACTION_BLUFOR =  | 	FACTION_BLUFOR = 1653989182, | ||
| 	FACTION_GREENFOR =  | 	FACTION_GREENFOR = 1691580533 | ||
| } | } | ||
| </ | </enforce> | ||
| Once that is done, scripts can be recompiled and new label should be available in drop down menu of various in-game editor properties. | Once that is done, scripts can be recompiled and new label should be available in drop down menu of various in-game editor properties. | ||
| {{Feature|warning|To avoid duplicated enum values, it is necessary to use some '''large random number'''. It is also possible to use current [https://en.wikipedia.org/wiki/Unix_time Unix time] to reduce likeness of enum values clash.}} | {{Feature|warning|To avoid duplicated enum values, it is necessary to use some '''large random number'''. It is also possible to use current [https://en.wikipedia.org/wiki/Unix_time Unix time] to reduce likeness of enum values clash.}}{{Messagebox|'''Recommended read''': You can learn more about script modding on [[Arma_Reforger:Scripting_Modding|'''Script Modding''']] page|📖|lightgrey}} | ||
| ==== Adding new faction to Editable Entity Core ==== | ==== Adding new faction to Editable Entity Core ==== | ||
| Once there is a label available, it is possible to | Once there is a label available, it is possible to | ||
| # Use  | # Use '''Override in addon''' function on {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Core/EditableEntityCore.conf}} located in ''Configs/Core'' folder | ||
| # Add new entry to '''Entity Labels''' array. Info part is using typical '''SCR_UIInfo''' layout | # Add new entry to '''Entity Labels''' array. Info part is using typical '''SCR_UIInfo''' layout | ||
| {| class="wikitable" | {| class="wikitable" | ||
| |Name | | Name | ||
| |Display name of faction | | Display name of faction | ||
| |''REDFOR'' | | ''REDFOR'' | ||
| |- | |- | ||
| | Description | |||
| | Description to be displayed in players UI | |||
| | | |||
| |- | |- | ||
| | Icon | |||
| | Icon representing this faction in players UI. Recommended size: 64x64px | |||
| | ''flag_red._ca.edds'' | |||
| |- | |- | ||
| | Icon Set Name | |||
| | - | |||
| | | |||
| |- | |- | ||
| |Order | | Order | ||
| |Integer used to manually modify order of label. Labels with higher numbers are listed first | | Integer used to manually modify order of label. Labels with higher numbers are listed first | ||
| | | | | ||
| |- | |- | ||
| |Label Type | | Label Type | ||
| |Label from EEditableEntityLabel enum which should be evaluated | | Label from EEditableEntityLabel enum which should be evaluated | ||
| |''FACTION_REDFOR'' | | ''FACTION_REDFOR'' | ||
| |- | |- | ||
| |Label Group Type | | Label Group Type | ||
| |Type of label - is it faction, trait, vehicle? | | Type of label - is it faction, trait, vehicle? | ||
| |''FACTION'' | | ''FACTION'' | ||
| |- | |- | ||
| |Filter Enabled | | Filter Enabled | ||
| | | | | ||
| |''True'' | | ''True'' | ||
| |} | |} | ||
| === Registering characters, groups & vehicles === | === Registering characters, groups & vehicles === | ||
| Detailed instructions on how to add assets to in-game editor can be found on  | |||
| Detailed instructions on how to add assets to in-game editor can be found on [[Arma Reforger:Asset Browser Mod Integration|'''Asset Browser Mod Integration''']] page and it is highly recommended to make yourself familiar with before proceeding anywhere further. Below are some general notes on how the process was performed for '''SampleFactionREDFOR''' related assets. | |||
| ==== Adjusting generators configs ==== | ==== Adjusting generators configs ==== | ||
|  '''Register Placeable Entities''' plugin is using  | Before registering new assets, it is necessary to make some adjustments in config, so  '''Register Placeable Entities''' plugin can work as intended. This plugin is using '''EditablePrefabsConfig.conf''' to run some rules which populate register of prefabs. This config links to few more sub configs and in case of '''Characters''' & '''Vehicles''', '''EditablePrefabsComponent_EditableEntity.conf''' is used to determine faction label. | ||
| '''EditablePrefabsComponent_EditableEntity.conf''' is used to determine faction label.   | |||
| [[ | [[File:armareforger-new-faction-generator-config.png|center]] | ||
| {{Clear}} | {{Clear}} | ||
| New rule can be added to  | New rule can be added to '''EditablePrefabsComponent_EditableEntity.conf''' in few steps described below: | ||
| # Use  | # Use '''[[Arma Reforger:Data Modding Basics#Using .22Override in....22 function|Override in]]''' [[Arma Reforger:Data Modding Basics#Using .22Override in....22 function|'''addon''']] function on '''EditablePrefabsComponent_EditableEntity.conf ''' located in ''Configs/Workbench/EditablePrefabs'' folder | ||
| # Add  | # Add '''EditablePrefabsLabel_Faction''' entry to '''Entity Label Rules''' array | ||
| # Select '''FACTION_REDFOR''' in '''Label''' drop down menu | # Select '''FACTION_REDFOR''' in '''Label''' drop down menu | ||
| # Adjust '''Faction To Check''' parameter by typing name of faction: '''SampleFactionREDFOR''' (it should be same string as in '''Faction affiliation''' parameter in  | # Adjust '''Faction To Check''' parameter by typing name of faction: '''SampleFactionREDFOR''' (it should be same string as in '''Faction affiliation''' parameter in '''FactionAffiliationComponent''' of characters or units) | ||
| Once those steps are complete, it is important to save all changes through Ctrl+S shortcut. In some rare cases changes applied to that config might need full restart of the Workbench. | Once those steps are complete, it is important to save all changes through Ctrl+S shortcut. In some rare cases changes applied to that config might need full restart of the Workbench. | ||
| ==== Adding assets to register ==== | ==== Adding assets to register ==== | ||
| After  | After '''EditablePrefabsComponent_EditableEntity.conf ''' is adjusted, it is time to move forward and start t | ||
| # Create new config files using '''SCR_PlaceableEntitiesRegistry''' class for: | # Create new config files using '''SCR_PlaceableEntitiesRegistry''' class for: | ||
| ## '''Characters ('''  | ## '''Characters (''' ''Characters_SampleFactionREDFOR.conf'' ''')''' | ||
| ## '''Groups ('''  | ## '''Groups (''' ''Groups_SampleFaction.conf'' ''')''' | ||
| ## '''Vehicles''' (  | ## '''Vehicles''' (''Vehicles_SampleFaction.conf'') | ||
| # Adjust '''Addon''' parameter in all those configs so it matches target addon (''SampleMod_NewFaction)'' | # Adjust '''Addon''' parameter in all those configs so it matches target addon (''SampleMod_NewFaction)'' | ||
| # Adjust '''Source Directory''' to match location of the prefabs | # Adjust '''Source Directory''' to match location of the prefabs | ||
| [[ | [[File:armareforger-new-faction-register-assets.png|center]] | ||
| {{Clear}} | {{Clear}} | ||
| Once those steps are completed, it is now possible to use  '''Register Placeable Entities''' plugin on all assets which should be available in in-game editor. This action should both generate '''placeholder images''' for assets previews & '''adjust''' '''Auto''' ''' | Once those steps are completed, it is now possible to use  '''Register Placeable Entities''' plugin on all assets which should be available in in-game editor. To do so, select in '''Resource Browser''' prefabs which you want to register and then navigate to '''Plugins -> In-game editor''' section in top bar and click on '''Register Placeable Entities'''. In new pop up window select config for assets which you want to register (i.e. if you have characters selected, select ''Characters_SampleFactionREDFOR.conf'') and click on '''Run''' button. | ||
| This action should both generate '''placeholder images''' for assets previews & '''adjust''' '''Auto''' '''Labels''' assigned in one of the respective components like '''SCR_EditableCharacterComponent, SCR_EditableVehicleComponent ''' or '''SCR_EditableGroupComponent.''' | |||
| [[File:armareforger-new-faction-editable-components.png|center]] | |||
| {{Clear}} | {{Clear}} | ||
| ===== Adjusting editable prefabs configuration ===== | ===== Adjusting editable prefabs configuration ===== | ||
| After processing prefabs with  '''Register Placeable Entities ''' plugin, assets will still need some manual adjustment to i.e. '''Authored Labels''' or '''Military Symbol'''  | After processing prefabs with  '''Register Placeable Entities ''' plugin, assets will still need some manual adjustment to i.e. '''Authored Labels''' or '''Military Symbol''' ''(in case of groups)'' configuration. Also, in most cases it will be necessary to add proper display name to assets. In case of characters, some existing localised strings can be used | ||
| Table with  | Table with localised strings | ||
| ====== Characters ====== | ====== Characters ====== | ||
| In case of characters, beside changing '''Name''' of assets in in-game content browser, few additions are necessary to '''Authored Labels''' array in  | In case of characters, beside changing '''Name''' of assets in in-game content browser, few additions are necessary to '''Authored Labels''' array in '''SCR_EditableCharacterComponent'''. Plugin responsible for automatic assignment of labels is not being able to distinguish character types automatically in current state so character role types has to be adjusted by hand. For example, Squad Leader (''Character_SampleFactionREDFOR_SL)'' can receive '''ROLE_LEADER''', Medic can get '''ROLE_MEDIC''', Machine gunner - '''ROLE_MACHINEGUNNER''' and so on. | ||
| Additionally, characters can also receive additional traits like, '''TRAIT_ARMED | Additionally, characters can also receive additional traits like, '''TRAIT_ARMED''', '''TRAIT_UNARMED''' or '''TRAIT_MEDICAL''', which improves filtering in in-game content browser. | ||
| ====== Vehicles ====== | ====== Vehicles ====== | ||
| When it comes to vehicles, it usually boils down to adding special vehicle traits like '''TRAIT_ARMED | When it comes to vehicles, it usually boils down to adding special vehicle traits like '''TRAIT_ARMED''', '''TRAIT_UNARMED, TRAIT_REFUELING''', etc. Some custom labels can be also established based on the needs but by no means its not necessary. | ||
| ====== Groups ====== | ====== Groups ====== | ||
| Similar to characters, also groups can use one of the already existing strings for '''Name''' property. | Similar to characters, also groups can use one of the already existing strings for '''Name''' property. | ||
| Table with localised strings | |||
| Table with  | |||
| <spoiler> | <spoiler> | ||
| {| class="wikitable" | {| class="wikitable" | ||
| |'''String''' | | '''String''' | ||
| |'''Display Name''' | | '''Display Name''' | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_AntiTankTeam |   AR-Group_AntiTankTeam | ||
| |Anti-Tank Team | | Anti-Tank Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Default |   AR-Group_Default | ||
| |Infantry Group | | Infantry Group | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_FireTeam |   AR-Group_FireTeam | ||
| |Fire Team | | Fire Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_FireTeamLight |   AR-Group_FireTeamLight | ||
| |Light Fire Team | | Light Fire Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_GrenadierTeam |   AR-Group_GrenadierTeam | ||
| |Grenadier Team | | Grenadier Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_FireTeam |   AR-Group_Guerrilla_FireTeam | ||
| |Guerrilla Fire Team | | Guerrilla Fire Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_HQ |   AR-Group_Guerrilla_HQ | ||
| |Guerrilla HQ | | Guerrilla HQ | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_MGTeam |   AR-Group_Guerrilla_MGTeam | ||
| |Guerrilla Machine Gun Team | | Guerrilla Machine Gun Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_ReconTeam |   AR-Group_Guerrilla_ReconTeam | ||
| |Guerrilla Recon Team | | Guerrilla Recon Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_SharpshooterTeam |   AR-Group_Guerrilla_SharpshooterTeam | ||
| |Guerrilla Sharpshooter Team | | Guerrilla Sharpshooter Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Guerrilla_Squad |   AR-Group_Guerrilla_Squad | ||
| |Guerrilla Squad | | Guerrilla Squad | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_LightAntiTankTeam |   AR-Group_LightAntiTankTeam | ||
| |Light Anti-Tank Team | | Light Anti-Tank Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_ManeuverGroup |   AR-Group_ManeuverGroup | ||
| |Maneuver Team | | Maneuver Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_MedicalSection |   AR-Group_MedicalSection | ||
| |Medical Support Team | | Medical Support Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_MGTeam |   AR-Group_MGTeam | ||
| |Machine Gun Team | | Machine Gun Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_MortarSquad |   AR-Group_MortarSquad | ||
| |Mortar Team | | Mortar Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_PlatoonHQ |   AR-Group_PlatoonHQ | ||
| |Platoon HQ | | Platoon HQ | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_SniperTeam |   AR-Group_SniperTeam | ||
| |Sniper Team | | Sniper Team | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_Squad |   AR-Group_Squad | ||
| |Rifle Squad | | Rifle Squad | ||
| |- | |- | ||
| | | | | ||
|   AR-Group_SuppressiveFireTeam |   AR-Group_SuppressiveFireTeam | ||
| |Base of Fire Team | | Base of Fire Team | ||
| |} | |} | ||
| </spoiler> | |||
| Compared to vehicles & characters though, there are no group related labels which have to be filled manually. | |||
| Compared to vehicles & characters though, there are no group related labels which have to be filled manually. However, groups also have special '''Military Symbol''' class, which holds information about icon which is visible in in-game editor above groups. Using checkboxes & drop menus available there, it is possible to assign one of [https://en.wikipedia.org/wiki/NATO_Joint_Military_Symbology NATO APP-6]  | However, groups also have special '''Military Symbol''' class, which holds information about icon which is visible in in-game editor above groups. | ||
| Using checkboxes & drop menus available there, it is possible to assign one of [https://en.wikipedia.org/wiki/NATO_Joint_Military_Symbology NATO APP-6] icon to selected group. | |||
| === Adding new faction to Faction Manager === | === Adding new faction to Faction Manager === | ||
| [[File:armareforger-new-faction-is-playable-change.jpg|thumb|Changing '''Is Playable''' parameter]] | |||
| One of the remaining steps towards integrating new faction into in-game editor is adding it to list of available factions. This can be done in two easy steps: | One of the remaining steps towards integrating new faction into in-game editor is adding it to list of available factions. This can be done in two easy steps: | ||
| # Use  | # Use '''[[Arma Reforger:Data Modding Basics#Using .22Override in....22 function|Override in '''addon''']] function on {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/MP/Managers/Factions/FactionManager_Editor.et}} located in ''Prefabs/MP/Managers/Factions'' folder | ||
| # Add new element to '''Factions''' array by drag and dropping faction config on that property | # Add new element to '''Factions''' array by drag and dropping faction config on that property | ||
| # Uncheck '''Is Playable''' parameter inside of '''SCR_Faction''' entry inside '''Factions''' array - by default, when Game Master session starts, there should be no factions available and it should be up to Game Master to decide which are | |||
| After that, faction should be selectable in respawn menu during game master sessions & assets should be using proper colorization in content browser.  | After that, faction should be selectable in respawn menu during game master sessions & assets should be using proper colorization in content browser. | ||
| [[ | [[File:armareforger-new-faction-adding-faction-to-manager.gif]] | ||
| === Creating new spawn points === | |||
| Spawn points are a special type of prefabs which are used to determine where player of given faction can spawn. | |||
| ==== Preparing new spawn point prefab ==== | |||
| First step will be creating new spawn point prefab - it is quite easy and involves following steps: | |||
| * Using '''Resource Browser''', find {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/MP/Spawning/SpawnPoint_Base.et}} prefab | |||
| * Click on it with '''Right Mouse Button''' and select option '''[[Arma Reforger:Data Modding Basics#Using .22Inherit in....22 function|Inherit in Addon]]''' | |||
| * Type name of new prefab (i.e. '''SpawnPoint_REDFOR''') | |||
| * Open prefab created in previous step (''SpawnPoint_REDFOR in this case)'' either by by using '''[[Arma Reforger:Prefabs Basics#Prefab edit mode|prefab edit mode]]''' or placing this prefab in World Editor | |||
| * In that prefab type name of your faction (''SampleModFactionREDFOR'') in '''Faction''' parameter | |||
| * Save your changes (using e.g {{Controls|Ctrl|S}}) | |||
| [[File:Image armareforger-new-faction-spawnpoint-creation.gif]] | |||
| ==== Creating editable variant of spawn point ==== | |||
| After creating base variants, it will be still necessary to make editable variant, which can be used directly in Game Master. Unlike before, editable variant of spawn point have to be created manually and below you can find instructions how to do it: | |||
| * In '''Resource Browser''', find {{Link|enfusion://ResourceManager/~ArmaReforger:PrefabsEditable/SpawnPoints/E_SpawnPoint.et}} | |||
| * Click on it with '''Right Mouse Button''' and select option '''[[Arma Reforger:Data Modding Basics#Using .22Inherit in....22 function|Inherit in Addon]]''' | |||
| * Type name of new prefab (i.e. '''E_SpawnPoint_REDFOR''') | |||
| * Open prefab created in previous step (''E_SpawnPoint_REDFOR in this case)'' either by by using '''[[Arma Reforger:Prefabs Basics#Prefab edit mode|prefab edit mode]]''' or placing this prefab in World Editor | |||
| <gallery mode="nolines" widths="500" heights="666"> | |||
| File:armareforger-new-faction-setting-editable-spawnpoint.png|'''SCR_SpawnPoint''' | |||
| File:armareforger-new-faction-spawnpoint-editable-component.png|'''SCR_EditableSpawnPointComponent''' | |||
| File:armareforger-new-faction-spawnpoint-faction-affilation.png|'''SCR_FactionAffiliationComponent''' | |||
| </gallery> | |||
| * In properties of '''SCR_SpawnPoint''' entity locate '''Faction''' parameter in unsorted category and write there name of the faction (''SampleFactionREDFOR'') | |||
| * In '''SCR_EditableSpawnPointComponent''' component do following changes: | |||
| ** Write name of your faction in '''Faction''' parameter | |||
| ** Assign '''texture''' to '''Image''' property. Currently all factions are using same texture, even though there are separate file names for them, so it's possible to use i.e. {{Link|enfusion://ResourceManager/~ArmaReforger:UI/Textures/EditorPreviews/Auto/Systems/SpawnPoints/E_SpawnPoint_USSR.edds}} | |||
| ** In Authored Labels array add two new elements: '''TRAIT_SPAWNPOINT''' (''it is missing in base class)'' and '''label of your faction''' (in this case it is '''FACTION_REDFOR''') | |||
| * In '''SCR_FactionAffiliationComponent''' adjusted '''Faction''' property and write there name of your faction (''SampleFactionREDFOR)'' | |||
| If everything went fine, spawn point should be ready to be plugged in into Game Master | |||
| ==== Registering spawn point ==== | |||
| Once editable spawn point prefab is ready, it is still necessary to register it in Game Master. This process is well described on [[Arma Reforger:Asset Browser Mod Integration|'''Asset Browser Mod Integration''']] and below is shortened version of it: | |||
| * [[Arma Reforger:Data Modding Basics#Using .22Duplicate to....22 function|Duplicate to]] addon {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Editor/PlaceableEntities/Systems/Systems.conf}} and call it i.e. ''Systems_SampleFaction.conf'' | |||
| * Open new config in '''Resource Manager''' | |||
| * Clear '''Prefabs''' array by clicking on little '''arrow (1)''' on the right side | |||
| * Add editable Spawn Point (''E_SpawnPoint_REDFOR.conf'') to '''Prefabs''' array | |||
| * ''Optionally:'' Modify Addon field so it matches addon name - in this case it would be '''SampleMod_NewFaction''' | |||
| * Save the config | |||
| [[File:armareforger-new-faction-registering-system.png|center|frame|Registering spawn point in Systems.conf]] | |||
| When config is ready, it is possible to register it in '''EditorModeEdit.et prefab''' as described on [[Arma Reforger:Asset Browser Mod Integration#Adding new register file to Editor|Asset Browser Mod Integration]] page. | |||
| === Generating editor previews === | === Generating editor previews === | ||
| Units, groups & vehicle previews used by in-game editor can be easily generated by using steps described on [[Arma_Reforger:Game_Master:_Image_Generation_Tutorial]] page & by loading  | |||
| Units, groups & vehicle previews used by in-game editor can be easily generated by using steps described on [[Arma_Reforger:Game_Master:_Image_Generation_Tutorial|Game Master: Image Generation Tutorial]] page & by loading {{Link|enfusion://WorldEditor/~worlds/Editor/Slots/AssetImages/Eden_AssetImages.ent}} world to generate those pictures. If previous steps were done correctly & assets were properly registered, then new images should be immediately available after generation process is completed. | |||
| {{Feature|important|Making screenshots disables debug console. It is necessary to restart whole Workbench to restore that functionality!}} | {{Feature|important|Making screenshots disables debug console. It is necessary to restart whole Workbench to restore that functionality!}} | ||
| == Integration with Conflict game mode == | == Integration with Conflict game mode == | ||
| Line 552: | Line 670: | ||
| ===== Faction config ===== | ===== Faction config ===== | ||
| Conflict is using extended version of regular faction config, which allows to configure '''ranks | Conflict is using extended version of regular faction config, which allows to configure '''ranks''', available '''structures''', default '''AI groups''', '''vehicles''' or '''radio equipment'''. Since this specialised version of config is extension of default '''SCR_Faction''' class, it is recommended to inherit from previously created '''SCR_Faction''' config - in this case it is '''SampleFactionREDFOR.conf.''' | ||
| {{Feature|important| Currently configs have to be adjusted in text editor of your choice since Workbench doesn't offer ability to change config class!}} | {{Feature|important| Currently configs have to be adjusted in text editor of your choice since Workbench doesn't offer ability to change config class!}} | ||
| Easiest way to create such config is using  | Easiest way to create such config is using '''''' '''Inherit''' option on '''SampleFactionREDFOR.conf'''. Once new config is created - named i.e. '''SampleFactionREDFOR_Campaign.conf'''. After this is complete, this file can be edited in text editor of your choice and '''SCR_Faction''' on first line of file | ||
| < | <enforce> | ||
| [...]</ | SCR_Faction : "{C93D9F19E9F3CD97}Configs/Factions/SampleFactionREDFOR.conf" { | ||
| [...] | |||
| </enforce> | |||
| can be replaced with '''SCR_CampaignFaction''' like on example below. | can be replaced with '''SCR_CampaignFaction''' like on example below. | ||
| < | <enforce> | ||
| [...]</ | SCR_CampaignFaction : "{C93D9F19E9F3CD97}Configs/Factions/SampleFactionREDFOR.conf" { | ||
| [...] | |||
| </enforce> | |||
| Once this adjustment is saved, it might be necessary to restart whole '''Workbench''' in order to have that change correctly loaded. | Once this adjustment is saved, it might be necessary to restart whole '''Workbench''' in order to have that change correctly loaded. | ||
| {{Feature|informative|'''Campaign''' is one of the code names of '''Conflict''' game mode and it is still referenced this way in few places.}}   | {{Feature|informative|'''Campaign''' is one of the code names of '''Conflict''' game mode and it is still referenced this way in few places.}} | ||
| Afterward,  | Afterward, class indication '''SampleFactionREDFOR_Campaign.conf''' should correctly show '''SCR_CampaignFaction''' class (see green area on picture below). | ||
| [[ | [[File:armareforger-new-faction-conflict-config.gif]] | ||
| By default, resulting config will be quite empty and most of the '''Conflict''' specific parameters have to be filled by hand. Using table below,  | By default, resulting config will be quite empty and most of the '''Conflict''' specific parameters have to be filled by hand. Using table below, '''SampleFactionREDFOR_Campaign.conf''' was populated with all necessary data. | ||
| {| class="wikitable" | {| class="wikitable" | ||
| ! Group | |||
| ! Parameters | |||
| ! Description | |||
| |- | |- | ||
| |Ranks | | Ranks | ||
| | | |||
| |Ranks that players can gain through the game | | Ranks that players can gain through the game | ||
| |- | |- | ||
| |Radio | | Radio | ||
| | Faction Radio Encryption Key | |||
| Faction Radio Frequency | Faction Radio Frequency | ||
| |Controls default frequency and | | Controls default frequency and | ||
| |- | |- | ||
| |AI | | AI | ||
| | AI Group Prefab | |||
| AI Vehicle Prefab | AI Vehicle Prefab | ||
| Line 601: | Line 723: | ||
| Spawn AIs | Spawn AIs | ||
| |Configuration of AI groups like base defenders or attacking squads | | Configuration of AI groups like base defenders or attacking squads | ||
| |- | |- | ||
| | AI (Independent) | |||
| | Remnant Groups | |||
| | AI groups spawned by '''INDFOR''' side on territory they are controlling. | |||
| |- | |- | ||
| |Structures | | Structures | ||
| | Radio Prefab | |||
| Base Building XXX | Base Building XXX | ||
| |Buildings & equipment used by factions | | Buildings & equipment used by factions | ||
| |- | |- | ||
| | Compositions | |||
| | Campaign Slot Compositions | |||
| | Compositions which can be build by this faction | |||
| |} | |} | ||
| Line 622: | Line 744: | ||
| '''Example code below can be used for inspiration''' | '''Example code below can be used for inspiration''' | ||
| <spoiler> | |||
| <syntaxhighlight lang="cpp"> | |||
| SCR_CampaignFaction : "{C93D9F19E9F3CD97}Configs/Factions/SampleFactionREDFOR.conf" { | |||
|   m_aRanks { |   m_aRanks { | ||
|  SCR_CharacterRank "{528E9D9FAAB617C6}" { | |||
|  m_sRankName "#AR-Rank_WestPrivate" | |||
|  m_sRankNameUpper "#AR-Rank_WestPrivate-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestPrivateShort" | |||
|  m_sInsignia "{2AA43D26EB40FF32}UI/Textures/Nametags/nametagPointerRankPrivate_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FAB192253}" { | |||
|  m_iRank CORPORAL | |||
|  m_sRankName "#AR-Rank_WestCorporal" | |||
|  m_sRankNameUpper "#AR-Rank_WestCorporal-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestCorporalShort" | |||
|  m_sInsignia "{9EB262BC94EA46F3}UI/Textures/Nametags/nametagPointerRankCorporal_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FAB87F519}" { | |||
|  m_iRank SERGEANT | |||
|  m_sRankName "#AR-Rank_WestSergeant" | |||
|  m_sRankNameUpper "#AR-Rank_WestSergeant-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestSergeantShort" | |||
|  m_sInsignia "{F879E808E02C9442}UI/Textures/Nametags/nametagPointerRankSergeant_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FA4EA5C39}" { | |||
|  m_iRank LIEUTENANT | |||
|  m_sRankName "#AR-Rank_WestLieutenant" | |||
|  m_sRankNameUpper "#AR-Rank_WestLieutenant-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestLieutenantShort" | |||
|  m_sInsignia "{F879E808E02C9442}UI/Textures/Nametags/nametagPointerRankSergeant_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FA563C005}" { | |||
|  m_iRank CAPTAIN | |||
|  m_sRankName "#AR-Rank_WestCaptain" | |||
|  m_sRankNameUpper "#AR-Rank_WestCaptain-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestCaptainShort" | |||
|  m_sInsignia "{F879E808E02C9442}UI/Textures/Nametags/nametagPointerRankSergeant_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FA64A043C}" { | |||
|  m_iRank MAJOR | |||
|  m_sRankName "#AR-Rank_WestMajor" | |||
|  m_sRankNameUpper "#AR-Rank_WestMajor-UC" | |||
|  m_sRankNameShort "#AR-Rank_WestMajorShort" | |||
|  m_sInsignia "{F879E808E02C9442}UI/Textures/Nametags/nametagPointerRankSergeant_ca.edds" | |||
|  } | |||
|  SCR_CharacterRank "{528E9D9FA77F696E}" { | |||
|  m_iRank RENEGADE | |||
|  m_sRankName "#AR-Rank_Renegade" | |||
|  m_sRankNameUpper "#AR-Rank_Renegade-UC" | |||
|  m_sInsignia "{F879E808E02C9442}UI/Textures/Nametags/nametagPointerRankSergeant_ca.edds" | |||
|  } | |||
|   } |   } | ||
|   m_sFactionRadioEncryptionKey "coldBorscht" |   m_sFactionRadioEncryptionKey "coldBorscht" | ||
| Line 704: | Line 828: | ||
|   m_BaseBuildingRadioAntennaNoSlot "{1AF9E0A02075CBB0}Prefabs/MP/Campaign/Bases/Campaign_Antenna_US.et" |   m_BaseBuildingRadioAntennaNoSlot "{1AF9E0A02075CBB0}Prefabs/MP/Campaign/Bases/Campaign_Antenna_US.et" | ||
|   m_aCampaignSlotCompositions { |   m_aCampaignSlotCompositions { | ||
|  SCR_CampaignSlotComposition "{5496D16E528E4C29}" { | |||
|  m_Resource "{4885DEA01D687DB2}PrefabsEditable/Auto/Compositions/Slotted/SlotFlatSmall/E_Bunker_S_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_SandbagBunker-UC" | |||
|  m_sMarkerImage "Building_Fortification" | |||
|  m_sIconImage "Slot_Fortification" | |||
|  m_iPrice 25 | |||
|  m_SlotType FlatSmall | |||
|  m_bIsServiceComposition 0 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{5496D16E532917AC}" { | |||
|  m_Resource "{1200F6499BA275FA}PrefabsEditable/Auto/Compositions/Slotted/SlotFlatSmall/E_SandbagPosition_S_USSR_03.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_SandbagPosition-UC" | |||
|  m_sMarkerImage "Building_Fortification" | |||
|  m_sIconImage "Slot_Fortification" | |||
|  m_iPrice 25 | |||
|  m_SlotType FlatSmall | |||
|  m_bIsServiceComposition 0 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{5496D16E6079CB08}" { | |||
|  m_Resource "{047B9C8AAB50CE0E}PrefabsEditable/Auto/Compositions/Slotted/SlotFlatSmall/E_MachineGunNest_S_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_MachineGunNest-UC" | |||
|  m_sMarkerImage "Building_Fortification" | |||
|  m_sIconImage "Slot_Fortification" | |||
|  m_iPrice 25 | |||
|  m_SlotType FlatSmall | |||
|  m_bIsServiceComposition 0 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{5496FB6B9D439DCD}" { | |||
|  m_Resource "{5AF4E84CA11058F3}PrefabsEditable/Auto/Compositions/Slotted/SlotRoadSmall/E_Checkpoint_S_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_SmallRoadCheckpoint-UC" | |||
|  m_sMarkerImage "Building_RoadBlock" | |||
|  m_sIconImage "Slot_Roadblock" | |||
|  m_iPrice 75 | |||
|  m_SlotType CheckpointSmall | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 0 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{5496FB6B958EA37C}" { | |||
|  m_Resource "{1DF9835399B603EA}PrefabsEditable/Auto/Compositions/Slotted/SlotRoadMedium/E_Checkpoint_M_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_MediumRoadCheckpoint-UC" | |||
|  m_sMarkerImage "Building_RoadBlock" | |||
|  m_sIconImage "Slot_Roadblock" | |||
|  m_iPrice 125 | |||
|  m_SlotType CheckpointMedium | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 0 | |||
|   } |   } | ||
| }</syntaxhighlight ></spoiler>}} |  SCR_CampaignSlotComposition "{5496FB6B95ED9102}" { | ||
|  m_Resource "{612AB9E420809988}PrefabsEditable/Auto/Compositions/Slotted/SlotRoadLarge/E_Checkpoint_L_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_LargeRoadCheckpoint-UC" | |||
|  m_sMarkerImage "Building_RoadBlock" | |||
|  m_sIconImage "Slot_Roadblock" | |||
|  m_iPrice 150 | |||
|  m_SlotType CheckpointLarge | |||
|  m_bCanBeRotated 0 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{54A088BB7FA2DFDA}" { | |||
|  m_Resource "{4D1E4357BC178D19}Prefabs/Compositions/Slotted/SlotFlatSmall/FuelStorage_S_USSR_01_Campaign.et" | |||
|  m_vBuildingControllerOffset -1.5 0 0 | |||
|  m_sDisplayName "#AR-Campaign_Building_FuelDepot-UC" | |||
|  m_sMarkerImage "Building_FuelDepot" | |||
|  m_sIconImage "Slot_Fuel" | |||
|  m_iPrice 750 | |||
|  m_SlotType Services | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 1 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{54A0A94A1B28CA0A}" { | |||
|  m_Resource "{A9A977F2EE4056E1}Prefabs/Compositions/Slotted/SlotFlatSmall/AmmoStorage_S_USSR_01_Campaign.et" | |||
|  m_vBuildingControllerOffset -5 0 0 | |||
|  m_sDisplayName "#AR-Campaign_Building_Armory-UC" | |||
|  m_sMarkerImage "Building_Armory" | |||
|  m_sIconImage "Slot_Armory" | |||
|  m_iPrice 750 | |||
|  m_SlotType Services | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 1 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{54A0A94A1AE6C81B}" { | |||
|  m_Resource "{FE5831BC3D5E33CD}Prefabs/Compositions/Slotted/SlotFlatSmall/VehicleMaintenance_S_USSR_01_Campaign.et" | |||
|  m_vBuildingControllerOffset -4 0 0 | |||
|  m_sDisplayName "#AR-Campaign_Building_RepairDepot-UC" | |||
|  m_sMarkerImage "Building_VehicleWorkshop" | |||
|  m_sIconImage "Slot_Repair" | |||
|  m_iPrice 750 | |||
|  m_SlotType Services | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 1 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{54A0E082FF414F1D}" { | |||
|  m_Resource "{70BEEEC472F2CD7D}Prefabs/Compositions/Slotted/SlotFlatMedium/FieldHospital_M_USSR_01.et" | |||
|  m_sDisplayName "#AR-Campaign_Building_FieldHospital-UC" | |||
|  m_sMarkerImage "Building_Hospital" | |||
|  m_sIconImage "Slot_Medical" | |||
|  m_iPrice 750 | |||
|  m_SlotType Services | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 1 | |||
|  } | |||
|  SCR_CampaignSlotComposition "{54A0E082D40B2C4D}" { | |||
|  m_Resource "{F68F3B7247F6E80F}Prefabs/Compositions/Slotted/SlotFlatLarge/LivingArea_L_USSR_01.et" | |||
|  m_vBuildingControllerOffset 0 0 0 | |||
|  m_sDisplayName "#AR-Campaign_Building_Barracks-UC" | |||
|  m_iPrice 750 | |||
|  m_SlotType Services | |||
|  m_bCanBeRotated 0 | |||
|  m_bIsServiceComposition 1 | |||
|  } | |||
|  } | |||
| } | |||
| </syntaxhighlight> | |||
| </spoiler> | |||
| }} | |||
| ==== Vehicle list ==== | ==== Vehicle list ==== | ||
| Pool of available for request vehicles is defined in config file using '''SCR_CampaignVehicleAssetList''' class. By default, Conflict is using  | Pool of available for request vehicles is defined in config file using '''SCR_CampaignVehicleAssetList''' class. By default, Conflict is using {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Campaign/VehicleAssetList.conf}} located in ''Configs/Campaign'' folder and this file is a good candidate for a custom variant. | ||
| After clicking on {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Campaign/VehicleAssetList.conf}} with Right Mouse Button , '''Duplicate''' option can be selected from context menu and new config file - like '''VehicleAssetList_SampleNewFaction.conf''' - can be prepared. | |||
| It is also possible to create new '''SCR_CampaignVehicleAssetList''' config from scratch through ''Create→ Config File'' too. | It is also possible to create new '''SCR_CampaignVehicleAssetList''' config from scratch through ''Create→ Config File'' too. | ||
| Having a new config file ready, it is possible to start adjusting thing inside of it. Every element inside of '''Vehicle Asset List''' array represents an vehicle which can be requested at '''Vehicle Depot''' by one of the sides participating in Conflict game mode. In case when  | Having a new config file ready, it is possible to start adjusting thing inside of it. | ||
| Every element inside of '''Vehicle Asset List''' array represents an vehicle which can be requested at '''Vehicle Depot''' by one of the sides participating in Conflict game mode. | |||
| In case when {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Campaign/VehicleAssetList.conf}} was duplicated, only things which need to be changed are '''Prefab & Prefab Opposite''' parameter. | |||
| [[ | [[File:armareforger-new-faction-conflict-vehicles.png|link=Special:FilePath/armareforger-new-faction-conflict-vehicles.png]] | ||
| '''Prefab''' parameter controls which asset will be spawned when this vehicle is requested in-game. In this tutorial '''REDFOR''' faction vehicles are going to be replaced with variants used by '''SampleFactionREDFOR''' faction and for instance  | '''Prefab''' parameter controls which asset will be spawned when this vehicle is requested in-game. | ||
| In this tutorial '''REDFOR''' faction vehicles are going to be replaced with variants used by '''SampleFactionREDFOR''' faction and for instance {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Vehicles/Wheeled/UAZ469/UAZ469.et}} prefab is being replaced with '''UAZ469_SampleFactionREDFOR.et.''' | |||
| Once replacement is completed on REDFOR vehicles, it also necessary to go through '''BLUFOR''' vehicles and update there assets assigned in '''Prefab Opposite''' parameter with current '''SampleFactionREDFOR''' counterparts. This parameter is mainly used when opposing faction captures vehicle depot with some vehicles being still  | Once replacement is completed on '''REDFOR''' vehicles, it also necessary to go through '''BLUFOR''' vehicles and update there assets assigned in '''Prefab Opposite''' parameter with current '''SampleFactionREDFOR''' counterparts. | ||
| This parameter is mainly used when opposing faction captures vehicle depot with some vehicles being still available there. | |||
| In this scenario, enemy vehicles will be still available to request but they will also consume total capacity of such depot. | |||
| For instance if '''BLUFOR''' captures depot with 8 UAZs, then in next reinforcement wave only two additional M151A2 cars will be added to the pool. | |||
| Conflict game mode supports only three sides in game and those are available in '''Faction''' drop down menu: | Conflict game mode supports only three sides in game and those are available in '''Faction''' drop down menu: | ||
| Line 833: | Line 967: | ||
| * '''BLUFOR''' - represent first playable team, which fights for control over the island with '''REDFOR''' & '''INDFOR''' forces | * '''BLUFOR''' - represent first playable team, which fights for control over the island with '''REDFOR''' & '''INDFOR''' forces | ||
| * '''REDFOR''' - represent second playable team, which fights for control over the island with '''BLUFOR''' & '''INDFOR''' forces | * '''REDFOR''' - represent second playable team, which fights for control over the island with '''BLUFOR''' & '''INDFOR''' forces | ||
| * '''INDFOR''' - represent non playable independent forces which are fighting with both '''BLUFOR''' & '''REDFOR''' forces''' | * '''INDFOR'<nowiki/>'' - represent non playable independent forces which are fighting with both '''''<nowiki/>''BLUFOR''' & '''REDFOR''' forces'<nowiki/>'''''. This faction holds at the beginning majority of the bases | ||
| Actual factions linked to '''BLUFOR''', '''REDFOR''' & '''INDFOR''' are defined in '''CampaignMPGameMode''' prefab which is placed and can be modified in Campaign world itself. More information about this feature can be found in chapter describing '''Conflict''' world. | Actual factions linked to '''BLUFOR''', '''REDFOR''' & '''INDFOR''' are defined in '''CampaignMPGameMode''' prefab which is placed and can be modified in Campaign world itself. | ||
| More information about this feature can be found in chapter describing '''Conflict''' world. | |||
| Since '''SampleFactionREDFOR''' is using color retextures of existing vehicles, it is possible to leave '''Display Name & Display Name UC''' parameters intact. | Since '''SampleFactionREDFOR''' is using color retextures of existing vehicles, it is possible to leave '''Display Name & Display Name UC''' parameters intact. | ||
| Line 842: | Line 977: | ||
| {| class="wikitable" | {| class="wikitable" | ||
| ! Property | |||
| ! Description | |||
| |- | |- | ||
| |'''Prefab''' | | '''Prefab''' | ||
| |Prefab of a vehicle which can be requested | | Prefab of a vehicle which can be requested | ||
| |- | |- | ||
| |'''Faction''' | | '''Faction''' | ||
| |One of the | | One of the | ||
| |- | |- | ||
| |'''Display Name''' | | '''Display Name''' | ||
| |Name which will be shown in UI (i.e. request menu) | | Name which will be shown in UI (i.e. request menu) | ||
| |- | |- | ||
| |'''Display Name UC''' | | '''Display Name UC''' | ||
| |Same as above but in upper case | | Same as above but in upper case | ||
| |- | |- | ||
| |'''Rank ID''' | | '''Rank ID''' | ||
| |Lowest rank which can request this vehicle | | Lowest rank which can request this vehicle | ||
| |- | |- | ||
| | '''Max''' | |||
| | Max amount of assets of that type that a base can hold | |||
| |- | |- | ||
| | '''Starting Amount''' | |||
| | Amount of vehicles available at mission start | |||
| |- | |- | ||
| | '''Reinforcements Amount''' | |||
| | Amount of vehicles which are added in reinforcement wave | |||
| |- | |- | ||
| | '''Prefab Opposite''' | |||
| | Opposing faction vehicle counterpart. This parameter is used mainly to correctly recognise maximal capacity of a vehicle depot | |||
| |} | |} | ||
| === Adding Conflict specific prefabs === | |||
| Conflict game mode requires few specialised prefabs in order to run properly. For starter, '''Conflict''' requires unique character prefabs - both for AI & players. | |||
| Conflict game mode requires few  | All those '''Conflict''' specific characters are located in ''Prefabs/Characters/Campaign'' folder and similar structure is used also for '''REDFOR''' faction. | ||
| Player characters used in Conflict game are typical characters, often derived from existing troops, with addition of few extra components: | |||
| * ''' | * '''SCR_ResourceComponent -''' used for handling '''Conflict''' related '''interactions with supplies''' | ||
| * '''SCR_CampaignBuildingComponent -''' used for handling of in-game '''construction of structures''' | * '''SCR_CampaignBuildingComponent -''' used for handling of in-game '''construction of structures''' | ||
| * '''MapDescriptorComponent -''' used for correctly '''showing unit on map''' | * '''MapDescriptorComponent -''' used for correctly '''showing unit on map''' | ||
| ==== Player Character ==== | ==== Player Character ==== | ||
| Beginning with '''Conflict player character''', a new  | Beginning with '''Conflict player character''', a new '''Campaign_SampleFactionREDFOR_Player.et''' prefab can be created by inheriting from one of already existing '''SampleFactionREDFOR''' character - i.e. '''Character_SampleFactionREDFOR_Rifleman.et''' '''-''' using for example '''''' '''[[Arma Reforger:Prefabs Basics#Using Inherit Prefab option|Inherit]]''' option. | ||
| In case of ''' | In case of '''SCR_ResourceComponent''', it is necessary to add new component via '''"+ Add Component"''' . After that, it will be still necessary to add one element to '''Consumers''' array of that component. | ||
| This can be achieved by drag & dropping {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Resources/Supplies/Consumers/Generic/Consumer_Self.conf}} from '''Resource Browser''' onto '''Consumers array in SCR_ResourceComponent''' in '''Object Properties''' window. After that, a '''SCR_ResourceComponent''' component should contain all necessary data for Conflict game mode'''.''' | |||
| [[ | [[File:armareforger-new-faction-resource-component.gif.gif]] | ||
| Similar to '''SCR_ResourceComponent''', the other two components - '''SCR_CampaignBuildingComponent''' & '''MapDescriptorComponent''' have to be added manually through "'''+ Add Component'''" button. | |||
| Once those components are added, the following tweaks can be applied: | |||
| * '''SCR_CampaignBuildingComponent''' | * '''SCR_CampaignBuildingComponent''' | ||
| **  | ** No changes are necessary | ||
| * '''MapDescriptorComponent''' | |||
| * '''MapDescriptorComponent'''   | |||
| ** '''Descriptor Visible''' should be '''unchecked''' | ** '''Descriptor Visible''' should be '''unchecked''' | ||
| ** '''Descriptor Type Enum''' should be changed to '''Unit''' | ** '''Descriptor Type Enum''' should be changed to '''Unit''' | ||
| Line 900: | Line 1,038: | ||
| ==== AI Character ==== | ==== AI Character ==== | ||
| Next on the list is preparing friendly AI prefab - '''Campaign_SampleFactionREDFOR_AI.et  | Next on the list is preparing friendly AI prefab - '''Campaign_SampleFactionREDFOR_AI.et''' - which can be i.e. spotted in friendly bases. Similar to player character, '''Character_SampleFactionREDFOR_Rifleman.et ''' can be used as base for such prefab. | ||
| Once new AI character is created, '''CampaignInteractions.ct''' can be applied to this prefab in same way as for player prefab. This is the only required prefab for AI character and after it is added, '''Campaign_SampleFactionREDFOR_AI.et''' should be ready for action! | |||
| === Adding Conflict specific groups === | |||
| Main playable factions require only few extra groups which can be created based on existing group prefabs. | |||
| Main playable factions require only few extra groups which can be created based on existing group prefabs.  | The main difference for non playable factions (''INDFOR'') is the presence of '''Remnants Groups''', which are using '''unique group compositions''' and their group members are also '''not being spawned immediately''' when given prefab is created. | ||
| {{Feature|informative|'''Remnants Groups''' are only relevant for given faction if its used as '''INDFOR''' forces. If it's not planned to use given faction as independent side then this step can be skipped. }}   | {{Feature|informative| | ||
| '''Remnants Groups''' are only relevant for given faction if its used as '''INDFOR''' forces. | |||
| If it's not planned to use given faction as independent side then this step can be skipped. | |||
| }} | |||
| This delayed spawning behavior is achieved by setting '''Spawn Immediately''' property to unchecked state. | This delayed spawning behavior is achieved by setting '''Spawn Immediately''' property to unchecked state. | ||
| Remnants group can be prepared in few simple steps.  | Remnants group can be prepared in few simple steps. | ||
| The whole process begins with creating faction specific Remnant group base ('''''Group_SampleFactionREDFOR_Remnants_Base.et''''') prefab using {{Link|enfusion://ResourceManager/~ArmaReforger:Prefabs/Groups/Campaign/Group_Remnants_Base.et}} prefab as parent. | |||
| In this new base prefab it is necessary to adjust '''Faction''' parameter and change it to name faction code name '''- SampleFactionREDFOR | In this new base prefab it is necessary to adjust '''Faction''' parameter and change it to name faction code name '''- SampleFactionREDFOR'''. | ||
| Next, it is possible to use that new prefab to create some extra groups like: | Next, it is possible to use that new prefab to create some extra groups like: | ||
| * Patrol Group (  | * Patrol Group ('''Group_SampleFactionGREENFOR_Remnants_Patrol.et''') | ||
| * Fire Team (  | * Fire Team ('''Group_SampleFactionGREENFOR_Remnants_FireTeamet''') | ||
| * AT Team (  | * AT Team ('''Group_SampleFactionGREENFOR_Remnants_AT.et''') | ||
| * MG Squad (  | * MG Squad ('''Group_SampleFactionGREENFOR_Remnants_MG.et''') | ||
| * Sniper Team (  | * Sniper Team ('''Group_SampleFactionGREENFOR_Remnants_Sniper.et''') | ||
| Once those prefabs are created, only remaining thing to do is adjusting composition of those groups according to their purpose. This can be done by changing  | Once those prefabs are created, only remaining thing to do is adjusting composition of those groups according to their purpose. This can be done by changing '''Unit Prefab Slots array'''. | ||
| It is worth mentioning that '''remnants groups can use regular character prefabs'''. For example, AT group can consist of '''Character_SampleFactionREDFOR_AT.et''' prefab. | |||
| After all groups are created & adjusted, it is possible to assign them to remnants forces rooster. This can be done by adding new elements to '''Remnant Groups''' array in  | After all groups are created & adjusted, it is possible to assign them to remnants forces rooster. This can be done by adding new elements to '''Remnant Groups''' array in '''SampleFactionREDFOR_Campaign.conf'''. | ||
| From this list, game will try to pick random groups depending on the context of area where they are supposed to be spawn (''SCR_CampaignREmnantsSpawnPoint''). | |||
| This is done by setting '''Probability & Type in SCR_CampaignRemnantsGroup''' entry in '''Remnant Groups''' array. | |||
| {{Feature|important|Currently BLUFOR & OPFOR AI forces are only assigned to base defence and '''cannot capture bases on their own'''. Configuration of attacking squads & their vehicles is therefor '''highly optional'''.}}   | {{Feature|important|Currently BLUFOR & OPFOR AI forces are only assigned to base defence and '''cannot capture bases on their own'''. Configuration of attacking squads & their vehicles is therefor '''highly optional'''.}} | ||
| Conflict attackers & defenders AI groups consist of previously created Conflict variant of AI characters. Configuration of those groups is basically the same as regular ones. '''Defenders''' groups are spawned '''in bases controlled by this faction''' and they are tasked with defending this territory. '''Attackers''' on the other hand should actively try to '''capture enemy bases''' using vehicle defined in faction config. | Conflict attackers & defenders AI groups consist of previously created Conflict variant of AI characters. | ||
| Configuration of those groups is basically the same as regular ones. '''Defenders''' groups are spawned '''in bases controlled by this faction''' and they are tasked with defending this territory. | |||
| '''Attackers''' on the other hand should actively try to '''capture enemy bases''' using vehicle defined in faction config. | |||
| [[ | [[File:armareforger-new-faction-conflict-attackers.png]] | ||
| Starting with creation of base group for '''both attackers & defender''', a new  | Starting with creation of base group for '''both attackers & defender''', a new '''Group_SampleFactionREDFOR_Campaign_Base.et''' prefab, inheriting from regular '''Group_SampleFactionREDFOR_Base.et ''' group, was created. | ||
| In this base prefab there is only one thing which need to be adjusted''':''' | In this base prefab there is only one thing which need to be adjusted''':''' | ||
| * '''Unit Prefab Slots''' array should be tweaked so only '''3'''  | * '''Unit Prefab Slots''' array should be tweaked so only '''3''' '''Campaign_SampleFactionREDFOR_AI.et''' prefabs are present. | ||
| Next, using  | Next, using '''Group_SampleFactionREDFOR_Campaign_Base.et''' as paraent, '''Group_SampleFactionREDFOR_Campaign_Defenders.et''' was prepared. This prefab doesn't need any additional refinements. | ||
| Similar to defenders group, attacker group -  | Similar to defenders group, attacker group - '''Group_SampleFactionREDFOR_Campaign.et''' - was prepared using '''Group_SampleFactionREDFOR_Campaign_Base.et''' as parent. This prefab needs two tweaks: | ||
| * '''Unit Prefab Slots''' array should consist from '''7'''  | * '''Unit Prefab Slots''' array should consist from '''7''' '''Campaign_SampleFactionREDFOR_AI.et''' characters | ||
| * '''Spawn  | * '''Spawn Immediately''' parameter should be '''unchecked'''. This is done to avoid spike in load when spawning those groups across the island | ||
| Finally, when those groups are ready, they can be  | Finally, when those groups are ready, they can be assigned to appropriate fields in '''SampleFactionREDFOR_Campaign.conf''' | ||
| * '''AI Group Prefab → Attacker group - Group_SampleFactionREDFOR_Campaign.et  | * '''AI Group Prefab → Attacker group - Group_SampleFactionREDFOR_Campaign.et ''' | ||
| * '''Defenders Group Prefab → Defenders group - Group_SampleFactionREDFOR_Campaign_Defenders.et  | * '''Defenders Group Prefab → Defenders group - Group_SampleFactionREDFOR_Campaign_Defenders.et ''' | ||
| ===  | === Creating new Conflict world === | ||
| ==== Using Conflict template ==== | ==== Using Conflict template ==== | ||
| ==== Adjusting scenario ==== | ==== Adjusting scenario ==== | ||
| After  | After successfully copying template to the addon, it's time to change playable faction in this scenario. | ||
| {{Feature|informative|All changes performed below are only applied to entities existing in that scenario and '''Apply To Prefab''' button '''shouldn't be used.'''}} | {{Feature|informative|All changes performed below are only applied to entities existing in that scenario and '''Apply To Prefab''' button '''shouldn't be used.'''}} | ||
| [[ | [[File:armareforger-new-faction-conflict-scenario.png]] | ||
| In '''logic layer | In '''logic layer''', there are three entities which have to be adjusted: | ||
| # '''CampaignFactionManager1 → ''' This entity holds information about factions which can be used in this scenario | # '''CampaignFactionManager1 → ''' This entity holds information about factions which can be used in this scenario | ||
| # '''CampaignMPGameMode1 → ''' One of the core '''Conflict''' entities - here it is possible to adjust all kind of '''Conflict gameplay options.'''   | # '''CampaignMPGameMode1 → ''' One of the core '''Conflict''' entities - here it is possible to adjust all kind of '''Conflict gameplay options.''' | ||
| # '''CampaignLoadoutManager_1 → ''' Defines '''characters''' (''loadouts'') which players can select in respawn menu   | # '''CampaignLoadoutManager_1 → ''' Defines '''characters''' (''loadouts'') which players can select in respawn menu | ||
| ===== Faction Manager ===== | ===== Faction Manager ===== | ||
| Line 975: | Line 1,122: | ||
| Faction Manager contains list of all factions that participate in Conflict game-mode. Main parameter of that entity is '''Factions''' array where it is possible to add or replace existing factions with custom ones. | Faction Manager contains list of all factions that participate in Conflict game-mode. Main parameter of that entity is '''Factions''' array where it is possible to add or replace existing factions with custom ones. | ||
| [[ | [[File:armareforger-new-faction-conflict-manager.gif]] | ||
| In this tutorial, default '''USSR''' faction is being replaced with '''SampleFactionREDFOR | In this tutorial, default '''USSR''' faction is being replaced with '''SampleFactionREDFOR'''. Such replacement can be achieved by drag & dropping '''SampleFactionREDFOR_Campaing.conf''' on '''SCR_CampaignFaction''' element representing '''USSR''' faction inside '''Factions''' array. | ||
| Another notable thing which is set in  | Another notable thing which is set in '''CampaignFactionManager1''' is '''Vehicle Asset List''', which contains link to a config file containing '''list of available for request vehicles'''. In this tutorial, previously created '''VehicleAssetList_SampleNewFaction.conf''' is assigned to this parameter. | ||
| ===== Game Mode tweaking ===== | ===== Game Mode tweaking ===== | ||
| SCR_GameModeCampaignMP | SCR_GameModeCampaignMP | ||
| [[ | [[File:armareforger-new-faction-conflict-gamemode.png]] | ||
| '''CampaignMPGameMode1''' entity contains also of various parameters but since goal here is just to change the playable faction, only '''faction key'''  | '''CampaignMPGameMode1''' entity contains also of various parameters but since goal here is just to change the playable faction, only '''faction key''' will be changed. Faction keys are used to connect factions defined in faction manger to one of the three playable sides in '''Conflict''' game mode. | ||
| In this tutorial, '''OPFOR Faction Key | In this tutorial, '''OPFOR Faction Key''', located in '''Unsorted''' group of parameters, is changed from '''USSR''' to '''SampleFactionREDFOR.''' | ||
| ==== Loadouts ==== | ==== Loadouts ==== | ||
| SCR_LoadoutManger | SCR_LoadoutManger | ||
| [[ | [[File:armareforger-new-faction-conflict-loadout.png]] | ||
| Loadout manager controls which classes player can select in respawn menu. In this case, '''USSR loadout''' will be replaced with '''SampleFactionREDFOR''' variant and following parameters will have to be adjusted: | Loadout manager controls which classes player can select in respawn menu. In this case, '''USSR loadout''' will be replaced with '''SampleFactionREDFOR''' variant and following parameters will have to be adjusted: | ||
| # '''Loadout Name''' → Display name of loadout in respawn menu. Here it is replaced  | # '''Loadout Name''' → Display name of loadout in respawn menu. Here it is replaced with '''REDFOR''' string | ||
| # '''Loadout Resource''' → Prefab of spawned character. This parameter can be replaced with previously created Conflict character -  | # '''Loadout Resource''' → Prefab of spawned character. This parameter can be replaced with previously created Conflict character - '''Campaign_SampleFactionREDFOR_Player.et''' . | ||
| # '''Affiliated Faction →''' Defines to which factions belongs this loadout''' | # '''Affiliated Faction →''' '''<nowiki/>'''Defines to which factions belongs this loadout. '''''<nowiki/>'''''Parameter was replaced with '''SampleFactionREDFOR''' | ||
| ==== Testing results in game ==== | ==== Testing results in game ==== | ||
| Once all those changes are done, it is possible to switch into play mode by either clicking on button with green arrow or by pressing F5 shortcut. | Once all those changes are done, it is possible to switch into play mode by either clicking on button with green arrow or by pressing F5 shortcut. | ||
| [[ | [[File:armareforger-new-faction-conflict-result.png|1200px]] | ||
| {{GameCategory|armaR|Modding|Tutorials | {{GameCategory|armaR|Modding|Assets|Tutorials}} | ||
Latest revision as of 14:31, 26 February 2025
Goals of this tutorial
In this tutorial you will learn about:
- Configuration of characters
- Preparation of units groups
- Creation of new factions
- Integration of new faction into Game Master
- Integration of new faction into Conflict game mode
Introduction
In this tutorial, process of creating new faction is explained and as an example, secrets of preparing Sample Faction - REDFOR will be unveiled.
This page goes through topics like preparing new characters, tweaking their configuration, creating new groups, preparing general faction configs & finally, integration into both in-game editor & Conflict game mode.
While the tutorial covers mostly process of creating faction out of already existing assets (or retextures of that content), same principle applies also to new content.
Since process of retexturing character equipment is slightly different from other assets like cars, buildings or weapons, this tutorial also contains small explanatory chapter about it.
Sample New Faction contains three new factions & this tutorial describes only steps necessary to prepare SampleFactionREDFOR. Steps for BLUFOR & GREENFOR factions are basically the same as for REDFOR faction.
File structure
New faction requires quite elaborate structure (based on Arma_Reforger:Directory_Structure page) and below there is tear down of it:
Character configuration
Retexturing existing equipment
One of the first steps of creating a retextured piece of equipment is actually creating a new prefab. In this tutorial, a new red variant of CombatBoots_Soviet_01.et prefab will be created. This can be done either through:
- Inherit option in Resource Browser
- By dropping instance of prefab to World Editor & then making a new prefab by grabbing that instance back selected folder in Resource Browser
In both cases, goal is to create CombatBoots_Soviet_01_red.et prefab inside Sample New Faction addon structure.
In comparison to other assets, character equipment is bit more complicated to retexture. MeshObject component of wearable equipment is actually not being used for showing the object and instead, visuals are controlled through Worn Model & Item Model properties. One of them define model which is visible when character is wearing given object (Worn Model property) and the other one is used when item is lying on a ground as an prop which can be picked up by other characters (Item Model property).
Those two parameters accept both XOB models and prefabs as well. In both cases, new materials can be created by for instance duplicating existing materials. In this case, CombatBoots_Soviet_01.emat was duplicated to SampleMod_NewFaction addon as CombatBoots_Soviet_01_red.emat and then color was changed by simply editing Color property in that new material.
Before proceeding further, prepare new materials
Creating retextures using prefabs
Creating prefabs for retextures is quite easy since process process is exactly same as for regular items.
Those new prefabs should be as simple as possible and they can be created by simply dragging XOB model to World Editor view port. As a result of that action, a new Generic Entity instance with MeshObject component is created and there, assigned materials can be changed as on any other entity. Once assigned materials are adjusted, this entity can be transformed to prefab by grabbing it from Hierarchy list to desired folder in Resource Browser window.
File:armareforger-new-faction-equipment-new-variant.mp4
Creating retextures using overrides
Alternatively, as mentioned before, it is also possible to use Materials Override parameters which are located under Worn & Item Model parameters.
In this case, it is necessary to add new element in Materials Override list and after that assign desired material to that property. If everything is done correctly, Workbench view port should show changed materials.
Under the hood, engine is remaping all materials assigned to this asset in order specified by Materials Override list, therefore caution is recommended since it might happen that order of materials changes after some data tweak. In this case responsibility falls into user hands and order of the materials has to be adjusted manually by the author of mod!
Those steps need to be performed for both Worn & Item Models. After that is completed, those new prefabs can be assigned to those two respective fields in BaseLoadoutClothComponent.
Additionally, it might be also worth to adjust Preview Model in SCR_UniveralInventoryStorageComponent > Custom Attributes > PreviewRenderAttributes, which controls how equipment is visible in inventory menu. Please note that right now this entry doesn't support material overrides and only prefabs with custom materials can be used.
In this tutorial, following prefabs (with respective item & worn variants) were created for REDFOR faction:
- CombatBoots_Soviet_01_red.et + (CombatBoots_Soviet_01_item_red.et & CombatBoots_Soviet_01_wear_red.et) - retexture of CombatBoots_Soviet_01.et
- Helmet_SSh68_01_red.et + (Helmet_SSh68_01_item_red.et & Helmet_SSh68_01_wear_red.et ) - retexture of Helmet_SSh68_01.et
- Jacket_M88_red.et + (Jacket_M88_item_red.et & Jacket_M88_wear_red.et) - retexture of Jacket_M88.et
- Pants_M88_red.et + (Pants_M88_item_red.et & Pants_M88_wear_red.et) - retexture of Pants_M88.et
- Vest_Lifchik_red.et + (Vest_Lifchik_item_red.et & Vest_Lifchik_wear_red.et) - retexture of Vest_Lifchik.et
- Vest_Lifchik_GL_red.et + (Vest_Lifchik_GrenadeBelt_item_red.et & Vest_Lifchik_GrenadeBelt_wear_red.et ) - retexture of Vest_Lifchik_GL.et
This set should be enough to have truly red faction.
Creating new characters prefabs
Preparing base character
Before proceeding with creating specific characters types like rifleman, medic or driver, it is generally a good practice to establish a base prefab, which will be used through the faction. Such prefab can contain common configuration like:
- Faction
- Radio protocol
- Identity
- Common parts of equipment (jacket, pants, boots and accessories)
In this example, Character_Base.et prefab is used to create Character_SampleFactionREDFOR_Base.et - a base for all REDFOR faction characters. Inheriting from Character_Base.et prefab should provide a solid base with all necessary components in a state, where only minor adjustments are necessary.
Configuring new characters
Below there is a table with most essential components which will be adjusted in further steps
| SCR_CommunicationSoundComponent | Defines radio protocol which will be used by this character | 
| SCR_CharacterInventoryStorageComponent | Main component which controls character inventory | 
| CharacterIdentityComponent | This component holds information about identity of character like head, base body & voice type | 
| BaseWeaponManagerComponent | This component controls which weapon is equipped by default | 
| BaseLoadoutManagerComponent | Defines character loadout like uniform, vest or harness, headgear, etc | 
| FactionAffiliationComponent | Defines to which faction this unit belongs to. | 
| SCR_EditableCharacterComponent | This component contains in-game related configuration like preview pictures, attributes, display name or budget | 
| SCR_InventoryStorageManagerComponent | This components controls what items are preassigned to character & in which part of equipment they should be stored in | 
| CharacterWeaponSlotComponent | Those components are used to control how many weapons (& what types of weapons) can have, | 
| CharacterGrenadeSlotComponent | This slot controls hand grenade logic | 
Changing used radio protocol
Starting with SCR_CommunicationSoundComponent', a default radio protocol will be changed by adjusting assigned audio configuration project files in Filenames property'. In this tutorial, default, English radio protocol will be replaced with Russian variant, which uses _RU suffix.
Changing character identity
Identity of character defines their voice variant (Voice parameter), visual appearance (Head & Body parameters) & name - all that configuration is stored in CharacterIdentityComponent. Unless working with custom model, there is no need to touch Body Meshes Config, since default values provide optimal configuration for wounded & healthy character materials.
By default, character identity will be randomly generated using parameters stored in faction config (this described later on that page) and values used in this component will be used only if Override property is checked.
Changing character faction
Character faction affiliation determines faction to which unit belongs to. Unlike in previous Arma titles made on Real Virtuality engine, characters in Reforger are no longer divided into few hardcoded sides but instead, faction system is used. In this setup, it is possible to setup alliances between factions in more flexible way depending on the mission creator needs.
Faction affiliation property is stored in FactionAffiliationComponent. This is fairly simple component which accepts name of faction provided as string in Faction affiliation parameter. Even without faction config ready (which creation process will be described in later part of this document), it is possible to write name of desired faction - in this case it is SampleFactionREDFOR - and create rest of configuration later.
Changing character outfit
Main character equipment configuration is stored in BaseLoadoutManagerComponent. In this component, it is possible to add slots, which determine what kind of prefabs are attached to the character, their type (used by inventory system) and what part of base body should be hidden when selected piece of equipment is worn - both to save performance and avoid mesh clipping.
Character_Base prefab contains six major slots which are currently handled by inventory system and in most cases there is no need to add more of them. Below is list of all currently supported slots:
- Helmet
- Jacket
- Pants
- Boots
- Vest
- Backpack
Slots inherited from Character_Base contain properly defined Name, Area & Meshes To Hide properties so in this case, only thing to do is changing prefab (through Prefab property ) which is used on selected slots.
In this tutorial all REDFOR faction characters are using same Helmet, Jacket, Pants & Boots, so it's safe to proceed further and assign previously created Helmet_SSh68_01_red.et, Jacket_M88_red.et, Pants_M88_red.et, CombatBoots_Soviet_01_red.et to their respective slots in SampleFactionREDFOR_Base prefab. Vest & backpack will be assigned in later part of this tutorial to appropriate character classes.
Adding items to character storage
Once character have basic clothing assigned, it is possible to start linking some key items to REDFOR faction base prefab. Items are linked via SCR_InventoryStorageManagerComponent and with this component it is possible to precisely select where given items are stored.
Goal here would be equipping Character_SampleFactionREDFOR_Base with single first aid kit to jacket & few other elementary items like compass, map & radio to character pants.
By default, Initial Inventory Items array is empty and new elements have to be added via plus button . Each element in the array represents a single container which is linked through Target Storage property to one of the prefabs attached to character. Jacket & pants are two separate containers so two new ItemsInitConfigurationItem elements have to be created in Initial Inventory Items array.
Once that is done, it is possible to change Target Storage of those newly created Initial Inventory Items elements. Starting with first element, Prefabs/Characters/Uniforms/Jacket_M88_red.et was selected from Target Storage drop-down menu of first entry of Initial Inventory Items array. This mean that Jacket_M88_red that all prefabs listed in Prefabs to Spawn array will be created in this container. New elements in Prefabs To Spawn array can be added via plus button and in this case only single new entry has to be added. After that is complete, first aid kit (FieldDressing_USSR_01.et) prefab can be assigned to that newly created slot.
Exactly same procedure can be used to add map (PaperMap_01_folded.et), compass (Compass_Adrianov.et), flash light (Flashlight_Soviet_01.et) & radio (Radio_R148.et) to pants. In this case Prefabs/Characters/Uniforms/Jacket_M88_red.et should be used as Target Storage and Prefabs To Spawn array should consist from 3 elements.
Creating character variants
Creating inherited variants
With base character ready, it is time to create actual units which can be used in various game modes or in-game editor. Using  Inherit option in Resource Browser, following new prefabs were prepared:
- Unarmed - Character_SampleFactionREDFOR_Unarmed.et
- Grenadier - Character_SampleFactionREDFOR_GL.et
- Rifleman - Character_SampleFactionREDFOR_Rifleman.et
- Medic - Character_SampleFactionREDFOR_Medic.et
- Machine Gunner - Character_SampleFactionREDFOR_MG.et
- Squad Leader - Character_SampleFactionREDFOR_SL.et
At this point, all those prefabs have identical equipment and their individual equipment can be tweaked. In case of Unarmed character, it can be left as it is, since equipment from base class should fit that role. Rest of the classes require some additional work and in this tutorial whole process of adding weapon & additional equipment to character will be explained on Machine Gunner character.
First thing in that process is adding additional equipment - in this case it is harness with pouch for machine gun magazine & backpack. Machine gunner harness (Vest_SovietHarness_MG.et) has to be assigned to Vest slot & backpack for extra magazines (Backpack_Veshmeshok.et) has to be assigned to Backpack slot.
Changing weapons
Characters inheriting from Character_Base.et are using 4 weapon slots. Three of them are using CharacterWeaponSlotComponent, where two of those are used for primary weapons like rifles or launchers, one is used for secondary armament like handguns and single CharacterGrenadeSlotComponent is used, as name would suggest, for throw able items like hand grenades.
Machine Gunner class prepared in this tutorial is supposed to have following loadout:
- PKM machine gun on first primary slot (MG_PKM.et)
- Makarov handgun on secondary slot (Handgun_Makarov.et)
- RGD-5 grenade on grenade slot (Grenade_RGD5.et)
Starting with PKM machine gun, first thing to do is locating correct CharacterWeaponSlotComponent. Since goal is to have that PKM machine gun in first primary slot, values of Weapon Slot Type & Weapon Slot Index has to be verified. In this case, component with Weapon Slot Type should have value " primary" and Weapon Slot Index should be set to 0.
Once that component is located, the only thing left to do is changing assigned prefab in Weapon Template by either clicking on select button or by dragging & dropping MG_PKM.et prefab on Weapon Template property.
Next on the list is PM handgun, which should be assigned to CharacterWeaponSlotComponent with Weapon Slot Type set to " secondary" and Weapon Slot Index set to 2. Same as with PKM machine gun, Weapon Template property has to be modified so Handgun_PM.et is assigned to that field.
Grenades follow exactly same logic and in this case its even bit easier, since there is only one CharacterGrenadeSlotComponent . After locating that component, Grenade_RGD5.et prefab can be assigned to Weapon Template property.
Adding magazines to loadout
In principle, procedure of adding magazines to loadout is same as for items. In case of machine gunner, additional complication is fact that there are more prefabs to choose from due to additional loadout elements like harness and backpack. Equipment prefabs can consist of multiple child prefabs and in case of Vest_SovietHarness_MG.et, magazine pouch is a separate item attached to the harness itself.
In this example, one magazine is added to Prefabs/Items/Equipment/Accessories/Pouch_Soviet_100rnd_PKM/Pouch_Soviet_100rnd_PKM.et - which is part of Vest_SovietHarness_MG.et prefab - and two magazines goes to backpack Prefabs/Items/Equipment/Backpacks/Backpack_Veshmeshok.et. Additionally, one smoke grenade was added to backpack
Vehicle configuration
Creating vehicle variants
Creating vehicle variants is fairly simple as it can be done in two steps:
- Creating inherited variant (either through  Inherit in action in Resource Browser in World Editor view port itself) of selected vehicle prefab in target addon
- Changing Faction affiliation parameter in FactionAffiliationComponent
Even if materials of vehicles are not changed, changing faction affiliation is quite important for AI systems and some of the game modes, so those extra faction specific prefabs are sort of mandatory if its planned to equip new faction with some vehicles.
Groups
Creating groups
It is recommended to create new groups by inheriting from Group_Base.et prefab which has all necessary components already in place. Procedure for it is same as for any other prefabs and it is possible to either use Inherit in Addon option in Resource Browser or go through World Editor view port flow.
Similar as with characters, when preparing set of new groups for a faction, it is also good habit to create base prefab for all groups so the first step here will be creating Group_SampleFactionREDFOR_Base.et which is inheriting from Group_Base.et . After that, rest of the groups can be created using previously prepared Group_SampleFactionREDFOR_Base.et prefab as base. In this tutorial, following small unit rooster is prepared:
- Group_SampleFactionREDFOR_RifleSquad.et
- Group_SampleFactionREDFOR_FireGroup.et
- Group_SampleFactionREDFOR_LightFireTeam.et
Basic group setup
Starting with adjusting Group_SampleFactionREDFOR_Base.et, adjustment has to be performed in properties located directly in entity configuration.
First step towards having a working group prefab will be modifying Faction property located in Groups tab & filling into that property name of target faction - SampleFactionREDFOR in this case.
Next on the list is adjusting of SCR_GroupIdentityComponent and setting there identity used by all SampleFactionREDFOR unit. This component is purely used for UI representation of group in game and it affects what kind of icon is used in both 3D interface and on 2D map. Changing Identity property to OPFOR will be result in hostile forces markers according to NATO APP-6 specification. Rest of those parameters like Icons or Amplifiers can be changed per specific group and is described in detail in later part of this tutorial.
Changing group composition
After basics are done, it is time to move forward and start editing actual composition of groups. Composition of groups is set directly in entity properties and is controlled through Unit Prefab Slot parameter in Group Members tab. Over there it is possible to simple add new groups slots via plus button and then assign character prefabs to them.
Factions
Creating faction config
Basic configuration
New faction configs can be only created either by duplicating (via Duplicate in "addon name" option) one of the existing configs one or by inheriting from existing faction through Inherit in "addon name" option.
First of all, it is necessary to get configs which we want to duplicate or inherit from in the addon itself. To do so, first we navigate to Configs→ Factions folder and there, it is possible to use Override in addon functionality located in context menu of Resource Browser. OPFOR.conf (both of them are located in Configs/Faction folder) can be used for inheritance and USSR.conf for duplication.
Retail version of game has packed data and its content locked - that's why such workaround has to applied. In all other cases this step can be skipped
Next step is creating either inherited config (in case OPFOR.conf was copied) through  Inherit option or creating duplicated file via Duplicate option if USSR.conf was transferred to addon. In both cases, a new config will be ready to be filled with actual data relevant to new faction.
| Faction Key | Unique identifier of the faction that was filled in i.e. FactionAffiliationComponent | SampleFactionREDFOR | 
| Faction Color | This option determines which color will be used to represent this faction in various UIs like in-game editor or game modes | 244,5,6,255 | 
| Name | Display name of faction | Sample Faction - REDFOR | 
| Description | Description to be displayed in players UI | |
| Icon | Icon representing this faction in players UI. Recommended size: 128x128px | flag_red_ca.edds | 
| Name Upper | Display name of faction in upper case | SAMPLE NEW FACTION - REDFOR | 
| Identity of soldiers | FactionIdentity_USSR.conf | |
| Is Playable | Controls if the faction will appear in players respawn menu | True | 
| Faction Flag | Flag representing this faction in players UI. Recommended size: 800x400px. Same texture as for Icon can be used | flag_red_ca.edds | 
| Faction Flag Material | Faction flag material - used on flag poles in f.e. Conflict | |
| Faction Label | Default faction loadout - this option is currently used (& defined) in Conflict only | |
| Friendly To Self | Are units in this faction friendly to itself? Used in Death Match scenarios | |
| Friendly Factions Ids | List of friendly Faction Keys | |
| Callsign Info | This class controls group callsigns available to this faction. Used in Conflict & in-game editor | Callsigns_USSR.conf | 
| Ranks | Military ranks available to given faction. Can be used to give custom, localised titles per faction | |
| Entity Catalogs | List of Entity Catalogs used by this faction. Determines what is i.e. available in Arsenal crates of selected faction | |
| Group Flags | Flag icon for group | |
| Group Flags Image Set | Flag imageset for groups of this faction | |
| Flag Names | Markers names available in Group Flags Image Set | |
| Base Callsigns | Call signs of bases. Used i.e. in Conflict for randomised bases names. | 
Faction identity
In case of Identity of soldiers and Callsign Info, it is possible to use already existing configs, which can serve as a templates. Here, SampleFactionREDFOR is going to use FactionIdentity_USSR.conf and Callsigns_USSR.conf. This can be achieved by drag & dropping those config files on respective fields:
- FactionIdentity_USSR.conf (Configs/Identities) is assigned to Identity of soldiers parameter
- Callsigns_USSR.conf (Configs/Callsigns) is assigned to Callsign Info property
Integration with in-game editor
Adding new faction to in-game editor
Adding new faction label
All labels usable by in-game editor are defined in EEditableEntityLabel enumerator. New entries can be added to it by using modded keyword. To do so, a new script file with unique name (you can use mod tag as prefix) have to be created and in this tutorial EEditableEntityLabel.c file was created in Scripts\Game\Editor\Enums\Modded folder. Afterwards, adding new labels is as simple as adding new all caps entry & assigning to it a number.
Once that is done, scripts can be recompiled and new label should be available in drop down menu of various in-game editor properties.
Adding new faction to Editable Entity Core
Once there is a label available, it is possible to
- Use Override in addon function on EditableEntityCore.conf located in Configs/Core folder
- Add new entry to Entity Labels array. Info part is using typical SCR_UIInfo layout
| Name | Display name of faction | REDFOR | 
| Description | Description to be displayed in players UI | |
| Icon | Icon representing this faction in players UI. Recommended size: 64x64px | flag_red._ca.edds | 
| Icon Set Name | - | |
| Order | Integer used to manually modify order of label. Labels with higher numbers are listed first | |
| Label Type | Label from EEditableEntityLabel enum which should be evaluated | FACTION_REDFOR | 
| Label Group Type | Type of label - is it faction, trait, vehicle? | FACTION | 
| Filter Enabled | True | 
Registering characters, groups & vehicles
Detailed instructions on how to add assets to in-game editor can be found on Asset Browser Mod Integration page and it is highly recommended to make yourself familiar with before proceeding anywhere further. Below are some general notes on how the process was performed for SampleFactionREDFOR related assets.
Adjusting generators configs
Before registering new assets, it is necessary to make some adjustments in config, so  Register Placeable Entities plugin can work as intended. This plugin is using EditablePrefabsConfig.conf to run some rules which populate register of prefabs. This config links to few more sub configs and in case of Characters & Vehicles, EditablePrefabsComponent_EditableEntity.conf is used to determine faction label.
New rule can be added to EditablePrefabsComponent_EditableEntity.conf in few steps described below:
- Use Override in addon function on EditablePrefabsComponent_EditableEntity.conf located in Configs/Workbench/EditablePrefabs folder
- Add EditablePrefabsLabel_Faction entry to Entity Label Rules array
- Select FACTION_REDFOR in Label drop down menu
- Adjust Faction To Check parameter by typing name of faction: SampleFactionREDFOR (it should be same string as in Faction affiliation parameter in FactionAffiliationComponent of characters or units)
Once those steps are complete, it is important to save all changes through Ctrl+S shortcut. In some rare cases changes applied to that config might need full restart of the Workbench.
Adding assets to register
After EditablePrefabsComponent_EditableEntity.conf is adjusted, it is time to move forward and start t
- Create new config files using SCR_PlaceableEntitiesRegistry class for:
- Characters ( Characters_SampleFactionREDFOR.conf )
- Groups ( Groups_SampleFaction.conf )
- Vehicles (Vehicles_SampleFaction.conf)
 
- Adjust Addon parameter in all those configs so it matches target addon (SampleMod_NewFaction)
- Adjust Source Directory to match location of the prefabs
Once those steps are completed, it is now possible to use  Register Placeable Entities plugin on all assets which should be available in in-game editor. To do so, select in Resource Browser prefabs which you want to register and then navigate to Plugins -> In-game editor section in top bar and click on Register Placeable Entities. In new pop up window select config for assets which you want to register (i.e. if you have characters selected, select Characters_SampleFactionREDFOR.conf) and click on Run button.
This action should both generate placeholder images for assets previews & adjust Auto Labels assigned in one of the respective components like SCR_EditableCharacterComponent, SCR_EditableVehicleComponent or SCR_EditableGroupComponent.
Adjusting editable prefabs configuration
After processing prefabs with  Register Placeable Entities plugin, assets will still need some manual adjustment to i.e. Authored Labels or Military Symbol (in case of groups) configuration. Also, in most cases it will be necessary to add proper display name to assets. In case of characters, some existing localised strings can be used
Table with localised strings
Characters
In case of characters, beside changing Name of assets in in-game content browser, few additions are necessary to Authored Labels array in SCR_EditableCharacterComponent. Plugin responsible for automatic assignment of labels is not being able to distinguish character types automatically in current state so character role types has to be adjusted by hand. For example, Squad Leader (Character_SampleFactionREDFOR_SL) can receive ROLE_LEADER, Medic can get ROLE_MEDIC, Machine gunner - ROLE_MACHINEGUNNER and so on.
Additionally, characters can also receive additional traits like, TRAIT_ARMED, TRAIT_UNARMED or TRAIT_MEDICAL, which improves filtering in in-game content browser.
Vehicles
When it comes to vehicles, it usually boils down to adding special vehicle traits like TRAIT_ARMED, TRAIT_UNARMED, TRAIT_REFUELING, etc. Some custom labels can be also established based on the needs but by no means its not necessary.
Groups
Similar to characters, also groups can use one of the already existing strings for Name property.
Table with localised strings
| String | Display Name | 
| AR-Group_AntiTankTeam | Anti-Tank Team | 
| AR-Group_Default | Infantry Group | 
| AR-Group_FireTeam | Fire Team | 
| AR-Group_FireTeamLight | Light Fire Team | 
| AR-Group_GrenadierTeam | Grenadier Team | 
| AR-Group_Guerrilla_FireTeam | Guerrilla Fire Team | 
| AR-Group_Guerrilla_HQ | Guerrilla HQ | 
| AR-Group_Guerrilla_MGTeam | Guerrilla Machine Gun Team | 
| AR-Group_Guerrilla_ReconTeam | Guerrilla Recon Team | 
| AR-Group_Guerrilla_SharpshooterTeam | Guerrilla Sharpshooter Team | 
| AR-Group_Guerrilla_Squad | Guerrilla Squad | 
| AR-Group_LightAntiTankTeam | Light Anti-Tank Team | 
| AR-Group_ManeuverGroup | Maneuver Team | 
| AR-Group_MedicalSection | Medical Support Team | 
| AR-Group_MGTeam | Machine Gun Team | 
| AR-Group_MortarSquad | Mortar Team | 
| AR-Group_PlatoonHQ | Platoon HQ | 
| AR-Group_SniperTeam | Sniper Team | 
| AR-Group_Squad | Rifle Squad | 
| AR-Group_SuppressiveFireTeam | Base of Fire Team | 
Compared to vehicles & characters though, there are no group related labels which have to be filled manually.
However, groups also have special Military Symbol class, which holds information about icon which is visible in in-game editor above groups.
Using checkboxes & drop menus available there, it is possible to assign one of NATO APP-6 icon to selected group.
Adding new faction to Faction Manager
One of the remaining steps towards integrating new faction into in-game editor is adding it to list of available factions. This can be done in two easy steps:
- Use Override in addon function on FactionManager_Editor.et located in Prefabs/MP/Managers/Factions folder
- Add new element to Factions array by drag and dropping faction config on that property
- Uncheck Is Playable parameter inside of SCR_Faction entry inside Factions array - by default, when Game Master session starts, there should be no factions available and it should be up to Game Master to decide which are
After that, faction should be selectable in respawn menu during game master sessions & assets should be using proper colorization in content browser.
Creating new spawn points
Spawn points are a special type of prefabs which are used to determine where player of given faction can spawn.
Preparing new spawn point prefab
First step will be creating new spawn point prefab - it is quite easy and involves following steps:
- Using Resource Browser, find SpawnPoint_Base.et prefab
- Click on it with Right Mouse Button and select option Inherit in Addon
- Type name of new prefab (i.e. SpawnPoint_REDFOR)
- Open prefab created in previous step (SpawnPoint_REDFOR in this case) either by by using prefab edit mode or placing this prefab in World Editor
- In that prefab type name of your faction (SampleModFactionREDFOR) in Faction parameter
- Save your changes (using e.g Ctrl + S)
Creating editable variant of spawn point
After creating base variants, it will be still necessary to make editable variant, which can be used directly in Game Master. Unlike before, editable variant of spawn point have to be created manually and below you can find instructions how to do it:
- In Resource Browser, find E_SpawnPoint.et
- Click on it with Right Mouse Button and select option Inherit in Addon
- Type name of new prefab (i.e. E_SpawnPoint_REDFOR)
- Open prefab created in previous step (E_SpawnPoint_REDFOR in this case) either by by using prefab edit mode or placing this prefab in World Editor
- In properties of SCR_SpawnPoint entity locate Faction parameter in unsorted category and write there name of the faction (SampleFactionREDFOR)
- In SCR_EditableSpawnPointComponent component do following changes:
- Write name of your faction in Faction parameter
- Assign texture to Image property. Currently all factions are using same texture, even though there are separate file names for them, so it's possible to use i.e. E_SpawnPoint_USSR.edds
- In Authored Labels array add two new elements: TRAIT_SPAWNPOINT (it is missing in base class) and label of your faction (in this case it is FACTION_REDFOR)
 
- In SCR_FactionAffiliationComponent adjusted Faction property and write there name of your faction (SampleFactionREDFOR)
If everything went fine, spawn point should be ready to be plugged in into Game Master
Registering spawn point
Once editable spawn point prefab is ready, it is still necessary to register it in Game Master. This process is well described on Asset Browser Mod Integration and below is shortened version of it:
- Duplicate to addon Systems.conf and call it i.e. Systems_SampleFaction.conf
- Open new config in Resource Manager
- Clear Prefabs array by clicking on little arrow (1) on the right side
- Add editable Spawn Point (E_SpawnPoint_REDFOR.conf) to Prefabs array
- Optionally: Modify Addon field so it matches addon name - in this case it would be SampleMod_NewFaction
- Save the config
When config is ready, it is possible to register it in EditorModeEdit.et prefab as described on Asset Browser Mod Integration page.
Generating editor previews
Units, groups & vehicle previews used by in-game editor can be easily generated by using steps described on Game Master: Image Generation Tutorial page & by loading Eden_AssetImages.ent world to generate those pictures. If previous steps were done correctly & assets were properly registered, then new images should be immediately available after generation process is completed.
Integration with Conflict game mode
Adding Conflict specific prefabs & configs
Creating Conflict specific configs
Faction config
Conflict is using extended version of regular faction config, which allows to configure ranks, available structures, default AI groups, vehicles or radio equipment. Since this specialised version of config is extension of default SCR_Faction class, it is recommended to inherit from previously created SCR_Faction config - in this case it is SampleFactionREDFOR.conf.
Easiest way to create such config is using  Inherit option on SampleFactionREDFOR.conf. Once new config is created - named i.e. SampleFactionREDFOR_Campaign.conf. After this is complete, this file can be edited in text editor of your choice and SCR_Faction on first line of file
can be replaced with SCR_CampaignFaction like on example below.
Once this adjustment is saved, it might be necessary to restart whole Workbench in order to have that change correctly loaded.
Afterward, class indication SampleFactionREDFOR_Campaign.conf should correctly show SCR_CampaignFaction class (see green area on picture below).
By default, resulting config will be quite empty and most of the Conflict specific parameters have to be filled by hand. Using table below, SampleFactionREDFOR_Campaign.conf was populated with all necessary data.
| Group | Parameters | Description | 
|---|---|---|
| Ranks | Ranks that players can gain through the game | |
| Radio | Faction Radio Encryption Key Faction Radio Frequency | Controls default frequency and | 
| AI | AI Group Prefab AI Vehicle Prefab Defenders Group Prefab Default Transport Prefab Spawn AIs | Configuration of AI groups like base defenders or attacking squads | 
| AI (Independent) | Remnant Groups | AI groups spawned by INDFOR side on territory they are controlling. | 
| Structures | Radio Prefab Base Building XXX | Buildings & equipment used by factions | 
| Compositions | Campaign Slot Compositions | Compositions which can be build by this faction | 
Vehicle list
Pool of available for request vehicles is defined in config file using SCR_CampaignVehicleAssetList class. By default, Conflict is using VehicleAssetList.conf located in Configs/Campaign folder and this file is a good candidate for a custom variant. After clicking on VehicleAssetList.conf with Right Mouse Button , Duplicate option can be selected from context menu and new config file - like VehicleAssetList_SampleNewFaction.conf - can be prepared.
It is also possible to create new SCR_CampaignVehicleAssetList config from scratch through Create→ Config File too.
Having a new config file ready, it is possible to start adjusting thing inside of it. Every element inside of Vehicle Asset List array represents an vehicle which can be requested at Vehicle Depot by one of the sides participating in Conflict game mode. In case when VehicleAssetList.conf was duplicated, only things which need to be changed are Prefab & Prefab Opposite parameter.
Prefab parameter controls which asset will be spawned when this vehicle is requested in-game. In this tutorial REDFOR faction vehicles are going to be replaced with variants used by SampleFactionREDFOR faction and for instance UAZ469.et prefab is being replaced with UAZ469_SampleFactionREDFOR.et.
Once replacement is completed on REDFOR vehicles, it also necessary to go through BLUFOR vehicles and update there assets assigned in Prefab Opposite parameter with current SampleFactionREDFOR counterparts. This parameter is mainly used when opposing faction captures vehicle depot with some vehicles being still available there. In this scenario, enemy vehicles will be still available to request but they will also consume total capacity of such depot. For instance if BLUFOR captures depot with 8 UAZs, then in next reinforcement wave only two additional M151A2 cars will be added to the pool.
Conflict game mode supports only three sides in game and those are available in Faction drop down menu:
- BLUFOR - represent first playable team, which fights for control over the island with REDFOR & INDFOR forces
- REDFOR - represent second playable team, which fights for control over the island with BLUFOR & INDFOR forces
- INDFOR' - represent non playable independent forces which are fighting with both BLUFOR & REDFOR forces'. This faction holds at the beginning majority of the bases
Actual factions linked to BLUFOR, REDFOR & INDFOR are defined in CampaignMPGameMode prefab which is placed and can be modified in Campaign world itself. More information about this feature can be found in chapter describing Conflict world.
Since SampleFactionREDFOR is using color retextures of existing vehicles, it is possible to leave Display Name & Display Name UC parameters intact.
In case config is being set of scratch, following table can be used as reference for making list of available vehicles.
| Property | Description | 
|---|---|
| Prefab | Prefab of a vehicle which can be requested | 
| Faction | One of the | 
| Display Name | Name which will be shown in UI (i.e. request menu) | 
| Display Name UC | Same as above but in upper case | 
| Rank ID | Lowest rank which can request this vehicle | 
| Max | Max amount of assets of that type that a base can hold | 
| Starting Amount | Amount of vehicles available at mission start | 
| Reinforcements Amount | Amount of vehicles which are added in reinforcement wave | 
| Prefab Opposite | Opposing faction vehicle counterpart. This parameter is used mainly to correctly recognise maximal capacity of a vehicle depot | 
Adding Conflict specific prefabs
Conflict game mode requires few specialised prefabs in order to run properly. For starter, Conflict requires unique character prefabs - both for AI & players. All those Conflict specific characters are located in Prefabs/Characters/Campaign folder and similar structure is used also for REDFOR faction. Player characters used in Conflict game are typical characters, often derived from existing troops, with addition of few extra components:
- SCR_ResourceComponent - used for handling Conflict related interactions with supplies
- SCR_CampaignBuildingComponent - used for handling of in-game construction of structures
- MapDescriptorComponent - used for correctly showing unit on map
Player Character
Beginning with Conflict player character, a new Campaign_SampleFactionREDFOR_Player.et prefab can be created by inheriting from one of already existing SampleFactionREDFOR character - i.e. Character_SampleFactionREDFOR_Rifleman.et - using for example  Inherit option.
In case of SCR_ResourceComponent, it is necessary to add new component via "+ Add Component" . After that, it will be still necessary to add one element to Consumers array of that component. This can be achieved by drag & dropping Consumer_Self.conf from Resource Browser onto Consumers array in SCR_ResourceComponent in Object Properties window. After that, a SCR_ResourceComponent component should contain all necessary data for Conflict game mode.
Similar to SCR_ResourceComponent, the other two components - SCR_CampaignBuildingComponent & MapDescriptorComponent have to be added manually through "+ Add Component" button.
Once those components are added, the following tweaks can be applied:
- SCR_CampaignBuildingComponent
- No changes are necessary
 
- MapDescriptorComponent
- Descriptor Visible should be unchecked
- Descriptor Type Enum should be changed to Unit
- Descriptor Unit Enum should be changed to Infantry
 
AI Character
Next on the list is preparing friendly AI prefab - Campaign_SampleFactionREDFOR_AI.et - which can be i.e. spotted in friendly bases. Similar to player character, Character_SampleFactionREDFOR_Rifleman.et can be used as base for such prefab.
Once new AI character is created, CampaignInteractions.ct can be applied to this prefab in same way as for player prefab. This is the only required prefab for AI character and after it is added, Campaign_SampleFactionREDFOR_AI.et should be ready for action!
Adding Conflict specific groups
Main playable factions require only few extra groups which can be created based on existing group prefabs. The main difference for non playable factions (INDFOR) is the presence of Remnants Groups, which are using unique group compositions and their group members are also not being spawned immediately when given prefab is created.
This delayed spawning behavior is achieved by setting Spawn Immediately property to unchecked state.
Remnants group can be prepared in few simple steps. The whole process begins with creating faction specific Remnant group base (Group_SampleFactionREDFOR_Remnants_Base.et) prefab using Group_Remnants_Base.et prefab as parent.
In this new base prefab it is necessary to adjust Faction parameter and change it to name faction code name - SampleFactionREDFOR.
Next, it is possible to use that new prefab to create some extra groups like:
- Patrol Group (Group_SampleFactionGREENFOR_Remnants_Patrol.et)
- Fire Team (Group_SampleFactionGREENFOR_Remnants_FireTeamet)
- AT Team (Group_SampleFactionGREENFOR_Remnants_AT.et)
- MG Squad (Group_SampleFactionGREENFOR_Remnants_MG.et)
- Sniper Team (Group_SampleFactionGREENFOR_Remnants_Sniper.et)
Once those prefabs are created, only remaining thing to do is adjusting composition of those groups according to their purpose. This can be done by changing Unit Prefab Slots array. It is worth mentioning that remnants groups can use regular character prefabs. For example, AT group can consist of Character_SampleFactionREDFOR_AT.et prefab.
After all groups are created & adjusted, it is possible to assign them to remnants forces rooster. This can be done by adding new elements to Remnant Groups array in SampleFactionREDFOR_Campaign.conf. From this list, game will try to pick random groups depending on the context of area where they are supposed to be spawn (SCR_CampaignREmnantsSpawnPoint). This is done by setting Probability & Type in SCR_CampaignRemnantsGroup entry in Remnant Groups array.
Conflict attackers & defenders AI groups consist of previously created Conflict variant of AI characters. Configuration of those groups is basically the same as regular ones. Defenders groups are spawned in bases controlled by this faction and they are tasked with defending this territory. Attackers on the other hand should actively try to capture enemy bases using vehicle defined in faction config.
Starting with creation of base group for both attackers & defender, a new Group_SampleFactionREDFOR_Campaign_Base.et prefab, inheriting from regular Group_SampleFactionREDFOR_Base.et group, was created.
In this base prefab there is only one thing which need to be adjusted:
- Unit Prefab Slots array should be tweaked so only 3 Campaign_SampleFactionREDFOR_AI.et prefabs are present.
Next, using Group_SampleFactionREDFOR_Campaign_Base.et as paraent, Group_SampleFactionREDFOR_Campaign_Defenders.et was prepared. This prefab doesn't need any additional refinements.
Similar to defenders group, attacker group - Group_SampleFactionREDFOR_Campaign.et - was prepared using Group_SampleFactionREDFOR_Campaign_Base.et as parent. This prefab needs two tweaks:
- Unit Prefab Slots array should consist from 7 Campaign_SampleFactionREDFOR_AI.et characters
- Spawn Immediately parameter should be unchecked. This is done to avoid spike in load when spawning those groups across the island
Finally, when those groups are ready, they can be assigned to appropriate fields in SampleFactionREDFOR_Campaign.conf
- AI Group Prefab → Attacker group - Group_SampleFactionREDFOR_Campaign.et
- Defenders Group Prefab → Defenders group - Group_SampleFactionREDFOR_Campaign_Defenders.et
Creating new Conflict world
Using Conflict template
Adjusting scenario
After successfully copying template to the addon, it's time to change playable faction in this scenario.
In logic layer, there are three entities which have to be adjusted:
- CampaignFactionManager1 → This entity holds information about factions which can be used in this scenario
- CampaignMPGameMode1 → One of the core Conflict entities - here it is possible to adjust all kind of Conflict gameplay options.
- CampaignLoadoutManager_1 → Defines characters (loadouts) which players can select in respawn menu
Faction Manager
SCR_CampaignFactionManager Faction Manager contains list of all factions that participate in Conflict game-mode. Main parameter of that entity is Factions array where it is possible to add or replace existing factions with custom ones.
In this tutorial, default USSR faction is being replaced with SampleFactionREDFOR. Such replacement can be achieved by drag & dropping SampleFactionREDFOR_Campaing.conf on SCR_CampaignFaction element representing USSR faction inside Factions array.
Another notable thing which is set in CampaignFactionManager1 is Vehicle Asset List, which contains link to a config file containing list of available for request vehicles. In this tutorial, previously created VehicleAssetList_SampleNewFaction.conf is assigned to this parameter.
Game Mode tweaking
SCR_GameModeCampaignMP
CampaignMPGameMode1 entity contains also of various parameters but since goal here is just to change the playable faction, only faction key will be changed. Faction keys are used to connect factions defined in faction manger to one of the three playable sides in Conflict game mode.
In this tutorial, OPFOR Faction Key, located in Unsorted group of parameters, is changed from USSR to SampleFactionREDFOR.
Loadouts
SCR_LoadoutManger
Loadout manager controls which classes player can select in respawn menu. In this case, USSR loadout will be replaced with SampleFactionREDFOR variant and following parameters will have to be adjusted:
- Loadout Name → Display name of loadout in respawn menu. Here it is replaced with REDFOR string
- Loadout Resource → Prefab of spawned character. This parameter can be replaced with previously created Conflict character - Campaign_SampleFactionREDFOR_Player.et .
- Affiliated Faction → Defines to which factions belongs this loadout. Parameter was replaced with SampleFactionREDFOR
Testing results in game
Once all those changes are done, it is possible to switch into play mode by either clicking on button with green arrow or by pressing F5 shortcut.
 
	




































