ACE3/docs/wiki/framework/fortify-framework.md
Dart 31217ae5d0
Fortify - Add onDeployStop event for cancelling before confirming (#9854)
* onDeployStop event

* Updated wiki with new event

* Fixed params

* Revert "onDeployStop event"

This reverts commit c3dae82915.

* Uses deployCanceled

* Re-added fortify stop event

* Update fnc_deployObject.sqf

---------

Co-authored-by: johnb432 <58661205+johnb432@users.noreply.github.com>
2024-03-25 09:08:06 -07:00

4.4 KiB

layout title description group order parent mod version redirect_from
wiki Fortify Framework Explains how to set-up the Fortify component. framework 6 wiki acex
major minor patch
3 3 0
/wiki/frameworkx/fortify-framework.html

1. Overview

The Fortify framework allows server admins or mission makers to give players the ability to place fortifications through self-interaction, using the Fortify Tool.

1.1 Chat commands

If the Fortify module is present in the mission, server admins can use chat commands to set-up or change the different parameters. Useful to give players additional resources based on progress on the mission for example.

  • #ace-fortify on turns fortify mode on
  • #ace-fortify off turns fortify mode off
  • #ace-fortify west small 500 registers the "small" preset for the west side with a budget of 500
  • #ace-fortify west medium registers the "medium" preset for the west side with no budget
  • #ace-fortify o big registers the "big" preset for the east side with no budget

1.2 Adding custom presets

There are three ways of adding custom presets to your mission, either via code, through desciption.ext or through config.

To add a preset via code you use the function call ace_fortify_fnc_registerObjects. Also enables Fortify.

* Registers the given objects in the given side's player interaction menu.
* Players on that side must have the `Fortify Tool` item in their inventory to access the menu.
* Classnames must be in the format [<classname>, <cost>, <category(optional)>]
* MUST BE CALLED ON SERVER!
*
* Arguments:
* 0: Side <SIDE>
* 1: Budget <NUMBER>
* 2: Object Classnames <ARRAY>
*
* Return Value:
* None
*
* Example:
* [west, 5000, [["Land_BagFence_Long_F", 5], ["Land_BagBunker_Small_F", 50]]] call ace_fortify_fnc_registerObjects
* [west, 5000, [["Land_BagFence_Long_F", 5, "tan"], ["Land_BagFence_01_long_green_F", 5, "green"]]] call ace_fortify_fnc_registerObjects

Adding it through description.ext or config you use:

class ACEX_Fortify_Presets {
    class TAG_MyPreset {
        displayName = "My Preset";
        objects[] = {
            {"Sandbag", 5},
            {"Bunker", 50}
        };
    };
    class TAG_categories {
        displayName = "My Categories";
        objects[] = {
            {"Sandbag", 5, "A Category"},
            {"Bunker", 50, "TAG_MyPreset"} // will use the localized displayName of that preset ("My Preset")
        };
    };
};

Then you will have to set the mission preset to TAG_MyPreset by either using the Fortify editor module or the chat command: #ace-fortify blufor TAG_MyPreset.

1.3 Adding custom deploy handlers

A custom deploy handler allows missions makers to decide if an object can be placed or not.

To verify that an object isn't above a certain terrain height we can check the height of the object before it is confirmed as placed. Returning false from the code block means that placement is not allowed.

[{
    params ["_unit", "_object", "_cost"];
    private _return = (getPosATL _object) select 2 < 1;
    _return
}] call ace_fortify_fnc_addDeployHandler;

1.4 Updating budget

The Fortify budget can be updated for any side using the function.

* Updates the given sides budget.
*
* Arguments:
* 0: Side <SIDE>
* 1: Change <NUMBER> (default: 0)
* 2: Display hint <BOOL> (default: true)
*
* Return Value:
* None
*
* Example:
* [west, -250, false] call ace_fortify_fnc_updateBudget

2. Events

2.1 Listenable

Event Name Passed Parameter(s) Locality Description
acex_fortify_objectPlaced [player, side, objectPlaced] Global Fortify object placed
acex_fortify_objectDeleted [player, side, objectDeleted] Global Fortify object deleted
acex_fortify_onDeployStart [player, object, cost] Local Player starts placing object
ace_fortify_onDeployStop [player, object, cost] Local Player stops placing object. Raised only if stopped before trying to place (= before progress bar appears). If it's during progress bar, only ace_fortify_deployCanceled is raised.
ace_fortify_deployFinished [[player, side, configName, posASL, vectorDir, vectorUp, cost], elapsedTime, totalTime, errorCode] Local Player successfully finishes building object
ace_fortify_deployCanceled [[player, side, configName, posASL, vectorDir, vectorUp, cost], elapsedTime, totalTime, errorCode] Local Player cancels building object