| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235 |
- /*
- * Copyright 2011-2023 Branimir Karadzic. All rights reserved.
- * License: https://github.com/bkaradzic/bgfx/blob/master/LICENSE
- */
- #include "common.h"
- #include "bgfx_utils.h"
- #include <entry/cmd.h>
- #include <entry/input.h>
- #include <debugdraw/debugdraw.h>
- #include "camera.h"
- #include "imgui/imgui.h"
- #include <bx/uint32_t.h>
- namespace
- {
- static DdVertex s_bunnyVertices[] =
- {
- { 25.0883f, -44.2788f, 31.0055f },
- { 0.945623f, 53.5504f, -24.6146f },
- { -0.94455f, -14.3443f, -16.8223f },
- { -20.1103f, -48.6664f, 12.6763f },
- { -1.60652f, -26.3165f, -24.5424f },
- { -30.6284f, -53.6299f, 14.7666f },
- { 1.69145f, -43.8075f, -15.2065f },
- { -20.5139f, 21.0521f, -5.40868f },
- { -13.9518f, 53.6299f, -39.1193f },
- { -21.7912f, 48.7801f, -42.0995f },
- { -26.8408f, 23.6537f, -17.7324f },
- { -23.1196f, 33.9692f, 4.91483f },
- { -12.3236f, -41.6303f, 31.8324f },
- { 27.6427f, -5.05034f, -11.3201f },
- { 32.2565f, 1.30521f, 30.2671f },
- { 47.2723f, -27.0974f, 11.1774f },
- { 33.598f, 10.5888f, 7.95916f },
- { -13.2898f, 12.6234f, 5.55953f },
- { -32.7364f, 19.0648f, -10.5736f },
- { -32.7536f, 31.4158f, -1.40712f },
- { -25.3672f, 30.2874f, -12.4682f },
- { 32.921f, -36.8408f, -12.0254f },
- { -37.7251f, -33.8989f, 0.378443f },
- { -35.6341f, -0.246891f, -9.25165f },
- { -16.7041f, -50.0254f, -15.6177f },
- { 24.6604f, -53.5319f, -11.1059f },
- { -7.77574f, -53.5719f, -16.6655f },
- { 20.6241f, 13.3489f, 0.376349f },
- { -44.2889f, 29.5222f, 18.7918f },
- { 18.5805f, 16.3651f, 12.6351f },
- { -23.7853f, 31.7598f, -6.54093f },
- { 24.7518f, -53.5075f, 2.14984f },
- { -45.7912f, -17.6301f, 21.1198f },
- { 51.8403f, -33.1847f, 24.3337f },
- { -47.5343f, -4.32792f, 4.06232f },
- { -50.6832f, -12.442f, 11.0994f },
- { -49.5132f, 19.2782f, 3.17559f },
- { -39.4881f, 29.0208f, -6.70431f },
- { -52.7286f, 1.23232f, 9.74872f },
- { 26.505f, -16.1297f, -17.0487f },
- { -25.367f, 20.0473f, -8.44282f },
- { -24.5797f, -10.3143f, -18.3154f },
- { -28.6707f, 6.12074f, 27.8025f },
- { -16.9868f, 22.6819f, 1.37408f },
- { -37.2678f, 23.9443f, -9.4945f },
- { -24.8562f, 21.3763f, 18.8847f },
- { -47.1879f, 3.8542f, -4.74621f },
- { 38.0706f, -7.33673f, -7.6099f },
- { -34.8833f, -3.57074f, 26.4838f },
- { 12.3797f, 5.46782f, 32.9762f },
- { -31.5974f, -22.956f, 30.5827f },
- { -6.80953f, 48.055f, -18.5116f },
- { 6.3474f, -15.1622f, -24.4726f },
- { -25.5733f, 25.2452f, -34.4736f },
- { -23.8955f, 31.8323f, -40.8696f },
- { -11.8622f, 38.2304f, -43.3125f },
- { -20.4918f, 41.2409f, -3.11271f },
- { 24.9806f, -8.53455f, 37.2862f },
- { -52.8935f, 5.3376f, 28.246f },
- { 34.106f, -41.7941f, 30.962f },
- { -1.26914f, 35.6664f, -18.7177f },
- { -0.13048f, 44.7288f, -28.7163f },
- { 2.47929f, 0.678165f, -14.6892f },
- { -31.8649f, -14.2299f, 32.2998f },
- { -19.774f, 30.8258f, 5.77293f },
- { 49.8059f, -37.125f, 4.97284f },
- { -28.0581f, -26.439f, -14.8316f },
- { -9.12066f, -27.3987f, -12.8592f },
- { -13.8752f, -29.9821f, 32.5962f },
- { -6.6222f, -10.9884f, 33.5007f },
- { -21.2664f, -53.6089f, -3.49195f },
- { -0.628672f, 52.8093f, -9.88088f },
- { 8.02417f, 51.8956f, -21.5834f },
- { -44.6547f, 11.9973f, 34.7897f },
- { -7.55466f, 37.9035f, -0.574101f },
- { 52.8252f, -27.1986f, 11.6429f },
- { -0.934591f, 9.81861f, 0.512566f },
- { -3.01043f, 5.70605f, 22.0954f },
- { -34.6337f, 44.5964f, -31.1713f },
- { -26.9017f, 35.1991f, -32.4307f },
- { 15.9884f, -8.92223f, -14.7411f },
- { -22.8337f, -43.458f, 26.7274f },
- { -31.9864f, -47.0243f, 9.36972f },
- { -36.9436f, 24.1866f, 29.2521f },
- { -26.5411f, 29.6549f, 21.2867f },
- { 33.7644f, -24.1886f, -13.8513f },
- { -2.44749f, -17.0148f, 41.6617f },
- { -38.364f, -13.9823f, -12.5705f },
- { -10.2972f, -51.6584f, 38.935f },
- { 1.28109f, -43.4943f, 36.6288f },
- { -19.7784f, -44.0413f, -4.23994f },
- { 37.0944f, -53.5479f, 27.6467f },
- { 24.9642f, -37.1722f, 35.7038f },
- { 37.5851f, 5.64874f, 21.6702f },
- { -17.4738f, -53.5734f, 30.0664f },
- { -8.93088f, 45.3429f, -34.4441f },
- { -17.7111f, -6.5723f, 29.5162f },
- { 44.0059f, -17.4408f, -5.08686f },
- { -46.2534f, -22.6115f, 0.702059f },
- { 43.9321f, -33.8575f, 4.31819f },
- { 41.6762f, -7.37115f, 27.6798f },
- { 8.20276f, -42.0948f, -18.0893f },
- { 26.2678f, -44.6777f, -10.6835f },
- { 17.709f, 13.1542f, 25.1769f },
- { -35.9897f, 3.92007f, 35.8198f },
- { -23.9323f, -37.3142f, -2.39396f },
- { 5.19169f, 46.8851f, -28.7587f },
- { -37.3072f, -35.0484f, 16.9719f },
- { 45.0639f, -28.5255f, 22.3465f },
- { -34.4175f, 35.5861f, -21.7562f },
- { 9.32684f, -12.6655f, 42.189f },
- { 1.00938f, -31.7694f, 43.1914f },
- { -45.4666f, -3.71104f, 19.2248f },
- { -28.7999f, -50.8481f, 31.5232f },
- { 35.2212f, -45.9047f, 0.199736f },
- { 40.3f, -53.5889f, 7.47622f },
- { 29.0515f, 5.1074f, -10.002f },
- { 13.4336f, 4.84341f, -9.72327f },
- { 11.0617f, -26.245f, -24.9471f },
- { -35.6056f, -51.2531f, 0.436527f },
- { -10.6863f, 34.7374f, -36.7452f },
- { -51.7652f, 27.4957f, 7.79363f },
- { -50.1898f, 18.379f, 26.3763f },
- { -49.6836f, -1.32722f, 26.2828f },
- { 19.0363f, -16.9114f, 41.8511f },
- { 32.7141f, -21.501f, 36.0025f },
- { 12.5418f, -28.4244f, 43.3125f },
- { -19.5634f, 42.6328f, -27.0687f },
- { -16.1942f, 6.55011f, 19.4066f },
- { 46.9886f, -18.8482f, 22.1332f },
- { 45.9697f, -3.76781f, 4.10111f },
- { -28.2912f, 51.3277f, -35.1815f },
- { -40.2796f, -27.7518f, 22.8684f },
- { -22.7984f, -38.9977f, 22.158f },
- { 54.0614f, -35.6096f, 12.694f },
- { 44.2064f, -53.6029f, 18.8679f },
- { 19.789f, -29.517f, -19.6094f },
- { -34.3769f, 34.8566f, 9.92517f },
- { -23.7518f, -45.0319f, 8.71282f },
- { -12.7978f, 3.55087f, -13.7108f },
- { -54.0614f, 8.83831f, 8.91353f },
- { 16.2986f, -53.5717f, 34.065f },
- { -36.6243f, -53.5079f, 24.6495f },
- { 16.5794f, -48.5747f, 35.5681f },
- { -32.3263f, 41.4526f, -18.7388f },
- { -18.8488f, 9.62627f, -8.81052f },
- { 5.35849f, 36.3616f, -12.9346f },
- { 6.19167f, 34.497f, -17.965f },
- };
- static const uint16_t s_bunnyTriList[] =
- {
- 80, 2, 52,
- 0, 143, 92,
- 51, 1, 71,
- 96, 128, 77,
- 67, 2, 41,
- 85, 39, 52,
- 58, 123, 38,
- 99, 21, 114,
- 55, 9, 54,
- 136, 102, 21,
- 3, 133, 81,
- 101, 136, 4,
- 5, 82, 3,
- 6, 90, 24,
- 7, 40, 145,
- 33, 75, 134,
- 55, 8, 9,
- 10, 40, 20,
- 46, 140, 38,
- 74, 64, 11,
- 89, 88, 12,
- 147, 60, 7,
- 47, 116, 13,
- 59, 129, 108,
- 147, 72, 106,
- 33, 108, 75,
- 100, 57, 14,
- 129, 130, 15,
- 32, 35, 112,
- 16, 29, 27,
- 107, 98, 132,
- 130, 116, 47,
- 17, 43, 7,
- 54, 44, 53,
- 46, 34, 23,
- 87, 41, 23,
- 40, 10, 18,
- 8, 131, 9,
- 11, 19, 56,
- 11, 137, 19,
- 19, 20, 30,
- 28, 121, 137,
- 122, 140, 36,
- 15, 130, 97,
- 28, 84, 83,
- 114, 21, 102,
- 87, 98, 22,
- 41, 145, 23,
- 133, 68, 12,
- 90, 70, 24,
- 31, 25, 26,
- 98, 34, 35,
- 16, 27, 116,
- 28, 83, 122,
- 29, 103, 77,
- 40, 30, 20,
- 14, 49, 103,
- 31, 26, 142,
- 78, 9, 131,
- 80, 62, 2,
- 6, 67, 105,
- 32, 48, 63,
- 60, 30, 7,
- 33, 135, 91,
- 116, 130, 16,
- 47, 13, 39,
- 70, 119, 5,
- 24, 26, 6,
- 102, 25, 31,
- 103, 49, 77,
- 16, 130, 93,
- 125, 126, 124,
- 111, 86, 110,
- 4, 52, 2,
- 87, 34, 98,
- 4, 6, 101,
- 29, 76, 27,
- 112, 35, 34,
- 6, 4, 67,
- 72, 1, 106,
- 26, 24, 70,
- 36, 37, 121,
- 81, 113, 142,
- 44, 109, 37,
- 122, 58, 38,
- 96, 48, 128,
- 71, 11, 56,
- 73, 122, 83,
- 52, 39, 80,
- 40, 18, 145,
- 82, 5, 119,
- 10, 20, 120,
- 139, 145, 41,
- 3, 142, 5,
- 76, 117, 27,
- 95, 120, 20,
- 104, 45, 42,
- 128, 43, 17,
- 44, 37, 36,
- 128, 45, 64,
- 143, 111, 126,
- 34, 46, 38,
- 97, 130, 47,
- 142, 91, 115,
- 114, 31, 115,
- 125, 100, 129,
- 48, 96, 63,
- 62, 41, 2,
- 69, 77, 49,
- 133, 50, 68,
- 60, 51, 30,
- 4, 118, 52,
- 53, 55, 54,
- 95, 8, 55,
- 121, 37, 19,
- 65, 75, 99,
- 51, 56, 30,
- 14, 57, 110,
- 58, 122, 73,
- 59, 92, 125,
- 42, 45, 128,
- 49, 14, 110,
- 60, 147, 61,
- 76, 62, 117,
- 69, 49, 86,
- 26, 5, 142,
- 46, 44, 36,
- 63, 50, 132,
- 128, 64, 43,
- 75, 108, 15,
- 134, 75, 65,
- 68, 69, 86,
- 62, 76, 145,
- 142, 141, 91,
- 67, 66, 105,
- 69, 68, 96,
- 119, 70, 90,
- 33, 91, 108,
- 136, 118, 4,
- 56, 51, 71,
- 1, 72, 71,
- 23, 18, 44,
- 104, 123, 73,
- 106, 1, 61,
- 86, 111, 68,
- 83, 45, 104,
- 30, 56, 19,
- 15, 97, 99,
- 71, 74, 11,
- 15, 99, 75,
- 25, 102, 6,
- 12, 94, 81,
- 135, 33, 134,
- 138, 133, 3,
- 76, 29, 77,
- 94, 88, 141,
- 115, 31, 142,
- 36, 121, 122,
- 4, 2, 67,
- 9, 78, 79,
- 137, 121, 19,
- 69, 96, 77,
- 13, 62, 80,
- 8, 127, 131,
- 143, 141, 89,
- 133, 12, 81,
- 82, 119, 138,
- 45, 83, 84,
- 21, 85, 136,
- 126, 110, 124,
- 86, 49, 110,
- 13, 116, 117,
- 22, 66, 87,
- 141, 88, 89,
- 64, 45, 84,
- 79, 78, 109,
- 26, 70, 5,
- 14, 93, 100,
- 68, 50, 63,
- 90, 105, 138,
- 141, 0, 91,
- 105, 90, 6,
- 0, 92, 59,
- 17, 145, 76,
- 29, 93, 103,
- 113, 81, 94,
- 39, 85, 47,
- 132, 35, 32,
- 128, 48, 42,
- 93, 29, 16,
- 145, 18, 23,
- 108, 129, 15,
- 32, 112, 48,
- 66, 41, 87,
- 120, 95, 55,
- 96, 68, 63,
- 85, 99, 97,
- 18, 53, 44,
- 22, 98, 107,
- 98, 35, 132,
- 95, 127, 8,
- 137, 64, 84,
- 18, 10, 53,
- 21, 99, 85,
- 54, 79, 44,
- 100, 93, 130,
- 142, 3, 81,
- 102, 101, 6,
- 93, 14, 103,
- 42, 48, 104,
- 87, 23, 34,
- 66, 22, 105,
- 106, 61, 147,
- 72, 74, 71,
- 109, 144, 37,
- 115, 65, 99,
- 107, 132, 133,
- 94, 12, 88,
- 108, 91, 59,
- 43, 64, 74,
- 109, 78, 144,
- 43, 147, 7,
- 91, 135, 115,
- 111, 110, 126,
- 38, 112, 34,
- 142, 113, 94,
- 54, 9, 79,
- 120, 53, 10,
- 138, 3, 82,
- 114, 102, 31,
- 134, 65, 115,
- 105, 22, 107,
- 125, 129, 59,
- 37, 144, 19,
- 17, 76, 77,
- 89, 12, 111,
- 41, 66, 67,
- 13, 117, 62,
- 116, 27, 117,
- 136, 52, 118,
- 51, 60, 61,
- 138, 119, 90,
- 53, 120, 55,
- 68, 111, 12,
- 122, 121, 28,
- 123, 58, 73,
- 110, 57, 124,
- 47, 85, 97,
- 44, 79, 109,
- 126, 125, 92,
- 43, 74, 146,
- 20, 19, 127,
- 128, 17, 77,
- 72, 146, 74,
- 115, 99, 114,
- 140, 122, 38,
- 133, 105, 107,
- 129, 100, 130,
- 131, 144, 78,
- 95, 20, 127,
- 123, 48, 112,
- 102, 136, 101,
- 89, 111, 143,
- 28, 137, 84,
- 133, 132, 50,
- 125, 57, 100,
- 38, 123, 112,
- 124, 57, 125,
- 135, 134, 115,
- 23, 44, 46,
- 136, 85, 52,
- 41, 62, 139,
- 137, 11, 64,
- 104, 48, 123,
- 133, 138, 105,
- 145, 139, 62,
- 25, 6, 26,
- 7, 30, 40,
- 46, 36, 140,
- 141, 143, 0,
- 132, 32, 63,
- 83, 104, 73,
- 19, 144, 127,
- 142, 94, 141,
- 39, 13, 80,
- 92, 143, 126,
- 127, 144, 131,
- 51, 61, 1,
- 91, 0, 59,
- 17, 7, 145,
- 43, 146, 147,
- 146, 72, 147,
- };
- struct Shape
- {
- struct Type
- {
- enum Enum
- {
- Sphere,
- Aabb,
- Triangle,
- Capsule,
- Plane,
- Disk,
- Obb,
- Cone,
- Cylinder,
- Count
- };
- };
- Shape() : type(uint8_t(Type::Count) ) {}
- Shape(const bx::Aabb & _a) : type(uint8_t(Type::Aabb ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Capsule & _a) : type(uint8_t(Type::Capsule ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Cone & _a) : type(uint8_t(Type::Cone ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Cylinder & _a) : type(uint8_t(Type::Cylinder) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Disk & _a) : type(uint8_t(Type::Disk ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Obb & _a) : type(uint8_t(Type::Obb ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Plane & _a) : type(uint8_t(Type::Plane ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Sphere & _a) : type(uint8_t(Type::Sphere ) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- Shape(const bx::Triangle & _a) : type(uint8_t(Type::Triangle) ) { bx::memCopy(data, &_a, sizeof(_a) ); }
- uint8_t data[64];
- uint8_t type;
- };
- #define OVERLAP(_shapeType) \
- bool overlap(const _shapeType& _shapeA, const Shape& _shapeB) \
- { \
- switch (_shapeB.type) \
- { \
- case Shape::Type::Aabb: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Aabb *>(_shapeB.data) ); \
- case Shape::Type::Capsule: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Capsule *>(_shapeB.data) ); \
- case Shape::Type::Cone: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Cone *>(_shapeB.data) ); \
- case Shape::Type::Cylinder: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Cylinder *>(_shapeB.data) ); \
- case Shape::Type::Disk: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Disk *>(_shapeB.data) ); \
- case Shape::Type::Obb: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Obb *>(_shapeB.data) ); \
- case Shape::Type::Plane: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Plane *>(_shapeB.data) ); \
- case Shape::Type::Sphere: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Sphere *>(_shapeB.data) ); \
- case Shape::Type::Triangle: return bx::overlap(_shapeA, *reinterpret_cast<const bx::Triangle *>(_shapeB.data) ); \
- } \
- return false; \
- }
- OVERLAP(bx::Aabb);
- OVERLAP(bx::Capsule);
- OVERLAP(bx::Cone);
- OVERLAP(bx::Cylinder);
- OVERLAP(bx::Disk);
- OVERLAP(bx::Obb);
- OVERLAP(bx::Plane);
- OVERLAP(bx::Sphere);
- OVERLAP(bx::Triangle);
- #undef OVERLAP
- void initA(Shape& _outShape, Shape::Type::Enum _type, bx::Vec3 _pos)
- {
- switch (_type)
- {
- case Shape::Type::Aabb:
- {
- bx::Aabb aabb;
- toAabb(aabb, _pos, { 0.5f, 0.5f, 0.5f });
- _outShape = Shape(aabb);
- }
- break;
- case Shape::Type::Capsule:
- _outShape = Shape(bx::Capsule
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.0f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.5f,
- });
- break;
- case Shape::Type::Cone:
- _outShape = Shape(bx::Cone
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.0f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.5f,
- });
- break;
- case Shape::Type::Cylinder:
- _outShape = Shape(bx::Cylinder
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.0f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.5f,
- });
- break;
- case Shape::Type::Disk:
- _outShape = Shape(bx::Disk
- {
- _pos,
- bx::normalize(bx::Vec3{0.0f, 1.0f, 1.0f}),
- 0.5f,
- });
- break;
- case Shape::Type::Obb:
- {
- bx::Obb obb;
- bx::mtxSRT(obb.mtx
- , 0.25f
- , 1.0f
- , 0.25f
- , bx::toRad(50.0f)
- , bx::toRad(15.0f)
- , bx::toRad(45.0f)
- , _pos.x
- , _pos.y
- , _pos.z
- );
- _outShape = Shape(obb);
- }
- break;
- case Shape::Type::Sphere:
- _outShape = Shape(bx::Sphere{_pos, 0.5f});
- break;
- case Shape::Type::Plane:
- {
- bx::Plane plane(bx::InitNone);
- bx::calcPlane(plane, bx::normalize(bx::Vec3{0.0f, 1.0f, 1.0f}), _pos);
- _outShape = Shape(plane);
- }
- break;
- case Shape::Type::Triangle:
- _outShape = Shape(bx::Triangle
- {
- { bx::add(_pos, {-0.4f, 0.0f, -0.4f}) },
- { bx::add(_pos, { 0.0f, -0.3f, 0.5f}) },
- { bx::add(_pos, { 0.0f, 0.5f, 0.3f}) },
- });
- break;
- default: break;
- }
- }
- void initB(Shape& _outShape, Shape::Type::Enum _type, bx::Vec3 _pos)
- {
- switch (_type)
- {
- case Shape::Type::Aabb:
- {
- bx::Aabb aabb;
- toAabb(aabb, _pos, { 0.5f, 0.5f, 0.5f });
- _outShape = Shape(aabb);
- }
- break;
- case Shape::Type::Capsule:
- _outShape = Shape(bx::Capsule
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.1f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.2f,
- });
- break;
- case Shape::Type::Cone:
- _outShape = Shape(bx::Cone
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.1f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.2f,
- });
- break;
- case Shape::Type::Cylinder:
- _outShape = Shape(bx::Cylinder
- {
- { bx::add(_pos, {0.0f, -1.0f, 0.1f}) },
- { bx::add(_pos, {0.0f, 1.0f, 0.0f}) },
- 0.2f,
- });
- break;
- case Shape::Type::Disk:
- _outShape = Shape(bx::Disk
- {
- _pos,
- bx::normalize(bx::Vec3{1.0f, 1.0f, 0.0f}),
- 0.5f,
- });
- break;
- case Shape::Type::Obb:
- {
- bx::Obb obb;
- bx::mtxSRT(obb.mtx
- , 1.0f
- , 0.25f
- , 0.25f
- , bx::toRad(10.0f)
- , bx::toRad(30.0f)
- , bx::toRad(70.0f)
- , _pos.x
- , _pos.y
- , _pos.z
- );
- _outShape = Shape(obb);
- }
- break;
- case Shape::Type::Plane:
- {
- bx::Plane plane(bx::InitNone);
- bx::calcPlane(plane, bx::normalize(bx::Vec3{1.0f, 1.0f, 0.0f}), _pos);
- _outShape = Shape(plane);
- }
- break;
- case Shape::Type::Sphere:
- _outShape = Shape(bx::Sphere{_pos, 0.5f});
- break;
- case Shape::Type::Triangle:
- _outShape = Shape(bx::Triangle
- {
- { bx::add(_pos, {-0.4f, 0.0f, -0.4f}) },
- { bx::add(_pos, {-0.5f, -0.3f, 0.0f}) },
- { bx::add(_pos, { 0.3f, 0.5f, 0.0f}) },
- });
- break;
- default: break;
- }
- }
- int32_t overlap(const Shape& _shapeA, const Shape& _shapeB)
- {
- switch (_shapeA.type)
- {
- case Shape::Type::Aabb: return ::overlap(*reinterpret_cast<const bx::Aabb *>(_shapeA.data), _shapeB);
- case Shape::Type::Capsule: return ::overlap(*reinterpret_cast<const bx::Capsule *>(_shapeA.data), _shapeB);
- case Shape::Type::Cone: return ::overlap(*reinterpret_cast<const bx::Cone *>(_shapeA.data), _shapeB);
- case Shape::Type::Cylinder: return ::overlap(*reinterpret_cast<const bx::Cylinder *>(_shapeA.data), _shapeB);
- case Shape::Type::Disk: return ::overlap(*reinterpret_cast<const bx::Disk *>(_shapeA.data), _shapeB);
- case Shape::Type::Obb: return ::overlap(*reinterpret_cast<const bx::Obb *>(_shapeA.data), _shapeB);
- case Shape::Type::Plane: return ::overlap(*reinterpret_cast<const bx::Plane *>(_shapeA.data), _shapeB);
- case Shape::Type::Sphere: return ::overlap(*reinterpret_cast<const bx::Sphere *>(_shapeA.data), _shapeB);
- case Shape::Type::Triangle: return ::overlap(*reinterpret_cast<const bx::Triangle *>(_shapeA.data), _shapeB);
- }
- return 2;
- }
- void draw(DebugDrawEncoder& _dde, const Shape& _shape, const bx::Vec3 _pos)
- {
- switch (_shape.type)
- {
- case Shape::Type::Aabb: _dde.draw (*reinterpret_cast<const bx::Aabb *>(_shape.data) ); break;
- case Shape::Type::Capsule: _dde.draw (*reinterpret_cast<const bx::Capsule *>(_shape.data) ); break;
- case Shape::Type::Cone: _dde.draw (*reinterpret_cast<const bx::Cone *>(_shape.data) ); break;
- case Shape::Type::Cylinder: _dde.draw (*reinterpret_cast<const bx::Cylinder *>(_shape.data) ); break;
- case Shape::Type::Disk: _dde.draw (*reinterpret_cast<const bx::Disk *>(_shape.data) ); break;
- case Shape::Type::Obb: _dde.draw (*reinterpret_cast<const bx::Obb *>(_shape.data) ); break;
- case Shape::Type::Plane: { _dde.drawGrid( reinterpret_cast<const bx::Plane *>(_shape.data)->normal, _pos, 9, 0.3f); } break;
- case Shape::Type::Sphere: _dde.draw (*reinterpret_cast<const bx::Sphere *>(_shape.data) ); break;
- case Shape::Type::Triangle: _dde.draw (*reinterpret_cast<const bx::Triangle *>(_shape.data) ); break;
- }
- }
- void imageCheckerboard(void* _dst, uint32_t _width, uint32_t _height, uint32_t _step, uint32_t _0, uint32_t _1)
- {
- uint32_t* dst = (uint32_t*)_dst;
- for (uint32_t yy = 0; yy < _height; ++yy)
- {
- for (uint32_t xx = 0; xx < _width; ++xx)
- {
- uint32_t abgr = ( (xx/_step)&1) ^ ( (yy/_step)&1) ? _1 : _0;
- *dst++ = abgr;
- }
- }
- }
- class ExampleDebugDraw : public entry::AppI
- {
- public:
- ExampleDebugDraw(const char* _name, const char* _description, const char* _url)
- : entry::AppI(_name, _description, _url)
- {
- }
- void init(int32_t _argc, const char* const* _argv, uint32_t _width, uint32_t _height) override
- {
- Args args(_argc, _argv);
- m_width = _width;
- m_height = _height;
- m_debug = BGFX_DEBUG_NONE;
- m_reset = BGFX_RESET_VSYNC | BGFX_RESET_MSAA_X16;
- bgfx::Init init;
- init.type = args.m_type;
- init.vendorId = args.m_pciId;
- init.platformData.nwh = entry::getNativeWindowHandle(entry::kDefaultWindowHandle);
- init.platformData.ndt = entry::getNativeDisplayHandle();
- init.platformData.type = entry::getNativeWindowHandleType();
- init.resolution.width = m_width;
- init.resolution.height = m_height;
- init.resolution.reset = m_reset;
- bgfx::init(init);
- // Enable m_debug text.
- bgfx::setDebug(m_debug);
- // Set view 0 clear state.
- bgfx::setViewClear(0
- , BGFX_CLEAR_COLOR|BGFX_CLEAR_DEPTH
- , 0x303030ff
- , 1.0f
- , 0
- );
- m_timeOffset = bx::getHPCounter();
- cameraCreate();
- cameraSetPosition({ 0.0f, 2.0f, -12.0f });
- cameraSetVerticalAngle(0.0f);
- ddInit();
- uint8_t data[32*32*4];
- imageCheckerboard(data, 32, 32, 4, 0xff808080, 0xffc0c0c0);
- m_sprite = ddCreateSprite(32, 32, data);
- m_bunny = ddCreateGeometry(
- BX_COUNTOF(s_bunnyVertices)
- , s_bunnyVertices
- , BX_COUNTOF(s_bunnyTriList)
- , s_bunnyTriList
- );
- imguiCreate();
- }
- virtual int shutdown() override
- {
- imguiDestroy();
- ddDestroy(m_bunny);
- ddDestroy(m_sprite);
- ddShutdown();
- cameraDestroy();
- // Shutdown bgfx.
- bgfx::shutdown();
- return 0;
- }
- template<typename Ty>
- bool intersect(DebugDrawEncoder* _dde, const bx::Ray& _ray, const Ty& _shape)
- {
- bx::Hit hit;
- if (bx::intersect(_ray, _shape, &hit) )
- {
- _dde->push();
- _dde->setWireframe(false);
- _dde->setColor(0xff0000ff);
- _dde->drawCone(hit.pos, bx::mad(hit.plane.normal, 0.7f, hit.pos), 0.1f);
- _dde->pop();
- return true;
- }
- return false;
- }
- bool update() override
- {
- if (!entry::processEvents(m_width, m_height, m_debug, m_reset, &m_mouseState) )
- {
- imguiBeginFrame(
- m_mouseState.m_mx
- , m_mouseState.m_my
- , (m_mouseState.m_buttons[entry::MouseButton::Left ] ? IMGUI_MBUT_LEFT : 0)
- | (m_mouseState.m_buttons[entry::MouseButton::Right ] ? IMGUI_MBUT_RIGHT : 0)
- | (m_mouseState.m_buttons[entry::MouseButton::Middle] ? IMGUI_MBUT_MIDDLE : 0)
- , m_mouseState.m_mz
- , uint16_t(m_width)
- , uint16_t(m_height)
- );
- showExampleDialog(this);
- ImGui::SetNextWindowPos(
- ImVec2(m_width - m_width / 5.0f - 10.0f, 10.0f)
- , ImGuiCond_FirstUseEver
- );
- ImGui::SetNextWindowSize(
- ImVec2(m_width / 5.0f, m_height / 3.0f)
- , ImGuiCond_FirstUseEver
- );
- ImGui::Begin("Settings"
- , NULL
- , 0
- );
- static float amplitudeMul = 0.0f;
- ImGui::SliderFloat("Amplitude", &litudeMul, 0.0f, 1.0f);
- static float timeScale = 1.0f;
- ImGui::SliderFloat("T scale", &timeScale, -1.0f, 1.0f);
- ImGui::End();
- imguiEndFrame();
- int64_t now = bx::getHPCounter() - m_timeOffset;
- static int64_t last = now;
- const int64_t frameTime = now - last;
- last = now;
- const double freq = double(bx::getHPFrequency() );
- const float deltaTime = float(frameTime/freq);
- // Update camera.
- cameraUpdate(deltaTime, m_mouseState, ImGui::MouseOverArea() );
- float view[16];
- cameraGetViewMtx(view);
- float proj[16];
- // Set view and projection matrix for view 0.
- {
- bx::mtxProj(proj, 60.0f, float(m_width)/float(m_height), 0.1f, 100.0f, bgfx::getCaps()->homogeneousDepth);
- bgfx::setViewTransform(0, view, proj);
- bgfx::setViewRect(0, 0, 0, uint16_t(m_width), uint16_t(m_height) );
- }
- float mtxVp[16];
- bx::mtxMul(mtxVp, view, proj);
- float mtxInvVp[16];
- bx::mtxInverse(mtxInvVp, mtxVp);
- const bx::Vec3 at = { 0.0f, 0.0f, 0.0f };
- const bx::Vec3 eye = { 5.0f, 10.0f, 5.0f };
- bx::mtxLookAt(view, eye, at);
- bx::mtxProj(proj, 45.0f, float(m_width)/float(m_height), 1.0f, 15.0f, bgfx::getCaps()->homogeneousDepth);
- bx::mtxMul(mtxVp, view, proj);
- bx::Ray ray = bx::makeRay(
- (float(m_mouseState.m_mx)/float(m_width) * 2.0f - 1.0f)
- , -(float(m_mouseState.m_my)/float(m_height) * 2.0f - 1.0f)
- , mtxInvVp
- );
- constexpr uint32_t kSelected = 0xff80ffff;
- constexpr uint32_t kOverlapA = 0xff0000ff;
- constexpr uint32_t kOverlapB = 0xff8080ff;
- DebugDrawEncoder dde;
- dde.begin(0);
- dde.drawAxis(0.0f, 0.0f, 0.0f);
- dde.push();
- bx::Aabb aabb =
- {
- { 5.0f, 1.0f, 1.0f },
- { 10.0f, 5.0f, 5.0f },
- };
- dde.setWireframe(true);
- dde.setColor(intersect(&dde, ray, aabb) ? kSelected : 0xff00ff00);
- dde.draw(aabb);
- dde.pop();
- static float time = 0.0f;
- time += deltaTime*timeScale;
- bx::Obb obb;
- bx::mtxRotateX(obb.mtx, time);
- dde.setWireframe(true);
- dde.setColor(intersect(&dde, ray, obb) ? kSelected : 0xffffffff);
- dde.draw(obb);
- bx::mtxSRT(obb.mtx, 1.0f, 1.0f, 1.0f, time*0.23f, time, 0.0f, 3.0f, 0.0f, 0.0f);
- dde.push();
- bx::toAabb(aabb, obb);
- dde.setWireframe(true);
- dde.setColor(0xff0000ff);
- dde.draw(aabb);
- dde.pop();
- dde.setWireframe(false);
- dde.setColor(intersect(&dde, ray, obb) ? kSelected : 0xffffffff);
- dde.draw(obb);
- dde.setColor(0xffffffff);
- dde.push();
- {
- float bunny[16];
- bx::mtxSRT(bunny, 0.03f, 0.03f, 0.03f, 0.0f, 0.0f, 0.0f, -3.0f, 0.0f, 0.0f);
- dde.setTransform(bunny);
- const bool wireframe = bx::mod(time, 2.0f) > 1.0f;
- dde.setWireframe(wireframe);
- dde.setColor(wireframe ? 0xffff00ff : 0xff00ff00);
- dde.draw(m_bunny);
- dde.setTransform(NULL);
- }
- dde.pop();
- {
- const bx::Vec3 normal = { 0.0f, 1.0f, 0.0f };
- const bx::Vec3 pos = { 0.0f, -2.0f, 0.0f };
- bx::Plane plane(bx::InitNone);
- bx::calcPlane(plane, normal, pos);
- dde.setColor(false
- || intersect(&dde, ray, plane)
- ? kSelected
- : 0xffffffff
- );
- dde.drawGrid(Axis::Y, pos, 128, 1.0f);
- }
- dde.drawFrustum(mtxVp);
- dde.push();
- bx::Sphere sphere = { { 0.0f, 5.0f, 0.0f }, 1.0f };
- dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xfff0c0ff);
- dde.setWireframe(true);
- dde.setLod(3);
- dde.draw(sphere);
- dde.setWireframe(false);
- sphere.center.x = -2.0f;
- dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xc0ffc0ff);
- dde.setLod(2);
- dde.draw(sphere);
- sphere.center.x = -4.0f;
- dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xa0f0ffff);
- dde.setLod(1);
- dde.draw(sphere);
- sphere.center.x = -6.0f;
- dde.setColor(intersect(&dde, ray, sphere) ? kSelected : 0xffc0ff00);
- dde.setLod(0);
- dde.draw(sphere);
- dde.pop();
- dde.setColor(0xffffffff);
- dde.push();
- {
- const bx::Vec3 normal = { 0.0f, 0.0f, 1.0f };
- const bx::Vec3 center = { -8.0f, 0.0f, 0.0f };
- dde.push();
- dde.setStipple(true, 1.0f, time*0.1f);
- dde.setColor(0xff0000ff);
- dde.drawCircle(normal, center, 1.0f, 0.5f + bx::sin(time*10.0f) );
- dde.pop();
- dde.setSpin(time);
- dde.drawQuad(m_sprite, normal, center, 2.0f);
- }
- dde.pop();
- dde.push();
- dde.setStipple(true, 1.0f, -time*0.1f);
- dde.drawCircle(Axis::Z, -8.0f, 0.0f, 0.0f, 1.25f, 2.0f);
- dde.pop();
- dde.push();
- dde.setLod(UINT8_MAX);
- dde.push();
- dde.setSpin(time*0.3f);
- {
- bx::Cone cone =
- {
- { -11.0f, 4.0f, 0.0f },
- { -13.0f, 6.0f, 1.0f },
- 1.0f
- };
- bx::Cylinder cylinder =
- {
- { -9.0f, 2.0f, -1.0f },
- { -11.0f, 4.0f, 0.0f },
- 0.5f
- };
- dde.setColor(false
- || intersect(&dde, ray, cone)
- || intersect(&dde, ray, cylinder)
- ? kSelected
- : 0xffffffff
- );
- dde.draw(cone);
- dde.draw(cylinder);
- }
- dde.pop();
- {
- dde.setLod(0);
- bx::Capsule capsule =
- {
- { 0.0f, 7.0f, 0.0f },
- { -6.0f, 7.0f, 0.0f },
- 0.5f
- };
- dde.setColor(intersect(&dde, ray, capsule) ? kSelected : 0xffffffff);
- dde.draw(capsule);
- }
- dde.pop();
- dde.push();
- float mtx[16];
- bx::mtxSRT(mtx
- , 1.0f, 1.0f, 1.0f
- , 0.0f, time, time*0.53f
- , -10.0f, 1.0f, 10.0f
- );
- bx::Cylinder cylinder =
- {
- { -10.0f, 1.0f, 10.0f },
- { 0.0f, 0.0f, 0.0f },
- 1.0f
- };
- cylinder.end = bx::mul({ 0.0f, 4.0f, 0.0f }, mtx);
- dde.setColor(intersect(&dde, ray, cylinder) ? kSelected : 0xffffffff);
- dde.draw(cylinder);
- dde.push();
- toAabb(aabb, cylinder);
- dde.setWireframe(true);
- dde.setColor(0xff0000ff);
- dde.draw(aabb);
- dde.pop();
- dde.pop();
- dde.drawOrb(-11.0f, 0.0f, 0.0f, 1.0f);
- dde.push();
- {
- constexpr uint32_t colorA[] =
- {
- 0xffffffff,
- kOverlapA,
- 0xff666666,
- 0xff6666ff,
- };
- constexpr uint32_t colorB[] =
- {
- 0xffffffff,
- kOverlapB,
- 0xff888888,
- 0xff8888ff,
- };
- constexpr float kStep = 3.0f;
- bx::Vec3 posA =
- {
- -4.5f*kStep,
- 1.0f,
- 20.0f,
- };
- for (uint32_t ii = 0; ii < Shape::Type::Count; ++ii)
- {
- const bx::Vec3 posB = bx::add(posA,
- {
- amplitudeMul*bx::sin(time*0.39f) * 1.03f,
- amplitudeMul*bx::cos(time*0.79f) * 1.03f,
- amplitudeMul*bx::cos(time) * 1.03f,
- });
- for (uint32_t jj = 0; jj < Shape::Type::Count; ++jj)
- {
- const bx::Vec3 pa = bx::add(posA, {jj*kStep, 0.0f, 0.0f});
- const bx::Vec3 pb = bx::add(posB, {jj*kStep, 0.0f, 0.0f});
- Shape shapeA, shapeB;
- initA(shapeA, Shape::Type::Enum(ii), pa);
- initB(shapeB, Shape::Type::Enum(jj), pb);
- int32_t olp = overlap(shapeA, shapeB);
- dde.setColor(colorA[olp]);
- dde.setWireframe(false);
- draw(dde, shapeA, pa);
- dde.setColor(colorB[olp]);
- dde.setWireframe(true);
- draw(dde, shapeB, pb);
- }
- posA = bx::add(posA, {0.0f, 0.0f, kStep});
- }
- }
- dde.pop();
- dde.end();
- // Advance to next frame. Rendering thread will be kicked to
- // process submitted rendering primitives.
- bgfx::frame();
- return true;
- }
- return false;
- }
- entry::MouseState m_mouseState;
- SpriteHandle m_sprite;
- GeometryHandle m_bunny;
- int64_t m_timeOffset;
- uint32_t m_width;
- uint32_t m_height;
- uint32_t m_debug;
- uint32_t m_reset;
- };
- } // namespace
- ENTRY_IMPLEMENT_MAIN(
- ExampleDebugDraw
- , "29-debugdraw"
- , "Debug draw."
- , "https://bkaradzic.github.io/bgfx/examples.html#debugdraw"
- );
|