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-10-06 03:52:41 +00:00
|
|
|
/**
|
2019-04-17 09:52:23 +00:00
|
|
|
* Round a value to the given precision.
|
|
|
|
*
|
|
|
|
* For example:
|
|
|
|
*
|
|
|
|
* ```javascript
|
|
|
|
* RoundTo(123.456, 0) = 123
|
|
|
|
* RoundTo(123.456, 1) = 120
|
|
|
|
* RoundTo(123.456, 2) = 100
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* To round the decimal, i.e. to round to precision, pass in a negative `place`:
|
|
|
|
*
|
|
|
|
* ```javascript
|
|
|
|
* RoundTo(123.456789, 0) = 123
|
|
|
|
* RoundTo(123.456789, -1) = 123.5
|
|
|
|
* RoundTo(123.456789, -2) = 123.46
|
|
|
|
* RoundTo(123.456789, -3) = 123.457
|
|
|
|
* ```
|
2017-10-06 03:52:41 +00:00
|
|
|
*
|
|
|
|
* @function Phaser.Math.RoundTo
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-05-24 11:59:27 +00:00
|
|
|
* @param {number} value - The value to round.
|
2019-04-17 09:52:23 +00:00
|
|
|
* @param {integer} [place=0] - The place to round to. Positive to round the units, negative to round the decimal.
|
2018-05-24 11:59:27 +00:00
|
|
|
* @param {integer} [base=10] - The base to round in. Default is 10 for decimal.
|
2017-10-06 03:52:41 +00:00
|
|
|
*
|
2018-05-23 09:46:16 +00:00
|
|
|
* @return {number} The rounded value.
|
2017-10-06 03:52:41 +00:00
|
|
|
*/
|
2016-12-07 17:16:59 +00:00
|
|
|
var RoundTo = function (value, place, base)
|
|
|
|
{
|
|
|
|
if (place === undefined) { place = 0; }
|
|
|
|
if (base === undefined) { base = 10; }
|
|
|
|
|
|
|
|
var p = Math.pow(base, -place);
|
|
|
|
|
|
|
|
return Math.round(value * p) / p;
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = RoundTo;
|