rj-action-library/Runtime/Math/Geometry/Box2.cs

107 lines
1.9 KiB
C#

using System.Collections;
using System.Collections.Generic;
using Godot;
namespace Rokojori
{
public class Box2
{
public Vector2 min = Vector2.Zero;
public Vector2 max = Vector2.Zero;
public Box2( Vector2 min, Vector2 max )
{
this.min = min;
this.max = max;
}
public Box2()
{}
public bool ContainsPoint( Vector2 point )
{
return ContainsPoint( min, max, point );
}
public Box2 Clone()
{
return new Box2( min, max );
}
public Vector2 center => ( min + max ) / 2;
public Vector2 size => max - min;
public void UnionWith( Box2 other )
{
min = min.Min( other.min );
max = max.Max( other.max );
}
public void Grow( Vector2 abs )
{
min -= abs;
max += abs;
}
public void GrowByPoint( Vector2 p )
{
min = min.Min( p );
max = max.Max( p );
}
public void GrowRelativeToSize( float amount )
{
Grow( size * amount );
}
public static bool ContainsPoint( Vector2 min, Vector2 max, Vector2 point )
{
if ( ! Range.Contains( min.X, max.X, point.X ) )
{
return false;
}
if ( ! Range.Contains( min.Y, max.Y, point.Y ) )
{
return false;
}
return true;
}
public float DistanceTo( Vector2 point )
{
if ( ContainsPoint( point ) )
{
return 0;
}
var c = center;
var s = size;
var dx = Mathf.Max( Mathf.Abs( point.X - c.X) - s.X / 2, 0);
var dy = Mathf.Max( Mathf.Abs( point.Y - c.Y) - s.Y / 2, 0);
return Mathf.Sqrt( dx * dx + dy * dy );
}
public void EnsureCorrectness()
{
if ( max.X < min.X )
{
var b = max.X; max.X = min.X; min.X = b;
}
if ( max.Y < min.Y )
{
var b = max.Y; max.Y = min.Y; min.Y = b;
}
}
}
}