Matrix3.js 2.3 KB
Newer Older
A
alteredq 已提交
1 2
/**
 * @author alteredq / http://alteredqualia.com/
3
 * @author WestLangley / http://github.com/WestLangley
A
alteredq 已提交
4 5
 */

6 7
THREE.Matrix3 = function () {

8
	this.elements = new Float32Array(9);
9 10 11 12 13

};

THREE.Matrix3.prototype = {

14 15
	constructor: THREE.Matrix3,

16 17 18 19 20 21 22 23 24 25 26 27 28 29
	multiplyVector3: function ( v ) {

		var te = this.elements;

		var vx = v.x, vy = v.y, vz = v.z;

		v.x = te[0] * vx + te[3] * vy + te[6] * vz;
		v.y = te[1] * vx + te[4] * vy + te[7] * vz;
		v.z = te[2] * vx + te[5] * vy + te[8] * vz;

		return v;

	},

30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
	multiplyVector3Array: function ( a ) {

		var tmp = THREE.Matrix3.__v1;

		for ( var i = 0, il = a.length; i < il; i += 3 ) {

			tmp.x = a[ i ];
			tmp.y = a[ i + 1 ];
			tmp.z = a[ i + 2 ];

			this.multiplyVector3( tmp );

			a[ i ]     = tmp.x;
			a[ i + 1 ] = tmp.y;
			a[ i + 2 ] = tmp.z;

		}

		return a;

	},

M
Mr.doob 已提交
52
	getInverse: function ( matrix ) {
53 54 55 56

		// input: THREE.Matrix4
		// ( based on http://code.google.com/p/webgl-mjs/ )

57 58
		var me = matrix.elements;

59 60 61 62 63 64 65 66 67
		var a11 =   me[10] * me[5] - me[6] * me[9];
		var a21 = - me[10] * me[1] + me[2] * me[9];
		var a31 =   me[6] * me[1] - me[2] * me[5];
		var a12 = - me[10] * me[4] + me[6] * me[8];
		var a22 =   me[10] * me[0] - me[2] * me[8];
		var a32 = - me[6] * me[0] + me[2] * me[4];
		var a13 =   me[9] * me[4] - me[5] * me[8];
		var a23 = - me[9] * me[0] + me[1] * me[8];
		var a33 =   me[5] * me[0] - me[1] * me[4];
68

69
		var det = me[0] * a11 + me[1] * a12 + me[2] * a13;
70 71 72 73 74 75 76 77 78 79 80

		// no inverse

		if ( det === 0 ) {

			console.warn( "Matrix3.getInverse(): determinant == 0" );

		}

		var idet = 1.0 / det;

81
		var m = this.elements;
82 83 84 85 86 87 88 89 90

		m[ 0 ] = idet * a11; m[ 1 ] = idet * a21; m[ 2 ] = idet * a31;
		m[ 3 ] = idet * a12; m[ 4 ] = idet * a22; m[ 5 ] = idet * a32;
		m[ 6 ] = idet * a13; m[ 7 ] = idet * a23; m[ 8 ] = idet * a33;

		return this;

	},

91

92
	transpose: function () {
93

94
		var tmp, m = this.elements;
95

A
astrodud 已提交
96 97 98
		tmp = m[1]; m[1] = m[3]; m[3] = tmp;
		tmp = m[2]; m[2] = m[6]; m[6] = tmp;
		tmp = m[5]; m[5] = m[7]; m[7] = tmp;
99 100 101

		return this;

A
alteredq 已提交
102
	},
103

104

105
	transposeIntoArray: function ( r ) {
A
alteredq 已提交
106

107
		var m = this.elements;
A
alteredq 已提交
108 109 110 111 112 113 114 115 116 117

		r[ 0 ] = m[ 0 ];
		r[ 1 ] = m[ 3 ];
		r[ 2 ] = m[ 6 ];
		r[ 3 ] = m[ 1 ];
		r[ 4 ] = m[ 4 ];
		r[ 5 ] = m[ 7 ];
		r[ 6 ] = m[ 2 ];
		r[ 7 ] = m[ 5 ];
		r[ 8 ] = m[ 8 ];
118

A
alteredq 已提交
119 120
		return this;

121
	}
122

123
};
124 125

THREE.Matrix3.__v1 = new THREE.Vector3();