Matrix3.js 3.3 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 21
};

THREE.Matrix3.prototype = {

22 23
	constructor: THREE.Matrix3,

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 64 65
	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;

	},

66 67 68 69 70 71 72 73 74 75
	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 ];

76
			tmp.applyMatrix3(this);
77 78 79 80 81 82 83 84 85 86 87

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

		}

		return a;

	},

88 89 90 91 92 93 94 95 96 97 98 99 100
	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 已提交
101

102
		var te = this.elements;
M
Mr.doob 已提交
103

104 105 106 107 108
		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 已提交
109

110 111 112
	},

	getInverse: function ( matrix, throwOnInvertible ) {
113 114 115 116

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

117
		var me = matrix.elements;
118
		var te = this.elements;
M
Mr.doob 已提交
119

120 121 122 123 124 125 126 127 128 129 130 131
		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 ];

132 133 134 135
		// no inverse

		if ( det === 0 ) {

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

M
Mr.doob 已提交
138
			if ( throwOnInvertible || false ) {
139

140
				throw new Error( msg ); 
141

M
Mr.doob 已提交
142
			} else {
143 144

				console.warn( msg );
145

146 147 148 149 150
			}

			this.identity();

			return this;
M
Mr.doob 已提交
151

152 153 154
		}

		this.multiplyScalar( 1.0 / det );
155 156 157 158 159

		return this;

	},

160

161
	transpose: function () {
162

163
		var tmp, m = this.elements;
164

A
astrodud 已提交
165 166 167
		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;
168 169 170

		return this;

A
alteredq 已提交
171
	},
172

173

174
	transposeIntoArray: function ( r ) {
A
alteredq 已提交
175

176
		var m = this.elements;
A
alteredq 已提交
177 178 179 180 181 182 183 184 185 186

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

A
alteredq 已提交
188 189
		return this;

190 191 192 193 194 195 196 197 198 199 200 201 202 203
	},

	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]

		);

204
	}
205

206
};
207

M
Mr.doob 已提交
208
THREE.Matrix3.__v1 = new THREE.Vector3();