Mirror/doc/Guides/Sync/SyncVarHook.md

46 lines
1.7 KiB
Markdown
Raw Normal View History

2019-01-07 17:00:09 +00:00
# SyncVar Hook
2019-12-16 21:51:53 +00:00
[![SyncVar hook video tutorial](../../images/video_tutorial.png)](https://www.youtube.com/watch?v=T7AoozedYfI&list=PLkx8oFug638oBYF5EOwsSS-gOVBXj1dkP&index=5)
2019-06-25 05:41:22 +00:00
The hook attribute can be used to specify a function to be called when the SyncVar changes value on the client. This ensures that all clients receive the proper variables from other clients.
- The Hook method must have a single parameter of the same type as the SyncVar property. This parameter should have a unique name, e.g. newValue.
- Reference the hook parameter inside the hook to use the new value. Referencing the property value will be the old value, in case you need to compare.
- The property will be updated after the hook completes. You may update the property yourself inside the hook.
2019-06-25 05:41:22 +00:00
Below is a simple example of assigning a random color to each player when they're spawned on the server. All clients will see all players in the correct colors, even if they join later.
2019-07-07 05:52:37 +00:00
```cs
2019-01-07 17:00:09 +00:00
using UnityEngine;
using UnityEngine.Networking;
2019-06-25 05:41:22 +00:00
public class PlayerController : NetworkBehaviour
2019-01-07 17:00:09 +00:00
{
2019-06-25 05:41:22 +00:00
[SyncVar(hook = nameof(SetColor))]
2019-07-20 00:00:49 +00:00
Color playerColor = Color.black;
2019-01-07 17:00:09 +00:00
2019-07-20 00:00:49 +00:00
// Unity makes a clone of the Material every time GetComponent<Renderer>().material is used.
// Cache it here and Destroy it in OnDestroy to prevent a memory leak.
Material cachedMaterial;
public override void OnStartServer()
{
base.OnStartServer();
playerColor = Random.ColorHSV(0f, 1f, 1f, 1f, 0.5f, 1f);
}
2019-06-25 05:41:22 +00:00
void SetColor(Color color)
2019-01-07 17:00:09 +00:00
{
2019-07-20 00:00:49 +00:00
if (cachedMaterial == null)
cachedMaterial = GetComponent<Renderer>().material;
2019-06-25 05:41:22 +00:00
2019-07-20 00:00:49 +00:00
cachedMaterial.color = color;
2019-01-07 17:00:09 +00:00
}
2019-07-20 00:00:49 +00:00
void OnDestroy()
2019-01-07 17:00:09 +00:00
{
2019-07-20 00:00:49 +00:00
Destroy(cachedMaterial);
2019-01-07 17:00:09 +00:00
}
}
```