BIS_fnc_animalSiteSpawn

From Bohemia Interactive Community
Revision as of 11:12, 27 July 2022 by Lou Montana (talk | contribs) (Text replacement - " " to " ")
Jump to navigation Jump to search
Hover & click on the images for description

Description

Description:
Create an area that spawns animals. The animals will be created or deleted if a player is inside or outside the area's radius.
Execution:
call
Groups:
Ambient

Syntax

Syntax:
[animalSite, classnamesToSpawn, radius] call BIS_fnc_animalSiteSpawn
Parameters:
animalSite: Object - The object to create the site around.
classnamesToSpawn: Array of Strings - Animals that can be spawned.
radius: Number - The radius by which animals are created or deleted.
Return Value:
Script Handle

Examples

Example 1:
[player, ["rabbit_f", "turtle_f", "hen_random_f"], 200] call BIS_fnc_animalSiteSpawn;

Additional Information

See also:
Arma 3 CfgVehicles Animals

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
DreadedEntity - c
Posted on Dec 07, 2014 - 08:37 (UTC)
The only way to stop the animals from spawning is to delete the object. When using this function, I recommend creating a non-solid object (almost anything from the "Objects (Helpers)" list in the editor, and using hideObjectGlobal on it. Using setVariable you can add the animal site to a reference object to find it easily when you want to delete it.
private _obj = createVehicle ["Sign_Sphere10cm_F", getPos player, [], 0, "CAN_COLLIDE"]; hideObjectGlobal _obj; player setVariable ["animalSite", _obj]; _obj = nil;
There are two hidden variables, "animalCount" and "radius". Use setVariable on the object to change these.
animalCount is supposed to limit the amount of animals that can spawn. In the code, the algorithm for this is hard to understand.
radius refers to how far away from the object the animals can spawn.
Both are numbers.

The "area" is imaginary. It is not a tangible area defined by trigger or marker radius, the area is only saved as an integer within the function.
Strangepete - c
Posted on Dec 07, 2014 - 09:26 (UTC)
Using the Script Handle returned, the function can be checked using scriptDone or killed with terminate; Existing generated animals will not be cleaned up when terminated.
_handle = [params] call BIS_fnc_animalSiteSpawn; if !(scriptDone _handle) then { terminate _handle; };