Pixel-Composer/scripts/d3d_plane/d3d_plane.gml

30 lines
722 B
Text
Raw Normal View History

function __ray(origin, direction) constructor {
self.origin = origin;
self.direction = direction.normalize();
static sampleDistance = function(t) {
gml_pragma("forceinline");
return origin.add(direction.multiply(t));
}
}
function __plane(origin, normal) constructor {
self.origin = origin;
self.normal = normal.normalize();
}
#region functions
function d3d_intersect_ray_plane(ray, plane) {
2023-08-16 20:16:31 +02:00
//print($"Intersect {ray}\n\tto {plane}");
var det = plane.normal.dot(ray.direction);
if(det == 0) return new __vec3();
var rayToPlane = plane.origin.subtract(ray.origin);
var t = rayToPlane.dot(plane.normal) / det;
if(t < 0) return new __vec3();
return ray.sampleDistance(t);
}
#endregion