Box2.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. /**
  2. * @author bhouston / http://exocortex.com
  3. */
  4. var x = 2;
  5. var y = 3;
  6. var z = 4;
  7. var w = 5;
  8. var negInf = new THREE.Vector3( -Infinity, -Infinity );
  9. var posInf = new THREE.Vector3( Infinity, Infinity );
  10. var zero = new THREE.Vector3();
  11. var one = new THREE.Vector3( 1, 1, 1 );
  12. module( "Box2" );
  13. test( "constructor", function() {
  14. var a = new THREE.Box2();
  15. ok( a.min.equals( posInf ), "Passed!" );
  16. ok( a.max.equals( negInf ), "Passed!" );
  17. a = new THREE.Box2( zero );
  18. ok( a.min.equals( zero ), "Passed!" );
  19. ok( a.max.equals( zero ), "Passed!" );
  20. a = new THREE.Box2( zero, one );
  21. ok( a.min.equals( zero ), "Passed!" );
  22. ok( a.max.equals( one ), "Passed!" );
  23. });
  24. test( "copy", function() {
  25. var a = new THREE.Box2( zero, one );
  26. var b = new THREE.Box2().copy( a );
  27. ok( b.min.equals( zero ), "Passed!" );
  28. ok( b.max.equals( one ), "Passed!" );
  29. // ensure that it is a true copy
  30. a.min = zero;
  31. a.max = one;
  32. ok( b.min.equals( zero ), "Passed!" );
  33. ok( b.max.equals( one ), "Passed!" );
  34. });
  35. test( "set", function() {
  36. var a = new THREE.Box2();
  37. a.set( zero, one )
  38. ok( a.min.equals( zero ), "Passed!" );
  39. ok( a.max.equals( one ), "Passed!" );
  40. });
  41. test( "empty/makeEmpty", function() {
  42. var a = new THREE.Box2();
  43. ok( a.empty(), "Passed!" );
  44. var a = new THREE.Box2( zero, one );
  45. ok( ! a.empty(), "Passed!" );
  46. a.makeEmpty();
  47. ok( a.empty(), "Passed!" );
  48. });
  49. test( "volume", function() {
  50. var a = new THREE.Box2( zero, one );
  51. ok( a.volume() == 1, "Passed!" );
  52. });
  53. test( "center", function() {
  54. var a = new THREE.Box2( zero );
  55. ok( a.center().equals( zero ), "Passed!" );
  56. a = new THREE.Box2( zero, one );
  57. var midpoint = one.clone().multiplyScalar( 0.5 );
  58. ok( a.center().equals( midpoint ), "Passed!" );
  59. });
  60. test( "size", function() {
  61. var a = new THREE.Box2( zero );
  62. ok( a.size().equals( zero ), "Passed!" );
  63. a = new THREE.Box2( zero, one );
  64. ok( a.size().equals( one ), "Passed!" );
  65. });
  66. test( "expandByPoint", function() {
  67. var a = new THREE.Box2( zero );
  68. a.expandByPoint( zero );
  69. ok( a.size().equals( zero ), "Passed!" );
  70. a.expandByPoint( one );
  71. ok( a.size().equals( one ), "Passed!" );
  72. a.expandByPoint( one.clone().negate() );
  73. ok( a.size().equals( one.clone().multiplyScalar( 2 ) ), "Passed!" );
  74. ok( a.center().equals( zero ), "Passed!" );
  75. });
  76. test( "expandByVector", function() {
  77. var a = new THREE.Box2( zero );
  78. a.expandByVector( zero );
  79. ok( a.size().equals( zero ), "Passed!" );
  80. a.expandByVector( one );
  81. ok( a.size().equals( one.clone().multiplyScalar( 2 ) ), "Passed!" );
  82. ok( a.center().equals( zero ), "Passed!" );
  83. });
  84. test( "expandByScalar", function() {
  85. var a = new THREE.Box2( zero );
  86. a.expandByScalar( 0 );
  87. ok( a.size().equals( zero ), "Passed!" );
  88. a.expandByScalar( 1 );
  89. ok( a.size().equals( oneone.clone().multiplyScalar( 2 ) ), "Passed!" );
  90. ok( a.center().equals( zero ), "Passed!" );
  91. });
  92. test( "containsPoint", function() {
  93. var a = new THREE.Box2( zero );
  94. ok( a.containsPoint( zero ), "Passed!" );
  95. ok( ! a.containsPoint( one ), "Passed!" );
  96. a.expandByScalar( 1 );
  97. ok( a.containsPoint( zero ), "Passed!" );
  98. ok( a.containsPoint( one ), "Passed!" );
  99. ok( a.containsPoint( one.clone().negate() ), "Passed!" );
  100. });
  101. test( "containsBox", function() {
  102. var a = new THREE.Box2( zero );
  103. var b = new THREE.Box2( zero, one );
  104. var c = new THREE.Box2( one.clone().negate(), one );
  105. ok( a.containsBox( a ), "Passed!" );
  106. ok( ! a.containsBox( b ), "Passed!" );
  107. ok( ! a.containsBox( c ), "Passed!" );
  108. ok( b.containsBox( a ), "Passed!" );
  109. ok( c.containsBox( a ), "Passed!" );
  110. ok( ! b.containsBox( c ), "Passed!" );
  111. });
  112. test( "getParameter", function() {
  113. var a = new THREE.Box2( zero, one );
  114. var b = new THREE.Box2( one.clone().negate(), one );
  115. ok( a.getParameter( new THREE.Vector2( 0, 0 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  116. ok( a.getParameter( new THREE.Vector2( 1, 1 ) ).equals( new THREE.Vector2( 1, 1 ) ), "Passed!" );
  117. ok( b.getParameter( new THREE.Vector2( -1, -1 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  118. ok( b.getParameter( new THREE.Vector2( 0, 0 ) ).equals( new THREE.Vector2( 0.5, 0.5 ) ), "Passed!" );
  119. ok( b.getParameter( new THREE.Vector2( 1, 1 ) ).equals( new THREE.Vector2( 1, 1 ) ), "Passed!" );
  120. });
  121. test( "clampPoint", function() {
  122. var a = new THREE.Box2( zero, one );
  123. var b = new THREE.Box2( one.clone().negate(), one );
  124. ok( a.clampPoint( new THREE.Vector2( 0, 0 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  125. ok( a.clampPoint( new THREE.Vector2( 1, 1 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  126. ok( a.clampPoint( new THREE.Vector2( -1, -1 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  127. ok( b.clampPoint( new THREE.Vector2( 2, 2 ) ).equals( new THREE.Vector2( 1, 1 ) ), "Passed!" );
  128. ok( b.clampPoint( new THREE.Vector2( 1, 1 ) ).equals( new THREE.Vector2( 1, 1 ) ), "Passed!" );
  129. ok( b.clampPoint( new THREE.Vector2( 0, 0 ) ).equals( new THREE.Vector2( 0, 0 ) ), "Passed!" );
  130. ok( b.clampPoint( new THREE.Vector2( -1, -1 ) ).equals( new THREE.Vector2( -1, -1 ) ), "Passed!" );
  131. ok( b.clampPoint( new THREE.Vector2( -2, -2 ) ).equals( new THREE.Vector2( -1, -1 ) ), "Passed!" );
  132. });
  133. test( "distanceToPoint", function() {
  134. var a = new THREE.Box2( zero, one );
  135. var b = new THREE.Box2( one.clone().negate(), one );
  136. ok( a.distanceToPoint( new THREE.Vector2( 0, 0 ) ) == 0, "Passed!" );
  137. ok( a.distanceToPoint( new THREE.Vector2( 1, 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  138. ok( a.distanceToPoint( new THREE.Vector2( -1, -1 ) ) == Math.sqrt( 2 ), "Passed!" );
  139. ok( b.distanceToPoint( new THREE.Vector2( 2, 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  140. ok( b.distanceToPoint( new THREE.Vector2( 1, 1 ) ) == 0, "Passed!" );
  141. ok( b.distanceToPoint( new THREE.Vector2( 0, 0 ) ) == 0, "Passed!" );
  142. ok( b.distanceToPoint( new THREE.Vector2( -1, -1 ) ) == 0, "Passed!" );
  143. ok( b.distanceToPoint( new THREE.Vector2( -2, -2 ) ) == Math.sqrt( 2 ), "Passed!" );
  144. });
  145. test( "distanceToPoint", function() {
  146. var a = new THREE.Box2( zero, one );
  147. var b = new THREE.Box2( one.clone().negate(), one );
  148. ok( a.distanceToPoint( new THREE.Vector2( 0, 0 ) ) == 0, "Passed!" );
  149. ok( a.distanceToPoint( new THREE.Vector2( 1, 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  150. ok( a.distanceToPoint( new THREE.Vector2( -1, -1 ) ) == Math.sqrt( 2 ), "Passed!" );
  151. ok( b.distanceToPoint( new THREE.Vector2( 2, 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  152. ok( b.distanceToPoint( new THREE.Vector2( 1, 1 ) ) == 0, "Passed!" );
  153. ok( b.distanceToPoint( new THREE.Vector2( 0, 0 ) ) == 0, "Passed!" );
  154. ok( b.distanceToPoint( new THREE.Vector2( -1, -1 ) ) == 0, "Passed!" );
  155. ok( b.distanceToPoint( new THREE.Vector2( -2, -2 ) ) == Math.sqrt( 2 ), "Passed!" );
  156. });
  157. test( "isIntersection", function() {
  158. var a = new THREE.Box2( zero );
  159. var b = new THREE.Box2( zero, one );
  160. var c = new THREE.Box2( one.clone().negate(), one );
  161. ok( a.isIntersection( a ), "Passed!" );
  162. ok( a.isIntersection( b ), "Passed!" );
  163. ok( a.isIntersection( c ), "Passed!" );
  164. ok( b.isIntersection( a ), "Passed!" );
  165. ok( c.isIntersection( a ), "Passed!" );
  166. ok( b.isIntersection( c ), "Passed!" );
  167. b.translate( one.clone().translate( new THREE.Vector2( 2, 2 ) ));
  168. ok( ! a.isIntersection( b ), "Passed!" );
  169. ok( ! b.isIntersection( a ), "Passed!" );
  170. ok( ! c.isIntersection( a ), "Passed!" );
  171. ok( ! b.isIntersection( c ), "Passed!" );
  172. });
  173. test( "intersect", function() {
  174. var a = new THREE.Box2( zero );
  175. var b = new THREE.Box2( zero, one );
  176. var c = new THREE.Box2( one.clone().negate(), one );
  177. ok( a.clone().intersect( a ).equals( a ), "Passed!" );
  178. ok( a.clone().intersect( b ).equals( a ), "Passed!" );
  179. ok( b.clone().intersect( b ).equals( b ), "Passed!" );
  180. ok( a.clone().intersect( c ).equals( a ), "Passed!" );
  181. ok( b.clone().intersect( c ).equals( b ), "Passed!" );
  182. ok( c.clone().intersect( c ).equals( c ), "Passed!" );
  183. });
  184. test( "union", function() {
  185. var a = new THREE.Box2( zero );
  186. var b = new THREE.Box2( zero, one );
  187. var c = new THREE.Box2( one.clone().negate(), one );
  188. ok( a.clone().union( a ).equals( a ), "Passed!" );
  189. ok( a.clone().union( b ).equals( b ), "Passed!" );
  190. ok( a.clone().union( c ).equals( c ), "Passed!" );
  191. ok( b.clone().union( c ).equals( c ), "Passed!" );
  192. });
  193. test( "translate", function() {
  194. var a = new THREE.Box2( zero );
  195. var b = new THREE.Box2( zero, one );
  196. var c = new THREE.Box2( one.clone().negate(), one );
  197. var d = new THREE.Box2( one.clone().negate(), zero );
  198. ok( a.clone().translate( one ).equals( new THREE.Box2( one, one ) ), "Passed!" );
  199. ok( a.clone().translate( one ).translate( one.clone().negate() ).equals( a ), "Passed!" );
  200. ok( d.clone().translate( one ).equals( b ), "Passed!" );
  201. ok( b.clone().translate( one.clone().negate() ).equals( d ), "Passed!" );
  202. });
  203. test( "scale", function() {
  204. var a = new THREE.Box2( zero );
  205. var b = new THREE.Box2( zero, one );
  206. var c = new THREE.Box2( one.clone().negate(), one );
  207. var d = new THREE.Box2( one.clone().negate(), zero );
  208. ok( b.clone().scale( 0 ).equals( a ), "Passed!" );
  209. ok( b.clone().scale( 2 ).equals( new THREE.Box2( zero, new THREE.Vector2( 2, 2 ) ) ), "Passed!" );
  210. ok( d.clone().scale( 2 ).equals( new THREE.Box2( new THREE.Vector2( 2, 2 ).negate(), zero ) ), "Passed!" );
  211. });
粤ICP备19079148号