OnPlayerWasted: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| Fernando187 (talk | contribs)  m (p) | |||
| (18 intermediate revisions by 14 users not shown) | |||
| Line 1: | Line 1: | ||
| __NOTOC__   | __NOTOC__   | ||
| {{Server event}} | {{Server event}} | ||
| {{New feature/item|3.0161|1.6.0|22620| | |||
| This event is triggered when a player is killed or dies. | This event is triggered when a player is killed or dies. | ||
| }} | |||
| ==Parameters== | ==Parameters== | ||
| <syntaxhighlight lang="lua"> | |||
| element killer, int killerWeapon, int bodypart  | int totalAmmo, element killer, int killerWeapon, int bodypart, bool stealth, int animGroup, int animID | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| *'''killer''': an [[element]] representing the player or  | *'''totalAmmo''': an [[int]] representing the total ammo the victim had when they died. | ||
| *'''killerWeapon''': an  | *'''killer''': an [[element]] representing the [[player]], [[ped]], [[vehicle]] or [[object]] who was the killer. Deaths resulting from fall damage provide the [[vehicle]] or [[object]] landed on as the killer. If there is no killer this is ''false''. | ||
| *'''bodypart''': an  | *'''killerWeapon''': an [[int]] representing the [[Weapons|killer weapon]] or the [[Damage Types|damage type]]. | ||
| *'''bodypart''': an [[int]] representing the bodypart ID the victim was hit on when they died. | |||
| {{BodyParts}} | {{BodyParts}} | ||
| *{{New feature/item|3|1.0||''' | *'''stealth''': a [[boolean]] value representing whether or not this was a stealth kill. | ||
| {{New feature/item|3.0161|1.6.0|22620| | |||
| *'''animGroup''': an [[int|integer]] representing the player's current animation group. | |||
| }} | |||
| {{New feature/item|3.0161|1.6.0|22620| | |||
| *'''animID''': an [[int|integer]] representing the player's current animation ID. | |||
| }} | |||
| ==Source== | ==Source== | ||
| Line 25: | Line 32: | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| -- register player_Wasted as a handler for onPlayerWasted | -- register player_Wasted as a handler for onPlayerWasted | ||
| function player_Wasted ( attacker, weapon, bodypart ) | function player_Wasted ( ammo, attacker, weapon, bodypart ) | ||
| 	-- if there was an attacker | 	-- if there was an attacker | ||
| 	if ( attacker ) then | 	if ( attacker ) then | ||
| Line 37: | Line 44: | ||
| 		elseif ( getElementType ( attacker ) == "vehicle" ) then | 		elseif ( getElementType ( attacker ) == "vehicle" ) then | ||
| 			-- we'll get the name from the attacker vehicle's driver | 			-- we'll get the name from the attacker vehicle's driver | ||
| 			tempString = getPlayerName ( getVehicleController ( attacker ) ).." killed "..getPlayerName ( source ).." ("..getWeaponNameFromID ( weapon )..")" | |||
| 		end | 		end | ||
| 		-- if the victim was shot in the head, append a special message | 		-- if the victim was shot in the head, append a special message | ||
| Line 54: | Line 61: | ||
| 	end | 	end | ||
| end | end | ||
| addEventHandler ( "onPlayerWasted",  | addEventHandler ( "onPlayerWasted", root, player_Wasted ) | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| Line 60: | Line 67: | ||
| And another example, this will spawn you in the middle of GTA SA world (x=0, y=0, z=3) after 2 seconds of your death | And another example, this will spawn you in the middle of GTA SA world (x=0, y=0, z=3) after 2 seconds of your death | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| addEventHandler( "onPlayerWasted",  | addEventHandler( "onPlayerWasted", root, | ||
| 	function() | 	function() | ||
| 		setTimer( spawnPlayer, 2000, 1, source, 0, 0, 3 ) | 		setTimer( spawnPlayer, 2000, 1, source, 0, 0, 3 ) | ||
| Line 68: | Line 75: | ||
| {{See also/Server event|Player events}} | {{See also/Server event|Player events}} | ||
| [[ru:onPlayerWasted]] | |||
Latest revision as of 12:43, 1 June 2025
Parameters
int totalAmmo, element killer, int killerWeapon, int bodypart, bool stealth, int animGroup, int animID
- totalAmmo: an int representing the total ammo the victim had when they died.
- killer: an element representing the player, ped, vehicle or object who was the killer. Deaths resulting from fall damage provide the vehicle or object landed on as the killer. If there is no killer this is false.
- killerWeapon: an int representing the killer weapon or the damage type.
- bodypart: an int representing the bodypart ID the victim was hit on when they died.
- 3: Torso
- 4: Ass
- 5: Left Arm
- 6: Right Arm
- 7: Left Leg
- 8: Right Leg
- 9: Head
 
- stealth: a boolean value representing whether or not this was a stealth kill.
Source
The source of this event is the player that died or got killed.
Example
This example prints the killer and bodypart to the chat when a player dies.
-- register player_Wasted as a handler for onPlayerWasted
function player_Wasted ( ammo, attacker, weapon, bodypart )
	-- if there was an attacker
	if ( attacker ) then
		-- we declare our variable outside the following checks
		local tempString
		-- if the element that killed him was a player,
		if ( getElementType ( attacker ) == "player" ) then
			-- put the attacker, victim and weapon info in the string
			tempString = getPlayerName ( attacker ).." killed "..getPlayerName ( source ).." ("..getWeaponNameFromID ( weapon )..")"
		-- else, if it was a vehicle,
		elseif ( getElementType ( attacker ) == "vehicle" ) then
			-- we'll get the name from the attacker vehicle's driver
			tempString = getPlayerName ( getVehicleController ( attacker ) ).." killed "..getPlayerName ( source ).." ("..getWeaponNameFromID ( weapon )..")"
		end
		-- if the victim was shot in the head, append a special message
		if ( bodypart == 9 ) then
			tempString = tempString.." (HEADSHOT!)"
		-- else, just append the bodypart name
		else
			tempString = tempString.." ("..getBodyPartName ( bodypart )..")"
		end
		-- display the message
		outputChatBox ( tempString )
	-- if there was no attacker,
	else
		-- output a death message without attacker info
		outputChatBox ( getPlayerName ( source ).." died. ("..getWeaponNameFromID ( weapon )..") ("..getBodyPartName ( bodypart )..")" )
	end
end
addEventHandler ( "onPlayerWasted", root, player_Wasted )
And another example, this will spawn you in the middle of GTA SA world (x=0, y=0, z=3) after 2 seconds of your death
addEventHandler( "onPlayerWasted", root, function() setTimer( spawnPlayer, 2000, 1, source, 0, 0, 3 ) end )
See Also
Player events
- onPlayerACInfo
- onPlayerBan
- onPlayerChangeNick
- onPlayerChat
- onPlayerClick
- onPlayerCommand
- onPlayerConnect
- onPlayerContact
- onPlayerDamage
- onPlayerJoin
- onPlayerLogin
- onPlayerLogout
- onPlayerMarkerHit
- onPlayerMarkerLeave
- onPlayerModInfo
- onPlayerMute
- onPlayerNetworkStatus
- onPlayerPickupHit
- onPlayerPickupLeave
- onPlayerPickupUse
- onPlayerPrivateMessage
- onPlayerQuit
- onPlayerScreenShot
- onPlayerSpawn
- onPlayerStealthKill
- onPlayerTarget
- onPlayerUnmute
- onPlayerVehicleEnter
- onPlayerVehicleExit
- onPlayerVoiceStart
- onPlayerVoiceStop
- onPlayerWasted
- onPlayerWeaponFire
- onPlayerWeaponSwitch