2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2019-01-15 16:20:22 +00:00
|
|
|
* @copyright 2019 Photon Storm Ltd.
|
2019-05-10 15:15:04 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
2018-02-12 16:01:20 +00:00
|
|
|
*/
|
|
|
|
|
2017-03-31 03:58:28 +00:00
|
|
|
// http://www.blackpawn.com/texts/pointinpoly/
|
|
|
|
|
|
|
|
// points is an array of Point-like objects with public x/y properties
|
2017-04-04 00:02:56 +00:00
|
|
|
// returns an array containing all points that are within the triangle, or an empty array if none
|
|
|
|
// if 'returnFirst' is true it will return after the first point within the triangle is found
|
2017-03-31 03:58:28 +00:00
|
|
|
|
2017-10-13 13:11:54 +00:00
|
|
|
/**
|
2018-09-27 14:29:32 +00:00
|
|
|
* Filters an array of point-like objects to only those contained within a triangle.
|
|
|
|
* If `returnFirst` is true, will return an array containing only the first point in the provided array that is within the triangle (or an empty array if there are no such points).
|
2017-10-13 13:11:54 +00:00
|
|
|
*
|
|
|
|
* @function Phaser.Geom.Triangle.ContainsArray
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-09-27 14:29:32 +00:00
|
|
|
* @param {Phaser.Geom.Triangle} triangle - The triangle that the points are being checked in.
|
|
|
|
* @param {Phaser.Geom.Point[]} points - An array of point-like objects (objects that have an `x` and `y` property)
|
|
|
|
* @param {boolean} [returnFirst=false] - If `true`, return an array containing only the first point found that is within the triangle.
|
|
|
|
* @param {array} [out] - If provided, the points that are within the triangle will be appended to this array instead of being added to a new array. If `returnFirst` is true, only the first point found within the triangle will be appended. This array will also be returned by this function.
|
2017-10-13 13:11:54 +00:00
|
|
|
*
|
2018-09-27 14:29:32 +00:00
|
|
|
* @return {Phaser.Geom.Point[]} An array containing all the points from `points` that are within the triangle, if an array was provided as `out`, points will be appended to that array and it will also be returned here.
|
2017-10-13 13:11:54 +00:00
|
|
|
*/
|
2017-04-04 00:02:56 +00:00
|
|
|
var ContainsArray = function (triangle, points, returnFirst, out)
|
2017-03-31 03:58:28 +00:00
|
|
|
{
|
2017-04-04 00:02:56 +00:00
|
|
|
if (returnFirst === undefined) { returnFirst = false; }
|
2017-03-31 03:58:28 +00:00
|
|
|
if (out === undefined) { out = []; }
|
|
|
|
|
|
|
|
var v0x = triangle.x3 - triangle.x1;
|
|
|
|
var v0y = triangle.y3 - triangle.y1;
|
|
|
|
|
|
|
|
var v1x = triangle.x2 - triangle.x1;
|
|
|
|
var v1y = triangle.y2 - triangle.y1;
|
|
|
|
|
|
|
|
var dot00 = (v0x * v0x) + (v0y * v0y);
|
|
|
|
var dot01 = (v0x * v1x) + (v0y * v1y);
|
|
|
|
var dot11 = (v1x * v1x) + (v1y * v1y);
|
|
|
|
|
|
|
|
// Compute barycentric coordinates
|
|
|
|
var b = ((dot00 * dot11) - (dot01 * dot01));
|
|
|
|
var inv = (b === 0) ? 0 : (1 / b);
|
|
|
|
|
|
|
|
var u;
|
|
|
|
var v;
|
|
|
|
var v2x;
|
|
|
|
var v2y;
|
|
|
|
var dot02;
|
|
|
|
var dot12;
|
|
|
|
|
|
|
|
var x1 = triangle.x1;
|
|
|
|
var y1 = triangle.y1;
|
|
|
|
|
|
|
|
for (var i = 0; i < points.length; i++)
|
|
|
|
{
|
|
|
|
v2x = points[i].x - x1;
|
|
|
|
v2y = points[i].y - y1;
|
|
|
|
|
|
|
|
dot02 = (v0x * v2x) + (v0y * v2y);
|
|
|
|
dot12 = (v1x * v2x) + (v1y * v2y);
|
|
|
|
|
|
|
|
u = ((dot11 * dot02) - (dot01 * dot12)) * inv;
|
|
|
|
v = ((dot00 * dot12) - (dot01 * dot02)) * inv;
|
|
|
|
|
2017-04-04 00:02:56 +00:00
|
|
|
if (u >= 0 && v >= 0 && (u + v < 1))
|
|
|
|
{
|
|
|
|
out.push({ x: points[i].x, y: points[i].y });
|
|
|
|
|
|
|
|
if (returnFirst)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2017-03-31 03:58:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return out;
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = ContainsArray;
|