Comparing version 1.0.0-alpha.6 to 1.0.0-alpha.7
@@ -6,4 +6,7 @@ /* eslint-disable no-shadow */ | ||
config.debug = true; | ||
config.precision = 4; | ||
config.printTypes = false; | ||
config.printDegrees = false; | ||
config.printRowMajor = true; | ||
config.precision = 4; | ||
export { config }; | ||
@@ -28,8 +31,27 @@ | ||
function round(value) { | ||
return Math.round(value / config.EPSILON) * config.EPSILON; | ||
} | ||
export function formatValue(value) { | ||
var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : config.precision || 4; | ||
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, | ||
_ref$precision = _ref.precision, | ||
precision = _ref$precision === undefined ? config.precision || 4 : _ref$precision; | ||
value = round(value); | ||
return parseFloat(value.toPrecision(precision)); | ||
} | ||
export function formatAngle(value) { | ||
var _ref2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, | ||
_ref2$precision = _ref2.precision, | ||
precision = _ref2$precision === undefined ? config.precision || 4 : _ref2$precision, | ||
_ref2$printDegrees = _ref2.printDegrees, | ||
printDegrees = _ref2$printDegrees === undefined ? config.printAngles : _ref2$printDegrees; | ||
value = printDegrees ? degrees(value) : value; | ||
value = round(value); | ||
return '' + parseFloat(value.toPrecision(precision)) + (printDegrees ? '°' : ''); | ||
} | ||
// Returns true if value is either an array or a typed array | ||
@@ -142,2 +164,2 @@ // Note: does not return true for ArrayBuffers and DataViews | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/common.js"],"names":["config","EPSILON","debug","printRowMajor","precision","configure","options","epsilon","checkNumber","value","Number","isFinite","Error","formatValue","parseFloat","toPrecision","isArray","Array","ArrayBuffer","isView","length","undefined","clone","array","map","func","result","i","radians","degrees","Math","PI","sin","angle","cos","tan","asin","acos","atan","clamp","min","max","equals","a","b","abs"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-shadow */\n// TODO - remove\nconst config = {};\nconfig.EPSILON = 1e-12;\nconfig.debug = true;\nconfig.printRowMajor = true;\nconfig.precision = 4;\nexport {config};\n\nexport function configure(options) {\n  if ('epsilon' in options) {\n    config.EPSILON = options.epsilon;\n  }\n\n  if ('debug' in options) {\n    config.debug = options.debug;\n  }\n}\n\nexport function checkNumber(value) {\n  if (!Number.isFinite(value)) {\n    throw new Error(`Invalid number ${value}`);\n  }\n  return value;\n}\n\nexport function formatValue(value, precision = config.precision || 4) {\n  return parseFloat(value.toPrecision(precision));\n}\n\n// Returns true if value is either an array or a typed array\n// Note: does not return true for ArrayBuffers and DataViews\nexport function isArray(value) {\n  return Array.isArray(value) || (ArrayBuffer.isView(value) && value.length !== undefined);\n}\n\n// If the array has a clone function, calls it, otherwise returns a copy\nexport function clone(array) {\n  return array.clone ? array.clone() : new Array(array);\n}\n\n// If the argument value is an array, applies the func element wise,\n// otherwise applies func to the argument value\nfunction map(value, func) {\n  if (isArray(value)) {\n    const result = clone(value);\n    for (let i = 0; i < result.length; ++i) {\n      result[i] = func(result[i], i, result);\n    }\n    return result;\n  }\n  return func(value);\n}\n\n//\n// GLSL math function equivalents\n// Works on both single values and vectors\n//\n\nexport function radians(degrees) {\n  return map(degrees, degrees => degrees / 180 * Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function degrees(radians) {\n  return map(radians, radians => radians * 180 / Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function sin(radians) {\n  return map(radians, angle => Math.sin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function cos(radians) {\n  return map(radians, angle => Math.cos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function tan(radians) {\n  return map(radians, angle => Math.tan(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function asin(radians) {\n  return map(radians, angle => Math.asin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function acos(radians) {\n  return map(radians, angle => Math.acos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function atan(radians) {\n  return map(radians, angle => Math.atan(angle));\n}\n\nexport function clamp(value, min, max) {\n  return map(value, value => Math.max(min, Math.min(max, value)));\n}\n\nexport function equals(a, b) {\n  if (Array.isArray(a) && Array.isArray(b)) {\n    if (a === b) {\n      return true;\n    }\n    if (a.length !== b.length) {\n      return false;\n    }\n    for (let i = 0; i < a.length; ++i) {\n      if (!equals(a[i], b[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n  return Math.abs(a - b) <= config.EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/common.js"],"names":["config","EPSILON","debug","precision","printTypes","printDegrees","printRowMajor","configure","options","epsilon","checkNumber","value","Number","isFinite","Error","round","Math","formatValue","parseFloat","toPrecision","formatAngle","printAngles","degrees","isArray","Array","ArrayBuffer","isView","length","undefined","clone","array","map","func","result","i","radians","PI","sin","angle","cos","tan","asin","acos","atan","clamp","min","max","equals","a","b","abs"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-shadow */\n// TODO - remove\nconst config = {};\nconfig.EPSILON = 1e-12;\nconfig.debug = true;\nconfig.precision = 4;\nconfig.printTypes = false;\nconfig.printDegrees = false;\nconfig.printRowMajor = true;\n\nexport {config};\n\nexport function configure(options) {\n  if ('epsilon' in options) {\n    config.EPSILON = options.epsilon;\n  }\n\n  if ('debug' in options) {\n    config.debug = options.debug;\n  }\n}\n\nexport function checkNumber(value) {\n  if (!Number.isFinite(value)) {\n    throw new Error(`Invalid number ${value}`);\n  }\n  return value;\n}\n\nfunction round(value) {\n  return Math.round(value / config.EPSILON) * config.EPSILON;\n}\n\nexport function formatValue(value, {\n  precision = config.precision || 4\n} = {}) {\n  value = round(value);\n  return parseFloat(value.toPrecision(precision));\n}\n\nexport function formatAngle(value, {\n  precision = config.precision || 4,\n  printDegrees = config.printAngles\n} = {}) {\n  value = printDegrees ? degrees(value) : value;\n  value = round(value);\n  return `${parseFloat(value.toPrecision(precision))}${printDegrees ? '°' : ''}`;\n}\n\n// Returns true if value is either an array or a typed array\n// Note: does not return true for ArrayBuffers and DataViews\nexport function isArray(value) {\n  return Array.isArray(value) || (ArrayBuffer.isView(value) && value.length !== undefined);\n}\n\n// If the array has a clone function, calls it, otherwise returns a copy\nexport function clone(array) {\n  return array.clone ? array.clone() : new Array(array);\n}\n\n// If the argument value is an array, applies the func element wise,\n// otherwise applies func to the argument value\nfunction map(value, func) {\n  if (isArray(value)) {\n    const result = clone(value);\n    for (let i = 0; i < result.length; ++i) {\n      result[i] = func(result[i], i, result);\n    }\n    return result;\n  }\n  return func(value);\n}\n\n//\n// GLSL math function equivalents\n// Works on both single values and vectors\n//\n\nexport function radians(degrees) {\n  return map(degrees, degrees => degrees / 180 * Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function degrees(radians) {\n  return map(radians, radians => radians * 180 / Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function sin(radians) {\n  return map(radians, angle => Math.sin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function cos(radians) {\n  return map(radians, angle => Math.cos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function tan(radians) {\n  return map(radians, angle => Math.tan(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function asin(radians) {\n  return map(radians, angle => Math.asin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function acos(radians) {\n  return map(radians, angle => Math.acos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function atan(radians) {\n  return map(radians, angle => Math.atan(angle));\n}\n\nexport function clamp(value, min, max) {\n  return map(value, value => Math.max(min, Math.min(max, value)));\n}\n\nexport function equals(a, b) {\n  if (Array.isArray(a) && Array.isArray(b)) {\n    if (a === b) {\n      return true;\n    }\n    if (a.length !== b.length) {\n      return false;\n    }\n    for (let i = 0; i < a.length; ++i) {\n      if (!equals(a[i], b[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n  return Math.abs(a - b) <= config.EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\n"]} |
@@ -89,7 +89,12 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); | ||
value: function toString() { | ||
return this.formatString(config); | ||
} | ||
}, { | ||
key: 'formatString', | ||
value: function formatString(opts) { | ||
var string = ''; | ||
for (var i = 0; i < this.ELEMENTS; ++i) { | ||
string += (i > 0 ? ', ' : '') + formatValue(this[i]); | ||
string += (i > 0 ? ', ' : '') + formatValue(this[i], opts); | ||
} | ||
return this.constructor.name + '(' + string + ')'; | ||
return (opts.printTypes ? this.constructor.name : '') + '[' + string + ']'; | ||
} | ||
@@ -157,2 +162,3 @@ }, { | ||
} | ||
return this; | ||
} | ||
@@ -177,2 +183,2 @@ }, { | ||
export default MathArray; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tYXRoLWFycmF5LmpzIl0sIm5hbWVzIjpbImZvcm1hdFZhbHVlIiwiZXF1YWxzIiwiY29uZmlnIiwiTWF0aEFycmF5IiwiU3ViY2xhc3MiLCJjb25zdHJ1Y3RvciIsImNsb25lIiwiY29weSIsImNoZWNrIiwiYXJyYXkiLCJpIiwiRUxFTUVOVFMiLCJhcmdzIiwib2Zmc2V0Iiwic3RyaW5nIiwibmFtZSIsIkZsb2F0MzJBcnJheSIsImxlbmd0aCIsInZhbGlkIiwiTnVtYmVyIiwiaXNGaW5pdGUiLCJkZWJ1ZyIsInZhbGlkYXRlIiwiRXJyb3IiLCJsZW4iLCJBcnJheSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsU0FBUUEsV0FBUixFQUFxQkMsaUJBQXJCLEVBQTZCQyxNQUE3QixRQUEwQyxVQUExQzs7SUFFcUJDLFM7Ozs7Ozs7Ozs7OzRCQUVYO0FBQ04sVUFBTUMsV0FBVyxLQUFLQyxXQUF0QjtBQUNBLFVBQU1DLFFBQVEsSUFBSUYsUUFBSixHQUFlRyxJQUFmLENBQW9CLElBQXBCLENBQWQ7QUFDQUQsWUFBTUUsS0FBTjtBQUNBLGFBQU9GLEtBQVA7QUFDRDs7O3lCQUVJRyxLLEVBQU87QUFDVixXQUFLLElBQUlDLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxhQUFLQSxDQUFMLElBQVVELE1BQU1DLENBQU4sQ0FBVjtBQUNEO0FBQ0QsV0FBS0YsS0FBTDtBQUNBLGFBQU8sSUFBUDtBQUNEOzs7MEJBRVk7QUFBQSx3Q0FBTkksSUFBTTtBQUFOQSxZQUFNO0FBQUE7O0FBQ1gsV0FBSyxJQUFJRixJQUFJLENBQWIsRUFBZ0JBLElBQUksS0FBS0MsUUFBekIsRUFBbUMsRUFBRUQsQ0FBckMsRUFBd0M7QUFDdEMsYUFBS0EsQ0FBTCxJQUFVRSxLQUFLRixDQUFMLEtBQVcsQ0FBckI7QUFDRDtBQUNELFdBQUtGLEtBQUw7QUFDQSxhQUFPLElBQVA7QUFDRDs7OzhCQUVTQyxLLEVBQW1CO0FBQUEsVUFBWkksTUFBWSx1RUFBSCxDQUFHOztBQUMzQixXQUFLLElBQUlILElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxhQUFLQSxDQUFMLElBQVVELE1BQU1DLElBQUlHLE1BQVYsQ0FBVjtBQUNEO0FBQ0QsV0FBS0wsS0FBTDtBQUNBLGFBQU8sSUFBUDtBQUNEOzs7K0JBRVU7QUFDVCxVQUFJTSxTQUFTLEVBQWI7QUFDQSxXQUFLLElBQUlKLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0Q0ksa0JBQVUsQ0FBQ0osSUFBSSxDQUFKLEdBQVEsSUFBUixHQUFlLEVBQWhCLElBQXNCVixZQUFZLEtBQUtVLENBQUwsQ0FBWixDQUFoQztBQUNEO0FBQ0QsYUFBVSxLQUFLTCxXQUFMLENBQWlCVSxJQUEzQixTQUFtQ0QsTUFBbkM7QUFDRDs7OzhCQUUrQjtBQUFBLFVBQXhCTCxLQUF3Qix1RUFBaEIsRUFBZ0I7QUFBQSxVQUFaSSxNQUFZLHVFQUFILENBQUc7O0FBQzlCLFdBQUssSUFBSUgsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDRCxjQUFNSSxTQUFTSCxDQUFmLElBQW9CLEtBQUtBLENBQUwsQ0FBcEI7QUFDRDtBQUNELGFBQU9ELEtBQVA7QUFDRDs7O3FDQUVnQjtBQUNmLGFBQU8sSUFBSU8sWUFBSixDQUFpQixJQUFqQixDQUFQO0FBQ0Q7OzsyQkFFTVAsSyxFQUFPO0FBQ1osVUFBSSxDQUFDQSxLQUFELElBQVUsS0FBS1EsTUFBTCxLQUFnQlIsTUFBTVEsTUFBcEMsRUFBNEM7QUFDMUMsZUFBTyxLQUFQO0FBQ0Q7QUFDRCxXQUFLLElBQUlQLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxZQUFJLENBQUNULFFBQU8sS0FBS1MsQ0FBTCxDQUFQLEVBQWdCRCxNQUFNQyxDQUFOLENBQWhCLENBQUwsRUFBZ0M7QUFDOUIsaUJBQU8sS0FBUDtBQUNEO0FBQ0Y7QUFDRCxhQUFPLElBQVA7QUFDRDs7O2dDQUVXRCxLLEVBQU87QUFDakIsVUFBSSxDQUFDQSxLQUFELElBQVUsS0FBS1EsTUFBTCxLQUFnQlIsTUFBTVEsTUFBcEMsRUFBNEM7QUFDMUMsZUFBTyxLQUFQO0FBQ0Q7QUFDRCxXQUFLLElBQUlQLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxZQUFJLEtBQUtBLENBQUwsTUFBWUQsTUFBTUMsQ0FBTixDQUFoQixFQUEwQjtBQUN4QixpQkFBTyxLQUFQO0FBQ0Q7QUFDRjtBQUNELGFBQU8sSUFBUDtBQUNEOzs7K0JBRXNCO0FBQUEsVUFBZEQsS0FBYyx1RUFBTixJQUFNOztBQUNyQixVQUFJUyxRQUFRVCxTQUFTQSxNQUFNUSxNQUFOLEtBQWlCLEtBQUtOLFFBQTNDO0FBQ0EsV0FBSyxJQUFJRCxJQUFJLENBQWIsRUFBZ0JBLElBQUksS0FBS0MsUUFBekIsRUFBbUMsRUFBRUQsQ0FBckMsRUFBd0M7QUFDdENRLGdCQUFRQSxTQUFTQyxPQUFPQyxRQUFQLENBQWdCWCxNQUFNQyxDQUFOLENBQWhCLENBQWpCO0FBQ0Q7QUFDRCxhQUFPUSxLQUFQO0FBQ0Q7Ozs0QkFFbUI7QUFBQSxVQUFkVCxLQUFjLHVFQUFOLElBQU07O0FBQ2xCLFVBQUlQLE9BQU9tQixLQUFQLElBQWdCLENBQUMsS0FBS0MsUUFBTCxDQUFjYixLQUFkLENBQXJCLEVBQTJDO0FBQ3pDLGNBQU0sSUFBSWMsS0FBSixjQUFxQixLQUFLbEIsV0FBTCxDQUFpQlUsSUFBdEMsQ0FBTjtBQUNEO0FBQ0Y7OztnQ0FFVztBQUNWLFVBQU1FLFNBQVMsS0FBS08sR0FBTCxFQUFmO0FBQ0EsVUFBSVAsV0FBVyxDQUFmLEVBQWtCO0FBQ2hCLGFBQUssSUFBSVAsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGVBQUtBLENBQUwsS0FBV08sTUFBWDtBQUNEO0FBQ0Y7QUFDRCxXQUFLVCxLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7Ozs7cUJBbkdvQ2lCLEs7O2VBQWxCdEIsUyIsImZpbGUiOiJtYXRoLWFycmF5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtmb3JtYXRWYWx1ZSwgZXF1YWxzLCBjb25maWd9IGZyb20gJy4vY29tbW9uJztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWF0aEFycmF5IGV4dGVuZHMgQXJyYXkge1xuXG4gIGNsb25lKCkge1xuICAgIGNvbnN0IFN1YmNsYXNzID0gdGhpcy5jb25zdHJ1Y3RvcjtcbiAgICBjb25zdCBjbG9uZSA9IG5ldyBTdWJjbGFzcygpLmNvcHkodGhpcyk7XG4gICAgY2xvbmUuY2hlY2soKTtcbiAgICByZXR1cm4gY2xvbmU7XG4gIH1cblxuICBjb3B5KGFycmF5KSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcnJheVtpXTtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgc2V0KC4uLmFyZ3MpIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgdGhpc1tpXSA9IGFyZ3NbaV0gfHwgMDtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZnJvbUFycmF5KGFycmF5LCBvZmZzZXQgPSAwKSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcnJheVtpICsgb2Zmc2V0XTtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgdG9TdHJpbmcoKSB7XG4gICAgbGV0IHN0cmluZyA9ICcnO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBzdHJpbmcgKz0gKGkgPiAwID8gJywgJyA6ICcnKSArIGZvcm1hdFZhbHVlKHRoaXNbaV0pO1xuICAgIH1cbiAgICByZXR1cm4gYCR7dGhpcy5jb25zdHJ1Y3Rvci5uYW1lfSgke3N0cmluZ30pYDtcbiAgfVxuXG4gIHRvQXJyYXkoYXJyYXkgPSBbXSwgb2Zmc2V0ID0gMCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBhcnJheVtvZmZzZXQgKyBpXSA9IHRoaXNbaV07XG4gICAgfVxuICAgIHJldHVybiBhcnJheTtcbiAgfVxuXG4gIHRvRmxvYXQzMkFycmF5KCkge1xuICAgIHJldHVybiBuZXcgRmxvYXQzMkFycmF5KHRoaXMpO1xuICB9XG5cbiAgZXF1YWxzKGFycmF5KSB7XG4gICAgaWYgKCFhcnJheSB8fCB0aGlzLmxlbmd0aCAhPT0gYXJyYXkubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBpZiAoIWVxdWFscyh0aGlzW2ldLCBhcnJheVtpXSkpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGV4YWN0RXF1YWxzKGFycmF5KSB7XG4gICAgaWYgKCFhcnJheSB8fCB0aGlzLmxlbmd0aCAhPT0gYXJyYXkubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBpZiAodGhpc1tpXSAhPT0gYXJyYXlbaV0pIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHZhbGlkYXRlKGFycmF5ID0gdGhpcykge1xuICAgIGxldCB2YWxpZCA9IGFycmF5ICYmIGFycmF5Lmxlbmd0aCA9PT0gdGhpcy5FTEVNRU5UUztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgdmFsaWQgPSB2YWxpZCAmJiBOdW1iZXIuaXNGaW5pdGUoYXJyYXlbaV0pO1xuICAgIH1cbiAgICByZXR1cm4gdmFsaWQ7XG4gIH1cblxuICBjaGVjayhhcnJheSA9IHRoaXMpIHtcbiAgICBpZiAoY29uZmlnLmRlYnVnICYmICF0aGlzLnZhbGlkYXRlKGFycmF5KSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkICR7dGhpcy5jb25zdHJ1Y3Rvci5uYW1lfWApO1xuICAgIH1cbiAgfVxuXG4gIG5vcm1hbGl6ZSgpIHtcbiAgICBjb25zdCBsZW5ndGggPSB0aGlzLmxlbigpO1xuICAgIGlmIChsZW5ndGggIT09IDApIHtcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICAgIHRoaXNbaV0gLz0gbGVuZ3RoO1xuICAgICAgfVxuICAgIH1cbiAgICB0aGlzLmNoZWNrKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tYXRoLWFycmF5LmpzIl0sIm5hbWVzIjpbImZvcm1hdFZhbHVlIiwiZXF1YWxzIiwiY29uZmlnIiwiTWF0aEFycmF5IiwiU3ViY2xhc3MiLCJjb25zdHJ1Y3RvciIsImNsb25lIiwiY29weSIsImNoZWNrIiwiYXJyYXkiLCJpIiwiRUxFTUVOVFMiLCJhcmdzIiwib2Zmc2V0IiwiZm9ybWF0U3RyaW5nIiwib3B0cyIsInN0cmluZyIsInByaW50VHlwZXMiLCJuYW1lIiwiRmxvYXQzMkFycmF5IiwibGVuZ3RoIiwidmFsaWQiLCJOdW1iZXIiLCJpc0Zpbml0ZSIsImRlYnVnIiwidmFsaWRhdGUiLCJFcnJvciIsImxlbiIsIkFycmF5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxTQUFRQSxXQUFSLEVBQXFCQyxpQkFBckIsRUFBNkJDLE1BQTdCLFFBQTBDLFVBQTFDOztJQUVxQkMsUzs7Ozs7Ozs7Ozs7NEJBRVg7QUFDTixVQUFNQyxXQUFXLEtBQUtDLFdBQXRCO0FBQ0EsVUFBTUMsUUFBUSxJQUFJRixRQUFKLEdBQWVHLElBQWYsQ0FBb0IsSUFBcEIsQ0FBZDtBQUNBRCxZQUFNRSxLQUFOO0FBQ0EsYUFBT0YsS0FBUDtBQUNEOzs7eUJBRUlHLEssRUFBTztBQUNWLFdBQUssSUFBSUMsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGFBQUtBLENBQUwsSUFBVUQsTUFBTUMsQ0FBTixDQUFWO0FBQ0Q7QUFDRCxXQUFLRixLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7OzswQkFFWTtBQUFBLHdDQUFOSSxJQUFNO0FBQU5BLFlBQU07QUFBQTs7QUFDWCxXQUFLLElBQUlGLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxhQUFLQSxDQUFMLElBQVVFLEtBQUtGLENBQUws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ekMsY0FBTSxJQUFJaUIsS0FBSixjQUFxQixLQUFLckIsV0FBTCxDQUFpQmEsSUFBdEMsQ0FBTjtBQUNEO0FBQ0QsYUFBTyxJQUFQO0FBQ0Q7OztnQ0FFVztBQUNWLFVBQU1FLFNBQVMsS0FBS08sR0FBTCxFQUFmO0FBQ0EsVUFBSVAsV0FBVyxDQUFmLEVBQWtCO0FBQ2hCLGFBQUssSUFBSVYsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGVBQUtBLENBQUwsS0FBV1UsTUFBWDtBQUNEO0FBQ0Y7QUFDRCxXQUFLWixLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7Ozs7cUJBeEdvQ29CLEs7O2VBQWxCekIsUyIsImZpbGUiOiJtYXRoLWFycmF5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtmb3JtYXRWYWx1ZSwgZXF1YWxzLCBjb25maWd9IGZyb20gJy4vY29tbW9uJztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWF0aEFycmF5IGV4dGVuZHMgQXJyYXkge1xuXG4gIGNsb25lKCkge1xuICAgIGNvbnN0IFN1YmNsYXNzID0gdGhpcy5jb25zdHJ1Y3RvcjtcbiAgICBjb25zdCBjbG9uZSA9IG5ldyBTdWJjbGFzcygpLmNvcHkodGhpcyk7XG4gICAgY2xvbmUuY2hlY2soKTtcbiAgICByZXR1cm4gY2xvbmU7XG4gIH1cblxuICBjb3B5KGFycmF5KSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcnJheVtpXTtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgc2V0KC4uLmFyZ3MpIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgdGhpc1tpXSA9IGFyZ3NbaV0gfHwgMDtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZnJvbUFycmF5KGFycmF5LCBvZmZzZXQgPSAwKSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcnJheVtpICsgb2Zmc2V0XTtcbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgdG9TdHJpbmcoKSB7XG4gICAgcmV0dXJuIHRoaXMuZm9ybWF0U3RyaW5nKGNvbmZpZyk7XG4gIH1cblxuICBmb3JtYXRTdHJpbmcob3B0cykge1xuICAgIGxldCBzdHJpbmcgPSAnJztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgc3RyaW5nICs9IChpID4gMCA/ICcsICcgOiAnJykgKyBmb3JtYXRWYWx1ZSh0aGlzW2ldLCBvcHRzKTtcbiAgICB9XG4gICAgcmV0dXJuIGAke29wdHMucHJpbnRUeXBlcyA/IHRoaXMuY29uc3RydWN0b3IubmFtZSA6ICcnfVske3N0cmluZ31dYDtcbiAgfVxuXG4gIHRvQXJyYXkoYXJyYXkgPSBbXSwgb2Zmc2V0ID0gMCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBhcnJheVtvZmZzZXQgKyBpXSA9IHRoaXNbaV07XG4gICAgfVxuICAgIHJldHVybiBhcnJheTtcbiAgfVxuXG4gIHRvRmxvYXQzMkFycmF5KCkge1xuICAgIHJldHVybiBuZXcgRmxvYXQzMkFycmF5KHRoaXMpO1xuICB9XG5cbiAgZXF1YWxzKGFycmF5KSB7XG4gICAgaWYgKCFhcnJheSB8fCB0aGlzLmxlbmd0aCAhPT0gYXJyYXkubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBpZiAoIWVxdWFscyh0aGlzW2ldLCBhcnJheVtpXSkpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGV4YWN0RXF1YWxzKGFycmF5KSB7XG4gICAgaWYgKCFhcnJheSB8fCB0aGlzLmxlbmd0aCAhPT0gYXJyYXkubGVuZ3RoKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICBpZiAodGhpc1tpXSAhPT0gYXJyYXlbaV0pIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHZhbGlkYXRlKGFycmF5ID0gdGhpcykge1xuICAgIGxldCB2YWxpZCA9IGFycmF5ICYmIGFycmF5Lmxlbmd0aCA9PT0gdGhpcy5FTEVNRU5UUztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgdmFsaWQgPSB2YWxpZCAmJiBOdW1iZXIuaXNGaW5pdGUoYXJyYXlbaV0pO1xuICAgIH1cbiAgICByZXR1cm4gdmFsaWQ7XG4gIH1cblxuICBjaGVjayhhcnJheSA9IHRoaXMpIHtcbiAgICBpZiAoY29uZmlnLmRlYnVnICYmICF0aGlzLnZhbGlkYXRlKGFycmF5KSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkICR7dGhpcy5jb25zdHJ1Y3Rvci5uYW1lfWApO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIG5vcm1hbGl6ZSgpIHtcbiAgICBjb25zdCBsZW5ndGggPSB0aGlzLmxlbigpO1xuICAgIGlmIChsZW5ndGggIT09IDApIHtcbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICAgIHRoaXNbaV0gLz0gbGVuZ3RoO1xuICAgICAgfVxuICAgIH1cbiAgICB0aGlzLmNoZWNrKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbn1cbiJdfQ== |
@@ -45,2 +45,4 @@ var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | ||
var tempVector4 = [0, 0, 0, 0]; | ||
var Matrix4 = function (_MathArray) { | ||
@@ -419,2 +421,58 @@ _inherits(Matrix4, _MathArray); | ||
}, { | ||
key: 'transformDirection', | ||
value: function transformDirection(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
vec4_transformMat4(tempVector4, [vector[0], vector[1], 0, 0], this); | ||
out = out || new Vector2(); | ||
out[0] = tempVector4[0]; | ||
out[1] = tempVector4[1]; | ||
break; | ||
case 3: | ||
vec4_transformMat4(tempVector4, [vector[0], vector[1], vector[2], 0], this); | ||
out = out || new Vector3(); | ||
out[0] = tempVector4[0]; | ||
out[1] = tempVector4[1]; | ||
out[2] = tempVector4[2]; | ||
break; | ||
case 4: | ||
assert(vector[3] === 0); | ||
out = out || new Vector4(); | ||
vec4_transformMat4(out, vector, this); | ||
break; | ||
default: | ||
throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
}, { | ||
key: 'transformPoint', | ||
value: function transformPoint(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
out = out || new Vector2(); | ||
vec4_transformMat4(out, [vector[0], vector[1], 0, 1], this); | ||
out.length = 2; | ||
assert(validateVector2(out)); | ||
break; | ||
case 3: | ||
out = out || new Vector3(); | ||
vec4_transformMat4(out, [vector[0], vector[1], vector[2], 1], this); | ||
out.length = 3; | ||
assert(validateVector3(out)); | ||
break; | ||
case 4: | ||
assert(vector[3] !== 0); | ||
out = out || new Vector4(); | ||
vec4_transformMat4(out, vector, this); | ||
assert(validateVector4(out)); | ||
break; | ||
default: | ||
throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
}, { | ||
key: 'ELEMENTS', | ||
@@ -558,2 +616,2 @@ get: function get() { | ||
export default Matrix4; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/matrix4.js"],"names":["MathArray","checkNumber","Vector2","validateVector2","Vector3","validateVector3","Vector4","validateVector4","assert","mat4_determinant","mat4_fromQuat","mat4_frustum","mat4_lookAt","mat4_ortho","mat4_perspective","mat4_transpose","mat4_invert","mat4_multiply","mat4_rotateX","mat4_rotateY","mat4_rotateZ","mat4_rotate","mat4_scale","mat4_translate","vec2_transformMat4","vec3_transformMat4","vec4_transformMat4","IDENTITY","validateMatrix4","m","length","Number","isFinite","Matrix4","args","Array","isArray","arguments","copy","identity","m00","m10","m20","m30","m01","m11","m21","m31","m02","m12","m22","m32","m03","m13","m23","m33","set","check","i","q","left","right","bottom","top","near","far","eye","center","up","fov","Math","PI","aspect","Error","a","radians","rx","ry","rz","rotateX","rotateY","rotateZ","axis","vec","vector","out","transformVector2","transformVector3","transformVector4","value"],"mappings":"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","file":"matrix4.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\nimport Vector2, {validateVector2} from './vector2';\nimport Vector3, {validateVector3} from './vector3';\nimport Vector4, {validateVector4} from './vector4';\nimport assert from 'assert';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport mat4_determinant from 'gl-mat4/determinant';\nimport mat4_fromQuat from 'gl-mat4/fromQuat';\nimport mat4_frustum from 'gl-mat4/frustum';\nimport mat4_lookAt from 'gl-mat4/lookAt';\nimport mat4_ortho from 'gl-mat4/ortho';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_transpose from 'gl-mat4/transpose';\nimport mat4_invert from 'gl-mat4/invert';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateY from 'gl-mat4/rotateY';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport mat4_rotate from 'gl-mat4/rotateZ';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport vec2_transformMat4 from 'gl-vec2/transformMat4';\nimport vec3_transformMat4 from 'gl-vec3/transformMat4';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\n\nconst IDENTITY = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n\nexport function validateMatrix4(m) {\n  return m.length === 16 &&\n    Number.isFinite(m[0]) && Number.isFinite(m[1]) &&\n    Number.isFinite(m[2]) && Number.isFinite(m[3]) &&\n    Number.isFinite(m[4]) && Number.isFinite(m[5]) &&\n    Number.isFinite(m[6]) && Number.isFinite(m[7]) &&\n    Number.isFinite(m[8]) && Number.isFinite(m[9]) &&\n    Number.isFinite(m[10]) && Number.isFinite(m[11]) &&\n    Number.isFinite(m[12]) && Number.isFinite(m[13]) &&\n    Number.isFinite(m[14]) && Number.isFinite(m[15]);\n}\n\nexport default class Matrix4 extends MathArray {\n  constructor(...args) {\n    super();\n    if (Array.isArray(args[0]) && arguments.length === 1) {\n      this.copy(args[0]);\n    } else {\n      this.identity();\n    }\n  }\n\n  get ELEMENTS() {\n    return 16;\n  }\n\n  /* eslint-disable max-params */\n  setRowMajor(\n    m00 = 1, m10 = 0, m20 = 0, m30 = 0,\n    m01 = 0, m11 = 1, m21 = 0, m31 = 0,\n    m02 = 0, m12 = 0, m22 = 1, m32 = 0,\n    m03 = 0, m13 = 0, m23 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  setColumnMajor(\n    m00 = 1, m01 = 0, m02 = 0, m03 = 0,\n    m10 = 0, m11 = 1, m12 = 0, m13 = 0,\n    m20 = 0, m21 = 0, m22 = 1, m23 = 0,\n    m30 = 0, m31 = 0, m32 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  set(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n    this[0] = m00;\n    this[1] = m01;\n    this[2] = m02;\n    this[3] = m03;\n    this[4] = m10;\n    this[5] = m11;\n    this[6] = m12;\n    this[7] = m13;\n    this[8] = m20;\n    this[9] = m21;\n    this[10] = m22;\n    this[11] = m23;\n    this[12] = m30;\n    this[13] = m31;\n    this[14] = m32;\n    this[15] = m33;\n    this.check();\n    return this;\n  }\n  /* eslint-enable max-params */\n\n  // toString() {\n  //   if (config.printRowMajor) {\n  //     mat4_str(this);\n  //   } else {\n  //     mat4_str(this);\n  //   }\n  // }\n\n  // Row major setters and getters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get m00()      { return this[0]; }\n  set m00(value) { return this[0] = checkNumber(value); }\n  get m01()      { return this[4]; }\n  set m01(value) { return this[4] = checkNumber(value); }\n  get m02()      { return this[8]; }\n  set m02(value) { return this[8] = checkNumber(value); }\n  get m03()      { return this[12]; }\n  set m03(value) { return this[12] = checkNumber(value); }\n  get m10()      { return this[1]; }\n  set m10(value) { return this[1] = checkNumber(value); }\n  get m11()      { return this[5]; }\n  set m11(value) { return this[5] = checkNumber(value); }\n  get m12()      { return this[9]; }\n  set m12(value) { return this[9] = checkNumber(value); }\n  get m13()      { return this[13]; }\n  set m13(value) { return this[13] = checkNumber(value); }\n  get m20()      { return this[2]; }\n  set m20(value) { return this[2] = checkNumber(value); }\n  get m21()      { return this[6]; }\n  set m21(value) { return this[6] = checkNumber(value); }\n  get m22()      { return this[10]; }\n  set m22(value) { return this[10] = checkNumber(value); }\n  get m23()      { return this[14]; }\n  set m23(value) { return this[14] = checkNumber(value); }\n  get m30()      { return this[3]; }\n  set m30(value) { return this[3] = checkNumber(value); }\n  get m31()      { return this[7]; }\n  set m31(value) { return this[7] = checkNumber(value); }\n  get m32()      { return this[11]; }\n  set m32(value) { return this[11] = checkNumber(value); }\n  get m33()      { return this[15]; }\n  set m33(value) { return this[15] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Accessors\n\n  determinant() {\n    return mat4_determinant(this);\n  }\n\n  // Constructors\n\n  identity() {\n    for (let i = 0; i < IDENTITY.length; ++i) {\n      this[i] = IDENTITY[i];\n    }\n    this.check();\n    return this;\n  }\n\n  // Calculates a 4x4 matrix from the given quaternion\n  // q quat  Quaternion to create matrix from\n  fromQuaternion(q) {\n    mat4_fromQuat(this, q);\n    this.check();\n    return this;\n  }\n\n  // Generates a frustum matrix with the given bounds\n  // left  Number  Left bound of the frustum\n  // right Number  Right bound of the frustum\n  // bottom  Number  Bottom bound of the frustum\n  // top Number  Top bound of the frustum\n  // near  Number  Near bound of the frustum\n  // far Number  Far bound of the frustum\n  frustum({left, right, bottom, top, near, far}) {\n    mat4_frustum(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a look-at matrix with the given eye position, focal point,\n  // and up axis\n  // eye vec3  Position of the viewer\n  // center  vec3  Point the viewer is looking at\n  // up  vec3  vec3 pointing up\n  lookAt({\n    eye,\n    center = [0, 0, 0],\n    up = [0, 1, 0]\n  } = {}) {\n    mat4_lookAt(this, eye, center, up);\n    this.check();\n    return this;\n  }\n\n  // Generates a orthogonal projection matrix with the given bounds\n  // left  number  Left bound of the frustum\n  // right number  Right bound of the frustum\n  // bottom  number  Bottom bound of the frustum\n  // top number  Top bound of the frustum\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  ortho({left, right, bottom, top, near = 0.1, far = 500}) {\n    mat4_ortho(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a perspective projection matrix with the given bounds\n  // fovy  number  Vertical field of view in radians\n  // aspect  number  Aspect ratio. typically viewport width/height\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  perspective({\n    fov = 45 * Math.PI / 180,\n    aspect = 1,\n    near = 0.1,\n    far = 500\n  } = {}) {\n    if (fov > Math.PI * 2) {\n      throw Error('radians');\n    }\n    mat4_perspective(this, fov, aspect, near, far);\n    this.check();\n    return this;\n  }\n\n  // Modifiers\n\n  transpose() {\n    mat4_transpose(this, this);\n    this.check();\n    return this;\n  }\n\n  invert() {\n    mat4_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Operations\n\n  multiplyLeft(a) {\n    mat4_multiply(this, a, this);\n    this.check();\n    return this;\n  }\n\n  multiplyRight(a) {\n    mat4_multiply(this, this, a);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the X axis\n  rotateX(radians) {\n    mat4_rotateX(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Y axis.\n  rotateY(radians) {\n    mat4_rotateY(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Z axis.\n  rotateZ(radians) {\n    mat4_rotateZ(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  rotateXYZ([rx, ry, rz]) {\n    return this.rotateX(rx).rotateY(ry).rotateZ(rz);\n  }\n\n  rotateAxis(radians, axis) {\n    mat4_rotate(this, this, radians, axis);\n    this.check();\n    return this;\n  }\n\n  scale(vec) {\n    mat4_scale(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  translate(vec) {\n    mat4_translate(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  transformVector2(vector, out) {\n    out = out || new Vector2();\n    vec2_transformMat4(out, vector, this);\n    assert(validateVector2(out));\n    return out;\n  }\n\n  transformVector3(vector, out = new Vector3()) {\n    out = out || new Vector3();\n    vec3_transformMat4(out, vector, this);\n    assert(validateVector3(out));\n    return out;\n  }\n\n  transformVector4(vector, out = new Vector4()) {\n    out = out || new Vector4();\n    vec4_transformMat4(out, vector, this);\n    assert(validateVector4(out));\n    return out;\n  }\n\n  // Transforms any 2, 3 or 4 element vector\n  // returns a newly minted Vector2, Vector3 or Vector4\n  transformVector(vector, out) {\n    switch (vector.length) {\n    case 2: return this.transformVector2(vector, out);\n    case 3: return this.transformVector3(vector, out);\n    case 4: return this.transformVector4(vector, out);\n    default: throw new Error('Illegal vector');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/matrix4.js"],"names":["MathArray","checkNumber","Vector2","validateVector2","Vector3","validateVector3","Vector4","validateVector4","assert","mat4_determinant","mat4_fromQuat","mat4_frustum","mat4_lookAt","mat4_ortho","mat4_perspective","mat4_transpose","mat4_invert","mat4_multiply","mat4_rotateX","mat4_rotateY","mat4_rotateZ","mat4_rotate","mat4_scale","mat4_translate","vec2_transformMat4","vec3_transformMat4","vec4_transformMat4","IDENTITY","validateMatrix4","m","length","Number","isFinite","tempVector4","Matrix4","args","Array","isArray","arguments","copy","identity","m00","m10","m20","m30","m01","m11","m21","m31","m02","m12","m22","m32","m03","m13","m23","m33","set","check","i","q","left","right","bottom","top","near","far","eye","center","up","fov","Math","PI","aspect","Error","a","radians","rx","ry","rz","rotateX","rotateY","rotateZ","axis","vec","vector","out","transformVector2","transformVector3","transformVector4","value"],"mappings":";;;;;;;;;;AAAA,OAAOA,SAAP,MAAsB,cAAtB;AACA,SAAQC,WAAR,QAA0B,UAA1B;AACA,OAAOC,OAAP,IAAiBC,eAAjB,QAAuC,WAAvC;AACA,OAAOC,OAAP,IAAiBC,eAAjB,QAAuC,WAAvC;AACA,OAAOC,OAAP,IAAiBC,eAAjB,QAAuC,WAAvC;AACA,OAAOC,MAAP,MAAmB,QAAnB;;AAEA;AACA;AACA,OAAOC,gBAAP,MAA6B,qBAA7B;AACA,OAAOC,aAAP,MAA0B,kBAA1B;AACA,OAAOC,YAAP,MAAyB,iBAAzB;AACA,OAAOC,WAAP,MAAwB,gBAAxB;AACA,OAAOC,UAAP,MAAuB,eAAvB;AACA,OAAOC,gBAAP,MAA6B,qBAA7B;AACA,OAAOC,cAAP,MAA2B,mBAA3B;AACA,OAAOC,WAAP,MAAwB,gBAAxB;AACA,OAAOC,aAAP,MAA0B,kBAA1B;AACA,OAAOC,YAAP,MAAyB,iBAAzB;AACA,OAAOC,YAAP,MAAyB,iBAAzB;AACA,OAAOC,YAAP,MAAyB,iBAAzB;AACA,OAAOC,WAAP,MAAwB,iBAAxB;AACA,OAAOC,UAAP,MAAuB,eAAvB;AACA,OAAOC,cAAP,MAA2B,mBAA3B;AACA,OAAOC,kBAAP,MAA+B,uBAA/B;AACA,OAAOC,kBAAP,MAA+B,uBAA/B;AACA,OAAOC,kBAAP,MAA+B,uBAA/B;;AAEA,IAAMC,WAAW,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,EAA4B,CAA5B,EAA+B,CAA/B,EAAkC,CAAlC,EAAqC,CAArC,EAAwC,CAAxC,EAA2C,CAA3C,EAA8C,CAA9C,CAAjB;;AAEA,OAAO,SAASC,eAAT,CAAyBC,CAAzB,EAA4B;AACjC,SAAOA,EAAEC,MAAF,KAAa,EAAb,IACLC,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADK,IACoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADpB,IAELE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAFK,IAEoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAFpB,IAGLE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAHK,IAGoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAHpB,IAILE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAJK,IAIoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAJpB,IAKLE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CALK,IAKoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CALpB,IAMLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CANK,IAMqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CANrB,IAOLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAPK,IAOqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAPrB,IAQLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CARK,IAQqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAR5B;AASD;;AAED,IAAMI,cAAc,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,CAApB;;IAEqBC,O;;;AACnB,qBAAqB;AAAA,sCAANC,IAAM;AAANA,UAAM;AAAA;;AAAA;;AAAA;;AAEnB,QAAIC,MAAMC,OAAN,CAAcF,KAAK,CAAL,CAAd,KAA0BG,UAAUR,MAAV,KAAqB,CAAnD,EAAsD;AACpD,YAAKS,IAAL,CAAUJ,KAAK,CAAL,CAAV;AACD,KAFD,MAEO;AACL,YAAKK,QAAL;AACD;AANkB;AAOpB;;;;;;AAMD;kCAME;AAAA,UAJAC,GAIA,uEAJM,CAIN;AAAA,UAJSC,GAIT,uEAJe,CAIf;AAAA,UAJkBC,GAIlB,uEAJwB,CAIxB;AAAA,UAJ2BC,GAI3B,uEAJiC,CAIjC;AAAA,UAHAC,GAGA,uEAHM,CAGN;AAAA,UAHSC,GAGT,uEAHe,CAGf;AAAA,UAHkBC,GAGlB,uEAHwB,CAGxB;AAAA,UAH2BC,GAG3B,uEAHiC,CAGjC;AAAA,UAFAC,GAEA,uEAFM,CAEN;AAAA,UAFSC,GAET,uEAFe,CAEf;AAAA,UAFkBC,GAElB,0EAFwB,CAExB;AAAA,UAF2BC,GAE3B,0EAFiC,CAEjC;AAAA,UADAC,GACA,0EADM,CACN;AAAA,UADSC,GACT,0EADe,CACf;AAAA,UADkBC,GAClB,0EADwB,CACxB;AAAA,UAD2BC,GAC3B,0EADiC,CACjC;;AACA,aAAO,KAAKC,GAAL,CACLhB,GADK,EACAI,GADA,EACKI,GADL,EACUI,GADV,EAELX,GAFK,EAEAI,GAFA,EAEKI,GAFL,EAEUI,GAFV,EAGLX,GAHK,EAGAI,GAHA,EAGKI,GAHL,EAGUI,GAHV,EAILX,GAJK,EAIAI,GAJA,EAIKI,GAJL,EAIUI,GAJV,CAAP;AAMD;;;qCAOC;AAAA,UAJAf,GAIA,uEAJM,CAIN;AAAA,UAJSI,GAIT,uEAJe,CAIf;AAAA,UAJkBI,GAIlB,uEAJwB,CAIxB;AAAA,UAJ2BI,GAI3B,uEAJiC,CAIjC;AAAA,UAHAX,GAGA,uEAHM,CAGN;AAAA,UAHSI,GAGT,uEAHe,CAGf;AAAA,UAHkBI,GAGlB,uEAHwB,CAGxB;AAAA,UAH2BI,GAG3B,uEAHiC,CAGjC;AAAA,UAFAX,GAEA,uEAFM,CAEN;AAAA,UAFSI,GAET,uEAFe,CAEf;AAAA,UAFkBI,GAElB,0EAFwB,CAExB;AAAA,UAF2BI,GAE3B,0EAFiC,CAEjC;AAAA,UADAX,GACA,0EADM,CACN;AAAA,UADSI,GACT,0EADe,CACf;AAAA,UADkBI,GAClB,0EADwB,CACxB;AAAA,UAD2BI,GAC3B,0EADiC,CACjC;;AACA,aAAO,KAAKC,GAAL,CACLhB,GADK,EACAI,GADA,EACKI,GADL,EACUI,GADV,EAELX,GAFK,EAEAI,GAFA,EAEKI,GAFL,EAEUI,GAFV,EAGLX,GAHK,EAGAI,GAHA,EAGKI,GAHL,EAGUI,GAHV,EAILX,GAJK,EAIAI,GAJA,EAIKI,GAJL,EAIUI,GAJV,CAAP;AAMD;;;wBAEGf,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAK;AAClF,WAAK,CAAL,IAAUf,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUX,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUX,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWX,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAKE,KAAL;AACA,aAAO,IAAP;AACD;AACD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;;AAiCA;;AAEA;;kCAEc;AACZ,aAAOjD,iBAAiB,IAAjB,CAAP;AACD;;AAED;;;;+BAEW;AACT,WAAK,IAAIkD,IAAI,CAAb,EAAgBA,IAAIhC,SAASG,MAA7B,EAAqC,EAAE6B,CAAvC,EAA0C;AACxC,aAAKA,CAAL,IAAUhC,SAASgC,CAAT,CAAV;AACD;AACD,WAAKD,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;;;;mCACeE,C,EAAG;AAChBlD,oBAAc,IAAd,EAAoBkD,CAApB;AACA,WAAKF,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;;;kCAC+C;AAAA,UAAtCG,IAAsC,QAAtCA,IAAsC;AAAA,UAAhCC,KAAgC,QAAhCA,KAAgC;AAAA,UAAzBC,MAAyB,QAAzBA,MAAyB;AAAA,UAAjBC,GAAiB,QAAjBA,GAAiB;AAAA,UAAZC,IAAY,QAAZA,IAAY;AAAA,UAANC,GAAM,QAANA,GAAM;;AAC7CvD,mBAAa,IAAb,EAAmBkD,IAAnB,EAAyBC,KAAzB,EAAgCC,MAAhC,EAAwCC,GAAxC,EAA6CC,IAA7C,EAAmDC,GAAnD;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;;;;6BAKQ;AAAA,sFAAJ,EAAI;AAAA,UAHNS,GAGM,SAHNA,GAGM;AAAA,+BAFNC,MAEM;AAAA,UAFNA,MAEM,gCAFG,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,CAEH;AAAA,2BADNC,EACM;AAAA,UADNA,EACM,4BADD,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,CACC;;AACNzD,kBAAY,IAAZ,EAAkBuD,GAAlB,EAAuBC,MAAvB,EAA+BC,EAA/B;AACA,WAAKX,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;;;iCACyD;AAAA,UAAlDG,IAAkD,SAAlDA,IAAkD;AAAA,UAA5CC,KAA4C,SAA5CA,KAA4C;AAAA,UAArCC,MAAqC,SAArCA,MAAqC;AAAA,UAA7BC,GAA6B,SAA7BA,GAA6B;AAAA,6BAAxBC,IAAwB;AAAA,UAAxBA,IAAwB,8BAAjB,GAAiB;AAAA,4BAAZC,GAAY;AAAA,UAAZA,GAAY,6BAAN,GAAM;;AACvDrD,iBAAW,IAAX,EAAiBgD,IAAjB,EAAuBC,KAAvB,EAA8BC,MAA9B,EAAsCC,GAAtC,EAA2CC,IAA3C,EAAiDC,GAAjD;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;;;;kCAMQ;AAAA,sFAAJ,EAAI;AAAA,4BAJNY,GAIM;AAAA,UAJNA,GAIM,6BAJA,KAAKC,KAAKC,EAAV,GAAe,GAIf;AAAA,+BAHNC,MAGM;AAAA,UAHNA,MAGM,gCAHG,CAGH;AAAA,6BAFNR,IAEM;AAAA,UAFNA,IAEM,8BAFC,GAED;AAAA,4BADNC,GACM;AAAA,UADNA,GACM,6BADA,GACA;;AACN,UAAII,MAAMC,KAAKC,EAAL,GAAU,CAApB,EAAuB;AACrB,cAAME,MAAM,SAAN,CAAN;AACD;AACD5D,uBAAiB,IAAjB,EAAuBwD,GAAvB,EAA4BG,MAA5B,EAAoCR,IAApC,EAA0CC,GAA1C;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;gCAEY;AACV3C,qBAAe,IAAf,EAAqB,IAArB;AACA,WAAK2C,KAAL;AACA,aAAO,IAAP;AACD;;;6BAEQ;AACP1C,kBAAY,IAAZ,EAAkB,IAAlB;AACA,WAAK0C,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;iCAEaiB,C,EAAG;AACd1D,oBAAc,IAAd,EAAoB0D,CAApB,EAAuB,IAAvB;AACA,WAAKjB,KAAL;AACA,aAAO,IAAP;AACD;;;kCAEaiB,C,EAAG;AACf1D,oBAAc,IAAd,EAAoB,IAApB,EAA0B0D,CAA1B;AACA,WAAKjB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACf1D,mBAAa,IAAb,EAAmB,IAAnB,EAAyB0D,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACfzD,mBAAa,IAAb,EAAmB,IAAnB,EAAyByD,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACfxD,mBAAa,IAAb,EAAmB,IAAnB,EAAyBwD,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;;qCAEuB;AAAA;AAAA,UAAbmB,EAAa;AAAA,UAATC,EAAS;AAAA,UAALC,EAAK;;AACtB,aAAO,KAAKC,OAAL,CAAaH,EAAb,EAAiBI,OAAjB,CAAyBH,EAAzB,EAA6BI,OAA7B,CAAqCH,EAArC,CAAP;AACD;;;+BAEUH,O,EAASO,I,EAAM;AACxB9D,kBAAY,IAAZ,EAAkB,IAAlB,EAAwBuD,OAAxB,EAAiCO,IAAjC;AACA,WAAKzB,KAAL;AACA,aAAO,IAAP;AACD;;;0BAEK0B,G,EAAK;AACT9D,iBAAW,IAAX,EAAiB,IAAjB,EAAuB8D,GAAvB;AACA,WAAK1B,KAAL;AACA,aAAO,IAAP;AACD;;;8BAES0B,G,EAAK;AACb7D,qBAAe,IAAf,EAAqB,IAArB,EAA2B6D,GAA3B;AACA,WAAK1B,KAAL;AACA,aAAO,IAAP;AACD;;;qCAEgB2B,M,EAAQC,G,EAAK;AAC5BA,YAAMA,OAAO,IAAIpF,OAAJ,EAAb;AACAsB,yBAAmB8D,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA7E,aAAOL,gBAAgBmF,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;;qCAEgBD,M,EAA6B;AAAA,UAArBC,GAAqB,uEAAf,IAAIlF,OAAJ,EAAe;;AAC5CkF,YAAMA,OAAO,IAAIlF,OAAJ,EAAb;AACAqB,yBAAmB6D,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA7E,aAAOH,gBAAgBiF,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;;qCAEgBD,M,EAA6B;AAAA,UAArBC,GAAqB,uEAAf,IAAIhF,OAAJ,EAAe;;AAC5CgF,YAAMA,OAAO,IAAIhF,OAAJ,EAAb;AACAoB,yBAAmB4D,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA7E,aAAOD,gBAAgB+E,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;AAED;AACA;;;;oCACgBD,M,EAAQC,G,EAAK;AAC3B,cAAQD,OAAOvD,MAAf;AACA,aAAK,CAAL;AAAQ,iBAAO,KAAKyD,gBAAL,CAAsBF,MAAtB,EAA8BC,GAA9B,CAAP;AACR,aAAK,CAAL;AAAQ,iBAAO,KAAKE,gBAAL,CAAsBH,MAAtB,EAA8BC,GAA9B,CAAP;AACR,aAAK,CAAL;AAAQ,iBAAO,KAAKG,gBAAL,CAAsBJ,MAAtB,EAA8BC,GAA9B,CAAP;AACR;AAAS,gBAAM,IAAIZ,KAAJ,CAAU,gBAAV,CAAN;AAJT;AAMD;;;uCAEkBW,M,EAAQC,G,EAAK;AAC9B,cAAQD,OAAOvD,MAAf;AACA,aAAK,CAAL;AACEJ,6BAAmBO,WAAnB,EAAgC,CAACoD,OAAO,CAAP,CAAD,EAAYA,OAAO,CAAP,CAAZ,EAAuB,CAAvB,EAA0B,CAA1B,CAAhC,EAA8D,IAA9D;AACAC,gBAAMA,OAAO,IAAIpF,OAAJ,EAAb;AACCoF,cAAI,CAAJ,CAHH,GAGqBrD,WAHrB;AAGWqD,cAAI,CAAJ,CAHX,GAGqBrD,WAHrB;;AAIE;AACF,aAAK,CAAL;AACEP,6BAAmBO,WAAnB,EAAgC,CAACoD,OAAO,CAAP,CAAD,EAAYA,OAAO,CAAP,CAAZ,EAAuBA,OAAO,CAAP,CAAvB,EAAkC,CAAlC,CAAhC,EAAsE,IAAtE;AACAC,gBAAMA,OAAO,IAAIlF,OAAJ,EAAb;AACCkF,cAAI,CAAJ,CAHH,GAG6BrD,WAH7B;AAGWqD,cAAI,CAAJ,CAHX,GAG6BrD,WAH7B;AAGmBqD,cAAI,CAAJ,CAHnB,GAG6BrD,WAH7B;;AAIE;AACF,aAAK,CAAL;AACEzB,iBAAO6E,OAAO,CAAP,MAAc,CAArB;AACAC,gBAAMA,OAAO,IAAIhF,OAAJ,EAAb;AACAoB,6BAAmB4D,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA;AACF;AAAS,gBAAM,IAAIX,KAAJ,CAAU,gBAAV,CAAN;AAhBT;AAkBA,aAAOY,GAAP;AACD;;;mCAEcD,M,EAAQC,G,EAAK;AAC1B,cAAQD,OAAOvD,MAAf;AACA,aAAK,CAAL;AACEwD,gBAAMA,OAAO,IAAIpF,OAAJ,EAAb;AACAwB,6BAAmB4D,GAAnB,EAAwB,CAACD,OAAO,CAAP,CAAD,EAAYA,OAAO,CAAP,CAAZ,EAAuB,CAAvB,EAA0B,CAA1B,CAAxB,EAAsD,IAAtD;AACAC,cAAIxD,MAAJ,GAAa,CAAb;AACAtB,iBAAOL,gBAAgBmF,GAAhB,CAAP;AACA;AACF,aAAK,CAAL;AACEA,gBAAMA,OAAO,IAAIlF,OAAJ,EAAb;AACAsB,6BAAmB4D,GAAnB,EAAwB,CAACD,OAAO,CAAP,CAAD,EAAYA,OAAO,CAAP,CAAZ,EAAuBA,OAAO,CAAP,CAAvB,EAAkC,CAAlC,CAAxB,EAA8D,IAA9D;AACAC,cAAIxD,MAAJ,GAAa,CAAb;AACAtB,iBAAOH,gBAAgBiF,GAAhB,CAAP;AACA;AACF,aAAK,CAAL;AACE9E,iBAAO6E,OAAO,CAAP,MAAc,CAArB;AACAC,gBAAMA,OAAO,IAAIhF,OAAJ,EAAb;AACAoB,6BAAmB4D,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA7E,iBAAOD,gBAAgB+E,GAAhB,CAAP;AACA;AACF;AACE,gBAAM,IAAIZ,KAAJ,CAAU,gBAAV,CAAN;AApBF;AAsBA,aAAOY,GAAP;AACD;;;wBA5Uc;AACb,aAAO,EAAP;AACD;;;wBA+Dc;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BI,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAUzF,YAAYyF,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAWzF,YAAYyF,KAAZ,CAAlB;AAAuC;;;;EA1GrB1F,S;;eAAhBkC,O","file":"matrix4.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\nimport Vector2, {validateVector2} from './vector2';\nimport Vector3, {validateVector3} from './vector3';\nimport Vector4, {validateVector4} from './vector4';\nimport assert from 'assert';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport mat4_determinant from 'gl-mat4/determinant';\nimport mat4_fromQuat from 'gl-mat4/fromQuat';\nimport mat4_frustum from 'gl-mat4/frustum';\nimport mat4_lookAt from 'gl-mat4/lookAt';\nimport mat4_ortho from 'gl-mat4/ortho';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_transpose from 'gl-mat4/transpose';\nimport mat4_invert from 'gl-mat4/invert';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateY from 'gl-mat4/rotateY';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport mat4_rotate from 'gl-mat4/rotateZ';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport vec2_transformMat4 from 'gl-vec2/transformMat4';\nimport vec3_transformMat4 from 'gl-vec3/transformMat4';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\n\nconst IDENTITY = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n\nexport function validateMatrix4(m) {\n  return m.length === 16 &&\n    Number.isFinite(m[0]) && Number.isFinite(m[1]) &&\n    Number.isFinite(m[2]) && Number.isFinite(m[3]) &&\n    Number.isFinite(m[4]) && Number.isFinite(m[5]) &&\n    Number.isFinite(m[6]) && Number.isFinite(m[7]) &&\n    Number.isFinite(m[8]) && Number.isFinite(m[9]) &&\n    Number.isFinite(m[10]) && Number.isFinite(m[11]) &&\n    Number.isFinite(m[12]) && Number.isFinite(m[13]) &&\n    Number.isFinite(m[14]) && Number.isFinite(m[15]);\n}\n\nconst tempVector4 = [0, 0, 0, 0];\n\nexport default class Matrix4 extends MathArray {\n  constructor(...args) {\n    super();\n    if (Array.isArray(args[0]) && arguments.length === 1) {\n      this.copy(args[0]);\n    } else {\n      this.identity();\n    }\n  }\n\n  get ELEMENTS() {\n    return 16;\n  }\n\n  /* eslint-disable max-params */\n  setRowMajor(\n    m00 = 1, m10 = 0, m20 = 0, m30 = 0,\n    m01 = 0, m11 = 1, m21 = 0, m31 = 0,\n    m02 = 0, m12 = 0, m22 = 1, m32 = 0,\n    m03 = 0, m13 = 0, m23 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  setColumnMajor(\n    m00 = 1, m01 = 0, m02 = 0, m03 = 0,\n    m10 = 0, m11 = 1, m12 = 0, m13 = 0,\n    m20 = 0, m21 = 0, m22 = 1, m23 = 0,\n    m30 = 0, m31 = 0, m32 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  set(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n    this[0] = m00;\n    this[1] = m01;\n    this[2] = m02;\n    this[3] = m03;\n    this[4] = m10;\n    this[5] = m11;\n    this[6] = m12;\n    this[7] = m13;\n    this[8] = m20;\n    this[9] = m21;\n    this[10] = m22;\n    this[11] = m23;\n    this[12] = m30;\n    this[13] = m31;\n    this[14] = m32;\n    this[15] = m33;\n    this.check();\n    return this;\n  }\n  /* eslint-enable max-params */\n\n  // toString() {\n  //   if (config.printRowMajor) {\n  //     mat4_str(this);\n  //   } else {\n  //     mat4_str(this);\n  //   }\n  // }\n\n  // Row major setters and getters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get m00()      { return this[0]; }\n  set m00(value) { return this[0] = checkNumber(value); }\n  get m01()      { return this[4]; }\n  set m01(value) { return this[4] = checkNumber(value); }\n  get m02()      { return this[8]; }\n  set m02(value) { return this[8] = checkNumber(value); }\n  get m03()      { return this[12]; }\n  set m03(value) { return this[12] = checkNumber(value); }\n  get m10()      { return this[1]; }\n  set m10(value) { return this[1] = checkNumber(value); }\n  get m11()      { return this[5]; }\n  set m11(value) { return this[5] = checkNumber(value); }\n  get m12()      { return this[9]; }\n  set m12(value) { return this[9] = checkNumber(value); }\n  get m13()      { return this[13]; }\n  set m13(value) { return this[13] = checkNumber(value); }\n  get m20()      { return this[2]; }\n  set m20(value) { return this[2] = checkNumber(value); }\n  get m21()      { return this[6]; }\n  set m21(value) { return this[6] = checkNumber(value); }\n  get m22()      { return this[10]; }\n  set m22(value) { return this[10] = checkNumber(value); }\n  get m23()      { return this[14]; }\n  set m23(value) { return this[14] = checkNumber(value); }\n  get m30()      { return this[3]; }\n  set m30(value) { return this[3] = checkNumber(value); }\n  get m31()      { return this[7]; }\n  set m31(value) { return this[7] = checkNumber(value); }\n  get m32()      { return this[11]; }\n  set m32(value) { return this[11] = checkNumber(value); }\n  get m33()      { return this[15]; }\n  set m33(value) { return this[15] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Accessors\n\n  determinant() {\n    return mat4_determinant(this);\n  }\n\n  // Constructors\n\n  identity() {\n    for (let i = 0; i < IDENTITY.length; ++i) {\n      this[i] = IDENTITY[i];\n    }\n    this.check();\n    return this;\n  }\n\n  // Calculates a 4x4 matrix from the given quaternion\n  // q quat  Quaternion to create matrix from\n  fromQuaternion(q) {\n    mat4_fromQuat(this, q);\n    this.check();\n    return this;\n  }\n\n  // Generates a frustum matrix with the given bounds\n  // left  Number  Left bound of the frustum\n  // right Number  Right bound of the frustum\n  // bottom  Number  Bottom bound of the frustum\n  // top Number  Top bound of the frustum\n  // near  Number  Near bound of the frustum\n  // far Number  Far bound of the frustum\n  frustum({left, right, bottom, top, near, far}) {\n    mat4_frustum(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a look-at matrix with the given eye position, focal point,\n  // and up axis\n  // eye vec3  Position of the viewer\n  // center  vec3  Point the viewer is looking at\n  // up  vec3  vec3 pointing up\n  lookAt({\n    eye,\n    center = [0, 0, 0],\n    up = [0, 1, 0]\n  } = {}) {\n    mat4_lookAt(this, eye, center, up);\n    this.check();\n    return this;\n  }\n\n  // Generates a orthogonal projection matrix with the given bounds\n  // left  number  Left bound of the frustum\n  // right number  Right bound of the frustum\n  // bottom  number  Bottom bound of the frustum\n  // top number  Top bound of the frustum\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  ortho({left, right, bottom, top, near = 0.1, far = 500}) {\n    mat4_ortho(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a perspective projection matrix with the given bounds\n  // fovy  number  Vertical field of view in radians\n  // aspect  number  Aspect ratio. typically viewport width/height\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  perspective({\n    fov = 45 * Math.PI / 180,\n    aspect = 1,\n    near = 0.1,\n    far = 500\n  } = {}) {\n    if (fov > Math.PI * 2) {\n      throw Error('radians');\n    }\n    mat4_perspective(this, fov, aspect, near, far);\n    this.check();\n    return this;\n  }\n\n  // Modifiers\n\n  transpose() {\n    mat4_transpose(this, this);\n    this.check();\n    return this;\n  }\n\n  invert() {\n    mat4_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Operations\n\n  multiplyLeft(a) {\n    mat4_multiply(this, a, this);\n    this.check();\n    return this;\n  }\n\n  multiplyRight(a) {\n    mat4_multiply(this, this, a);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the X axis\n  rotateX(radians) {\n    mat4_rotateX(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Y axis.\n  rotateY(radians) {\n    mat4_rotateY(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Z axis.\n  rotateZ(radians) {\n    mat4_rotateZ(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  rotateXYZ([rx, ry, rz]) {\n    return this.rotateX(rx).rotateY(ry).rotateZ(rz);\n  }\n\n  rotateAxis(radians, axis) {\n    mat4_rotate(this, this, radians, axis);\n    this.check();\n    return this;\n  }\n\n  scale(vec) {\n    mat4_scale(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  translate(vec) {\n    mat4_translate(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  transformVector2(vector, out) {\n    out = out || new Vector2();\n    vec2_transformMat4(out, vector, this);\n    assert(validateVector2(out));\n    return out;\n  }\n\n  transformVector3(vector, out = new Vector3()) {\n    out = out || new Vector3();\n    vec3_transformMat4(out, vector, this);\n    assert(validateVector3(out));\n    return out;\n  }\n\n  transformVector4(vector, out = new Vector4()) {\n    out = out || new Vector4();\n    vec4_transformMat4(out, vector, this);\n    assert(validateVector4(out));\n    return out;\n  }\n\n  // Transforms any 2, 3 or 4 element vector\n  // returns a newly minted Vector2, Vector3 or Vector4\n  transformVector(vector, out) {\n    switch (vector.length) {\n    case 2: return this.transformVector2(vector, out);\n    case 3: return this.transformVector3(vector, out);\n    case 4: return this.transformVector4(vector, out);\n    default: throw new Error('Illegal vector');\n    }\n  }\n\n  transformDirection(vector, out) {\n    switch (vector.length) {\n    case 2:\n      vec4_transformMat4(tempVector4, [vector[0], vector[1], 0, 0], this);\n      out = out || new Vector2();\n      [out[0], out[1]] = tempVector4;\n      break;\n    case 3:\n      vec4_transformMat4(tempVector4, [vector[0], vector[1], vector[2], 0], this);\n      out = out || new Vector3();\n      [out[0], out[1], out[2]] = tempVector4;\n      break;\n    case 4:\n      assert(vector[3] === 0);\n      out = out || new Vector4();\n      vec4_transformMat4(out, vector, this);\n      break;\n    default: throw new Error('Illegal vector');\n    }\n    return out;\n  }\n\n  transformPoint(vector, out) {\n    switch (vector.length) {\n    case 2:\n      out = out || new Vector2();\n      vec4_transformMat4(out, [vector[0], vector[1], 0, 1], this);\n      out.length = 2;\n      assert(validateVector2(out));\n      break;\n    case 3:\n      out = out || new Vector3();\n      vec4_transformMat4(out, [vector[0], vector[1], vector[2], 1], this);\n      out.length = 3;\n      assert(validateVector3(out));\n      break;\n    case 4:\n      assert(vector[3] !== 0);\n      out = out || new Vector4();\n      vec4_transformMat4(out, vector, this);\n      assert(validateVector4(out));\n      break;\n    default:\n      throw new Error('Illegal vector');\n    }\n    return out;\n  }\n}\n"]} |
@@ -8,2 +8,3 @@ var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | ||
// Adaptation of THREE.js Spherical class, under MIT license | ||
import { formatValue, equals as _equals, config } from './common'; | ||
import { degrees, radians, clamp } from './common'; | ||
@@ -68,5 +69,24 @@ import Vector3 from './vector3'; | ||
value: function toString() { | ||
return '[rho:' + this.radius + ',theta:' + this.theta + ',phi:' + this.phi + ']'; | ||
return this.formatString(config); | ||
} | ||
}, { | ||
key: 'formatString', | ||
value: function formatString(_ref2) { | ||
var printTypes = _ref2.printTypes, | ||
printDegrees = _ref2.printDegrees; | ||
var f = formatValue; | ||
return (printTypes ? 'Spherical' : '') + '[rho:' + f(this.radius) + ',theta:' + f(this.theta) + ',phi:' + f(this.phi) + ']'; | ||
} | ||
}, { | ||
key: 'equals', | ||
value: function equals(other) { | ||
return _equals(this.radius, other.radius) && _equals(this.theta, other.theta) && _equals(this.phi, other.phi); | ||
} | ||
}, { | ||
key: 'exactEquals', | ||
value: function exactEquals(other) { | ||
return this.radius === other.radius && this.theta === other.theta && this.phi === other.phi; | ||
} | ||
/* eslint-disable brace-style */ | ||
@@ -101,7 +121,7 @@ // Cartographic (bearing 0 north, pitch 0 look from above) | ||
key: 'fromLngLatZ', | ||
value: function fromLngLatZ(_ref2) { | ||
var _ref3 = _slicedToArray(_ref2, 3), | ||
lng = _ref3[0], | ||
lat = _ref3[1], | ||
z = _ref3[2]; | ||
value: function fromLngLatZ(_ref3) { | ||
var _ref4 = _slicedToArray(_ref3, 3), | ||
lng = _ref4[0], | ||
lat = _ref4[1], | ||
z = _ref4[2]; | ||
@@ -128,3 +148,3 @@ this.radius = 1 + z / this.radiusScale; | ||
value: function toVector3() { | ||
return new Vector3(0, 0, this.radius).rotateX({ radians: -this.theta }).rotateZ({ radians: -this.phi }); | ||
return new Vector3(0, 0, this.radius).rotateX({ radians: this.theta }).rotateZ({ radians: this.phi }); | ||
} | ||
@@ -199,2 +219,2 @@ | ||
export default SphericalCoordinates; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/spherical-coordinates.js"],"names":["degrees","radians","clamp","Vector3","vec3_length","assert","EPSILON","EARTH_RADIUS_METERS","SphericalCoordinates","phi","theta","radius","bearing","pitch","altitude","radiusScale","arguments","length","Number","isFinite","check","constructor","copy","other","lng","lat","z","v","Math","atan2","acos","rotateX","rotateZ","max","min","PI"],"mappings":"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","file":"spherical-coordinates.js","sourcesContent":["// Adaptation of THREE.js Spherical class, under MIT license\nimport {degrees, radians, clamp} from './common';\nimport Vector3 from './vector3';\n\n/* eslint-disable camelcase */\nimport vec3_length from 'gl-vec3/length';\nimport assert from 'assert';\n\n// TODO - import epsilon\nconst EPSILON = 0.000001;\n\nconst EARTH_RADIUS_METERS = 6.371e6;\n\n// Todo [rho, theta, phi] ?\nexport default class SphericalCoordinates {\n\n  /**\n   * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n   * The poles (phi) are at the positive and negative y axis.\n   * The equator starts at positive z.\n   * @class\n   * @param {Number} phi=0 - rotation around X (latitude)\n   * @param {Number} theta=0 - rotation around Y (longitude)\n   * @param {Number} radius=1 - Distance from center\n   */\n  /* eslint-disable complexity */\n  constructor({\n    phi, theta, radius,\n    bearing, pitch, altitude,\n    radiusScale = EARTH_RADIUS_METERS\n  } = {}) {\n    if (arguments.length === 0) {\n      this.phi = 0;\n      this.theta = 0;\n      this.radius = 1;\n    } else if (Number.isFinite(phi) || Number.isFinite(theta)) {\n      this.phi = phi || 0;         // up / down towards top and bottom pole\n      this.theta = theta || 0;     // around the equator of the sphere\n    } else if (Number.isFinite(bearing) || Number.isFinite(pitch)) {\n      this.bearing = bearing || 0;         // up / down towards top and bottom pole\n      this.pitch = pitch || 0;     // around the equator of the sphere\n    }\n    this.radius = radius || 1;   // radial distance from center\n    this.radiusScale = radiusScale || 1; // Used by lngLatZ\n    this.check();\n  }\n  /* eslint-enable complexity */\n\n  toString() {\n    return `[rho:${this.radius},theta:${this.theta},phi:${this.phi}]`;\n  }\n\n  /* eslint-disable brace-style */\n  // Cartographic (bearing 0 north, pitch 0 look from above)\n  get bearing() { return 180 - degrees(this.phi); }\n  set bearing(v) { this.phi = Math.PI - radians(v); }\n  get pitch() { return degrees(this.theta); }\n  set pitch(v) { this.theta = radians(v); }\n  // get pitch() { return 90 - degrees(this.phi); }\n  // set pitch(v) { this.phi = radians(v) + Math.PI / 2; }\n  // get altitude() { return this.radius - 1; } // relative altitude\n\n  // lnglatZ coordinates\n  get longitude() { return degrees(this.phi); }\n  get latitude() { return degrees(this.theta); }\n  get lng() { return degrees(this.phi); }\n  get lat() { return degrees(this.theta); }\n  get z() { return (this.radius - 1) * this.radiusScale; }\n  /* eslint-enable brace-style */\n\n  set(radius, phi, theta) {\n    this.radius = radius;\n    this.phi = phi;\n    this.theta = theta;\n    return this.check();\n  }\n\n  clone() {\n    return new this.constructor().copy(this);\n  }\n\n  copy(other) {\n    this.radius = other.radius;\n    this.phi = other.phi;\n    this.theta = other.theta;\n    return this.check();\n  }\n\n  fromLngLatZ([lng, lat, z]) {\n    this.radius = 1 + z / this.radiusScale;\n    this.phi = radians(lat);\n    this.theta = radians(lng);\n  }\n\n  fromVector3(v) {\n    this.radius = vec3_length(v);\n    if (this.radius === 0) {\n      this.theta = 0;\n      this.phi = 0;\n    } else {\n      this.theta = Math.atan2(v[0], v[1]); // equator angle around y-up axis\n      this.phi = Math.acos(clamp(v[2] / this.radius, -1, 1)); // polar angle\n    }\n    return this.check();\n  }\n\n  toVector3() {\n    return new Vector3(0, 0, this.radius)\n      .rotateX({radians: -this.theta})\n      .rotateZ({radians: -this.phi});\n  }\n\n  // restrict phi to be betwee EPS and PI-EPS\n  makeSafe() {\n    this.phi = Math.max(EPSILON, Math.min(Math.PI - EPSILON, this.phi));\n  }\n\n  check() {\n    // this.makeSafe();\n    assert(Number.isFinite(this.phi) && Number.isFinite(this.theta) && this.radius > 0);\n    return this;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/spherical-coordinates.js"],"names":["formatValue","equals","config","degrees","radians","clamp","Vector3","vec3_length","assert","EPSILON","EARTH_RADIUS_METERS","SphericalCoordinates","phi","theta","radius","bearing","pitch","altitude","radiusScale","arguments","length","Number","isFinite","check","formatString","printTypes","printDegrees","f","other","constructor","copy","lng","lat","z","v","Math","atan2","acos","rotateX","rotateZ","max","min","PI"],"mappings":"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","file":"spherical-coordinates.js","sourcesContent":["// Adaptation of THREE.js Spherical class, under MIT license\nimport {formatValue, equals, config} from './common';\nimport {degrees, radians, clamp} from './common';\nimport Vector3 from './vector3';\n\n/* eslint-disable camelcase */\nimport vec3_length from 'gl-vec3/length';\nimport assert from 'assert';\n\n// TODO - import epsilon\nconst EPSILON = 0.000001;\n\nconst EARTH_RADIUS_METERS = 6.371e6;\n\n// Todo [rho, theta, phi] ?\nexport default class SphericalCoordinates {\n\n  /**\n   * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n   * The poles (phi) are at the positive and negative y axis.\n   * The equator starts at positive z.\n   * @class\n   * @param {Number} phi=0 - rotation around X (latitude)\n   * @param {Number} theta=0 - rotation around Y (longitude)\n   * @param {Number} radius=1 - Distance from center\n   */\n  /* eslint-disable complexity */\n  constructor({\n    phi, theta, radius,\n    bearing, pitch, altitude,\n    radiusScale = EARTH_RADIUS_METERS\n  } = {}) {\n    if (arguments.length === 0) {\n      this.phi = 0;\n      this.theta = 0;\n      this.radius = 1;\n    } else if (Number.isFinite(phi) || Number.isFinite(theta)) {\n      this.phi = phi || 0;         // up / down towards top and bottom pole\n      this.theta = theta || 0;     // around the equator of the sphere\n    } else if (Number.isFinite(bearing) || Number.isFinite(pitch)) {\n      this.bearing = bearing || 0;         // up / down towards top and bottom pole\n      this.pitch = pitch || 0;     // around the equator of the sphere\n    }\n    this.radius = radius || 1;   // radial distance from center\n    this.radiusScale = radiusScale || 1; // Used by lngLatZ\n    this.check();\n  }\n  /* eslint-enable complexity */\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString({printTypes, printDegrees}) {\n    const f = formatValue;\n    return `${printTypes ? 'Spherical' : ''}\\\n[rho:${f(this.radius)},theta:${f(this.theta)},phi:${f(this.phi)}]`;\n  }\n\n  equals(other) {\n    return equals(this.radius, other.radius) &&\n      equals(this.theta, other.theta) &&\n      equals(this.phi, other.phi);\n  }\n\n  exactEquals(other) {\n    return this.radius === other.radius &&\n      this.theta === other.theta &&\n      this.phi === other.phi;\n  }\n\n  /* eslint-disable brace-style */\n  // Cartographic (bearing 0 north, pitch 0 look from above)\n  get bearing() { return 180 - degrees(this.phi); }\n  set bearing(v) { this.phi = Math.PI - radians(v); }\n  get pitch() { return degrees(this.theta); }\n  set pitch(v) { this.theta = radians(v); }\n  // get pitch() { return 90 - degrees(this.phi); }\n  // set pitch(v) { this.phi = radians(v) + Math.PI / 2; }\n  // get altitude() { return this.radius - 1; } // relative altitude\n\n  // lnglatZ coordinates\n  get longitude() { return degrees(this.phi); }\n  get latitude() { return degrees(this.theta); }\n  get lng() { return degrees(this.phi); }\n  get lat() { return degrees(this.theta); }\n  get z() { return (this.radius - 1) * this.radiusScale; }\n  /* eslint-enable brace-style */\n\n  set(radius, phi, theta) {\n    this.radius = radius;\n    this.phi = phi;\n    this.theta = theta;\n    return this.check();\n  }\n\n  clone() {\n    return new this.constructor().copy(this);\n  }\n\n  copy(other) {\n    this.radius = other.radius;\n    this.phi = other.phi;\n    this.theta = other.theta;\n    return this.check();\n  }\n\n  fromLngLatZ([lng, lat, z]) {\n    this.radius = 1 + z / this.radiusScale;\n    this.phi = radians(lat);\n    this.theta = radians(lng);\n  }\n\n  fromVector3(v) {\n    this.radius = vec3_length(v);\n    if (this.radius === 0) {\n      this.theta = 0;\n      this.phi = 0;\n    } else {\n      this.theta = Math.atan2(v[0], v[1]); // equator angle around y-up axis\n      this.phi = Math.acos(clamp(v[2] / this.radius, -1, 1)); // polar angle\n    }\n    return this.check();\n  }\n\n  toVector3() {\n    return new Vector3(0, 0, this.radius)\n      .rotateX({radians: this.theta})\n      .rotateZ({radians: this.phi});\n  }\n\n  // restrict phi to be betwee EPS and PI-EPS\n  makeSafe() {\n    this.phi = Math.max(EPSILON, Math.min(Math.PI - EPSILON, this.phi));\n  }\n\n  check() {\n    // this.makeSafe();\n    assert(Number.isFinite(this.phi) && Number.isFinite(this.theta) && this.radius > 0);\n    return this;\n  }\n}\n"]} |
@@ -72,4 +72,3 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); | ||
vec3_set(this, x, y, z); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -138,4 +137,3 @@ | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -174,4 +172,3 @@ }, { | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -210,41 +207,5 @@ }, { | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'divide', | ||
value: function divide() { | ||
for (var _len4 = arguments.length, vectors = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { | ||
vectors[_key4] = arguments[_key4]; | ||
} | ||
var _iteratorNormalCompletion4 = true; | ||
var _didIteratorError4 = false; | ||
var _iteratorError4 = undefined; | ||
try { | ||
for (var _iterator4 = vectors[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) { | ||
var vector = _step4.value; | ||
vec3_divide(this, this, vector); | ||
} | ||
} catch (err) { | ||
_didIteratorError4 = true; | ||
_iteratorError4 = err; | ||
} finally { | ||
try { | ||
if (!_iteratorNormalCompletion4 && _iterator4.return) { | ||
_iterator4.return(); | ||
} | ||
} finally { | ||
if (_didIteratorError4) { | ||
throw _iteratorError4; | ||
} | ||
} | ||
} | ||
this.check(); | ||
return this; | ||
} | ||
}, { | ||
key: 'scale', | ||
@@ -255,20 +216,11 @@ value: function scale(_scale) { | ||
} else { | ||
vec3_dot(this, this, _scale); | ||
vec3_multiply(this, this, _scale); | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'scaleAndAdd', | ||
value: function scaleAndAdd(vector, scale) { | ||
vec3_scaleAndAdd(this, this, vector, scale); | ||
this.check(); | ||
return this; | ||
} | ||
}, { | ||
key: 'negate', | ||
value: function negate() { | ||
vec3_negate(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -279,4 +231,3 @@ }, { | ||
vec3_inverse(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -287,4 +238,3 @@ }, { | ||
vec3_normalize(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -295,4 +245,3 @@ }, { | ||
vec3_cross(this, this, vector); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -303,4 +252,3 @@ }, { | ||
vec3_lerp(this, this, vector, coeff); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -315,4 +263,3 @@ }, { | ||
vec3_rotateX(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -327,4 +274,3 @@ }, { | ||
vec3_rotateY(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -339,4 +285,3 @@ }, { | ||
vec3_rotateZ(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -346,11 +291,53 @@ }, { | ||
value: function operation(_operation) { | ||
for (var _len5 = arguments.length, args = Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) { | ||
args[_key5 - 1] = arguments[_key5]; | ||
for (var _len4 = arguments.length, args = Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) { | ||
args[_key4 - 1] = arguments[_key4]; | ||
} | ||
_operation.apply(undefined, [this, this].concat(args)); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
// TBD - do we really need these? | ||
}, { | ||
key: 'divide', | ||
value: function divide() { | ||
for (var _len5 = arguments.length, vectors = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) { | ||
vectors[_key5] = arguments[_key5]; | ||
} | ||
var _iteratorNormalCompletion4 = true; | ||
var _didIteratorError4 = false; | ||
var _iteratorError4 = undefined; | ||
try { | ||
for (var _iterator4 = vectors[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) { | ||
var vector = _step4.value; | ||
vec3_divide(this, this, vector); | ||
} | ||
} catch (err) { | ||
_didIteratorError4 = true; | ||
_iteratorError4 = err; | ||
} finally { | ||
try { | ||
if (!_iteratorNormalCompletion4 && _iterator4.return) { | ||
_iterator4.return(); | ||
} | ||
} finally { | ||
if (_didIteratorError4) { | ||
throw _iteratorError4; | ||
} | ||
} | ||
} | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'scaleAndAdd', | ||
value: function scaleAndAdd(vector, scale) { | ||
vec3_scaleAndAdd(this, this, vector, scale); | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'ELEMENTS', | ||
@@ -390,2 +377,2 @@ get: function get() { | ||
export default Vector3; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["MathArray","checkNumber","vec3_set","vec3_length","vec3_distance","vec3_angle","vec3_add","vec3_subtract","vec3_multiply","vec3_divide","vec3_scale","vec3_scaleAndAdd","vec3_negate","vec3_inverse","vec3_normalize","vec3_dot","vec3_cross","vec3_lerp","vec3_rotateX","vec3_rotateY","vec3_rotateZ","ORIGIN","validateVector3","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_dot(this, this, scale);\n    }\n    this.check();\n    return this;\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    this.check();\n    return this;\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    this.check();\n    return this;\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    this.check();\n    return this;\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    this.check();\n    return this;\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    this.check();\n    return this;\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    this.check();\n    return this;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["MathArray","checkNumber","vec3_set","vec3_length","vec3_distance","vec3_angle","vec3_add","vec3_subtract","vec3_multiply","vec3_divide","vec3_scale","vec3_scaleAndAdd","vec3_negate","vec3_inverse","vec3_normalize","vec3_dot","vec3_cross","vec3_lerp","vec3_rotateX","vec3_rotateY","vec3_rotateZ","ORIGIN","validateVector3","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    return this.check();\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    return this.check();\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]} |
@@ -9,2 +9,3 @@ 'use strict'; | ||
exports.formatValue = formatValue; | ||
exports.formatAngle = formatAngle; | ||
exports.isArray = isArray; | ||
@@ -27,4 +28,7 @@ exports.clone = clone; | ||
config.debug = true; | ||
config.precision = 4; | ||
config.printTypes = false; | ||
config.printDegrees = false; | ||
config.printRowMajor = true; | ||
config.precision = 4; | ||
exports.config = config; | ||
@@ -48,8 +52,27 @@ function configure(options) { | ||
function round(value) { | ||
return Math.round(value / config.EPSILON) * config.EPSILON; | ||
} | ||
function formatValue(value) { | ||
var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : config.precision || 4; | ||
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, | ||
_ref$precision = _ref.precision, | ||
precision = _ref$precision === undefined ? config.precision || 4 : _ref$precision; | ||
value = round(value); | ||
return parseFloat(value.toPrecision(precision)); | ||
} | ||
function formatAngle(value) { | ||
var _ref2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, | ||
_ref2$precision = _ref2.precision, | ||
precision = _ref2$precision === undefined ? config.precision || 4 : _ref2$precision, | ||
_ref2$printDegrees = _ref2.printDegrees, | ||
printDegrees = _ref2$printDegrees === undefined ? config.printAngles : _ref2$printDegrees; | ||
value = printDegrees ? degrees(value) : value; | ||
value = round(value); | ||
return '' + parseFloat(value.toPrecision(precision)) + (printDegrees ? '°' : ''); | ||
} | ||
// Returns true if value is either an array or a typed array | ||
@@ -162,2 +185,2 @@ // Note: does not return true for ArrayBuffers and DataViews | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/common.js"],"names":["configure","checkNumber","formatValue","isArray","clone","radians","degrees","sin","cos","tan","asin","acos","atan","clamp","equals","config","EPSILON","debug","printRowMajor","precision","options","epsilon","value","Number","isFinite","Error","parseFloat","toPrecision","Array","ArrayBuffer","isView","length","undefined","array","map","func","result","i","Math","PI","angle","min","max","a","b","abs"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-shadow */\n// TODO - remove\nconst config = {};\nconfig.EPSILON = 1e-12;\nconfig.debug = true;\nconfig.printRowMajor = true;\nconfig.precision = 4;\nexport {config};\n\nexport function configure(options) {\n  if ('epsilon' in options) {\n    config.EPSILON = options.epsilon;\n  }\n\n  if ('debug' in options) {\n    config.debug = options.debug;\n  }\n}\n\nexport function checkNumber(value) {\n  if (!Number.isFinite(value)) {\n    throw new Error(`Invalid number ${value}`);\n  }\n  return value;\n}\n\nexport function formatValue(value, precision = config.precision || 4) {\n  return parseFloat(value.toPrecision(precision));\n}\n\n// Returns true if value is either an array or a typed array\n// Note: does not return true for ArrayBuffers and DataViews\nexport function isArray(value) {\n  return Array.isArray(value) || (ArrayBuffer.isView(value) && value.length !== undefined);\n}\n\n// If the array has a clone function, calls it, otherwise returns a copy\nexport function clone(array) {\n  return array.clone ? array.clone() : new Array(array);\n}\n\n// If the argument value is an array, applies the func element wise,\n// otherwise applies func to the argument value\nfunction map(value, func) {\n  if (isArray(value)) {\n    const result = clone(value);\n    for (let i = 0; i < result.length; ++i) {\n      result[i] = func(result[i], i, result);\n    }\n    return result;\n  }\n  return func(value);\n}\n\n//\n// GLSL math function equivalents\n// Works on both single values and vectors\n//\n\nexport function radians(degrees) {\n  return map(degrees, degrees => degrees / 180 * Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function degrees(radians) {\n  return map(radians, radians => radians * 180 / Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function sin(radians) {\n  return map(radians, angle => Math.sin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function cos(radians) {\n  return map(radians, angle => Math.cos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function tan(radians) {\n  return map(radians, angle => Math.tan(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function asin(radians) {\n  return map(radians, angle => Math.asin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function acos(radians) {\n  return map(radians, angle => Math.acos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function atan(radians) {\n  return map(radians, angle => Math.atan(angle));\n}\n\nexport function clamp(value, min, max) {\n  return map(value, value => Math.max(min, Math.min(max, value)));\n}\n\nexport function equals(a, b) {\n  if (Array.isArray(a) && Array.isArray(b)) {\n    if (a === b) {\n      return true;\n    }\n    if (a.length !== b.length) {\n      return false;\n    }\n    for (let i = 0; i < a.length; ++i) {\n      if (!equals(a[i], b[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n  return Math.abs(a - b) <= config.EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/common.js"],"names":["configure","checkNumber","formatValue","formatAngle","isArray","clone","radians","degrees","sin","cos","tan","asin","acos","atan","clamp","equals","config","EPSILON","debug","precision","printTypes","printDegrees","printRowMajor","options","epsilon","value","Number","isFinite","Error","round","Math","parseFloat","toPrecision","printAngles","Array","ArrayBuffer","isView","length","undefined","array","map","func","result","i","PI","angle","min","max","a","b","abs"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-shadow */\n// TODO - remove\nconst config = {};\nconfig.EPSILON = 1e-12;\nconfig.debug = true;\nconfig.precision = 4;\nconfig.printTypes = false;\nconfig.printDegrees = false;\nconfig.printRowMajor = true;\n\nexport {config};\n\nexport function configure(options) {\n  if ('epsilon' in options) {\n    config.EPSILON = options.epsilon;\n  }\n\n  if ('debug' in options) {\n    config.debug = options.debug;\n  }\n}\n\nexport function checkNumber(value) {\n  if (!Number.isFinite(value)) {\n    throw new Error(`Invalid number ${value}`);\n  }\n  return value;\n}\n\nfunction round(value) {\n  return Math.round(value / config.EPSILON) * config.EPSILON;\n}\n\nexport function formatValue(value, {\n  precision = config.precision || 4\n} = {}) {\n  value = round(value);\n  return parseFloat(value.toPrecision(precision));\n}\n\nexport function formatAngle(value, {\n  precision = config.precision || 4,\n  printDegrees = config.printAngles\n} = {}) {\n  value = printDegrees ? degrees(value) : value;\n  value = round(value);\n  return `${parseFloat(value.toPrecision(precision))}${printDegrees ? '°' : ''}`;\n}\n\n// Returns true if value is either an array or a typed array\n// Note: does not return true for ArrayBuffers and DataViews\nexport function isArray(value) {\n  return Array.isArray(value) || (ArrayBuffer.isView(value) && value.length !== undefined);\n}\n\n// If the array has a clone function, calls it, otherwise returns a copy\nexport function clone(array) {\n  return array.clone ? array.clone() : new Array(array);\n}\n\n// If the argument value is an array, applies the func element wise,\n// otherwise applies func to the argument value\nfunction map(value, func) {\n  if (isArray(value)) {\n    const result = clone(value);\n    for (let i = 0; i < result.length; ++i) {\n      result[i] = func(result[i], i, result);\n    }\n    return result;\n  }\n  return func(value);\n}\n\n//\n// GLSL math function equivalents\n// Works on both single values and vectors\n//\n\nexport function radians(degrees) {\n  return map(degrees, degrees => degrees / 180 * Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function degrees(radians) {\n  return map(radians, radians => radians * 180 / Math.PI);\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function sin(radians) {\n  return map(radians, angle => Math.sin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function cos(radians) {\n  return map(radians, angle => Math.cos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function tan(radians) {\n  return map(radians, angle => Math.tan(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function asin(radians) {\n  return map(radians, angle => Math.asin(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function acos(radians) {\n  return map(radians, angle => Math.acos(angle));\n}\n\n// GLSL equivalent: Works on single values and vectors\nexport function atan(radians) {\n  return map(radians, angle => Math.atan(angle));\n}\n\nexport function clamp(value, min, max) {\n  return map(value, value => Math.max(min, Math.min(max, value)));\n}\n\nexport function equals(a, b) {\n  if (Array.isArray(a) && Array.isArray(b)) {\n    if (a === b) {\n      return true;\n    }\n    if (a.length !== b.length) {\n      return false;\n    }\n    for (let i = 0; i < a.length; ++i) {\n      if (!equals(a[i], b[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n  return Math.abs(a - b) <= config.EPSILON * Math.max(1.0, Math.abs(a), Math.abs(b));\n}\n"]} |
@@ -95,7 +95,12 @@ 'use strict'; | ||
value: function toString() { | ||
return this.formatString(_common.config); | ||
} | ||
}, { | ||
key: 'formatString', | ||
value: function formatString(opts) { | ||
var string = ''; | ||
for (var i = 0; i < this.ELEMENTS; ++i) { | ||
string += (i > 0 ? ', ' : '') + (0, _common.formatValue)(this[i]); | ||
string += (i > 0 ? ', ' : '') + (0, _common.formatValue)(this[i], opts); | ||
} | ||
return this.constructor.name + '(' + string + ')'; | ||
return (opts.printTypes ? this.constructor.name : '') + '[' + string + ']'; | ||
} | ||
@@ -163,2 +168,3 @@ }, { | ||
} | ||
return this; | ||
} | ||
@@ -183,2 +189,2 @@ }, { | ||
exports.default = MathArray; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tYXRoLWFycmF5LmpzIl0sIm5hbWVzIjpbIk1hdGhBcnJheSIsIlN1YmNsYXNzIiwiY29uc3RydWN0b3IiLCJjbG9uZSIsImNvcHkiLCJjaGVjayIsImFycmF5IiwiaSIsIkVMRU1FTlRTIiwiYXJncyIsIm9mZnNldCIsInN0cmluZyIsIm5hbWUiLCJGbG9hdDMyQXJyYXkiLCJsZW5ndGgiLCJ2YWxpZCIsIk51bWJlciIsImlzRmluaXRlIiwiZGVidWciLCJ2YWxpZGF0ZSIsIkVycm9yIiwibGVuIiwiQXJyYXkiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUVxQkEsUzs7Ozs7Ozs7Ozs7NEJBRVg7QUFDTixVQUFNQyxXQUFXLEtBQUtDLFdBQXRCO0FBQ0EsVUFBTUMsUUFBUSxJQUFJRixRQUFKLEdBQWVHLElBQWYsQ0FBb0IsSUFBcEIsQ0FBZDtBQUNBRCxZQUFNRSxLQUFOO0FBQ0EsYUFBT0YsS0FBUDtBQUNEOzs7eUJBRUlHLEssRUFBTztBQUNWLFdBQUssSUFBSUMsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGFBQUtBLENBQUwsSUFBVUQsTUFBTUMsQ0FBTixDQUFWO0FBQ0Q7QUFDRCxXQUFLRixLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7OzswQkFFWTtBQUFBLHdDQUFOSSxJQUFNO0FBQU5BLFlBQU07QUFBQTs7QUFDWCxXQUFLLElBQUlGLElBQUksQ0FBYixFQUFnQkEsSUFBSSxLQUFLQyxRQUF6QixFQUFtQyxFQUFFRCxDQUFyQyxFQUF3QztBQUN0QyxhQUFLQSxDQUFMLElBQVVFLEtBQUtGLENBQUwsS0FBVyxDQUFyQjtBQUNEO0FBQ0QsV0FBS0YsS0FBTDtBQUNBLGFBQU8sSUFBUDtBQUNEOzs7OEJBRVNDLEssRUFBbUI7QUFBQSxVQUFaSSxNQUFZLHVFQUFILENBQUc7O0FBQzNCLFdBQUssSUFB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LENBQUwsS0FBV08sTUFBWDtBQUNEO0FBQ0Y7QUFDRCxXQUFLVCxLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7Ozs7cUJBbkdvQ2lCLEs7O2tCQUFsQnRCLFMiLCJmaWxlIjoibWF0aC1hcnJheS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Zm9ybWF0VmFsdWUsIGVxdWFscywgY29uZmlnfSBmcm9tICcuL2NvbW1vbic7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1hdGhBcnJheSBleHRlbmRzIEFycmF5IHtcblxuICBjbG9uZSgpIHtcbiAgICBjb25zdCBTdWJjbGFzcyA9IHRoaXMuY29uc3RydWN0b3I7XG4gICAgY29uc3QgY2xvbmUgPSBuZXcgU3ViY2xhc3MoKS5jb3B5KHRoaXMpO1xuICAgIGNsb25lLmNoZWNrKCk7XG4gICAgcmV0dXJuIGNsb25lO1xuICB9XG5cbiAgY29weShhcnJheSkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICB0aGlzW2ldID0gYXJyYXlbaV07XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHNldCguLi5hcmdzKSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcmdzW2ldIHx8IDA7XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIGZyb21BcnJheShhcnJheSwgb2Zmc2V0ID0gMCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICB0aGlzW2ldID0gYXJyYXlbaSArIG9mZnNldF07XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRvU3RyaW5nKCkge1xuICAgIGxldCBzdHJpbmcgPSAnJztcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgc3RyaW5nICs9IChpID4gMCA/ICcsICcgOiAnJykgKyBmb3JtYXRWYWx1ZSh0aGlzW2ldKTtcbiAgICB9XG4gICAgcmV0dXJuIGAke3RoaXMuY29uc3RydWN0b3IubmFtZX0oJHtzdHJpbmd9KWA7XG4gIH1cblxuICB0b0FycmF5KGFycmF5ID0gW10sIG9mZnNldCA9IDApIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgYXJyYXlbb2Zmc2V0ICsgaV0gPSB0aGlzW2ldO1xuICAgIH1cbiAgICByZXR1cm4gYXJyYXk7XG4gIH1cblxuICB0b0Zsb2F0MzJBcnJheSgpIHtcbiAgICByZXR1cm4gbmV3IEZsb2F0MzJBcnJheSh0aGlzKTtcbiAgfVxuXG4gIGVxdWFscyhhcnJheSkge1xuICAgIGlmICghYXJyYXkgfHwgdGhpcy5sZW5ndGggIT09IGFycmF5Lmxlbmd0aCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgaWYgKCFlcXVhbHModGhpc1tpXSwgYXJyYXlbaV0pKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBleGFjdEVxdWFscyhhcnJheSkge1xuICAgIGlmICghYXJyYXkgfHwgdGhpcy5sZW5ndGggIT09IGFycmF5Lmxlbmd0aCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgaWYgKHRoaXNbaV0gIT09IGFycmF5W2ldKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICB2YWxpZGF0ZShhcnJheSA9IHRoaXMpIHtcbiAgICBsZXQgdmFsaWQgPSBhcnJheSAmJiBhcnJheS5sZW5ndGggPT09IHRoaXMuRUxFTUVOVFM7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHZhbGlkID0gdmFsaWQgJiYgTnVtYmVyLmlzRmluaXRlKGFycmF5W2ldKTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbGlkO1xuICB9XG5cbiAgY2hlY2soYXJyYXkgPSB0aGlzKSB7XG4gICAgaWYgKGNvbmZpZy5kZWJ1ZyAmJiAhdGhpcy52YWxpZGF0ZShhcnJheSkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCAke3RoaXMuY29uc3RydWN0b3IubmFtZX1gKTtcbiAgICB9XG4gIH1cblxuICBub3JtYWxpemUoKSB7XG4gICAgY29uc3QgbGVuZ3RoID0gdGhpcy5sZW4oKTtcbiAgICBpZiAobGVuZ3RoICE9PSAwKSB7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgICB0aGlzW2ldIC89IGxlbmd0aDtcbiAgICAgIH1cbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tYXRoLWFycmF5LmpzIl0sIm5hbWVzIjpbIk1hdGhBcnJheSIsIlN1YmNsYXNzIiwiY29uc3RydWN0b3IiLCJjbG9uZSIsImNvcHkiLCJjaGVjayIsImFycmF5IiwiaSIsIkVMRU1FTlRTIiwiYXJncyIsIm9mZnNldCIsImZvcm1hdFN0cmluZyIsIm9wdHMiLCJzdHJpbmciLCJwcmludFR5cGVzIiwibmFtZSIsIkZsb2F0MzJBcnJheSIsImxlbmd0aCIsInZhbGlkIiwiTnVtYmVyIiwiaXNGaW5pdGUiLCJkZWJ1ZyIsInZhbGlkYXRlIiwiRXJyb3IiLCJsZW4iLCJBcnJheSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBRXFCQSxTOzs7Ozs7Ozs7Ozs0QkFFWDtBQUNOLFVBQU1DLFdBQVcsS0FBS0MsV0FBdEI7QUFDQSxVQUFNQyxRQUFRLElBQUlGLFFBQUosR0FBZUcsSUFBZixDQUFvQixJQUFwQixDQUFkO0FBQ0FELFlBQU1FLEtBQU47QUFDQSxhQUFPRixLQUFQO0FBQ0Q7Ozt5QkFFSUcsSyxFQUFPO0FBQ1YsV0FBSyxJQUFJQyxJQUFJLENBQWIsRUFBZ0JBLElBQUksS0FBS0MsUUFBekIsRUFBbUMsRUFBRUQsQ0FBckMsRUFBd0M7QUFDdEMsYUFBS0EsQ0FBTCxJQUFVRCxNQUFNQyxDQUFOLENBQVY7QUFDRDtBQUNELFdBQUtGLEtBQUw7QUFDQSxhQUFPLElBQVA7QUFDRDs7OzBCQUVZO0FBQUEsd0NBQU5JLElBQU07QUFBTkEsWUFBTTtBQUFBOztBQUNYLFdBQUssSUFBSUYsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGFBQUtBLENBQUwsSUFBVUUsS0FBS0YsQ0FBTCxLQUFXLENBQXJCO0FBQ0Q7QUFDRCxXQUFLRixLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7Ozs4QkFFU0MsSyxFQUFtQjtBQUFBLFVB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QUNWLFVBQU1FLFNBQVMsS0FBS08sR0FBTCxFQUFmO0FBQ0EsVUFBSVAsV0FBVyxDQUFmLEVBQWtCO0FBQ2hCLGFBQUssSUFBSVYsSUFBSSxDQUFiLEVBQWdCQSxJQUFJLEtBQUtDLFFBQXpCLEVBQW1DLEVBQUVELENBQXJDLEVBQXdDO0FBQ3RDLGVBQUtBLENBQUwsS0FBV1UsTUFBWDtBQUNEO0FBQ0Y7QUFDRCxXQUFLWixLQUFMO0FBQ0EsYUFBTyxJQUFQO0FBQ0Q7Ozs7cUJBeEdvQ29CLEs7O2tCQUFsQnpCLFMiLCJmaWxlIjoibWF0aC1hcnJheS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Zm9ybWF0VmFsdWUsIGVxdWFscywgY29uZmlnfSBmcm9tICcuL2NvbW1vbic7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1hdGhBcnJheSBleHRlbmRzIEFycmF5IHtcblxuICBjbG9uZSgpIHtcbiAgICBjb25zdCBTdWJjbGFzcyA9IHRoaXMuY29uc3RydWN0b3I7XG4gICAgY29uc3QgY2xvbmUgPSBuZXcgU3ViY2xhc3MoKS5jb3B5KHRoaXMpO1xuICAgIGNsb25lLmNoZWNrKCk7XG4gICAgcmV0dXJuIGNsb25lO1xuICB9XG5cbiAgY29weShhcnJheSkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICB0aGlzW2ldID0gYXJyYXlbaV07XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHNldCguLi5hcmdzKSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHRoaXNbaV0gPSBhcmdzW2ldIHx8IDA7XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIGZyb21BcnJheShhcnJheSwgb2Zmc2V0ID0gMCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5FTEVNRU5UUzsgKytpKSB7XG4gICAgICB0aGlzW2ldID0gYXJyYXlbaSArIG9mZnNldF07XG4gICAgfVxuICAgIHRoaXMuY2hlY2soKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRvU3RyaW5nKCkge1xuICAgIHJldHVybiB0aGlzLmZvcm1hdFN0cmluZyhjb25maWcpO1xuICB9XG5cbiAgZm9ybWF0U3RyaW5nKG9wdHMpIHtcbiAgICBsZXQgc3RyaW5nID0gJyc7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHN0cmluZyArPSAoaSA+IDAgPyAnLCAnIDogJycpICsgZm9ybWF0VmFsdWUodGhpc1tpXSwgb3B0cyk7XG4gICAgfVxuICAgIHJldHVybiBgJHtvcHRzLnByaW50VHlwZXMgPyB0aGlzLmNvbnN0cnVjdG9yLm5hbWUgOiAnJ31bJHtzdHJpbmd9XWA7XG4gIH1cblxuICB0b0FycmF5KGFycmF5ID0gW10sIG9mZnNldCA9IDApIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgYXJyYXlbb2Zmc2V0ICsgaV0gPSB0aGlzW2ldO1xuICAgIH1cbiAgICByZXR1cm4gYXJyYXk7XG4gIH1cblxuICB0b0Zsb2F0MzJBcnJheSgpIHtcbiAgICByZXR1cm4gbmV3IEZsb2F0MzJBcnJheSh0aGlzKTtcbiAgfVxuXG4gIGVxdWFscyhhcnJheSkge1xuICAgIGlmICghYXJyYXkgfHwgdGhpcy5sZW5ndGggIT09IGFycmF5Lmxlbmd0aCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgaWYgKCFlcXVhbHModGhpc1tpXSwgYXJyYXlbaV0pKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBleGFjdEVxdWFscyhhcnJheSkge1xuICAgIGlmICghYXJyYXkgfHwgdGhpcy5sZW5ndGggIT09IGFycmF5Lmxlbmd0aCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgaWYgKHRoaXNbaV0gIT09IGFycmF5W2ldKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICB2YWxpZGF0ZShhcnJheSA9IHRoaXMpIHtcbiAgICBsZXQgdmFsaWQgPSBhcnJheSAmJiBhcnJheS5sZW5ndGggPT09IHRoaXMuRUxFTUVOVFM7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLkVMRU1FTlRTOyArK2kpIHtcbiAgICAgIHZhbGlkID0gdmFsaWQgJiYgTnVtYmVyLmlzRmluaXRlKGFycmF5W2ldKTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbGlkO1xuICB9XG5cbiAgY2hlY2soYXJyYXkgPSB0aGlzKSB7XG4gICAgaWYgKGNvbmZpZy5kZWJ1ZyAmJiAhdGhpcy52YWxpZGF0ZShhcnJheSkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCAke3RoaXMuY29uc3RydWN0b3IubmFtZX1gKTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBub3JtYWxpemUoKSB7XG4gICAgY29uc3QgbGVuZ3RoID0gdGhpcy5sZW4oKTtcbiAgICBpZiAobGVuZ3RoICE9PSAwKSB7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHRoaXMuRUxFTUVOVFM7ICsraSkge1xuICAgICAgICB0aGlzW2ldIC89IGxlbmd0aDtcbiAgICAgIH1cbiAgICB9XG4gICAgdGhpcy5jaGVjaygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG59XG4iXX0= |
@@ -121,2 +121,4 @@ 'use strict'; | ||
var tempVector4 = [0, 0, 0, 0]; | ||
var Matrix4 = function (_MathArray) { | ||
@@ -495,2 +497,58 @@ _inherits(Matrix4, _MathArray); | ||
}, { | ||
key: 'transformDirection', | ||
value: function transformDirection(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
(0, _transformMat6.default)(tempVector4, [vector[0], vector[1], 0, 0], this); | ||
out = out || new _vector2.default(); | ||
out[0] = tempVector4[0]; | ||
out[1] = tempVector4[1]; | ||
break; | ||
case 3: | ||
(0, _transformMat6.default)(tempVector4, [vector[0], vector[1], vector[2], 0], this); | ||
out = out || new _vector4.default(); | ||
out[0] = tempVector4[0]; | ||
out[1] = tempVector4[1]; | ||
out[2] = tempVector4[2]; | ||
break; | ||
case 4: | ||
(0, _assert2.default)(vector[3] === 0); | ||
out = out || new _vector6.default(); | ||
(0, _transformMat6.default)(out, vector, this); | ||
break; | ||
default: | ||
throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
}, { | ||
key: 'transformPoint', | ||
value: function transformPoint(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
out = out || new _vector2.default(); | ||
(0, _transformMat6.default)(out, [vector[0], vector[1], 0, 1], this); | ||
out.length = 2; | ||
(0, _assert2.default)((0, _vector.validateVector2)(out)); | ||
break; | ||
case 3: | ||
out = out || new _vector4.default(); | ||
(0, _transformMat6.default)(out, [vector[0], vector[1], vector[2], 1], this); | ||
out.length = 3; | ||
(0, _assert2.default)((0, _vector3.validateVector3)(out)); | ||
break; | ||
case 4: | ||
(0, _assert2.default)(vector[3] !== 0); | ||
out = out || new _vector6.default(); | ||
(0, _transformMat6.default)(out, vector, this); | ||
(0, _assert2.default)((0, _vector5.validateVector4)(out)); | ||
break; | ||
default: | ||
throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
}, { | ||
key: 'ELEMENTS', | ||
@@ -634,2 +692,2 @@ get: function get() { | ||
exports.default = Matrix4; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/matrix4.js"],"names":["validateMatrix4","IDENTITY","m","length","Number","isFinite","Matrix4","args","Array","isArray","arguments","copy","identity","m00","m10","m20","m30","m01","m11","m21","m31","m02","m12","m22","m32","m03","m13","m23","m33","set","check","i","q","left","right","bottom","top","near","far","eye","center","up","fov","Math","PI","aspect","Error","a","radians","rx","ry","rz","rotateX","rotateY","rotateZ","axis","vec","vector","out","transformVector2","transformVector3","transformVector4","value"],"mappings":";;;;;;;;;;QA8BgBA,e,GAAAA,e;;AA9BhB;;;;AACA;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAIA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;;;;;AAnBA;AACA;;;AAoBA,IAAMC,WAAW,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,EAA4B,CAA5B,EAA+B,CAA/B,EAAkC,CAAlC,EAAqC,CAArC,EAAwC,CAAxC,EAA2C,CAA3C,EAA8C,CAA9C,CAAjB;;AAEO,SAASD,eAAT,CAAyBE,CAAzB,EAA4B;AACjC,SAAOA,EAAEC,MAAF,KAAa,EAAb,IACLC,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADK,IACoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADpB,IAELE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAFK,IAEoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAFpB,IAGLE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAHK,IAGoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAHpB,IAILE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAJK,IAIoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAJpB,IAKLE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CALK,IAKoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CALpB,IAMLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CANK,IAMqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CANrB,IAOLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAPK,IAOqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAPrB,IAQLE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CARK,IAQqBE,OAAOC,QAAP,CAAgBH,EAAE,EAAF,CAAhB,CAR5B;AASD;;IAEoBI,O;;;AACnB,qBAAqB;AAAA,sCAANC,IAAM;AAANA,UAAM;AAAA;;AAAA;;AAAA;;AAEnB,QAAIC,MAAMC,OAAN,CAAcF,KAAK,CAAL,CAAd,KAA0BG,UAAUP,MAAV,KAAqB,CAAnD,EAAsD;AACpD,YAAKQ,IAAL,CAAUJ,KAAK,CAAL,CAAV;AACD,KAFD,MAEO;AACL,YAAKK,QAAL;AACD;AANkB;AAOpB;;;;;;AAMD;kCAME;AAAA,UAJAC,GAIA,uEAJM,CAIN;AAAA,UAJSC,GAIT,uEAJe,CAIf;AAAA,UAJkBC,GAIlB,uEAJwB,CAIxB;AAAA,UAJ2BC,GAI3B,uEAJiC,CAIjC;AAAA,UAHAC,GAGA,uEAHM,CAGN;AAAA,UAHSC,GAGT,uEAHe,CAGf;AAAA,UAHkBC,GAGlB,uEAHwB,CAGxB;AAAA,UAH2BC,GAG3B,uEAHiC,CAGjC;AAAA,UAFAC,GAEA,uEAFM,CAEN;AAAA,UAFSC,GAET,uEAFe,CAEf;AAAA,UAFkBC,GAElB,0EAFwB,CAExB;AAAA,UAF2BC,GAE3B,0EAFiC,CAEjC;AAAA,UADAC,GACA,0EADM,CACN;AAAA,UADSC,GACT,0EADe,CACf;AAAA,UADkBC,GAClB,0EADwB,CACxB;AAAA,UAD2BC,GAC3B,0EADiC,CACjC;;AACA,aAAO,KAAKC,GAAL,CACLhB,GADK,EACAI,GADA,EACKI,GADL,EACUI,GADV,EAELX,GAFK,EAEAI,GAFA,EAEKI,GAFL,EAEUI,GAFV,EAGLX,GAHK,EAGAI,GAHA,EAGKI,GAHL,EAGUI,GAHV,EAILX,GAJK,EAIAI,GAJA,EAIKI,GAJL,EAIUI,GAJV,CAAP;AAMD;;;qCAOC;AAAA,UAJAf,GAIA,uEAJM,CAIN;AAAA,UAJSI,GAIT,uEAJe,CAIf;AAAA,UAJkBI,GAIlB,uEAJwB,CAIxB;AAAA,UAJ2BI,GAI3B,uEAJiC,CAIjC;AAAA,UAHAX,GAGA,uEAHM,CAGN;AAAA,UAHSI,GAGT,uEAHe,CAGf;AAAA,UAHkBI,GAGlB,uEAHwB,CAGxB;AAAA,UAH2BI,GAG3B,uEAHiC,CAGjC;AAAA,UAFAX,GAEA,uEAFM,CAEN;AAAA,UAFSI,GAET,uEAFe,CAEf;AAAA,UAFkBI,GAElB,0EAFwB,CAExB;AAAA,UAF2BI,GAE3B,0EAFiC,CAEjC;AAAA,UADAX,GACA,0EADM,CACN;AAAA,UADSI,GACT,0EADe,CACf;AAAA,UADkBI,GAClB,0EADwB,CACxB;AAAA,UAD2BI,GAC3B,0EADiC,CACjC;;AACA,aAAO,KAAKC,GAAL,CACLhB,GADK,EACAI,GADA,EACKI,GADL,EACUI,GADV,EAELX,GAFK,EAEAI,GAFA,EAEKI,GAFL,EAEUI,GAFV,EAGLX,GAHK,EAGAI,GAHA,EAGKI,GAHL,EAGUI,GAHV,EAILX,GAJK,EAIAI,GAJA,EAIKI,GAJL,EAIUI,GAJV,CAAP;AAMD;;;wBAEGf,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAKX,G,EAAKI,G,EAAKI,G,EAAKI,G,EAAK;AAClF,WAAK,CAAL,IAAUf,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUX,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,CAAL,IAAUX,GAAV;AACA,WAAK,CAAL,IAAUI,GAAV;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWX,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAK,EAAL,IAAWI,GAAX;AACA,WAAKE,KAAL;AACA,aAAO,IAAP;AACD;AACD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;;AAiCA;;AAEA;;kCAEc;AACZ,aAAO,2BAAiB,IAAjB,CAAP;AACD;;AAED;;;;+BAEW;AACT,WAAK,IAAIC,IAAI,CAAb,EAAgBA,IAAI9B,SAASE,MAA7B,EAAqC,EAAE4B,CAAvC,EAA0C;AACxC,aAAKA,CAAL,IAAU9B,SAAS8B,CAAT,CAAV;AACD;AACD,WAAKD,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;;;;mCACeE,C,EAAG;AAChB,8BAAc,IAAd,EAAoBA,CAApB;AACA,WAAKF,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;;;kCAC+C;AAAA,UAAtCG,IAAsC,QAAtCA,IAAsC;AAAA,UAAhCC,KAAgC,QAAhCA,KAAgC;AAAA,UAAzBC,MAAyB,QAAzBA,MAAyB;AAAA,UAAjBC,GAAiB,QAAjBA,GAAiB;AAAA,UAAZC,IAAY,QAAZA,IAAY;AAAA,UAANC,GAAM,QAANA,GAAM;;AAC7C,6BAAa,IAAb,EAAmBL,IAAnB,EAAyBC,KAAzB,EAAgCC,MAAhC,EAAwCC,GAAxC,EAA6CC,IAA7C,EAAmDC,GAAnD;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;;;;6BAKQ;AAAA,sFAAJ,EAAI;AAAA,UAHNS,GAGM,SAHNA,GAGM;AAAA,+BAFNC,MAEM;AAAA,UAFNA,MAEM,gCAFG,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,CAEH;AAAA,2BADNC,EACM;AAAA,UADNA,EACM,4BADD,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,CACC;;AACN,4BAAY,IAAZ,EAAkBF,GAAlB,EAAuBC,MAAvB,EAA+BC,EAA/B;AACA,WAAKX,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;;;iCACyD;AAAA,UAAlDG,IAAkD,SAAlDA,IAAkD;AAAA,UAA5CC,KAA4C,SAA5CA,KAA4C;AAAA,UAArCC,MAAqC,SAArCA,MAAqC;AAAA,UAA7BC,GAA6B,SAA7BA,GAA6B;AAAA,6BAAxBC,IAAwB;AAAA,UAAxBA,IAAwB,8BAAjB,GAAiB;AAAA,4BAAZC,GAAY;AAAA,UAAZA,GAAY,6BAAN,GAAM;;AACvD,2BAAW,IAAX,EAAiBL,IAAjB,EAAuBC,KAAvB,EAA8BC,MAA9B,EAAsCC,GAAtC,EAA2CC,IAA3C,EAAiDC,GAAjD;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;;;;kCAMQ;AAAA,sFAAJ,EAAI;AAAA,4BAJNY,GAIM;AAAA,UAJNA,GAIM,6BAJA,KAAKC,KAAKC,EAAV,GAAe,GAIf;AAAA,+BAHNC,MAGM;AAAA,UAHNA,MAGM,gCAHG,CAGH;AAAA,6BAFNR,IAEM;AAAA,UAFNA,IAEM,8BAFC,GAED;AAAA,4BADNC,GACM;AAAA,UADNA,GACM,6BADA,GACA;;AACN,UAAII,MAAMC,KAAKC,EAAL,GAAU,CAApB,EAAuB;AACrB,cAAME,MAAM,SAAN,CAAN;AACD;AACD,iCAAiB,IAAjB,EAAuBJ,GAAvB,EAA4BG,MAA5B,EAAoCR,IAApC,EAA0CC,GAA1C;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;gCAEY;AACV,+BAAe,IAAf,EAAqB,IAArB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;;6BAEQ;AACP,4BAAY,IAAZ,EAAkB,IAAlB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;iCAEaiB,C,EAAG;AACd,8BAAc,IAAd,EAAoBA,CAApB,EAAuB,IAAvB;AACA,WAAKjB,KAAL;AACA,aAAO,IAAP;AACD;;;kCAEaiB,C,EAAG;AACf,8BAAc,IAAd,EAAoB,IAApB,EAA0BA,CAA1B;AACA,WAAKjB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACf,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACf,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQkB,O,EAAS;AACf,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,OAAzB;AACA,WAAKlB,KAAL;AACA,aAAO,IAAP;AACD;;;qCAEuB;AAAA;AAAA,UAAbmB,EAAa;AAAA,UAATC,EAAS;AAAA,UAALC,EAAK;;AACtB,aAAO,KAAKC,OAAL,CAAaH,EAAb,EAAiBI,OAAjB,CAAyBH,EAAzB,EAA6BI,OAA7B,CAAqCH,EAArC,CAAP;AACD;;;+BAEUH,O,EAASO,I,EAAM;AACxB,6BAAY,IAAZ,EAAkB,IAAlB,EAAwBP,OAAxB,EAAiCO,IAAjC;AACA,WAAKzB,KAAL;AACA,aAAO,IAAP;AACD;;;0BAEK0B,G,EAAK;AACT,2BAAW,IAAX,EAAiB,IAAjB,EAAuBA,GAAvB;AACA,WAAK1B,KAAL;AACA,aAAO,IAAP;AACD;;;8BAES0B,G,EAAK;AACb,+BAAe,IAAf,EAAqB,IAArB,EAA2BA,GAA3B;AACA,WAAK1B,KAAL;AACA,aAAO,IAAP;AACD;;;qCAEgB2B,M,EAAQC,G,EAAK;AAC5BA,YAAMA,OAAO,sBAAb;AACA,kCAAmBA,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA,4BAAO,6BAAgBC,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;;qCAEgBD,M,EAA6B;AAAA,UAArBC,GAAqB,uEAAf,sBAAe;;AAC5CA,YAAMA,OAAO,sBAAb;AACA,kCAAmBA,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA,4BAAO,8BAAgBC,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;;qCAEgBD,M,EAA6B;AAAA,UAArBC,GAAqB,uEAAf,sBAAe;;AAC5CA,YAAMA,OAAO,sBAAb;AACA,kCAAmBA,GAAnB,EAAwBD,MAAxB,EAAgC,IAAhC;AACA,4BAAO,8BAAgBC,GAAhB,CAAP;AACA,aAAOA,GAAP;AACD;;AAED;AACA;;;;oCACgBD,M,EAAQC,G,EAAK;AAC3B,cAAQD,OAAOtD,MAAf;AACA,aAAK,CAAL;AAAQ,iBAAO,KAAKwD,gBAAL,CAAsBF,MAAtB,EAA8BC,GAA9B,CAAP;AACR,aAAK,CAAL;AAAQ,iBAAO,KAAKE,gBAAL,CAAsBH,MAAtB,EAA8BC,GAA9B,CAAP;AACR,aAAK,CAAL;AAAQ,iBAAO,KAAKG,gBAAL,CAAsBJ,MAAtB,EAA8BC,GAA9B,CAAP;AACR;AAAS,gBAAM,IAAIZ,KAAJ,CAAU,gBAAV,CAAN;AAJT;AAMD;;;wBA5Rc;AACb,aAAO,EAAP;AACD;;;wBA+Dc;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BgB,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;wBACzC;AAAE,aAAO,KAAK,EAAL,CAAP;AAAkB,K;sBAC3BA,K,EAAO;AAAE,aAAO,KAAK,EAAL,IAAW,yBAAYA,KAAZ,CAAlB;AAAuC;;;;;;kBA1GrCxD,O","file":"matrix4.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\nimport Vector2, {validateVector2} from './vector2';\nimport Vector3, {validateVector3} from './vector3';\nimport Vector4, {validateVector4} from './vector4';\nimport assert from 'assert';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport mat4_determinant from 'gl-mat4/determinant';\nimport mat4_fromQuat from 'gl-mat4/fromQuat';\nimport mat4_frustum from 'gl-mat4/frustum';\nimport mat4_lookAt from 'gl-mat4/lookAt';\nimport mat4_ortho from 'gl-mat4/ortho';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_transpose from 'gl-mat4/transpose';\nimport mat4_invert from 'gl-mat4/invert';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateY from 'gl-mat4/rotateY';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport mat4_rotate from 'gl-mat4/rotateZ';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport vec2_transformMat4 from 'gl-vec2/transformMat4';\nimport vec3_transformMat4 from 'gl-vec3/transformMat4';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\n\nconst IDENTITY = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n\nexport function validateMatrix4(m) {\n  return m.length === 16 &&\n    Number.isFinite(m[0]) && Number.isFinite(m[1]) &&\n    Number.isFinite(m[2]) && Number.isFinite(m[3]) &&\n    Number.isFinite(m[4]) && Number.isFinite(m[5]) &&\n    Number.isFinite(m[6]) && Number.isFinite(m[7]) &&\n    Number.isFinite(m[8]) && Number.isFinite(m[9]) &&\n    Number.isFinite(m[10]) && Number.isFinite(m[11]) &&\n    Number.isFinite(m[12]) && Number.isFinite(m[13]) &&\n    Number.isFinite(m[14]) && Number.isFinite(m[15]);\n}\n\nexport default class Matrix4 extends MathArray {\n  constructor(...args) {\n    super();\n    if (Array.isArray(args[0]) && arguments.length === 1) {\n      this.copy(args[0]);\n    } else {\n      this.identity();\n    }\n  }\n\n  get ELEMENTS() {\n    return 16;\n  }\n\n  /* eslint-disable max-params */\n  setRowMajor(\n    m00 = 1, m10 = 0, m20 = 0, m30 = 0,\n    m01 = 0, m11 = 1, m21 = 0, m31 = 0,\n    m02 = 0, m12 = 0, m22 = 1, m32 = 0,\n    m03 = 0, m13 = 0, m23 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  setColumnMajor(\n    m00 = 1, m01 = 0, m02 = 0, m03 = 0,\n    m10 = 0, m11 = 1, m12 = 0, m13 = 0,\n    m20 = 0, m21 = 0, m22 = 1, m23 = 0,\n    m30 = 0, m31 = 0, m32 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  set(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n    this[0] = m00;\n    this[1] = m01;\n    this[2] = m02;\n    this[3] = m03;\n    this[4] = m10;\n    this[5] = m11;\n    this[6] = m12;\n    this[7] = m13;\n    this[8] = m20;\n    this[9] = m21;\n    this[10] = m22;\n    this[11] = m23;\n    this[12] = m30;\n    this[13] = m31;\n    this[14] = m32;\n    this[15] = m33;\n    this.check();\n    return this;\n  }\n  /* eslint-enable max-params */\n\n  // toString() {\n  //   if (config.printRowMajor) {\n  //     mat4_str(this);\n  //   } else {\n  //     mat4_str(this);\n  //   }\n  // }\n\n  // Row major setters and getters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get m00()      { return this[0]; }\n  set m00(value) { return this[0] = checkNumber(value); }\n  get m01()      { return this[4]; }\n  set m01(value) { return this[4] = checkNumber(value); }\n  get m02()      { return this[8]; }\n  set m02(value) { return this[8] = checkNumber(value); }\n  get m03()      { return this[12]; }\n  set m03(value) { return this[12] = checkNumber(value); }\n  get m10()      { return this[1]; }\n  set m10(value) { return this[1] = checkNumber(value); }\n  get m11()      { return this[5]; }\n  set m11(value) { return this[5] = checkNumber(value); }\n  get m12()      { return this[9]; }\n  set m12(value) { return this[9] = checkNumber(value); }\n  get m13()      { return this[13]; }\n  set m13(value) { return this[13] = checkNumber(value); }\n  get m20()      { return this[2]; }\n  set m20(value) { return this[2] = checkNumber(value); }\n  get m21()      { return this[6]; }\n  set m21(value) { return this[6] = checkNumber(value); }\n  get m22()      { return this[10]; }\n  set m22(value) { return this[10] = checkNumber(value); }\n  get m23()      { return this[14]; }\n  set m23(value) { return this[14] = checkNumber(value); }\n  get m30()      { return this[3]; }\n  set m30(value) { return this[3] = checkNumber(value); }\n  get m31()      { return this[7]; }\n  set m31(value) { return this[7] = checkNumber(value); }\n  get m32()      { return this[11]; }\n  set m32(value) { return this[11] = checkNumber(value); }\n  get m33()      { return this[15]; }\n  set m33(value) { return this[15] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Accessors\n\n  determinant() {\n    return mat4_determinant(this);\n  }\n\n  // Constructors\n\n  identity() {\n    for (let i = 0; i < IDENTITY.length; ++i) {\n      this[i] = IDENTITY[i];\n    }\n    this.check();\n    return this;\n  }\n\n  // Calculates a 4x4 matrix from the given quaternion\n  // q quat  Quaternion to create matrix from\n  fromQuaternion(q) {\n    mat4_fromQuat(this, q);\n    this.check();\n    return this;\n  }\n\n  // Generates a frustum matrix with the given bounds\n  // left  Number  Left bound of the frustum\n  // right Number  Right bound of the frustum\n  // bottom  Number  Bottom bound of the frustum\n  // top Number  Top bound of the frustum\n  // near  Number  Near bound of the frustum\n  // far Number  Far bound of the frustum\n  frustum({left, right, bottom, top, near, far}) {\n    mat4_frustum(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a look-at matrix with the given eye position, focal point,\n  // and up axis\n  // eye vec3  Position of the viewer\n  // center  vec3  Point the viewer is looking at\n  // up  vec3  vec3 pointing up\n  lookAt({\n    eye,\n    center = [0, 0, 0],\n    up = [0, 1, 0]\n  } = {}) {\n    mat4_lookAt(this, eye, center, up);\n    this.check();\n    return this;\n  }\n\n  // Generates a orthogonal projection matrix with the given bounds\n  // left  number  Left bound of the frustum\n  // right number  Right bound of the frustum\n  // bottom  number  Bottom bound of the frustum\n  // top number  Top bound of the frustum\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  ortho({left, right, bottom, top, near = 0.1, far = 500}) {\n    mat4_ortho(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a perspective projection matrix with the given bounds\n  // fovy  number  Vertical field of view in radians\n  // aspect  number  Aspect ratio. typically viewport width/height\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  perspective({\n    fov = 45 * Math.PI / 180,\n    aspect = 1,\n    near = 0.1,\n    far = 500\n  } = {}) {\n    if (fov > Math.PI * 2) {\n      throw Error('radians');\n    }\n    mat4_perspective(this, fov, aspect, near, far);\n    this.check();\n    return this;\n  }\n\n  // Modifiers\n\n  transpose() {\n    mat4_transpose(this, this);\n    this.check();\n    return this;\n  }\n\n  invert() {\n    mat4_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Operations\n\n  multiplyLeft(a) {\n    mat4_multiply(this, a, this);\n    this.check();\n    return this;\n  }\n\n  multiplyRight(a) {\n    mat4_multiply(this, this, a);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the X axis\n  rotateX(radians) {\n    mat4_rotateX(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Y axis.\n  rotateY(radians) {\n    mat4_rotateY(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Z axis.\n  rotateZ(radians) {\n    mat4_rotateZ(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  rotateXYZ([rx, ry, rz]) {\n    return this.rotateX(rx).rotateY(ry).rotateZ(rz);\n  }\n\n  rotateAxis(radians, axis) {\n    mat4_rotate(this, this, radians, axis);\n    this.check();\n    return this;\n  }\n\n  scale(vec) {\n    mat4_scale(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  translate(vec) {\n    mat4_translate(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  transformVector2(vector, out) {\n    out = out || new Vector2();\n    vec2_transformMat4(out, vector, this);\n    assert(validateVector2(out));\n    return out;\n  }\n\n  transformVector3(vector, out = new Vector3()) {\n    out = out || new Vector3();\n    vec3_transformMat4(out, vector, this);\n    assert(validateVector3(out));\n    return out;\n  }\n\n  transformVector4(vector, out = new Vector4()) {\n    out = out || new Vector4();\n    vec4_transformMat4(out, vector, this);\n    assert(validateVector4(out));\n    return out;\n  }\n\n  // Transforms any 2, 3 or 4 element vector\n  // returns a newly minted Vector2, Vector3 or Vector4\n  transformVector(vector, out) {\n    switch (vector.length) {\n    case 2: return this.transformVector2(vector, out);\n    case 3: return this.transformVector3(vector, out);\n    case 4: return this.transformVector4(vector, out);\n    default: throw new Error('Illegal vector');\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/matrix4.js"],"names":["validateMatrix4","IDENTITY","m","length","Number","isFinite","tempVector4","Matrix4","args","Array","isArray","arguments","copy","identity","m00","m10","m20","m30","m01","m11","m21","m31","m02","m12","m22","m32","m03","m13","m23","m33","set","check","i","q","left","right","bottom","top","near","far","eye","center","up","fov","Math","PI","aspect","Error","a","radians","rx","ry","rz","rotateX","rotateY","rotateZ","axis","vec","vector","out","transformVector2","transformVector3","transformVector4","value"],"mappings":"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","file":"matrix4.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\nimport Vector2, {validateVector2} from './vector2';\nimport Vector3, {validateVector3} from './vector3';\nimport Vector4, {validateVector4} from './vector4';\nimport assert from 'assert';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport mat4_determinant from 'gl-mat4/determinant';\nimport mat4_fromQuat from 'gl-mat4/fromQuat';\nimport mat4_frustum from 'gl-mat4/frustum';\nimport mat4_lookAt from 'gl-mat4/lookAt';\nimport mat4_ortho from 'gl-mat4/ortho';\nimport mat4_perspective from 'gl-mat4/perspective';\nimport mat4_transpose from 'gl-mat4/transpose';\nimport mat4_invert from 'gl-mat4/invert';\nimport mat4_multiply from 'gl-mat4/multiply';\nimport mat4_rotateX from 'gl-mat4/rotateX';\nimport mat4_rotateY from 'gl-mat4/rotateY';\nimport mat4_rotateZ from 'gl-mat4/rotateZ';\nimport mat4_rotate from 'gl-mat4/rotateZ';\nimport mat4_scale from 'gl-mat4/scale';\nimport mat4_translate from 'gl-mat4/translate';\nimport vec2_transformMat4 from 'gl-vec2/transformMat4';\nimport vec3_transformMat4 from 'gl-vec3/transformMat4';\nimport vec4_transformMat4 from 'gl-vec4/transformMat4';\n\nconst IDENTITY = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n\nexport function validateMatrix4(m) {\n  return m.length === 16 &&\n    Number.isFinite(m[0]) && Number.isFinite(m[1]) &&\n    Number.isFinite(m[2]) && Number.isFinite(m[3]) &&\n    Number.isFinite(m[4]) && Number.isFinite(m[5]) &&\n    Number.isFinite(m[6]) && Number.isFinite(m[7]) &&\n    Number.isFinite(m[8]) && Number.isFinite(m[9]) &&\n    Number.isFinite(m[10]) && Number.isFinite(m[11]) &&\n    Number.isFinite(m[12]) && Number.isFinite(m[13]) &&\n    Number.isFinite(m[14]) && Number.isFinite(m[15]);\n}\n\nconst tempVector4 = [0, 0, 0, 0];\n\nexport default class Matrix4 extends MathArray {\n  constructor(...args) {\n    super();\n    if (Array.isArray(args[0]) && arguments.length === 1) {\n      this.copy(args[0]);\n    } else {\n      this.identity();\n    }\n  }\n\n  get ELEMENTS() {\n    return 16;\n  }\n\n  /* eslint-disable max-params */\n  setRowMajor(\n    m00 = 1, m10 = 0, m20 = 0, m30 = 0,\n    m01 = 0, m11 = 1, m21 = 0, m31 = 0,\n    m02 = 0, m12 = 0, m22 = 1, m32 = 0,\n    m03 = 0, m13 = 0, m23 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  setColumnMajor(\n    m00 = 1, m01 = 0, m02 = 0, m03 = 0,\n    m10 = 0, m11 = 1, m12 = 0, m13 = 0,\n    m20 = 0, m21 = 0, m22 = 1, m23 = 0,\n    m30 = 0, m31 = 0, m32 = 0, m33 = 1\n  ) {\n    return this.set(\n      m00, m01, m02, m03,\n      m10, m11, m12, m13,\n      m20, m21, m22, m23,\n      m30, m31, m32, m33\n    );\n  }\n\n  set(m00, m01, m02, m03, m10, m11, m12, m13, m20, m21, m22, m23, m30, m31, m32, m33) {\n    this[0] = m00;\n    this[1] = m01;\n    this[2] = m02;\n    this[3] = m03;\n    this[4] = m10;\n    this[5] = m11;\n    this[6] = m12;\n    this[7] = m13;\n    this[8] = m20;\n    this[9] = m21;\n    this[10] = m22;\n    this[11] = m23;\n    this[12] = m30;\n    this[13] = m31;\n    this[14] = m32;\n    this[15] = m33;\n    this.check();\n    return this;\n  }\n  /* eslint-enable max-params */\n\n  // toString() {\n  //   if (config.printRowMajor) {\n  //     mat4_str(this);\n  //   } else {\n  //     mat4_str(this);\n  //   }\n  // }\n\n  // Row major setters and getters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get m00()      { return this[0]; }\n  set m00(value) { return this[0] = checkNumber(value); }\n  get m01()      { return this[4]; }\n  set m01(value) { return this[4] = checkNumber(value); }\n  get m02()      { return this[8]; }\n  set m02(value) { return this[8] = checkNumber(value); }\n  get m03()      { return this[12]; }\n  set m03(value) { return this[12] = checkNumber(value); }\n  get m10()      { return this[1]; }\n  set m10(value) { return this[1] = checkNumber(value); }\n  get m11()      { return this[5]; }\n  set m11(value) { return this[5] = checkNumber(value); }\n  get m12()      { return this[9]; }\n  set m12(value) { return this[9] = checkNumber(value); }\n  get m13()      { return this[13]; }\n  set m13(value) { return this[13] = checkNumber(value); }\n  get m20()      { return this[2]; }\n  set m20(value) { return this[2] = checkNumber(value); }\n  get m21()      { return this[6]; }\n  set m21(value) { return this[6] = checkNumber(value); }\n  get m22()      { return this[10]; }\n  set m22(value) { return this[10] = checkNumber(value); }\n  get m23()      { return this[14]; }\n  set m23(value) { return this[14] = checkNumber(value); }\n  get m30()      { return this[3]; }\n  set m30(value) { return this[3] = checkNumber(value); }\n  get m31()      { return this[7]; }\n  set m31(value) { return this[7] = checkNumber(value); }\n  get m32()      { return this[11]; }\n  set m32(value) { return this[11] = checkNumber(value); }\n  get m33()      { return this[15]; }\n  set m33(value) { return this[15] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Accessors\n\n  determinant() {\n    return mat4_determinant(this);\n  }\n\n  // Constructors\n\n  identity() {\n    for (let i = 0; i < IDENTITY.length; ++i) {\n      this[i] = IDENTITY[i];\n    }\n    this.check();\n    return this;\n  }\n\n  // Calculates a 4x4 matrix from the given quaternion\n  // q quat  Quaternion to create matrix from\n  fromQuaternion(q) {\n    mat4_fromQuat(this, q);\n    this.check();\n    return this;\n  }\n\n  // Generates a frustum matrix with the given bounds\n  // left  Number  Left bound of the frustum\n  // right Number  Right bound of the frustum\n  // bottom  Number  Bottom bound of the frustum\n  // top Number  Top bound of the frustum\n  // near  Number  Near bound of the frustum\n  // far Number  Far bound of the frustum\n  frustum({left, right, bottom, top, near, far}) {\n    mat4_frustum(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a look-at matrix with the given eye position, focal point,\n  // and up axis\n  // eye vec3  Position of the viewer\n  // center  vec3  Point the viewer is looking at\n  // up  vec3  vec3 pointing up\n  lookAt({\n    eye,\n    center = [0, 0, 0],\n    up = [0, 1, 0]\n  } = {}) {\n    mat4_lookAt(this, eye, center, up);\n    this.check();\n    return this;\n  }\n\n  // Generates a orthogonal projection matrix with the given bounds\n  // left  number  Left bound of the frustum\n  // right number  Right bound of the frustum\n  // bottom  number  Bottom bound of the frustum\n  // top number  Top bound of the frustum\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  ortho({left, right, bottom, top, near = 0.1, far = 500}) {\n    mat4_ortho(this, left, right, bottom, top, near, far);\n    this.check();\n    return this;\n  }\n\n  // Generates a perspective projection matrix with the given bounds\n  // fovy  number  Vertical field of view in radians\n  // aspect  number  Aspect ratio. typically viewport width/height\n  // near  number  Near bound of the frustum\n  // far number  Far bound of the frustum\n  perspective({\n    fov = 45 * Math.PI / 180,\n    aspect = 1,\n    near = 0.1,\n    far = 500\n  } = {}) {\n    if (fov > Math.PI * 2) {\n      throw Error('radians');\n    }\n    mat4_perspective(this, fov, aspect, near, far);\n    this.check();\n    return this;\n  }\n\n  // Modifiers\n\n  transpose() {\n    mat4_transpose(this, this);\n    this.check();\n    return this;\n  }\n\n  invert() {\n    mat4_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Operations\n\n  multiplyLeft(a) {\n    mat4_multiply(this, a, this);\n    this.check();\n    return this;\n  }\n\n  multiplyRight(a) {\n    mat4_multiply(this, this, a);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the X axis\n  rotateX(radians) {\n    mat4_rotateX(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Y axis.\n  rotateY(radians) {\n    mat4_rotateY(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  // Rotates a matrix by the given angle around the Z axis.\n  rotateZ(radians) {\n    mat4_rotateZ(this, this, radians);\n    this.check();\n    return this;\n  }\n\n  rotateXYZ([rx, ry, rz]) {\n    return this.rotateX(rx).rotateY(ry).rotateZ(rz);\n  }\n\n  rotateAxis(radians, axis) {\n    mat4_rotate(this, this, radians, axis);\n    this.check();\n    return this;\n  }\n\n  scale(vec) {\n    mat4_scale(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  translate(vec) {\n    mat4_translate(this, this, vec);\n    this.check();\n    return this;\n  }\n\n  transformVector2(vector, out) {\n    out = out || new Vector2();\n    vec2_transformMat4(out, vector, this);\n    assert(validateVector2(out));\n    return out;\n  }\n\n  transformVector3(vector, out = new Vector3()) {\n    out = out || new Vector3();\n    vec3_transformMat4(out, vector, this);\n    assert(validateVector3(out));\n    return out;\n  }\n\n  transformVector4(vector, out = new Vector4()) {\n    out = out || new Vector4();\n    vec4_transformMat4(out, vector, this);\n    assert(validateVector4(out));\n    return out;\n  }\n\n  // Transforms any 2, 3 or 4 element vector\n  // returns a newly minted Vector2, Vector3 or Vector4\n  transformVector(vector, out) {\n    switch (vector.length) {\n    case 2: return this.transformVector2(vector, out);\n    case 3: return this.transformVector3(vector, out);\n    case 4: return this.transformVector4(vector, out);\n    default: throw new Error('Illegal vector');\n    }\n  }\n\n  transformDirection(vector, out) {\n    switch (vector.length) {\n    case 2:\n      vec4_transformMat4(tempVector4, [vector[0], vector[1], 0, 0], this);\n      out = out || new Vector2();\n      [out[0], out[1]] = tempVector4;\n      break;\n    case 3:\n      vec4_transformMat4(tempVector4, [vector[0], vector[1], vector[2], 0], this);\n      out = out || new Vector3();\n      [out[0], out[1], out[2]] = tempVector4;\n      break;\n    case 4:\n      assert(vector[3] === 0);\n      out = out || new Vector4();\n      vec4_transformMat4(out, vector, this);\n      break;\n    default: throw new Error('Illegal vector');\n    }\n    return out;\n  }\n\n  transformPoint(vector, out) {\n    switch (vector.length) {\n    case 2:\n      out = out || new Vector2();\n      vec4_transformMat4(out, [vector[0], vector[1], 0, 1], this);\n      out.length = 2;\n      assert(validateVector2(out));\n      break;\n    case 3:\n      out = out || new Vector3();\n      vec4_transformMat4(out, [vector[0], vector[1], vector[2], 1], this);\n      out.length = 3;\n      assert(validateVector3(out));\n      break;\n    case 4:\n      assert(vector[3] !== 0);\n      out = out || new Vector4();\n      vec4_transformMat4(out, vector, this);\n      assert(validateVector4(out));\n      break;\n    default:\n      throw new Error('Illegal vector');\n    }\n    return out;\n  }\n}\n"]} |
@@ -85,5 +85,24 @@ 'use strict'; | ||
value: function toString() { | ||
return '[rho:' + this.radius + ',theta:' + this.theta + ',phi:' + this.phi + ']'; | ||
return this.formatString(_common.config); | ||
} | ||
}, { | ||
key: 'formatString', | ||
value: function formatString(_ref2) { | ||
var printTypes = _ref2.printTypes, | ||
printDegrees = _ref2.printDegrees; | ||
var f = _common.formatValue; | ||
return (printTypes ? 'Spherical' : '') + '[rho:' + f(this.radius) + ',theta:' + f(this.theta) + ',phi:' + f(this.phi) + ']'; | ||
} | ||
}, { | ||
key: 'equals', | ||
value: function equals(other) { | ||
return (0, _common.equals)(this.radius, other.radius) && (0, _common.equals)(this.theta, other.theta) && (0, _common.equals)(this.phi, other.phi); | ||
} | ||
}, { | ||
key: 'exactEquals', | ||
value: function exactEquals(other) { | ||
return this.radius === other.radius && this.theta === other.theta && this.phi === other.phi; | ||
} | ||
/* eslint-disable brace-style */ | ||
@@ -118,7 +137,7 @@ // Cartographic (bearing 0 north, pitch 0 look from above) | ||
key: 'fromLngLatZ', | ||
value: function fromLngLatZ(_ref2) { | ||
var _ref3 = _slicedToArray(_ref2, 3), | ||
lng = _ref3[0], | ||
lat = _ref3[1], | ||
z = _ref3[2]; | ||
value: function fromLngLatZ(_ref3) { | ||
var _ref4 = _slicedToArray(_ref3, 3), | ||
lng = _ref4[0], | ||
lat = _ref4[1], | ||
z = _ref4[2]; | ||
@@ -145,3 +164,3 @@ this.radius = 1 + z / this.radiusScale; | ||
value: function toVector3() { | ||
return new _vector2.default(0, 0, this.radius).rotateX({ radians: -this.theta }).rotateZ({ radians: -this.phi }); | ||
return new _vector2.default(0, 0, this.radius).rotateX({ radians: this.theta }).rotateZ({ radians: this.phi }); | ||
} | ||
@@ -216,2 +235,2 @@ | ||
exports.default = SphericalCoordinates; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/spherical-coordinates.js"],"names":["EPSILON","EARTH_RADIUS_METERS","SphericalCoordinates","phi","theta","radius","bearing","pitch","altitude","radiusScale","arguments","length","Number","isFinite","check","constructor","copy","other","lng","lat","z","v","Math","atan2","acos","rotateX","radians","rotateZ","max","min","PI"],"mappings":"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","file":"spherical-coordinates.js","sourcesContent":["// Adaptation of THREE.js Spherical class, under MIT license\nimport {degrees, radians, clamp} from './common';\nimport Vector3 from './vector3';\n\n/* eslint-disable camelcase */\nimport vec3_length from 'gl-vec3/length';\nimport assert from 'assert';\n\n// TODO - import epsilon\nconst EPSILON = 0.000001;\n\nconst EARTH_RADIUS_METERS = 6.371e6;\n\n// Todo [rho, theta, phi] ?\nexport default class SphericalCoordinates {\n\n  /**\n   * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n   * The poles (phi) are at the positive and negative y axis.\n   * The equator starts at positive z.\n   * @class\n   * @param {Number} phi=0 - rotation around X (latitude)\n   * @param {Number} theta=0 - rotation around Y (longitude)\n   * @param {Number} radius=1 - Distance from center\n   */\n  /* eslint-disable complexity */\n  constructor({\n    phi, theta, radius,\n    bearing, pitch, altitude,\n    radiusScale = EARTH_RADIUS_METERS\n  } = {}) {\n    if (arguments.length === 0) {\n      this.phi = 0;\n      this.theta = 0;\n      this.radius = 1;\n    } else if (Number.isFinite(phi) || Number.isFinite(theta)) {\n      this.phi = phi || 0;         // up / down towards top and bottom pole\n      this.theta = theta || 0;     // around the equator of the sphere\n    } else if (Number.isFinite(bearing) || Number.isFinite(pitch)) {\n      this.bearing = bearing || 0;         // up / down towards top and bottom pole\n      this.pitch = pitch || 0;     // around the equator of the sphere\n    }\n    this.radius = radius || 1;   // radial distance from center\n    this.radiusScale = radiusScale || 1; // Used by lngLatZ\n    this.check();\n  }\n  /* eslint-enable complexity */\n\n  toString() {\n    return `[rho:${this.radius},theta:${this.theta},phi:${this.phi}]`;\n  }\n\n  /* eslint-disable brace-style */\n  // Cartographic (bearing 0 north, pitch 0 look from above)\n  get bearing() { return 180 - degrees(this.phi); }\n  set bearing(v) { this.phi = Math.PI - radians(v); }\n  get pitch() { return degrees(this.theta); }\n  set pitch(v) { this.theta = radians(v); }\n  // get pitch() { return 90 - degrees(this.phi); }\n  // set pitch(v) { this.phi = radians(v) + Math.PI / 2; }\n  // get altitude() { return this.radius - 1; } // relative altitude\n\n  // lnglatZ coordinates\n  get longitude() { return degrees(this.phi); }\n  get latitude() { return degrees(this.theta); }\n  get lng() { return degrees(this.phi); }\n  get lat() { return degrees(this.theta); }\n  get z() { return (this.radius - 1) * this.radiusScale; }\n  /* eslint-enable brace-style */\n\n  set(radius, phi, theta) {\n    this.radius = radius;\n    this.phi = phi;\n    this.theta = theta;\n    return this.check();\n  }\n\n  clone() {\n    return new this.constructor().copy(this);\n  }\n\n  copy(other) {\n    this.radius = other.radius;\n    this.phi = other.phi;\n    this.theta = other.theta;\n    return this.check();\n  }\n\n  fromLngLatZ([lng, lat, z]) {\n    this.radius = 1 + z / this.radiusScale;\n    this.phi = radians(lat);\n    this.theta = radians(lng);\n  }\n\n  fromVector3(v) {\n    this.radius = vec3_length(v);\n    if (this.radius === 0) {\n      this.theta = 0;\n      this.phi = 0;\n    } else {\n      this.theta = Math.atan2(v[0], v[1]); // equator angle around y-up axis\n      this.phi = Math.acos(clamp(v[2] / this.radius, -1, 1)); // polar angle\n    }\n    return this.check();\n  }\n\n  toVector3() {\n    return new Vector3(0, 0, this.radius)\n      .rotateX({radians: -this.theta})\n      .rotateZ({radians: -this.phi});\n  }\n\n  // restrict phi to be betwee EPS and PI-EPS\n  makeSafe() {\n    this.phi = Math.max(EPSILON, Math.min(Math.PI - EPSILON, this.phi));\n  }\n\n  check() {\n    // this.makeSafe();\n    assert(Number.isFinite(this.phi) && Number.isFinite(this.theta) && this.radius > 0);\n    return this;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/spherical-coordinates.js"],"names":["EPSILON","EARTH_RADIUS_METERS","SphericalCoordinates","phi","theta","radius","bearing","pitch","altitude","radiusScale","arguments","length","Number","isFinite","check","formatString","printTypes","printDegrees","f","other","constructor","copy","lng","lat","z","v","Math","atan2","acos","rotateX","radians","rotateZ","max","min","PI"],"mappings":"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","file":"spherical-coordinates.js","sourcesContent":["// Adaptation of THREE.js Spherical class, under MIT license\nimport {formatValue, equals, config} from './common';\nimport {degrees, radians, clamp} from './common';\nimport Vector3 from './vector3';\n\n/* eslint-disable camelcase */\nimport vec3_length from 'gl-vec3/length';\nimport assert from 'assert';\n\n// TODO - import epsilon\nconst EPSILON = 0.000001;\n\nconst EARTH_RADIUS_METERS = 6.371e6;\n\n// Todo [rho, theta, phi] ?\nexport default class SphericalCoordinates {\n\n  /**\n   * Ref: https://en.wikipedia.org/wiki/Spherical_coordinate_system\n   * The poles (phi) are at the positive and negative y axis.\n   * The equator starts at positive z.\n   * @class\n   * @param {Number} phi=0 - rotation around X (latitude)\n   * @param {Number} theta=0 - rotation around Y (longitude)\n   * @param {Number} radius=1 - Distance from center\n   */\n  /* eslint-disable complexity */\n  constructor({\n    phi, theta, radius,\n    bearing, pitch, altitude,\n    radiusScale = EARTH_RADIUS_METERS\n  } = {}) {\n    if (arguments.length === 0) {\n      this.phi = 0;\n      this.theta = 0;\n      this.radius = 1;\n    } else if (Number.isFinite(phi) || Number.isFinite(theta)) {\n      this.phi = phi || 0;         // up / down towards top and bottom pole\n      this.theta = theta || 0;     // around the equator of the sphere\n    } else if (Number.isFinite(bearing) || Number.isFinite(pitch)) {\n      this.bearing = bearing || 0;         // up / down towards top and bottom pole\n      this.pitch = pitch || 0;     // around the equator of the sphere\n    }\n    this.radius = radius || 1;   // radial distance from center\n    this.radiusScale = radiusScale || 1; // Used by lngLatZ\n    this.check();\n  }\n  /* eslint-enable complexity */\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString({printTypes, printDegrees}) {\n    const f = formatValue;\n    return `${printTypes ? 'Spherical' : ''}\\\n[rho:${f(this.radius)},theta:${f(this.theta)},phi:${f(this.phi)}]`;\n  }\n\n  equals(other) {\n    return equals(this.radius, other.radius) &&\n      equals(this.theta, other.theta) &&\n      equals(this.phi, other.phi);\n  }\n\n  exactEquals(other) {\n    return this.radius === other.radius &&\n      this.theta === other.theta &&\n      this.phi === other.phi;\n  }\n\n  /* eslint-disable brace-style */\n  // Cartographic (bearing 0 north, pitch 0 look from above)\n  get bearing() { return 180 - degrees(this.phi); }\n  set bearing(v) { this.phi = Math.PI - radians(v); }\n  get pitch() { return degrees(this.theta); }\n  set pitch(v) { this.theta = radians(v); }\n  // get pitch() { return 90 - degrees(this.phi); }\n  // set pitch(v) { this.phi = radians(v) + Math.PI / 2; }\n  // get altitude() { return this.radius - 1; } // relative altitude\n\n  // lnglatZ coordinates\n  get longitude() { return degrees(this.phi); }\n  get latitude() { return degrees(this.theta); }\n  get lng() { return degrees(this.phi); }\n  get lat() { return degrees(this.theta); }\n  get z() { return (this.radius - 1) * this.radiusScale; }\n  /* eslint-enable brace-style */\n\n  set(radius, phi, theta) {\n    this.radius = radius;\n    this.phi = phi;\n    this.theta = theta;\n    return this.check();\n  }\n\n  clone() {\n    return new this.constructor().copy(this);\n  }\n\n  copy(other) {\n    this.radius = other.radius;\n    this.phi = other.phi;\n    this.theta = other.theta;\n    return this.check();\n  }\n\n  fromLngLatZ([lng, lat, z]) {\n    this.radius = 1 + z / this.radiusScale;\n    this.phi = radians(lat);\n    this.theta = radians(lng);\n  }\n\n  fromVector3(v) {\n    this.radius = vec3_length(v);\n    if (this.radius === 0) {\n      this.theta = 0;\n      this.phi = 0;\n    } else {\n      this.theta = Math.atan2(v[0], v[1]); // equator angle around y-up axis\n      this.phi = Math.acos(clamp(v[2] / this.radius, -1, 1)); // polar angle\n    }\n    return this.check();\n  }\n\n  toVector3() {\n    return new Vector3(0, 0, this.radius)\n      .rotateX({radians: this.theta})\n      .rotateZ({radians: this.phi});\n  }\n\n  // restrict phi to be betwee EPS and PI-EPS\n  makeSafe() {\n    this.phi = Math.max(EPSILON, Math.min(Math.PI - EPSILON, this.phi));\n  }\n\n  check() {\n    // this.makeSafe();\n    assert(Number.isFinite(this.phi) && Number.isFinite(this.theta) && this.radius > 0);\n    return this;\n  }\n}\n"]} |
@@ -143,4 +143,3 @@ 'use strict'; | ||
(0, _set2.default)(this, x, y, z); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -209,4 +208,3 @@ | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -245,4 +243,3 @@ }, { | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -281,41 +278,5 @@ }, { | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'divide', | ||
value: function divide() { | ||
for (var _len4 = arguments.length, vectors = Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { | ||
vectors[_key4] = arguments[_key4]; | ||
} | ||
var _iteratorNormalCompletion4 = true; | ||
var _didIteratorError4 = false; | ||
var _iteratorError4 = undefined; | ||
try { | ||
for (var _iterator4 = vectors[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) { | ||
var vector = _step4.value; | ||
(0, _divide2.default)(this, this, vector); | ||
} | ||
} catch (err) { | ||
_didIteratorError4 = true; | ||
_iteratorError4 = err; | ||
} finally { | ||
try { | ||
if (!_iteratorNormalCompletion4 && _iterator4.return) { | ||
_iterator4.return(); | ||
} | ||
} finally { | ||
if (_didIteratorError4) { | ||
throw _iteratorError4; | ||
} | ||
} | ||
} | ||
this.check(); | ||
return this; | ||
} | ||
}, { | ||
key: 'scale', | ||
@@ -326,20 +287,11 @@ value: function scale(_scale) { | ||
} else { | ||
(0, _dot2.default)(this, this, _scale); | ||
(0, _multiply2.default)(this, this, _scale); | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'scaleAndAdd', | ||
value: function scaleAndAdd(vector, scale) { | ||
(0, _scaleAndAdd2.default)(this, this, vector, scale); | ||
this.check(); | ||
return this; | ||
} | ||
}, { | ||
key: 'negate', | ||
value: function negate() { | ||
(0, _negate2.default)(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -350,4 +302,3 @@ }, { | ||
(0, _inverse2.default)(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -358,4 +309,3 @@ }, { | ||
(0, _normalize2.default)(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -366,4 +316,3 @@ }, { | ||
(0, _cross2.default)(this, this, vector); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -374,4 +323,3 @@ }, { | ||
(0, _lerp2.default)(this, this, vector, coeff); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -386,4 +334,3 @@ }, { | ||
(0, _rotateX2.default)(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -398,4 +345,3 @@ }, { | ||
(0, _rotateY2.default)(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -410,4 +356,3 @@ }, { | ||
(0, _rotateZ2.default)(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -417,11 +362,53 @@ }, { | ||
value: function operation(_operation) { | ||
for (var _len5 = arguments.length, args = Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) { | ||
args[_key5 - 1] = arguments[_key5]; | ||
for (var _len4 = arguments.length, args = Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) { | ||
args[_key4 - 1] = arguments[_key4]; | ||
} | ||
_operation.apply(undefined, [this, this].concat(args)); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
// TBD - do we really need these? | ||
}, { | ||
key: 'divide', | ||
value: function divide() { | ||
for (var _len5 = arguments.length, vectors = Array(_len5), _key5 = 0; _key5 < _len5; _key5++) { | ||
vectors[_key5] = arguments[_key5]; | ||
} | ||
var _iteratorNormalCompletion4 = true; | ||
var _didIteratorError4 = false; | ||
var _iteratorError4 = undefined; | ||
try { | ||
for (var _iterator4 = vectors[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) { | ||
var vector = _step4.value; | ||
(0, _divide2.default)(this, this, vector); | ||
} | ||
} catch (err) { | ||
_didIteratorError4 = true; | ||
_iteratorError4 = err; | ||
} finally { | ||
try { | ||
if (!_iteratorNormalCompletion4 && _iterator4.return) { | ||
_iterator4.return(); | ||
} | ||
} finally { | ||
if (_didIteratorError4) { | ||
throw _iteratorError4; | ||
} | ||
} | ||
} | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'scaleAndAdd', | ||
value: function scaleAndAdd(vector, scale) { | ||
(0, _scaleAndAdd2.default)(this, this, vector, scale); | ||
return this.check(); | ||
} | ||
}, { | ||
key: 'ELEMENTS', | ||
@@ -461,2 +448,2 @@ get: function get() { | ||
exports.default = Vector3; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["validateVector3","ORIGIN","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    this.check();\n    return this;\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_dot(this, this, scale);\n    }\n    this.check();\n    return this;\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    this.check();\n    return this;\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    this.check();\n    return this;\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    this.check();\n    return this;\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    this.check();\n    return this;\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    this.check();\n    return this;\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    this.check();\n    return this;\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    this.check();\n    return this;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["validateVector3","ORIGIN","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["import MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    return this.check();\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    return this.check();\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]} |
@@ -5,3 +5,3 @@ { | ||
"license": "MIT", | ||
"version": "1.0.0-alpha.6", | ||
"version": "1.0.0-alpha.7", | ||
"keywords": [ | ||
@@ -8,0 +8,0 @@ "webgl", |
@@ -6,4 +6,7 @@ /* eslint-disable no-shadow */ | ||
config.debug = true; | ||
config.precision = 4; | ||
config.printTypes = false; | ||
config.printDegrees = false; | ||
config.printRowMajor = true; | ||
config.precision = 4; | ||
export {config}; | ||
@@ -28,6 +31,22 @@ | ||
export function formatValue(value, precision = config.precision || 4) { | ||
function round(value) { | ||
return Math.round(value / config.EPSILON) * config.EPSILON; | ||
} | ||
export function formatValue(value, { | ||
precision = config.precision || 4 | ||
} = {}) { | ||
value = round(value); | ||
return parseFloat(value.toPrecision(precision)); | ||
} | ||
export function formatAngle(value, { | ||
precision = config.precision || 4, | ||
printDegrees = config.printAngles | ||
} = {}) { | ||
value = printDegrees ? degrees(value) : value; | ||
value = round(value); | ||
return `${parseFloat(value.toPrecision(precision))}${printDegrees ? '°' : ''}`; | ||
} | ||
// Returns true if value is either an array or a typed array | ||
@@ -34,0 +53,0 @@ // Note: does not return true for ArrayBuffers and DataViews |
@@ -37,7 +37,11 @@ import {formatValue, equals, config} from './common'; | ||
toString() { | ||
return this.formatString(config); | ||
} | ||
formatString(opts) { | ||
let string = ''; | ||
for (let i = 0; i < this.ELEMENTS; ++i) { | ||
string += (i > 0 ? ', ' : '') + formatValue(this[i]); | ||
string += (i > 0 ? ', ' : '') + formatValue(this[i], opts); | ||
} | ||
return `${this.constructor.name}(${string})`; | ||
return `${opts.printTypes ? this.constructor.name : ''}[${string}]`; | ||
} | ||
@@ -92,2 +96,3 @@ | ||
} | ||
return this; | ||
} | ||
@@ -94,0 +99,0 @@ |
@@ -43,2 +43,4 @@ import MathArray from './math-array'; | ||
const tempVector4 = [0, 0, 0, 0]; | ||
export default class Matrix4 extends MathArray { | ||
@@ -339,2 +341,50 @@ constructor(...args) { | ||
} | ||
transformDirection(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
vec4_transformMat4(tempVector4, [vector[0], vector[1], 0, 0], this); | ||
out = out || new Vector2(); | ||
[out[0], out[1]] = tempVector4; | ||
break; | ||
case 3: | ||
vec4_transformMat4(tempVector4, [vector[0], vector[1], vector[2], 0], this); | ||
out = out || new Vector3(); | ||
[out[0], out[1], out[2]] = tempVector4; | ||
break; | ||
case 4: | ||
assert(vector[3] === 0); | ||
out = out || new Vector4(); | ||
vec4_transformMat4(out, vector, this); | ||
break; | ||
default: throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
transformPoint(vector, out) { | ||
switch (vector.length) { | ||
case 2: | ||
out = out || new Vector2(); | ||
vec4_transformMat4(out, [vector[0], vector[1], 0, 1], this); | ||
out.length = 2; | ||
assert(validateVector2(out)); | ||
break; | ||
case 3: | ||
out = out || new Vector3(); | ||
vec4_transformMat4(out, [vector[0], vector[1], vector[2], 1], this); | ||
out.length = 3; | ||
assert(validateVector3(out)); | ||
break; | ||
case 4: | ||
assert(vector[3] !== 0); | ||
out = out || new Vector4(); | ||
vec4_transformMat4(out, vector, this); | ||
assert(validateVector4(out)); | ||
break; | ||
default: | ||
throw new Error('Illegal vector'); | ||
} | ||
return out; | ||
} | ||
} |
// Adaptation of THREE.js Spherical class, under MIT license | ||
import {formatValue, equals, config} from './common'; | ||
import {degrees, radians, clamp} from './common'; | ||
@@ -50,5 +51,23 @@ import Vector3 from './vector3'; | ||
toString() { | ||
return `[rho:${this.radius},theta:${this.theta},phi:${this.phi}]`; | ||
return this.formatString(config); | ||
} | ||
formatString({printTypes, printDegrees}) { | ||
const f = formatValue; | ||
return `${printTypes ? 'Spherical' : ''}\ | ||
[rho:${f(this.radius)},theta:${f(this.theta)},phi:${f(this.phi)}]`; | ||
} | ||
equals(other) { | ||
return equals(this.radius, other.radius) && | ||
equals(this.theta, other.theta) && | ||
equals(this.phi, other.phi); | ||
} | ||
exactEquals(other) { | ||
return this.radius === other.radius && | ||
this.theta === other.theta && | ||
this.phi === other.phi; | ||
} | ||
/* eslint-disable brace-style */ | ||
@@ -110,4 +129,4 @@ // Cartographic (bearing 0 north, pitch 0 look from above) | ||
return new Vector3(0, 0, this.radius) | ||
.rotateX({radians: -this.theta}) | ||
.rotateZ({radians: -this.phi}); | ||
.rotateX({radians: this.theta}) | ||
.rotateZ({radians: this.phi}); | ||
} | ||
@@ -114,0 +133,0 @@ |
@@ -53,4 +53,3 @@ import MathArray from './math-array'; | ||
vec3_set(this, x, y, z); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -91,4 +90,3 @@ | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -100,4 +98,3 @@ | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -109,14 +106,5 @@ | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
divide(...vectors) { | ||
for (const vector of vectors) { | ||
vec3_divide(this, this, vector); | ||
} | ||
this.check(); | ||
return this; | ||
} | ||
scale(scale) { | ||
@@ -126,18 +114,10 @@ if (Number.isFinite(scale)) { | ||
} else { | ||
vec3_dot(this, this, scale); | ||
vec3_multiply(this, this, scale); | ||
} | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
scaleAndAdd(vector, scale) { | ||
vec3_scaleAndAdd(this, this, vector, scale); | ||
this.check(); | ||
return this; | ||
} | ||
negate() { | ||
vec3_negate(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -147,4 +127,3 @@ | ||
vec3_inverse(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -154,4 +133,3 @@ | ||
vec3_normalize(this, this); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -161,4 +139,3 @@ | ||
vec3_cross(this, this, vector); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -168,4 +145,3 @@ | ||
vec3_lerp(this, this, vector, coeff); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -175,4 +151,3 @@ | ||
vec3_rotateX(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -182,4 +157,3 @@ | ||
vec3_rotateY(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -189,4 +163,3 @@ | ||
vec3_rotateZ(this, this, origin, radians); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
@@ -196,5 +169,17 @@ | ||
operation(this, this, ...args); | ||
this.check(); | ||
return this; | ||
return this.check(); | ||
} | ||
// TBD - do we really need these? | ||
divide(...vectors) { | ||
for (const vector of vectors) { | ||
vec3_divide(this, this, vector); | ||
} | ||
return this.check(); | ||
} | ||
scaleAndAdd(vector, scale) { | ||
vec3_scaleAndAdd(this, this, vector, scale); | ||
return this.check(); | ||
} | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
610137
8563