diff options
Diffstat (limited to 'o3d')
-rw-r--r-- | o3d/documentation/externs/o3d-extra-externs.js | 7 | ||||
-rw-r--r-- | o3d/samples/o3djs/base.js | 13 | ||||
-rw-r--r-- | o3d/samples/o3djs/math.js | 294 | ||||
-rw-r--r-- | o3d/samples/o3djs/plugin_math.js | 89 | ||||
-rw-r--r-- | o3d/samples/o3djs/serialization.js | 2 |
5 files changed, 207 insertions, 198 deletions
diff --git a/o3d/documentation/externs/o3d-extra-externs.js b/o3d/documentation/externs/o3d-extra-externs.js index 712b568..82a62e0 100644 --- a/o3d/documentation/externs/o3d-extra-externs.js +++ b/o3d/documentation/externs/o3d-extra-externs.js @@ -34,6 +34,13 @@ var Vectormath; Vectormath.Aos = Vectormath.Aos || { }; /** + * A stand-in class definition for Float32Array. + * @param {number} size The size. + * @constructor + */ +var Float32Array = function(size) { }; + +/** * A 4x4 Matrix of floats * @type {!Array.<!Array.<number>>} */ diff --git a/o3d/samples/o3djs/base.js b/o3d/samples/o3djs/base.js index 281f5bc..00c5af8 100644 --- a/o3d/samples/o3djs/base.js +++ b/o3d/samples/o3djs/base.js @@ -91,13 +91,16 @@ o3djs.provided_ = []; * Creates object stubs for a namespace. When present in a file, * o3djs.provide also indicates that the file defines the indicated * object. - * @param {string} name name of the object that this file defines. + * @param {string} name Name of the object that this file defines. + * @param {boolean} opt_replace Whether to replace existing namespace. */ -o3djs.provide = function(name) { +o3djs.provide = function(name, opt_replace) { // Ensure that the same namespace isn't provided twice. - if (o3djs.getObjectByName(name) && - !o3djs.implicitNamespaces_[name]) { - throw 'Namespace "' + name + '" already declared.'; + if (!opt_replace) { + if (o3djs.getObjectByName(name) && + !o3djs.implicitNamespaces_[name]) { + throw 'Namespace "' + name + '" already declared.'; + } } var namespace = name; diff --git a/o3d/samples/o3djs/math.js b/o3d/samples/o3djs/math.js index b52b382..ba07048 100644 --- a/o3d/samples/o3djs/math.js +++ b/o3d/samples/o3djs/math.js @@ -110,6 +110,100 @@ if ((typeof o3d != 'undefined') && o3d && o3d.Transform && o3djs.provide("o3djs.flat_math"); + +/** + * A module for math for o3djs.math. + * @namespace + */ +o3djs.math = o3djs.math || {}; + +/** + * Functions which deal with 4-by-4 transformation matrices are kept in their + * own namespsace. + * @namespace + */ +o3djs.math.matrix4 = o3djs.math.matrix4 || {}; + +/** + * Functions that are specifically row major are kept in their own namespace. + * @namespace + */ +o3djs.math.rowMajor = o3djs.math.rowMajor || {}; + +/** + * Functions that are specifically column major are kept in their own namespace. + * @namespace + */ +o3djs.math.columnMajor = o3djs.math.columnMajor || {}; + +/** + * Functions that do error checking are stored in their own namespace. + * @namespace + */ +o3djs.math.errorCheck = o3djs.math.errorCheck || {}; + +/** + * Functions that do no error checking and have a separate version that does in + * o3djs.math.errorCheck are stored in their own namespace. + * @namespace + */ +o3djs.math.errorCheckFree = o3djs.math.errorCheckFree || {}; + +/** + * An Array of 2 floats + * @type {(!Array.<number>|!o3d.Float2)} + */ +o3djs.math.Vector2 = goog.typedef; + +/** + * An Array of 3 floats + * @type {(!Array.<number>|!o3d.Float3)} + */ +o3djs.math.Vector3 = goog.typedef; + +/** + * An Array of 4 floats + * @type {(!Array.<number>|!o3d.Float4)} + */ +o3djs.math.Vector4 = goog.typedef; + +/** + * An Array of floats. + * @type {!Array.<number>} + */ +o3djs.math.Vector = goog.typedef; + +/** + * A 1x1 Matrix of floats + * @type {!Array.<!Array.<number>>} + */ +o3djs.math.Matrix1 = goog.typedef; + +/** + * A 2x2 Matrix of floats + * @type {!Array.<!Array.<number>>} + */ +o3djs.math.Matrix2 = goog.typedef; + +/** + * A 3x3 Matrix of floats + * @type {!Array.<!Array.<number>>} + */ +o3djs.math.Matrix3 = goog.typedef; + +/** + * A 4x4 Matrix of floats + * @type {(!Array.<!Array.<number>>|!o3d.Matrix4)} + */ +o3djs.math.Matrix4 = goog.typedef; + +/** + * A arbitrary size Matrix of floats + * @type {(!Array.<!Array.<number>>|!o3d.Matrix4)} + */ +o3djs.math.Matrix = goog.typedef; + + /** * A module for math functions where a matrix is represented as a flat * (1-dimensional) array. @@ -165,44 +259,44 @@ o3djs.flat_math.errorCheckFree = o3djs.flat_math.errorCheckFree || {}; /** * An Float32Array of 2 floats - * @type {(!Float32Array.<number>|!o3d.Float2)} + * @type {!Array.<number>} */ o3djs.flat_math.Vector2 = goog.typedef; /** * An Float32Array of 3 floats - * @type {(!Float32Array.<number>|!o3d.Float3)} + * @type {!Array.<number>} */ o3djs.flat_math.Vector3 = goog.typedef; /** * An Float32Array of 4 floats - * @type {(!Float32Array.<number>|!o3d.Float4)} + * @type {!Array.<number>} */ o3djs.flat_math.Vector4 = goog.typedef; /** * A 1x1 Matrix of floats - * @type {!Array.<number>} + * @type {(!Array.<number>|Float32Array)} */ o3djs.flat_math.Matrix1 = goog.typedef; /** * A 2x2 Matrix of floats - * @type {!Array.<number>} + * @type {(!Array.<number>|Float32Array)} */ o3djs.flat_math.Matrix2 = goog.typedef; /** * A 3x3 Matrix of floats - * @type {!Array.<number>} + * @type {(!Array.<number>|Float32Array)} */ o3djs.flat_math.Matrix3 = goog.typedef; /** * A 4x4 Matrix of floats - * @type {(!Array.<number>|!o3d.Matrix4)} + * @type {(!Array.<number>|Float32Array)} */ o3djs.flat_math.Matrix4 = goog.typedef; @@ -210,38 +304,40 @@ o3djs.flat_math.useFloat32Array_ = false; /** * A arbitrary size Matrix of floats - * @type {(!Array.<number>|!o3d.Matrix4)} + * @type {(!Array.<number>|Float32Array|o3djs.flat_math.Matrix1| + * o3djs.flat_math.Matrix2|o3djs.flat_math.Matrix3|o3djs.flat_math.Matrix4)} */ o3djs.flat_math.Matrix = goog.typedef; /** * A arbitrary size Matrix of floats - * @type {(!Array.<number>)} + * @type {!Array.<number>} */ o3djs.flat_math.Vector = goog.typedef; /** - * Namespace for Float32Array specific math functions + * Namespace for Float32Array specific math functions. + * @namespace */ o3djs.flat_math.Float32Array = {}; /** * A arbitrary size Matrix of floats - * @type {(!Array.<number>|!o3d.Matrix4)} + * @constructor */ -o3djs.flat_math.Float32Array.Matrix = - (use_plugin_math ? goog.typedef : Float32Array); +o3djs.flat_math.Float32Array.Matrix = Float32Array; + /** - * An Float32Array of floats. - * @type {!Array.<number>} + * A Float32Array. + * @constructor */ -o3djs.flat_math.Float32Array.Vector = - (use_plugin_math ? goog.typedef : Float32Array); +o3djs.flat_math.Float32Array.Vector = Float32Array; /** * If 16 arguments, this returns a 4x4 matrix * with values set to the passed in arguments + * If 9 arguments returns a 3x3 matrix, if 4 arguments returns a 2x2 matrix. * @param {number} a [0][0] element * @param {number} b [0][1] element * @param {number} c [0][2] element @@ -258,23 +354,6 @@ o3djs.flat_math.Float32Array.Vector = * @param {number} n [3][1] element * @param {number} o [3][2] element * @param {number} p [3][3] element - * - * If 9 arguments returns a 3x3 matrix - * @param {number} a [0][0] element - * @param {number} b [0][1] element - * @param {number} c [0][2] element - * @param {number} d [1][0] element - * @param {number} e [1][1] element - * @param {number} f [1][2] element - * @param {number} g [2][0] element - * @param {number} h [2][1] element - * @param {number} i [2][2] element - - * If 4 arguments returns a 2x2 matrix - * @param {number} a [0][0] element - * @param {number} b [0][1] element - * @param {number} c [1][0] element - * @param {number} d [1][1] element * @returns {!o3djs.flat_math.Matrix} */ o3djs.flat_math.Float32Array.makeMatrix = function( @@ -424,19 +503,20 @@ o3djs.flat_math.Array={}; /** * A arbitrary size Matrix of floats - * @type {(!Array.<!Array.<number>>|!o3d.Matrix4)} + * @constructor */ -o3djs.flat_math.Array.Matrix = (use_plugin_math ? goog.typedef: Array); +o3djs.flat_math.Array.Matrix = Array; /** * An Float32Array of floats. - * @type {!Float32Array.<number>} + * @constructor */ -o3djs.flat_math.Array.Vector = (use_plugin_math ? goog.typedef: Array); +o3djs.flat_math.Array.Vector = Array; /** - * If 16 arguments, this returns a 4x4 matrix - * with values set to the passed in arguments + * If 16 arguments, this returns a 4x4 matrix with values set to the passed + * in arguments. If 9 arguments returns a 3x3 matrix, if 4 arguments returns + * a 2x2 matrix * @param {number} a [0][0] element * @param {number} b [0][1] element * @param {number} c [0][2] element @@ -453,24 +533,6 @@ o3djs.flat_math.Array.Vector = (use_plugin_math ? goog.typedef: Array); * @param {number} n [3][1] element * @param {number} o [3][2] element * @param {number} p [3][3] element - * - * If 9 arguments returns a 3x3 matrix - * @param {number} a [0][0] element - * @param {number} b [0][1] element - * @param {number} c [0][2] element - * @param {number} d [1][0] element - * @param {number} e [1][1] element - * @param {number} f [1][2] element - * @param {number} g [2][0] element - * @param {number} h [2][1] element - * @param {number} i [2][2] element - - * If 4 arguments returns a 2x2 matrix - * @param {number} a [0][0] element - * @param {number} b [0][1] element - * @param {number} c [1][0] element - * @param {number} d [1][1] element - * @returns {!o3djs.flat_math.Matrix} */ o3djs.flat_math.Array.makeMatrix = function( a, b, c, d, @@ -547,23 +609,32 @@ o3djs.flat_math.Array.makeMatrix4 = function( return [a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p]; }; -if (o3djs.flat_math.useFloat32Array_) { - o3djs.flat_math.Matrix = o3djs.flat_math.Float32Array.Matrix; - o3djs.flat_math.Vector = o3djs.flat_math.Float32Array.Vector; - for (var i in o3djs.flat_math.Float32Array) { - if (o3djs.flat_math.Float32Array[i].call) - o3djs.flat_math[i]=o3djs.flat_math.Float32Array[i]; - } -} else { - o3djs.flat_math.Matrix = o3djs.flat_math.Array.Matrix; - o3djs.flat_math.Vector = o3djs.flat_math.Array.Vector; - for (var i in o3djs.flat_math.Array) { - if (o3djs.flat_math.Array[i].call) - o3djs.flat_math[i]=o3djs.flat_math.Array[i]; + +/** + * Helper function to copy functions from one namespace into another. + * @param {Object} source The source namespace. + * @param {Object} target The target namespace. + */ +o3djs.copyFunctions_ = function(source, target) { + for (var i in source) { + var value = source[i]; + // If it's a function, copy it. + if (value.call) { + target[i] = value; } -} + } +}; +if (o3djs.flat_math.useFloat32Array_) { + o3djs.flat_math.Matrix = o3djs.flat_math.Float32Array.Matrix; + o3djs.flat_math.Vector = o3djs.flat_math.Float32Array.Vector; + o3djs.copyFunctions_(o3djs.flat_math.Float32Array, o3djs.flat_math); +} else { + o3djs.flat_math.Matrix = o3djs.flat_math.Array.Matrix; + o3djs.flat_math.Vector = o3djs.flat_math.Array.Vector; + o3djs.copyFunctions_(o3djs.flat_math.Array, o3djs.flat_math); +} /** @@ -1170,7 +1241,7 @@ o3djs.flat_math.rowMajor.mulVectorMatrix = function(v, m) { * matrix entries are accessed in [column*4+row] fashion. * @param {!o3djs.flat_math.Vector} v The vector. * @param {!o3djs.flat_math.Matrix} m The matrix. - * @param {!o3djs.flat_math.Vector} r The product of v and m as a row vector. + * @return {!o3djs.flat_math.Vector} The product of v and m as a row vector. */ o3djs.flat_math.rowMajor.mulMatrixVector4 = function(m, v) { var r = new o3djs.flat_math.Vector(4); @@ -1189,7 +1260,7 @@ o3djs.flat_math.rowMajor.mulMatrixVector4 = function(m, v) { * matrix entries are accessed in [column*3+row] fashion. * @param {!o3djs.flat_math.Vector} v The vector. * @param {!o3djs.flat_math.Matrix} m The matrix. - * @param {!o3djs.flat_math.Vector} r The product of v and m as a row vector. + * @return {!o3djs.flat_math.Vector} The product of v and m as a row vector. */ o3djs.flat_math.rowMajor.mulMatrixVector3 = function(m, v) { var r = new o3djs.flat_math.Vector(3); @@ -1207,7 +1278,7 @@ o3djs.flat_math.rowMajor.mulMatrixVector3 = function(m, v) { * matrix entries are accessed in [column*2+row] fashion. * @param {!o3djs.flat_math.Vector} v The vector. * @param {!o3djs.flat_math.Matrix} m The matrix. - * @param {!o3djs.flat_math.Vector} r The product of v and m as a row vector. + * @return {!o3djs.flat_math.Vector} The product of v and m as a row vector. */ o3djs.flat_math.rowMajor.mulMatrixVector2 = function(m, v) { var r = new o3djs.flat_math.Vector(2); @@ -1555,9 +1626,8 @@ o3djs.flat_math.columnMajor.mulMatrixMatrix4 = function(a, b) { o3djs.flat_math.mulMatrixMatrix4 = null; /** - * Multiplies two matrices; assumes that the sizes of the matrices are - * appropriately compatible; assumes matrix entries are accessed in - * [row][column] fashion. + * Multiplies two matrices; assumes the matrices are square of size 2, 3 or 4; + * assumes matrix entries are accessed in row-major fashion. * @param {!o3djs.flat_math.Matrix} a The matrix on the left. * @param {!o3djs.flat_math.Matrix} b The matrix on the right. * @return {!o3djs.flat_math.Matrix} The matrix product of a and b. @@ -1565,16 +1635,46 @@ o3djs.flat_math.mulMatrixMatrix4 = null; o3djs.flat_math.rowMajor.mulMatrixMatrix = function(a, b) { switch(a.length) { case 4: - return o3djs.flat_math.rowMajor.mulMatrixMatrix2(a,b); + return o3djs.flat_math.rowMajor.mulMatrixMatrix2(a, b); + case 9: + return o3djs.flat_math.rowMajor.mulMatrixMatrix3(a, b); + case 16: + return o3djs.flat_math.rowMajor.mulMatrixMatrix4(a, b); + default: + throw "Unable to handle irregular matrices or matrices of dim > 4 or < 2"; + } +}; + + +/** + * Multiplies two matrices; assumes the matrices are square of size 2, 3 or 4; + * assumes matrix entries are accessed in column-major fashion. + * @param {!o3djs.flat_math.Matrix} a The matrix on the left. + * @param {!o3djs.flat_math.Matrix} b The matrix on the right. + * @return {!o3djs.flat_math.Matrix} The matrix product of a and b. + */ +o3djs.flat_math.columnMajor.mulMatrixMatrix = function(a, b) { + switch(a.length) { + case 4: + return o3djs.flat_math.columnMajor.mulMatrixMatrix2(a, b); case 9: - return o3djs.flat_math.rowMajor.mulMatrixMatrix3(a,b); + return o3djs.flat_math.columnMajor.mulMatrixMatrix3(a, b); case 16: - return o3djs.flat_math.rowMajor.mulMatrixMatrix4(a,b); + return o3djs.flat_math.columnMajor.mulMatrixMatrix4(a, b); default: throw "Unable to handle irregular matrices or matrices of dim > 4 or < 2"; } - }; +}; + +/** + * Multiplies two matrices; assumes that the sizes of the matrices are + * appropriately compatible; assumes matrix entries are accessed in + * [column][row] fashion. + * @param {!o3djs.flat_math.Matrix} a The matrix on the left. + * @param {!o3djs.flat_math.Matrix} b The matrix on the right. + * @return {!o3djs.flat_math.Matrix} The matrix product of a and b. + */ o3djs.flat_math.rowMajor.generalizedMulMatrixMatrix= function(a, b) { var r = []; var aRows = a.length; @@ -1595,27 +1695,6 @@ o3djs.flat_math.rowMajor.generalizedMulMatrixMatrix= function(a, b) { /** * Multiplies two matrices; assumes that the sizes of the matrices are - * appropriately compatible; assumes matrix entries are accessed in - * [row][column] fashion. - * @param {!o3djs.flat_math.Matrix} a The matrix on the left. - * @param {!o3djs.flat_math.Matrix} b The matrix on the right. - * @return {!o3djs.flat_math.Matrix} The matrix product of a and b. - */ -o3djs.flat_math.columnMajor.mulMatrixMatrix = function(a, b) { - switch(a.length) { - case 4: - return o3djs.flat_math.columnMajor.mulMatrixMatrix2(a,b); - case 9: - return o3djs.flat_math.columnMajor.mulMatrixMatrix3(a,b); - case 16: - return o3djs.flat_math.columnMajor.mulMatrixMatrix4(a,b); - default: - throw "Unable to handle irregular matrices or matrices of dim > 4 or < 2"; - } -}; - -/** - * Multiplies two matrices; assumes that the sizes of the matrices are * appropriately compatible. * @param {!o3djs.flat_math.Matrix} a The matrix on the left. * @param {!o3djs.flat_math.Matrix} b The matrix on the right. @@ -2626,6 +2705,11 @@ o3djs.flat_math.matrix4.translate = function(m, v) { var m32 = m[14]; var m33 = m[15]; + var v0 = v[0]; + var v1 = v[1]; + var v2 = v[2]; + var v3 = v[3]; + m[12] = m00 * v0 + m10 * v1 + m20 * v2 + m30; m[13] = m01 * v0 + m11 * v1 + m21 * v2 + m31; m[14] = m02 * v0 + m12 * v1 + m22 * v2 + m32; @@ -3068,8 +3152,8 @@ o3djs.flat_math.installRowMajorFunctions(); o3djs.flat_math.installErrorCheckFunctions(); if (!use_plugin_math) { - for (var i in o3djs.flat_math) { - o3djs.math[i] = o3djs.flat_math[i]; + for (var f in o3djs.flat_math) { + o3djs.math[f] = o3djs.flat_math[f]; } /** diff --git a/o3d/samples/o3djs/plugin_math.js b/o3d/samples/o3djs/plugin_math.js index 799ce78..25ce285 100644 --- a/o3d/samples/o3djs/plugin_math.js +++ b/o3d/samples/o3djs/plugin_math.js @@ -99,7 +99,8 @@ * */ -o3djs.provide('o3djs.math'); +o3djs.provide('o3djs.math', true); + /** * A module for math for o3djs.math. @@ -121,92 +122,6 @@ o3djs.math.randomSeed_ = 0; */ o3djs.math.RANDOM_RANGE_ = Math.pow(2, 32); -/** - * Functions which deal with 4-by-4 transformation matrices are kept in their - * own namespsace. - * @namespace - */ -o3djs.math.matrix4 = o3djs.math.matrix4 || {}; - -/** - * Functions that are specifically row major are kept in their own namespace. - * @namespace - */ -o3djs.math.rowMajor = o3djs.math.rowMajor || {}; - -/** - * Functions that are specifically column major are kept in their own namespace. - * @namespace - */ -o3djs.math.columnMajor = o3djs.math.columnMajor || {}; - -/** - * Functions that do error checking are stored in their own namespace. - * @namespace - */ -o3djs.math.errorCheck = o3djs.math.errorCheck || {}; - -/** - * Functions that do no error checking and have a separate version that does in - * o3djs.math.errorCheck are stored in their own namespace. - * @namespace - */ -o3djs.math.errorCheckFree = o3djs.math.errorCheckFree || {}; - -/** - * An Array of 2 floats - * @type {(!Array.<number>|!o3d.Float2)} - */ -o3djs.math.Vector2 = goog.typedef; - -/** - * An Array of 3 floats - * @type {(!Array.<number>|!o3d.Float3)} - */ -o3djs.math.Vector3 = goog.typedef; - -/** - * An Array of 4 floats - * @type {(!Array.<number>|!o3d.Float4)} - */ -o3djs.math.Vector4 = goog.typedef; - -/** - * An Array of floats. - * @type {!Array.<number>} - */ -o3djs.math.Vector = goog.typedef; - -/** - * A 1x1 Matrix of floats - * @type {!Array.<!Array.<number>>} - */ -o3djs.math.Matrix1 = goog.typedef; - -/** - * A 2x2 Matrix of floats - * @type {!Array.<!Array.<number>>} - */ -o3djs.math.Matrix2 = goog.typedef; - -/** - * A 3x3 Matrix of floats - * @type {!Array.<!Array.<number>>} - */ -o3djs.math.Matrix3 = goog.typedef; - -/** - * A 4x4 Matrix of floats - * @type {(!Array.<!Array.<number>>|!o3d.Matrix4)} - */ -o3djs.math.Matrix4 = goog.typedef; - -/** - * A arbitrary size Matrix of floats - * @type {(!Array.<!Array.<number>>|!o3d.Matrix4)} - */ -o3djs.math.Matrix = goog.typedef; - o3djs.math.makeMatrix = function(a,b,c,d, e,f,g,h, diff --git a/o3d/samples/o3djs/serialization.js b/o3d/samples/o3djs/serialization.js index 9a5ed29..c02e405 100644 --- a/o3d/samples/o3djs/serialization.js +++ b/o3d/samples/o3djs/serialization.js @@ -753,7 +753,7 @@ o3djs.serialization.deserialize = function(pack, json) { * This function looks at a given data type, determines if it is an old style * matrix that is a 2d doubly nested array. If so, it flattens the matrix in * place so that it may be handled by the code. - * @param {object} parsed a potential array that will be repaired + * @param {Object} parsed a potential array that will be repaired */ o3djs.serialization.fixMatrices = function(parsed) { function isMatrix(m) { |