-
Notifications
You must be signed in to change notification settings - Fork 0
/
GravityManager.cs
63 lines (47 loc) · 1.62 KB
/
GravityManager.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
using UnityEngine;
using System.Collections.Generic;
/**
* GravityManager can give you a gravity force vector at any point in the scene.
*/
public class GravityManager : Singleton<GravityManager>
{
// Properties
// -----------------------------------------------------
/** Maximum distance from ground at which gravity applies. */
public float GroundMaxDistance = 100;
/** Layer mask for determining what constitutes solid ground. */
public LayerMask GroundLayers;
/** Strength of the gravitational field. */
public float Strength;
/** Number of samples to take when estimating gravity. */
public int Samples = 128;
// Members
// -----------------------------------------------------
/** Raycast hit info. */
private RaycastHit hit = new RaycastHit();
// Public Methods
// -----------------------------------------------------
/** Return a gravity force vector, given a point in world space. */
public Vector3 ForceAt(Vector3 point)
{
// Scatter rays out randomly, looking for solid ground.
// When we hit it, accumulate the resulting surface normal.
Vector3 gravity = Vector3.zero;
for (int i = 0; i < Samples; i++)
{
Vector3 direction = Random.onUnitSphere;
if (Physics.Raycast(point, direction, out hit, GroundMaxDistance, GroundLayers))
gravity -= (hit.normal * 1 / (hit.distance * hit.distance));
/*
{
// Recover the gravity source.
GravitySource source = hit.collider.gameObject.GetComponent<GravitySource>();
if (source)
gravity += hit.normal * source.Strength;
}
*/
}
// Return the overall gravity direction.
return gravity.normalized * Strength;
}
}