Matrix3.js 3.6 KB
Newer Older
A
alteredq 已提交
1 2
/**
 * @author alteredq / http://alteredqualia.com/
3
 * @author WestLangley / http://github.com/WestLangley
B
Ben Houston 已提交
4
 * @author bhouston / http://exocortex.com
A
alteredq 已提交
5 6
 */

7
THREE.Matrix3 = function ( n11, n12, n13, n21, n22, n23, n31, n32, n33 ) {
8

9
	this.elements = new Float32Array(9);
10

11 12 13 14 15 16 17
	this.set(

		( n11 !== undefined ) ? n11 : 1, n12 || 0, n13 || 0,
		n21 || 0, ( n22 !== undefined ) ? n22 : 1, n23 || 0,
		n31 || 0, n32 || 0, ( n33 !== undefined ) ? n33 : 1

	);
18 19
};

20
THREE.extend( THREE.Matrix3.prototype, {
21

22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
	set: function ( n11, n12, n13, n21, n22, n23, n31, n32, n33 ) {

		var te = this.elements;

		te[0] = n11; te[3] = n12; te[6] = n13;
		te[1] = n21; te[4] = n22; te[7] = n23;
		te[2] = n31; te[5] = n32; te[8] = n33;

		return this;

	},

	identity: function () {

		this.set(

			1, 0, 0,
			0, 1, 0,
			0, 0, 1

		);

		return this;

	},

	copy: function ( m ) {

		var me = m.elements;

		this.set(

			me[0], me[3], me[6],
			me[1], me[4], me[7],
			me[2], me[5], me[8]

		);

		return this;

	},

64 65
	multiplyVector3: function ( vector ) {

66
		console.warn( 'DEPRECATED: Matrix3\'s .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.' );
67 68 69 70
		return vector.applyMatrix3( this );

	},

71
	multiplyVector3Array: function() {
72

73
		var v1 = new THREE.Vector3();
M
Mr.doob 已提交
74

75
		return function ( a ) {
76

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

79 80 81
				v1.x = a[ i ];
				v1.y = a[ i + 1 ];
				v1.z = a[ i + 2 ];
82

83
				v1.applyMatrix3(this);
84

85 86 87
				a[ i ]     = v1.x;
				a[ i + 1 ] = v1.y;
				a[ i + 2 ] = v1.z;
88

89
			}
90

91
			return a;
92

93 94 95
		};

	}(),
96

97 98 99 100 101 102 103 104 105 106 107 108 109
	multiplyScalar: function ( s ) {

		var te = this.elements;

		te[0] *= s; te[3] *= s; te[6] *= s;
		te[1] *= s; te[4] *= s; te[7] *= s;
		te[2] *= s; te[5] *= s; te[8] *= s;

		return this;

	},

	determinant: function () {
M
Mr.doob 已提交
110

111
		var te = this.elements;
M
Mr.doob 已提交
112

113 114 115 116 117
		var a = te[0], b = te[1], c = te[2],
			d = te[3], e = te[4], f = te[5],
			g = te[6], h = te[7], i = te[8];

		return a*e*i - a*f*h - b*d*i + b*f*g + c*d*h - c*e*g;
M
Mr.doob 已提交
118

119 120 121
	},

	getInverse: function ( matrix, throwOnInvertible ) {
122 123 124 125

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

126
		var me = matrix.elements;
127
		var te = this.elements;
M
Mr.doob 已提交
128

129 130 131 132 133 134 135 136 137 138 139 140
		te[ 0 ] =   me[10] * me[5] - me[6] * me[9];
		te[ 1 ] = - me[10] * me[1] + me[2] * me[9];
		te[ 2 ] =   me[6] * me[1] - me[2] * me[5];
		te[ 3 ] = - me[10] * me[4] + me[6] * me[8];
		te[ 4 ] =   me[10] * me[0] - me[2] * me[8];
		te[ 5 ] = - me[6] * me[0] + me[2] * me[4];
		te[ 6 ] =   me[9] * me[4] - me[5] * me[8];
		te[ 7 ] = - me[9] * me[0] + me[1] * me[8];
		te[ 8 ] =   me[5] * me[0] - me[1] * me[4];

		var det = me[ 0 ] * te[ 0 ] + me[ 1 ] * te[ 3 ] + me[ 2 ] * te[ 6 ];

141 142 143 144
		// no inverse

		if ( det === 0 ) {

145
			var msg = "Matrix3.getInverse(): can't invert matrix, determinant is 0";
146

M
Mr.doob 已提交
147
			if ( throwOnInvertible || false ) {
148

149
				throw new Error( msg ); 
150

M
Mr.doob 已提交
151
			} else {
152 153

				console.warn( msg );
154

155 156 157 158 159
			}

			this.identity();

			return this;
M
Mr.doob 已提交
160

161 162 163
		}

		this.multiplyScalar( 1.0 / det );
164 165 166 167 168

		return this;

	},

169
	transpose: function () {
170

171
		var tmp, m = this.elements;
172

A
astrodud 已提交
173 174 175
		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;
176 177 178

		return this;

A
alteredq 已提交
179
	},
180

181 182 183 184 185 186 187 188 189
	getNormalMatrix: function ( m ) {

		// input: THREE.Matrix4

		this.getInverse( m ).transpose();

		return this;

	},
190

191
	transposeIntoArray: function ( r ) {
A
alteredq 已提交
192

193
		var m = this.elements;
A
alteredq 已提交
194 195 196 197 198 199 200 201 202 203

		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 ];
204

A
alteredq 已提交
205 206
		return this;

207 208 209 210 211 212 213 214 215 216 217 218 219 220
	},

	clone: function () {

		var te = this.elements;

		return new THREE.Matrix3(

			te[0], te[3], te[6],
			te[1], te[4], te[7],
			te[2], te[5], te[8]

		);

221
	}
222

M
Mr.doob 已提交
223
} );