2024-08-11 17:38:06 +00:00
|
|
|
using System.Collections;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using Godot;
|
|
|
|
|
|
|
|
namespace Rokojori
|
|
|
|
{
|
|
|
|
public class Sphere
|
|
|
|
{
|
|
|
|
public Vector3 center = Vector3.Zero;
|
|
|
|
public float radius = 1;
|
|
|
|
|
|
|
|
public Sphere( Vector3 center, float radius )
|
|
|
|
{
|
|
|
|
this.center = center;
|
|
|
|
this.radius = radius;
|
|
|
|
}
|
|
|
|
|
2024-09-14 06:41:52 +00:00
|
|
|
public Sphere(){}
|
|
|
|
|
|
|
|
public Sphere Create( Vector3 center, float radius )
|
|
|
|
{
|
|
|
|
var sphere = new Sphere();
|
|
|
|
sphere.center = center;
|
|
|
|
sphere.radius = radius;
|
|
|
|
|
|
|
|
return sphere;
|
|
|
|
}
|
|
|
|
|
2024-08-11 17:38:06 +00:00
|
|
|
public Sphere Copy()
|
|
|
|
{
|
|
|
|
return new Sphere( center, radius );
|
|
|
|
}
|
|
|
|
|
|
|
|
public float DistanceToPoint( Vector3 point )
|
|
|
|
{
|
|
|
|
return Mathf.Max( 0, ( point - center ).Length() - radius );
|
|
|
|
}
|
|
|
|
|
|
|
|
public bool ContainsPoint( Vector3 point )
|
|
|
|
{
|
|
|
|
return DistanceToPoint( point ) <= 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public float DistanceToSphere( Sphere sphere )
|
|
|
|
{
|
|
|
|
var distance = sphere.center - center;
|
|
|
|
var radiusBoth = sphere.radius + radius;
|
|
|
|
return Mathf.Max( 0, distance.Length() - radiusBoth );
|
|
|
|
}
|
|
|
|
|
|
|
|
public bool IntersectsSphere( Sphere sphere )
|
|
|
|
{
|
|
|
|
return DistanceToSphere( sphere ) <= 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Box3 CreateBox()
|
|
|
|
{
|
|
|
|
var offset = radius * Vector3.One;
|
|
|
|
return Box3.Create( center -offset, center + offset );
|
|
|
|
}
|
2024-12-01 17:07:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
public static Sphere ContainingBox( Box3 box )
|
|
|
|
{
|
2025-01-03 12:09:23 +00:00
|
|
|
if ( box == null )
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2024-12-01 17:07:41 +00:00
|
|
|
return new Sphere( box.center, box.maxDistance / 2f );
|
|
|
|
}
|
2024-08-11 17:38:06 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|