| | 1 | | using DCL; |
| | 2 | | using UnityEngine; |
| | 3 | |
|
| | 4 | | [RequireComponent(typeof(AvatarRenderer))] |
| | 5 | | public class ParticlesOnAvatarVisualCue : MonoBehaviour |
| | 6 | | { |
| | 7 | | [SerializeField] private IAvatarRenderer.VisualCue avatarVisualCue; |
| | 8 | | [SerializeField] private GameObject particlePrefab; |
| | 9 | | [SerializeField] private bool followAvatar; |
| 1032 | 10 | | [SerializeField] private bool ignoreIfFaraway = true; |
| | 11 | |
|
| | 12 | | private AvatarRenderer avatarRenderer; |
| | 13 | | private float lodDistanceSqr; |
| | 14 | |
|
| | 15 | | private void Awake() |
| | 16 | | { |
| | 17 | | //If we allow this distance to be changed at runtime, we cannot cache it |
| 806 | 18 | | lodDistanceSqr = DataStore.i.avatarsLOD.LODDistance.Get(); |
| 806 | 19 | | lodDistanceSqr *= lodDistanceSqr; |
| | 20 | |
|
| 806 | 21 | | avatarRenderer = GetComponent<AvatarRenderer>(); |
| 806 | 22 | | avatarRenderer.OnVisualCue += OnVisualCue; |
| 806 | 23 | | } |
| | 24 | |
|
| | 25 | | private void OnVisualCue(IAvatarRenderer.VisualCue cue) |
| | 26 | | { |
| 1470 | 27 | | if (ignoreIfFaraway && (avatarRenderer.transform.position - CommonScriptableObjects.playerUnityPosition.Get()).s |
| 68 | 28 | | return; |
| | 29 | |
|
| 1402 | 30 | | if (cue != avatarVisualCue || particlePrefab == null) |
| 1402 | 31 | | return; |
| | 32 | |
|
| 0 | 33 | | GameObject particles = Instantiate(particlePrefab); |
| 0 | 34 | | particles.transform.position = avatarRenderer.transform.position + particlePrefab.transform.position; |
| 0 | 35 | | if (followAvatar) |
| | 36 | | { |
| 0 | 37 | | FollowObject particlesFollow = particles.AddComponent<FollowObject>(); |
| 0 | 38 | | particlesFollow.target = avatarRenderer.transform; |
| 0 | 39 | | particlesFollow.offset = particlePrefab.transform.position; |
| | 40 | | } |
| 0 | 41 | | } |
| | 42 | |
|
| | 43 | | private void OnDestroy() |
| | 44 | | { |
| 805 | 45 | | if (avatarRenderer == null) |
| 0 | 46 | | return; |
| 805 | 47 | | avatarRenderer.OnVisualCue -= OnVisualCue; |
| 805 | 48 | | } |
| | 49 | | } |