debugdraw.cpp 28 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183
  1. /*
  2. * Copyright 2011-2019 Branimir Karadzic. All rights reserved.
  3. * License: https://github.com/bkaradzic/bgfx#license-bsd-2-clause
  4. */
  5. #include "common.h"
  6. #include "bgfx_utils.h"
  7. #include <entry/cmd.h>
  8. #include <entry/input.h>
  9. #include <debugdraw/debugdraw.h>
  10. #include "camera.h"
  11. #include "imgui/imgui.h"
  12. #include <bx/uint32_t.h>
  13. namespace
  14. {
  15. static DdVertex s_bunnyVertices[] =
  16. {
  17. { 25.0883f, -44.2788f, 31.0055f },
  18. { 0.945623f, 53.5504f, -24.6146f },
  19. { -0.94455f, -14.3443f, -16.8223f },
  20. { -20.1103f, -48.6664f, 12.6763f },
  21. { -1.60652f, -26.3165f, -24.5424f },
  22. { -30.6284f, -53.6299f, 14.7666f },
  23. { 1.69145f, -43.8075f, -15.2065f },
  24. { -20.5139f, 21.0521f, -5.40868f },
  25. { -13.9518f, 53.6299f, -39.1193f },
  26. { -21.7912f, 48.7801f, -42.0995f },
  27. { -26.8408f, 23.6537f, -17.7324f },
  28. { -23.1196f, 33.9692f, 4.91483f },
  29. { -12.3236f, -41.6303f, 31.8324f },
  30. { 27.6427f, -5.05034f, -11.3201f },
  31. { 32.2565f, 1.30521f, 30.2671f },
  32. { 47.2723f, -27.0974f, 11.1774f },
  33. { 33.598f, 10.5888f, 7.95916f },
  34. { -13.2898f, 12.6234f, 5.55953f },
  35. { -32.7364f, 19.0648f, -10.5736f },
  36. { -32.7536f, 31.4158f, -1.40712f },
  37. { -25.3672f, 30.2874f, -12.4682f },
  38. { 32.921f, -36.8408f, -12.0254f },
  39. { -37.7251f, -33.8989f, 0.378443f },
  40. { -35.6341f, -0.246891f, -9.25165f },
  41. { -16.7041f, -50.0254f, -15.6177f },
  42. { 24.6604f, -53.5319f, -11.1059f },
  43. { -7.77574f, -53.5719f, -16.6655f },
  44. { 20.6241f, 13.3489f, 0.376349f },
  45. { -44.2889f, 29.5222f, 18.7918f },
  46. { 18.5805f, 16.3651f, 12.6351f },
  47. { -23.7853f, 31.7598f, -6.54093f },
  48. { 24.7518f, -53.5075f, 2.14984f },
  49. { -45.7912f, -17.6301f, 21.1198f },
  50. { 51.8403f, -33.1847f, 24.3337f },
  51. { -47.5343f, -4.32792f, 4.06232f },
  52. { -50.6832f, -12.442f, 11.0994f },
  53. { -49.5132f, 19.2782f, 3.17559f },
  54. { -39.4881f, 29.0208f, -6.70431f },
  55. { -52.7286f, 1.23232f, 9.74872f },
  56. { 26.505f, -16.1297f, -17.0487f },
  57. { -25.367f, 20.0473f, -8.44282f },
  58. { -24.5797f, -10.3143f, -18.3154f },
  59. { -28.6707f, 6.12074f, 27.8025f },
  60. { -16.9868f, 22.6819f, 1.37408f },
  61. { -37.2678f, 23.9443f, -9.4945f },
  62. { -24.8562f, 21.3763f, 18.8847f },
  63. { -47.1879f, 3.8542f, -4.74621f },
  64. { 38.0706f, -7.33673f, -7.6099f },
  65. { -34.8833f, -3.57074f, 26.4838f },
  66. { 12.3797f, 5.46782f, 32.9762f },
  67. { -31.5974f, -22.956f, 30.5827f },
  68. { -6.80953f, 48.055f, -18.5116f },
  69. { 6.3474f, -15.1622f, -24.4726f },
  70. { -25.5733f, 25.2452f, -34.4736f },
  71. { -23.8955f, 31.8323f, -40.8696f },
  72. { -11.8622f, 38.2304f, -43.3125f },
  73. { -20.4918f, 41.2409f, -3.11271f },
  74. { 24.9806f, -8.53455f, 37.2862f },
  75. { -52.8935f, 5.3376f, 28.246f },
  76. { 34.106f, -41.7941f, 30.962f },
  77. { -1.26914f, 35.6664f, -18.7177f },
  78. { -0.13048f, 44.7288f, -28.7163f },
  79. { 2.47929f, 0.678165f, -14.6892f },
  80. { -31.8649f, -14.2299f, 32.2998f },
  81. { -19.774f, 30.8258f, 5.77293f },
  82. { 49.8059f, -37.125f, 4.97284f },
  83. { -28.0581f, -26.439f, -14.8316f },
  84. { -9.12066f, -27.3987f, -12.8592f },
  85. { -13.8752f, -29.9821f, 32.5962f },
  86. { -6.6222f, -10.9884f, 33.5007f },
  87. { -21.2664f, -53.6089f, -3.49195f },
  88. { -0.628672f, 52.8093f, -9.88088f },
  89. { 8.02417f, 51.8956f, -21.5834f },
  90. { -44.6547f, 11.9973f, 34.7897f },
  91. { -7.55466f, 37.9035f, -0.574101f },
  92. { 52.8252f, -27.1986f, 11.6429f },
  93. { -0.934591f, 9.81861f, 0.512566f },
  94. { -3.01043f, 5.70605f, 22.0954f },
  95. { -34.6337f, 44.5964f, -31.1713f },
  96. { -26.9017f, 35.1991f, -32.4307f },
  97. { 15.9884f, -8.92223f, -14.7411f },
  98. { -22.8337f, -43.458f, 26.7274f },
  99. { -31.9864f, -47.0243f, 9.36972f },
  100. { -36.9436f, 24.1866f, 29.2521f },
  101. { -26.5411f, 29.6549f, 21.2867f },
  102. { 33.7644f, -24.1886f, -13.8513f },
  103. { -2.44749f, -17.0148f, 41.6617f },
  104. { -38.364f, -13.9823f, -12.5705f },
  105. { -10.2972f, -51.6584f, 38.935f },
  106. { 1.28109f, -43.4943f, 36.6288f },
  107. { -19.7784f, -44.0413f, -4.23994f },
  108. { 37.0944f, -53.5479f, 27.6467f },
  109. { 24.9642f, -37.1722f, 35.7038f },
  110. { 37.5851f, 5.64874f, 21.6702f },
  111. { -17.4738f, -53.5734f, 30.0664f },
  112. { -8.93088f, 45.3429f, -34.4441f },
  113. { -17.7111f, -6.5723f, 29.5162f },
  114. { 44.0059f, -17.4408f, -5.08686f },
  115. { -46.2534f, -22.6115f, 0.702059f },
  116. { 43.9321f, -33.8575f, 4.31819f },
  117. { 41.6762f, -7.37115f, 27.6798f },
  118. { 8.20276f, -42.0948f, -18.0893f },
  119. { 26.2678f, -44.6777f, -10.6835f },
  120. { 17.709f, 13.1542f, 25.1769f },
  121. { -35.9897f, 3.92007f, 35.8198f },
  122. { -23.9323f, -37.3142f, -2.39396f },
  123. { 5.19169f, 46.8851f, -28.7587f },
  124. { -37.3072f, -35.0484f, 16.9719f },
  125. { 45.0639f, -28.5255f, 22.3465f },
  126. { -34.4175f, 35.5861f, -21.7562f },
  127. { 9.32684f, -12.6655f, 42.189f },
  128. { 1.00938f, -31.7694f, 43.1914f },
  129. { -45.4666f, -3.71104f, 19.2248f },
  130. { -28.7999f, -50.8481f, 31.5232f },
  131. { 35.2212f, -45.9047f, 0.199736f },
  132. { 40.3f, -53.5889f, 7.47622f },
  133. { 29.0515f, 5.1074f, -10.002f },
  134. { 13.4336f, 4.84341f, -9.72327f },
  135. { 11.0617f, -26.245f, -24.9471f },
  136. { -35.6056f, -51.2531f, 0.436527f },
  137. { -10.6863f, 34.7374f, -36.7452f },
  138. { -51.7652f, 27.4957f, 7.79363f },
  139. { -50.1898f, 18.379f, 26.3763f },
  140. { -49.6836f, -1.32722f, 26.2828f },
  141. { 19.0363f, -16.9114f, 41.8511f },
  142. { 32.7141f, -21.501f, 36.0025f },
  143. { 12.5418f, -28.4244f, 43.3125f },
  144. { -19.5634f, 42.6328f, -27.0687f },
  145. { -16.1942f, 6.55011f, 19.4066f },
  146. { 46.9886f, -18.8482f, 22.1332f },
  147. { 45.9697f, -3.76781f, 4.10111f },
  148. { -28.2912f, 51.3277f, -35.1815f },
  149. { -40.2796f, -27.7518f, 22.8684f },
  150. { -22.7984f, -38.9977f, 22.158f },
  151. { 54.0614f, -35.6096f, 12.694f },
  152. { 44.2064f, -53.6029f, 18.8679f },
  153. { 19.789f, -29.517f, -19.6094f },
  154. { -34.3769f, 34.8566f, 9.92517f },
  155. { -23.7518f, -45.0319f, 8.71282f },
  156. { -12.7978f, 3.55087f, -13.7108f },
  157. { -54.0614f, 8.83831f, 8.91353f },
  158. { 16.2986f, -53.5717f, 34.065f },
  159. { -36.6243f, -53.5079f, 24.6495f },
  160. { 16.5794f, -48.5747f, 35.5681f },
  161. { -32.3263f, 41.4526f, -18.7388f },
  162. { -18.8488f, 9.62627f, -8.81052f },
  163. { 5.35849f, 36.3616f, -12.9346f },
  164. { 6.19167f, 34.497f, -17.965f },
  165. };
  166. static const uint16_t s_bunnyTriList[] =
  167. {
  168. 80, 2, 52,
  169. 0, 143, 92,
  170. 51, 1, 71,
  171. 96, 128, 77,
  172. 67, 2, 41,
  173. 85, 39, 52,
  174. 58, 123, 38,
  175. 99, 21, 114,
  176. 55, 9, 54,
  177. 136, 102, 21,
  178. 3, 133, 81,
  179. 101, 136, 4,
  180. 5, 82, 3,
  181. 6, 90, 24,
  182. 7, 40, 145,
  183. 33, 75, 134,
  184. 55, 8, 9,
  185. 10, 40, 20,
  186. 46, 140, 38,
  187. 74, 64, 11,
  188. 89, 88, 12,
  189. 147, 60, 7,
  190. 47, 116, 13,
  191. 59, 129, 108,
  192. 147, 72, 106,
  193. 33, 108, 75,
  194. 100, 57, 14,
  195. 129, 130, 15,
  196. 32, 35, 112,
  197. 16, 29, 27,
  198. 107, 98, 132,
  199. 130, 116, 47,
  200. 17, 43, 7,
  201. 54, 44, 53,
  202. 46, 34, 23,
  203. 87, 41, 23,
  204. 40, 10, 18,
  205. 8, 131, 9,
  206. 11, 19, 56,
  207. 11, 137, 19,
  208. 19, 20, 30,
  209. 28, 121, 137,
  210. 122, 140, 36,
  211. 15, 130, 97,
  212. 28, 84, 83,
  213. 114, 21, 102,
  214. 87, 98, 22,
  215. 41, 145, 23,
  216. 133, 68, 12,
  217. 90, 70, 24,
  218. 31, 25, 26,
  219. 98, 34, 35,
  220. 16, 27, 116,
  221. 28, 83, 122,
  222. 29, 103, 77,
  223. 40, 30, 20,
  224. 14, 49, 103,
  225. 31, 26, 142,
  226. 78, 9, 131,
  227. 80, 62, 2,
  228. 6, 67, 105,
  229. 32, 48, 63,
  230. 60, 30, 7,
  231. 33, 135, 91,
  232. 116, 130, 16,
  233. 47, 13, 39,
  234. 70, 119, 5,
  235. 24, 26, 6,
  236. 102, 25, 31,
  237. 103, 49, 77,
  238. 16, 130, 93,
  239. 125, 126, 124,
  240. 111, 86, 110,
  241. 4, 52, 2,
  242. 87, 34, 98,
  243. 4, 6, 101,
  244. 29, 76, 27,
  245. 112, 35, 34,
  246. 6, 4, 67,
  247. 72, 1, 106,
  248. 26, 24, 70,
  249. 36, 37, 121,
  250. 81, 113, 142,
  251. 44, 109, 37,
  252. 122, 58, 38,
  253. 96, 48, 128,
  254. 71, 11, 56,
  255. 73, 122, 83,
  256. 52, 39, 80,
  257. 40, 18, 145,
  258. 82, 5, 119,
  259. 10, 20, 120,
  260. 139, 145, 41,
  261. 3, 142, 5,
  262. 76, 117, 27,
  263. 95, 120, 20,
  264. 104, 45, 42,
  265. 128, 43, 17,
  266. 44, 37, 36,
  267. 128, 45, 64,
  268. 143, 111, 126,
  269. 34, 46, 38,
  270. 97, 130, 47,
  271. 142, 91, 115,
  272. 114, 31, 115,
  273. 125, 100, 129,
  274. 48, 96, 63,
  275. 62, 41, 2,
  276. 69, 77, 49,
  277. 133, 50, 68,
  278. 60, 51, 30,
  279. 4, 118, 52,
  280. 53, 55, 54,
  281. 95, 8, 55,
  282. 121, 37, 19,
  283. 65, 75, 99,
  284. 51, 56, 30,
  285. 14, 57, 110,
  286. 58, 122, 73,
  287. 59, 92, 125,
  288. 42, 45, 128,
  289. 49, 14, 110,
  290. 60, 147, 61,
  291. 76, 62, 117,
  292. 69, 49, 86,
  293. 26, 5, 142,
  294. 46, 44, 36,
  295. 63, 50, 132,
  296. 128, 64, 43,
  297. 75, 108, 15,
  298. 134, 75, 65,
  299. 68, 69, 86,
  300. 62, 76, 145,
  301. 142, 141, 91,
  302. 67, 66, 105,
  303. 69, 68, 96,
  304. 119, 70, 90,
  305. 33, 91, 108,
  306. 136, 118, 4,
  307. 56, 51, 71,
  308. 1, 72, 71,
  309. 23, 18, 44,
  310. 104, 123, 73,
  311. 106, 1, 61,
  312. 86, 111, 68,
  313. 83, 45, 104,
  314. 30, 56, 19,
  315. 15, 97, 99,
  316. 71, 74, 11,
  317. 15, 99, 75,
  318. 25, 102, 6,
  319. 12, 94, 81,
  320. 135, 33, 134,
  321. 138, 133, 3,
  322. 76, 29, 77,
  323. 94, 88, 141,
  324. 115, 31, 142,
  325. 36, 121, 122,
  326. 4, 2, 67,
  327. 9, 78, 79,
  328. 137, 121, 19,
  329. 69, 96, 77,
  330. 13, 62, 80,
  331. 8, 127, 131,
  332. 143, 141, 89,
  333. 133, 12, 81,
  334. 82, 119, 138,
  335. 45, 83, 84,
  336. 21, 85, 136,
  337. 126, 110, 124,
  338. 86, 49, 110,
  339. 13, 116, 117,
  340. 22, 66, 87,
  341. 141, 88, 89,
  342. 64, 45, 84,
  343. 79, 78, 109,
  344. 26, 70, 5,
  345. 14, 93, 100,
  346. 68, 50, 63,
  347. 90, 105, 138,
  348. 141, 0, 91,
  349. 105, 90, 6,
  350. 0, 92, 59,
  351. 17, 145, 76,
  352. 29, 93, 103,
  353. 113, 81, 94,
  354. 39, 85, 47,
  355. 132, 35, 32,
  356. 128, 48, 42,
  357. 93, 29, 16,
  358. 145, 18, 23,
  359. 108, 129, 15,
  360. 32, 112, 48,
  361. 66, 41, 87,
  362. 120, 95, 55,
  363. 96, 68, 63,
  364. 85, 99, 97,
  365. 18, 53, 44,
  366. 22, 98, 107,
  367. 98, 35, 132,
  368. 95, 127, 8,
  369. 137, 64, 84,
  370. 18, 10, 53,
  371. 21, 99, 85,
  372. 54, 79, 44,
  373. 100, 93, 130,
  374. 142, 3, 81,
  375. 102, 101, 6,
  376. 93, 14, 103,
  377. 42, 48, 104,
  378. 87, 23, 34,
  379. 66, 22, 105,
  380. 106, 61, 147,
  381. 72, 74, 71,
  382. 109, 144, 37,
  383. 115, 65, 99,
  384. 107, 132, 133,
  385. 94, 12, 88,
  386. 108, 91, 59,
  387. 43, 64, 74,
  388. 109, 78, 144,
  389. 43, 147, 7,
  390. 91, 135, 115,
  391. 111, 110, 126,
  392. 38, 112, 34,
  393. 142, 113, 94,
  394. 54, 9, 79,
  395. 120, 53, 10,
  396. 138, 3, 82,
  397. 114, 102, 31,
  398. 134, 65, 115,
  399. 105, 22, 107,
  400. 125, 129, 59,
  401. 37, 144, 19,
  402. 17, 76, 77,
  403. 89, 12, 111,
  404. 41, 66, 67,
  405. 13, 117, 62,
  406. 116, 27, 117,
  407. 136, 52, 118,
  408. 51, 60, 61,
  409. 138, 119, 90,
  410. 53, 120, 55,
  411. 68, 111, 12,
  412. 122, 121, 28,
  413. 123, 58, 73,
  414. 110, 57, 124,
  415. 47, 85, 97,
  416. 44, 79, 109,
  417. 126, 125, 92,
  418. 43, 74, 146,
  419. 20, 19, 127,
  420. 128, 17, 77,
  421. 72, 146, 74,
  422. 115, 99, 114,
  423. 140, 122, 38,
  424. 133, 105, 107,
  425. 129, 100, 130,
  426. 131, 144, 78,
  427. 95, 20, 127,
  428. 123, 48, 112,
  429. 102, 136, 101,
  430. 89, 111, 143,
  431. 28, 137, 84,
  432. 133, 132, 50,
  433. 125, 57, 100,
  434. 38, 123, 112,
  435. 124, 57, 125,
  436. 135, 134, 115,
  437. 23, 44, 46,
  438. 136, 85, 52,
  439. 41, 62, 139,
  440. 137, 11, 64,
  441. 104, 48, 123,
  442. 133, 138, 105,
  443. 145, 139, 62,
  444. 25, 6, 26,
  445. 7, 30, 40,
  446. 46, 36, 140,
  447. 141, 143, 0,
  448. 132, 32, 63,
  449. 83, 104, 73,
  450. 19, 144, 127,
  451. 142, 94, 141,
  452. 39, 13, 80,
  453. 92, 143, 126,
  454. 127, 144, 131,
  455. 51, 61, 1,
  456. 91, 0, 59,
  457. 17, 7, 145,
  458. 43, 146, 147,
  459. 146, 72, 147,
  460. };
  461. void imageCheckerboard(void* _dst, uint32_t _width, uint32_t _height, uint32_t _step, uint32_t _0, uint32_t _1)
  462. {
  463. uint32_t* dst = (uint32_t*)_dst;
  464. for (uint32_t yy = 0; yy < _height; ++yy)
  465. {
  466. for (uint32_t xx = 0; xx < _width; ++xx)
  467. {
  468. uint32_t abgr = ( (xx/_step)&1) ^ ( (yy/_step)&1) ? _1 : _0;
  469. *dst++ = abgr;
  470. }
  471. }
  472. }
  473. void translate(Triangle& _inout, bx::Vec3 _pos)
  474. {
  475. _inout.v0 = bx::add(_inout.v0, _pos);
  476. _inout.v1 = bx::add(_inout.v1, _pos);
  477. _inout.v2 = bx::add(_inout.v2, _pos);
  478. }
  479. class ExampleDebugDraw : public entry::AppI
  480. {
  481. public:
  482. ExampleDebugDraw(const char* _name, const char* _description)
  483. : entry::AppI(_name, _description)
  484. {
  485. }
  486. void init(int32_t _argc, const char* const* _argv, uint32_t _width, uint32_t _height) override
  487. {
  488. Args args(_argc, _argv);
  489. m_width = _width;
  490. m_height = _height;
  491. m_debug = BGFX_DEBUG_NONE;
  492. m_reset = BGFX_RESET_VSYNC | BGFX_RESET_MSAA_X16;
  493. bgfx::Init init;
  494. init.type = args.m_type;
  495. init.vendorId = args.m_pciId;
  496. init.resolution.width = m_width;
  497. init.resolution.height = m_height;
  498. init.resolution.reset = m_reset;
  499. bgfx::init(init);
  500. // Enable m_debug text.
  501. bgfx::setDebug(m_debug);
  502. // Set view 0 clear state.
  503. bgfx::setViewClear(0
  504. , BGFX_CLEAR_COLOR|BGFX_CLEAR_DEPTH
  505. , 0x303030ff
  506. , 1.0f
  507. , 0
  508. );
  509. m_timeOffset = bx::getHPCounter();
  510. cameraCreate();
  511. cameraSetPosition({ 0.0f, 2.0f, -12.0f });
  512. cameraSetVerticalAngle(0.0f);
  513. ddInit();
  514. uint8_t data[32*32*4];
  515. imageCheckerboard(data, 32, 32, 4, 0xff808080, 0xffc0c0c0);
  516. m_sprite = ddCreateSprite(32, 32, data);
  517. m_bunny = ddCreateGeometry(
  518. BX_COUNTOF(s_bunnyVertices)
  519. , s_bunnyVertices
  520. , BX_COUNTOF(s_bunnyTriList)
  521. , s_bunnyTriList
  522. );
  523. imguiCreate();
  524. }
  525. virtual int shutdown() override
  526. {
  527. imguiDestroy();
  528. ddDestroy(m_bunny);
  529. ddDestroy(m_sprite);
  530. ddShutdown();
  531. cameraDestroy();
  532. // Shutdown bgfx.
  533. bgfx::shutdown();
  534. return 0;
  535. }
  536. template<typename Ty>
  537. bool intersect(DebugDrawEncoder* _dde, const Ray& _ray, const Ty& _shape)
  538. {
  539. Hit hit;
  540. if (::intersect(_ray, _shape, &hit) )
  541. {
  542. _dde->push();
  543. _dde->setWireframe(false);
  544. _dde->setColor(0xff0000ff);
  545. const bx::Vec3 tmp = bx::mul(hit.plane.normal, 0.7f);
  546. const bx::Vec3 end = bx::add(hit.pos, tmp);
  547. _dde->drawCone(hit.pos, end, 0.1f);
  548. _dde->pop();
  549. return true;
  550. }
  551. return false;
  552. }
  553. bool update() override
  554. {
  555. if (!entry::processEvents(m_width, m_height, m_debug, m_reset, &m_mouseState) )
  556. {
  557. imguiBeginFrame(
  558. m_mouseState.m_mx
  559. , m_mouseState.m_my
  560. , (m_mouseState.m_buttons[entry::MouseButton::Left ] ? IMGUI_MBUT_LEFT : 0)
  561. | (m_mouseState.m_buttons[entry::MouseButton::Right ] ? IMGUI_MBUT_RIGHT : 0)
  562. | (m_mouseState.m_buttons[entry::MouseButton::Middle] ? IMGUI_MBUT_MIDDLE : 0)
  563. , m_mouseState.m_mz
  564. , uint16_t(m_width)
  565. , uint16_t(m_height)
  566. );
  567. showExampleDialog(this);
  568. imguiEndFrame();
  569. int64_t now = bx::getHPCounter() - m_timeOffset;
  570. static int64_t last = now;
  571. const int64_t frameTime = now - last;
  572. last = now;
  573. const double freq = double(bx::getHPFrequency() );
  574. const float deltaTime = float(frameTime/freq);
  575. // Update camera.
  576. cameraUpdate(deltaTime, m_mouseState);
  577. float view[16];
  578. cameraGetViewMtx(view);
  579. float proj[16];
  580. // Set view and projection matrix for view 0.
  581. {
  582. bx::mtxProj(proj, 60.0f, float(m_width)/float(m_height), 0.1f, 100.0f, bgfx::getCaps()->homogeneousDepth);
  583. bgfx::setViewTransform(0, view, proj);
  584. bgfx::setViewRect(0, 0, 0, uint16_t(m_width), uint16_t(m_height) );
  585. }
  586. float mtxVp[16];
  587. bx::mtxMul(mtxVp, view, proj);
  588. float mtxInvVp[16];
  589. bx::mtxInverse(mtxInvVp, mtxVp);
  590. const bx::Vec3 at = { 0.0f, 0.0f, 0.0f };
  591. const bx::Vec3 eye = { 5.0f, 10.0f, 5.0f };
  592. bx::mtxLookAt(view, eye, at);
  593. bx::mtxProj(proj, 45.0f, float(m_width)/float(m_height), 1.0f, 15.0f, bgfx::getCaps()->homogeneousDepth);
  594. bx::mtxMul(mtxVp, view, proj);
  595. Ray ray = makeRay(
  596. (float(m_mouseState.m_mx)/float(m_width) * 2.0f - 1.0f)
  597. , -(float(m_mouseState.m_my)/float(m_height) * 2.0f - 1.0f)
  598. , mtxInvVp
  599. );
  600. constexpr uint32_t kSelected = 0xff80ffff;
  601. constexpr uint32_t kOverlap = 0xff0000ff;
  602. DebugDrawEncoder dde;
  603. dde.begin(0);
  604. dde.drawAxis(0.0f, 0.0f, 0.0f);
  605. dde.push();
  606. Aabb aabb =
  607. {
  608. { 5.0f, 1.0f, 1.0f },
  609. { 10.0f, 5.0f, 5.0f },
  610. };
  611. dde.setWireframe(true);
  612. dde.setColor(intersect(&dde, ray, aabb) ? kSelected : 0xff00ff00);
  613. dde.draw(aabb);
  614. dde.pop();
  615. float time = float(now/freq);
  616. Obb obb;
  617. bx::mtxRotateX(obb.mtx, time);
  618. dde.setWireframe(true);
  619. dde.setColor(intersect(&dde, ray, obb) ? kSelected : 0xffffffff);
  620. dde.draw(obb);
  621. bx::mtxSRT(obb.mtx, 1.0f, 1.0f, 1.0f, time*0.23f, time, 0.0f, 3.0f, 0.0f, 0.0f);
  622. dde.push();
  623. toAabb(aabb, obb);
  624. dde.setWireframe(true);
  625. dde.setColor(0xff0000ff);
  626. dde.draw(aabb);
  627. dde.pop();
  628. dde.setWireframe(false);
  629. dde.setColor(intersect(&dde, ray, obb) ? kSelected : 0xffffffff);
  630. dde.draw(obb);
  631. dde.setColor(0xffffffff);
  632. dde.push();
  633. {
  634. float bunny[16];
  635. bx::mtxSRT(bunny, 0.03f, 0.03f, 0.03f, 0.0f, 0.0f, 0.0f, -3.0f, 0.0f, 0.0f);
  636. dde.setTransform(bunny);
  637. const bool wireframe = bx::mod(time, 2.0f) > 1.0f;
  638. dde.setWireframe(wireframe);
  639. dde.setColor(wireframe ? 0xffff00ff : 0xff00ff00);
  640. dde.draw(m_bunny);
  641. dde.setTransform(NULL);
  642. }
  643. dde.pop();
  644. {
  645. const bx::Vec3 normal = { 0.0f, 1.0f, 0.0f };
  646. const bx::Vec3 pos = { 0.0f, -2.0f, 0.0f };
  647. bx::Plane plane;
  648. bx::calcPlane(plane, normal, pos);
  649. dde.setColor(false
  650. || intersect(&dde, ray, plane)
  651. ? kSelected
  652. : 0xffffffff
  653. );
  654. dde.drawGrid(Axis::Y, pos, 128, 1.0f);
  655. }
  656. dde.drawFrustum(mtxVp);
  657. dde.push();
  658. Sphere sphere = { { 0.0f, 5.0f, 0.0f }, 1.0f };
  659. dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xfff0c0ff);
  660. dde.setWireframe(true);
  661. dde.setLod(3);
  662. dde.draw(sphere);
  663. dde.setWireframe(false);
  664. sphere.center.x = -2.0f;
  665. dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xc0ffc0ff);
  666. dde.setLod(2);
  667. dde.draw(sphere);
  668. sphere.center.x = -4.0f;
  669. dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xa0f0ffff);
  670. dde.setLod(1);
  671. dde.draw(sphere);
  672. sphere.center.x = -6.0f;
  673. dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xffc0ff00);
  674. dde.setLod(0);
  675. dde.draw(sphere);
  676. dde.pop();
  677. dde.setColor(0xffffffff);
  678. dde.push();
  679. {
  680. const bx::Vec3 normal = { 0.0f, 0.0f, 1.0f };
  681. const bx::Vec3 center = { -8.0f, 0.0f, 0.0f };
  682. dde.push();
  683. dde.setStipple(true, 1.0f, time*0.1f);
  684. dde.setColor(0xff0000ff);
  685. dde.drawCircle(normal, center, 1.0f, 0.5f + bx::sin(time*10.0f) );
  686. dde.pop();
  687. dde.setSpin(time);
  688. dde.drawQuad(m_sprite, normal, center, 2.0f);
  689. }
  690. dde.pop();
  691. dde.push();
  692. dde.setStipple(true, 1.0f, -time*0.1f);
  693. dde.drawCircle(Axis::Z, -8.0f, 0.0f, 0.0f, 1.25f, 2.0f);
  694. dde.pop();
  695. dde.push();
  696. dde.setLod(UINT8_MAX);
  697. dde.push();
  698. dde.setSpin(time*0.3f);
  699. {
  700. Cone cone =
  701. {
  702. { -11.0f, 4.0f, 0.0f },
  703. { -13.0f, 6.0f, 1.0f },
  704. 1.0f
  705. };
  706. Cylinder cylinder =
  707. {
  708. { -9.0f, 2.0f, -1.0f },
  709. { -11.0f, 4.0f, 0.0f },
  710. 0.5f
  711. };
  712. dde.setColor(false
  713. || intersect(&dde, ray, cone)
  714. || intersect(&dde, ray, cylinder)
  715. ? kSelected
  716. : 0xffffffff
  717. );
  718. dde.draw(cone);
  719. dde.draw(cylinder);
  720. }
  721. dde.pop();
  722. {
  723. dde.setLod(0);
  724. Capsule capsule =
  725. {
  726. { 0.0f, 7.0f, 0.0f },
  727. { -6.0f, 7.0f, 0.0f },
  728. 0.5f
  729. };
  730. dde.setColor(intersect(&dde, ray, capsule) ? kSelected : 0xffffffff);
  731. dde.draw(capsule);
  732. }
  733. dde.pop();
  734. dde.push();
  735. float mtx[16];
  736. bx::mtxSRT(mtx
  737. , 1.0f, 1.0f, 1.0f
  738. , 0.0f, time, time*0.53f
  739. , -10.0f, 1.0f, 10.0f
  740. );
  741. Cylinder cylinder =
  742. {
  743. { -10.0f, 1.0f, 10.0f },
  744. { 0.0f, 0.0f, 0.0f },
  745. 1.0f
  746. };
  747. cylinder.end = bx::mul({ 0.0f, 4.0f, 0.0f }, mtx);
  748. dde.setColor(intersect(&dde, ray, cylinder) ? kSelected : 0xffffffff);
  749. dde.draw(cylinder);
  750. dde.push();
  751. toAabb(aabb, cylinder);
  752. dde.setWireframe(true);
  753. dde.setColor(0xff0000ff);
  754. dde.draw(aabb);
  755. dde.pop();
  756. dde.pop();
  757. dde.drawOrb(-11.0f, 0.0f, 0.0f, 1.0f);
  758. dde.push();
  759. {
  760. bool olp;
  761. constexpr float kStepX = 3.0f;
  762. constexpr float kStepZ = 3.0f;
  763. const float px = 0.0f;
  764. const float py = 1.0f;
  765. const float pz = 10.0f;
  766. const float xx = bx::sin(time*0.39f) * 1.03f + px;
  767. const float yy = bx::cos(time*0.79f) * 1.03f + py;
  768. const float zz = bx::cos(time) * 1.03f + pz;
  769. // Sphere ---
  770. {
  771. Sphere sphereA = { { px+kStepX*0.0f, py, pz+kStepZ*0.0f }, 0.5f };
  772. Sphere sphereB = { { xx+kStepX*0.0f, yy, zz+kStepZ*0.0f }, 0.5f };
  773. olp = overlap(sphereA, sphereB);;
  774. dde.setColor(olp ? kOverlap : 0xffffffff);
  775. dde.setWireframe(false);
  776. dde.draw(sphereA);
  777. dde.setColor(olp ? kOverlap : 0xffffffff);
  778. dde.setWireframe(true);
  779. dde.draw(sphereB);
  780. }
  781. {
  782. Sphere sphereA = { { px+kStepX*1.0f, py, pz+kStepZ*0.0f }, 0.5f };
  783. Aabb aabbB;
  784. toAabb(aabbB, { xx+kStepX*1.0f, yy, zz+kStepZ*0.0f }, { 0.5f, 0.5f, 0.5f });
  785. olp = overlap(sphereA, aabbB);
  786. dde.setColor(olp ? kOverlap : 0xffffffff);
  787. dde.setWireframe(false);
  788. dde.draw(sphereA);
  789. dde.setColor(olp ? kOverlap : 0xffffffff);
  790. dde.setWireframe(true);
  791. dde.draw(aabbB);
  792. }
  793. {
  794. Sphere sphereA = { { px+kStepX*2.0f, py, pz+kStepZ*0.0f }, 0.5f };
  795. Triangle triangleB =
  796. {
  797. { xx-0.4f, yy+0.0f, zz-0.4f },
  798. { xx-0.5f, yy-0.3f, zz+0.0f },
  799. { xx+0.3f, yy+0.5f, zz+0.0f },
  800. };
  801. translate(triangleB, {kStepX*2.0f, 0.0f, kStepZ*0.0f});
  802. olp = overlap(sphereA, triangleB);
  803. dde.setColor(olp ? kOverlap : 0xffffffff);
  804. dde.setWireframe(false);
  805. dde.draw(sphereA);
  806. dde.setColor(olp ? kOverlap : 0xffffffff);
  807. dde.setWireframe(true);
  808. dde.draw(triangleB);
  809. }
  810. {
  811. Sphere sphereA = { { px+kStepX*3.0f, py, pz+kStepZ*0.0f }, 0.5f };
  812. Triangle triangleB =
  813. {
  814. { xx-0.4f, yy+0.0f, zz-0.4f },
  815. { xx-0.5f, yy-0.3f, zz+0.0f },
  816. { xx+0.3f, yy+0.5f, zz+0.0f },
  817. };
  818. translate(triangleB, {kStepX*3.0f, 0.0f, kStepZ*0.0f});
  819. bx::Plane planeB;
  820. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  821. olp = overlap(sphereA, planeB);
  822. dde.setColor(olp ? kOverlap : 0xffffffff);
  823. dde.setWireframe(false);
  824. dde.draw(sphereA);
  825. dde.setColor(olp ? kOverlap : 0xffffffff);
  826. dde.setWireframe(true);
  827. dde.drawGrid(planeB.normal, triangleB.v0, 10, 0.3f);
  828. }
  829. {
  830. Sphere sphereA = { { px+kStepX*4.0f, py, pz+kStepZ*0.0f }, 0.5f };
  831. Triangle triangleB =
  832. {
  833. { xx-0.4f, yy+0.0f, zz-0.4f },
  834. { xx-0.5f, yy-0.3f, zz+0.0f },
  835. { xx+0.3f, yy+0.5f, zz+0.0f },
  836. };
  837. translate(triangleB, {kStepX*4.0f, 0.0f, kStepZ*0.0f});
  838. bx::Plane planeB;
  839. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  840. const Disk diskB = { getCenter(triangleB), planeB.normal, 0.5f };
  841. olp = overlap(sphereA, diskB);
  842. dde.setColor(olp ? kOverlap : 0xffffffff);
  843. dde.setWireframe(false);
  844. dde.draw(sphereA);
  845. dde.setColor(olp ? kOverlap : 0xffffffff);
  846. dde.setWireframe(true);
  847. dde.draw(diskB);
  848. }
  849. // AABB ---
  850. {
  851. Aabb aabbA, aabbB;
  852. toAabb(aabbA, { px+kStepX*1.0f, py, pz+kStepZ*1.0f }, { 0.5f, 0.5f, 0.5f });
  853. toAabb(aabbB, { xx+kStepX*1.0f, yy, zz+kStepZ*1.0f }, { 0.5f, 0.5f, 0.5f });
  854. olp = overlap(aabbA, aabbB);
  855. dde.setColor(olp ? kOverlap : 0xffffffff);
  856. dde.setWireframe(false);
  857. dde.draw(aabbA);
  858. dde.setColor(olp ? kOverlap : 0xffffffff);
  859. dde.setWireframe(true);
  860. dde.draw(aabbB);
  861. }
  862. {
  863. Aabb aabbA;
  864. toAabb(aabbA, { px+kStepX*2.0f, py, pz+kStepZ*1.0f }, { 0.5f, 0.5f, 0.5f });
  865. Triangle triangleB =
  866. {
  867. { xx-0.4f, yy+0.0f, zz-0.4f },
  868. { xx-0.5f, yy-0.3f, zz+0.0f },
  869. { xx+0.3f, yy+0.5f, zz+0.0f },
  870. };
  871. translate(triangleB, {kStepX*2.0f, 0.0f, kStepZ*1.0f});
  872. olp = overlap(aabbA, triangleB);
  873. dde.setColor(olp ? kOverlap : 0xffffffff);
  874. dde.setWireframe(false);
  875. dde.draw(aabbA);
  876. dde.setColor(olp ? kOverlap : 0xffffffff);
  877. dde.setWireframe(true);
  878. dde.draw(triangleB);
  879. }
  880. {
  881. Aabb aabbA;
  882. toAabb(aabbA, { px+kStepX*3.0f, py, pz+kStepZ*1.0f }, { 0.5f, 0.5f, 0.5f });
  883. Triangle triangleB =
  884. {
  885. { xx-0.4f, yy+0.0f, zz-0.4f },
  886. { xx-0.5f, yy-0.3f, zz+0.0f },
  887. { xx+0.3f, yy+0.5f, zz+0.0f },
  888. };
  889. translate(triangleB, {kStepX*3.0f, 0.0f, kStepZ*1.0f});
  890. bx::Plane planeB;
  891. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  892. olp = overlap(aabbA, planeB);
  893. dde.setColor(olp ? kOverlap : 0xffffffff);
  894. dde.setWireframe(false);
  895. dde.draw(aabbA);
  896. dde.setColor(olp ? kOverlap : 0xffffffff);
  897. dde.setWireframe(true);
  898. dde.drawGrid(planeB.normal, triangleB.v0, 10, 0.3f);
  899. }
  900. {
  901. Aabb aabbA;
  902. toAabb(aabbA, { px+kStepX*4.0f, py, pz+kStepZ*1.0f }, { 0.5f, 0.5f, 0.5f });
  903. Triangle triangleB =
  904. {
  905. { xx-0.4f, yy+0.0f, zz-0.4f },
  906. { xx-0.5f, yy-0.3f, zz+0.0f },
  907. { xx+0.3f, yy+0.5f, zz+0.0f },
  908. };
  909. translate(triangleB, {kStepX*4.0f, 0.0f, kStepZ*1.0f});
  910. bx::Plane planeB;
  911. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  912. const Disk diskB = { getCenter(triangleB), planeB.normal, 0.5f };
  913. olp = overlap(aabbA, diskB);
  914. dde.setColor(olp ? kOverlap : 0xffffffff);
  915. dde.setWireframe(false);
  916. dde.draw(aabbA);
  917. dde.setColor(olp ? kOverlap : 0xffffffff);
  918. dde.setWireframe(true);
  919. dde.draw(diskB);
  920. }
  921. // Triangle ---
  922. {
  923. Triangle triangleA =
  924. {
  925. { px-0.4f, py+0.0f, pz-0.4f },
  926. { px+0.0f, py-0.3f, pz-0.5f },
  927. { px+0.0f, py+0.5f, pz+0.3f },
  928. };
  929. translate(triangleA, {kStepX*2.0f, 0.0f, kStepZ*2.0f});
  930. Triangle triangleB =
  931. {
  932. { xx-0.4f, yy+0.0f, zz-0.4f },
  933. { xx-0.5f, yy-0.3f, zz+0.0f },
  934. { xx+0.3f, yy+0.5f, zz+0.0f },
  935. };
  936. translate(triangleB, {kStepX*2.0f, 0.0f, kStepZ*2.0f});
  937. olp = overlap(triangleA, triangleB);
  938. dde.setColor(olp ? kOverlap : 0xffffffff);
  939. dde.setWireframe(false);
  940. dde.draw(triangleA);
  941. dde.setColor(olp ? kOverlap : 0xffffffff);
  942. dde.setWireframe(true);
  943. dde.draw(triangleB);
  944. }
  945. {
  946. Triangle triangleA =
  947. {
  948. { px-0.4f, py+0.0f, pz-0.4f },
  949. { px+0.0f, py-0.3f, pz-0.5f },
  950. { px+0.0f, py+0.5f, pz+0.3f },
  951. };
  952. translate(triangleA, {kStepX*3.0f, 0.0f, kStepZ*2.0f});
  953. Triangle triangleB =
  954. {
  955. { xx-0.4f, yy+0.0f, zz-0.4f },
  956. { xx-0.5f, yy-0.3f, zz+0.0f },
  957. { xx+0.3f, yy+0.5f, zz+0.0f },
  958. };
  959. translate(triangleB, {kStepX*3.0f, 0.0f, kStepZ*2.0f});
  960. bx::Plane planeB;
  961. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  962. olp = overlap(triangleA, planeB);
  963. dde.setColor(olp ? kOverlap : 0xffffffff);
  964. dde.setWireframe(false);
  965. dde.draw(triangleA);
  966. dde.setColor(olp ? kOverlap : 0xffffffff);
  967. dde.setWireframe(true);
  968. dde.drawGrid(planeB.normal, triangleB.v0, 10, 0.3f);
  969. }
  970. {
  971. Triangle triangleA =
  972. {
  973. { px-0.4f, py+0.0f, pz-0.4f },
  974. { px+0.0f, py-0.3f, pz-0.5f },
  975. { px+0.0f, py+0.5f, pz+0.3f },
  976. };
  977. translate(triangleA, {kStepX*4.0f, 0.0f, kStepZ*2.0f});
  978. Triangle triangleB =
  979. {
  980. { xx-0.4f, yy+0.0f, zz-0.4f },
  981. { xx-0.5f, yy-0.3f, zz+0.0f },
  982. { xx+0.3f, yy+0.5f, zz+0.0f },
  983. };
  984. translate(triangleB, {kStepX*4.0f, 0.0f, kStepZ*2.0f});
  985. bx::Plane planeB;
  986. bx::calcPlane(planeB, triangleB.v0, triangleB.v1, triangleB.v2);
  987. const Disk diskB = { getCenter(triangleB), planeB.normal, 0.5f };
  988. olp = overlap(triangleA, diskB);
  989. dde.setColor(olp ? kOverlap : 0xffffffff);
  990. dde.setWireframe(false);
  991. dde.draw(triangleA);
  992. dde.setColor(olp ? kOverlap : 0xffffffff);
  993. dde.setWireframe(true);
  994. dde.draw(diskB);
  995. }
  996. }
  997. dde.pop();
  998. dde.end();
  999. // Advance to next frame. Rendering thread will be kicked to
  1000. // process submitted rendering primitives.
  1001. bgfx::frame();
  1002. return true;
  1003. }
  1004. return false;
  1005. }
  1006. entry::MouseState m_mouseState;
  1007. SpriteHandle m_sprite;
  1008. GeometryHandle m_bunny;
  1009. int64_t m_timeOffset;
  1010. uint32_t m_width;
  1011. uint32_t m_height;
  1012. uint32_t m_debug;
  1013. uint32_t m_reset;
  1014. };
  1015. } // namespace
  1016. ENTRY_IMPLEMENT_MAIN(ExampleDebugDraw, "29-debugdraw", "Debug draw.");