CancelEvent: Difference between revisions

From Multi Theft Auto: Wiki
Jump to navigation Jump to search
No edit summary
mNo edit summary
 
(19 intermediate revisions by 12 users not shown)
Line 3: Line 3:
This function is used to stop the automatic internal handling of events, for example this can be used to prevent an item being given to a player when they walk over a pickup, by canceling the [[onPickupUse]] event.  
This function is used to stop the automatic internal handling of events, for example this can be used to prevent an item being given to a player when they walk over a pickup, by canceling the [[onPickupUse]] event.  


[[cancelEvent]] does not have an effect on all events, see the individual event's pages for information on what happens when the event is canceled. [[cancelEvent]] does not stop further event handlers from being called, as the order of event handlers being called is undefined in many cases. Instead, you can see if the currently active event has been cancelled using [[wasEventCanceled]].
[[cancelEvent]] does not have an effect on all events, see the individual event's pages for information on what happens when the event is canceled. [[cancelEvent]] does not stop further event handlers from being called, as the order of event handlers being called is undefined in many cases. Instead, you can see if the currently active event has been cancelled using [[wasEventCancelled]].


The use of cancelEvent outside of an event handler has no effect.
The use of cancelEvent outside of an event handler has no effect.


If you implement your own custom events and want to handle them being cancelled, you should call [[wasEventCanceled]] to check after your call to [[triggerEvent]].
If you implement your own custom events and want to handle them being cancelled, you should call [[wasEventCancelled]] to check after your call to [[triggerEvent]].


==Syntax==  
==Syntax==  
<section name="Server" class="server" show="true">
<syntaxhighlight lang="lua">
bool cancelEvent ( [ bool cancel = true, string reason = "" ] ) 
</syntaxhighlight>
</section>
<section name="Client" class="client" show="true">
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
bool cancelEvent ()   
bool cancelEvent ()   
</syntaxhighlight>
</syntaxhighlight>
</section>
===Optional Arguments===
{{OptionalArg}}
*'''cancel:''' True to cancel, false to uncancel.
*'''reason:''' The reason for cancelling the event.


===Returns===
===Returns===
Line 18: Line 31:


==Example==  
==Example==  
<section name="Example 1" class="server" show="true">
<section name="Example 1 - Server" class="server" show="true">
This example stops the player ''huntedPlayer'' from entering a vehicle:
This example stops the player from entering a vehicle.
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
-- call 'stopVehicleEntry' whenever hunterPlayer is about to enter a vehicle:
function onVehicleStartEnter()
function stopVehicleEntry ( theplayer, seat, jacked )
   cancelEvent()
   cancelEvent () -- stop the event from occuring
end
end
addEventHandler ( "onVehicleStartEnter", huntedPlayer, stopVehicleEntry )
addEventHandler("onVehicleStartEnter", root, onVehicleStartEnter)
</syntaxhighlight>
</syntaxhighlight>
</section>
</section>
<section name="Example 2" class="client" show="true">
<section name="Example 2 - Client" class="client" show="true">
This example prevents any damage to a player clientside.
This example prevents any damage to a player clientside by making [[cancelEvent]] an event handler for the [[onClientPlayerDamage]] event.
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
addEventHandler ( "onClientPlayerDamage", getRootElement(), cancelEvent )
function onClientPlayerDamage()
cancelEvent()
end
addEventHandler("onClientPlayerDamage", root, onClientPlayerDamage)
</syntaxhighlight>
</syntaxhighlight>
</section>
</section>
==See Also==
==See Also==
{{Event functions}}
{{Event functions}}
[[ru:cancelEvent]]

Latest revision as of 11:23, 8 June 2022

This function is used to stop the automatic internal handling of events, for example this can be used to prevent an item being given to a player when they walk over a pickup, by canceling the onPickupUse event.

cancelEvent does not have an effect on all events, see the individual event's pages for information on what happens when the event is canceled. cancelEvent does not stop further event handlers from being called, as the order of event handlers being called is undefined in many cases. Instead, you can see if the currently active event has been cancelled using wasEventCancelled.

The use of cancelEvent outside of an event handler has no effect.

If you implement your own custom events and want to handle them being cancelled, you should call wasEventCancelled to check after your call to triggerEvent.

Syntax

Click to collapse [-]
Server
bool cancelEvent ( [ bool cancel = true, string reason = "" ] )   
Click to collapse [-]
Client
bool cancelEvent ()   

Optional Arguments

NOTE: When using optional arguments, you might need to supply all arguments before the one you wish to use. For more information on optional arguments, see optional arguments.

  • cancel: True to cancel, false to uncancel.
  • reason: The reason for cancelling the event.

Returns

Always returns true.

Example

Click to collapse [-]
Example 1 - Server

This example stops the player from entering a vehicle.

function onVehicleStartEnter()
   cancelEvent()
end
addEventHandler("onVehicleStartEnter", root, onVehicleStartEnter)
Click to collapse [-]
Example 2 - Client

This example prevents any damage to a player clientside by making cancelEvent an event handler for the onClientPlayerDamage event.

function onClientPlayerDamage()
	cancelEvent()
end
addEventHandler("onClientPlayerDamage", root, onClientPlayerDamage)

See Also