phaser/src/physics/arcade/GetOverlapY.js

110 lines
3.2 KiB
JavaScript
Raw Normal View History

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.
2018-02-12 16:01:20 +00:00
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
*/
2019-03-15 19:22:42 +00:00
var IntersectsRect = require('./IntersectsRect');
2019-03-11 17:28:23 +00:00
2018-02-09 03:44:23 +00:00
/**
* Calculates and returns the vertical overlap between two arcade physics bodies.
*
* We know the bodies are intersecting based on a previous check, so the point of this function
* is to determine which face the overlap is occurring on and at what depth.
2018-02-09 03:44:23 +00:00
*
* @function Phaser.Physics.Arcade.GetOverlapY
* @since 3.0.0
*
2018-10-19 16:45:05 +00:00
* @param {Phaser.Physics.Arcade.Body} body1 - The first Body to separate.
* @param {Phaser.Physics.Arcade.Body} body2 - The second Body to separate.
* @param {boolean} [overlapOnly] - Is this an overlap only check, or part of separation?
* @param {number} [bias] - A value added to the delta values during collision checks. Increase it to prevent sprite tunneling (sprites passing through each other instead of colliding).
2018-02-09 03:44:23 +00:00
*
* @return {number[]} An array containing the amount of overlap in element 0 and the face of body1 in element 1 (true = bottom, false = top).
2018-02-09 03:44:23 +00:00
*/
2017-11-09 15:30:44 +00:00
var GetOverlapY = function (body1, body2, overlapOnly, bias)
{
if (overlapOnly === undefined) { overlapOnly = false; }
if (bias === undefined) { bias = 0; }
var overlap = 0;
// var maxOverlap = body1.deltaAbsY() + body2.deltaAbsY() + bias;
var distance1 = body1.bottom - body2.y;
var distance2 = body2.bottom - body1.y;
2019-03-11 17:28:23 +00:00
var prevDistance1 = (body1.prev.y + body1.height) - body2.prev.y;
var prevDistance2 = (body2.prev.y + body2.height) - body1.prev.y;
var embedded = false;
2019-03-15 19:22:42 +00:00
var topFace = (distance1 > distance2 && prevDistance1 > prevDistance2);
2019-03-15 19:22:42 +00:00
var intersects = IntersectsRect(body1, body2);
if (!topFace)
{
// body1 bottom is touching body2 top
if (intersects)
{
overlap = distance1;
}
if (!body1.checkCollision.down || !body2.checkCollision.up)
{
overlap = 0;
intersects = false;
}
if (!overlapOnly)
2019-03-11 17:28:23 +00:00
{
body1.setTouchingDown();
body2.setTouchingUp();
2019-03-21 01:02:38 +00:00
body1.setBlockedDown(body2, intersects);
body2.setBlockedUp(body1, intersects);
2019-03-11 17:28:23 +00:00
}
}
else
{
// body1 top is touching body2 bottom
if (intersects)
{
overlap = distance2;
}
if (!body1.checkCollision.up || !body2.checkCollision.down)
{
overlap = 0;
intersects = false;
}
if (!overlapOnly)
2019-03-11 17:28:23 +00:00
{
body1.setTouchingUp();
body2.setTouchingDown();
2019-03-15 19:22:42 +00:00
2019-03-21 01:02:38 +00:00
body1.setBlockedUp(body2, intersects);
body2.setBlockedDown(body1, intersects);
2019-03-11 17:28:23 +00:00
}
}
2019-03-11 17:28:23 +00:00
// Resets the overlapY to zero if there is no overlap, or to the actual pixel value if there is
body1.overlapY = overlap;
body2.overlapY = overlap;
if (embedded)
{
// We let the block resolution move it
overlap = 0;
body1.embedded = embedded;
body2.embedded = embedded;
}
return { overlap: overlap, topFace: topFace, intersects: intersects };
};
module.exports = GetOverlapY;