setHit: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "| Nothing |x1=" to "|r1= Nothing |x1=")
m (2.16 -> 2.18)
(37 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{RV|type=command
{{RV|type=command


| arma2
|game1= arma2
|1.00
|version1= 1.00


|game2= arma2oa
|game2= arma2oa
Line 19: Line 19:
|gr1= Object Manipulation
|gr1= Object Manipulation


| Set damage on a part of an object.
|descr=
{{Feature | Informative | Some part names are in Czech; see [[Translations|translation table]]. }}
{{{!}} class="wikitable float-right align-center-col-2"
{{!}}+
! {{Link|:Category: Event Handlers|Event Handler}}
! Triggered
{{!}}-
{{!}} {{hl|Hit}}
{{!}} {{Icon|unchecked}}
{{!}}-
{{!}} {{hl|HandleDamage}}
{{!}} {{Icon|unchecked}}
{{!}}-
{{!}} {{hl|Killed}}
{{!}} {{Icon|checked}}
{{!}}-
{{!}} {{hl|MPKilled}}
{{!}} {{Icon|checked}}
{{!}}}


| object [[setHit]] [part, damage, useEffects]
Set damage on a part of an object.
{{Feature|informative|Some part names are in Czech; see the [[ArmA: Armed Assault: Selection Translations|translation table]].}}


|p1 = [part, damage, useEffects]: [[Array]]
|s1= object [[setHit]] [part, damage, useEffects, killer, instigator, breakRotor]


|p2= object: [[Object]] - [[local]] object
|p1= object: [[Object]] - [[local]] object


|p3= part: [[String]] - Name of the part ([[Named_Selection|selection]] name)
|p2= part: [[String]] - name of the part ([[Named_Selection|selection]] name)


|p4= damage: [[Number]] - Damage value ranging 0..1, 0 being fully functional, 1 being destroyed
|p3= damage: [[Number]] - damage value ranging 0..1, 0 being fully functional, 1 being destroyed


|p5 = {{GVI|arma3|1.68}} useEffects: [[Boolean]] - (Optional, default [[true]]) [[false]] to skip destruction effects
|p4= useEffects: [[Boolean]] - (Optional, default [[true]]) [[false]] to skip destruction effects
|p4since= arma3 1.68
 
|p5= killer: [[Object]] - (Optional, default [[objNull]]) the entity that caused the damage. If the damage leads to the death of the unit, the killer will be used as the object that caused the kill.
* it can be used to show "killed by player" in debriefing statistics and kill messages in the chat (if death messages are enabled).
* it will alter the killer's [[rating]] as if the killer directly killed the unit.
* it will be listed as <sqf inline>_killer</sqf> parameter in the [[Arma 3: Event Handlers#Killed|Killed]] event handler.
|p5since= arma3 2.08
 
|p6= instigator: [[Object]] - (Optional, default [[objNull]]) the person that instigated the damage.
* if a tank is a killer, the tank gunner that pulled the trigger is instigator
* it will be listed as <sqf inline>_instigator</sqf> parameter in the [[Arma 3: Event Handlers#Killed|Killed]] event handler.
|p6since= arma3 2.12
 
|p7= breakRotor: [[Boolean]] - (Optional, default [[false]]) if the hitpoint is rotor on a helicopter, [[true]] will break the rotor as well as play corresponding sound if 'useEffects' is also [[true]].
|p7since= arma3 2.18


|r1= [[Nothing]]
|r1= [[Nothing]]


|x1= <code>[[vehicle]] [[player]] [[setHit]] ["motor", 1];</code>
|x1= <sqf>vehicle player setHit ["motor", 1];</sqf>


|x2= <code>[[vehicle]] [[player]] [[setHit]] ["mala vrtule", 0.95];</code>
|x2= <sqf>vehicle player setHit ["mala vrtule", 0.95];</sqf>


|x3= <code>[[if]] ([[local]] _heli) [[then]] {
|x3= <sqf>
_heli [[setHit]] ["velka vrtule", 0];
if (local _heli) then
} [[else]] {
{
[[hint]] ("Vehicle " + [[str]] _heli + " must be local to this machine to do that!");
_heli setHit ["velka vrtule", 0];
};</code>
}
else
{
hint ("Vehicle " + str _heli + " must be local to this machine to do that!");
};
</sqf>


|seealso= [[getHit]], [[getHitPointDamage]], [[setHitPointDamage]], [[damage]], [[setDamage]], [[setFuel]], [[setAmmo]], [[getHitIndex]], [[setHitIndex]]
|seealso= [[getHit]] [[getHitPointDamage]] [[setHitPointDamage]] [[damage]] [[setDamage]] [[setFuel]] [[setAmmo]] [[getHitIndex]] [[setHitIndex]] [[forceHitPointsDamageSync]]
}}
}}


<dl class="command_description">
{{Note
<dt><dt>
|user= Deadfast
<dd class="notedate">
|timestamp= 20090824110900
<dt class="note">[[User:Deadfast|Deadfast]]</dt>
|text= Damaging specific parts of the vehicle will not update its overall [[damage]] value (as of v1.03):
<dd class="note">Damaging specific parts of the vehicle will not update its overall [[damage]] value (as of v1.03):
<sqf>
<code>[[player]] [[setHit]] ["hands", 0.9];
player setHit ["hands", 0.9];
[[hint]] [[str]] ([[damage]] [[player]]); {{cc|will return 0}}</code>
hint str (damage player); // will return 0
<dt><dt>
</sqf>
<dd class="notedate">
|game= arma2
<dt class="note">[[User:DenV|denisko.redisko]]</dt>
}}
<dd class="note">Direct use of the names of sections of the model is likely a bad practice, and will not work on some addons.
 
{{Note
|user= DenV
|timestamp= 20110329142500
|text= Direct use of the names of sections of the model is likely a bad practice, and will not work on some addons.
So instead:
So instead:
<code>_MH60S [[setHit]] ["elektronika", _hit];</code>
<sqf>_MH60S setHit ["elektronika", _hit];</sqf>
should be used:
should be used:
<code>_MH60S [[setHit]] [<nowiki/>[[getText]] ([[configFile]] >> "cfgVehicles" >> "MH60S" >> "HitPoints" >> "HitAvionics" >> "name"), _hit];</code>
<sqf>_MH60S setHit [getText (configFile >> "cfgVehicles" >> "MH60S" >> "HitPoints" >> "HitAvionics" >> "name"), _hit];</sqf>
</dl>
}}
 
 
{{GameCategory|arma2|Scripting Commands}}
{{GameCategory|arma3|Scripting Commands}}
{{GameCategory|tkoh|Scripting Commands}}
 
<dl class="command_description">
<dt></dt>
<dd class="notedate">Posted on September 11, 2018 - 19:37 (UTC)</dd>
<dt class="note">[[User:HazJ|HazJ]]</dt>
<dd class="note">
You can use [[getHit]] if you are using 1.64 EOL version.
</dd>
</dl>

Revision as of 15:06, 8 February 2024

Hover & click on the images for description

Description

Description:
Event Handler Triggered
Hit Unchecked
HandleDamage Unchecked
Killed Checked
MPKilled Checked

Set damage on a part of an object.

Some part names are in Czech; see the translation table.
Groups:
Object Manipulation

Syntax

Syntax:
object setHit [part, damage, useEffects, killer, instigator, breakRotor]
Parameters:
object: Object - local object
part: String - name of the part (selection name)
damage: Number - damage value ranging 0..1, 0 being fully functional, 1 being destroyed
since Arma 3 logo black.png1.68
useEffects: Boolean - (Optional, default true) false to skip destruction effects
since Arma 3 logo black.png2.08
killer: Object - (Optional, default objNull) the entity that caused the damage. If the damage leads to the death of the unit, the killer will be used as the object that caused the kill.
  • it can be used to show "killed by player" in debriefing statistics and kill messages in the chat (if death messages are enabled).
  • it will alter the killer's rating as if the killer directly killed the unit.
  • it will be listed as _killer parameter in the Killed event handler.
since Arma 3 logo black.png2.12
instigator: Object - (Optional, default objNull) the person that instigated the damage.
  • if a tank is a killer, the tank gunner that pulled the trigger is instigator
  • it will be listed as _instigator parameter in the Killed event handler.
since Arma 3 logo black.png2.18
breakRotor: Boolean - (Optional, default false) if the hitpoint is rotor on a helicopter, true will break the rotor as well as play corresponding sound if 'useEffects' is also true.
Return Value:
Nothing

Examples

Example 1:
vehicle player setHit ["motor", 1];
Example 2:
vehicle player setHit ["mala vrtule", 0.95];
Example 3:
if (local _heli) then { _heli setHit ["velka vrtule", 0]; } else { hint ("Vehicle " + str _heli + " must be local to this machine to do that!"); };

Additional Information

See also:
getHit getHitPointDamage setHitPointDamage damage setDamage setFuel setAmmo getHitIndex setHitIndex forceHitPointsDamageSync

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
Deadfast - c
Posted on Aug 24, 2009 - 11:09 (UTC)

Damaging specific parts of the vehicle will not update its overall damage value (as of v1.03):

player setHit ["hands", 0.9]; hint str (damage player); // will return 0

DenV - c
Posted on Mar 29, 2011 - 14:25 (UTC)
Direct use of the names of sections of the model is likely a bad practice, and will not work on some addons. So instead:
_MH60S setHit ["elektronika", _hit];
should be used:
_MH60S setHit [getText (configFile >> "cfgVehicles" >> "MH60S" >> "HitPoints" >> "HitAvionics" >> "name"), _hit];