Box2.tests.js 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  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. zero2,
  12. one2,
  13. two2
  14. } from './Constants.tests';
  15. export default QUnit.module( 'Maths', () => {
  16. QUnit.module( 'Box2', () => {
  17. // INSTANCING
  18. QUnit.test( "Instancing", ( assert ) => {
  19. var a = new Box2();
  20. assert.ok( a.min.equals( posInf2 ), "Passed!" );
  21. assert.ok( a.max.equals( negInf2 ), "Passed!" );
  22. var a = new Box2( zero2.clone(), zero2.clone() );
  23. assert.ok( a.min.equals( zero2 ), "Passed!" );
  24. assert.ok( a.max.equals( zero2 ), "Passed!" );
  25. var a = new Box2( zero2.clone(), one2.clone() );
  26. assert.ok( a.min.equals( zero2 ), "Passed!" );
  27. assert.ok( a.max.equals( one2 ), "Passed!" );
  28. } );
  29. // PUBLIC STUFF
  30. QUnit.test( "set", ( assert ) => {
  31. var a = new Box2();
  32. a.set( zero2, one2 );
  33. assert.ok( a.min.equals( zero2 ), "Passed!" );
  34. assert.ok( a.max.equals( one2 ), "Passed!" );
  35. } );
  36. QUnit.test( "setFromPoints", ( assert ) => {
  37. var a = new Box2();
  38. a.setFromPoints( [ zero2, one2, two2 ] );
  39. assert.ok( a.min.equals( zero2 ), "Passed!" );
  40. assert.ok( a.max.equals( two2 ), "Passed!" );
  41. a.setFromPoints( [ one2 ] );
  42. assert.ok( a.min.equals( one2 ), "Passed!" );
  43. assert.ok( a.max.equals( one2 ), "Passed!" );
  44. a.setFromPoints( [] );
  45. assert.ok( a.isEmpty(), "Passed!" );
  46. } );
  47. QUnit.todo( "setFromCenterAndSize", ( assert ) => {
  48. assert.ok( false, "everything's gonna be alright" );
  49. } );
  50. QUnit.todo( "clone", ( assert ) => {
  51. assert.ok( false, "everything's gonna be alright" );
  52. } );
  53. QUnit.test( "copy", ( assert ) => {
  54. var a = new Box2( zero2.clone(), one2.clone() );
  55. var b = new Box2().copy( a );
  56. assert.ok( b.min.equals( zero2 ), "Passed!" );
  57. assert.ok( b.max.equals( one2 ), "Passed!" );
  58. // ensure that it is a true copy
  59. a.min = zero2;
  60. a.max = one2;
  61. assert.ok( b.min.equals( zero2 ), "Passed!" );
  62. assert.ok( b.max.equals( one2 ), "Passed!" );
  63. } );
  64. QUnit.test( "empty/makeEmpty", ( assert ) => {
  65. var a = new Box2();
  66. assert.ok( a.isEmpty(), "Passed!" );
  67. var a = new Box2( zero2.clone(), one2.clone() );
  68. assert.ok( ! a.isEmpty(), "Passed!" );
  69. a.makeEmpty();
  70. assert.ok( a.isEmpty(), "Passed!" );
  71. } );
  72. QUnit.todo( "isEmpty", ( assert ) => {
  73. assert.ok( false, "everything's gonna be alright" );
  74. } );
  75. QUnit.test( "getCenter", ( assert ) => {
  76. var a = new Box2( zero2.clone(), zero2.clone() );
  77. assert.ok( a.getCenter().equals( zero2 ), "Passed!" );
  78. var a = new Box2( zero2, one2 );
  79. var midpoint = one2.clone().multiplyScalar( 0.5 );
  80. assert.ok( a.getCenter().equals( midpoint ), "Passed!" );
  81. } );
  82. QUnit.test( "getSize", ( assert ) => {
  83. var a = new Box2( zero2.clone(), zero2.clone() );
  84. assert.ok( a.getSize().equals( zero2 ), "Passed!" );
  85. var a = new Box2( zero2.clone(), one2.clone() );
  86. assert.ok( a.getSize().equals( one2 ), "Passed!" );
  87. } );
  88. QUnit.test( "expandByPoint", ( assert ) => {
  89. var a = new Box2( zero2.clone(), zero2.clone() );
  90. a.expandByPoint( zero2 );
  91. assert.ok( a.getSize().equals( zero2 ), "Passed!" );
  92. a.expandByPoint( one2 );
  93. assert.ok( a.getSize().equals( one2 ), "Passed!" );
  94. a.expandByPoint( one2.clone().negate() );
  95. assert.ok( a.getSize().equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  96. assert.ok( a.getCenter().equals( zero2 ), "Passed!" );
  97. } );
  98. QUnit.test( "expandByVector", ( assert ) => {
  99. var a = new Box2( zero2.clone(), zero2.clone() );
  100. a.expandByVector( zero2 );
  101. assert.ok( a.getSize().equals( zero2 ), "Passed!" );
  102. a.expandByVector( one2 );
  103. assert.ok( a.getSize().equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  104. assert.ok( a.getCenter().equals( zero2 ), "Passed!" );
  105. } );
  106. QUnit.test( "expandByScalar", ( assert ) => {
  107. var a = new Box2( zero2.clone(), zero2.clone() );
  108. a.expandByScalar( 0 );
  109. assert.ok( a.getSize().equals( zero2 ), "Passed!" );
  110. a.expandByScalar( 1 );
  111. assert.ok( a.getSize().equals( one2.clone().multiplyScalar( 2 ) ), "Passed!" );
  112. assert.ok( a.getCenter().equals( zero2 ), "Passed!" );
  113. } );
  114. QUnit.test( "containsPoint", ( assert ) => {
  115. var a = new Box2( zero2.clone(), zero2.clone() );
  116. assert.ok( a.containsPoint( zero2 ), "Passed!" );
  117. assert.ok( ! a.containsPoint( one2 ), "Passed!" );
  118. a.expandByScalar( 1 );
  119. assert.ok( a.containsPoint( zero2 ), "Passed!" );
  120. assert.ok( a.containsPoint( one2 ), "Passed!" );
  121. assert.ok( a.containsPoint( one2.clone().negate() ), "Passed!" );
  122. } );
  123. QUnit.test( "containsBox", ( assert ) => {
  124. var a = new Box2( zero2.clone(), zero2.clone() );
  125. var b = new Box2( zero2.clone(), one2.clone() );
  126. var c = new Box2( one2.clone().negate(), one2.clone() );
  127. assert.ok( a.containsBox( a ), "Passed!" );
  128. assert.ok( ! a.containsBox( b ), "Passed!" );
  129. assert.ok( ! a.containsBox( c ), "Passed!" );
  130. assert.ok( b.containsBox( a ), "Passed!" );
  131. assert.ok( c.containsBox( a ), "Passed!" );
  132. assert.ok( ! b.containsBox( c ), "Passed!" );
  133. } );
  134. QUnit.test( "getParameter", ( assert ) => {
  135. var a = new Box2( zero2.clone(), one2.clone() );
  136. var b = new Box2( one2.clone().negate(), one2.clone() );
  137. assert.ok( a.getParameter( new Vector2( 0, 0 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  138. assert.ok( a.getParameter( new Vector2( 1, 1 ) ).equals( new Vector2( 1, 1 ) ), "Passed!" );
  139. assert.ok( b.getParameter( new Vector2( - 1, - 1 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  140. assert.ok( b.getParameter( new Vector2( 0, 0 ) ).equals( new Vector2( 0.5, 0.5 ) ), "Passed!" );
  141. assert.ok( b.getParameter( new Vector2( 1, 1 ) ).equals( new Vector2( 1, 1 ) ), "Passed!" );
  142. } );
  143. QUnit.test( "intersectsBox", ( assert ) => {
  144. var a = new Box2( zero2.clone(), zero2.clone() );
  145. var b = new Box2( zero2.clone(), one2.clone() );
  146. var c = new Box2( one2.clone().negate(), one2.clone() );
  147. assert.ok( a.intersectsBox( a ), "Passed!" );
  148. assert.ok( a.intersectsBox( b ), "Passed!" );
  149. assert.ok( a.intersectsBox( c ), "Passed!" );
  150. assert.ok( b.intersectsBox( a ), "Passed!" );
  151. assert.ok( c.intersectsBox( a ), "Passed!" );
  152. assert.ok( b.intersectsBox( c ), "Passed!" );
  153. b.translate( new Vector2( 2, 2 ) );
  154. assert.ok( ! a.intersectsBox( b ), "Passed!" );
  155. assert.ok( ! b.intersectsBox( a ), "Passed!" );
  156. assert.ok( ! b.intersectsBox( c ), "Passed!" );
  157. } );
  158. QUnit.test( "clampPoint", ( assert ) => {
  159. var a = new Box2( zero2.clone(), zero2.clone() );
  160. var b = new Box2( one2.clone().negate(), one2.clone() );
  161. assert.ok( a.clampPoint( new Vector2( 0, 0 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  162. assert.ok( a.clampPoint( new Vector2( 1, 1 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  163. assert.ok( a.clampPoint( new Vector2( - 1, - 1 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  164. assert.ok( b.clampPoint( new Vector2( 2, 2 ) ).equals( new Vector2( 1, 1 ) ), "Passed!" );
  165. assert.ok( b.clampPoint( new Vector2( 1, 1 ) ).equals( new Vector2( 1, 1 ) ), "Passed!" );
  166. assert.ok( b.clampPoint( new Vector2( 0, 0 ) ).equals( new Vector2( 0, 0 ) ), "Passed!" );
  167. assert.ok( b.clampPoint( new Vector2( - 1, - 1 ) ).equals( new Vector2( - 1, - 1 ) ), "Passed!" );
  168. assert.ok( b.clampPoint( new Vector2( - 2, - 2 ) ).equals( new Vector2( - 1, - 1 ) ), "Passed!" );
  169. } );
  170. QUnit.test( "distanceToPoint", ( assert ) => {
  171. var a = new Box2( zero2.clone(), zero2.clone() );
  172. var b = new Box2( one2.clone().negate(), one2.clone() );
  173. assert.ok( a.distanceToPoint( new Vector2( 0, 0 ) ) == 0, "Passed!" );
  174. assert.ok( a.distanceToPoint( new Vector2( 1, 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  175. assert.ok( a.distanceToPoint( new Vector2( - 1, - 1 ) ) == Math.sqrt( 2 ), "Passed!" );
  176. assert.ok( b.distanceToPoint( new Vector2( 2, 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  177. assert.ok( b.distanceToPoint( new Vector2( 1, 1 ) ) == 0, "Passed!" );
  178. assert.ok( b.distanceToPoint( new Vector2( 0, 0 ) ) == 0, "Passed!" );
  179. assert.ok( b.distanceToPoint( new Vector2( - 1, - 1 ) ) == 0, "Passed!" );
  180. assert.ok( b.distanceToPoint( new Vector2( - 2, - 2 ) ) == Math.sqrt( 2 ), "Passed!" );
  181. } );
  182. QUnit.test( "intersect", ( assert ) => {
  183. var a = new Box2( zero2.clone(), zero2.clone() );
  184. var b = new Box2( zero2.clone(), one2.clone() );
  185. var c = new Box2( one2.clone().negate(), one2.clone() );
  186. assert.ok( a.clone().intersect( a ).equals( a ), "Passed!" );
  187. assert.ok( a.clone().intersect( b ).equals( a ), "Passed!" );
  188. assert.ok( b.clone().intersect( b ).equals( b ), "Passed!" );
  189. assert.ok( a.clone().intersect( c ).equals( a ), "Passed!" );
  190. assert.ok( b.clone().intersect( c ).equals( b ), "Passed!" );
  191. assert.ok( c.clone().intersect( c ).equals( c ), "Passed!" );
  192. } );
  193. QUnit.test( "union", ( assert ) => {
  194. var a = new Box2( zero2.clone(), zero2.clone() );
  195. var b = new Box2( zero2.clone(), one2.clone() );
  196. var c = new Box2( one2.clone().negate(), one2.clone() );
  197. assert.ok( a.clone().union( a ).equals( a ), "Passed!" );
  198. assert.ok( a.clone().union( b ).equals( b ), "Passed!" );
  199. assert.ok( a.clone().union( c ).equals( c ), "Passed!" );
  200. assert.ok( b.clone().union( c ).equals( c ), "Passed!" );
  201. } );
  202. QUnit.test( "translate", ( assert ) => {
  203. var a = new Box2( zero2.clone(), zero2.clone() );
  204. var b = new Box2( zero2.clone(), one2.clone() );
  205. var c = new Box2( one2.clone().negate(), one2.clone() );
  206. var d = new Box2( one2.clone().negate(), zero2.clone() );
  207. assert.ok( a.clone().translate( one2 ).equals( new Box2( one2, one2 ) ), "Passed!" );
  208. assert.ok( a.clone().translate( one2 ).translate( one2.clone().negate() ).equals( a ), "Passed!" );
  209. assert.ok( d.clone().translate( one2 ).equals( b ), "Passed!" );
  210. assert.ok( b.clone().translate( one2.clone().negate() ).equals( d ), "Passed!" );
  211. } );
  212. QUnit.todo( "equals", ( assert ) => {
  213. assert.ok( false, "everything's gonna be alright" );
  214. } );
  215. } );
  216. } );
粤ICP备19079148号