Element data: Difference between revisions
| m (Indexing of the Portuguese version) | mNo edit summary | ||
| (4 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
| Each [[element]] that is loaded is able to have [[element data]] values attached to it. These are values that can be accessed using a keyword string and directly correspond to the element's attributes in the map file, unless changed via scripting. Element data is a good way to store distributed information you want associated with an element, for example you could use it to associate a score with a player, or a team with a vehicle. | Each [[element]] that is loaded is able to have [[element data]] values attached to it. These are values that can be accessed using a keyword string and directly correspond to the element's attributes in the map file, unless changed via scripting. Element data is a good (but expensive) way to store distributed information you want associated with an element, for example you could use it to associate a score with a player, or a team with a vehicle. | ||
| Element data is synchronized between the server and the client. Setting data from any of the two sides will force an update in the other, triggering the corresponding element data change events. This is very useful, as it provides a simple way to keep element properties synced without having to set special events to do it manually.  This also means that excessive use of element data to store variables that are not required by both server and client becomes a waste of bandwidth. | Element data is synchronized by default between the server and the client (you can disable it via fourth argument in [[setElementData]]. Setting data from any of the two sides will force an update in the other, triggering the corresponding element data change events. This is very useful, as it provides a simple way to keep element properties synced without having to set special events to do it manually.  This also means that excessive use of element data to store variables that are not required by both server and client becomes a waste of bandwidth. | ||
| Since not all  | Since not all data types can be packetized to be transferred, there are some restrictions. The types that cannot be stored as element data are ''non-element userdata'' (see [[MTA Classes]]), ''functions'' and ''threads''. Also, you may not send tables which contain one or more values of any of these types. | ||
| {{Added feature/item|1.6.1|1.6.0|22790|Element data is not protected from client changes by default. You '''SHOULD''' enable [[Server_mtaserver.conf#elementdata_whitelisted|elementdata_whitelisted]] in '''mtaserver.conf''' to protect your server simple cheats. Use the '''clientChangesPolicy''' parameter in [[setElementData]] to allow some changes.}} | |||
| ==Relevant functions== | ==Relevant functions== | ||
| Line 11: | Line 13: | ||
| ==Relevant events== | ==Relevant events== | ||
| * [[onElementDataChange]]: triggered on the server after element data is changed. | * [[onElementDataChange]]: triggered on the server after element data is changed. | ||
| * [[onPlayerChangesProtectedData]]: triggered on the server after the client attempts to change protected element data. | |||
| * [[onClientElementDataChange]]: triggered on the client after element data is changed. | * [[onClientElementDataChange]]: triggered on the client after element data is changed. | ||
| [[pt-br:Element_data]] | [[pt-br:Element_data]] | ||
| [[pl:Element data]] | |||
| [[Category:Scripting Concepts]] | |||
Latest revision as of 05:30, 11 July 2025
Each element that is loaded is able to have element data values attached to it. These are values that can be accessed using a keyword string and directly correspond to the element's attributes in the map file, unless changed via scripting. Element data is a good (but expensive) way to store distributed information you want associated with an element, for example you could use it to associate a score with a player, or a team with a vehicle.
Element data is synchronized by default between the server and the client (you can disable it via fourth argument in setElementData. Setting data from any of the two sides will force an update in the other, triggering the corresponding element data change events. This is very useful, as it provides a simple way to keep element properties synced without having to set special events to do it manually. This also means that excessive use of element data to store variables that are not required by both server and client becomes a waste of bandwidth.
Since not all data types can be packetized to be transferred, there are some restrictions. The types that cannot be stored as element data are non-element userdata (see MTA Classes), functions and threads. Also, you may not send tables which contain one or more values of any of these types.
Relevant functions
- setElementData: sets an element data value.
- getElementData: retrieves an element data value.
Relevant events
- onElementDataChange: triggered on the server after element data is changed.
- onPlayerChangesProtectedData: triggered on the server after the client attempts to change protected element data.
- onClientElementDataChange: triggered on the client after element data is changed.