1
Fork 0
mirror of https://github.com/Steffo99/gravity-fusion.git synced 2024-11-24 17:24:19 +00:00
gravity-fusion/Assets/Components/Gravitation.cs

57 lines
1.6 KiB
C#

using System.Collections;
using System.Linq;
using System.Collections.Generic;
using UnityEngine;
[RequireComponent(typeof(Rigidbody2D))]
public class Gravitation : MonoBehaviour
{
public bool isStatic;
protected Rigidbody2D rigidbody;
protected GameController gameController;
public List<Gravitation> SimulatedObjects {
get {
return gameController.simulatedObjects;
}
}
public float Mass {
get {
return rigidbody.mass;
}
}
public float GravitationConstant {
get {
return gameController.gravitationConstant;
}
}
private void Awake() {
rigidbody = GetComponent<Rigidbody2D>();
gameController = GameObject.Find("GameController").GetComponent<GameController>();
}
private void OnEnable() {
SimulatedObjects.Add(this);
}
private void OnDisable() {
SimulatedObjects.Remove(this);
}
// O(n²)
private void FixedUpdate()
{
int positionInList = SimulatedObjects.IndexOf(this);
foreach(Gravitation other in SimulatedObjects.Skip(positionInList)) {
float distance = Vector3.Distance(this.transform.position, other.transform.position);
float force = GravitationConstant * this.Mass * other.Mass / Mathf.Clamp(Mathf.Pow(distance, 2), 0.1f, float.PositiveInfinity);
Vector3 direction = (other.transform.position - this.transform.position).normalized;
if(!this.isStatic) rigidbody.AddForce(direction * force);
if(!other.isStatic) other.rigidbody.AddForce(-direction * force);
}
}
}