Box3.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. /**
  2. * @author bhouston / http://exocortex.com
  3. */
  4. QUnit.module( "Box3" );
  5. QUnit.test( "constructor" , function( assert ) {
  6. var a = new THREE.Box3();
  7. assert.ok( a.min.equals( posInf3 ), "Passed!" );
  8. assert.ok( a.max.equals( negInf3 ), "Passed!" );
  9. a = new THREE.Box3( zero3.clone(), zero3.clone() );
  10. assert.ok( a.min.equals( zero3 ), "Passed!" );
  11. assert.ok( a.max.equals( zero3 ), "Passed!" );
  12. a = new THREE.Box3( zero3.clone(), one3.clone() );
  13. assert.ok( a.min.equals( zero3 ), "Passed!" );
  14. assert.ok( a.max.equals( one3 ), "Passed!" );
  15. });
  16. QUnit.test( "copy" , function( assert ) {
  17. var a = new THREE.Box3( zero3.clone(), one3.clone() );
  18. var b = new THREE.Box3().copy( a );
  19. assert.ok( b.min.equals( zero3 ), "Passed!" );
  20. assert.ok( b.max.equals( one3 ), "Passed!" );
  21. // ensure that it is a true copy
  22. a.min = zero3;
  23. a.max = one3;
  24. assert.ok( b.min.equals( zero3 ), "Passed!" );
  25. assert.ok( b.max.equals( one3 ), "Passed!" );
  26. });
  27. QUnit.test( "set" , function( assert ) {
  28. var a = new THREE.Box3();
  29. a.set( zero3, one3 );
  30. assert.ok( a.min.equals( zero3 ), "Passed!" );
  31. assert.ok( a.max.equals( one3 ), "Passed!" );
  32. });
  33. QUnit.test( "setFromPoints" , function( assert ) {
  34. var a = new THREE.Box3();
  35. a.setFromPoints( [ zero3, one3, two3 ] );
  36. assert.ok( a.min.equals( zero3 ), "Passed!" );
  37. assert.ok( a.max.equals( two3 ), "Passed!" );
  38. a.setFromPoints( [ one3 ] );
  39. assert.ok( a.min.equals( one3 ), "Passed!" );
  40. assert.ok( a.max.equals( one3 ), "Passed!" );
  41. a.setFromPoints( [] );
  42. assert.ok( a.isEmpty(), "Passed!" );
  43. });
  44. QUnit.test( "empty/makeEmpty", function( assert ) {
  45. var a = new THREE.Box3();
  46. assert.ok( a.isEmpty(), "Passed!" );
  47. var a = new THREE.Box3( zero3.clone(), one3.clone() );
  48. assert.ok( ! a.isEmpty(), "Passed!" );
  49. a.makeEmpty();
  50. assert.ok( a.isEmpty(), "Passed!" );
  51. });
  52. QUnit.test( "getCenter" , function( assert ) {
  53. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  54. assert.ok( a.getCenter().equals( zero3 ), "Passed!" );
  55. a = new THREE.Box3( zero3.clone(), one3.clone() );
  56. var midpoint = one3.clone().multiplyScalar( 0.5 );
  57. assert.ok( a.getCenter().equals( midpoint ), "Passed!" );
  58. });
  59. QUnit.test( "getSize" , function( assert ) {
  60. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  61. assert.ok( a.getSize().equals( zero3 ), "Passed!" );
  62. a = new THREE.Box3( zero3.clone(), one3.clone() );
  63. assert.ok( a.getSize().equals( one3 ), "Passed!" );
  64. });
  65. QUnit.test( "expandByPoint" , function( assert ) {
  66. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  67. a.expandByPoint( zero3 );
  68. assert.ok( a.getSize().equals( zero3 ), "Passed!" );
  69. a.expandByPoint( one3 );
  70. assert.ok( a.getSize().equals( one3 ), "Passed!" );
  71. a.expandByPoint( one3.clone().negate() );
  72. assert.ok( a.getSize().equals( one3.clone().multiplyScalar( 2 ) ), "Passed!" );
  73. assert.ok( a.getCenter().equals( zero3 ), "Passed!" );
  74. });
  75. QUnit.test( "expandByVector" , function( assert ) {
  76. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  77. a.expandByVector( zero3 );
  78. assert.ok( a.getSize().equals( zero3 ), "Passed!" );
  79. a.expandByVector( one3 );
  80. assert.ok( a.getSize().equals( one3.clone().multiplyScalar( 2 ) ), "Passed!" );
  81. assert.ok( a.getCenter().equals( zero3 ), "Passed!" );
  82. });
  83. QUnit.test( "expandByScalar" , function( assert ) {
  84. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  85. a.expandByScalar( 0 );
  86. assert.ok( a.getSize().equals( zero3 ), "Passed!" );
  87. a.expandByScalar( 1 );
  88. assert.ok( a.getSize().equals( one3.clone().multiplyScalar( 2 ) ), "Passed!" );
  89. assert.ok( a.getCenter().equals( zero3 ), "Passed!" );
  90. });
  91. QUnit.test( "containsPoint" , function( assert ) {
  92. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  93. assert.ok( a.containsPoint( zero3 ), "Passed!" );
  94. assert.ok( ! a.containsPoint( one3 ), "Passed!" );
  95. a.expandByScalar( 1 );
  96. assert.ok( a.containsPoint( zero3 ), "Passed!" );
  97. assert.ok( a.containsPoint( one3 ), "Passed!" );
  98. assert.ok( a.containsPoint( one3.clone().negate() ), "Passed!" );
  99. });
  100. QUnit.test( "containsBox" , function( assert ) {
  101. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  102. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  103. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  104. assert.ok( a.containsBox( a ), "Passed!" );
  105. assert.ok( ! a.containsBox( b ), "Passed!" );
  106. assert.ok( ! a.containsBox( c ), "Passed!" );
  107. assert.ok( b.containsBox( a ), "Passed!" );
  108. assert.ok( c.containsBox( a ), "Passed!" );
  109. assert.ok( ! b.containsBox( c ), "Passed!" );
  110. });
  111. QUnit.test( "getParameter" , function( assert ) {
  112. var a = new THREE.Box3( zero3.clone(), one3.clone() );
  113. var b = new THREE.Box3( one3.clone().negate(), one3.clone() );
  114. assert.ok( a.getParameter( new THREE.Vector3( 0, 0, 0 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  115. assert.ok( a.getParameter( new THREE.Vector3( 1, 1, 1 ) ).equals( new THREE.Vector3( 1, 1, 1 ) ), "Passed!" );
  116. assert.ok( b.getParameter( new THREE.Vector3( -1, -1, -1 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  117. assert.ok( b.getParameter( new THREE.Vector3( 0, 0, 0 ) ).equals( new THREE.Vector3( 0.5, 0.5, 0.5 ) ), "Passed!" );
  118. assert.ok( b.getParameter( new THREE.Vector3( 1, 1, 1 ) ).equals( new THREE.Vector3( 1, 1, 1 ) ), "Passed!" );
  119. });
  120. QUnit.test( "clampPoint" , function( assert ) {
  121. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  122. var b = new THREE.Box3( one3.clone().negate(), one3.clone() );
  123. assert.ok( a.clampPoint( new THREE.Vector3( 0, 0, 0 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  124. assert.ok( a.clampPoint( new THREE.Vector3( 1, 1, 1 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  125. assert.ok( a.clampPoint( new THREE.Vector3( -1, -1, -1 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  126. assert.ok( b.clampPoint( new THREE.Vector3( 2, 2, 2 ) ).equals( new THREE.Vector3( 1, 1, 1 ) ), "Passed!" );
  127. assert.ok( b.clampPoint( new THREE.Vector3( 1, 1, 1 ) ).equals( new THREE.Vector3( 1, 1, 1 ) ), "Passed!" );
  128. assert.ok( b.clampPoint( new THREE.Vector3( 0, 0, 0 ) ).equals( new THREE.Vector3( 0, 0, 0 ) ), "Passed!" );
  129. assert.ok( b.clampPoint( new THREE.Vector3( -1, -1, -1 ) ).equals( new THREE.Vector3( -1, -1, -1 ) ), "Passed!" );
  130. assert.ok( b.clampPoint( new THREE.Vector3( -2, -2, -2 ) ).equals( new THREE.Vector3( -1, -1, -1 ) ), "Passed!" );
  131. });
  132. QUnit.test( "distanceToPoint" , function( assert ) {
  133. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  134. var b = new THREE.Box3( one3.clone().negate(), one3.clone() );
  135. assert.ok( a.distanceToPoint( new THREE.Vector3( 0, 0, 0 ) ) == 0, "Passed!" );
  136. assert.ok( a.distanceToPoint( new THREE.Vector3( 1, 1, 1 ) ) == Math.sqrt( 3 ), "Passed!" );
  137. assert.ok( a.distanceToPoint( new THREE.Vector3( -1, -1, -1 ) ) == Math.sqrt( 3 ), "Passed!" );
  138. assert.ok( b.distanceToPoint( new THREE.Vector3( 2, 2, 2 ) ) == Math.sqrt( 3 ), "Passed!" );
  139. assert.ok( b.distanceToPoint( new THREE.Vector3( 1, 1, 1 ) ) == 0, "Passed!" );
  140. assert.ok( b.distanceToPoint( new THREE.Vector3( 0, 0, 0 ) ) == 0, "Passed!" );
  141. assert.ok( b.distanceToPoint( new THREE.Vector3( -1, -1, -1 ) ) == 0, "Passed!" );
  142. assert.ok( b.distanceToPoint( new THREE.Vector3( -2, -2, -2 ) ) == Math.sqrt( 3 ), "Passed!" );
  143. });
  144. QUnit.test( "distanceToPoint" , function( assert ) {
  145. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  146. var b = new THREE.Box3( one3.clone().negate(), one3.clone() );
  147. assert.ok( a.distanceToPoint( new THREE.Vector3( 0, 0, 0 ) ) == 0, "Passed!" );
  148. assert.ok( a.distanceToPoint( new THREE.Vector3( 1, 1, 1 ) ) == Math.sqrt( 3 ), "Passed!" );
  149. assert.ok( a.distanceToPoint( new THREE.Vector3( -1, -1, -1 ) ) == Math.sqrt( 3 ), "Passed!" );
  150. assert.ok( b.distanceToPoint( new THREE.Vector3( 2, 2, 2 ) ) == Math.sqrt( 3 ), "Passed!" );
  151. assert.ok( b.distanceToPoint( new THREE.Vector3( 1, 1, 1 ) ) == 0, "Passed!" );
  152. assert.ok( b.distanceToPoint( new THREE.Vector3( 0, 0, 0 ) ) == 0, "Passed!" );
  153. assert.ok( b.distanceToPoint( new THREE.Vector3( -1, -1, -1 ) ) == 0, "Passed!" );
  154. assert.ok( b.distanceToPoint( new THREE.Vector3( -2, -2, -2 ) ) == Math.sqrt( 3 ), "Passed!" );
  155. });
  156. QUnit.test( "intersectsBox" , function( assert ) {
  157. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  158. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  159. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  160. assert.ok( a.intersectsBox( a ), "Passed!" );
  161. assert.ok( a.intersectsBox( b ), "Passed!" );
  162. assert.ok( a.intersectsBox( c ), "Passed!" );
  163. assert.ok( b.intersectsBox( a ), "Passed!" );
  164. assert.ok( c.intersectsBox( a ), "Passed!" );
  165. assert.ok( b.intersectsBox( c ), "Passed!" );
  166. b.translate( new THREE.Vector3( 2, 2, 2 ) );
  167. assert.ok( ! a.intersectsBox( b ), "Passed!" );
  168. assert.ok( ! b.intersectsBox( a ), "Passed!" );
  169. assert.ok( ! b.intersectsBox( c ), "Passed!" );
  170. });
  171. QUnit.test( "intersectsSphere" , function( assert ) {
  172. var a = new THREE.Box3( zero3.clone(), one3.clone() );
  173. var b = new THREE.Sphere( zero3.clone(), 1 );
  174. assert.ok( a.intersectsSphere( b ) , "Passed!" );
  175. b.translate( new THREE.Vector3( 2, 2, 2 ) );
  176. assert.ok( ! a.intersectsSphere( b ) , "Passed!" );
  177. });
  178. QUnit.test( "intersectsPlane" , function( assert ) {
  179. var a = new THREE.Box3( zero3.clone(), one3.clone() );
  180. var b = new THREE.Plane( new THREE.Vector3( 0, 1, 0 ), 1 );
  181. var c = new THREE.Plane( new THREE.Vector3( 0, 1, 0 ), 1.25 );
  182. var d = new THREE.Plane( new THREE.Vector3( 0, -1, 0 ), 1.25 );
  183. assert.ok( a.intersectsPlane( b ) , "Passed!" );
  184. assert.ok( ! a.intersectsPlane( c ) , "Passed!" );
  185. assert.ok( ! a.intersectsPlane( d ) , "Passed!" );
  186. });
  187. QUnit.test( "getBoundingSphere" , function( assert ) {
  188. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  189. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  190. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  191. assert.ok( a.getBoundingSphere().equals( new THREE.Sphere( zero3, 0 ) ), "Passed!" );
  192. assert.ok( b.getBoundingSphere().equals( new THREE.Sphere( one3.clone().multiplyScalar( 0.5 ), Math.sqrt( 3 ) * 0.5 ) ), "Passed!" );
  193. assert.ok( c.getBoundingSphere().equals( new THREE.Sphere( zero3, Math.sqrt( 12 ) * 0.5 ) ), "Passed!" );
  194. });
  195. QUnit.test( "intersect" , function( assert ) {
  196. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  197. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  198. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  199. assert.ok( a.clone().intersect( a ).equals( a ), "Passed!" );
  200. assert.ok( a.clone().intersect( b ).equals( a ), "Passed!" );
  201. assert.ok( b.clone().intersect( b ).equals( b ), "Passed!" );
  202. assert.ok( a.clone().intersect( c ).equals( a ), "Passed!" );
  203. assert.ok( b.clone().intersect( c ).equals( b ), "Passed!" );
  204. assert.ok( c.clone().intersect( c ).equals( c ), "Passed!" );
  205. });
  206. QUnit.test( "union" , function( assert ) {
  207. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  208. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  209. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  210. assert.ok( a.clone().union( a ).equals( a ), "Passed!" );
  211. assert.ok( a.clone().union( b ).equals( b ), "Passed!" );
  212. assert.ok( a.clone().union( c ).equals( c ), "Passed!" );
  213. assert.ok( b.clone().union( c ).equals( c ), "Passed!" );
  214. });
  215. var compareBox = function ( a, b, threshold ) {
  216. threshold = threshold || 0.0001;
  217. return ( a.min.distanceTo( b.min ) < threshold &&
  218. a.max.distanceTo( b.max ) < threshold );
  219. };
  220. QUnit.test( "applyMatrix4" , function( assert ) {
  221. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  222. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  223. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  224. var d = new THREE.Box3( one3.clone().negate(), zero3.clone() );
  225. var m = new THREE.Matrix4().makeTranslation( 1, -2, 1 );
  226. var t1 = new THREE.Vector3( 1, -2, 1 );
  227. assert.ok( compareBox( a.clone().applyMatrix4( m ), a.clone().translate( t1 ) ), "Passed!" );
  228. assert.ok( compareBox( b.clone().applyMatrix4( m ), b.clone().translate( t1 ) ), "Passed!" );
  229. assert.ok( compareBox( c.clone().applyMatrix4( m ), c.clone().translate( t1 ) ), "Passed!" );
  230. assert.ok( compareBox( d.clone().applyMatrix4( m ), d.clone().translate( t1 ) ), "Passed!" );
  231. });
  232. QUnit.test( "translate" , function( assert ) {
  233. var a = new THREE.Box3( zero3.clone(), zero3.clone() );
  234. var b = new THREE.Box3( zero3.clone(), one3.clone() );
  235. var c = new THREE.Box3( one3.clone().negate(), one3.clone() );
  236. var d = new THREE.Box3( one3.clone().negate(), zero3.clone() );
  237. assert.ok( a.clone().translate( one3 ).equals( new THREE.Box3( one3, one3 ) ), "Passed!" );
  238. assert.ok( a.clone().translate( one3 ).translate( one3.clone().negate() ).equals( a ), "Passed!" );
  239. assert.ok( d.clone().translate( one3 ).equals( b ), "Passed!" );
  240. assert.ok( b.clone().translate( one3.clone().negate() ).equals( d ), "Passed!" );
  241. });
粤ICP备19079148号