Vector2.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. /**
  2. * @author bhouston / http://exocortex.com
  3. */
  4. QUnit.module( "Vector2" );
  5. QUnit.test( "constructor" , function( assert ) {
  6. var a = new THREE.Vector2();
  7. assert.ok( a.x == 0, "Passed!" );
  8. assert.ok( a.y == 0, "Passed!" );
  9. a = new THREE.Vector2( x, y );
  10. assert.ok( a.x === x, "Passed!" );
  11. assert.ok( a.y === y, "Passed!" );
  12. });
  13. QUnit.test( "copy" , function( assert ) {
  14. var a = new THREE.Vector2( x, y );
  15. var b = new THREE.Vector2().copy( a );
  16. assert.ok( b.x == x, "Passed!" );
  17. assert.ok( b.y == y, "Passed!" );
  18. // ensure that it is a true copy
  19. a.x = 0;
  20. a.y = -1;
  21. assert.ok( b.x == x, "Passed!" );
  22. assert.ok( b.y == y, "Passed!" );
  23. });
  24. QUnit.test( "set" , function( assert ) {
  25. var a = new THREE.Vector2();
  26. assert.ok( a.x == 0, "Passed!" );
  27. assert.ok( a.y == 0, "Passed!" );
  28. a.set( x, y );
  29. assert.ok( a.x == x, "Passed!" );
  30. assert.ok( a.y == y, "Passed!" );
  31. });
  32. QUnit.test( "setX,setY", function( assert ) {
  33. var a = new THREE.Vector2();
  34. assert.ok( a.x == 0, "Passed!" );
  35. assert.ok( a.y == 0, "Passed!" );
  36. a.setX( x );
  37. a.setY( y );
  38. assert.ok( a.x == x, "Passed!" );
  39. assert.ok( a.y == y, "Passed!" );
  40. });
  41. QUnit.test( "setComponent,getComponent", function( assert ) {
  42. var a = new THREE.Vector2();
  43. assert.ok( a.x == 0, "Passed!" );
  44. assert.ok( a.y == 0, "Passed!" );
  45. a.setComponent( 0, 1 );
  46. a.setComponent( 1, 2 );
  47. assert.ok( a.getComponent( 0 ) == 1, "Passed!" );
  48. assert.ok( a.getComponent( 1 ) == 2, "Passed!" );
  49. });
  50. QUnit.test( "add" , function( assert ) {
  51. var a = new THREE.Vector2( x, y );
  52. var b = new THREE.Vector2( -x, -y );
  53. a.add( b );
  54. assert.ok( a.x == 0, "Passed!" );
  55. assert.ok( a.y == 0, "Passed!" );
  56. var c = new THREE.Vector2().addVectors( b, b );
  57. assert.ok( c.x == -2*x, "Passed!" );
  58. assert.ok( c.y == -2*y, "Passed!" );
  59. });
  60. QUnit.test( "sub" , function( assert ) {
  61. var a = new THREE.Vector2( x, y );
  62. var b = new THREE.Vector2( -x, -y );
  63. a.sub( b );
  64. assert.ok( a.x == 2*x, "Passed!" );
  65. assert.ok( a.y == 2*y, "Passed!" );
  66. var c = new THREE.Vector2().subVectors( a, a );
  67. assert.ok( c.x == 0, "Passed!" );
  68. assert.ok( c.y == 0, "Passed!" );
  69. });
  70. QUnit.test( "multiply/divide", function( assert ) {
  71. var a = new THREE.Vector2( x, y );
  72. var b = new THREE.Vector2( -x, -y );
  73. a.multiplyScalar( -2 );
  74. assert.ok( a.x == x*-2, "Passed!" );
  75. assert.ok( a.y == y*-2, "Passed!" );
  76. b.multiplyScalar( -2 );
  77. assert.ok( b.x == 2*x, "Passed!" );
  78. assert.ok( b.y == 2*y, "Passed!" );
  79. a.divideScalar( -2 );
  80. assert.ok( a.x == x, "Passed!" );
  81. assert.ok( a.y == y, "Passed!" );
  82. b.divideScalar( -2 );
  83. assert.ok( b.x == -x, "Passed!" );
  84. assert.ok( b.y == -y, "Passed!" );
  85. });
  86. QUnit.test( "min/max/clamp", function( assert ) {
  87. var a = new THREE.Vector2( x, y );
  88. var b = new THREE.Vector2( -x, -y );
  89. var c = new THREE.Vector2();
  90. c.copy( a ).min( b );
  91. assert.ok( c.x == -x, "Passed!" );
  92. assert.ok( c.y == -y, "Passed!" );
  93. c.copy( a ).max( b );
  94. assert.ok( c.x == x, "Passed!" );
  95. assert.ok( c.y == y, "Passed!" );
  96. c.set( -2*x, 2*y );
  97. c.clamp( b, a );
  98. assert.ok( c.x == -x, "Passed!" );
  99. assert.ok( c.y == y, "Passed!" );
  100. c.set(-2*x, 2*x);
  101. c.clampScalar( -x, x );
  102. assert.equal( c.x, -x, "scalar clamp x" );
  103. assert.equal( c.y, x, "scalar clamp y" );
  104. });
  105. QUnit.test( "rounding" , function( assert ) {
  106. assert.deepEqual( new THREE.Vector2( -0.1, 0.1 ).floor(), new THREE.Vector2( -1, 0 ), "floor .1" );
  107. assert.deepEqual( new THREE.Vector2( -0.5, 0.5 ).floor(), new THREE.Vector2( -1, 0 ), "floor .5" );
  108. assert.deepEqual( new THREE.Vector2( -0.9, 0.9 ).floor(), new THREE.Vector2( -1, 0 ), "floor .9" );
  109. assert.deepEqual( new THREE.Vector2( -0.1, 0.1 ).ceil(), new THREE.Vector2( 0, 1 ), "ceil .1" );
  110. assert.deepEqual( new THREE.Vector2( -0.5, 0.5 ).ceil(), new THREE.Vector2( 0, 1 ), "ceil .5" );
  111. assert.deepEqual( new THREE.Vector2( -0.9, 0.9 ).ceil(), new THREE.Vector2( 0, 1 ), "ceil .9" );
  112. assert.deepEqual( new THREE.Vector2( -0.1, 0.1 ).round(), new THREE.Vector2( 0, 0 ), "round .1" );
  113. assert.deepEqual( new THREE.Vector2( -0.5, 0.5 ).round(), new THREE.Vector2( 0, 1 ), "round .5" );
  114. assert.deepEqual( new THREE.Vector2( -0.9, 0.9 ).round(), new THREE.Vector2( -1, 1 ), "round .9" );
  115. assert.deepEqual( new THREE.Vector2( -0.1, 0.1 ).roundToZero(), new THREE.Vector2( 0, 0 ), "roundToZero .1" );
  116. assert.deepEqual( new THREE.Vector2( -0.5, 0.5 ).roundToZero(), new THREE.Vector2( 0, 0 ), "roundToZero .5" );
  117. assert.deepEqual( new THREE.Vector2( -0.9, 0.9 ).roundToZero(), new THREE.Vector2( 0, 0 ), "roundToZero .9" );
  118. assert.deepEqual( new THREE.Vector2( -1.1, 1.1 ).roundToZero(), new THREE.Vector2( -1, 1 ), "roundToZero 1.1" );
  119. assert.deepEqual( new THREE.Vector2( -1.5, 1.5 ).roundToZero(), new THREE.Vector2( -1, 1 ), "roundToZero 1.5" );
  120. assert.deepEqual( new THREE.Vector2( -1.9, 1.9 ).roundToZero(), new THREE.Vector2( -1, 1 ), "roundToZero 1.9" );
  121. });
  122. QUnit.test( "negate" , function( assert ) {
  123. var a = new THREE.Vector2( x, y );
  124. a.negate();
  125. assert.ok( a.x == -x, "Passed!" );
  126. assert.ok( a.y == -y, "Passed!" );
  127. });
  128. QUnit.test( "dot" , function( assert ) {
  129. var a = new THREE.Vector2( x, y );
  130. var b = new THREE.Vector2( -x, -y );
  131. var c = new THREE.Vector2();
  132. var result = a.dot( b );
  133. assert.ok( result == (-x*x-y*y), "Passed!" );
  134. result = a.dot( c );
  135. assert.ok( result == 0, "Passed!" );
  136. });
  137. QUnit.test( "length/lengthSq", function( assert ) {
  138. var a = new THREE.Vector2( x, 0 );
  139. var b = new THREE.Vector2( 0, -y );
  140. var c = new THREE.Vector2();
  141. assert.ok( a.length() == x, "Passed!" );
  142. assert.ok( a.lengthSq() == x*x, "Passed!" );
  143. assert.ok( b.length() == y, "Passed!" );
  144. assert.ok( b.lengthSq() == y*y, "Passed!" );
  145. assert.ok( c.length() == 0, "Passed!" );
  146. assert.ok( c.lengthSq() == 0, "Passed!" );
  147. a.set( x, y );
  148. assert.ok( a.length() == Math.sqrt( x*x + y*y ), "Passed!" );
  149. assert.ok( a.lengthSq() == ( x*x + y*y ), "Passed!" );
  150. });
  151. QUnit.test( "normalize" , function( assert ) {
  152. var a = new THREE.Vector2( x, 0 );
  153. var b = new THREE.Vector2( 0, -y );
  154. var c = new THREE.Vector2();
  155. a.normalize();
  156. assert.ok( a.length() == 1, "Passed!" );
  157. assert.ok( a.x == 1, "Passed!" );
  158. b.normalize();
  159. assert.ok( b.length() == 1, "Passed!" );
  160. assert.ok( b.y == -1, "Passed!" );
  161. });
  162. QUnit.test( "distanceTo/distanceToSquared", function( assert ) {
  163. var a = new THREE.Vector2( x, 0 );
  164. var b = new THREE.Vector2( 0, -y );
  165. var c = new THREE.Vector2();
  166. assert.ok( a.distanceTo( c ) == x, "Passed!" );
  167. assert.ok( a.distanceToSquared( c ) == x*x, "Passed!" );
  168. assert.ok( b.distanceTo( c ) == y, "Passed!" );
  169. assert.ok( b.distanceToSquared( c ) == y*y, "Passed!" );
  170. });
  171. QUnit.test( "setLength" , function( assert ) {
  172. var a = new THREE.Vector2( x, 0 );
  173. assert.ok( a.length() == x, "Passed!" );
  174. a.setLength( y );
  175. assert.ok( a.length() == y, "Passed!" );
  176. a = new THREE.Vector2( 0, 0 );
  177. assert.ok( a.length() == 0, "Passed!" );
  178. a.setLength( y );
  179. assert.ok( isNaN( a.length() ), "Passed!" );
  180. });
  181. QUnit.test( "lerp/clone", function( assert ) {
  182. var a = new THREE.Vector2( x, 0 );
  183. var b = new THREE.Vector2( 0, -y );
  184. assert.ok( a.lerp( a, 0 ).equals( a.lerp( a, 0.5 ) ), "Passed!" );
  185. assert.ok( a.lerp( a, 0 ).equals( a.lerp( a, 1 ) ), "Passed!" );
  186. assert.ok( a.clone().lerp( b, 0 ).equals( a ), "Passed!" );
  187. assert.ok( a.clone().lerp( b, 0.5 ).x == x*0.5, "Passed!" );
  188. assert.ok( a.clone().lerp( b, 0.5 ).y == -y*0.5, "Passed!" );
  189. assert.ok( a.clone().lerp( b, 1 ).equals( b ), "Passed!" );
  190. });
  191. QUnit.test( "equals" , function( assert ) {
  192. var a = new THREE.Vector2( x, 0 );
  193. var b = new THREE.Vector2( 0, -y );
  194. assert.ok( a.x != b.x, "Passed!" );
  195. assert.ok( a.y != b.y, "Passed!" );
  196. assert.ok( ! a.equals( b ), "Passed!" );
  197. assert.ok( ! b.equals( a ), "Passed!" );
  198. a.copy( b );
  199. assert.ok( a.x == b.x, "Passed!" );
  200. assert.ok( a.y == b.y, "Passed!" );
  201. assert.ok( a.equals( b ), "Passed!" );
  202. assert.ok( b.equals( a ), "Passed!" );
  203. });
粤ICP备19079148号