Game Master: Composition Configuration Tutorial – Arma Reforger
Lou Montana (talk | contribs) (Page creation (placeholder)) |
Lou Montana (talk | contribs) m (Text replacement - "<code>" to "<code style="display: block">") |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{ | {{TOC|side}} | ||
Game Master compositions are prefabs that have to be created, configured and maintained in a specific way in order for them to work correctly in [[Arma Reforger:Game Master]]. | |||
{{GameCategory|armaR|Modding|Tutorials}} | == Creating Composition Prefab == | ||
=== Flexible === | |||
Follow these steps if the composition is meant for flexible slots (i.e., the composition can be placed anywhere in the world or in one of compatible slots). | |||
# Select '''Prefabs/Compositions/Slotted/CompositionBase.et''' and open it by ''Plugins > Edit Selected Prefab(s)'' or by pressing '''Ctrl+Shift+E'''. | |||
# Create new composition prefab by dragging '''CompositionBase''' entity from Hierarchy list to desired folder in Resource Browser. Choose the folder based on intended slot type (i.e. Flat slot, Road slot, and their respective sizes). | |||
# Name the prefab according to this key: <code style="display: block"><NAME>_<SIZE ABBREVIATION>_<FACTION>_<ID></code> | |||
#* '''NAME''' - composition name eg: RoadBlock | |||
#** Note that names have no spaces and are written with camel case. | |||
#* '''SIZE ABBREVIATION''' - L, M or S | |||
#** Large, Medium or Small | |||
#* '''FACTION''' - either '''US''', '''USSR''', or '''FIA''' | |||
#* '''ID''' - two-digit iterator starting from 01 | |||
{{Feature|informative| | |||
Naming Examples: | |||
* Flat Composition: | |||
** ''PlayerHub_L_US_01'' | |||
* Road Composition: | |||
** ''Checkpoint_S_USSR_01'' | |||
}} | |||
=== Static === | |||
Follow these steps if the composition is meant for static slots (i.e., the composition can be placed only on one specific position in the world). | |||
# Open the world on which the composition is going to be placed | |||
# Place '''Prefabs/Compositions/Slotted/CompositionBase.et''' entity on desired location | |||
# In entity's '''SCR_SlotCompositionComponent''', set the location prefab the composition belongs to | |||
# Create new composition prefab by dragging '''CompositionBase''' entity from Hierarchy list to desired folder in Resource Browser. Choose the folder based on world and location names (e.g., ''Eden/Le_Moule'') | |||
# Name the prefab according to this key: <code style="display: block"><NAME>_<FACTION>_<ID></code> | |||
#* '''NAME''' - custom name describing the composition | |||
#* '''FACTION''' - either '''US''', '''USSR''', or '''FIA''' | |||
#* '''ID''' - two-digit iterator starting from 01 | |||
{{Feature|informative| | |||
Naming Example: | |||
* ''Camping_US_01'' | |||
}} | |||
== Configuring Composition == | |||
The composition itself has several attributes that influence its behavior. | |||
[[Image:armareforger-gm-compositions-attributes2.jpg|right|400px]] | |||
* '''Slot Prefab''' | |||
** Prefab this composition can be snapped to in in-game editor. Can be either a flexible slot, or static location in the world. | |||
* '''Orient Children To Terrain''' | |||
** When enabled, children will be snapped and oriented to terrain when the composition is transformed. | |||
** This influences also position of non-editable compositions created in a flexible slot or positioned using dedicated function in the composition component. | |||
** Use this when child objects are lying on the ground, e.g., tables and chairs under a camo net, but not tables and chairs inside a house. | |||
* '''Non Editable Children''' | |||
** When enabled, children will not be turned into editable entities. | |||
** The composition will appear as a single entity in in-game editor. | |||
** Use this for smaller compositions which have a lot of smaller objects, e.g., pallets with boxes. | |||
{{Clear}} | |||
== Editing Composition == | |||
Select the composition prefab and edit it by ''Plugins > Edit Selected Prefab(s)'' or by pressing '''Ctrl+Shift+E'''. | |||
=== Prefab Editing === | |||
Keep in mind that [[Arma_Reforger:Prefabs_Basics|prefab editing]] has a few caveats: | |||
* After [[Arma_Reforger:Prefabs_Basics#Adding_entities_to_prefab|'''adding a new entity''']], move it inside the composition by '''Alt+LMB drag''', not just by LMB drag. How to tell them apart... | |||
{| role="presentation" class="wikitable mw-collapsible mw-collapsed" | |||
| <strong>How to tell them apart...</strong> | |||
|- | |||
| | |||
* Entity added to composition instance ('''LMB drag''') will have its own prefab mentioned in Hierarchy's ''prefab'' column. | |||
* Entity added to composition prefab ('''Alt+LMB drag''') will have the composition prefab in the ''prefab'' column. | |||
[[Image:armareforger-gm-compositions-prefabs-column.png]] | |||
|} | |||
* When '''editing entities''', only their instances are modified. Follow these steps to apply changes to prefab: | |||
*# Select modified entities | |||
*# Click on '''Apply to prefab''' at the bottom of Object properties panel. | |||
*# In the dialog window, leave the composition prefab selected, but tick '''Apply to transformation''' option | |||
*# Confirm | |||
* '''Save all changes''' to the prefab by saving the world ('''Ctrl + S''') | |||
** Until the world is saved, no changes (not even the ones manually applied using Apply to prefab button) are saved into prefab file. | |||
* To [[Arma_Reforger:Prefabs_Basics#Deleting_entities_from_prefab|'''delete an entity''']], use ''RMB > Delete from prefab''. Pressing 'Delete' key would simply try to remove an instance of the entity. | |||
=== Technical Rules === | |||
In later stages, following rules will be automatically checked by Workbench plugin. | |||
* '''Use only entities from ''Prefabs'' folder''', not from ''PrefabsEditable'' folder! Conversion to editable variants is performed automatically in the next step. | |||
* Entity '''bounding boxes should not extend past the borders''' of the slot! You can see the bounding boxes by hovering over entities with the mouse, and entities that do cross this boundary while part of the composition prefab will show a warning. This is done to ensure compositions align well with slots in the world. | |||
=== Tips === | |||
* To toggle surface clutter, use ''[[Arma Reforger:Diag Menu|Diag Menu]] > Render > Terrain grass > Render grass''. Use this sparingly, as creating the composition without grass can provide inaccurate representation. | |||
* If your composition contains some editable prefabs, you can convert them back to their sources using ''Plugins > In-game Editor > Convert to/from Editable Entities...'', and the choosing '''To Non-editable'''. | |||
{{Feature|warning|Steps below are applicable if you're making a composition that should be editable in in-game editor. | |||
If that is not the case, please click RMB on '''SCR_SlotCompositionComponent''' and choose '''Configure composition''' before saving and committing. | |||
This will make sure the composition is set-up correctly, e.g., all child entities are in hierarchy. Conversion to editable variant performs this step automatically.}} | |||
== Creating Editable Variant == | |||
When you're done editing the composition, auto-generate its editable variant. To do so, follow the configuration guide: | |||
=== Selecting compositions === | |||
In Resource Browser, '''select prefab files''' (*.et) of entities you want to process. | |||
Check editable entity types to see which prefabs should be marked as editable. | |||
''Tip: Both Resource Manager and World Editor browsers are supported, but not Resource Manager'' | |||
=== Creating editable prefab === | |||
With files selected, activate '''''Plugins > In-game Editor > Create/Update Selected Editable Prefabs''''' | |||
''Tip: You can also press '''Ctrl+Shift+U''' to perform this action.'' | |||
After the operation is done, please check the log, it will list all processed prefabs. They can end up with one of the following states: | |||
* '''Created / Updated''' - successful processed | |||
* '''Failed''' - unable to generate the prefab, most commonly due to presence of child entity with RplComponent | |||
* '''Non-editable''' - some child entities which don't have editable prefab variant were detected. Please revise them and consider if some of them could be made editable as well. | |||
=== Updating editable prefab === | |||
Editable prefabs needs to be regenerated every time the source prefab changes. This can be achieved by several ways: | |||
* Activate '''''Plugins > In-game Editor > Update All Editable Prefabs''''' | |||
** This will update all auto-generated editable prefabs. | |||
** It will also handle renamed / moved / deleted source prefabs (enable '''Only File Changes''' attribute to perform this operation only). | |||
* Select an editable or a source prefab and activate '''''Plugins > In-game Editor > Create/Update Selected Editable Prefabs''''' | |||
Changes will be made in '''PrefabsEditable/Auto''' as well as '''UI/Textures/EditorPreviews/Auto''' folders | |||
{{Feature|informative|Repeat those steps every time you perform changes in existing composition.}} | |||
== Registering Composition == | |||
# In Resource Manager, activate '''''Plugins > In-game Editor > Register Placeable Entities...''''' | |||
# Set config to {{Link|enfusion://ResourceManager/~ArmaReforger:Configs/Editor/PlaceableEntities/Compositions/Compositions.conf|Configs/Editor/PlaceableEntities/Compositions/Compositions.conf}} | |||
# Run the process. It will register all prefabs in ''Prefabs/Compositions'' folder, including the newly added one. | |||
{{Feature|important|For newly added compositions through mods, this config should be extended. The new compositions should then be added to that config file. | |||
In that case the config should be set to the modded config file.}} | |||
== Testing in In-game Editor == | |||
# Load the world [enfusion://WorldEditor/worlds/GameMaster/GM_Eden.ent|''worlds\GameMaster\GM_Eden.ent''] | |||
# Press play and open the '''Entity Browser''' by pressing the button in the bottom right or by pressing TAB. | |||
# Find your composition in the list and click on it to start placing. Compatible slots should light-up. | |||
# Hover over compatible slot to snap the composition to it. | |||
{{Feature|informative|If no compatible slots are available and snapping doesn't work, it's possible something is wrong with composition configuration.}} | |||
<gallery mode="packed" heights="200px"> | |||
File:armareforger-gm-compositions-asset-browser.jpg | |||
File:armareforger-gm-compositions-slots.jpg | |||
</gallery> | |||
{{GameCategory|armaR|Modding|Tutorials|Game Master}} |
Latest revision as of 11:53, 11 January 2023
Game Master compositions are prefabs that have to be created, configured and maintained in a specific way in order for them to work correctly in Arma Reforger:Game Master.
Creating Composition Prefab
Flexible
Follow these steps if the composition is meant for flexible slots (i.e., the composition can be placed anywhere in the world or in one of compatible slots).
- Select Prefabs/Compositions/Slotted/CompositionBase.et and open it by Plugins > Edit Selected Prefab(s) or by pressing Ctrl+Shift+E.
- Create new composition prefab by dragging CompositionBase entity from Hierarchy list to desired folder in Resource Browser. Choose the folder based on intended slot type (i.e. Flat slot, Road slot, and their respective sizes).
- Name the prefab according to this key:
<NAME>_<SIZE ABBREVIATION>_<FACTION>_<ID>
- NAME - composition name eg: RoadBlock
- Note that names have no spaces and are written with camel case.
- SIZE ABBREVIATION - L, M or S
- Large, Medium or Small
- FACTION - either US, USSR, or FIA
- ID - two-digit iterator starting from 01
- NAME - composition name eg: RoadBlock
Static
Follow these steps if the composition is meant for static slots (i.e., the composition can be placed only on one specific position in the world).
- Open the world on which the composition is going to be placed
- Place Prefabs/Compositions/Slotted/CompositionBase.et entity on desired location
- In entity's SCR_SlotCompositionComponent, set the location prefab the composition belongs to
- Create new composition prefab by dragging CompositionBase entity from Hierarchy list to desired folder in Resource Browser. Choose the folder based on world and location names (e.g., Eden/Le_Moule)
- Name the prefab according to this key:
<NAME>_<FACTION>_<ID>
- NAME - custom name describing the composition
- FACTION - either US, USSR, or FIA
- ID - two-digit iterator starting from 01
Configuring Composition
The composition itself has several attributes that influence its behavior.
- Slot Prefab
- Prefab this composition can be snapped to in in-game editor. Can be either a flexible slot, or static location in the world.
- Orient Children To Terrain
- When enabled, children will be snapped and oriented to terrain when the composition is transformed.
- This influences also position of non-editable compositions created in a flexible slot or positioned using dedicated function in the composition component.
- Use this when child objects are lying on the ground, e.g., tables and chairs under a camo net, but not tables and chairs inside a house.
- Non Editable Children
- When enabled, children will not be turned into editable entities.
- The composition will appear as a single entity in in-game editor.
- Use this for smaller compositions which have a lot of smaller objects, e.g., pallets with boxes.
Editing Composition
Select the composition prefab and edit it by Plugins > Edit Selected Prefab(s) or by pressing Ctrl+Shift+E.
Prefab Editing
Keep in mind that prefab editing has a few caveats:
- After adding a new entity, move it inside the composition by Alt+LMB drag, not just by LMB drag. How to tell them apart...
How to tell them apart... |
|
- When editing entities, only their instances are modified. Follow these steps to apply changes to prefab:
- Select modified entities
- Click on Apply to prefab at the bottom of Object properties panel.
- In the dialog window, leave the composition prefab selected, but tick Apply to transformation option
- Confirm
- Save all changes to the prefab by saving the world (Ctrl + S)
- Until the world is saved, no changes (not even the ones manually applied using Apply to prefab button) are saved into prefab file.
- To delete an entity, use RMB > Delete from prefab. Pressing 'Delete' key would simply try to remove an instance of the entity.
Technical Rules
In later stages, following rules will be automatically checked by Workbench plugin.
- Use only entities from Prefabs folder, not from PrefabsEditable folder! Conversion to editable variants is performed automatically in the next step.
- Entity bounding boxes should not extend past the borders of the slot! You can see the bounding boxes by hovering over entities with the mouse, and entities that do cross this boundary while part of the composition prefab will show a warning. This is done to ensure compositions align well with slots in the world.
Tips
- To toggle surface clutter, use Diag Menu > Render > Terrain grass > Render grass. Use this sparingly, as creating the composition without grass can provide inaccurate representation.
- If your composition contains some editable prefabs, you can convert them back to their sources using Plugins > In-game Editor > Convert to/from Editable Entities..., and the choosing To Non-editable.
Creating Editable Variant
When you're done editing the composition, auto-generate its editable variant. To do so, follow the configuration guide:
Selecting compositions
In Resource Browser, select prefab files (*.et) of entities you want to process.
Check editable entity types to see which prefabs should be marked as editable.
Tip: Both Resource Manager and World Editor browsers are supported, but not Resource Manager
Creating editable prefab
With files selected, activate Plugins > In-game Editor > Create/Update Selected Editable Prefabs
Tip: You can also press Ctrl+Shift+U to perform this action.
After the operation is done, please check the log, it will list all processed prefabs. They can end up with one of the following states:
- Created / Updated - successful processed
- Failed - unable to generate the prefab, most commonly due to presence of child entity with RplComponent
- Non-editable - some child entities which don't have editable prefab variant were detected. Please revise them and consider if some of them could be made editable as well.
Updating editable prefab
Editable prefabs needs to be regenerated every time the source prefab changes. This can be achieved by several ways:
- Activate Plugins > In-game Editor > Update All Editable Prefabs
- This will update all auto-generated editable prefabs.
- It will also handle renamed / moved / deleted source prefabs (enable Only File Changes attribute to perform this operation only).
- Select an editable or a source prefab and activate Plugins > In-game Editor > Create/Update Selected Editable Prefabs
Changes will be made in PrefabsEditable/Auto as well as UI/Textures/EditorPreviews/Auto folders
Registering Composition
- In Resource Manager, activate Plugins > In-game Editor > Register Placeable Entities...
- Set config to Configs/Editor/PlaceableEntities/Compositions/Compositions.conf
- Run the process. It will register all prefabs in Prefabs/Compositions folder, including the newly added one.
Testing in In-game Editor
- Load the world worlds\GameMaster\GM_Eden.ent
- Press play and open the Entity Browser by pressing the button in the bottom right or by pressing TAB.
- Find your composition in the list and click on it to start placing. Compatible slots should light-up.
- Hover over compatible slot to snap the composition to it.