| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549 |
- /**
- * @author bhouston / http://exocortex.com
- */
- QUnit.module( "Matrix4" );
- var matrixEquals4 = function( a, b, tolerance ) {
- tolerance = tolerance || 0.0001;
- if( a.elements.length != b.elements.length ) {
- return false;
- }
- for( var i = 0, il = a.elements.length; i < il; i ++ ) {
- var delta = a.elements[i] - b.elements[i];
- if( delta > tolerance ) {
- return false;
- }
- }
- return true;
- };
- // from Euler.js
- var eulerEquals = function ( a, b, tolerance ) {
- tolerance = tolerance || 0.0001;
- var diff = Math.abs( a.x - b.x ) + Math.abs( a.y - b.y ) + Math.abs( a.z - b.z );
- return ( diff < tolerance );
- };
- QUnit.test( "constructor" , function( assert ) {
- var a = new THREE.Matrix4();
- assert.ok( a.determinant() == 1, "Passed!" );
- var b = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- assert.ok( b.elements[0] == 0 );
- assert.ok( b.elements[1] == 4 );
- assert.ok( b.elements[2] == 8 );
- assert.ok( b.elements[3] == 12 );
- assert.ok( b.elements[4] == 1 );
- assert.ok( b.elements[5] == 5 );
- assert.ok( b.elements[6] == 9 );
- assert.ok( b.elements[7] == 13 );
- assert.ok( b.elements[8] == 2 );
- assert.ok( b.elements[9] == 6 );
- assert.ok( b.elements[10] == 10 );
- assert.ok( b.elements[11] == 14 );
- assert.ok( b.elements[12] == 3 );
- assert.ok( b.elements[13] == 7 );
- assert.ok( b.elements[14] == 11 );
- assert.ok( b.elements[15] == 15 );
- assert.ok( ! matrixEquals4( a, b ), "Passed!" );
- });
- QUnit.test( "copy" , function( assert ) {
- var a = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- var b = new THREE.Matrix4().copy( a );
- assert.ok( matrixEquals4( a, b ), "Passed!" );
- // ensure that it is a true copy
- a.elements[0] = 2;
- assert.ok( ! matrixEquals4( a, b ), "Passed!" );
- });
- QUnit.test( "set" , function( assert ) {
- var b = new THREE.Matrix4();
- assert.ok( b.determinant() == 1, "Passed!" );
- b.set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- assert.ok( b.elements[0] == 0 );
- assert.ok( b.elements[1] == 4 );
- assert.ok( b.elements[2] == 8 );
- assert.ok( b.elements[3] == 12 );
- assert.ok( b.elements[4] == 1 );
- assert.ok( b.elements[5] == 5 );
- assert.ok( b.elements[6] == 9 );
- assert.ok( b.elements[7] == 13 );
- assert.ok( b.elements[8] == 2 );
- assert.ok( b.elements[9] == 6 );
- assert.ok( b.elements[10] == 10 );
- assert.ok( b.elements[11] == 14 );
- assert.ok( b.elements[12] == 3 );
- assert.ok( b.elements[13] == 7 );
- assert.ok( b.elements[14] == 11 );
- assert.ok( b.elements[15] == 15 );
- });
- QUnit.test( "identity" , function( assert ) {
- var b = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- assert.ok( b.elements[0] == 0 );
- assert.ok( b.elements[1] == 4 );
- assert.ok( b.elements[2] == 8 );
- assert.ok( b.elements[3] == 12 );
- assert.ok( b.elements[4] == 1 );
- assert.ok( b.elements[5] == 5 );
- assert.ok( b.elements[6] == 9 );
- assert.ok( b.elements[7] == 13 );
- assert.ok( b.elements[8] == 2 );
- assert.ok( b.elements[9] == 6 );
- assert.ok( b.elements[10] == 10 );
- assert.ok( b.elements[11] == 14 );
- assert.ok( b.elements[12] == 3 );
- assert.ok( b.elements[13] == 7 );
- assert.ok( b.elements[14] == 11 );
- assert.ok( b.elements[15] == 15 );
- var a = new THREE.Matrix4();
- assert.ok( ! matrixEquals4( a, b ), "Passed!" );
- b.identity();
- assert.ok( matrixEquals4( a, b ), "Passed!" );
- });
- QUnit.test( "multiplyMatrices" , function ( assert ) {
- // Reference:
- //
- // #!/usr/bin/env python
- // from __future__ import print_function
- // import numpy as np
- // print(
- // np.dot(
- // np.reshape([2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53], (4, 4)),
- // np.reshape([59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131], (4, 4))
- // )
- // )
- //
- // [[ 1585 1655 1787 1861]
- // [ 5318 5562 5980 6246]
- // [10514 11006 11840 12378]
- // [15894 16634 17888 18710]]
- var lhs = new THREE.Matrix4().set( 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53 );
- var rhs = new THREE.Matrix4().set( 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131 );
- var ans = new THREE.Matrix4();
- ans.multiplyMatrices(lhs, rhs);
- assert.ok( ans.elements[0] == 1585 );
- assert.ok( ans.elements[1] == 5318 );
- assert.ok( ans.elements[2] == 10514 );
- assert.ok( ans.elements[3] == 15894 );
- assert.ok( ans.elements[4] == 1655 );
- assert.ok( ans.elements[5] == 5562 );
- assert.ok( ans.elements[6] == 11006 );
- assert.ok( ans.elements[7] == 16634 );
- assert.ok( ans.elements[8] == 1787 );
- assert.ok( ans.elements[9] == 5980 );
- assert.ok( ans.elements[10] == 11840 );
- assert.ok( ans.elements[11] == 17888 );
- assert.ok( ans.elements[12] == 1861 );
- assert.ok( ans.elements[13] == 6246 );
- assert.ok( ans.elements[14] == 12378 );
- assert.ok( ans.elements[15] == 18710 );
- });
- QUnit.test( "multiplyScalar" , function( assert ) {
- var b = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- assert.ok( b.elements[0] == 0 );
- assert.ok( b.elements[1] == 4 );
- assert.ok( b.elements[2] == 8 );
- assert.ok( b.elements[3] == 12 );
- assert.ok( b.elements[4] == 1 );
- assert.ok( b.elements[5] == 5 );
- assert.ok( b.elements[6] == 9 );
- assert.ok( b.elements[7] == 13 );
- assert.ok( b.elements[8] == 2 );
- assert.ok( b.elements[9] == 6 );
- assert.ok( b.elements[10] == 10 );
- assert.ok( b.elements[11] == 14 );
- assert.ok( b.elements[12] == 3 );
- assert.ok( b.elements[13] == 7 );
- assert.ok( b.elements[14] == 11 );
- assert.ok( b.elements[15] == 15 );
- b.multiplyScalar( 2 );
- assert.ok( b.elements[0] == 0*2 );
- assert.ok( b.elements[1] == 4*2 );
- assert.ok( b.elements[2] == 8*2 );
- assert.ok( b.elements[3] == 12*2 );
- assert.ok( b.elements[4] == 1*2 );
- assert.ok( b.elements[5] == 5*2 );
- assert.ok( b.elements[6] == 9*2 );
- assert.ok( b.elements[7] == 13*2 );
- assert.ok( b.elements[8] == 2*2 );
- assert.ok( b.elements[9] == 6*2 );
- assert.ok( b.elements[10] == 10*2 );
- assert.ok( b.elements[11] == 14*2 );
- assert.ok( b.elements[12] == 3*2 );
- assert.ok( b.elements[13] == 7*2 );
- assert.ok( b.elements[14] == 11*2 );
- assert.ok( b.elements[15] == 15*2 );
- });
- QUnit.test( "determinant" , function( assert ) {
- var a = new THREE.Matrix4();
- assert.ok( a.determinant() == 1, "Passed!" );
- a.elements[0] = 2;
- assert.ok( a.determinant() == 2, "Passed!" );
- a.elements[0] = 0;
- assert.ok( a.determinant() == 0, "Passed!" );
- // calculated via http://www.euclideanspace.com/maths/algebra/matrix/functions/determinant/fourD/index.htm
- a.set( 2, 3, 4, 5, -1, -21, -3, -4, 6, 7, 8, 10, -8, -9, -10, -12 );
- assert.ok( a.determinant() == 76, "Passed!" );
- });
- QUnit.test( "getInverse" , function( assert ) {
- var identity = new THREE.Matrix4();
- var a = new THREE.Matrix4();
- var b = new THREE.Matrix4().set( 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
- var c = new THREE.Matrix4().set( 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 );
- assert.ok( ! matrixEquals4( a, b ), "Passed!" );
- b.getInverse( a, false );
- assert.ok( matrixEquals4( b, new THREE.Matrix4() ), "Passed!" );
- try {
- b.getInverse( c, true );
- assert.ok( false, "Passed!" ); // should never get here.
- }
- catch( err ) {
- assert.ok( true, "Passed!" );
- }
- var testMatrices = [
- new THREE.Matrix4().makeRotationX( 0.3 ),
- new THREE.Matrix4().makeRotationX( -0.3 ),
- new THREE.Matrix4().makeRotationY( 0.3 ),
- new THREE.Matrix4().makeRotationY( -0.3 ),
- new THREE.Matrix4().makeRotationZ( 0.3 ),
- new THREE.Matrix4().makeRotationZ( -0.3 ),
- new THREE.Matrix4().makeScale( 1, 2, 3 ),
- new THREE.Matrix4().makeScale( 1/8, 1/2, 1/3 ),
- new THREE.Matrix4().makePerspective( -1, 1, 1, -1, 1, 1000 ),
- new THREE.Matrix4().makePerspective( -16, 16, 9, -9, 0.1, 10000 ),
- new THREE.Matrix4().makeTranslation( 1, 2, 3 )
- ];
- for( var i = 0, il = testMatrices.length; i < il; i ++ ) {
- var m = testMatrices[i];
- var mInverse = new THREE.Matrix4().getInverse( m );
- var mSelfInverse = m.clone();
- mSelfInverse.getInverse( mSelfInverse );
- // self-inverse should the same as inverse
- assert.ok( matrixEquals4( mSelfInverse, mInverse ), "Passed!" );
- // the determinant of the inverse should be the reciprocal
- assert.ok( Math.abs( m.determinant() * mInverse.determinant() - 1 ) < 0.0001, "Passed!" );
- var mProduct = new THREE.Matrix4().multiplyMatrices( m, mInverse );
- // the determinant of the identity matrix is 1
- assert.ok( Math.abs( mProduct.determinant() - 1 ) < 0.0001, "Passed!" );
- assert.ok( matrixEquals4( mProduct, identity ), "Passed!" );
- }
- });
- QUnit.test( "makeBasis/extractBasis", function( assert ) {
- var identityBasis = [ new THREE.Vector3( 1, 0, 0 ), new THREE.Vector3( 0, 1, 0 ), new THREE.Vector3( 0, 0, 1 ) ];
- var a = new THREE.Matrix4().makeBasis( identityBasis[0], identityBasis[1], identityBasis[2] );
- var identity = new THREE.Matrix4();
- assert.ok( matrixEquals4( a, identity ), "Passed!" );
- var testBases = [ [ new THREE.Vector3( 0, 1, 0 ), new THREE.Vector3( -1, 0, 0 ), new THREE.Vector3( 0, 0, 1 ) ] ];
- for( var i = 0; i < testBases.length; i ++ ) {
- var testBasis = testBases[i];
- var b = new THREE.Matrix4().makeBasis( testBasis[0], testBasis[1], testBasis[2] );
- var outBasis = [ new THREE.Vector3(), new THREE.Vector3(), new THREE.Vector3() ];
- b.extractBasis( outBasis[0], outBasis[1], outBasis[2] );
- // check what goes in, is what comes out.
- for( var j = 0; j < outBasis.length; j ++ ) {
- assert.ok( outBasis[j].equals( testBasis[j] ), "Passed!" );
- }
- // get the basis out the hard war
- for( var j = 0; j < identityBasis.length; j ++ ) {
- outBasis[j].copy( identityBasis[j] );
- outBasis[j].applyMatrix4( b );
- }
- // did the multiply method of basis extraction work?
- for( var j = 0; j < outBasis.length; j ++ ) {
- assert.ok( outBasis[j].equals( testBasis[j] ), "Passed!" );
- }
- }
- });
- QUnit.test( "transpose" , function( assert ) {
- var a = new THREE.Matrix4();
- var b = a.clone().transpose();
- assert.ok( matrixEquals4( a, b ), "Passed!" );
- b = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- var c = b.clone().transpose();
- assert.ok( ! matrixEquals4( b, c ), "Passed!" );
- c.transpose();
- assert.ok( matrixEquals4( b, c ), "Passed!" );
- });
- QUnit.test( "clone" , function( assert ) {
- var a = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 );
- var b = a.clone();
- assert.ok( matrixEquals4( a, b ), "Passed!" );
- // ensure that it is a true copy
- a.elements[0] = 2;
- assert.ok( ! matrixEquals4( a, b ), "Passed!" );
- });
- QUnit.test( "compose/decompose", function( assert ) {
- var tValues = [
- new THREE.Vector3(),
- new THREE.Vector3( 3, 0, 0 ),
- new THREE.Vector3( 0, 4, 0 ),
- new THREE.Vector3( 0, 0, 5 ),
- new THREE.Vector3( -6, 0, 0 ),
- new THREE.Vector3( 0, -7, 0 ),
- new THREE.Vector3( 0, 0, -8 ),
- new THREE.Vector3( -2, 5, -9 ),
- new THREE.Vector3( -2, -5, -9 )
- ];
- var sValues = [
- new THREE.Vector3( 1, 1, 1 ),
- new THREE.Vector3( 2, 2, 2 ),
- new THREE.Vector3( 1, -1, 1 ),
- new THREE.Vector3( -1, 1, 1 ),
- new THREE.Vector3( 1, 1, -1 ),
- new THREE.Vector3( 2, -2, 1 ),
- new THREE.Vector3( -1, 2, -2 ),
- new THREE.Vector3( -1, -1, -1 ),
- new THREE.Vector3( -2, -2, -2 )
- ];
- var rValues = [
- new THREE.Quaternion(),
- new THREE.Quaternion().setFromEuler( new THREE.Euler( 1, 1, 0 ) ),
- new THREE.Quaternion().setFromEuler( new THREE.Euler( 1, -1, 1 ) ),
- new THREE.Quaternion( 0, 0.9238795292366128, 0, 0.38268342717215614 )
- ];
- for( var ti = 0; ti < tValues.length; ti ++ ) {
- for( var si = 0; si < sValues.length; si ++ ) {
- for( var ri = 0; ri < rValues.length; ri ++ ) {
- var t = tValues[ti];
- var s = sValues[si];
- var r = rValues[ri];
- var m = new THREE.Matrix4().compose( t, r, s );
- var t2 = new THREE.Vector3();
- var r2 = new THREE.Quaternion();
- var s2 = new THREE.Vector3();
- m.decompose( t2, r2, s2 );
- var m2 = new THREE.Matrix4().compose( t2, r2, s2 );
- var matrixIsSame = matrixEquals4( m, m2 );
- /* debug code
- if( ! matrixIsSame ) {
- console.log( t, s, r );
- console.log( t2, s2, r2 );
- console.log( m, m2 );
- }*/
- assert.ok( matrixEquals4( m, m2 ), "Passed!" );
- }
- }
- }
- });
- QUnit.test( "copyPosition", function ( assert ) {
- var a = new THREE.Matrix4().set( 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- var b = new THREE.Matrix4().set( 1, 2, 3, 0, 5, 6, 7, 0, 9, 10, 11, 0, 13, 14, 15, 16 );
- assert.notOk( matrixEquals4( a, b ), "a and b initially not equal" );
- b.copyPosition( a );
- assert.ok( matrixEquals4( a, b ), "a and b equal after copyPosition()" );
- } );
- QUnit.test( "makeRotationFromEuler/extractRotation", function ( assert ) {
- var testValues = [
- new THREE.Euler( 0, 0, 0, "XYZ" ),
- new THREE.Euler( 1, 0, 0, "XYZ" ),
- new THREE.Euler( 0, 1, 0, "ZYX" ),
- new THREE.Euler( 0, 0, 0.5, "YZX" ),
- new THREE.Euler( 0, 0, - 0.5, "YZX" )
- ];
- for ( var i = 0; i < testValues.length; i ++ ) {
- var v = testValues[ i ];
- var m = new THREE.Matrix4().makeRotationFromEuler( v );
- var v2 = new THREE.Euler().setFromRotationMatrix( m, v.order );
- var m2 = new THREE.Matrix4().makeRotationFromEuler( v2 );
- assert.ok( matrixEquals4( m, m2, eps ), "makeRotationFromEuler #" + i + ": original and Euler-derived matrices are equal" );
- assert.ok( eulerEquals( v, v2, eps ), "makeRotationFromEuler #" + i + ": original and matrix-derived Eulers are equal" );
- var m3 = new THREE.Matrix4().extractRotation( m2 );
- var v3 = new THREE.Euler().setFromRotationMatrix( m3, v.order );
- assert.ok( matrixEquals4( m, m3, eps ), "extractRotation #" + i + ": original and extracted matrices are equal" );
- assert.ok( eulerEquals( v, v3, eps ), "extractRotation #" + i + ": original and extracted Eulers are equal" );
- }
- } );
- QUnit.test( "applyToBufferAttribute", function ( assert ) {
- var a = new THREE.Matrix4().set( 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- var attr = new THREE.Float32BufferAttribute( [ 1, 2, 1, 3, 0, 3 ], 3 );
- var expected = new THREE.Float32BufferAttribute( [
- 0.1666666716337204, 0.4444444477558136, 0.7222222089767456,
- 0.1599999964237213, 0.4399999976158142, 0.7200000286102295
- ], 3 );
- var applied = a.applyToBufferAttribute( attr );
- assert.strictEqual( expected.count, applied.count, "Applied buffer and expected buffer have the same number of entries" );
- for ( var i = 0, l = expected.count; i < l; i ++ ) {
- assert.ok( Math.abs( applied.getX( i ) - expected.getX( i ) ) <= eps, "Check x" );
- assert.ok( Math.abs( applied.getY( i ) - expected.getY( i ) ) <= eps, "Check y" );
- assert.ok( Math.abs( applied.getZ( i ) - expected.getZ( i ) ) <= eps, "Check z" );
- }
- } );
- QUnit.test( "equals", function ( assert ) {
- var a = new THREE.Matrix4().set( 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- var b = new THREE.Matrix4().set( 0, - 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- assert.notOk( a.equals( b ), "Check that a does not equal b" );
- assert.notOk( b.equals( a ), "Check that b does not equal a" );
- a.copy( b );
- assert.ok( a.equals( b ), "Check that a equals b after copy()" );
- assert.ok( b.equals( a ), "Check that b equals a after copy()" );
- } );
- QUnit.test( "toArray", function ( assert ) {
- var a = new THREE.Matrix4().set( 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- var noOffset = [ 1, 5, 9, 13, 2, 6, 10, 14, 3, 7, 11, 15, 4, 8, 12, 16 ];
- var withOffset = [ undefined, 1, 5, 9, 13, 2, 6, 10, 14, 3, 7, 11, 15, 4, 8, 12, 16 ];
- var array = a.toArray();
- assert.deepEqual( array, noOffset, "No array, no offset" );
- array = [];
- a.toArray( array );
- assert.deepEqual( array, noOffset, "With array, no offset" );
- array = [];
- a.toArray( array, 1 );
- assert.deepEqual( array, withOffset, "With array, with offset" );
- } );
- QUnit.test( "getMaxScaleOnAxis", function ( assert ) {
- var a = new THREE.Matrix4().set( 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 );
- var expected = Math.sqrt( 3 * 3 + 7 * 7 + 11 * 11 );
- assert.ok( Math.abs( a.getMaxScaleOnAxis() - expected ) <= eps, "Check result" );
- } );
- QUnit.test( "makeOrthographic", function ( assert ) {
- var a = new THREE.Matrix4().makeOrthographic( - 1, 1, - 1, 1, 1, 100 );
- var expected = new THREE.Matrix4().set(
- 1, 0, 0, 0,
- 0, - 1, 0, 0,
- 0, 0, - 2 / 99, - 101 / 99,
- 0, 0, 0, 1
- );
- assert.ok( matrixEquals4( a, expected ), "Check result" );
- } );
- QUnit.test( "makeRotationAxis", function ( assert ) {
- var axis = new THREE.Vector3( 1.5, 0.0, 1.0 ).normalize();
- var radians = THREE.Math.degToRad( 45 );
- var a = new THREE.Matrix4().makeRotationAxis( axis, radians );
- var expected = new THREE.Matrix4().set(
- 0.9098790095958609, - 0.39223227027636803, 0.13518148560620882, 0,
- 0.39223227027636803, 0.7071067811865476, - 0.588348405414552, 0,
- 0.13518148560620882, 0.588348405414552, 0.7972277715906868, 0,
- 0, 0, 0, 1
- );
- assert.ok( matrixEquals4( a, expected ), "Check numeric result" );
- } );
- QUnit.test( "lookAt", function ( assert ) {
- var a = new THREE.Matrix4();
- var expected = new THREE.Matrix4().identity();
- var eye = new THREE.Vector3( 0, 0, 0 );
- var target = new THREE.Vector3( 0, 1, - 1 );
- var up = new THREE.Vector3( 0, 1, 0 );
- a.lookAt( eye, target, up );
- var rotation = new THREE.Euler().setFromRotationMatrix( a );
- assert.numEqual( rotation.x * ( 180 / Math.PI ), 45, "Check the rotation" );
- // eye and target are in the same position
- eye.copy( target );
- a.lookAt( eye, target, up );
- assert.ok( matrixEquals4( a, expected ), "Check the result for eye == target" );
- // up and z are parallel
- eye.set( 0, 1, 0 );
- target.set( 0, 0, 0 );
- a.lookAt( eye, target, up );
- expected.set(
- 1, 0, 0, 0,
- 0, 0.0001, 1, 0,
- 0, - 1, 0.0001, 0,
- 0, 0, 0, 1
- );
- assert.ok( matrixEquals4( a, expected ), "Check the result for when up and z are parallel" );
- } );
|