OnClientWorldSound: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
|||
(7 intermediate revisions by 5 users not shown) | |||
Line 1: | Line 1: | ||
{{Client event}} | {{Client event}} | ||
__NOTOC__ | __NOTOC__ | ||
{{New feature/item|3.0157|1.5. | {{New feature/item|3.0157|1.5.6|14652|This event triggers whenever a GTA sound starts playing.}} | ||
This event triggers whenever a GTA sound starts playing. | |||
}} | |||
{{Note|Use [[setWorldSoundEnabled]] if you want to disable certain sounds conditionless. | {{Note|Use [[setWorldSoundEnabled]] if you want to disable certain sounds conditionless. | ||
For example, you should only cancel player emitted sounds in this event, because when you cancel certain vehicle sounds, the game will try to play the same sound on the next frame.}} | For example, you should only cancel player emitted sounds in this event, because when you cancel certain vehicle sounds, the game will try to play the same sound on the next frame.}} | ||
Line 24: | Line 21: | ||
If this event is [[Event system#Canceling|canceled]], the sound won't play at all. | If this event is [[Event system#Canceling|canceled]], the sound won't play at all. | ||
==Example== | ==Example== | ||
This | '''Example 1:''' This example will cancel every vehicle sound. | ||
<syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
-- | addEventHandler("onClientWorldSound", root, function() | ||
if getElementType(source) == "vehicle" then | |||
cancelEvent() | |||
end | |||
end) | |||
</syntaxhighlight> | |||
'''Example 2:''' This example lets you see how many times each sound that gets played has been played using '/seesoundlist'. | |||
<syntaxhighlight lang="lua"> | |||
local sounds = {} | |||
addEventHandler("onClientWorldSound", root, function(group, index) | |||
sounds[group.." | "..index] = (sounds[group.." | "..index] or 0) + 1 | |||
end) | |||
function cmdSeeSoundList() | |||
-- Put the non iterated table into an interated table so we can sort them | |||
local tbl = {} | |||
for sound, count in pairs(sounds) do | |||
tbl[#tbl + 1] = {sound, count} | |||
end | |||
table.sort(tbl, function(a, b) return a[2] > b[2] end) | |||
-- Output the table to clipboard | |||
local str = "Group | Index: Times played\n" | |||
for i, dat in ipairs(tbl) do | |||
str = str..dat[1]..": "..dat[2].."\n" | |||
end | |||
setClipboard(str) | |||
outputChatBox("Use CTRL + V in notepad to view the table.") | |||
end | |||
addCommandHandler("seesoundlist", cmdSeeSoundList) | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Latest revision as of 21:03, 5 April 2020
This event triggers whenever a GTA sound starts playing.
Parameters
int group, int index, float x, float y, float z
- group: An integer representing the world sound group
- index: An integer representing an individual sound within the group
- x: a floating point number representing the X coordinate on the map.
- y: a floating point number representing the Y coordinate on the map.
- z: a floating point number representing the Z coordinate on the map.
Source
The source of this event is the element, which emitted the sound.
Cancel effect
If this event is canceled, the sound won't play at all.
Example
Example 1: This example will cancel every vehicle sound.
addEventHandler("onClientWorldSound", root, function() if getElementType(source) == "vehicle" then cancelEvent() end end)
Example 2: This example lets you see how many times each sound that gets played has been played using '/seesoundlist'.
local sounds = {} addEventHandler("onClientWorldSound", root, function(group, index) sounds[group.." | "..index] = (sounds[group.." | "..index] or 0) + 1 end) function cmdSeeSoundList() -- Put the non iterated table into an interated table so we can sort them local tbl = {} for sound, count in pairs(sounds) do tbl[#tbl + 1] = {sound, count} end table.sort(tbl, function(a, b) return a[2] > b[2] end) -- Output the table to clipboard local str = "Group | Index: Times played\n" for i, dat in ipairs(tbl) do str = str..dat[1]..": "..dat[2].."\n" end setClipboard(str) outputChatBox("Use CTRL + V in notepad to view the table.") end addCommandHandler("seesoundlist", cmdSeeSoundList)
See Also
World sound functions
Client other events
- onClientChatMessage
- onClientConsole
- onClientDebugMessage
- onClientExplosion
- onClientFileDownloadComplete
- onClientHUDRender
- onClientMinimize
- onClientMTAFocusChange
- onClientPedsProcessed
- onClientPlayerNetworkStatus
- onClientPreRender
- onClientRender
- onClientRestore
- onClientTransferBoxProgressChange
- onClientTransferBoxVisibilityChange
- onClientWorldSound
Client event functions
- triggerLatentServerEvent
- triggerServerEvent
- Shared
- addEvent
- addEventHandler
- cancelEvent
- cancelLatentEvent
- getEventHandlers
- getLatentEventHandles
- getLatentEventStatus
- removeEventHandler
- triggerEvent
- wasEventCancelled