Box2.tests.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. /**
  2. * @author bhouston / http://exocortex.com
  3. * @author TristanVALCKE / https://github.com/Itee
  4. */
  5. /* global QUnit */
  6. import { Box2 } from '../../../../src/math/Box2';
  7. import { Vector2 } from '../../../../src/math/Vector2';
  8. import {
  9. negInf2,
  10. posInf2,
  11. negOne2,
  12. zero2,
  13. one2,
  14. two2
  15. } from './Constants.tests';
  16. export default QUnit.module( 'Maths', () => {
  17. QUnit.module( 'Box2', () => {
  18. // INSTANCING
  19. QUnit.test( "Instancing", ( assert ) => {
  20. var a = new Box2();
  21. assert.ok( a.min.equals( posInf2 ), "Passed!" );
  22. assert.ok( a.max.equals( negInf2 ), "Passed!" );
  23. var a = new Box2( zero2.clone(), zero2.clone() );
  24. assert.ok( a.min.equals( zero2 ), "Passed!" );
  25. assert.ok( a.max.equals( zero2 ), "Passed!" );
  26. var a = new Box2( zero2.clone(), one2.clone() );
  27. assert.ok( a.min.equals( zero2 ), "Passed!" );
  28. assert.ok( a.max.equals( one2 ), "Passed!" );
  29. } );
  30. // PUBLIC STUFF
  31. QUnit.test( "set", ( assert ) => {
  32. var a = new Box2();
  33. a.set( zero2, one2 );
  34. assert.ok( a.min.equals( zero2 ), "Passed!" );
  35. assert.ok( a.max.equals( one2 ), "Passed!" );
  36. } );
  37. QUnit.test( "setFromPoints", ( assert ) => {
  38. var a = new Box2();
  39. a.setFromPoints( [ zero2, one2, two2 ] );
  40. assert.ok( a.min.equals( zero2 ), "Passed!" );
  41. assert.ok( a.max.equals( two2 ), "Passed!" );
  42. a.setFromPoints( [ one2 ] );
  43. assert.ok( a.min.equals( one2 ), "Passed!" );
  44. assert.ok( a.max.equals( one2 ), "Passed!" );
  45. a.setFromPoints( [] );
  46. assert.ok( a.isEmpty(), "Passed!" );
  47. } );
  48. QUnit.test( "setFromCenterAndSize", ( assert ) => {
  49. var a = new Box2();
  50. a.setFromCenterAndSize( zero2, two2 );
  51. assert.ok(a.min.equals( negOne2 ), "Passed!");
  52. assert.ok(a.max.equals( one2 ), "Passed!");
  53. a.setFromCenterAndSize(one2, two2);
  54. assert.ok(a.min.equals(zero2), "Passed!");
  55. assert.ok(a.max.equals(two2), "Passed!");
  56. a.setFromCenterAndSize(zero2, zero2);
  57. assert.ok(a.min.equals(zero2), "Passed!");
  58. assert.ok(a.max.equals(zero2), "Passed!");
  59. } );
  60. QUnit.todo( "clone", ( assert ) => {
  61. var a = new Box2( zero2, zero2 );
  62. var b = a.clone();
  63. assert.ok(b.min.equals(zero2), "Passed!");
  64. assert.ok(b.max.equals(zero2), "Passed!");
  65. a = new Box2(zero2, zero2);
  66. var b = a.clone();
  67. assert.ok(b.min.equals(posInf2), "Passed!");
  68. assert.ok(b.max.equals(negInf2), "Passed!");
  69. } );
  70. QUnit.test( "copy", ( assert ) => {
  71. var a = new Box2( zero2.clone(), one2.clone() );
  72. var b = new Box2().copy( a );
  73. assert.ok( b.min.equals( zero2 ), "Passed!" );
  74. assert.ok( b.max.equals( one2 ), "Passed!" );
  75. // ensure that it is a true copy
  76. a.min = zero2;
  77. a.max = one2;
  78. assert.ok( b.min.equals( zero2 ), "Passed!" );
  79. assert.ok( b.max.equals( one2 ), "Passed!" );
  80. } );
  81. QUnit.test( "empty/makeEmpty", ( assert ) => {
  82. var a = new Box2();
  83. assert.ok( a.isEmpty(), "Passed!" );
  84. var a = new Box2( zero2.clone(), one2.clone() );
  85. assert.ok( ! a.isEmpty(), "Passed!" );
  86. a.makeEmpty();
  87. assert.ok( a.isEmpty(), "Passed!" );
  88. } );
  89. QUnit.test("isEmpty", (assert) => {
  90. var a = new Box2(zero2.clone(), zero2.clone());
  91. assert.ok(a.isEmpty(), "Passed!");
  92. var a = new Box2(zero2.clone(), one2.clone());
  93. assert.ok(!a.isEmpty(), "Passed!");
  94. var a = new Box2(two2.clone(), one2.clone());
  95. assert.ok(a.isEmpty(), "Passed!");
  96. var a = new Box2(posInf2.clone(), negInf2.clone());
  97. assert.ok(a.isEmpty(), "Passed!");
  98. } );
  99. QUnit.test( "getCenter", ( assert ) => {
  100. var a = new Box2( zero2.clone(), zero2.clone() );
  101. var center = new Vector2();
  102. assert.ok( a.getCenter( center ).equals( zero2 ), "Passed!" );
  103. var a = new Box2( zero2, one2 );
  104. var midpoint = one2.clone().multiplyScalar( 0.5 );
  105. assert.ok( a.getCenter( center ).equals( midpoint ), "Passed!" );
  106. } );
  107. QUnit.test( "getSize", ( assert ) => {
  108. var a = new Box2( zero2.clone(), zero2.clone() );
  109. var size = new Vector2();
  110. assert.ok( a.getSize( size ).equals( zero2 ), "Passed!" );
  111. var a = new Box2( zero2.clone(), one2.clone() );
  112. assert.ok( a.getSize( size ).equals( one2 ), "Passed!" );
  113. } );
  114. QUnit.test( "expandByPoint", ( assert ) => {
  115. var a = new Box2( zero2.clone(), zero2.clone() );
  116. var size = new Vector2();
  117. var center = new Vector2();
  118. a.expandByPoint( zero2 );
  119. assert.ok( a.getSize( size ).equals( zero2 ), "Passed!" );
  120. a.expandByPoint( one2 );
  121. assert.ok( a.getSize( size ).equals( one2 ), "Passed!" );
  122. a.expandByPoint( one2.clone().negate() );
  123. assert.ok( a.getSize( size ).equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  124. assert.ok( a.getCenter( center ).equals( zero2 ), "Passed!" );
  125. } );
  126. QUnit.test( "expandByVector", ( assert ) => {
  127. var a = new Box2( zero2.clone(), zero2.clone() );
  128. var size = new Vector2();
  129. var center = new Vector2();
  130. a.expandByVector( zero2 );
  131. assert.ok( a.getSize( size ).equals( zero2 ), "Passed!" );
  132. a.expandByVector( one2 );
  133. assert.ok( a.getSize( size ).equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  134. assert.ok( a.getCenter( center ).equals( zero2 ), "Passed!" );
  135. } );
  136. QUnit.test( "expandByScalar", ( assert ) => {
  137. var a = new Box2( zero2.clone(), zero2.clone() );
  138. var size = new Vector2();
  139. var center = new Vector2();
  140. a.expandByScalar( 0 );
  141. assert.ok( a.getSize( size ).equals( zero2 ), "Passed!" );
  142. a.expandByScalar( 1 );
  143. assert.ok( a.getSize( size ).equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  144. assert.ok( a.getCenter( center ).equals( zero2 ), "Passed!" );
  145. } );
  146. QUnit.test( "containsPoint", ( assert ) => {
  147. var a = new Box2( zero2.clone(), zero2.clone() );
  148. assert.ok( a.containsPoint( zero2 ), "Passed!" );
  149. assert.ok( ! a.containsPoint( one2 ), "Passed!" );
  150. a.expandByScalar( 1 );
  151. assert.ok( a.containsPoint( zero2 ), "Passed!" );
  152. assert.ok( a.containsPoint( one2 ), "Passed!" );
  153. assert.ok( a.containsPoint( one2.clone().negate() ), "Passed!" );
  154. } );
  155. QUnit.test( "containsBox", ( assert ) => {
  156. var a = new Box2( zero2.clone(), zero2.clone() );
  157. var b = new Box2( zero2.clone(), one2.clone() );
  158. var c = new Box2( one2.clone().negate(), one2.clone() );
  159. assert.ok( a.containsBox( a ), "Passed!" );
  160. assert.ok( ! a.containsBox( b ), "Passed!" );
  161. assert.ok( ! a.containsBox( c ), "Passed!" );
  162. assert.ok( b.containsBox( a ), "Passed!" );
  163. assert.ok( c.containsBox( a ), "Passed!" );
  164. assert.ok( ! b.containsBox( c ), "Passed!" );
  165. } );
  166. QUnit.test( "getParameter", ( assert ) => {
  167. var a = new Box2( zero2.clone(), one2.clone() );
  168. var b = new Box2( one2.clone().negate(), one2.clone() );
  169. var parameter = new Vector2();
  170. a.getParameter( zero2, parameter );
  171. assert.ok( parameter.equals( zero2 ), "Passed!" );
  172. a.getParameter( one2, parameter );
  173. assert.ok( parameter.equals( one2 ), "Passed!" );
  174. b.getParameter( one2.clone().negate(), parameter );
  175. assert.ok( parameter.equals( zero2 ), "Passed!" );
  176. b.getParameter( zero2, parameter );
  177. assert.ok( parameter.equals( new Vector2( 0.5, 0.5 ) ), "Passed!" );
  178. b.getParameter( one2, parameter );
  179. assert.ok( parameter.equals( one2 ), "Passed!" );
  180. } );
  181. QUnit.test( "intersectsBox", ( assert ) => {
  182. var a = new Box2( zero2.clone(), zero2.clone() );
  183. var b = new Box2( zero2.clone(), one2.clone() );
  184. var c = new Box2( one2.clone().negate(), one2.clone() );
  185. assert.ok( a.intersectsBox( a ), "Passed!" );
  186. assert.ok( a.intersectsBox( b ), "Passed!" );
  187. assert.ok( a.intersectsBox( c ), "Passed!" );
  188. assert.ok( b.intersectsBox( a ), "Passed!" );
  189. assert.ok( c.intersectsBox( a ), "Passed!" );
  190. assert.ok( b.intersectsBox( c ), "Passed!" );
  191. b.translate( two2 );
  192. assert.ok( ! a.intersectsBox( b ), "Passed!" );
  193. assert.ok( ! b.intersectsBox( a ), "Passed!" );
  194. assert.ok( ! b.intersectsBox( c ), "Passed!" );
  195. } );
  196. QUnit.test( "clampPoint", ( assert ) => {
  197. var a = new Box2( zero2.clone(), zero2.clone() );
  198. var b = new Box2( one2.clone().negate(), one2.clone() );
  199. var point = new Vector2();
  200. a.clampPoint( zero2, point );
  201. assert.ok( point.equals( new Vector2( 0, 0 ) ), "Passed!" );
  202. a.clampPoint( one2, point );
  203. assert.ok( point.equals( new Vector2( 0, 0 ) ), "Passed!" );
  204. a.clampPoint( one2.clone().negate(), point );
  205. assert.ok( point.equals( new Vector2( 0, 0 ) ), "Passed!" );
  206. b.clampPoint( two2, point );
  207. assert.ok( point.equals( new Vector2( 1, 1 ) ), "Passed!" );
  208. b.clampPoint( one2, point );
  209. assert.ok( point.equals( new Vector2( 1, 1 ) ), "Passed!" );
  210. b.clampPoint( zero2, point );
  211. assert.ok( point.equals( new Vector2( 0, 0 ) ), "Passed!" );
  212. b.clampPoint( one2.clone().negate(), point );
  213. assert.ok( point.equals( new Vector2( - 1, - 1 ) ), "Passed!" );
  214. b.clampPoint( two2.clone().negate(), point );
  215. assert.ok( point.equals( new Vector2( - 1, - 1 ) ), "Passed!" );
  216. } );
  217. QUnit.test( "distanceToPoint", ( assert ) => {
  218. var a = new Box2( zero2.clone(), zero2.clone() );
  219. var b = new Box2( one2.clone().negate(), one2.clone() );
  220. assert.ok( a.distanceToPoint( new Vector2( 0, 0 ) ) == 0, "Passed!" );
  221. assert.ok( a.distanceToPoint( new Vector2( 1, 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  222. assert.ok( a.distanceToPoint( new Vector2( - 1, - 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  223. assert.ok( b.distanceToPoint( new Vector2( 2, 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  224. assert.ok( b.distanceToPoint( new Vector2( 1, 1 ) ) == 0, "Passed!" );
  225. assert.ok( b.distanceToPoint( new Vector2( 0, 0 ) ) == 0, "Passed!" );
  226. assert.ok( b.distanceToPoint( new Vector2( - 1, - 1 ) ) == 0, "Passed!" );
  227. assert.ok( b.distanceToPoint( new Vector2( - 2, - 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  228. } );
  229. QUnit.test( "intersect", ( assert ) => {
  230. var a = new Box2( zero2.clone(), zero2.clone() );
  231. var b = new Box2( zero2.clone(), one2.clone() );
  232. var c = new Box2( one2.clone().negate(), one2.clone() );
  233. assert.ok( a.clone().intersect( a ).equals( a ), "Passed!" );
  234. assert.ok( a.clone().intersect( b ).equals( a ), "Passed!" );
  235. assert.ok( b.clone().intersect( b ).equals( b ), "Passed!" );
  236. assert.ok( a.clone().intersect( c ).equals( a ), "Passed!" );
  237. assert.ok( b.clone().intersect( c ).equals( b ), "Passed!" );
  238. assert.ok( c.clone().intersect( c ).equals( c ), "Passed!" );
  239. } );
  240. QUnit.test( "union", ( assert ) => {
  241. var a = new Box2( zero2.clone(), zero2.clone() );
  242. var b = new Box2( zero2.clone(), one2.clone() );
  243. var c = new Box2( one2.clone().negate(), one2.clone() );
  244. assert.ok( a.clone().union( a ).equals( a ), "Passed!" );
  245. assert.ok( a.clone().union( b ).equals( b ), "Passed!" );
  246. assert.ok( a.clone().union( c ).equals( c ), "Passed!" );
  247. assert.ok( b.clone().union( c ).equals( c ), "Passed!" );
  248. } );
  249. QUnit.test( "translate", ( assert ) => {
  250. var a = new Box2( zero2.clone(), zero2.clone() );
  251. var b = new Box2( zero2.clone(), one2.clone() );
  252. var c = new Box2( one2.clone().negate(), one2.clone() );
  253. var d = new Box2( one2.clone().negate(), zero2.clone() );
  254. assert.ok( a.clone().translate( one2 ).equals( new Box2( one2, one2 ) ), "Passed!" );
  255. assert.ok( a.clone().translate( one2 ).translate( one2.clone().negate() ).equals( a ), "Passed!" );
  256. assert.ok( d.clone().translate( one2 ).equals( b ), "Passed!" );
  257. assert.ok( b.clone().translate( one2.clone().negate() ).equals( d ), "Passed!" );
  258. } );
  259. QUnit.test( "equals", ( assert ) => {
  260. var a = new Box2();
  261. var b = new Box2();
  262. assert.ok(b.equals(a), "Passed!");
  263. assert.ok(a.equals(b), "Passed!");
  264. a = new Box2(one2, two2);
  265. b = new Box2(one2, two2);
  266. assert.ok(b.equals(a), "Passed!");
  267. assert.ok(a.equals(b), "Passed!");
  268. a = new Box2(one2, two2);
  269. b = a.clone();
  270. assert.ok(b.equals(a), "Passed!");
  271. assert.ok(a.equals(b), "Passed!");
  272. a = new Box2(one2, two2);
  273. b = new Box2(one2, one2);
  274. assert.ok(!b.equals(a), "Passed!");
  275. assert.ok(!a.equals(b), "Passed!");
  276. a = new Box2();
  277. b = new Box2(one2, one2);
  278. assert.ok(!b.equals(a), "Passed!");
  279. assert.ok(!a.equals(b), "Passed!");
  280. a = new Box2(one2, two2);
  281. b = new Box2(one2, one2);
  282. assert.ok(!b.equals(a), "Passed!");
  283. assert.ok(!a.equals(b), "Passed!");
  284. } );
  285. } );
  286. } );
粤ICP备19079148号