mirror of
https://github.com/photonstorm/phaser
synced 2024-11-23 13:13:43 +00:00
Merge pull request #865 from woutercommandeur/dev
Fix Phaser.Line.intersectsPoints for floating point inaccuracy.
This commit is contained in:
commit
c025b95959
1 changed files with 7 additions and 2 deletions
|
@ -375,8 +375,13 @@ Phaser.Line.intersectsPoints = function (a, b, e, f, asSegment, result) {
|
|||
return null;
|
||||
}
|
||||
|
||||
result.x = ((b1 * c2) - (b2 * c1)) / denom;
|
||||
result.y = ((a2 * c1) - (a1 * c2)) / denom;
|
||||
/*
|
||||
Round to 3 decimals here, due to javascript floating point is 'broken'
|
||||
http://stackoverflow.com/questions/11832914/round-to-at-most-2-decimal-places-in-javascript
|
||||
See workaround explanation there in accepted answer there..
|
||||
*/
|
||||
result.x = Math.round( ((((b1 * c2) - (b2 * c1)) / denom)+0.00001)*1000 ) / 1000;
|
||||
result.y = Math.round( ((((a2 * c1) - (a1 * c2)) / denom)+0.00001)*1000 ) / 1000;
|
||||
|
||||
if (asSegment)
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue