buildingPos: Difference between revisions

From Bohemia Interactive Community
mNo edit summary
m (Text replacement - "<sqf>([^↵][^\/]*↵[^\/]*)<\/sqf>" to "<sqf> $1 </sqf>")
 
(108 intermediate revisions by 21 users not shown)
Line 1: Line 1:
[[Category:Scripting Commands|B]]
{{RV|type=command
[[Category:Scripting Commands OFP 1.97|B]]
[[Category:Scripting Commands OFP 1.46|B]]
[[Category:Scripting Commands ArmA|B]]


|game1= ofp
|version1= 1.00


<h2 style="color:#000066">'''''building'' buildingPos ''index'''''</h2>
|game2= ofpe
|version2= 1.00


|game3= arma1
|version3= 1.00


'''Operand types:'''
|game4= arma2
|version4= 1.00


'''building:''' [[Object]]
|game5= arma2oa
|version5= 1.50


'''index:''' [[Number]]
|game6= tkoh
|version6= 1.00


'''Type of returned value:'''
|game7= arma3
|version7= 0.50


[[Array]]
|arg= global


'''Description:'''
|gr1= Positions


Returns given indexed position in building, returned value is in format [[Position]].
|descr= Returns position of a given indexed position in a [[Object#Building|building]].


|s1= building [[buildingPos]]  index


'''Examples:'''
|p1= building: [[Object]]


'''buildingPos''' [building2, 1]
|p2= index: [[Number]] - index of a specific position {{Feature|arma3|Since v1.56 index {{hl|-1}} will return all available building positions.}}
unit [[setPos]] (([[object]] 21222) '''buildingPos''' 1)


|r1= [[Array]] in format [[Position#PositionAGL|PositionAGL]] - a single building position. If building position with given index does not exist, {{hl|[0, 0, 0]}} is returned
{{Feature|arma3|Since v1.56 it can also return an [[Array|array]] of all building positions in format [[Position#PositionAGL|PositionAGL]] if index that was given is {{hl|-1}}.}}


'''Comments:'''
|x1= <sqf>_soldier setPosATL (_house1 buildingPos 2);</sqf>


|x2= <sqf>_allpositions = nearestBuilding player buildingPos -1;</sqf>


These examples will move a unit to the 1st position specified in a buildings model, in the second example - '''''bunker1'''''.
|seealso= [[nearestBuilding]] [[nearestObject]] [[nearestObjects]] [[nearObjects]] [[insideBuilding]] [[buildingExit]] [[position]] [[setPos]] [[setWaypointHousePosition]] [[waypointHousePosition]] [[BIS_fnc_buildingPositions]]
}}


this [[move]] (building '''buildingPos''' 1)
<dl class="command_description">


this [[move]] (bunker1 '''buildingPos''' 1)
<dt><dt>
<dd class="notedate">Posted on 2006-08-02 - 10:45</dd>
<dt class="note">[[User:Hardrock|hardrock]]</dt>
<dd class="note">
''Notes from before the conversion:''
These examples will move a unit to the 1st position specified in a buildings model, in the second example - bunker1.
<sqf>
this move (building buildingPos 1);
this move (bunker1 buildingPos 1);
</sqf>
In the default game buildings, the buildingPos is usually right behind a window. This can make it easy to place units in the windows of buildings, by putting the unit near a building and putting this in its init field:
<sqf>this setPosATL ((nearestBuilding this) buildingPos 1);</sqf>
The location returned by buildingPos is not reliable after the player has exited and then resumed the mission. For code that is executed immediately after the mission starts there is no problem.
If buildingPos locations are to be accessed during the mission when the player may have exited and then resumed, save the locations you require at the start of the mission and use these saved locations in your subsequent scripts.


<dt><dt>
<dd class="notedate">Posted on 2007-01-26 - 01:02</dd>
<dt class="note">[[User:Kronzky|Kronzky]]</dt>
<dd class="note">
The highest index is ''not'' necessarily the highest position in a building! Check the z-value to find out the absolute height of a position.


In the default game buildings, the '''buildingPos''' is usually right behind a window.
<dt><dt>
 
<dd class="notedate">Posted on 2011-01-08</dd>
This can make it easy to place units in the windows of buildings, by putting the unit near a building and putting this in its init field:
<dt class="note">[[User:.kju|.kju]]</dt>
 
<dd class="note">
this [[setPos]] [[getPos]] ('''buildingPos''' [ [[nearestBuilding]] this, 1])
Almost all buildings loose their building positions when they get (visually) damaged or destroyed. Some debris do still have building positions though. So it is no technical limitation. Just most damaged/destructed buildings models do not (yet?) have building positions. Keep in mind that a damaged or destroyed building is a different object instance (and model).
 
</dl>
 
The location returned by '''buildingPos''' is not reliable after the player has exited and then resumed the mission. For code that is executed immediately the mission starts there is no problem.  If '''buildingPos''' locations are to be accessed during the mission when the player may have exited and then resumed, save the locations you require at the start of the mission and use these saved locations in your subsequent scripts.

Latest revision as of 11:25, 3 September 2024

Hover & click on the images for description

Description

Description:
Returns position of a given indexed position in a building.
Groups:
Positions

Syntax

Syntax:
building buildingPos index
Parameters:
building: Object
index: Number - index of a specific position
Arma 3
Since v1.56 index -1 will return all available building positions.
Return Value:
Array in format PositionAGL - a single building position. If building position with given index does not exist, [0, 0, 0] is returned
Arma 3
Since v1.56 it can also return an array of all building positions in format PositionAGL if index that was given is -1.

Examples

Example 1:
_soldier setPosATL (_house1 buildingPos 2);
Example 2:
_allpositions = nearestBuilding player buildingPos -1;

Additional Information

See also:
nearestBuilding nearestObject nearestObjects nearObjects insideBuilding buildingExit position setPos setWaypointHousePosition waypointHousePosition BIS_fnc_buildingPositions

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
Posted on 2006-08-02 - 10:45
hardrock
Notes from before the conversion: These examples will move a unit to the 1st position specified in a buildings model, in the second example - bunker1.
this move (building buildingPos 1); this move (bunker1 buildingPos 1);
In the default game buildings, the buildingPos is usually right behind a window. This can make it easy to place units in the windows of buildings, by putting the unit near a building and putting this in its init field:
this setPosATL ((nearestBuilding this) buildingPos 1);
The location returned by buildingPos is not reliable after the player has exited and then resumed the mission. For code that is executed immediately after the mission starts there is no problem. If buildingPos locations are to be accessed during the mission when the player may have exited and then resumed, save the locations you require at the start of the mission and use these saved locations in your subsequent scripts.
Posted on 2007-01-26 - 01:02
Kronzky
The highest index is not necessarily the highest position in a building! Check the z-value to find out the absolute height of a position.
Posted on 2011-01-08
.kju
Almost all buildings loose their building positions when they get (visually) damaged or destroyed. Some debris do still have building positions though. So it is no technical limitation. Just most damaged/destructed buildings models do not (yet?) have building positions. Keep in mind that a damaged or destroyed building is a different object instance (and model).