debugdraw.cpp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865
  1. /*
  2. * Copyright 2011-2018 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. class ExampleDebugDraw : public entry::AppI
  474. {
  475. public:
  476. ExampleDebugDraw(const char* _name, const char* _description)
  477. : entry::AppI(_name, _description)
  478. {
  479. }
  480. void init(int32_t _argc, const char* const* _argv, uint32_t _width, uint32_t _height) override
  481. {
  482. Args args(_argc, _argv);
  483. m_width = _width;
  484. m_height = _height;
  485. m_debug = BGFX_DEBUG_NONE;
  486. m_reset = BGFX_RESET_VSYNC | BGFX_RESET_MSAA_X16;
  487. bgfx::Init init;
  488. init.type = args.m_type;
  489. init.vendorId = args.m_pciId;
  490. init.resolution.width = m_width;
  491. init.resolution.height = m_height;
  492. init.resolution.reset = m_reset;
  493. bgfx::init(init);
  494. // Enable m_debug text.
  495. bgfx::setDebug(m_debug);
  496. // Set view 0 clear state.
  497. bgfx::setViewClear(0
  498. , BGFX_CLEAR_COLOR|BGFX_CLEAR_DEPTH
  499. , 0x303030ff
  500. , 1.0f
  501. , 0
  502. );
  503. m_timeOffset = bx::getHPCounter();
  504. cameraCreate();
  505. const float initialPos[3] = { 0.0f, 2.0f, -12.0f };
  506. cameraSetPosition(initialPos);
  507. cameraSetVerticalAngle(0.0f);
  508. ddInit();
  509. uint8_t data[32*32*4];
  510. imageCheckerboard(data, 32, 32, 4, 0xff808080, 0xffc0c0c0);
  511. m_sprite = ddCreateSprite(32, 32, data);
  512. m_bunny = ddCreateGeometry(
  513. BX_COUNTOF(s_bunnyVertices)
  514. , s_bunnyVertices
  515. , BX_COUNTOF(s_bunnyTriList)
  516. , s_bunnyTriList
  517. );
  518. imguiCreate();
  519. }
  520. virtual int shutdown() override
  521. {
  522. imguiDestroy();
  523. ddDestroy(m_bunny);
  524. ddDestroy(m_sprite);
  525. ddShutdown();
  526. cameraDestroy();
  527. // Shutdown bgfx.
  528. bgfx::shutdown();
  529. return 0;
  530. }
  531. template<typename Ty>
  532. bool intersect(DebugDrawEncoder* _dde, const Ray& _ray, const Ty& _shape)
  533. {
  534. Hit hit;
  535. if (::intersect(_ray, _shape, &hit) )
  536. {
  537. _dde->push();
  538. _dde->setWireframe(false);
  539. _dde->setColor(0xff0000ff);
  540. const bx::Vec3 tmp = bx::mul(hit.m_normal, 0.7f);
  541. const bx::Vec3 end = bx::add(hit.m_pos, tmp);
  542. _dde->drawCone(&hit.m_pos.x, &end.x, 0.1f);
  543. _dde->pop();
  544. return true;
  545. }
  546. return false;
  547. }
  548. bool update() override
  549. {
  550. if (!entry::processEvents(m_width, m_height, m_debug, m_reset, &m_mouseState) )
  551. {
  552. imguiBeginFrame(
  553. m_mouseState.m_mx
  554. , m_mouseState.m_my
  555. , (m_mouseState.m_buttons[entry::MouseButton::Left ] ? IMGUI_MBUT_LEFT : 0)
  556. | (m_mouseState.m_buttons[entry::MouseButton::Right ] ? IMGUI_MBUT_RIGHT : 0)
  557. | (m_mouseState.m_buttons[entry::MouseButton::Middle] ? IMGUI_MBUT_MIDDLE : 0)
  558. , m_mouseState.m_mz
  559. , uint16_t(m_width)
  560. , uint16_t(m_height)
  561. );
  562. showExampleDialog(this);
  563. imguiEndFrame();
  564. int64_t now = bx::getHPCounter() - m_timeOffset;
  565. static int64_t last = now;
  566. const int64_t frameTime = now - last;
  567. last = now;
  568. const double freq = double(bx::getHPFrequency() );
  569. const float deltaTime = float(frameTime/freq);
  570. // Update camera.
  571. cameraUpdate(deltaTime, m_mouseState);
  572. float view[16];
  573. cameraGetViewMtx(view);
  574. float proj[16];
  575. // Set view and projection matrix for view 0.
  576. {
  577. bx::mtxProj(proj, 60.0f, float(m_width)/float(m_height), 0.1f, 100.0f, bgfx::getCaps()->homogeneousDepth);
  578. bgfx::setViewTransform(0, view, proj);
  579. bgfx::setViewRect(0, 0, 0, uint16_t(m_width), uint16_t(m_height) );
  580. }
  581. float mtxVp[16];
  582. bx::mtxMul(mtxVp, view, proj);
  583. float mtxInvVp[16];
  584. bx::mtxInverse(mtxInvVp, mtxVp);
  585. const bx::Vec3 at = { 0.0f, 0.0f, 0.0f };
  586. const bx::Vec3 eye = { 5.0f, 10.0f, 5.0f };
  587. bx::mtxLookAt(view, eye, at);
  588. bx::mtxProj(proj, 45.0f, float(m_width)/float(m_height), 1.0f, 15.0f, bgfx::getCaps()->homogeneousDepth);
  589. bx::mtxMul(mtxVp, view, proj);
  590. Ray ray = makeRay(
  591. (float(m_mouseState.m_mx)/float(m_width) * 2.0f - 1.0f)
  592. , -(float(m_mouseState.m_my)/float(m_height) * 2.0f - 1.0f)
  593. , mtxInvVp
  594. );
  595. const uint32_t selected = 0xff80ffff;
  596. DebugDrawEncoder dde;
  597. dde.begin(0);
  598. dde.drawAxis(0.0f, 0.0f, 0.0f);
  599. dde.push();
  600. Aabb aabb =
  601. {
  602. { 5.0f, 1.0f, 1.0f },
  603. { 10.0f, 5.0f, 5.0f },
  604. };
  605. dde.setWireframe(true);
  606. dde.setColor(intersect(&dde, ray, aabb) ? selected : 0xff00ff00);
  607. dde.draw(aabb);
  608. dde.pop();
  609. float time = float(now/freq);
  610. Obb obb;
  611. bx::mtxRotateX(obb.m_mtx, time);
  612. dde.setWireframe(true);
  613. dde.setColor(intersect(&dde, ray, obb) ? selected : 0xffffffff);
  614. dde.draw(obb);
  615. bx::mtxSRT(obb.m_mtx, 1.0f, 1.0f, 1.0f, time*0.23f, time, 0.0f, 3.0f, 0.0f, 0.0f);
  616. dde.push();
  617. toAabb(aabb, obb);
  618. dde.setWireframe(true);
  619. dde.setColor(0xff0000ff);
  620. dde.draw(aabb);
  621. dde.pop();
  622. dde.setWireframe(false);
  623. dde.setColor(intersect(&dde, ray, obb) ? selected : 0xffffffff);
  624. dde.draw(obb);
  625. dde.setColor(0xffffffff);
  626. dde.push();
  627. {
  628. float bunny[16];
  629. bx::mtxSRT(bunny, 0.03f, 0.03f, 0.03f, 0.0f, 0.0f, 0.0f, -3.0f, 0.0f, 0.0f);
  630. dde.setTransform(bunny);
  631. const bool wireframe = bx::mod(time, 2.0f) > 1.0f;
  632. dde.setWireframe(wireframe);
  633. dde.setColor(wireframe ? 0xffff00ff : 0xff00ff00);
  634. dde.draw(m_bunny);
  635. dde.setTransform(NULL);
  636. }
  637. dde.pop();
  638. {
  639. const float normal[] = { 0.0f, 1.0f, 0.0f };
  640. const float pos[] = { 0.0f, -2.0f, 0.0f };
  641. Plane plane;
  642. bx::calcPlane(&plane.m_normal.x, normal, pos);
  643. dde.setColor(false
  644. || intersect(&dde, ray, plane)
  645. ? selected
  646. : 0xffffffff
  647. );
  648. dde.drawGrid(Axis::Y, pos, 20, 1.0f);
  649. }
  650. dde.drawFrustum(mtxVp);
  651. dde.push();
  652. Sphere sphere = { { 0.0f, 5.0f, 0.0f }, 1.0f };
  653. dde.setColor(intersect(&dde, ray, sphere) ? selected : 0xfff0c0ff);
  654. dde.setWireframe(true);
  655. dde.setLod(3);
  656. dde.draw(sphere);
  657. dde.setWireframe(false);
  658. sphere.m_center.x = -2.0f;
  659. dde.setColor(intersect(&dde, ray, sphere) ? selected : 0xc0ffc0ff);
  660. dde.setLod(2);
  661. dde.draw(sphere);
  662. sphere.m_center.x = -4.0f;
  663. dde.setColor(intersect(&dde, ray, sphere) ? selected : 0xa0f0ffff);
  664. dde.setLod(1);
  665. dde.draw(sphere);
  666. sphere.m_center.x = -6.0f;
  667. dde.setColor(intersect(&dde, ray, sphere) ? selected : 0xffc0ff00);
  668. dde.setLod(0);
  669. dde.draw(sphere);
  670. dde.pop();
  671. dde.setColor(0xffffffff);
  672. dde.push();
  673. {
  674. float normal[3] = { 0.0f, 0.0f, 1.0f };
  675. float center[3] = { -8.0f, 0.0f, 0.0f };
  676. dde.push();
  677. dde.setStipple(true, 1.0f, time*0.1f);
  678. dde.setColor(0xff0000ff);
  679. dde.drawCircle(normal, center, 1.0f, 0.5f + bx::sin(time*10.0f) );
  680. dde.pop();
  681. dde.setSpin(time);
  682. dde.drawQuad(m_sprite, normal, center, 2.0f);
  683. }
  684. dde.pop();
  685. dde.push();
  686. dde.setStipple(true, 1.0f, -time*0.1f);
  687. dde.drawCircle(Axis::Z, -8.0f, 0.0f, 0.0f, 1.25f, 2.0f);
  688. dde.pop();
  689. dde.push();
  690. dde.setLod(UINT8_MAX);
  691. dde.push();
  692. dde.setSpin(time*0.3f);
  693. {
  694. Cone cone =
  695. {
  696. { -11.0f, 4.0f, 0.0f },
  697. { -13.0f, 6.0f, 1.0f },
  698. 1.0f
  699. };
  700. Cylinder cylinder =
  701. {
  702. { -9.0f, 2.0f, -1.0f },
  703. { -11.0f, 4.0f, 0.0f },
  704. 0.5f
  705. };
  706. dde.setColor(false
  707. || intersect(&dde, ray, cone)
  708. || intersect(&dde, ray, cylinder)
  709. ? selected
  710. : 0xffffffff
  711. );
  712. dde.draw(cone);
  713. dde.draw(cylinder);
  714. }
  715. dde.pop();
  716. {
  717. dde.setLod(0);
  718. Capsule capsule =
  719. {
  720. { 0.0f, 7.0f, 0.0f },
  721. { -6.0f, 7.0f, 0.0f },
  722. 0.5f
  723. };
  724. dde.setColor(intersect(&dde, ray, capsule) ? selected : 0xffffffff);
  725. dde.draw(capsule);
  726. }
  727. dde.pop();
  728. dde.push();
  729. float mtx[16];
  730. bx::mtxSRT(mtx
  731. , 1.0f, 1.0f, 1.0f
  732. , 0.0f, time, time*0.53f
  733. , -10.0f, 1.0f, 10.0f
  734. );
  735. Cylinder cylinder =
  736. {
  737. { -10.0f, 1.0f, 10.0f },
  738. { 0.0f, 0.0f, 0.0f },
  739. 1.0f
  740. };
  741. float up[3] = { 0.0f, 4.0f, 0.0f };
  742. bx::vec3MulMtx(&cylinder.m_end.x, up, mtx);
  743. dde.setColor(intersect(&dde, ray, cylinder) ? selected : 0xffffffff);
  744. dde.draw(cylinder);
  745. dde.push();
  746. toAabb(aabb, cylinder);
  747. dde.setWireframe(true);
  748. dde.setColor(0xff0000ff);
  749. dde.draw(aabb);
  750. dde.pop();
  751. dde.pop();
  752. dde.drawOrb(-11.0f, 0.0f, 0.0f, 1.0f);
  753. dde.end();
  754. // Advance to next frame. Rendering thread will be kicked to
  755. // process submitted rendering primitives.
  756. bgfx::frame();
  757. return true;
  758. }
  759. return false;
  760. }
  761. entry::MouseState m_mouseState;
  762. SpriteHandle m_sprite;
  763. GeometryHandle m_bunny;
  764. int64_t m_timeOffset;
  765. uint32_t m_width;
  766. uint32_t m_height;
  767. uint32_t m_debug;
  768. uint32_t m_reset;
  769. };
  770. } // namespace
  771. ENTRY_IMPLEMENT_MAIN(ExampleDebugDraw, "29-debugdraw", "Debug draw.");