phaser/src/math/SinCosTableGenerator.js

56 lines
1.4 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}
*/
2018-03-21 13:15:25 +00:00
/**
* @typedef {object} SinCosTable
*
* @property {number} sin - The sine value.
* @property {number} cos - The cosine value.
* @property {number} length - The length.
2018-03-21 13:15:25 +00:00
*/
2018-01-26 06:19:27 +00:00
/**
* Generate a series of sine and cosine values.
2018-01-26 06:19:27 +00:00
*
* @function Phaser.Math.SinCosTableGenerator
* @since 3.0.0
*
* @param {number} length - The number of values to generate.
* @param {number} [sinAmp=1] - The sine value amplitude.
* @param {number} [cosAmp=1] - The cosine value amplitude.
* @param {number} [frequency=1] - The frequency of the values.
2018-01-26 06:19:27 +00:00
*
* @return {SinCosTable} The generated values.
2018-01-26 06:19:27 +00:00
*/
var SinCosTableGenerator = function (length, sinAmp, cosAmp, frequency)
{
if (sinAmp === undefined) { sinAmp = 1; }
if (cosAmp === undefined) { cosAmp = 1; }
if (frequency === undefined) { frequency = 1; }
frequency *= Math.PI / length;
var cos = [];
var sin = [];
for (var c = 0; c < length; c++)
{
cosAmp -= sinAmp * frequency;
sinAmp += cosAmp * frequency;
cos[c] = cosAmp;
sin[c] = sinAmp;
}
return {
sin: sin,
cos: cos,
length: length
};
};
module.exports = SinCosTableGenerator;