Vector3.js 8.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
/**
 * @author bhouston / http://exocortex.com
 */

module( "Vector3" );

test( "constructor", function() {
	var a = new THREE.Vector3();
	ok( a.x == 0, "Passed!" );
	ok( a.y == 0, "Passed!" );
	ok( a.z == 0, "Passed!" );

	a = new THREE.Vector3( x, y, z );
	ok( a.x === x, "Passed!" );
	ok( a.y === y, "Passed!" );
	ok( a.z === z, "Passed!" );
});

test( "copy", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3().copy( a );
	ok( b.x == x, "Passed!" );
	ok( b.y == y, "Passed!" );
	ok( b.z == z, "Passed!" );

	// ensure that it is a true copy
	a.x = 0;
	a.y = -1;
	a.z = -2;
	ok( b.x == x, "Passed!" );
	ok( b.y == y, "Passed!" );
	ok( b.z == z, "Passed!" );
});

test( "set", function() {
	var a = new THREE.Vector3();
	ok( a.x == 0, "Passed!" );
	ok( a.y == 0, "Passed!" );
	ok( a.z == 0, "Passed!" );

41
	a.set( x, y, z );
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
	ok( a.x == x, "Passed!" );
	ok( a.y == y, "Passed!" );
	ok( a.z == z, "Passed!" );
});

test( "setX,setY,setZ", function() {
	var a = new THREE.Vector3();
	ok( a.x == 0, "Passed!" );
	ok( a.y == 0, "Passed!" );
	ok( a.z == 0, "Passed!" );

	a.setX( x );
	a.setY( y );
	a.setZ( z );

	ok( a.x == x, "Passed!" );
	ok( a.y == y, "Passed!" );
	ok( a.z == z, "Passed!" );
});

62 63 64 65 66 67 68 69 70 71 72 73 74 75
test( "setComponent,getComponent", function() {
	var a = new THREE.Vector3();
	ok( a.x == 0, "Passed!" );
	ok( a.y == 0, "Passed!" );
	ok( a.z == 0, "Passed!" );

	a.setComponent( 0, 1 );
	a.setComponent( 1, 2 );
	a.setComponent( 2, 3 );
	ok( a.getComponent( 0 ) == 1, "Passed!" );
	ok( a.getComponent( 1 ) == 2, "Passed!" );
	ok( a.getComponent( 2 ) == 3, "Passed!" );
});

76 77 78 79
test( "add", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3( -x, -y, -z );

80
	a.add( b );
81 82 83 84
	ok( a.x == 0, "Passed!" );
	ok( a.y == 0, "Passed!" );
	ok( a.z == 0, "Passed!" );

85
	var c = new THREE.Vector3().addVectors( b, b );
86
	ok( c.x == -2*x, "Passed!" );
87 88
	ok( c.y == -2*y, "Passed!" );
	ok( c.z == -2*z, "Passed!" );
89 90 91 92 93 94
});

test( "sub", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3( -x, -y, -z );

95
	a.sub( b );
96 97 98 99
	ok( a.x == 2*x, "Passed!" );
	ok( a.y == 2*y, "Passed!" );
	ok( a.z == 2*z, "Passed!" );

100
	var c = new THREE.Vector3().subVectors( a, a );
101
	ok( c.x == 0, "Passed!" );
102 103
	ok( c.y == 0, "Passed!" );
	ok( c.z == 0, "Passed!" );
104 105 106 107 108 109 110 111 112 113 114 115 116
});

test( "multiply/divide", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3( -x, -y, -z );

	a.multiplyScalar( -2 );
	ok( a.x == x*-2, "Passed!" );
	ok( a.y == y*-2, "Passed!" );
	ok( a.z == z*-2, "Passed!" );

	b.multiplyScalar( -2 );
	ok( b.x == 2*x, "Passed!" );
117 118
	ok( b.y == 2*y, "Passed!" );
	ok( b.z == 2*z, "Passed!" );
119 120 121 122 123 124 125 126

	a.divideScalar( -2 );
	ok( a.x == x, "Passed!" );
	ok( a.y == y, "Passed!" );
	ok( a.z == z, "Passed!" );

	b.divideScalar( -2 );
	ok( b.x == -x, "Passed!" );
127 128
	ok( b.y == -y, "Passed!" );
	ok( b.z == -z, "Passed!" );
129 130 131 132 133 134 135
});

test( "min/max/clamp", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3( -x, -y, -z );
	var c = new THREE.Vector3();

136
	c.copy( a ).min( b );
137 138 139 140
	ok( c.x == -x, "Passed!" );
	ok( c.y == -y, "Passed!" );
	ok( c.z == -z, "Passed!" );

141
	c.copy( a ).max( b );
142 143 144 145 146
	ok( c.x == x, "Passed!" );
	ok( c.y == y, "Passed!" );
	ok( c.z == z, "Passed!" );

	c.set( -2*x, 2*y, -2*z );
147
	c.clamp( b, a );
148
	ok( c.x == -x, "Passed!" );
149 150
	ok( c.y == y, "Passed!" );
	ok( c.z == -z, "Passed!" );
151 152 153 154
});

test( "negate", function() {
	var a = new THREE.Vector3( x, y, z );
155

156 157 158 159 160 161 162 163 164 165
	a.negate();
	ok( a.x == -x, "Passed!" );
	ok( a.y == -y, "Passed!" );
	ok( a.z == -z, "Passed!" );
});

test( "dot", function() {
	var a = new THREE.Vector3( x, y, z );
	var b = new THREE.Vector3( -x, -y, -z );
	var c = new THREE.Vector3();
166

167 168 169 170 171 172 173 174 175 176 177 178
	var result = a.dot( b );
	ok( result == (-x*x-y*y-z*z), "Passed!" );

	result = a.dot( c );
	ok( result == 0, "Passed!" );
});

test( "length/lengthSq", function() {
	var a = new THREE.Vector3( x, 0, 0 );
	var b = new THREE.Vector3( 0, -y, 0 );
	var c = new THREE.Vector3( 0, 0, z );
	var d = new THREE.Vector3();
179

180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197
	ok( a.length() == x, "Passed!" );
	ok( a.lengthSq() == x*x, "Passed!" );
	ok( b.length() == y, "Passed!" );
	ok( b.lengthSq() == y*y, "Passed!" );
	ok( c.length() == z, "Passed!" );
	ok( c.lengthSq() == z*z, "Passed!" );
	ok( d.length() == 0, "Passed!" );
	ok( d.lengthSq() == 0, "Passed!" );

	a.set( x, y, z );
	ok( a.length() == Math.sqrt( x*x + y*y + z*z ), "Passed!" );
	ok( a.lengthSq() == ( x*x + y*y + z*z ), "Passed!" );
});

test( "normalize", function() {
	var a = new THREE.Vector3( x, 0, 0 );
	var b = new THREE.Vector3( 0, -y, 0 );
	var c = new THREE.Vector3( 0, 0, z );
198

199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216
	a.normalize();
	ok( a.length() == 1, "Passed!" );
	ok( a.x == 1, "Passed!" );

	b.normalize();
	ok( b.length() == 1, "Passed!" );
	ok( b.y == -1, "Passed!" );

	c.normalize();
	ok( c.length() == 1, "Passed!" );
	ok( c.z == 1, "Passed!" );
});

test( "distanceTo/distanceToSquared", function() {
	var a = new THREE.Vector3( x, 0, 0 );
	var b = new THREE.Vector3( 0, -y, 0 );
	var c = new THREE.Vector3( 0, 0, z );
	var d = new THREE.Vector3();
217

218 219 220 221 222 223 224 225 226 227 228 229
	ok( a.distanceTo( d ) == x, "Passed!" );
	ok( a.distanceToSquared( d ) == x*x, "Passed!" );

	ok( b.distanceTo( d ) == y, "Passed!" );
	ok( b.distanceToSquared( d ) == y*y, "Passed!" );

	ok( c.distanceTo( d ) == z, "Passed!" );
	ok( c.distanceToSquared( d ) == z*z, "Passed!" );
});

test( "setLength", function() {
	var a = new THREE.Vector3( x, 0, 0 );
230

231 232 233
	ok( a.length() == x, "Passed!" );
	a.setLength( y );
	ok( a.length() == y, "Passed!" );
234 235 236 237 238 239

	a = new THREE.Vector3( 0, 0, 0 );
	ok( a.length() == 0, "Passed!" );
	a.setLength( y );
	ok( a.length() == 0, "Passed!" );

240 241
});

242
test( "projectOn", function() {
243 244 245 246
	var a = new THREE.Vector3( 1, 0, 0 );
	var b = new THREE.Vector3();
	var normal = new THREE.Vector3( 1, 0, 0 );

247
	ok( b.copy( a ).projectOn( normal ).equals( new THREE.Vector3( 1, 0, 0 ) ), "Passed!" );
248 249

	a.set( 0, 1, 0 );
250
	ok( b.copy( a ).projectOn( normal ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
251 252

	a.set( 0, 0, -1 );
253
	ok( b.copy( a ).projectOn( normal ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
254 255

	a.set( -1, 0, 0 );
256
	ok( b.copy( a ).projectOn( normal ).equals( new THREE.Vector3( -1, 0, 0 ) ), "Passed!" );
257 258 259

});

260
test( "orthoTo", function() {
261 262 263 264
	var a = new THREE.Vector3( 1, 0, 0 );
	var b = new THREE.Vector3();
	var normal = new THREE.Vector3( 1, 0, 0 );

265
	ok( b.copy( a ).orthoTo( normal ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
266 267

	a.set( 0, 1, 0 );
268
	ok( b.copy( a ).orthoTo( normal ).equals( new THREE.Vector3( 0, 1, 0 ) ), "Passed!" );
269 270

	a.set( 0, 0, -1 );
271
	ok( b.copy( a ).orthoTo( normal ).equals( new THREE.Vector3( 0, 0, -1 ) ), "Passed!" );
272 273

	a.set( -1, 0, 0 );
274
	ok( b.copy( a ).orthoTo( normal ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292

});

test( "reflect", function() {
	var a = new THREE.Vector3( 1, 0, 0 );
	var normal = new THREE.Vector3( 1, 0, 0 );
	var b = new THREE.Vector3( 0, 0, 0 );

	ok( b.copy( a ).reflect( normal ).equals( new THREE.Vector3( 1, 0, 0 ) ), "Passed!" );

	a.set( 1, -1, 0 );
	ok( b.copy( a ).reflect( normal ).equals( new THREE.Vector3( 1, 1, 0 ) ), "Passed!" );

	a.set( 1, -1, 0 );
	normal.set( 0, -1, 0 )
	ok( b.copy( a ).reflect(  normal ).equals( new THREE.Vector3( -1, -1, 0 ) ), "Passed!" );
});

293
test( "lerp/clone", function() {
294 295 296
	var a = new THREE.Vector3( x, 0, z );
	var b = new THREE.Vector3( 0, -y, 0 );

297 298
	ok( a.lerp( a, 0 ).equals( a.lerp( a, 0.5 ) ), "Passed!" );
	ok( a.lerp( a, 0 ).equals( a.lerp( a, 1 ) ), "Passed!" );
299

300
	ok( a.clone().lerp( b, 0 ).equals( a ), "Passed!" );
301

302 303 304 305 306
	ok( a.clone().lerp( b, 0.5 ).x == x*0.5, "Passed!" );
	ok( a.clone().lerp( b, 0.5 ).y == -y*0.5, "Passed!" );
	ok( a.clone().lerp( b, 0.5 ).z == z*0.5, "Passed!" );

	ok( a.clone().lerp( b, 1 ).equals( b ), "Passed!" );
307 308 309 310 311
});

test( "equals", function() {
	var a = new THREE.Vector3( x, 0, z );
	var b = new THREE.Vector3( 0, -y, 0 );
312

313 314 315 316 317 318 319 320 321 322 323 324 325 326 327
	ok( a.x != b.x, "Passed!" );
	ok( a.y != b.y, "Passed!" );
	ok( a.z != b.z, "Passed!" );

	ok( ! a.equals( b ), "Passed!" );
	ok( ! b.equals( a ), "Passed!" );

	a.copy( b );
	ok( a.x == b.x, "Passed!" );
	ok( a.y == b.y, "Passed!" );
	ok( a.z == b.z, "Passed!" );

	ok( a.equals( b ), "Passed!" );
	ok( b.equals( a ), "Passed!" );
});