2023-08-15 11:36:26 +02:00
|
|
|
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}");
|
2023-08-15 11:36:26 +02:00
|
|
|
|
|
|
|
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
|