From eb55518d1f19f42fb69cba12baf78d06068aa707 Mon Sep 17 00:00:00 2001 From: atom0s Date: Fri, 25 Nov 2016 22:12:15 -0800 Subject: [PATCH] Initial major beta commit. --- Ashita.dll | Bin 1998336 -> 1998336 bytes ffxi-bootmod/pol.exe | Bin 0 -> 48640 bytes injector.exe | Bin 0 -> 173568 bytes plugins/ADK/AS_BinaryData.h | 267 ++ plugins/ADK/AS_CommandParser.h | 232 ++ plugins/ADK/AS_Event.h | 103 + plugins/ADK/AS_Exception.h | 149 + plugins/ADK/AS_LockableObject.h | 79 + plugins/ADK/AS_Memory.h | 126 + plugins/ADK/AS_Objects.h | 128 + plugins/ADK/AS_Registry.h | 141 + plugins/ADK/AS_Thread.h | 236 ++ plugins/ADK/Ashita.h | 1532 ++++++++ plugins/ADK/d3d8/includes/d3d8.h | 1279 +++++++ plugins/ADK/d3d8/includes/d3d8caps.h | 364 ++ plugins/ADK/d3d8/includes/d3d8types.h | 1684 +++++++++ plugins/ADK/d3d8/includes/d3dx8.h | 45 + plugins/ADK/d3d8/includes/d3dx8core.h | 563 +++ plugins/ADK/d3d8/includes/d3dx8effect.h | 226 ++ plugins/ADK/d3d8/includes/d3dx8math.h | 1215 +++++++ plugins/ADK/d3d8/includes/d3dx8math.inl | 1757 +++++++++ plugins/ADK/d3d8/includes/d3dx8mesh.h | 760 ++++ plugins/ADK/d3d8/includes/d3dx8shape.h | 220 ++ plugins/ADK/d3d8/includes/d3dx8tex.h | 1592 ++++++++ plugins/ADK/d3d8/includes/dinput.h | 4417 +++++++++++++++++++++++ plugins/ADK/d3d8/includes/dxerr8.h | 100 + plugins/ADK/d3d8/includes/dxfile.h | 240 ++ plugins/ADK/d3d8/lib/DxErr8.lib | Bin 0 -> 1083572 bytes plugins/ADK/d3d8/lib/d3d8.lib | Bin 0 -> 2704 bytes plugins/ADK/d3d8/lib/d3dx8.lib | Bin 0 -> 2150226 bytes plugins/ADK/d3d8/lib/dxguid.lib | Bin 0 -> 570238 bytes plugins/ADK/ffxi/entity.h | 204 ++ plugins/ADK/ffxi/enums.h | 659 ++++ plugins/ADK/ffxi/inventory.h | 92 + plugins/ADK/ffxi/party.h | 84 + plugins/ADK/ffxi/player.h | 193 + plugins/ADK/ffxi/target.h | 93 + plugins/ADK/imgui.h | 1385 +++++++ plugins/ADK/newIDirectInputDevice8A.h | 80 + 39 files changed, 20245 insertions(+) create mode 100644 ffxi-bootmod/pol.exe create mode 100644 injector.exe create mode 100644 plugins/ADK/AS_BinaryData.h create mode 100644 plugins/ADK/AS_CommandParser.h create mode 100644 plugins/ADK/AS_Event.h create mode 100644 plugins/ADK/AS_Exception.h create mode 100644 plugins/ADK/AS_LockableObject.h create mode 100644 plugins/ADK/AS_Memory.h create mode 100644 plugins/ADK/AS_Objects.h create mode 100644 plugins/ADK/AS_Registry.h create mode 100644 plugins/ADK/AS_Thread.h create mode 100644 plugins/ADK/Ashita.h create mode 100644 plugins/ADK/d3d8/includes/d3d8.h create mode 100644 plugins/ADK/d3d8/includes/d3d8caps.h create mode 100644 plugins/ADK/d3d8/includes/d3d8types.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8core.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8effect.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8math.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8math.inl create mode 100644 plugins/ADK/d3d8/includes/d3dx8mesh.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8shape.h create mode 100644 plugins/ADK/d3d8/includes/d3dx8tex.h create mode 100644 plugins/ADK/d3d8/includes/dinput.h create mode 100644 plugins/ADK/d3d8/includes/dxerr8.h create mode 100644 plugins/ADK/d3d8/includes/dxfile.h create mode 100644 plugins/ADK/d3d8/lib/DxErr8.lib create mode 100644 plugins/ADK/d3d8/lib/d3d8.lib create mode 100644 plugins/ADK/d3d8/lib/d3dx8.lib create mode 100644 plugins/ADK/d3d8/lib/dxguid.lib create mode 100644 plugins/ADK/ffxi/entity.h create mode 100644 plugins/ADK/ffxi/enums.h create mode 100644 plugins/ADK/ffxi/inventory.h create mode 100644 plugins/ADK/ffxi/party.h create mode 100644 plugins/ADK/ffxi/player.h create mode 100644 plugins/ADK/ffxi/target.h create mode 100644 plugins/ADK/imgui.h create mode 100644 plugins/ADK/newIDirectInputDevice8A.h diff --git a/Ashita.dll b/Ashita.dll index f7485859d78203c31d4a84b51ea4e9b273a8f146..f4df7f26d3f4ba7a009608ea223bc938d2f7e101 100644 GIT binary patch delta 180642 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 f^I!$|Jsb!N}>m7~|p# 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

j>uEb0r(@I1zP4REGz5Sg{7O>j!7fL%P})(q;D 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%0A<4$;g!?EnLBaN zFy-EhAM?of-}eyvGm<##^AM`JZ+{JW;V4(xxv!D8=R;(S-Dcc)1m4Ua`qK_X(=Ut} zIgjY!^N8v@#a!eTgsoz(fqEj8{e+>k5#fA&NC)|b^b2g?i>MWQ88ep|($<%;Lm+)VfA)8^Cznr-d>~+aJSOUg69yg!EC)*;^Pw8IBscfC%m#3!?rG?LUGb(lxm6 z1oIH*kUc^Szs;OqID8%11Dp-bIe_7v2jSVZ9f6ejAnFn?#+v?&QN_;->^OwNBOjq; z&o%B*h{dD#OhW|o&HSF?3;&XAKQC7~B-WKaS5vOg%)$Ne$yfzrvn=lOs)3sMGTxi} zpzUOV(7Fwr#qcf?H=IG`kxx1E0SKo~4P(5OvX-+$4}XFVV)8Z+SG9uJK+(N>@#u6d zg%@T%YK`fWEtq5Ufd^;pmUC}lCvklGh}k;8ReSME1hwv93^vTY2fG-jbyH^7Bbt2S z#-5V!+B-TSnm%Ia0Da2-6Y#EQo~f35_&8VGi+lT>=)ZW8<}TC^Rx$Okk0?h#b~jRn zIcIv$n@HnqLnr2Xvez78kNZ>nUX$P%Gr&I9P25-7Dmvho;`{Sbl|$_R-8_)9S4P#Y z2=0yWVclX`iaEw%#0M+m|JZSZ z_d@L8FUbdxYrU)c{Zcx&Ae;CsCiW@NvJ8WzXFhv9QlPUWiZkCzaQ{7b;sOuKSsig0 zvPaJ$f%&*X(!1*LU(rN;P=4ZlWN*C5neA^NfA`zOk0Z_-F+5T?96{NB&ImooneLm< zA&s*{LRinWU{C)O+DfezPiX1DIyo2deH)R)y;z0EK0xNSYv_Ofdu6`I=I@C6MZOq$ zoBjkbAOur**SB|gY#;yDL9B>@S3e_m06&-U{R~Z`A8CE3zTN-&-=MK%mU3=^ekF{| zbMV*$hOkesK-s!Oa$aVl{}OV4yiDbgYn{$z{>Y@K;h! zP6XyHOvGF**2wfrf4ZL$gFDbmyv)*F?;>mcZOZ>;BoAFg-T`835|>wOd)(0TNL+Uf zB}YC%(z@#?JMt&AF;7rW9G4ZORo%Hy=p$ZY4PYIf;vU~8ROjRO)8^rk$5fS`<4K$s zFy#q#%${q8XH>NDjD|iQoiv?2TI|n@lbElRdp`;=b(XI3y{OFa(ET%&=fAo4an=-5 z*uS(znIqdvUBv5Dmd{y$bOMKdSJ4_Tx9LLi5kwz zDLn8tGS^>1{Md7dp5<)5cZt~aXt`z zQ!n=I%D#R22!1P$Ac8SO=AM_(`YQ1%NpqP6QhDRWpJ;Dj!hLFLj+iyq8*_9bFm1Lw zaSlSrhkH>){1@I2>5cj&m<5^{Yv~pk7tj&=@?9BX)S2^?jG72`_Km`5l@(Z`o#TfvrJ_Fh) z?}-~Rw^vD# z@*SVNM-Lj*VY6o2V5Wu()aOS*Pty@kPqrnlK@5@``cOp7K;DaAN*o|@pUgO3$Q7u| zz0g%-$B;Zg{l6#xQ)W;`RDCetC<(LmqA+uoEmYJUpf=kc)769*EMRI_0kx?f%KhbM zz$7jnk!ug4=-?ZupzV%ad4~OiTadE#8mc)TZkTx88$Tp3+@S9;_9m(i|A4B~r1hS^ zp?KS;tRMUdVJlxk)<)uTa>hh0u|Sv8UQ`gXbJ@jjP)l9WL7d3^qc33jNzR<4UCG-2 zXA~a%64^UmM?L3L4iXP^2l;K_>i;YAsv3bXwyuWC9QLYCH^Q^iEiqTa9dp&4i6O#0 zLZ;kf?3K@16+4MfwW@;GGLd^fczMbp^cURkMLCTv>z$c5TQ;7S3hofITv=+OvACddI z>{6h<_bT(m@1bb_$0*$W5pg;{M$v`~C>Ud1sC@@~>JPI|WKBt2 z_wiz0gY+_q-!|jgwQF@`83Yj%fG`Iz4y!{*{sR?Zaw+uL-}uy%7SPluo{_2( zraa@xo;UXWIVB>wcMGa^-4goC=S}n)u+U%feoGw^i&uqKtwiDAHtxUW{tjEwkx|f? z%l-7a?EhI91ugo^b5$&%GcO#P)M8~wwgjruwqyTlp?#A`8e*? zj9<@LESv$8x^f+9cNB@O`&i>Sht+&NX&jdrsCcN3;le?2k7jCz1PZJa{Akc@c-yjGnc_Kj2iH!AWkIgyE;2l`3= z(|h*5lDLX>mil4hu;jtOI)ySGg&8w_xbHIpdh>%xe}CFg56q-bsAm}m+tB5B=w1Un z{mdfh8nd@9jXBzyVdN2uH#ooA|3^AJZ629p8oFxFj)J|f)u(N_)f_?D9sCAJ*?XIH zxpCNJlrrDD4V8!A!}AHd{Fg^FTS|t8^S%!*W-~6I1@jleNKcs&TE^f1 zC+@XeukfdQSMl$jUF;fal(F&DD}}6SN42a8;-!*S8QJ`6bZ( z?)?^e2^N@X1#`Ely*oKGkMj@qUPWTpR^*Se7l&9sSVB*qjwBRyvFJ`Zc^ecc5M@YGY2zUA-#UAmti{p;~x z+yUWxu>opj;}=oE{)kNW;APMcD%f}$C9DPIt>=Eq-aSZMxl3eK^rrY!qBq2rOTAR+ zEWJZZx$L>zxIBM+l;5SV#E@$-mm`;t@q80J_LzbrQ^nu^Cv-pm&9BFQa0f)+iTpj5 zv2u4xWc8q3R8^m8V1CteZ_`ApM`VBn&>+w&# z17h!l4@3@S$@8Bt`McP6vD0EJM3x=6gys>`W_q61RE@#BDFJwLh8G^6=7}jPVeI?z z#-ynZcx19C9-ijGx=}11d?cMYr2Fv9j45z3vwe&27aJm<|LgIudk2I*;wOl%7ai{P z=)()URaDs*pcVzq*^zi^sw-4xM6kBz&e~cCCe3oiW6v64>SP;CpSBoJJY|N5pAE(R zkLbW*sVa5D??v{-N069IcJd<#6$F)8kx--j z&zu@a`ukxz<$m&HCp`P48=l~!hQ1N^^qZ63VbD_1fR@HHm^bqY;`Cco@pDzVM6Zax z`StkMx&wD(}JNgJq)wBW~xQ7UhKvGAb(7o;fATxf-q%r z3}!KZtWNB}XH*yB{wD+AX{LfX)9!=*JRdyxL@rcR0=MxqB?l>f=W)*ZNyUq|9P z9WH0CnCU8{xoQYh)xt4zMlfc~3dOWp0n`Ce3e9KD_F;dG4}CsQOnoX9v!+JlshR8( znq~nv<0W{8n1QZFD!BLe>>-)riJ3FQF=MK02|rtOfbiR|$G^rM5LyUL)VOT9B2{L` zupUI&pGn=%rLGzWRn=IitFuQ?HIwvraIf$INNd=m+{!XSibq?Z|AE$glYMk{|fh58zGs7deC$cXRc=s+!4ARf(p(XaAg9 zEN0J&razxZS|{=MMD_@!WBTkM$}{Pz5=y<`&pyHVxc^Z%+I&@*Xx#&CmEXb5%oF!K z;KX@6&X}q~Y!}*%S+gR<7nHa{{ET0Ze~mjJIRVM%nLYB@oRXQU>;Y6ygPM9A=J0Wj zI%z*A6I$wdwBd2kRL^29H375cq(gOf66Zz-u&**4lbq!H??YIm^Ca$hB#*H| z9Bas-#MXDgv(ua~dpiAuS%H7x{}O%k>+!E~2PChn!ey&6JN!BIIl1ipV^4@?613)I zaDG-6pJ!r@W)9}fEn<&&4u4N)&nSDu853yo^{N{2;@>e&NWcuWQs#mZ`4~x^;m_XD zV6Ff>Go8L7U#~tRTy%is6n{Pb`FB8UzvTHOK6jfu!*!2_Rw*>+iri)FXbMP9fvNboPtJ(+`MbtdPOq(-b=~oxe|+8OXje_K#>KD!zj% zd1emZ&;RwS{QvW5FW*37amn|XaD`5p${z3eZS4Qdf!@427?SQ<^OiwJs~(1nYoRl@ zk^Qp;(9x^JT%Bt6g_f`{m{_n28rf^-k7s9Dk~cU{hWzvFOy&b;g%d+Q4|8+#RO1LB8^KW?QuH}izHUO99PdN5C?0Q2WJLsz$fJ)v#X1C20P z(gdUV?a-nQ(AHfBZLLb$i8AQf6>^?tE3`FwnCo|h>fCVl4yR-0^dM->9^)KO_7@uF z&<~6wAC)qX6e;pAHs{ylpMM9W)+hBn=jpTjHtFg%LT}N~9bZp}n6A1t(AR6j0@B@Z zVFwHstR!#LlD;+MjYjAg)M0^LK6AcJFr0rBdb;c<)TV!^MVwdtRv74QW`BC!hNXq9g|(|M%D9pMM8L4(D)r=q_AAU0(w|L(*8gj=H^=dcKbN+a@d&o1otf zlZAsY)L(@;dS%d^U&oocZJ2LW&-r29FjzPO{YBkaU_`y~|Fm~4P+e8&{*csA(Ty6$ z>lBlWFGvy3`|R@uL_o!2k^l|I2cR$^AfTZ`S27}0Dj%qrnB;@8w4}sGMoC6xlTDgr zmROo-jM+quW7L@Y{`Q}T=Dn4!X|0-j*=rpR-`QvHv(NWF`@i@1F}{!=!QR1TSX)?3 z2a5CP0H!zk--9{i1SbFNo3p$8^cd*${cn>s$ZjZn{DH;T_pyxj@0SHxFTuXAxv&Kf zQF+KhD&RUX9;YE9t_@j)n99qMuX`C4Wt_=ll-DaE>x>r`(onUM3b+>1Zxsy{(FS~Q z>u)n?ubb|860gmEd+shjJqFlsy=>k$+O{{*zWjZV`7$~Xdj3|(>%c+K^MfD4o`5nc zhCD(;Ll#n1T@D*j2Kpjyto<~V2E0gz4BSXHa~&0|D#}9_@Cx*VTn)Q04Zi<0=z`T$ z5HWYq-{bpt&;S4QbnhHN=iHy+gx8!6l}e$z=i?gy2k1U9_yNd%8F*km4dqMdtpgvS zlDLd&WI6o7HI&%fp!+dLfIWADvY3kMI;uFeR5EI4usVwd$f0y#$O_8KE2yLvV9p3J zd^XQqeQx{N`C`O>u#Sw;u&rO^5FV6z{lgE1GtzW@5)dM_1)hv5G$q`Lhm zHBH!h=_zWud#D~+O$UT$U~lMb8mg?MqO*+-G5$n(p`5y5`>AZ~qSjD+M+OyPy-3_5 zJgZyx{~RdaK8DWU{nv+? zZKRU9okk3MhdRzX)G~L`=n-#IC-P+)IrMcJ9{oCX!ghlG;0bvlz47L8U*Q>SzM=cK z-*(*pT>dh7WWW7~>PF>`f%1d+zP}%Sz(X_ywtOIydlT}ktbrci0RMkA4R;@=B)oTMcx`@1x1#CxEBBaOQ49U2pd*dLK^QY(Brc%&BdzeP;%cd!5ZxlsJu<6!d0 z{J>j$e0mNgkk>vTg&z8g@){ZzBS#*jBx(m0?A4efSj}k9`tO!|AmL|P*ct$~-oKw4vE_&py#xEb zm*7|lo&Pi)qC);j74kQ1rKP zP-EnNszts+C0w(Hzec0S9z%Y`V~8bkhK@?1G$#2N_LATJv6S91g(9!kCx{EOEgNl_uh*^ffrNk4!qx>a z*=2KeH{R0kuAr#+mM4cMyt{lP^nA>ORysWM8yb^<*gKV!CU2nBOgKIb_jc1ANccZg zm_A@~%y@yV6JvUT{bta4F#ce^J*)4QcOap=bYq|!1Kk+t#y~d)x-rm=flI*vLRg;d zyw7C;Ex!kz?Wv~cI`3}>J@M{6mo9?6I^m-B20boPd;jn7x$9fM zRe#Q_V?Z74&vF0NUf=P&bDax*yWsX}1aI|}uGhI3<}RxLAMosNx98enHtp12Tu=Sw z!d>Ix+S~sSd{O_N)M^(z|6=$&xjOp4s6E2icMQL?zNQoIc)ugx51$L`tZ#q)vlqc_ zoz)%q>YygBw)cNAeE$7Ap5N8pZGXUJ!sq*IZ~w2tUE7@$?xs`dqFHNtnUppcfnq*&}~KM;T{Zb?SzZaVQ=X>^knh81B;LsAdfEufU8UFKqu)z!$zBd;a&q?0tJPymS-> zyPW_#1D^eTa1mltURdh6PS$R}+WM`>GXw2jc>BNfe=r8eHev8MytqL8<+urKw&l_a zo1DE#&!>7sBpsSGkq%G99>IW{Y2K`P^xjRLJPeo9uZx?1i-XM@ z%8BFi>9CBMG#B~&@{uEq&E7}G1(x2c=Ux(b2Q#^S=Qev}; z>Dat7np;&zAKbj3&fD@9%~)JRC)|fz;Ia22A5uN*pUr1oYPr6kdJipm;Si0uGledG z6Zx^9+V9DKxs9HqyKp>-d^grOtd*ChA|CpSwB*@0*fTC^|9jtvyeqxDysocm{NTW* zkC86{d9a=Xr+tRwD*xWBAG!noKk*f%qtfQl_!*US?J z(8tPsr|Cm4eC+9y^?MN4D&9goe#GHlg#10ln?ImP#YLY)ynfWP`Qb|{V`k3(`mw!d zX!*;>>4Jt6^dX!VBmc|FxBgC7HGV@^?f;T4ed%L**Qk+n?(>J}(D74Q|Cd?@q^_u= z>WFx(HRTbvHj>(-Cedljw;(s<({#oA=V-!h*&7sKckPl`Wc;3^*ZbSQrDlG zzqwUH&Y&nNMkdmcnR96cav27X98dj!*@xbA)2-MeLFn8i6|`~hQ98c(F*-738tea( z_P1Tp!+V@KauSWcXE6<*GK)r}+)wSvMbsW&M4j>3h_^hAy6IUo>h61}jr{1tb4n>0 zlS8lZznR5R`N2YdpT9P4=3ILFy-N^#eGYQqCDKV{kI~`xApdj0A{vulN=M~a(CFOz zXw7icWqy&V1tBzI-g)F=1Tx!b>_Zr=TLRN)#r7I|QY<<6s{(u?VM z#HJlH`%#+q=r*b#Pq+|&_u@+&JG;$`;PxRxE!N%Ta~?*?!DREx%?t z99ZrKmY>0sj{$iYSgr+@TY=?N7>~ROEKdR~j3);|N6v#w?f)tkBa+32M1uevu{cPr{K;XzL zI6wSlb?LC*J-DKxb|~1#3kJOxTsT%&3eSx#qd-6nw_s{!;Ec4~yo~HDJ4guSg96jC zQnFJsvZmNUcg9BzCP9ID`4h8JCuU}6rP)C<)AE8`=eldGiFtWxQzvE43`7T6d3MnB z+$#Dr4 zdRPIP=HsI!hYdB;f!#F7$qi(i=>Ux0jXKKN>=4ad9u7zUMJVdU&sR# zSxHbzl%>iBg(?YZs#>C+P(M{OwHz&9E6@tHN44j**R{SxAh(lbGK)M&){!k_KRH4I z_228;^w;zc^e7|Ac*eNKj4)@K#qI`ooBO8wfqUHjn+qY}$}rxZd@w(bH-zItPcc{= zCrZ*7>2WDhc~?2Ae5_1T=c!fdI(38kth!5mQ+-$cK>b=Bs-Ky)kka51`vhhlO5!CeZGEJA7P9& zCL7a@GGo7S#^_-tn5pI;&H3h|=0@}H<^W5vVy(s2tJZ$&3j0Po${uZ>u)nY;JGss> z=TA(r4)p>gD<>eTlK!*ktT54jade zOf%Q4Hn*Gk&U4PI&OYbY?f_SE9k&{|mGr z@@sO7{Iz_Qa)a_4B~*!3W`LtkC})%sb*cKadPcnx)Vq@OBRo-wOQw)g@+he$&yW|$ zU&twPM!(VsGGxOrh8lMpmBxBwv$50IYy1tg?PogXXfwq_;ht7MtHi3X&RM=~&*z`w_d{-n3G0P7g#n^0W{8VKRURgPDW6c@ez$ z|1?LMzca73`dA58y0ygGWR=(z_9|zcbHZtJ`nzH7Ocxy%aa=J@i^Ub<8gYYoM!Zt8 zq)Aephl3-*zlS_BpQRj7jw`*?A?h9Kjan~F(`-#KEF;W_G-8ZcBhHA2OeY%?j8r4t z$TV_{e51f9G>VL3qZC}d6jWMjt}`dw1@-~E#g1|koHLG(oA0i1xdj}1J?>h_SQ0M@ zy6`GwDpJf74~adcVCjBouC!J1lhc%^Ap5>*n)QKjhFF$0+={oVtu0oa!w8*;=Y7n7%2$h9!~;@`G+8c? z_sj2rCli!(Wwx?fc}=-N9jqqcX{r{XC2BLY`?Y8E=k!nYxyC*t!Avukn=hHF6=}`1 zR$EuwH`{CNKil8feVqwTiBpev3w1wonF3+&<^%2VFn^WcFT@C0;HBe2f7y_u<#>6# z{Dl0X{Dyo`J_byiN{n)+GC`?PUQymwK2%OB@2Mx%0h*${Mh57zey5(HziPc}`PzMK z!-;mLgO|5DyB*FQ?54YCT&|wu%JDpJejr~BJ%5Oog>YfEuuxbn>;qO$2%iZ{#r42z zA1PCsDV0bIr5w3Z-YI`5|5X{N3hGdG1hjfO^y^x6y}D8DsRe1v$rB{UxYw9xEHO?P z|L{;U&gu^>RAF!M&@~d(IKbi^$|NOMnWM~C)+_bOtI8p0 z;jfe)>P_lMyxjwMzm3qy4eCCX(|okwXnnO2uwgT`*;^lj384rZ8Og-H0PS-=1S=6t!ACM3ljbpv(bFtJYt?O zPnlnsZRROk*7yvvW|v-ny3T)v!N$*@ekso;x2J8tkXPchg2l*kS*Y6rLqe=#;bR$i_|yN7WFKoo4_L6re$ku zwJq8k(8IqXw-A|(B@dAXa+>tlBVZGj=C1ED#IDQn5^|5o^WmVx3qoHozk75%-FXVvBf6Y!%mQ8$t70ZM#;d z)oTsfZf%dYS8GJ?P1+Hy8MgYA)~cP>+O)G8N4$v-@g;u5pY$RDBoJ0An1sMm$%GJ# zgpo)RLt^3iOdzQw9b8mO7LamMMb?rUQcLQA!@Z;t-cU1X1vWX|Tldrb^+3I!&O^S# z^hiBUkJl&Ysd|o{uP=b*tq>^#bpOKySrZ6ToqWRuOFEdTYB?2aY=k zemiA(+dj6h?Qi$818rhkcD$Wxr$ciWg6}HqN>H`d-fq{~4R(`##BR1v+1`%7)5{5P z0-azd#Ni#;W678uo8aU)`A)G@>XbQaomywRQwQz1+i7x6IjzoV=t*DK&-Hf$T-hbA z18EClcP`V#B>iA6^X^*qy=IHcxgMhqgnF?)#E|yRFVTKSCTrio3xNN z@M1qb1k|)Z%~((~8Pv=KH4F7(P_#y`*PHcI`f2?vyaQjuAO1lsG9mspV=V?Ava2FSN;7c;vyFtXWzzz9BO4C9^=Qf>x-7?6-l+ zzL4uU51lK>dPs32Y4XT#8wml8V<54`kkcxCz1{@6w!uco@QdQ$0~NymDZ^JsrLor7 zXw({YklH<o zvdk%WDnb8^kjpv`7c@dHn<1H};ZX$Qdq{TUA&cp5DI}5cLY>;Qkh)$%KYU%r3Q711D1x+=3zfoNNLm2sZi!)H3?wVbL;C`; z$Rk= 1020) +#pragma once +#endif + +/** + * Credits to the original ProjectXI team for these functions which is where they have + * originated from. (See CBasePacket of the ProjectXI source code base.) + */ + +namespace Ashita +{ + class BinaryData + { + public: + /** + * Packs data into the given buffer. (Big Endian) + */ + static uint32_t PackBitsBE(uint8_t* data, uint64_t value, uint32_t offset, uint8_t len) + { + return PackBitsBE(data, value, 0, offset, len); + } + + /** + * Packs data into the given buffer. (Big Endian) + */ + static uint32_t PackBitsBE(uint8_t* data, uint64_t value, uint32_t byteOffset, uint32_t bitOffset, uint8_t len) + { + byteOffset += bitOffset >> 3; + bitOffset %= 8; + + auto bitmask = (uint64_t)0xFFFFFFFFFFFFFFFFLL; + bitmask >>= 64 - len; + bitmask <<= bitOffset; + value <<= bitOffset; + value &= bitmask; + bitmask ^= 0xFFFFFFFFFFFFFFFFLL; + + if (len + bitOffset <= 8) + { + auto dataPointer = (uint8_t*)&data[byteOffset]; + auto bitmaskUC = (uint8_t)bitmask; + auto valueUC = (uint8_t)value; + *dataPointer &= bitmaskUC; + *dataPointer |= valueUC; + } + else if (len + bitOffset <= 16) + { + auto dataPointer = (uint16_t*)&data[byteOffset]; + auto bitmaskUC = (uint16_t)bitmask; + auto valueUC = (uint16_t)value; + *dataPointer &= bitmaskUC; + *dataPointer |= valueUC; + } + else if (len + bitOffset <= 32) + { + auto dataPointer = (uint32_t*)&data[byteOffset]; + auto bitmaskUC = (uint32_t)bitmask; + auto valueUC = (uint32_t)value; + *dataPointer &= bitmaskUC; + *dataPointer |= valueUC; + } + else if (len + bitOffset <= 64) + { + auto dataPointer = (uint64_t*)&data[byteOffset]; + *dataPointer &= bitmask; + *dataPointer |= value; + } + else + { + // We should not get here.. an error occurred.. + // data size > 64bits + } + + return (byteOffset << 3) + bitOffset + len; + } + + /** + * Unpacks data from the given buffer. (Big Endian) + */ + static uint64_t UnpackBitsBE(uint8_t* data, uint32_t offset, uint8_t len) + { + return UnpackBitsBE(data, 0, offset, len); + } + + /** + * Unpacks data from the given buffer. (Big Endian) + */ + static uint64_t UnpackBitsBE(uint8_t* data, uint32_t byteOffset, uint32_t bitOffset, uint8_t len) + { + byteOffset += (bitOffset >> 3); + bitOffset %= 8; + + uint64_t retVal; + auto bitmask = (uint64_t)0xFFFFFFFFFFFFFFFFLL; + bitmask >>= (64 - len); + bitmask <<= bitOffset; + + if (len + bitOffset <= 8) + { + auto dataPointer = (uint8_t*)&data[byteOffset]; + retVal = (*dataPointer&(uint8_t)bitmask) >> bitOffset; + } + else if (len + bitOffset <= 16) + { + auto dataPointer = (uint16_t*)&data[byteOffset]; + retVal = (*dataPointer&(uint16_t)bitmask) >> bitOffset; + } + else if (len + bitOffset <= 32) + { + auto dataPointer = (uint32_t*)&data[byteOffset]; + retVal = (*dataPointer&(uint32_t)bitmask) >> bitOffset; + } + else if (len + bitOffset <= 64) + { + auto dataPointer = (uint64_t*)&data[byteOffset]; + retVal = (*dataPointer&(uint64_t)bitmask) >> bitOffset; + } + else + { + // We should not get here.. an error occurred.. + // data size > 64bits + return 0; + } + + return retVal; + } + + /** + * Packs data into the given buffer. (Little Endian) + */ + static uint32_t PackBitsLE(uint8_t* data, uint64_t value, uint32_t offset, uint8_t len) + { + return PackBitsLE(data, value, 0, offset, len); + } + + /** + * Packs data into the given buffer. (Little Endian) + */ + static uint32_t PackBitsLE(uint8_t* data, uint64_t value, uint32_t byteOffset, uint32_t bitOffset, uint8_t len) + { + byteOffset += bitOffset >> 3; + bitOffset %= 8; + + uint8_t bytesNeeded; + if (bitOffset + len <= 8) + bytesNeeded = 1; + else if (bitOffset + len <= 16) + bytesNeeded = 2; + else if (bitOffset + len <= 32) + bytesNeeded = 4; + else if (bitOffset + len <= 64) + bytesNeeded = 8; + else + { + // We should not get here.. an error occurred.. + // data size > 64bits + return 0; + } + + auto modifieddata = new uint8_t[bytesNeeded]; + for (uint8_t curByte = 0; curByte < bytesNeeded; ++curByte) + { + modifieddata[curByte] = data[byteOffset + (bytesNeeded - 1) - curByte]; + } + + int newBitOffset = (bytesNeeded << 3) - (bitOffset + len); + PackBitsBE(&modifieddata[0], value, 0, newBitOffset, len); + + for (uint8_t curByte = 0; curByte < bytesNeeded; ++curByte) + { + data[byteOffset + (bytesNeeded - 1) - curByte] = modifieddata[curByte]; + } + + if (modifieddata) + delete[] modifieddata; + + return (byteOffset << 3) + bitOffset + len; + } + + /** + * Unpacks data from the given buffer. (Little Endian) + */ + static uint64_t UnpackBitsLE(uint8_t* data, uint32_t offset, uint8_t len) + { + return UnpackBitsLE(data, 0, offset, len); + } + + /** + * Unpacks data from the given buffer. (Little Endian) + */ + static uint64_t UnpackBitsLE(uint8_t* data, uint32_t byteOffset, uint32_t bitOffset, uint8_t len) + { + byteOffset += bitOffset >> 3; + bitOffset %= 8; + + uint8_t bytesNeeded; + if (bitOffset + len <= 8) + bytesNeeded = 1; + else if (bitOffset + len <= 16) + bytesNeeded = 2; + else if (bitOffset + len <= 32) + bytesNeeded = 4; + else if (bitOffset + len <= 64) + bytesNeeded = 8; + else + { + // We should not get here.. an error occurred.. + // data size > 64bits + return 0; + } + + uint64_t retVal; + + auto modifieddata = new uint8_t[bytesNeeded]; + for (uint8_t curByte = 0; curByte < bytesNeeded; ++curByte) + { + modifieddata[curByte] = data[byteOffset + (bytesNeeded - 1) - curByte]; + } + + if (bytesNeeded == 1) + { + uint8_t bitmask = 0xFF >> bitOffset; + retVal = (modifieddata[0] & bitmask) >> (8 - (len + bitOffset)); + } + else + { + int newBitOffset = (bytesNeeded * 8) - (bitOffset + len); + retVal = UnpackBitsBE(&modifieddata[0], 0, newBitOffset, len); + } + + if (modifieddata) + delete[] modifieddata; + + return retVal; + } + }; +}; // Ashita + +#endif // __ASHITA_AS_BINARYDATA_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_CommandParser.h b/plugins/ADK/AS_CommandParser.h new file mode 100644 index 0000000..87bf6d2 --- /dev/null +++ b/plugins/ADK/AS_CommandParser.h @@ -0,0 +1,232 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_COMMANDPARSER_H_INCLUDED__ +#define __ASHITA_AS_COMMANDPARSER_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include +#include + +// Helper Macros +#define HANDLECOMMAND_GA(arg1, arg2, arg3, arg4, arg5, arg6, ...) arg6 +#define HANDLECOMMAND_01(a) Ashita::CommandParser::__command_parse(args[0].c_str(), a) +#define HANDLECOMMAND_02(a, b) Ashita::CommandParser::__command_parse(args[0].c_str(), a, b) +#define HANDLECOMMAND_03(a, b, c) Ashita::CommandParser::__command_parse(args[0].c_str(), a, b, c) +#define HANDLECOMMAND_04(a, b, c, d) Ashita::CommandParser::__command_parse(args[0].c_str(), a, b, c, d) +#define HANDLECOMMAND_05(a, b, c, d, e) Ashita::CommandParser::__command_parse(args[0].c_str(), a, b, c, d, e) +#define HANDLECOMMAND_CC(...) HANDLECOMMAND_GA(__VA_ARGS__, HANDLECOMMAND_05, HANDLECOMMAND_04, HANDLECOMMAND_03, HANDLECOMMAND_02, HANDLECOMMAND_01,) +#define HANDLECOMMAND(...) if(args.size() > 0 && HANDLECOMMAND_CC(__VA_ARGS__)(__VA_ARGS__)) + +namespace Ashita +{ + namespace CommandParser + { + /** + * Compares a command to a subarg to determine if they match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + static bool __forceinline __command_cmp(const char* cmd, const char* arg1) + { + if (cmd == nullptr || arg1 == nullptr) + return false; + return (_stricmp(cmd, arg1) == 0); + } + + /** + * Compares a command to a subarg to determine if they match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + template + static bool __command_parse(T cmd, T arg1) + { + return __command_cmp(cmd, arg1); + } + + /** + * Compares a command to subargs to determine if either match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @param {const char*} arg2 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + template + static bool __command_parse(T cmd, T arg1, T arg2) + { + return __command_cmp(cmd, arg1) || __command_cmp(cmd, arg2); + } + + /** + * Compares a command to subargs to determine if either match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @param {const char*} arg2 - The argument to compare to. + * @param {const char*} arg3 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + template + static bool __command_parse(T cmd, T arg1, T arg2, T arg3) + { + return __command_cmp(cmd, arg1) || __command_cmp(cmd, arg2) || __command_cmp(cmd, arg3); + } + + /** + * Compares a command to subargs to determine if either match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @param {const char*} arg2 - The argument to compare to. + * @param {const char*} arg3 - The argument to compare to. + * @param {const char*} arg4 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + template + static bool __command_parse(T cmd, T arg1, T arg2, T arg3, T arg4) + { + return __command_cmp(cmd, arg1) || __command_cmp(cmd, arg2) || __command_cmp(cmd, arg3) || __command_cmp(cmd, arg4); + } + + /** + * Compares a command to subargs to determine if either match. + * + * @param {const char*} cmd - The command to compare against + * @param {const char*} arg1 - The argument to compare to. + * @param {const char*} arg2 - The argument to compare to. + * @param {const char*} arg3 - The argument to compare to. + * @param {const char*} arg4 - The argument to compare to. + * @param {const char*} arg5 - The argument to compare to. + * @returns {bool} True if matches, false otherwise. + */ + template + static bool __command_parse(T cmd, T arg1, T arg2, T arg3, T arg4, T arg5) + { + return __command_cmp(cmd, arg1) || __command_cmp(cmd, arg2) || __command_cmp(cmd, arg3) || __command_cmp(cmd, arg4) || __command_cmp(cmd, arg5); + } + }; // namespace CommandParser + + namespace Commands + { + /** + * Determines if the given character is a space character. + * (Used to avoid CRT asserts.) + * + * @param {char} c - The character to check. + * @returns {bool} True if a space char, false otherwise. + */ + static __forceinline bool _isspace(char c) + { + auto num = (int32_t)c; + + // Checks for the following: ' ', \t \n \v \f \r + if (num == 0x20 || num == 0x09 || num == 0x0A || num == 0x0B || num == 0x0C || num == 0x0D) + return true; + return false; + } + + /** + * Obtains the command arguments from the given raw command. + * + * @param {const char*} command - The command to parse for arguments. + * @param {std::vector} args - The return vector to hold the found arguments. + * @returns {uint32_t} The number of arguments parsed from the command. + */ + static uint32_t GetCommandArgs(const char* command, std::vector* args) + { + // The current parsing state we are in.. + enum { NONE, IN_WORD, IN_STRING } state = NONE; + + char currentArgument[255] = { 0 }; + auto p = command; + char *pStart = nullptr; + + // Walk the string to locate arguments.. + for (; *p != 0; ++p) + { + // Obtain the current character.. + auto currChar = (char)*p; + + // Handle the current state.. + switch (state) + { + case NONE: + if (Ashita::Commands::_isspace(currChar)) + continue; + if (currChar == '"') + { + state = IN_STRING; + pStart = (char*)p + 1; + continue; + } + state = IN_WORD; + pStart = (char*)p; + continue; + + case IN_STRING: + if (currChar == '"') + { + strncpy_s(currentArgument, pStart, p - pStart); + args->push_back(std::string(currentArgument)); + state = NONE; + pStart = nullptr; + } + continue; + + case IN_WORD: + if (Ashita::Commands::_isspace(currChar)) + { + strncpy_s(currentArgument, pStart, p - pStart); + args->push_back(std::string(currentArgument)); + state = NONE; + pStart = nullptr; + } + continue; + } + } + + // Add any left-over words.. + if (pStart != nullptr) + { + strncpy_s(currentArgument, pStart, p - pStart); + args->push_back(std::string(currentArgument)); + } + + // Return the number of found arguments.. + return args->size(); + } + }; // namespace Commands +}; // namespace Ashita + +#endif // __ASHITA_AS_COMMANDPARSER_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Event.h b/plugins/ADK/AS_Event.h new file mode 100644 index 0000000..c813e5c --- /dev/null +++ b/plugins/ADK/AS_Event.h @@ -0,0 +1,103 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_EVENT_H_INCLUDED__ +#define __ASHITA_AS_EVENT_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include + +namespace Ashita +{ + namespace Threading + { + class AS_Event + { + HANDLE m_EventHandle; + + public: + /** + * Constructor and Deconstructor + */ + explicit AS_Event(bool manualReset = true) + { + this->m_EventHandle = ::CreateEvent(nullptr, manualReset, FALSE, nullptr); + } + virtual AS_Event::~AS_Event(void) + { + if (this->m_EventHandle != nullptr) + ::CloseHandle(this->m_EventHandle); + this->m_EventHandle = nullptr; + } + + public: + /** + * Resets the event to its default state. + * + * @returns {bool} True on success, false otherwise. + */ + bool Reset(void) + { + return ::ResetEvent(this->m_EventHandle) ? true : false; + } + + /** + * Raises the events signal. + * + * @returns {bool} True on success, false otherwise. + */ + bool Raise(void) + { + return (::SetEvent(this->m_EventHandle) ? true : false); + } + + /** + * Determines if the event is signaled. + * + * @returns {bool} True on success, false otherwise. + */ + bool IsSignaled(void) const + { + return (::WaitForSingleObject(this->m_EventHandle, 0) == WAIT_OBJECT_0); + } + + /** + * Waits for the event to be signaled. + * + * @param {uint32_t} milliseconds - The amount of time, in milliseconds, to wait. + * @returns {bool} True on success, false otherwise. + */ + bool WaitForEvent(uint32_t milliseconds) const + { + return (::WaitForSingleObject(this->m_EventHandle, milliseconds) == WAIT_OBJECT_0); + } + }; + }; // namespace Threading +}; // namespace Ashita + +#endif // __ASHITA_AS_EVENT_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Exception.h b/plugins/ADK/AS_Exception.h new file mode 100644 index 0000000..083e5b7 --- /dev/null +++ b/plugins/ADK/AS_Exception.h @@ -0,0 +1,149 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_EXCEPTION_H_INCLUDED__ +#define __ASHITA_AS_EXCEPTION_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include +#include + +// Missing Status Code Defines +#ifndef STATUS_POSSIBLE_DEADLOCK +#define STATUS_POSSIBLE_DEADLOCK 0xC0000194 +#endif + +// Macro For Handling Exception Cases +#define CASE(Exception) \ + case Exception: \ + this->m_Exception = #Exception; \ + break; + +namespace Ashita +{ + namespace Exception + { + class AS_Exception + { + uint32_t m_ExceptionId; + const char* m_Exception; + + public: + /** + * Constructor and Deconstructor + */ + explicit AS_Exception(uint32_t id) + : m_ExceptionId(id) + , m_Exception(nullptr) + { + switch (this->m_ExceptionId) + { + CASE(EXCEPTION_ACCESS_VIOLATION); + CASE(EXCEPTION_ARRAY_BOUNDS_EXCEEDED); + CASE(EXCEPTION_BREAKPOINT); + CASE(EXCEPTION_DATATYPE_MISALIGNMENT); + CASE(EXCEPTION_FLT_DENORMAL_OPERAND); + CASE(EXCEPTION_FLT_DIVIDE_BY_ZERO); + CASE(EXCEPTION_FLT_INEXACT_RESULT); + CASE(EXCEPTION_FLT_INVALID_OPERATION); + CASE(EXCEPTION_FLT_OVERFLOW); + CASE(EXCEPTION_FLT_STACK_CHECK); + CASE(EXCEPTION_FLT_UNDERFLOW); + CASE(EXCEPTION_GUARD_PAGE); + CASE(EXCEPTION_ILLEGAL_INSTRUCTION); + CASE(EXCEPTION_IN_PAGE_ERROR); + CASE(EXCEPTION_INT_DIVIDE_BY_ZERO); + CASE(EXCEPTION_INT_OVERFLOW); + CASE(EXCEPTION_INVALID_DISPOSITION); + CASE(EXCEPTION_INVALID_HANDLE); + CASE(EXCEPTION_NONCONTINUABLE_EXCEPTION); + CASE(EXCEPTION_POSSIBLE_DEADLOCK); + CASE(EXCEPTION_PRIV_INSTRUCTION); + CASE(EXCEPTION_SINGLE_STEP); + CASE(EXCEPTION_STACK_OVERFLOW); + + default: + this->m_Exception = "Unknown exception occurred."; + break; + } + } + ~AS_Exception(void) { } + + public: + /** + * Returns the exception id of the current wrapped exception. + * + * @returns {uint32_t} The exception id. + */ + uint32_t GetExceptionId(void) const + { + return this->m_ExceptionId; + } + const char* GetException(void) const + { + return this->m_Exception; + } + }; + + class ScopedTranslator + { + _se_translator_function m_Function; + + public: + /** + * Constructor and Deconstructor + */ + ScopedTranslator(void) + { + this->m_Function = ::_set_se_translator(&ScopedTranslator::ScopedTranslatorFunc); + } + ~ScopedTranslator(void) + { + if (this->m_Function != nullptr) + ::_set_se_translator(this->m_Function); + this->m_Function = nullptr; + } + + private: + /** + * Exception translation function used to convert a C structured exception to a C++ typed exception. + * (Used to wrap the exception into our custom exception object.) + * + * @param {uint32_t} id - The id of the exception being wrapped. + * @param {EXCEPTION_POINTERS*} pointers - The pointer information of the exception being handled. + */ + static void ScopedTranslatorFunc(uint32_t id, struct _EXCEPTION_POINTERS* pointers) + { + UNREFERENCED_PARAMETER(pointers); + throw AS_Exception(id); + } + }; + }; // namespace Exception +}; // namespace Ashita + +#endif // __ASHITA_AS_EXCEPTION_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_LockableObject.h b/plugins/ADK/AS_LockableObject.h new file mode 100644 index 0000000..027f619 --- /dev/null +++ b/plugins/ADK/AS_LockableObject.h @@ -0,0 +1,79 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_LOCKABLEOBJECT_H_INCLUDED__ +#define __ASHITA_AS_LOCKABLEOBJECT_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include + +namespace Ashita +{ + namespace Threading + { + class AS_LockableObject + { + CRITICAL_SECTION m_CriticalSection; + + // Delete the copy constructor. + AS_LockableObject(const AS_LockableObject& obj) = delete; + + public: + /** + * Constructor and Deconstructor + */ + AS_LockableObject(void) + { + ::InitializeCriticalSection(&this->m_CriticalSection); + } + virtual AS_LockableObject::~AS_LockableObject(void) + { + ::DeleteCriticalSection(&this->m_CriticalSection); + } + + public: + /** + * Locks the object for exclusive usage. + */ + void Lock(void) + { + ::EnterCriticalSection(&this->m_CriticalSection); + } + + /** + * Unlocks the object from exclusive usage. + */ + void Unlock(void) + { + ::LeaveCriticalSection(&this->m_CriticalSection); + } + }; + }; // namespace Threading +}; // namespace Ashita + +#endif // __ASHITA_AS_LOCKABLEOBJECT_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Memory.h b/plugins/ADK/AS_Memory.h new file mode 100644 index 0000000..763b0f2 --- /dev/null +++ b/plugins/ADK/AS_Memory.h @@ -0,0 +1,126 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_MEMORY_H_INCLUDED__ +#define __ASHITA_AS_MEMORY_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include +#include +#include +#include + +namespace Ashita +{ + class Memory + { + public: + /** + * Locates a pattern of data within a large block of memory. + * + * @param {std::vector} data - The data to scan for the pattern within. + * @param {uintptr_t} baseAddress - The base address to add to the offset when the pattern is found. + * @param {const char*} pattern - The pattern to scan for. + * @param {uintptr_t} offset - The offset to add after the pattern has been found. + * @param {uintptr_t} count - The result count to use if the pattern is found multiple times. + * @returns {uintptr_t} The address where the pattern was located, 0 otherwise. + */ + static uintptr_t FindPattern(std::vector data, uintptr_t baseAddress, const char* pattern, uintptr_t offset, uintptr_t count) + { + // Ensure the incoming pattern is properly aligned.. + if (strlen(pattern) % 2 > 0) + return 0; + + // Convert the pattern to a vector of data.. + std::vector> vpattern; + for (size_t x = 0, y = strlen(pattern) / 2; x < y; x++) + { + // Obtain the current byte.. + std::stringstream stream(std::string(pattern + (x * 2), 2)); + + // Check if this is a wildcard.. + if (stream.str() == "??") + vpattern.push_back(std::make_pair(00, false)); + else + { + auto byte = strtol(stream.str().c_str(), nullptr, 16); + vpattern.push_back(std::make_pair((uint8_t)byte, true)); + } + } + + auto scanStart = data.begin(); + auto result = (uintptr_t)0; + + while (true) + { + // Search for the pattern.. + auto ret = std::search(scanStart, data.end(), vpattern.begin(), vpattern.end(), + [&](uint8_t curr, std::pair currPattern) + { + return (!currPattern.second) || curr == currPattern.first; + }); + + // Did we find a match.. + if (ret != data.end()) + { + // If we hit the usage count, return the result.. + if (result == count || count == 0) + return (std::distance(data.begin(), ret) + baseAddress) + offset; + + // Increment the found count and scan again.. + ++result; + scanStart = ++ret; + } + else + break; + } + + return 0; + } + + /** + * Obtains the calling module handle for the given address. + * + * @param {uintptr_t} returnAddress - The address to locate the module owner of. + * @returns {HMODULE} The module handle if found, nullptr otherwise. + */ + static HMODULE __stdcall GetCallingModule(uintptr_t returnAddress) + { + if (returnAddress == 0) + return nullptr; + + MEMORY_BASIC_INFORMATION mbi = { 0 }; + if (::VirtualQuery((LPCVOID)returnAddress, &mbi, sizeof(MEMORY_BASIC_INFORMATION)) == sizeof(MEMORY_BASIC_INFORMATION)) + return (HMODULE)mbi.AllocationBase; + + return nullptr; + } + }; +}; // namespace Ashita + +#endif // __ASHITA_AS_MEMORY_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Objects.h b/plugins/ADK/AS_Objects.h new file mode 100644 index 0000000..dcb08e9 --- /dev/null +++ b/plugins/ADK/AS_Objects.h @@ -0,0 +1,128 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_OBJECTS_H_INCLUDED__ +#define __ASHITA_AS_OBJECTS_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include + +namespace Ashita +{ + typedef struct tagAS_Rect + { + uint32_t x, y, w, h; + + tagAS_Rect(void) + : x(0), y(0), w(0), h(0) + { } + tagAS_Rect(uint32_t nW, uint32_t nH) + : x(0), y(0), w(nW), h(nH) + { } + tagAS_Rect(uint32_t nX, uint32_t nY, uint32_t nW, uint32_t nH) + : x(nX), y(nY), w(nW), h(nH) + { } + explicit tagAS_Rect(const RECT& r) + : x(r.left), y(r.top), w(r.right - r.left), h(r.bottom - r.top) + { } + + // Assignment operator overload. + tagAS_Rect operator= (const tagAS_Rect& r) + { + this->x = r.x; + this->y = r.y; + this->w = r.w; + this->h = r.h; + + return *this; + } + // Addition operator overload. + tagAS_Rect operator+ (const tagAS_Rect& r) + { + this->x += r.x; + this->y += r.y; + this->w += r.w; + this->h += r.h; + + return *this; + } + // Subtraction operator overload. + tagAS_Rect operator- (const tagAS_Rect& r) + { + this->x -= r.x; + this->y -= r.y; + this->w -= r.w; + this->h -= r.h; + + return *this; + } + + // Equality operator overload. + bool operator== (const tagAS_Rect& r) const + { + return this->x == r.x && this->y == r.y && this->w == r.w && this->h == r.h; + } + + // Non-Equality opreator overload. + bool operator!= (const tagAS_Rect& r) const + { + return !(*this == r); + } + } asrect_t; + + typedef struct tagAS_WindowInfo + { + HWND Hwnd; + uint32_t Style; + uint32_t StyleEx; + asrect_t WindowRect; + + tagAS_WindowInfo(void) + : Hwnd(nullptr), Style(0), StyleEx(0), WindowRect(0, 0, 0, 0) + { } + tagAS_WindowInfo(HWND hWnd, uint32_t dwStyle, uint32_t dwStyleEx, int32_t x, int32_t y, int32_t w, int32_t h) + : Hwnd(hWnd), Style(dwStyle), StyleEx(dwStyleEx), WindowRect(x, y, w, h) + { } + + /** + * Resets the window information class. + */ + void Reset(void) + { + this->Hwnd = nullptr; + this->Style = 0; + this->StyleEx = 0; + this->WindowRect.x = 0; + this->WindowRect.y = 0; + this->WindowRect.w = 0; + this->WindowRect.h = 0; + } + } aswindowinfo_t; +}; // namespace Ashita + +#endif // __ASHITA_AS_OBJECTS_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Registry.h b/plugins/ADK/AS_Registry.h new file mode 100644 index 0000000..93348ce --- /dev/null +++ b/plugins/ADK/AS_Registry.h @@ -0,0 +1,141 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_REGISTRY_H_INCLUDED__ +#define __ASHITA_AS_REGISTRY_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include + +namespace Ashita +{ + /** + * Language Id Enumeration + */ + enum class LanguageId : uint32_t { + Default = 0, + Japanese = 1, + English = 2, + European = 3 + }; + + /** + * Install Path Id Enumeration + */ + enum class SquareEnixEntity : uint32_t { + PlayOnline = 0, + FinalFantasyXI = 1, + FinalFantasyXI_TestClient = 2, + TetraMaster = 3 + }; + + class Registry + { + public: + /** + * Obtains the install path for the given Square Enix entity. + * + * @param {LanguageId} langId - The language id to use for looking up the proper registry key parent. + * @param {SquareEnixEntity} entity - The Square Enix entity id to lookup. + * @param {LPSTR} buffer - The output buffer to hold the path. + * @param {uint32_t} - The maximum size of the buffer. + * @returns {bool} True on success, false otherwise. + */ + static bool GetInstallPath(LanguageId langId, SquareEnixEntity entity, LPSTR buffer, uint32_t bufferSize) + { + // Ensure the language id is within a valid range.. + if ((uint32_t)langId < 0 || (uint32_t)langId > 4) + return false; + + const char languageTags[4][255] = { "US", "", "US", "EU" }; + const char installFolder[4][255] = { "1000", "0001", "0015", "0002" }; + + // Build the registry key to read from.. + char registryPath[MAX_PATH] = { 0 }; + sprintf_s(registryPath, MAX_PATH, "SOFTWARE\\PlayOnline%s\\InstallFolder", languageTags[(uint32_t)langId]); + + // Open the key for reading.. + HKEY key = nullptr; + if (!(::RegOpenKeyExA(HKEY_LOCAL_MACHINE, registryPath, 0, KEY_QUERY_VALUE | KEY_WOW64_32KEY, &key) == ERROR_SUCCESS)) + return false; + + // Read the install path from the registry.. + char installPath[MAX_PATH] = { 0 }; + DWORD size = MAX_PATH; + DWORD type = REG_DWORD; + if (!(::RegQueryValueExA(key, installFolder[(uint32_t)entity], nullptr, &type, (LPBYTE)installPath, &size) == ERROR_SUCCESS)) + { + ::RegCloseKey(key); + return false; + } + ::RegCloseKey(key); + + // Ensure our buffer is large enough.. + if (strlen(installPath) > bufferSize) + return false; + + memcpy_s(buffer, bufferSize, installPath, size); + return true; + } + + /** + * Sets a value in the registry. + * + * @param {LanguageId} langId - The language id to use for writing to the proper registry key parent. + * @param {const char*} parent - The inner parent that holds the key we want to write to. + * @param {const char*} keyName - The key name to write the value to. + * @param {uint32_t} value - The value to write to the key. + * @returns {bool} True on success, false otherwise. + */ + static bool SetValue(LanguageId langId, const char* parent, const char* keyName, uint32_t value) + { + // Ensure the language id is within a valid range.. + if ((uint32_t)langId < 0 || (uint32_t)langId > 4) + return false; + + const char languageTags[4][255] = { "US", "", "US", "EU" }; + + // Build the registry key to read from.. + char registryPath[MAX_PATH] = { 0 }; + sprintf_s(registryPath, MAX_PATH, "SOFTWARE\\PlayOnline%s\\%s", languageTags[(uint32_t)langId], parent); + + // Open the key for writing.. + HKEY key = nullptr; + if (!(::RegOpenKeyExA(HKEY_LOCAL_MACHINE, registryPath, 0, KEY_WRITE | KEY_QUERY_VALUE | KEY_WOW64_32KEY, &key) == ERROR_SUCCESS)) + return false; + + // Write the value.. + auto ret = ::RegSetValueExA(key, keyName, NULL, REG_DWORD, (LPBYTE)&value, sizeof(DWORD)); + ::RegCloseKey(key); + + return ret == ERROR_SUCCESS; + } + }; +}; // namespace Ashita + +#endif // __ASHITA_AS_REGISTRY_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/AS_Thread.h b/plugins/ADK/AS_Thread.h new file mode 100644 index 0000000..1813aec --- /dev/null +++ b/plugins/ADK/AS_Thread.h @@ -0,0 +1,236 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_AS_THREAD_H_INCLUDED__ +#define __ASHITA_AS_THREAD_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include +#include "AS_Event.h" + +namespace Ashita +{ + namespace Threading + { + /** + * Thread Priority Enumeration + */ + enum class ThreadPriority : int32_t { + Lowest = -2, + BelowNormal = -1, + Normal = 0, + AboveNormal = 1, + Highest = 2 + }; + + class AS_Thread + { + HANDLE m_ThreadHandle; + uint32_t m_ThreadId; + AS_Event m_StartEvent; + AS_Event m_EndEvent; + + public: + AS_Thread(void) + : m_ThreadHandle(nullptr) + , m_ThreadId(0) + , m_StartEvent(true) + , m_EndEvent(true) + { } + virtual ~AS_Thread(void) + { + if (this->m_ThreadHandle != nullptr) + this->Stop(); + } + + public: + /** + * Thread entry function the inheriting class must implement. + * + * @returns {uint32_t} The thread functions return value. + */ + virtual uint32_t ThreadEntry(void) = 0; + + public: + /** + * Thread entry function used to signal the thread and run the inheriting + * classes thread entry function. + * + * @returns {uint32_t} The thread functions return value. + */ + uint32_t InternalEntry(void) + { + if (this->IsTerminated()) + return 0; + + this->m_EndEvent.Reset(); + ::Sleep(10); + this->m_StartEvent.Raise(); + + return this->ThreadEntry(); + } + + /** + * Starts the thread. + */ + void Start() + { + this->m_StartEvent.Reset(); + this->m_ThreadHandle = ::CreateThread(nullptr, 0, (LPTHREAD_START_ROUTINE)ThreadCallback, (LPVOID)this, 0, (LPDWORD)&this->m_ThreadId); + } + + /** + * Stops the thread. + */ + void Stop(void) + { + this->RaiseEnd(); + + if (this->WaitForFinish(INFINITE)) + { + ::CloseHandle(this->m_ThreadHandle); + this->m_ThreadHandle = nullptr; + this->m_ThreadId = 0; + } + } + + /** + * Waits the given amount of milliseconds for the thread handle to signal. + * + * @param {uint32_t} milliseconds - The amount of time, in milliseconds, to wait. + * @returns {uint32_t} True on success, false otherwise. + */ + bool WaitForFinish(uint32_t milliseconds = INFINITE) const + { + if (this->m_ThreadHandle == nullptr) + return false; + + return ::WaitForSingleObject(this->m_ThreadHandle, milliseconds) != WAIT_TIMEOUT; + } + + /** + * Sets the threads priority. + * + * @param {ThreadPriority} p - The thread priority to set the thread to. + */ + void SetPriority(ThreadPriority p) const + { + if (this->m_ThreadHandle != nullptr) + ::SetThreadPriority(this->m_ThreadHandle, (int32_t)p); + } + + /** + * Gets the threads priority. + * + * @returns {ThreadPriority} The threads priority. + */ + ThreadPriority GetPriority(void) const + { + if (this->m_ThreadHandle == nullptr) + return (ThreadPriority)0; + + return (ThreadPriority)::GetThreadPriority(this->m_ThreadHandle); + } + + /** + * Signals the end event telling the thread it should stop. + */ + void RaiseEnd(void) + { + this->m_EndEvent.Raise(); + } + + /** + * Resets the end event signal. + */ + void ResetEnd(void) + { + this->m_EndEvent.Reset(); + } + + /** + * Returns if the thread has been terminated or not. + * + * @returns {bool} True if the thread is terminated, false otherwise. + */ + bool IsTerminated(void) const + { + return this->m_EndEvent.IsSignaled(); + } + + public: + /** + * Returns the threads handle. + * + * @returns {HANDLE} This threads handle. + */ + HANDLE GetHandle(void) const { return this->m_ThreadHandle; } + + /** + * Returns the threads id. + * + * @returns {uint32_t} This threads id. + */ + uint32_t GetId(void) const { return this->m_ThreadId; } + + /** + * Returns the threads exit code. + * + * @returns {uint32_t} This threads exit code. + */ + uint32_t GetExitCode(void) const + { + if (this->m_ThreadHandle == nullptr) + return 0; + + uint32_t exitCode = 0; + ::GetExitCodeThread(this->m_ThreadHandle, (LPDWORD)&exitCode); + + return exitCode; + } + + private: + /** + * Internal thread callback to invoke the inheriting objects thread handler. + * + * @param {LPVOID} param - The AS_Thread object passed to this callback. + * @returns {uint32_t} The internal threads return value, 0 otherwise. + */ + static uint32_t __stdcall ThreadCallback(LPVOID param) + { + auto thread = (AS_Thread*)param; + if (thread != nullptr) + return thread->InternalEntry(); + + return 0; + } + }; + }; // namespace Threading +}; // namespace Ashita + +#endif // __ASHITA_AS_THREAD_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/Ashita.h b/plugins/ADK/Ashita.h new file mode 100644 index 0000000..b54614b --- /dev/null +++ b/plugins/ADK/Ashita.h @@ -0,0 +1,1532 @@ +/** + * Ashita - Copyright (c) 2014 - 2016 atom0s [atom0s@live.com] + * + * This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License. + * To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to + * Creative Commons, PO Box 1866, Mountain View, CA 94042, USA. + * + * By using Ashita, you agree to the above license and its terms. + * + * Attribution - You must give appropriate credit, provide a link to the license and indicate if changes were + * made. You must do so in any reasonable manner, but not in any way that suggests the licensor + * endorses you or your use. + * + * Non-Commercial - You may not use the material (Ashita) for commercial purposes. + * + * No-Derivatives - If you remix, transform, or build upon the material (Ashita), you may not distribute the + * modified material. You are, however, allowed to submit the modified works back to the original + * Ashita project in attempt to have it added to the original project. + * + * You may not apply legal terms or technological measures that legally restrict others + * from doing anything the license permits. + * + * No warranties are given. + */ + +#ifndef __ASHITA_ADK_H_INCLUDED__ +#define __ASHITA_ADK_H_INCLUDED__ + +#if defined (_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// ReSharper Specific Disables (Please do not edit these!) +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// ReSharper disable CppUnusedIncludeDirective +// ReSharper disable CppPolymorphicClassWithNonVirtualPublicDestructor +// +//////////////////////////////////////////////////////////////////////////////////////////////////// + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Interface Version +// +// Defines the current interface version that Ashita is compiled against. This version must match +// when a plugin is loaded for it to work properly. Invalid versions will result in the plugin +// not loading and printing an error. +// +// DO NOT EDIT THIS! +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +#define ASHITA_INTERFACE_VERSION 3.0 + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Direct Input SDK Version Definition +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +#ifndef DIRECTINPUT_VERSION +#define DIRECTINPUT_VERSION 0x0800 +#endif + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// General Includes +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +#include +#include +#include "d3d8/includes/d3d8.h" +#include "d3d8/includes/d3dx8.h" + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita SDK Includes +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +#include "newIDirectInputDevice8A.h" +#include "AS_BinaryData.h" +#include "AS_CommandParser.h" +#include "AS_Event.h" +#include "AS_Exception.h" +#include "AS_LockableObject.h" +#include "AS_Memory.h" +#include "AS_Objects.h" +#include "AS_Registry.h" +#include "AS_Thread.h" +#include "ffxi/entity.h" +#include "ffxi/enums.h" +#include "ffxi/inventory.h" +#include "ffxi/party.h" +#include "ffxi/player.h" +#include "ffxi/target.h" +#include "imgui.h" + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Forward Declarations +// +//////////////////////////////////////////////////////////////////////////////////////////////////// + +struct IEntity; // IEntity forward-declaration. +struct IInventory; // IInventory forward-declaration. +struct IParty; // IParty forward-declaration. +struct IPlayer; // IPlayer forward-declaration. +struct ITarget; // ITarget forward-declaration. +struct IFontObject; // IFontObject forward declaration. +struct IPrimitiveObject; // IPrimitiveObject forward declaration. +struct IKeyboard; // IKeyboard forward declaration. +struct IMouse; // IMouse forward declaration. + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Version Return Object +// +// Used with the GetVersion export of the Ashita.dll file, this can be used to read the +// current version of Ashita from the file properly. +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +#pragma warning(disable : 4201) +union ashitaversion_t +{ + // The raw version value. + uint64_t Version; + + // Union based data parts of Version. + struct { + uint16_t Major; + uint16_t Minor; + uint16_t Build; + uint16_t Revision; + }; +}; +#pragma warning(default : 4201) + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Install Parameters +// +// Used with the Install export of Ashita.dll file. These are the parameters Ashita expects +// to be passed to the install call when it is first being prepared for usage. +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +struct ashitainstallparams_t +{ + HMODULE ModuleInstance; // The module instance of Ashita.dll. + uint32_t LanguageId; // The language id to use. + char BootScript[MAX_PATH]; // The boot script to load for the boot configurations. +}; + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Forward Declarations +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +struct lua_State { }; + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Enumerations +// +// Enumerations used within Ashita's various interfaces and functions. +// +//////////////////////////////////////////////////////////////////////////////////////////////////// +namespace Ashita +{ + /** + * Command Input Type Enumeration + * + * Used with the Ashita ChatManager command functions. + */ + enum class CommandInputType : int32_t { + ForceHandle = -3, // Informs Ashita to handle the command by force. + Script = -2, // Informs Ashita to handle the command as an Ashita based script command. + Parse = -1, // Informs Ashita to handle the command as an Ashita based command. + Menu = 0, // Informs Ashita to handle the command as if it were input via an in-game menu. + Typed = 1, // Informs Ashita to handle the command as if it were typed into the chat window by the player. + Macro = 2 // Informs Ashita to handle the command as if it were invoked from a macro. + }; + + /** + * Frame Anchor Enumeration + * + * Used with Ashita's custom font objects. + */ + enum class FrameAnchor : uint32_t { + TopLeft = 0, // Anchors the font object to the top-left. + TopRight = 1, // Anchors the font object to the top-right. + BottomLeft = 2, // Anchors the font object to the bottom-left. + BottomRight = 3, // Anchors the font object to the bottom-right. + Right = 1, // Anchors the font object to the right. + Bottom = 2 // Anchors the font object to the bottom. + }; + + /** + * FrameAnchor bitwise AND operator override. + * + * @param {FrameAnchor} a - The first frame anchor value. + * @param {FrameAnchor} b - The second frame anchor value. + * @returns {uint32_t} The AND value of a and b. + */ + inline uint32_t operator& (const FrameAnchor& a, const FrameAnchor& b) + { + return (uint32_t)((uint32_t)a & (uint32_t)b); + } + + /** + * Mouse Input Enumeration + * + * Used with Ashita's custom font objects mouse event callback. + */ + enum class MouseInput : uint32_t { + LeftClick = 0, // Left mouse button was clicked. + RightClick = 1, // Right mouse button was clicked. + MiddleClick = 2, // Middle mouse button was clicked. + X1Click = 3, // X1 mouse button was clicked. + X2Click = 4, // X2 mouse button was clicked. + MouseWheelUp = 5, // Mouse wheel was scrolled up. + MouseWheelDown = 6, // Mouse wheel was scrolled down. + MouseMove = 7 // Mouse was moved over the object. + }; + + /** + * Log Level Enumeration + * + * Used with Ashita's logging manager. + */ + enum class LogLevel : uint32_t { + None = 0, + Information = 1, + Warning = 2, + Error = 3, + Debug = 4 + }; +}; // namespace Ashita + +//////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Input Defines +// +//////////////////////////////////////////////////////////////////////////////////////////////////// + +typedef HRESULT /**/(__stdcall *getdatacallback_t)(DWORD, LPDIDEVICEOBJECTDATA, DWORD, LPDWORD, DWORD); +typedef HRESULT /**/(__stdcall *getstatecallback_t)(DWORD, LPVOID); +typedef BOOL /**/(__stdcall *keyboardcallback_t)(WPARAM, LPARAM); +typedef BOOL /**/(__stdcall *mousecallback_t)(WPARAM, LPARAM); + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Font Object Defines +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +typedef std::function MOUSEEVENT; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Resource File Definitions +// +// IAbility +// +// An ability entry parsed from the games data files. Contatins information on how the +// ability works, requirements, and other useful information. +// +// ISpell +// +// A spell entry parsed from the games data files. Contains information on how the spell +// works, requirements, and other useful information. +// +// IMonstrosityAbility +// +// A monstrosity ability entry. Contains info on the abilities requirements. (Used for items.) +// +// IItem +// +// An item entry parsed from the games data files. Contains information on how the item +// works, can be used, requirements, and other useful information. Also contains the items +// bitmap icon used and displayed in-game. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +struct IAbility +{ + uint16_t Id; // The abilities id. (Not the same as its recast id!) + uint8_t Type; // The abilities type. (Type & 7) + uint8_t Element; // The abilities element. + uint16_t ListIconId; // The abilities list icon id. + uint16_t ManaCost; // The abilities mana cost. + uint16_t TimerId; // The abilities timer id. + uint16_t ValidTargets; // The abilities valid targets. + int16_t TP; // The abilities TP cost. + uint8_t Unknown0000; // Unknown. + uint8_t MonsterLevel; // The abilities monster level. + int8_t Range; // The abilities usage range. (Range % 0x0F) + uint8_t Unknown0001[30]; // Unknown. + uint8_t EOE; // EOE (End of entry. 0xFF) + + const char* Name[3]; // The abilities name. (0 = Default, 1 = Japanese, 2 = English) + const char* Description[3]; // The abilities description. (0 = Default, 1 = Japanese, 2 = English) +}; + +struct ISpell +{ + uint16_t Index; // The spells index. (Used with recast.) + uint16_t Type; // The spells magic type. + uint16_t Element; // The spells element type. + uint16_t ValidTargets; // The spells valid targets. + uint16_t Skill; // The spells magic skill type. + uint16_t ManaCost; // The spells mana coast. + uint8_t CastTime; // The spells cast time. (CastTime / 4.0) + uint8_t RecastDelay; // The spells recast delay. (RecastDelay / 4.0) + int16_t LevelRequired[24]; // The spells level requirements. (Per-job, if 0xFF, cannot be learned.) + uint16_t Id; // The spells id. + uint16_t ListIcon1; // The spells icon id (1). + uint16_t ListIcon2; // The spells icon id (2). + uint8_t Requirements; // The spells requirements. + int8_t Range; // The spells casting range. (Range % 0x0F) + uint8_t Unknown0000[29]; // Unknown. + uint8_t EOE; // EOE (End of entry. 0xFF) + + const char* Name[3]; // The spells name. (0 = Default, 1 = Japanese, 2 = English) + const char* Description[3]; // The spells description. (0 = Default, 1 = Japanese, 2 = English) +}; + +struct IMonstrosityAbility +{ + uint16_t MoveId; // The monster move id of the ability. + int8_t Level; // The monster level of the ability. + uint8_t Unknown0000; // Unknown. +}; + +struct IItem +{ + uint32_t ItemId; // The items id. + uint16_t Flags; // The items flags. + uint16_t StackSize; // The items stack size. + uint16_t ItemType; // The items type. + uint16_t ResourceId; // The items resource id. (Mainly used for AH sorting.) + uint16_t ValidTargets; // The items valid targets for use. + + uint16_t Level; // The items level requirement to use. + uint16_t Slots; // The items equipment slots where the item can be equipped to. + uint16_t Races; // The items races that can use the item. + uint32_t Jobs; // The items jobs that can use the item. + uint8_t SuperiorLevel; // The items superior level. + uint16_t ShieldSize; // The items shield size. + uint8_t MaxCharges; // The items max charges. + uint16_t CastTime; // The items cast time. + uint16_t CastDelay; // The items cast delay. + uint32_t RecastDelay; // The items recast delay. + uint16_t BaseItemId; // The items base item id used for upgrades. + uint16_t ItemLevel; // The items item level. + uint16_t Damage; // The items damage. + uint16_t Delay; // The items delay. + uint16_t DPS; // The items damae per second. + uint8_t Skill; // The items skill type. + uint8_t JugSize; // The items jug size. + + uint16_t InstinctCost; // The items instinct cost. + + uint16_t MonstrosityId; // The items monstrosity id. + char MonstrosityName[32]; // The items monstrosity name. + IMonstrosityAbility MonstrosityAbilities[16]; // The items monstrosity abilities. + + uint16_t PuppetSlotId; // The items slot id (for PUP). + uint32_t PuppetElements; // The items elements (for PUP). + + const char* Name[3]; // The items name. + const char* Description[3]; // The items description. + const char* LogNameSingular[3]; // The items log name (singular). + const char* LogNamePlural[3]; // The items log name (plural). + + uint32_t ImageSize; // The items image size. + uint8_t ImageType; // The items image type. + uint8_t ImageName[0x10]; // The items image name. + uint8_t Bitmap[0x980]; // The items bitmap data. +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Chat Manager +// +// Ashita chat manager that interacts with the games chat and command systems. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IChatManager +{ + // Command Functions + virtual void ParseCommand(const char* command, int32_t type) = 0; + virtual void QueueCommand(const char* command, int32_t type) = 0; + + // Chat Functions + virtual void AddChatMessage(int32_t mode, const char* message) = 0; + virtual int32_t ParseAutoTranslate(const char* message, char* buffer, int32_t bufferSize, bool useBrackets) = 0; + + // Script Functions + virtual void RunScript(bool useTaskQueue, const char* file) = 0; + + // Input Text Functions + virtual const char* GetInputText(void) const = 0; + virtual void SetInputText(const char* message) = 0; + virtual bool IsInputOpen(void) = 0; + + // Chat Functions (Helpers) + virtual void Write(const char* msg) = 0; + virtual void Writef(const char* format, ...) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Configuration Manager +// +// Ashita configuration manager that interacts with simple XML based configuration files. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IConfigurationManager +{ + // Configuration File Functions + virtual bool Load(const char* alias, const char* file) = 0; + virtual bool Save(const char* alias, const char* file) = 0; + virtual void Remove(const char* alias) = 0; + + // Value Related Functions + virtual void set_value(const char* alias, const char* name, const char* value) = 0; + virtual const char* get_string(const char* alias, const char* name) = 0; + virtual bool get_bool(const char* alias, const char* name, bool defaultValue) = 0; + virtual uint8_t get_uint8(const char* alias, const char* name, uint8_t defaultValue) = 0; + virtual uint16_t get_uint16(const char* alias, const char* name, uint16_t defaultValue) = 0; + virtual uint32_t get_uint32(const char* alias, const char* name, uint32_t defaultValue) = 0; + virtual uint64_t get_uint64(const char* alias, const char* name, uint64_t defaultValue) = 0; + virtual int8_t get_int8(const char* alias, const char* name, int8_t defaultValue) = 0; + virtual int16_t get_int16(const char* alias, const char* name, int16_t defaultValue) = 0; + virtual int32_t get_int32(const char* alias, const char* name, int32_t defaultValue) = 0; + virtual int64_t get_int64(const char* alias, const char* name, int64_t defaultValue) = 0; + virtual float get_float(const char* alias, const char* name, float defaultValue) = 0; + virtual double get_double(const char* alias, const char* name, double defaultValue) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Data Manager +// +// Ashita data manager that interacts with various in-game memory structures such as +// inventory, player, party, target, etc. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IDataManager +{ + virtual IEntity* GetEntity(void) = 0; + virtual IInventory* GetInventory(void) = 0; + virtual IParty* GetParty(void) = 0; + virtual IPlayer* GetPlayer(void) = 0; + virtual ITarget* GetTarget(void) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Font Manager +// +// Ashita font manager that interacts with Ashitas built-in highly customizable font objects. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IFontManager +{ + virtual IFontObject* Create(const char* alias) = 0; + virtual IFontObject* Get(const char* alias) = 0; + virtual void Delete(const char* alias) = 0; + virtual bool GetHideObjects(void) const = 0; + virtual void SetHideObjects(bool hide) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Font Object +// +// Ashita font object interface that allows interaction with the highly customizable font objects. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IFontObject +{ + // Helper Functions + virtual bool HitTest(int32_t x, int32_t y) = 0; + + // Property Getters + virtual const char* GetAlias(void) const = 0; + virtual bool GetVisibility(void) const = 0; + virtual const char* GetFontFamily(void) const = 0; + virtual int32_t GetFontHeight(void) const = 0; + virtual float GetPositionX(void) const = 0; + virtual float GetPositionY(void) const = 0; + virtual bool GetLocked(void) const = 0; + virtual float GetPadding(void) const = 0; + virtual uint32_t GetAnchor(void) const = 0; + virtual uint32_t GetAnchorParent(void) const = 0; + virtual D3DCOLOR GetColor(void) const = 0; + virtual uint32_t GetCreateFlags(void) const = 0; + virtual uint32_t GetDrawFlags(void) const = 0; + virtual bool GetBold(void) const = 0; + virtual bool GetItalic(void) const = 0; + virtual bool GetRightJustified(void) const = 0; + virtual const char* GetText(void) const = 0; + virtual bool GetDirtyFlag(void) const = 0; + virtual bool GetAutoResize(void) const = 0; + virtual float GetWindowWidth(void) const = 0; + virtual float GetWindowHeight(void) const = 0; + virtual float GetRealPositionX(void) const = 0; + virtual float GetRealPositionY(void) const = 0; + virtual MOUSEEVENT GetMouseEventFunction(void) const = 0; + virtual void GetTextSize(SIZE* size) const = 0; + virtual IFontObject* GetParent(void) const = 0; + + virtual IPrimitiveObject* GetBackground(void) const = 0; + + // Property Setters + virtual void SetAlias(const char* alias) = 0; + virtual void SetVisibility(bool visible) = 0; + virtual void SetFontFamily(const char* family) = 0; + virtual void SetFontHeight(int32_t height) = 0; + virtual void SetPositionX(float x) = 0; + virtual void SetPositionY(float y) = 0; + virtual void SetLocked(bool locked) = 0; + virtual void SetPadding(float size) = 0; + virtual void SetAnchor(uint32_t anchor) = 0; + virtual void SetAnchorParent(uint32_t anchor) = 0; + virtual void SetColor(D3DCOLOR color) = 0; + virtual void SetCreateFlags(uint32_t flags) = 0; + virtual void SetDrawFlags(uint32_t flags) = 0; + virtual void SetBold(bool bold) = 0; + virtual void SetItalic(bool italic) = 0; + virtual void SetRightJustified(bool justified) = 0; + virtual void SetText(const char* text) = 0; + virtual void SetDirtyFlag(bool dirty) = 0; + virtual void SetAutoResize(bool resize) = 0; + virtual void SetWindowWidth(float width) = 0; + virtual void SetWindowHeight(float height) = 0; + virtual void SetMouseEventFunction(MOUSEEVENT func) = 0; + virtual void SetParent(IFontObject* parent) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Input Manager +// +// Ashita input manager that interacts with the hooked keyboard and mouse devices. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IInputManager +{ + virtual IKeyboard* GetKeyboard(void) const = 0; + virtual IMouse* GetMouse(void) const = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Log Manager +// +// Ashita log manager that interacts with the per-instance created log file that Ashita uses to +// record various information about its operation. This file can be used to help debug issues +// with addons and plugins. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface ILogManager +{ + virtual bool Log(uint32_t level, const char* source, const char* msg) = 0; + virtual bool Logf(uint32_t level, const char* source, const char* fmt, ...) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Packet Manager +// +// Ashita packet manager that interacts with the games packet system. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IPacketManager +{ + virtual void AddIncomingPacket(uint16_t id, uint32_t len, void* data) = 0; + virtual void AddOutgoingPacket(uint16_t id, uint32_t len, void* data) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Plugin Manager +// +// Ashita plugin manager that interacts with Ashitas internal plugin system. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IPluginManager +{ + virtual bool Load(const char* name) = 0; + virtual bool Unload(const char* name) = 0; + virtual void UnloadAll(void) = 0; + virtual void* GetPlugin(const char* name) = 0; + virtual void* GetPlugin(uint32_t index) = 0; + virtual uint32_t GetPluginCount(void) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Pointer Manager +// +// Ashita pointer manager that interacts with Ashitas internal pointer system. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IPointerManager +{ + virtual uintptr_t GetPointer(const char* name) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Primitive Object +// +// Ashita primitive object interface that allows interaction with the primitive objects created +// within Ashita via the Font Manager. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IPrimitiveObject +{ + // Helper Functions + virtual void SetTextureFromFile(const char* file) = 0; + virtual void SetTextureFromResource(const char* moduleName, const char* resource) = 0; + virtual bool HitTest(int32_t x, int32_t y) = 0; + + // Property Getters + virtual bool GetVisibility(void) const = 0; + virtual float GetPositionX(void) const = 0; + virtual float GetPositionY(void) const = 0; + virtual float GetWidth(void) const = 0; + virtual float GetHeight(void) const = 0; + virtual D3DCOLOR GetColor(void) const = 0; + virtual bool GetBorderVisibility(void) const = 0; + virtual D3DCOLOR GetBorderColor(void) const = 0; + virtual uint32_t GetBorderFlags(void) const = 0; + virtual Ashita::asrect_t GetBorderSizes(void) const = 0; + + // Property Setters + virtual void SetVisibility(bool isVisible) = 0; + virtual void SetPositionX(float x) = 0; + virtual void SetPositionY(float y) = 0; + virtual void SetWidth(float width) = 0; + virtual void SetHeight(float height) = 0; + virtual void SetColor(D3DCOLOR color) = 0; + virtual void SetBorderVisibility(bool isVisible) = 0; + virtual void SetBorderColor(D3DCOLOR color) = 0; + virtual void SetBorderFlags(uint32_t flags) = 0; + virtual void SetBorderSizes(uint32_t top, uint32_t right, uint32_t bottom, uint32_t left) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Resource Manager +// +// Ashita resource manager interface that interacts with the internal DAT file parser to obtain +// various information about the games content. (Abilities, Spells, Items, Various Strings, etc.) +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IResourceManager +{ + // Ability Functions + virtual IAbility* GetAbilityById(uint32_t id) = 0; + virtual IAbility* GetAbilityByName(const char* name, uint32_t languageId) = 0; + virtual IAbility* GetAbilityByTimerId(uint32_t id) = 0; + + // Spell Functions + virtual ISpell* GetSpellById(uint32_t id) = 0; + virtual ISpell* GetSpellByName(const char* name, uint32_t languageId) = 0; + + // Item Functions + virtual IItem* GetItemById(uint32_t id) = 0; + virtual IItem* GetItemByName(const char* name, uint32_t languageId) = 0; + + // String Functions + virtual const char* GetString(const char* table, uint32_t index) = 0; + virtual const char* GetString(const char* table, uint32_t index, uint32_t languageId) = 0; + virtual int32_t GetString(const char* table, const char* name) = 0; + virtual int32_t GetString(const char* table, const char* name, uint32_t languageId) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Data Related Interfaces +// +// IEntity +// +// Exposes functions to interact with the games various entities. (Players, Monsters, NPCs, etc.) +// +// IInventory +// +// Exposes functions to interact with the inventory block of the games data. This includes the +// players inventory and storage, the players equipment, and the treasure pool. +// +// IParty +// +// Exposes functions to interact with the games party data. +// +// IPlayer +// +// Exposes functions to interact with the local players information. (Level, job, skills, etc.) +// +// ITarget +// +// Exposes functions to interact with the current target information. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IEntity +{ + // WARNING: Plugins should not use this function! + // + // Use the Get/Set functions instead to help ensure your plugin does not + // break between updates of Ashita! + virtual Ashita::FFXI::ffxi_entity_t* GetEntity(uint32_t index) const = 0; + + // Property Getters + virtual float GetLocalX(uint32_t index) const = 0; + virtual float GetLocalY(uint32_t index) const = 0; + virtual float GetLocalZ(uint32_t index) const = 0; + virtual float GetLocalRoll(uint32_t index) const = 0; + virtual float GetLocalYaw(uint32_t index) const = 0; + virtual float GetLocalPitch(uint32_t index) const = 0; + virtual float GetLastX(uint32_t index) const = 0; + virtual float GetLastY(uint32_t index) const = 0; + virtual float GetLastZ(uint32_t index) const = 0; + virtual float GetLastRoll(uint32_t index) const = 0; + virtual float GetLastYaw(uint32_t index) const = 0; + virtual float GetLastPitch(uint32_t index) const = 0; + virtual float GetMoveX(uint32_t index) const = 0; + virtual float GetMoveY(uint32_t index) const = 0; + virtual float GetMoveZ(uint32_t index) const = 0; + virtual uint32_t GetTargetIndex(uint32_t index) const = 0; + virtual uint32_t GetServerId(uint32_t index) const = 0; + virtual const char* GetName(uint32_t index) const = 0; + virtual float GetSpeed(uint32_t index) const = 0; + virtual float GetAnimationSpeed(uint32_t index) const = 0; + virtual uintptr_t GetWarpPointer(uint32_t index) const = 0; + virtual float GetDistance(uint32_t index) const = 0; + virtual float GetHeading(uint32_t index) const = 0; + virtual uintptr_t GetPetOwnerId(uint32_t index) const = 0; + virtual uint8_t GetHealthPercent(uint32_t index) const = 0; + virtual uint8_t GetManaPercent(uint32_t index) const = 0; + virtual uint8_t GetEntityType(uint32_t index) const = 0; + virtual uint8_t GetRace(uint32_t index) const = 0; + virtual uint16_t GetModelFade(uint32_t index) const = 0; + virtual uint16_t GetLookHair(uint32_t index) const = 0; + virtual uint16_t GetLookHead(uint32_t index) const = 0; + virtual uint16_t GetLookBody(uint32_t index) const = 0; + virtual uint16_t GetLookHands(uint32_t index) const = 0; + virtual uint16_t GetLookLegs(uint32_t index) const = 0; + virtual uint16_t GetLookFeet(uint32_t index) const = 0; + virtual uint16_t GetLookMain(uint32_t index) const = 0; + virtual uint16_t GetLookSub(uint32_t index) const = 0; + virtual uint16_t GetLookRanged(uint32_t index) const = 0; + virtual uint16_t GetActionTimer1(uint32_t index) const = 0; + virtual uint16_t GetActionTimer2(uint32_t index) const = 0; + virtual uint32_t GetRenderFlags0(uint32_t index) const = 0; + virtual uint32_t GetRenderFlags1(uint32_t index) const = 0; + virtual uint32_t GetRenderFlags2(uint32_t index) const = 0; + virtual uint32_t GetRenderFlags3(uint32_t index) const = 0; + virtual uint32_t GetRenderFlags4(uint32_t index) const = 0; + virtual uint16_t GetNpcSpeechLoop(uint32_t index) const = 0; + virtual uint16_t GetNpcSpeechFrame(uint32_t index) const = 0; + virtual float GetSpeed2(uint32_t index) const = 0; + virtual uint16_t GetNpcWalkPosition1(uint32_t index) const = 0; + virtual uint16_t GetNpcWalkPosition2(uint32_t index) const = 0; + virtual uint16_t GetNpcWalkMode(uint32_t index) const = 0; + virtual uint16_t GetCostumeId(uint32_t index) const = 0; + virtual uint32_t GetStatus(uint32_t index) const = 0; + virtual uint32_t GetStatusServer(uint32_t index) const = 0; + virtual uint32_t GetStatusNpcChat(uint32_t index) const = 0; + virtual uint32_t GetClaimServerId(uint32_t index) const = 0; + virtual uint8_t* GetAnimations(uint32_t index) const = 0; + virtual uint16_t GetAnimationTick(uint32_t index) const = 0; + virtual uint16_t GetAnimationStep(uint32_t index) const = 0; + virtual uint8_t GetAnimationPlay(uint32_t index) const = 0; + virtual uint16_t GetEmoteTargetIndex(uint32_t index) const = 0; + virtual uint16_t GetEmoteId(uint32_t index) const = 0; + virtual uint32_t GetEmoteIdString(uint32_t index) const = 0; + virtual uintptr_t GetEmoteTargetWarpPointer(uint32_t index) const = 0; + virtual uint32_t GetSpawnFlags(uint32_t index) const = 0; + virtual uint32_t GetLinkshellColor(uint32_t index) const = 0; + virtual uint16_t GetNameColor(uint32_t index) const = 0; + virtual uint16_t GetCampaignNameFlag(uint32_t index) const = 0; + virtual uint16_t GetFishingTimer(uint32_t index) const = 0; + virtual uint16_t GetFishingCastTimer(uint32_t index) const = 0; + virtual uint32_t GetFishingUnknown0000(uint32_t index) const = 0; + virtual uint32_t GetFishingUnknown0001(uint32_t index) const = 0; + virtual uint16_t GetFishingUnknown0002(uint32_t index) const = 0; + virtual uint16_t GetTargetedIndex(uint32_t index) const = 0; + virtual uint16_t GetPetTargetIndex(uint32_t index) const = 0; + virtual uint8_t GetBallistaScoreFlag(uint32_t index) const = 0; + virtual uint8_t GetPankrationEnabled(uint32_t index) const = 0; + virtual uint8_t GetPankrationFlagFlip(uint32_t index) const = 0; + virtual float GetModelSize(uint32_t index) const = 0; + virtual uint16_t GetMonstrosityFlag(uint32_t index) const = 0; + virtual uint16_t GetMonstrosityNameId(uint32_t index) const = 0; + virtual const char* GetMonstrosityName(uint32_t index) const = 0; + + // Property Setters + virtual void SetLocalX(uint32_t index, float x) const = 0; + virtual void SetLocalY(uint32_t index, float y) const = 0; + virtual void SetLocalZ(uint32_t index, float z) const = 0; + virtual void SetLocalRoll(uint32_t index, float roll) const = 0; + virtual void SetLocalYaw(uint32_t index, float yaw) const = 0; + virtual void SetLocalPitch(uint32_t index, float pitch) const = 0; + virtual void SetLastX(uint32_t index, float x) const = 0; + virtual void SetLastY(uint32_t index, float y) const = 0; + virtual void SetLastZ(uint32_t index, float z) const = 0; + virtual void SetLastRoll(uint32_t index, float roll) const = 0; + virtual void SetLastYaw(uint32_t index, float yaw) const = 0; + virtual void SetLastPitch(uint32_t index, float pitch) const = 0; + virtual void SetMoveX(uint32_t index, float x) const = 0; + virtual void SetMoveY(uint32_t index, float y) const = 0; + virtual void SetMoveZ(uint32_t index, float z) const = 0; + virtual void SetTargetIndex(uint32_t index, uint32_t targetIndex) const = 0; + virtual void SetServerId(uint32_t index, uint32_t serverId) const = 0; + virtual void SetName(uint32_t index, const char* name) const = 0; + virtual void SetSpeed(uint32_t index, float speed) const = 0; + virtual void SetAnimationSpeed(uint32_t index, float speed) const = 0; + virtual void SetWarpPointer(uint32_t index, uintptr_t ptr) const = 0; + virtual void SetDistance(uint32_t index, float distance) const = 0; + virtual void SetHeading(uint32_t index, float heading) const = 0; + virtual void SetPetOwnerId(uint32_t index, uintptr_t petOwnerId) const = 0; + virtual void SetHealthPercent(uint32_t index, uint8_t hpp) const = 0; + virtual void SetManaPercent(uint32_t index, uint8_t mpp) const = 0; + virtual void SetEntityType(uint32_t index, uint8_t type) const = 0; + virtual void SetRace(uint32_t index, uint8_t race) const = 0; + virtual void SetModelFade(uint32_t index, uint16_t fade) const = 0; + virtual void SetLookHair(uint32_t index, uint16_t hair) const = 0; + virtual void SetLookHead(uint32_t index, uint16_t head) const = 0; + virtual void SetLookBody(uint32_t index, uint16_t body) const = 0; + virtual void SetLookHands(uint32_t index, uint16_t hands) const = 0; + virtual void SetLookLegs(uint32_t index, uint16_t legs) const = 0; + virtual void SetLookFeet(uint32_t index, uint16_t feet) const = 0; + virtual void SetLookMain(uint32_t index, uint16_t main) const = 0; + virtual void SetLookSub(uint32_t index, uint16_t sub) const = 0; + virtual void SetLookRanged(uint32_t index, uint16_t ranged) const = 0; + virtual void SetActionTimer1(uint32_t index, uint16_t time) const = 0; + virtual void SetActionTimer2(uint32_t index, uint16_t time) const = 0; + virtual void SetRenderFlags0(uint32_t index, uint32_t flags) const = 0; + virtual void SetRenderFlags1(uint32_t index, uint32_t flags) const = 0; + virtual void SetRenderFlags2(uint32_t index, uint32_t flags) const = 0; + virtual void SetRenderFlags3(uint32_t index, uint32_t flags) const = 0; + virtual void SetRenderFlags4(uint32_t index, uint32_t flags) const = 0; + virtual void SetNpcSpeechLoop(uint32_t index, uint16_t loop) const = 0; + virtual void SetNpcSpeechFrame(uint32_t index, uint16_t frame) const = 0; + virtual void SetSpeed2(uint32_t index, float speed) const = 0; + virtual void SetNpcWalkPosition1(uint32_t index, uint16_t pos) const = 0; + virtual void SetNpcWalkPosition2(uint32_t index, uint16_t pos) const = 0; + virtual void SetNpcWalkMode(uint32_t index, uint16_t mode) const = 0; + virtual void SetCostumeId(uint32_t index, uint16_t costume) const = 0; + virtual void SetStatus(uint32_t index, uint32_t status) const = 0; + virtual void SetStatusServer(uint32_t index, uint32_t status) const = 0; + virtual void SetStatusNpcChat(uint32_t index, uint32_t status) const = 0; + virtual void SetClaimServerId(uint32_t index, uint32_t claimid) const = 0; + virtual void SetAnimations(uint32_t index, uint8_t* data) const = 0; + virtual void SetAnimationTick(uint32_t index, uint16_t tick) const = 0; + virtual void SetAnimationStep(uint32_t index, uint16_t step) const = 0; + virtual void SetAnimationPlay(uint32_t index, uint8_t play) const = 0; + virtual void SetEmoteTargetIndex(uint32_t index, uint16_t targetIndex) const = 0; + virtual void SetEmoteId(uint32_t index, uint16_t emoteid) const = 0; + virtual void SetEmoteIdString(uint32_t index, uint32_t emoteid) const = 0; + virtual void SetEmoteTargetWarpPointer(uint32_t index, uintptr_t warpPointer) const = 0; + virtual void SetSpawnFlags(uint32_t index, uint32_t flags) const = 0; + virtual void SetLinkshellColor(uint32_t index, uint32_t color) const = 0; + virtual void SetNameColor(uint32_t index, uint16_t color) const = 0; + virtual void SetCampaignNameFlag(uint32_t index, uint16_t flags) const = 0; + virtual void SetFishingTimer(uint32_t index, uint16_t timer) const = 0; + virtual void SetFishingCastTimer(uint32_t index, uint16_t timer) const = 0; + virtual void SetFishingUnknown0000(uint32_t index, uint32_t unk) const = 0; + virtual void SetFishingUnknown0001(uint32_t index, uint32_t unk) const = 0; + virtual void SetFishingUnknown0002(uint32_t index, uint16_t unk) const = 0; + virtual void SetTargetedIndex(uint32_t index, uint16_t targetedIndex) const = 0; + virtual void SetPetTargetIndex(uint32_t index, uint16_t petIndex) const = 0; + virtual void SetBallistaScoreFlag(uint32_t index, uint8_t flag) const = 0; + virtual void SetPankrationEnabled(uint32_t index, uint8_t enabled) const = 0; + virtual void SetPankrationFlagFlip(uint32_t index, uint8_t flagflip) const = 0; + virtual void SetModelSize(uint32_t index, float size) const = 0; + virtual void SetMonstrosityFlag(uint32_t index, uint16_t flag) const = 0; + virtual void SetMonstrosityNameId(uint32_t index, uint16_t nameid) const = 0; + virtual void SetMonstrosityName(uint32_t index, const char* name) const = 0; +}; + +interface IInventory +{ + virtual Ashita::FFXI::item_t* GetItem(int32_t containerId, int32_t slotId) const = 0; + virtual uint16_t GetContainerMax(int32_t containerId) const = 0; + virtual Ashita::FFXI::treasureitem_t* GetTreasureItem(int32_t slotId) const = 0; + virtual Ashita::FFXI::equipment_t* GetEquippedItem(int32_t equipSlotId) const = 0; + virtual uint32_t GetCraftWait(void) const = 0; +}; + +interface IParty +{ + // Alliance Property Getters + virtual uint32_t GetAllianceLeaderServerId(void) const = 0; + virtual uint32_t GetAllianceParty0LeaderServerId(void) const = 0; + virtual uint32_t GetAllianceParty1LeaderServerId(void) const = 0; + virtual uint32_t GetAllianceParty2LeaderServerId(void) const = 0; + virtual int8_t GetAllianceParty0Visible(void) const = 0; + virtual int8_t GetAllianceParty1Visible(void) const = 0; + virtual int8_t GetAllianceParty2Visible(void) const = 0; + virtual int8_t GetAllianceParty0MemberCount(void) const = 0; + virtual int8_t GetAllianceParty1MemberCount(void) const = 0; + virtual int8_t GetAllianceParty2MemberCount(void) const = 0; + virtual int8_t GetAllianceInvited(void) const = 0; + + // Party Member Property Getters + virtual uint8_t GetMemberIndex(uint32_t index) const = 0; + virtual uint8_t GetMemberNumber(uint32_t index) const = 0; + virtual const char* GetMemberName(uint32_t index) const = 0; + virtual uint32_t GetMemberServerId(uint32_t index) const = 0; + virtual uint32_t GetMemberTargetIndex(uint32_t index) const = 0; + virtual uint32_t GetMemberCurrentHP(uint32_t index) const = 0; + virtual uint32_t GetMemberCurrentMP(uint32_t index) const = 0; + virtual uint32_t GetMemberCurrentTP(uint32_t index) const = 0; + virtual uint8_t GetMemberCurrentHPP(uint32_t index) const = 0; + virtual uint8_t GetMemberCurrentMPP(uint32_t index) const = 0; + virtual uint16_t GetMemberZone(uint32_t index) const = 0; + virtual uint32_t GetMemberFlagMask(uint32_t index) const = 0; + virtual uint8_t GetMemberMainJob(uint32_t index) const = 0; + virtual uint8_t GetMemberMainJobLevel(uint32_t index) const = 0; + virtual uint8_t GetMemberSubJob(uint32_t index) const = 0; + virtual uint8_t GetMemberSubJobLvl(uint32_t index) const = 0; + virtual uint32_t GetMemberServerId2(uint32_t index) const = 0; + virtual uint8_t GetMemberCurrentHPP2(uint32_t index) const = 0; + virtual uint8_t GetMemberCurrentMPP2(uint32_t index) const = 0; + virtual uint8_t GetMemberActive(uint32_t index) const = 0; +}; + +interface IPlayer +{ + // Property Getters + virtual uint32_t GetHealthMax(void) const = 0; + virtual uint32_t GetManaMax(void) const = 0; + virtual uint8_t GetMainJob(void) const = 0; + virtual uint8_t GetMainJobLevel(void) const = 0; + virtual uint8_t GetSubJob(void) const = 0; + virtual uint8_t GetSubJobLevel(void) const = 0; + virtual uint16_t GetExpCurrent(void) const = 0; + virtual uint16_t GetExpNeeded(void) const = 0; + virtual int16_t GetStat(uint32_t stat) const = 0; + virtual int16_t GetStatsModifiers(uint32_t stat) const = 0; + virtual int16_t GetAttack(void) const = 0; + virtual int16_t GetDefense(void) const = 0; + virtual int16_t GetResist(uint32_t stat) const = 0; + virtual uint16_t GetTitle(void) const = 0; + virtual uint16_t GetRank(void) const = 0; + virtual uint16_t GetRankPoints(void) const = 0; + virtual uint8_t GetNation(void) const = 0; + virtual uint8_t GetResidence(void) const = 0; + virtual uint32_t GetHomepoint(void) const = 0; + virtual Ashita::FFXI::combatskill_t GetCombatSkill(uint32_t skill) const = 0; + virtual Ashita::FFXI::craftskill_t GetCraftSkill(uint32_t skill) const = 0; + virtual uint16_t GetAbilityRecast(uint32_t index) const = 0; + virtual uint16_t GetAbilityRecastTimerId(uint32_t index) const = 0; + virtual uint16_t GetLimitPoints(void) const = 0; + virtual uint8_t GetMeritPoints(void) const = 0; + virtual uint8_t GetLimitMode(void) const = 0; + virtual uint32_t GetMeritPointsMax(void) const = 0; + virtual int16_t* GetStatusIcons(void) const = 0; + virtual int32_t* GetStatusTimers(void) const = 0; + virtual int16_t* GetBuffs(void) const = 0; + + // Helper Functions + virtual bool HasAbility(uint32_t id) const = 0; + virtual bool HasKeyItem(uint32_t id) const = 0; + virtual bool HasPetCommand(uint32_t id) const = 0; + virtual bool HasSpell(uint32_t id) const = 0; + virtual bool HasTrait(uint32_t id) const = 0; + virtual bool HasWeaponSkill(uint32_t id) const = 0; + + // Pet Functions + virtual uint32_t GetPetTP(void) const = 0; + virtual uint32_t GetPetMP(void) const = 0; +}; + +interface ITarget +{ + // Property Getters + virtual uint32_t GetTargetIndex(void) const = 0; + virtual uint32_t GetTargetServerId(void) const = 0; + virtual uintptr_t GetTargetEntityPointer(void) const = 0; + virtual uintptr_t GetTargetWarpPointer(void) const = 0; + virtual uint8_t GetTargetVisible(void) const = 0; + virtual uint16_t GetTargetMask(void) const = 0; + virtual uint16_t GetTargetCalculatedId(void) const = 0; + virtual uint32_t GetSubTargetIndex(void) const = 0; + virtual uint32_t GetSubTargetServerId(void) const = 0; + virtual uintptr_t GetSubTargetEntityPointer(void) const = 0; + virtual uintptr_t GetSubTargetWarpPointer(void) const = 0; + virtual uint8_t GetSubTargetVisible(void) const = 0; + virtual uint16_t GetSubTargetMask(void) const = 0; + virtual uint8_t GetSubTargetActive(void) const = 0; + virtual uint8_t GetTargetDeactivate(void) const = 0; + virtual uint8_t GetIsLockedOn(void) const = 0; + virtual uint32_t GetTargetSelectionMask(void) const = 0; + virtual uint8_t GetIsMenuOpen(void) const = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Input Related Interfaces +// +// IKeyboard +// +// Exposes functions to interact with the hooked and wrapped keyboard device. +// +// IMouse +// +// Exposes functions to interact with the hooked and wrapped mouse device. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IKeyboard : newIDirectInputDevice8A +{ + // Keybind Related Functions + virtual void BindKey(uint32_t key, bool down, bool alt, bool ctrl, bool win, bool apps, bool shift, const char* command) = 0; + virtual void UnbindKey(uint32_t key, bool down, bool alt, bool ctrl, bool win, bool apps, bool shift) = 0; + virtual void UnbindAll(void) = 0; + virtual bool IsKeyBound(uint32_t key, bool alt, bool ctrl, bool win, bool apps, bool shift) = 0; + virtual void ListBinds(void) = 0; + + // Callback Related Functions + virtual void AddCallback(const char* alias, LPVOID lpGetDataCallback, LPVOID lpGetStateCallback, LPVOID lpKeyboardCallack, LPVOID lpMouseCallback) = 0; + virtual void RemoveCallback(const char* alias) = 0; + + // Key Related Helper Functions + virtual uint32_t V2D(uint32_t key) const = 0; + virtual uint32_t D2V(uint32_t key) const = 0; + virtual uint32_t S2D(const char* key) const = 0; + virtual const char* D2S(uint32_t key) const = 0; + + virtual HWND GetParentWindow(void) const = 0; + virtual bool GetBlocked(void) const = 0; + virtual void SetBlocked(bool blocked) = 0; +}; + +interface IMouse : newIDirectInputDevice8A +{ + virtual HWND GetParentWindow(void) const = 0; + virtual bool GetBlocked(void) const = 0; + virtual void SetBlocked(bool blocked) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Core +// +// The main Ashita interface passed to plugins when they are loaded that includes the ability +// to obtain and interact with the other various objects defined in this header. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IAshitaCore +{ + // Manager Exposure Functions + virtual IChatManager* GetChatManager(void) const = 0; + virtual IConfigurationManager* GetConfigurationManager(void) const = 0; + virtual IDataManager* GetDataManager(void) const = 0; + virtual IFontManager* GetFontManager(void) const = 0; + virtual IGuiManager* GetGuiManager(void) const = 0; + virtual IInputManager* GetInputManager(void) const = 0; + virtual IPacketManager* GetPacketManager(void) const = 0; + virtual IPluginManager* GetPluginManager(void) const = 0; + virtual IPointerManager* GetPointerManager(void) const = 0; + virtual IResourceManager* GetResourceManager(void) const = 0; + + // Ashita Property Functions + virtual HMODULE GetHandle(void) const = 0; + virtual const char* GetAshitaInstallPathA(void) const = 0; + virtual const wchar_t* GetAshitaInstallPathW(void) const = 0; + virtual Ashita::aswindowinfo_t* GetPlayOnlineWindowInfo(void) const = 0; + virtual Ashita::aswindowinfo_t* GetMaskWindowInfo(void) const = 0; + virtual Ashita::aswindowinfo_t* GetFFXiWindowInfo(void) const = 0; + virtual bool GetMouseUnhooked(void) const = 0; + virtual void SetMouseUnhooked(bool hooked) = 0; + + // Direct3D Property Functions + virtual uint32_t GetD3DFillMode(void) const = 0; + virtual bool GetD3DAmbientEnabled(void) const = 0; + virtual D3DCOLOR GetD3DAmbientColor(void) const = 0; + virtual void SetD3DFillMode(uint32_t fillmode) = 0; + virtual void SetD3DAmbientEnabled(bool enabled) = 0; + virtual void SetD3DAmbientColor(D3DCOLOR color) = 0; + + // DirectInput Property Functions + virtual bool GetAllowGamepadInBackground(void) const = 0; + virtual void SetAllowGamepadInBackground(bool enabled) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Plugin Information +// +// Plugin information that is shared back to the Ashita plugin manager while a plugin is being +// loaded. Plugins must populate this data in order to be considered valid. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +struct plugininfo_t +{ + char Name[512]; // The plugins name. + char Author[512]; // The plugins author. + double InterfaceVersion; // The plugins ADK interface version that it was compiled with. + double PluginVersion; // The plugins version. + int32_t Priority; // The plugins execution priority. + + /** + * Default Constructor + */ + plugininfo_t(void) + { + strcpy_s(this->Name, 512, "Unknown"); + strcpy_s(this->Author, 512, "Ashita Development Team"); + + this->InterfaceVersion = ASHITA_INTERFACE_VERSION; + this->PluginVersion = 1.0f; + this->Priority = 0; + } + + /** + * Default Constructor + */ + plugininfo_t(const char* name, const char* author, double interfaceVersion, double pluginVersion, int32_t priority) + { + strcpy_s(this->Name, 512, name); + strcpy_s(this->Author, 512, author); + + this->InterfaceVersion = interfaceVersion; + this->PluginVersion = pluginVersion; + this->Priority = priority; + } +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Plugin Base +// +// The main plugin interface that exposes the proper implementation of a plugins base class. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +interface IPluginBase +{ + /** + * Returns the plugins information structure. + * + * @returns {plugininfo_t} The plugin information structure of the plugin. + */ + virtual plugininfo_t GetPluginInfo(void) = 0; + + /** + * Invoked when the plugin is loaded, allowing it to prepare for usage. + * + * @param {IAshitaCore*} core - The Ashita core object to interact with the various Ashita managers. + * @param {ILogManager*} log - The log manager used to interact with the current log file. + * @param {uint32_t} id - The plugins id, or its module base, that identifies it other than its name. + * @returns {bool} True on success, false otherwise. (If false, the plugin will not be loaded.) + */ + virtual bool Initialize(IAshitaCore* core, ILogManager* log, uint32_t id) = 0; + + /** + * Invoked when the plugin is being unloaded, allowing it to cleanup its resources. + */ + virtual void Release(void) = 0; + + /////////////////////////////////////////////////////////////////////////////////////////////////// + // Chat Manager Callbacks + /////////////////////////////////////////////////////////////////////////////////////////////////// + + /** + * Invoked when a command is being processed by the game client. + * + * Note: + * Please note, this handles all things done via the game in terms of commands + * and chat. All / commands as well as normal chat you type, macros, etc. will + * be processed through here. You should only use this to handle / commands. + * + * If you wish to handle other bits of outgoing text before the client sees it, + * then use the HandleOutgoingText callback instead. + * + * @param {const char*} command - The raw command string being processed. + * @param {uint32_t} type - The type of the command being processed. (See Ashita::CommandInputType enumeration.) + * @returns {bool} True if handled and should be blocked, false otherwise. + */ + virtual bool HandleCommand(const char* command, int32_t type) = 0; + + /** + * Invoked when incoming text being sent to the chat log is being processed. + * + * @param {int16_t} mode - The mode of the message being added to the chatlog. + * @param {const char*} message - The raw message being added to the chat log. + * @param {int16_t*} modifiedMode - The modified mode, if any, that has been altered by other plugins/addons. + * @param {char*} modifiedMessage - The modified message, if any, that has been altered by other plugins/addons. + * @param {bool} blocked - Flag if this message has been blocked already by another plugin. (Once blocked, other plugins cannot restore it.) + * @returns {bool} True if handled and should be blocked, false otherwise. + */ + virtual bool HandleIncomingText(int16_t mode, const char* message, int16_t* modifiedMode, char* modifiedMessage, bool blocked) = 0; + + /** + * Invoked when outgoing text has not been handled by other plugins/addons. + * Invoked after HandleCommand if nothing else processed the data. + * + * @param {int16_t} mode - The type of the text that is being sent. (See Ashita::CommandInputType enumeration.) + * @param {const char*} message - The raw message being sent. + * @param {int16_t*} modifiedMode - The modified mode, if any, that has been altered by other plugins/addons. + * @param {char*} modifiedMessage - The modified message, if any, that has been altered by other plugins/addons. + * @param {bool} blocked - Flag if this message has been blocked already by another plugin. (Once blocked, other plugins cannot restore it.) + * @returns {bool} True if handled and should be blocked, false otherwise. + */ + virtual bool HandleOutgoingText(int32_t type, const char* message, int32_t* modifiedType, char* modifiedMessage, bool blocked) = 0; + + /////////////////////////////////////////////////////////////////////////////////////////////////// + // Packet Manager Callbacks + /////////////////////////////////////////////////////////////////////////////////////////////////// + + /** + * Invoked when an incoming packet is being handled. + * + * @param {uint16_t} id - The id of the packet. + * @param {uint32_t} size - The size of the packet data. + * @param {void*} data - The raw data of the packet. + * @param {void*} modified - The modified data, if any, that has been altered by other plugins/addons. + * @param {bool} blocked - Flag if this message has been blocked already by another plugin. (Once blocked, other plugins cannot restore it.) + * @returns {bool} True if handled and should be blocked, false otherwise. + */ + virtual bool HandleIncomingPacket(uint16_t id, uint32_t size, void* data, void* modified, bool blocked) = 0; + + /** + * Invoked when an outgoing packet is being handled. + * + * @param {uint16_t} id - The id of the packet. + * @param {uint32_t} size - The size of the packet data. + * @param {void*} data - The raw data of the packet. + * @param {void*} modified - The modified data, if any, that has been altered by other plugins/addons. + * @param {bool} blocked - Flag if this message has been blocked already by another plugin. (Once blocked, other plugins cannot restore it.) + * @returns {bool} True if handled and should be blocked, false otherwise. + */ + virtual bool HandleOutgoingPacket(uint16_t id, uint32_t size, void* data, void* modified, bool blocked) = 0; + + /////////////////////////////////////////////////////////////////////////////////////////////////// + // Direct3D Callbacks + /////////////////////////////////////////////////////////////////////////////////////////////////// + + /** + * Invoked when the plugin is being initialized for Direct3D rendering. + * + * Note: + * Plugins must return true with this function in order to have the other Direct3D + * functions invoked. Returning false is ideal here if you do not need to use the + * Direct3D functions within your plugin. This can help with overall performance. + * + * @param {IDirect3DDevice8*} device - The Direct3D device pointer currently being used by the game. + * @return {bool} True if the plugin should handle the other Direct3D messages, false otherwise. + */ + virtual bool Direct3DInitialize(IDirect3DDevice8* device) = 0; + + /** + * Invoked when the plugin is being unloaded and is able to cleanup its Direct3D related resources. + */ + virtual void Direct3DRelease(void) = 0; + + /** + * Invoked when the Direct3D device is beginning to render. (BeginScene) + */ + virtual void Direct3DPreRender(void) = 0; + + /** + * Invoked when the Direct3D device is ending its rendering. (EndScene) + */ + virtual void Direct3DRender(void) = 0; + + /** + * Invoked when the Direct3D device is presenting the scene. (Present) + * + * @param {RECT*} pSourceRect - The source rect being rendered into. + * @param {RECT*} pDestRect - The destination rect being rendered from. + * @param {HWND} hDestWindowOverride - The window handle, if any, to override the rendering into. + * @param {RGNDATA*} pDirtyRegion - The dirty region data. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DPresent(const RECT* pSourceRect, const RECT* pDestRect, HWND hDestWindowOverride, const RGNDATA* pDirtyRegion) = 0; + + /** + * Invoked when the Direct3D device is drawing a primitive to the scene. (DrawPrimitive) + * + * @param {D3DPRIMITIVETYPE} PrimitiveType - The type of primitive being rendered. + * @param {UINT} StartVertex - Index of the first vertex to load. + * @param {UINT} PrimitiveCount - Number of primitives to render. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DDrawPrimitive(D3DPRIMITIVETYPE PrimitiveType, UINT StartVertex, UINT PrimitiveCount) = 0; + + /** + * Invoked when the Direct3D device is drawing a primitive to the scene. (DrawIndexedPrimitive) + * + * @param {D3DPRIMITIVETYPE} PrimitiveType - The type of primitive being rendered. + * @param {UINT} minIndex - Minimum vertex index for vertices used during this call. + * @param {UINT} numVertices - Number of vertices used during this call + * @param {UINT} startIndex - Index of the first index to use when accesssing the vertex buffer. + * @param {UINT} primCount - Number of primitives to render. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DDrawIndexedPrimitive(D3DPRIMITIVETYPE PrimitiveType, UINT minIndex, UINT NumVertices, UINT startIndex, UINT primCount) = 0; + + /** + * Invoked when the Direct3D device is drawing a primitive to the scene. (DrawPrimitiveUP) + * + * @param {D3DPRIMITIVETYPE} PrimitiveType - The type of primitive being rendered. + * @param {UINT} PrimitiveCount - Number of primitives to render. + * @param {void*} pVertexStreamZeroData - User memory pointer to the vertex data. + * @param {UINT} VertexStreamZeroStride - The number of bytes of data for each vertex. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DDrawPrimitiveUP(D3DPRIMITIVETYPE PrimitiveType, UINT PrimitiveCount, CONST void* pVertexStreamZeroData, UINT VertexStreamZeroStride) = 0; + + /** + * Invoked when the Direct3D device is drawing a primitive to the scene. (DrawIndexedPrimitiveUP) + * + * @param {D3DPRIMITIVETYPE} PrimitiveType - The type of primitive being rendered. + * @param {UINT} MinVertexIndex - Minimum vertex index. + * @param {UINT} NumVertexIndices - Number of vertices used during this call. + * @param {UINT} PrimitiveCount - Number of primitives to render. + * @param {void*} pIndexData - User memory pointer to the index data. + * @param {D3DFORMAT} IndexDataFormat - The format of the index data. + * @param {void*} pVertexStreamZeroData - User memory pointer to the vertex data. + * @param {UINT} VertexStreamZeroStride - The number of bytes of data for each vertex. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DDrawIndexedPrimitiveUP(D3DPRIMITIVETYPE PrimitiveType, UINT MinVertexIndex, UINT NumVertexIndices, UINT PrimitiveCount, CONST void* pIndexData, D3DFORMAT IndexDataFormat, CONST void* pVertexStreamZeroData, UINT VertexStreamZeroStride) = 0; + + /** + * Invoked when the Direct3D device is setting a render state. (SetRenderState) + * + * @param {D3DRENDERSTATETYPE} state - The render state to alter. + * @param {DWORD} value - The new value for the render state. + * @returns {bool} True if the call should be blocked, false otherwise. + */ + virtual bool Direct3DSetRenderState(D3DRENDERSTATETYPE State, DWORD Value) = 0; +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Plugin +// +// The main base class that plugins should inherit from. Defaults the function handlers that are +// not overriden to ensure that the plugin does not interfere with calls that it does not use. +// +// Note: +// Plugins should inherit from this base class to ensure they meet the standards of being +// a valid Ashita plugin. Failure to export a class that inherits from this base can lead +// to crashes and potential loss of data / settings. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +class IPlugin : public IPluginBase +{ +protected: + IAshitaCore* m_AshitaCore; + ILogManager* m_LogManager; + uint32_t m_PluginId; + IDirect3DDevice8* m_Direct3DDevice; + +public: + IPlugin(void) { } + virtual ~IPlugin(void) { } + +public: + plugininfo_t GetPluginInfo(void) override + { + return plugininfo_t("IPlugin", "Ashita Development Team", ASHITA_INTERFACE_VERSION, 1.0f, 0); + } + +public: + bool Initialize(IAshitaCore* core, ILogManager* log, uint32_t id) override + { + this->m_AshitaCore = core; + this->m_LogManager = log; + this->m_Direct3DDevice = nullptr; + this->m_PluginId = id; + return false; + } + void Release(void) override + { } + bool HandleCommand(const char* command, int32_t type) override + { + UNREFERENCED_PARAMETER(command); + UNREFERENCED_PARAMETER(type); + return false; + } + bool HandleIncomingText(int16_t mode, const char* message, int16_t* modifiedMode, char* modifiedMessage, bool blocked) override + { + UNREFERENCED_PARAMETER(mode); + UNREFERENCED_PARAMETER(message); + UNREFERENCED_PARAMETER(modifiedMode); + UNREFERENCED_PARAMETER(modifiedMessage); + UNREFERENCED_PARAMETER(blocked); + return false; + } + bool HandleOutgoingText(int32_t type, const char* message, int32_t* modifiedType, char* modifiedMessage, bool blocked) override + { + UNREFERENCED_PARAMETER(type); + UNREFERENCED_PARAMETER(message); + UNREFERENCED_PARAMETER(modifiedType); + UNREFERENCED_PARAMETER(modifiedMessage); + UNREFERENCED_PARAMETER(blocked); + return false; + } + bool HandleIncomingPacket(uint16_t id, uint32_t size, void* data, void* modified, bool blocked) override + { + UNREFERENCED_PARAMETER(id); + UNREFERENCED_PARAMETER(size); + UNREFERENCED_PARAMETER(data); + UNREFERENCED_PARAMETER(modified); + UNREFERENCED_PARAMETER(blocked); + return false; + } + bool HandleOutgoingPacket(uint16_t id, uint32_t size, void* data, void* modified, bool blocked) override + { + UNREFERENCED_PARAMETER(id); + UNREFERENCED_PARAMETER(size); + UNREFERENCED_PARAMETER(data); + UNREFERENCED_PARAMETER(modified); + UNREFERENCED_PARAMETER(blocked); + return false; + } + bool Direct3DInitialize(IDirect3DDevice8* device) override + { + this->m_Direct3DDevice = device; + return false; + } + void Direct3DRelease(void) override + { } + void Direct3DPreRender(void) override + { } + void Direct3DRender(void) override + { } + bool Direct3DPresent(const RECT* pSourceRect, const RECT* pDestRect, HWND hDestWindowOverride, const RGNDATA* pDirtyRegion) override + { + UNREFERENCED_PARAMETER(pSourceRect); + UNREFERENCED_PARAMETER(pDestRect); + UNREFERENCED_PARAMETER(hDestWindowOverride); + UNREFERENCED_PARAMETER(pDirtyRegion); + return false; + } + bool Direct3DDrawPrimitive(D3DPRIMITIVETYPE PrimitiveType, UINT StartVertex, UINT PrimitiveCount) override + { + UNREFERENCED_PARAMETER(PrimitiveType); + UNREFERENCED_PARAMETER(StartVertex); + UNREFERENCED_PARAMETER(PrimitiveCount); + return false; + } + bool Direct3DDrawIndexedPrimitive(D3DPRIMITIVETYPE PrimitiveType, UINT minIndex, UINT NumVertices, UINT startIndex, UINT primCount) override + { + UNREFERENCED_PARAMETER(PrimitiveType); + UNREFERENCED_PARAMETER(minIndex); + UNREFERENCED_PARAMETER(NumVertices); + UNREFERENCED_PARAMETER(startIndex); + UNREFERENCED_PARAMETER(primCount); + return false; + } + bool Direct3DDrawPrimitiveUP(D3DPRIMITIVETYPE PrimitiveType, UINT PrimitiveCount, CONST void* pVertexStreamZeroData, UINT VertexStreamZeroStride) override + { + UNREFERENCED_PARAMETER(PrimitiveType); + UNREFERENCED_PARAMETER(PrimitiveCount); + UNREFERENCED_PARAMETER(pVertexStreamZeroData); + UNREFERENCED_PARAMETER(VertexStreamZeroStride); + return false; + } + bool Direct3DDrawIndexedPrimitiveUP(D3DPRIMITIVETYPE PrimitiveType, UINT MinVertexIndex, UINT NumVertexIndices, UINT PrimitiveCount, CONST void* pIndexData, D3DFORMAT IndexDataFormat, CONST void* pVertexStreamZeroData, UINT VertexStreamZeroStride) override + { + UNREFERENCED_PARAMETER(PrimitiveType); + UNREFERENCED_PARAMETER(MinVertexIndex); + UNREFERENCED_PARAMETER(NumVertexIndices); + UNREFERENCED_PARAMETER(PrimitiveCount); + UNREFERENCED_PARAMETER(pIndexData); + UNREFERENCED_PARAMETER(IndexDataFormat); + UNREFERENCED_PARAMETER(pVertexStreamZeroData); + UNREFERENCED_PARAMETER(VertexStreamZeroStride); + return false; + } + bool Direct3DSetRenderState(D3DRENDERSTATETYPE State, DWORD Value) override + { + UNREFERENCED_PARAMETER(State); + UNREFERENCED_PARAMETER(Value); + return false; + } +}; + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// +// Ashita Plugin Exports +// +// These functions are required to be exported by all plugins in order to be validated +// for loading. Failure to export these functions will result in your plugin not being +// loaded. Plugins must return proper data for the plugin information and plugin creation +// otherwise it can lead to crashes! +// +// getinterfaceversion_f +// Exported function to return the plugins interface version it was compiled with. +// +// createplugininfo_f +// Exported function to return information about the given plugin back to Ashita. +// This info is used to validate the plugin as well as used when the plugin list is printed. +// +// createplugin_f +// Exported function to return a new instance of the plugins base class. This class must +// inherit from IPlugin as the returned value will be the inherited base object. +// +/////////////////////////////////////////////////////////////////////////////////////////////////// + +typedef double /**/(__stdcall *getinterfaceversion_f)(void); +typedef void /**/(__stdcall *createplugininfo_f)(plugininfo_t* info); +typedef IPlugin* /**/(__stdcall *createplugin_f)(void); + +#endif // __ASHITA_ADK_H_INCLUDED__ \ No newline at end of file diff --git a/plugins/ADK/d3d8/includes/d3d8.h b/plugins/ADK/d3d8/includes/d3d8.h new file mode 100644 index 0000000..adf91eb --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3d8.h @@ -0,0 +1,1279 @@ +/*==========================================================================; + * + * Copyright (C) Microsoft Corporation. All Rights Reserved. + * + * File: d3d8.h + * Content: Direct3D include file + * + ****************************************************************************/ + +#ifndef _D3D8_H_ +#define _D3D8_H_ + +#ifndef DIRECT3D_VERSION +#define DIRECT3D_VERSION 0x0800 +#endif //DIRECT3D_VERSION + +// include this file content only if compiling for DX8 interfaces +#if(DIRECT3D_VERSION >= 0x0800) + + +/* This identifier is passed to Direct3DCreate8 in order to ensure that an + * application was built against the correct header files. This number is + * incremented whenever a header (or other) change would require applications + * to be rebuilt. If the version doesn't match, Direct3DCreate8 will fail. + * (The number itself has no meaning.)*/ + +#define D3D_SDK_VERSION 220 + + +#include + +#define COM_NO_WINDOWS_H +#include + +#include + +#if !defined(HMONITOR_DECLARED) && (WINVER < 0x0500) + #define HMONITOR_DECLARED + DECLARE_HANDLE(HMONITOR); +#endif + +#define D3DAPI WINAPI + +/* + * Interface IID's + */ +#if defined( _WIN32 ) && !defined( _NO_COM) + +/* IID_IDirect3D8 */ +/* {1DD9E8DA-1C77-4d40-B0CF-98FEFDFF9512} */ +DEFINE_GUID(IID_IDirect3D8, 0x1dd9e8da, 0x1c77, 0x4d40, 0xb0, 0xcf, 0x98, 0xfe, 0xfd, 0xff, 0x95, 0x12); + +/* IID_IDirect3DDevice8 */ +/* {7385E5DF-8FE8-41D5-86B6-D7B48547B6CF} */ +DEFINE_GUID(IID_IDirect3DDevice8, 0x7385e5df, 0x8fe8, 0x41d5, 0x86, 0xb6, 0xd7, 0xb4, 0x85, 0x47, 0xb6, 0xcf); + +/* IID_IDirect3DResource8 */ +/* {1B36BB7B-09B7-410a-B445-7D1430D7B33F} */ +DEFINE_GUID(IID_IDirect3DResource8, 0x1b36bb7b, 0x9b7, 0x410a, 0xb4, 0x45, 0x7d, 0x14, 0x30, 0xd7, 0xb3, 0x3f); + +/* IID_IDirect3DBaseTexture8 */ +/* {B4211CFA-51B9-4a9f-AB78-DB99B2BB678E} */ +DEFINE_GUID(IID_IDirect3DBaseTexture8, 0xb4211cfa, 0x51b9, 0x4a9f, 0xab, 0x78, 0xdb, 0x99, 0xb2, 0xbb, 0x67, 0x8e); + +/* IID_IDirect3DTexture8 */ +/* {E4CDD575-2866-4f01-B12E-7EECE1EC9358} */ +DEFINE_GUID(IID_IDirect3DTexture8, 0xe4cdd575, 0x2866, 0x4f01, 0xb1, 0x2e, 0x7e, 0xec, 0xe1, 0xec, 0x93, 0x58); + +/* IID_IDirect3DCubeTexture8 */ +/* {3EE5B968-2ACA-4c34-8BB5-7E0C3D19B750} */ +DEFINE_GUID(IID_IDirect3DCubeTexture8, 0x3ee5b968, 0x2aca, 0x4c34, 0x8b, 0xb5, 0x7e, 0x0c, 0x3d, 0x19, 0xb7, 0x50); + +/* IID_IDirect3DVolumeTexture8 */ +/* {4B8AAAFA-140F-42ba-9131-597EAFAA2EAD} */ +DEFINE_GUID(IID_IDirect3DVolumeTexture8, 0x4b8aaafa, 0x140f, 0x42ba, 0x91, 0x31, 0x59, 0x7e, 0xaf, 0xaa, 0x2e, 0xad); + +/* IID_IDirect3DVertexBuffer8 */ +/* {8AEEEAC7-05F9-44d4-B591-000B0DF1CB95} */ +DEFINE_GUID(IID_IDirect3DVertexBuffer8, 0x8aeeeac7, 0x05f9, 0x44d4, 0xb5, 0x91, 0x00, 0x0b, 0x0d, 0xf1, 0xcb, 0x95); + +/* IID_IDirect3DIndexBuffer8 */ +/* {0E689C9A-053D-44a0-9D92-DB0E3D750F86} */ +DEFINE_GUID(IID_IDirect3DIndexBuffer8, 0x0e689c9a, 0x053d, 0x44a0, 0x9d, 0x92, 0xdb, 0x0e, 0x3d, 0x75, 0x0f, 0x86); + +/* IID_IDirect3DSurface8 */ +/* {B96EEBCA-B326-4ea5-882F-2FF5BAE021DD} */ +DEFINE_GUID(IID_IDirect3DSurface8, 0xb96eebca, 0xb326, 0x4ea5, 0x88, 0x2f, 0x2f, 0xf5, 0xba, 0xe0, 0x21, 0xdd); + +/* IID_IDirect3DVolume8 */ +/* {BD7349F5-14F1-42e4-9C79-972380DB40C0} */ +DEFINE_GUID(IID_IDirect3DVolume8, 0xbd7349f5, 0x14f1, 0x42e4, 0x9c, 0x79, 0x97, 0x23, 0x80, 0xdb, 0x40, 0xc0); + +/* IID_IDirect3DSwapChain8 */ +/* {928C088B-76B9-4C6B-A536-A590853876CD} */ +DEFINE_GUID(IID_IDirect3DSwapChain8, 0x928c088b, 0x76b9, 0x4c6b, 0xa5, 0x36, 0xa5, 0x90, 0x85, 0x38, 0x76, 0xcd); + +#endif + +#ifdef __cplusplus + +interface IDirect3D8; +interface IDirect3DDevice8; + +interface IDirect3DResource8; +interface IDirect3DBaseTexture8; +interface IDirect3DTexture8; +interface IDirect3DVolumeTexture8; +interface IDirect3DCubeTexture8; + +interface IDirect3DVertexBuffer8; +interface IDirect3DIndexBuffer8; + +interface IDirect3DSurface8; +interface IDirect3DVolume8; + +interface IDirect3DSwapChain8; + +#endif + + +typedef interface IDirect3D8 IDirect3D8; +typedef interface IDirect3DDevice8 IDirect3DDevice8; +typedef interface IDirect3DResource8 IDirect3DResource8; +typedef interface IDirect3DBaseTexture8 IDirect3DBaseTexture8; +typedef interface IDirect3DTexture8 IDirect3DTexture8; +typedef interface IDirect3DVolumeTexture8 IDirect3DVolumeTexture8; +typedef interface IDirect3DCubeTexture8 IDirect3DCubeTexture8; +typedef interface IDirect3DVertexBuffer8 IDirect3DVertexBuffer8; +typedef interface IDirect3DIndexBuffer8 IDirect3DIndexBuffer8; +typedef interface IDirect3DSurface8 IDirect3DSurface8; +typedef interface IDirect3DVolume8 IDirect3DVolume8; +typedef interface IDirect3DSwapChain8 IDirect3DSwapChain8; + +#include "d3d8types.h" +#include "d3d8caps.h" + + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * DLL Function for creating a Direct3D8 object. This object supports + * enumeration and allows the creation of Direct3DDevice8 objects. + * Pass the value of the constant D3D_SDK_VERSION to this function, so + * that the run-time can validate that your application was compiled + * against the right headers. + */ + +IDirect3D8 * WINAPI Direct3DCreate8(UINT SDKVersion); + + +/* + * Direct3D interfaces + */ + + + + + + +#undef INTERFACE +#define INTERFACE IDirect3D8 + +DECLARE_INTERFACE_(IDirect3D8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3D8 methods ***/ + STDMETHOD(RegisterSoftwareDevice)(THIS_ void* pInitializeFunction) PURE; + STDMETHOD_(UINT, GetAdapterCount)(THIS) PURE; + STDMETHOD(GetAdapterIdentifier)(THIS_ UINT Adapter,DWORD Flags,D3DADAPTER_IDENTIFIER8* pIdentifier) PURE; + STDMETHOD_(UINT, GetAdapterModeCount)(THIS_ UINT Adapter) PURE; + STDMETHOD(EnumAdapterModes)(THIS_ UINT Adapter,UINT Mode,D3DDISPLAYMODE* pMode) PURE; + STDMETHOD(GetAdapterDisplayMode)(THIS_ UINT Adapter,D3DDISPLAYMODE* pMode) PURE; + STDMETHOD(CheckDeviceType)(THIS_ UINT Adapter,D3DDEVTYPE CheckType,D3DFORMAT DisplayFormat,D3DFORMAT BackBufferFormat,BOOL Windowed) PURE; + STDMETHOD(CheckDeviceFormat)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT AdapterFormat,DWORD Usage,D3DRESOURCETYPE RType,D3DFORMAT CheckFormat) PURE; + STDMETHOD(CheckDeviceMultiSampleType)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT SurfaceFormat,BOOL Windowed,D3DMULTISAMPLE_TYPE MultiSampleType) PURE; + STDMETHOD(CheckDepthStencilMatch)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DFORMAT AdapterFormat,D3DFORMAT RenderTargetFormat,D3DFORMAT DepthStencilFormat) PURE; + STDMETHOD(GetDeviceCaps)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,D3DCAPS8* pCaps) PURE; + STDMETHOD_(HMONITOR, GetAdapterMonitor)(THIS_ UINT Adapter) PURE; + STDMETHOD(CreateDevice)(THIS_ UINT Adapter,D3DDEVTYPE DeviceType,HWND hFocusWindow,DWORD BehaviorFlags,D3DPRESENT_PARAMETERS* pPresentationParameters,IDirect3DDevice8** ppReturnedDeviceInterface) PURE; +}; + +typedef struct IDirect3D8 *LPDIRECT3D8, *PDIRECT3D8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3D8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3D8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3D8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3D8_RegisterSoftwareDevice(p,a) (p)->lpVtbl->RegisterSoftwareDevice(p,a) +#define IDirect3D8_GetAdapterCount(p) (p)->lpVtbl->GetAdapterCount(p) +#define IDirect3D8_GetAdapterIdentifier(p,a,b,c) (p)->lpVtbl->GetAdapterIdentifier(p,a,b,c) +#define IDirect3D8_GetAdapterModeCount(p,a) (p)->lpVtbl->GetAdapterModeCount(p,a) +#define IDirect3D8_EnumAdapterModes(p,a,b,c) (p)->lpVtbl->EnumAdapterModes(p,a,b,c) +#define IDirect3D8_GetAdapterDisplayMode(p,a,b) (p)->lpVtbl->GetAdapterDisplayMode(p,a,b) +#define IDirect3D8_CheckDeviceType(p,a,b,c,d,e) (p)->lpVtbl->CheckDeviceType(p,a,b,c,d,e) +#define IDirect3D8_CheckDeviceFormat(p,a,b,c,d,e,f) (p)->lpVtbl->CheckDeviceFormat(p,a,b,c,d,e,f) +#define IDirect3D8_CheckDeviceMultiSampleType(p,a,b,c,d,e) (p)->lpVtbl->CheckDeviceMultiSampleType(p,a,b,c,d,e) +#define IDirect3D8_CheckDepthStencilMatch(p,a,b,c,d,e) (p)->lpVtbl->CheckDepthStencilMatch(p,a,b,c,d,e) +#define IDirect3D8_GetDeviceCaps(p,a,b,c) (p)->lpVtbl->GetDeviceCaps(p,a,b,c) +#define IDirect3D8_GetAdapterMonitor(p,a) (p)->lpVtbl->GetAdapterMonitor(p,a) +#define IDirect3D8_CreateDevice(p,a,b,c,d,e,f) (p)->lpVtbl->CreateDevice(p,a,b,c,d,e,f) +#else +#define IDirect3D8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3D8_AddRef(p) (p)->AddRef() +#define IDirect3D8_Release(p) (p)->Release() +#define IDirect3D8_RegisterSoftwareDevice(p,a) (p)->RegisterSoftwareDevice(a) +#define IDirect3D8_GetAdapterCount(p) (p)->GetAdapterCount() +#define IDirect3D8_GetAdapterIdentifier(p,a,b,c) (p)->GetAdapterIdentifier(a,b,c) +#define IDirect3D8_GetAdapterModeCount(p,a) (p)->GetAdapterModeCount(a) +#define IDirect3D8_EnumAdapterModes(p,a,b,c) (p)->EnumAdapterModes(a,b,c) +#define IDirect3D8_GetAdapterDisplayMode(p,a,b) (p)->GetAdapterDisplayMode(a,b) +#define IDirect3D8_CheckDeviceType(p,a,b,c,d,e) (p)->CheckDeviceType(a,b,c,d,e) +#define IDirect3D8_CheckDeviceFormat(p,a,b,c,d,e,f) (p)->CheckDeviceFormat(a,b,c,d,e,f) +#define IDirect3D8_CheckDeviceMultiSampleType(p,a,b,c,d,e) (p)->CheckDeviceMultiSampleType(a,b,c,d,e) +#define IDirect3D8_CheckDepthStencilMatch(p,a,b,c,d,e) (p)->CheckDepthStencilMatch(a,b,c,d,e) +#define IDirect3D8_GetDeviceCaps(p,a,b,c) (p)->GetDeviceCaps(a,b,c) +#define IDirect3D8_GetAdapterMonitor(p,a) (p)->GetAdapterMonitor(a) +#define IDirect3D8_CreateDevice(p,a,b,c,d,e,f) (p)->CreateDevice(a,b,c,d,e,f) +#endif + + + + + + + + + + + + + + + + + + + +#undef INTERFACE +#define INTERFACE IDirect3DDevice8 + +DECLARE_INTERFACE_(IDirect3DDevice8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DDevice8 methods ***/ + STDMETHOD(TestCooperativeLevel)(THIS) PURE; + STDMETHOD_(UINT, GetAvailableTextureMem)(THIS) PURE; + STDMETHOD(ResourceManagerDiscardBytes)(THIS_ DWORD Bytes) PURE; + STDMETHOD(GetDirect3D)(THIS_ IDirect3D8** ppD3D8) PURE; + STDMETHOD(GetDeviceCaps)(THIS_ D3DCAPS8* pCaps) PURE; + STDMETHOD(GetDisplayMode)(THIS_ D3DDISPLAYMODE* pMode) PURE; + STDMETHOD(GetCreationParameters)(THIS_ D3DDEVICE_CREATION_PARAMETERS *pParameters) PURE; + STDMETHOD(SetCursorProperties)(THIS_ UINT XHotSpot,UINT YHotSpot,IDirect3DSurface8* pCursorBitmap) PURE; + STDMETHOD_(void, SetCursorPosition)(THIS_ int X,int Y,DWORD Flags) PURE; + STDMETHOD_(BOOL, ShowCursor)(THIS_ BOOL bShow) PURE; + STDMETHOD(CreateAdditionalSwapChain)(THIS_ D3DPRESENT_PARAMETERS* pPresentationParameters,IDirect3DSwapChain8** pSwapChain) PURE; + STDMETHOD(Reset)(THIS_ D3DPRESENT_PARAMETERS* pPresentationParameters) PURE; + STDMETHOD(Present)(THIS_ CONST RECT* pSourceRect,CONST RECT* pDestRect,HWND hDestWindowOverride,CONST RGNDATA* pDirtyRegion) PURE; + STDMETHOD(GetBackBuffer)(THIS_ UINT BackBuffer,D3DBACKBUFFER_TYPE Type,IDirect3DSurface8** ppBackBuffer) PURE; + STDMETHOD(GetRasterStatus)(THIS_ D3DRASTER_STATUS* pRasterStatus) PURE; + STDMETHOD_(void, SetGammaRamp)(THIS_ DWORD Flags,CONST D3DGAMMARAMP* pRamp) PURE; + STDMETHOD_(void, GetGammaRamp)(THIS_ D3DGAMMARAMP* pRamp) PURE; + STDMETHOD(CreateTexture)(THIS_ UINT Width,UINT Height,UINT Levels,DWORD Usage,D3DFORMAT Format,D3DPOOL Pool,IDirect3DTexture8** ppTexture) PURE; + STDMETHOD(CreateVolumeTexture)(THIS_ UINT Width,UINT Height,UINT Depth,UINT Levels,DWORD Usage,D3DFORMAT Format,D3DPOOL Pool,IDirect3DVolumeTexture8** ppVolumeTexture) PURE; + STDMETHOD(CreateCubeTexture)(THIS_ UINT EdgeLength,UINT Levels,DWORD Usage,D3DFORMAT Format,D3DPOOL Pool,IDirect3DCubeTexture8** ppCubeTexture) PURE; + STDMETHOD(CreateVertexBuffer)(THIS_ UINT Length,DWORD Usage,DWORD FVF,D3DPOOL Pool,IDirect3DVertexBuffer8** ppVertexBuffer) PURE; + STDMETHOD(CreateIndexBuffer)(THIS_ UINT Length,DWORD Usage,D3DFORMAT Format,D3DPOOL Pool,IDirect3DIndexBuffer8** ppIndexBuffer) PURE; + STDMETHOD(CreateRenderTarget)(THIS_ UINT Width,UINT Height,D3DFORMAT Format,D3DMULTISAMPLE_TYPE MultiSample,BOOL Lockable,IDirect3DSurface8** ppSurface) PURE; + STDMETHOD(CreateDepthStencilSurface)(THIS_ UINT Width,UINT Height,D3DFORMAT Format,D3DMULTISAMPLE_TYPE MultiSample,IDirect3DSurface8** ppSurface) PURE; + STDMETHOD(CreateImageSurface)(THIS_ UINT Width,UINT Height,D3DFORMAT Format,IDirect3DSurface8** ppSurface) PURE; + STDMETHOD(CopyRects)(THIS_ IDirect3DSurface8* pSourceSurface,CONST RECT* pSourceRectsArray,UINT cRects,IDirect3DSurface8* pDestinationSurface,CONST POINT* pDestPointsArray) PURE; + STDMETHOD(UpdateTexture)(THIS_ IDirect3DBaseTexture8* pSourceTexture,IDirect3DBaseTexture8* pDestinationTexture) PURE; + STDMETHOD(GetFrontBuffer)(THIS_ IDirect3DSurface8* pDestSurface) PURE; + STDMETHOD(SetRenderTarget)(THIS_ IDirect3DSurface8* pRenderTarget,IDirect3DSurface8* pNewZStencil) PURE; + STDMETHOD(GetRenderTarget)(THIS_ IDirect3DSurface8** ppRenderTarget) PURE; + STDMETHOD(GetDepthStencilSurface)(THIS_ IDirect3DSurface8** ppZStencilSurface) PURE; + STDMETHOD(BeginScene)(THIS) PURE; + STDMETHOD(EndScene)(THIS) PURE; + STDMETHOD(Clear)(THIS_ DWORD Count,CONST D3DRECT* pRects,DWORD Flags,D3DCOLOR Color,float Z,DWORD Stencil) PURE; + STDMETHOD(SetTransform)(THIS_ D3DTRANSFORMSTATETYPE State,CONST D3DMATRIX* pMatrix) PURE; + STDMETHOD(GetTransform)(THIS_ D3DTRANSFORMSTATETYPE State,D3DMATRIX* pMatrix) PURE; + STDMETHOD(MultiplyTransform)(THIS_ D3DTRANSFORMSTATETYPE,CONST D3DMATRIX*) PURE; + STDMETHOD(SetViewport)(THIS_ CONST D3DVIEWPORT8* pViewport) PURE; + STDMETHOD(GetViewport)(THIS_ D3DVIEWPORT8* pViewport) PURE; + STDMETHOD(SetMaterial)(THIS_ CONST D3DMATERIAL8* pMaterial) PURE; + STDMETHOD(GetMaterial)(THIS_ D3DMATERIAL8* pMaterial) PURE; + STDMETHOD(SetLight)(THIS_ DWORD Index,CONST D3DLIGHT8*) PURE; + STDMETHOD(GetLight)(THIS_ DWORD Index,D3DLIGHT8*) PURE; + STDMETHOD(LightEnable)(THIS_ DWORD Index,BOOL Enable) PURE; + STDMETHOD(GetLightEnable)(THIS_ DWORD Index,BOOL* pEnable) PURE; + STDMETHOD(SetClipPlane)(THIS_ DWORD Index,CONST float* pPlane) PURE; + STDMETHOD(GetClipPlane)(THIS_ DWORD Index,float* pPlane) PURE; + STDMETHOD(SetRenderState)(THIS_ D3DRENDERSTATETYPE State,DWORD Value) PURE; + STDMETHOD(GetRenderState)(THIS_ D3DRENDERSTATETYPE State,DWORD* pValue) PURE; + STDMETHOD(BeginStateBlock)(THIS) PURE; + STDMETHOD(EndStateBlock)(THIS_ DWORD* pToken) PURE; + STDMETHOD(ApplyStateBlock)(THIS_ DWORD Token) PURE; + STDMETHOD(CaptureStateBlock)(THIS_ DWORD Token) PURE; + STDMETHOD(DeleteStateBlock)(THIS_ DWORD Token) PURE; + STDMETHOD(CreateStateBlock)(THIS_ D3DSTATEBLOCKTYPE Type,DWORD* pToken) PURE; + STDMETHOD(SetClipStatus)(THIS_ CONST D3DCLIPSTATUS8* pClipStatus) PURE; + STDMETHOD(GetClipStatus)(THIS_ D3DCLIPSTATUS8* pClipStatus) PURE; + STDMETHOD(GetTexture)(THIS_ DWORD Stage,IDirect3DBaseTexture8** ppTexture) PURE; + STDMETHOD(SetTexture)(THIS_ DWORD Stage,IDirect3DBaseTexture8* pTexture) PURE; + STDMETHOD(GetTextureStageState)(THIS_ DWORD Stage,D3DTEXTURESTAGESTATETYPE Type,DWORD* pValue) PURE; + STDMETHOD(SetTextureStageState)(THIS_ DWORD Stage,D3DTEXTURESTAGESTATETYPE Type,DWORD Value) PURE; + STDMETHOD(ValidateDevice)(THIS_ DWORD* pNumPasses) PURE; + STDMETHOD(GetInfo)(THIS_ DWORD DevInfoID,void* pDevInfoStruct,DWORD DevInfoStructSize) PURE; + STDMETHOD(SetPaletteEntries)(THIS_ UINT PaletteNumber,CONST PALETTEENTRY* pEntries) PURE; + STDMETHOD(GetPaletteEntries)(THIS_ UINT PaletteNumber,PALETTEENTRY* pEntries) PURE; + STDMETHOD(SetCurrentTexturePalette)(THIS_ UINT PaletteNumber) PURE; + STDMETHOD(GetCurrentTexturePalette)(THIS_ UINT *PaletteNumber) PURE; + STDMETHOD(DrawPrimitive)(THIS_ D3DPRIMITIVETYPE PrimitiveType,UINT StartVertex,UINT PrimitiveCount) PURE; + STDMETHOD(DrawIndexedPrimitive)(THIS_ D3DPRIMITIVETYPE,UINT minIndex,UINT NumVertices,UINT startIndex,UINT primCount) PURE; + STDMETHOD(DrawPrimitiveUP)(THIS_ D3DPRIMITIVETYPE PrimitiveType,UINT PrimitiveCount,CONST void* pVertexStreamZeroData,UINT VertexStreamZeroStride) PURE; + STDMETHOD(DrawIndexedPrimitiveUP)(THIS_ D3DPRIMITIVETYPE PrimitiveType,UINT MinVertexIndex,UINT NumVertexIndices,UINT PrimitiveCount,CONST void* pIndexData,D3DFORMAT IndexDataFormat,CONST void* pVertexStreamZeroData,UINT VertexStreamZeroStride) PURE; + STDMETHOD(ProcessVertices)(THIS_ UINT SrcStartIndex,UINT DestIndex,UINT VertexCount,IDirect3DVertexBuffer8* pDestBuffer,DWORD Flags) PURE; + STDMETHOD(CreateVertexShader)(THIS_ CONST DWORD* pDeclaration,CONST DWORD* pFunction,DWORD* pHandle,DWORD Usage) PURE; + STDMETHOD(SetVertexShader)(THIS_ DWORD Handle) PURE; + STDMETHOD(GetVertexShader)(THIS_ DWORD* pHandle) PURE; + STDMETHOD(DeleteVertexShader)(THIS_ DWORD Handle) PURE; + STDMETHOD(SetVertexShaderConstant)(THIS_ DWORD Register,CONST void* pConstantData,DWORD ConstantCount) PURE; + STDMETHOD(GetVertexShaderConstant)(THIS_ DWORD Register,void* pConstantData,DWORD ConstantCount) PURE; + STDMETHOD(GetVertexShaderDeclaration)(THIS_ DWORD Handle,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(GetVertexShaderFunction)(THIS_ DWORD Handle,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(SetStreamSource)(THIS_ UINT StreamNumber,IDirect3DVertexBuffer8* pStreamData,UINT Stride) PURE; + STDMETHOD(GetStreamSource)(THIS_ UINT StreamNumber,IDirect3DVertexBuffer8** ppStreamData,UINT* pStride) PURE; + STDMETHOD(SetIndices)(THIS_ IDirect3DIndexBuffer8* pIndexData,UINT BaseVertexIndex) PURE; + STDMETHOD(GetIndices)(THIS_ IDirect3DIndexBuffer8** ppIndexData,UINT* pBaseVertexIndex) PURE; + STDMETHOD(CreatePixelShader)(THIS_ CONST DWORD* pFunction,DWORD* pHandle) PURE; + STDMETHOD(SetPixelShader)(THIS_ DWORD Handle) PURE; + STDMETHOD(GetPixelShader)(THIS_ DWORD* pHandle) PURE; + STDMETHOD(DeletePixelShader)(THIS_ DWORD Handle) PURE; + STDMETHOD(SetPixelShaderConstant)(THIS_ DWORD Register,CONST void* pConstantData,DWORD ConstantCount) PURE; + STDMETHOD(GetPixelShaderConstant)(THIS_ DWORD Register,void* pConstantData,DWORD ConstantCount) PURE; + STDMETHOD(GetPixelShaderFunction)(THIS_ DWORD Handle,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(DrawRectPatch)(THIS_ UINT Handle,CONST float* pNumSegs,CONST D3DRECTPATCH_INFO* pRectPatchInfo) PURE; + STDMETHOD(DrawTriPatch)(THIS_ UINT Handle,CONST float* pNumSegs,CONST D3DTRIPATCH_INFO* pTriPatchInfo) PURE; + STDMETHOD(DeletePatch)(THIS_ UINT Handle) PURE; +}; + +typedef struct IDirect3DDevice8 *LPDIRECT3DDEVICE8, *PDIRECT3DDEVICE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DDevice8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DDevice8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DDevice8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DDevice8_TestCooperativeLevel(p) (p)->lpVtbl->TestCooperativeLevel(p) +#define IDirect3DDevice8_GetAvailableTextureMem(p) (p)->lpVtbl->GetAvailableTextureMem(p) +#define IDirect3DDevice8_ResourceManagerDiscardBytes(p,a) (p)->lpVtbl->ResourceManagerDiscardBytes(p,a) +#define IDirect3DDevice8_GetDirect3D(p,a) (p)->lpVtbl->GetDirect3D(p,a) +#define IDirect3DDevice8_GetDeviceCaps(p,a) (p)->lpVtbl->GetDeviceCaps(p,a) +#define IDirect3DDevice8_GetDisplayMode(p,a) (p)->lpVtbl->GetDisplayMode(p,a) +#define IDirect3DDevice8_GetCreationParameters(p,a) (p)->lpVtbl->GetCreationParameters(p,a) +#define IDirect3DDevice8_SetCursorProperties(p,a,b,c) (p)->lpVtbl->SetCursorProperties(p,a,b,c) +#define IDirect3DDevice8_SetCursorPosition(p,a,b,c) (p)->lpVtbl->SetCursorPosition(p,a,b,c) +#define IDirect3DDevice8_ShowCursor(p,a) (p)->lpVtbl->ShowCursor(p,a) +#define IDirect3DDevice8_CreateAdditionalSwapChain(p,a,b) (p)->lpVtbl->CreateAdditionalSwapChain(p,a,b) +#define IDirect3DDevice8_Reset(p,a) (p)->lpVtbl->Reset(p,a) +#define IDirect3DDevice8_Present(p,a,b,c,d) (p)->lpVtbl->Present(p,a,b,c,d) +#define IDirect3DDevice8_GetBackBuffer(p,a,b,c) (p)->lpVtbl->GetBackBuffer(p,a,b,c) +#define IDirect3DDevice8_GetRasterStatus(p,a) (p)->lpVtbl->GetRasterStatus(p,a) +#define IDirect3DDevice8_SetGammaRamp(p,a,b) (p)->lpVtbl->SetGammaRamp(p,a,b) +#define IDirect3DDevice8_GetGammaRamp(p,a) (p)->lpVtbl->GetGammaRamp(p,a) +#define IDirect3DDevice8_CreateTexture(p,a,b,c,d,e,f,g) (p)->lpVtbl->CreateTexture(p,a,b,c,d,e,f,g) +#define IDirect3DDevice8_CreateVolumeTexture(p,a,b,c,d,e,f,g,h) (p)->lpVtbl->CreateVolumeTexture(p,a,b,c,d,e,f,g,h) +#define IDirect3DDevice8_CreateCubeTexture(p,a,b,c,d,e,f) (p)->lpVtbl->CreateCubeTexture(p,a,b,c,d,e,f) +#define IDirect3DDevice8_CreateVertexBuffer(p,a,b,c,d,e) (p)->lpVtbl->CreateVertexBuffer(p,a,b,c,d,e) +#define IDirect3DDevice8_CreateIndexBuffer(p,a,b,c,d,e) (p)->lpVtbl->CreateIndexBuffer(p,a,b,c,d,e) +#define IDirect3DDevice8_CreateRenderTarget(p,a,b,c,d,e,f) (p)->lpVtbl->CreateRenderTarget(p,a,b,c,d,e,f) +#define IDirect3DDevice8_CreateDepthStencilSurface(p,a,b,c,d,e) (p)->lpVtbl->CreateDepthStencilSurface(p,a,b,c,d,e) +#define IDirect3DDevice8_CreateImageSurface(p,a,b,c,d) (p)->lpVtbl->CreateImageSurface(p,a,b,c,d) +#define IDirect3DDevice8_CopyRects(p,a,b,c,d,e) (p)->lpVtbl->CopyRects(p,a,b,c,d,e) +#define IDirect3DDevice8_UpdateTexture(p,a,b) (p)->lpVtbl->UpdateTexture(p,a,b) +#define IDirect3DDevice8_GetFrontBuffer(p,a) (p)->lpVtbl->GetFrontBuffer(p,a) +#define IDirect3DDevice8_SetRenderTarget(p,a,b) (p)->lpVtbl->SetRenderTarget(p,a,b) +#define IDirect3DDevice8_GetRenderTarget(p,a) (p)->lpVtbl->GetRenderTarget(p,a) +#define IDirect3DDevice8_GetDepthStencilSurface(p,a) (p)->lpVtbl->GetDepthStencilSurface(p,a) +#define IDirect3DDevice8_BeginScene(p) (p)->lpVtbl->BeginScene(p) +#define IDirect3DDevice8_EndScene(p) (p)->lpVtbl->EndScene(p) +#define IDirect3DDevice8_Clear(p,a,b,c,d,e,f) (p)->lpVtbl->Clear(p,a,b,c,d,e,f) +#define IDirect3DDevice8_SetTransform(p,a,b) (p)->lpVtbl->SetTransform(p,a,b) +#define IDirect3DDevice8_GetTransform(p,a,b) (p)->lpVtbl->GetTransform(p,a,b) +#define IDirect3DDevice8_MultiplyTransform(p,a,b) (p)->lpVtbl->MultiplyTransform(p,a,b) +#define IDirect3DDevice8_SetViewport(p,a) (p)->lpVtbl->SetViewport(p,a) +#define IDirect3DDevice8_GetViewport(p,a) (p)->lpVtbl->GetViewport(p,a) +#define IDirect3DDevice8_SetMaterial(p,a) (p)->lpVtbl->SetMaterial(p,a) +#define IDirect3DDevice8_GetMaterial(p,a) (p)->lpVtbl->GetMaterial(p,a) +#define IDirect3DDevice8_SetLight(p,a,b) (p)->lpVtbl->SetLight(p,a,b) +#define IDirect3DDevice8_GetLight(p,a,b) (p)->lpVtbl->GetLight(p,a,b) +#define IDirect3DDevice8_LightEnable(p,a,b) (p)->lpVtbl->LightEnable(p,a,b) +#define IDirect3DDevice8_GetLightEnable(p,a,b) (p)->lpVtbl->GetLightEnable(p,a,b) +#define IDirect3DDevice8_SetClipPlane(p,a,b) (p)->lpVtbl->SetClipPlane(p,a,b) +#define IDirect3DDevice8_GetClipPlane(p,a,b) (p)->lpVtbl->GetClipPlane(p,a,b) +#define IDirect3DDevice8_SetRenderState(p,a,b) (p)->lpVtbl->SetRenderState(p,a,b) +#define IDirect3DDevice8_GetRenderState(p,a,b) (p)->lpVtbl->GetRenderState(p,a,b) +#define IDirect3DDevice8_BeginStateBlock(p) (p)->lpVtbl->BeginStateBlock(p) +#define IDirect3DDevice8_EndStateBlock(p,a) (p)->lpVtbl->EndStateBlock(p,a) +#define IDirect3DDevice8_ApplyStateBlock(p,a) (p)->lpVtbl->ApplyStateBlock(p,a) +#define IDirect3DDevice8_CaptureStateBlock(p,a) (p)->lpVtbl->CaptureStateBlock(p,a) +#define IDirect3DDevice8_DeleteStateBlock(p,a) (p)->lpVtbl->DeleteStateBlock(p,a) +#define IDirect3DDevice8_CreateStateBlock(p,a,b) (p)->lpVtbl->CreateStateBlock(p,a,b) +#define IDirect3DDevice8_SetClipStatus(p,a) (p)->lpVtbl->SetClipStatus(p,a) +#define IDirect3DDevice8_GetClipStatus(p,a) (p)->lpVtbl->GetClipStatus(p,a) +#define IDirect3DDevice8_GetTexture(p,a,b) (p)->lpVtbl->GetTexture(p,a,b) +#define IDirect3DDevice8_SetTexture(p,a,b) (p)->lpVtbl->SetTexture(p,a,b) +#define IDirect3DDevice8_GetTextureStageState(p,a,b,c) (p)->lpVtbl->GetTextureStageState(p,a,b,c) +#define IDirect3DDevice8_SetTextureStageState(p,a,b,c) (p)->lpVtbl->SetTextureStageState(p,a,b,c) +#define IDirect3DDevice8_ValidateDevice(p,a) (p)->lpVtbl->ValidateDevice(p,a) +#define IDirect3DDevice8_GetInfo(p,a,b,c) (p)->lpVtbl->GetInfo(p,a,b,c) +#define IDirect3DDevice8_SetPaletteEntries(p,a,b) (p)->lpVtbl->SetPaletteEntries(p,a,b) +#define IDirect3DDevice8_GetPaletteEntries(p,a,b) (p)->lpVtbl->GetPaletteEntries(p,a,b) +#define IDirect3DDevice8_SetCurrentTexturePalette(p,a) (p)->lpVtbl->SetCurrentTexturePalette(p,a) +#define IDirect3DDevice8_GetCurrentTexturePalette(p,a) (p)->lpVtbl->GetCurrentTexturePalette(p,a) +#define IDirect3DDevice8_DrawPrimitive(p,a,b,c) (p)->lpVtbl->DrawPrimitive(p,a,b,c) +#define IDirect3DDevice8_DrawIndexedPrimitive(p,a,b,c,d,e) (p)->lpVtbl->DrawIndexedPrimitive(p,a,b,c,d,e) +#define IDirect3DDevice8_DrawPrimitiveUP(p,a,b,c,d) (p)->lpVtbl->DrawPrimitiveUP(p,a,b,c,d) +#define IDirect3DDevice8_DrawIndexedPrimitiveUP(p,a,b,c,d,e,f,g,h) (p)->lpVtbl->DrawIndexedPrimitiveUP(p,a,b,c,d,e,f,g,h) +#define IDirect3DDevice8_ProcessVertices(p,a,b,c,d,e) (p)->lpVtbl->ProcessVertices(p,a,b,c,d,e) +#define IDirect3DDevice8_CreateVertexShader(p,a,b,c,d) (p)->lpVtbl->CreateVertexShader(p,a,b,c,d) +#define IDirect3DDevice8_SetVertexShader(p,a) (p)->lpVtbl->SetVertexShader(p,a) +#define IDirect3DDevice8_GetVertexShader(p,a) (p)->lpVtbl->GetVertexShader(p,a) +#define IDirect3DDevice8_DeleteVertexShader(p,a) (p)->lpVtbl->DeleteVertexShader(p,a) +#define IDirect3DDevice8_SetVertexShaderConstant(p,a,b,c) (p)->lpVtbl->SetVertexShaderConstant(p,a,b,c) +#define IDirect3DDevice8_GetVertexShaderConstant(p,a,b,c) (p)->lpVtbl->GetVertexShaderConstant(p,a,b,c) +#define IDirect3DDevice8_GetVertexShaderDeclaration(p,a,b,c) (p)->lpVtbl->GetVertexShaderDeclaration(p,a,b,c) +#define IDirect3DDevice8_GetVertexShaderFunction(p,a,b,c) (p)->lpVtbl->GetVertexShaderFunction(p,a,b,c) +#define IDirect3DDevice8_SetStreamSource(p,a,b,c) (p)->lpVtbl->SetStreamSource(p,a,b,c) +#define IDirect3DDevice8_GetStreamSource(p,a,b,c) (p)->lpVtbl->GetStreamSource(p,a,b,c) +#define IDirect3DDevice8_SetIndices(p,a,b) (p)->lpVtbl->SetIndices(p,a,b) +#define IDirect3DDevice8_GetIndices(p,a,b) (p)->lpVtbl->GetIndices(p,a,b) +#define IDirect3DDevice8_CreatePixelShader(p,a,b) (p)->lpVtbl->CreatePixelShader(p,a,b) +#define IDirect3DDevice8_SetPixelShader(p,a) (p)->lpVtbl->SetPixelShader(p,a) +#define IDirect3DDevice8_GetPixelShader(p,a) (p)->lpVtbl->GetPixelShader(p,a) +#define IDirect3DDevice8_DeletePixelShader(p,a) (p)->lpVtbl->DeletePixelShader(p,a) +#define IDirect3DDevice8_SetPixelShaderConstant(p,a,b,c) (p)->lpVtbl->SetPixelShaderConstant(p,a,b,c) +#define IDirect3DDevice8_GetPixelShaderConstant(p,a,b,c) (p)->lpVtbl->GetPixelShaderConstant(p,a,b,c) +#define IDirect3DDevice8_GetPixelShaderFunction(p,a,b,c) (p)->lpVtbl->GetPixelShaderFunction(p,a,b,c) +#define IDirect3DDevice8_DrawRectPatch(p,a,b,c) (p)->lpVtbl->DrawRectPatch(p,a,b,c) +#define IDirect3DDevice8_DrawTriPatch(p,a,b,c) (p)->lpVtbl->DrawTriPatch(p,a,b,c) +#define IDirect3DDevice8_DeletePatch(p,a) (p)->lpVtbl->DeletePatch(p,a) +#else +#define IDirect3DDevice8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DDevice8_AddRef(p) (p)->AddRef() +#define IDirect3DDevice8_Release(p) (p)->Release() +#define IDirect3DDevice8_TestCooperativeLevel(p) (p)->TestCooperativeLevel() +#define IDirect3DDevice8_GetAvailableTextureMem(p) (p)->GetAvailableTextureMem() +#define IDirect3DDevice8_ResourceManagerDiscardBytes(p,a) (p)->ResourceManagerDiscardBytes(a) +#define IDirect3DDevice8_GetDirect3D(p,a) (p)->GetDirect3D(a) +#define IDirect3DDevice8_GetDeviceCaps(p,a) (p)->GetDeviceCaps(a) +#define IDirect3DDevice8_GetDisplayMode(p,a) (p)->GetDisplayMode(a) +#define IDirect3DDevice8_GetCreationParameters(p,a) (p)->GetCreationParameters(a) +#define IDirect3DDevice8_SetCursorProperties(p,a,b,c) (p)->SetCursorProperties(a,b,c) +#define IDirect3DDevice8_SetCursorPosition(p,a,b,c) (p)->SetCursorPosition(a,b,c) +#define IDirect3DDevice8_ShowCursor(p,a) (p)->ShowCursor(a) +#define IDirect3DDevice8_CreateAdditionalSwapChain(p,a,b) (p)->CreateAdditionalSwapChain(a,b) +#define IDirect3DDevice8_Reset(p,a) (p)->Reset(a) +#define IDirect3DDevice8_Present(p,a,b,c,d) (p)->Present(a,b,c,d) +#define IDirect3DDevice8_GetBackBuffer(p,a,b,c) (p)->GetBackBuffer(a,b,c) +#define IDirect3DDevice8_GetRasterStatus(p,a) (p)->GetRasterStatus(a) +#define IDirect3DDevice8_SetGammaRamp(p,a,b) (p)->SetGammaRamp(a,b) +#define IDirect3DDevice8_GetGammaRamp(p,a) (p)->GetGammaRamp(a) +#define IDirect3DDevice8_CreateTexture(p,a,b,c,d,e,f,g) (p)->CreateTexture(a,b,c,d,e,f,g) +#define IDirect3DDevice8_CreateVolumeTexture(p,a,b,c,d,e,f,g,h) (p)->CreateVolumeTexture(a,b,c,d,e,f,g,h) +#define IDirect3DDevice8_CreateCubeTexture(p,a,b,c,d,e,f) (p)->CreateCubeTexture(a,b,c,d,e,f) +#define IDirect3DDevice8_CreateVertexBuffer(p,a,b,c,d,e) (p)->CreateVertexBuffer(a,b,c,d,e) +#define IDirect3DDevice8_CreateIndexBuffer(p,a,b,c,d,e) (p)->CreateIndexBuffer(a,b,c,d,e) +#define IDirect3DDevice8_CreateRenderTarget(p,a,b,c,d,e,f) (p)->CreateRenderTarget(a,b,c,d,e,f) +#define IDirect3DDevice8_CreateDepthStencilSurface(p,a,b,c,d,e) (p)->CreateDepthStencilSurface(a,b,c,d,e) +#define IDirect3DDevice8_CreateImageSurface(p,a,b,c,d) (p)->CreateImageSurface(a,b,c,d) +#define IDirect3DDevice8_CopyRects(p,a,b,c,d,e) (p)->CopyRects(a,b,c,d,e) +#define IDirect3DDevice8_UpdateTexture(p,a,b) (p)->UpdateTexture(a,b) +#define IDirect3DDevice8_GetFrontBuffer(p,a) (p)->GetFrontBuffer(a) +#define IDirect3DDevice8_SetRenderTarget(p,a,b) (p)->SetRenderTarget(a,b) +#define IDirect3DDevice8_GetRenderTarget(p,a) (p)->GetRenderTarget(a) +#define IDirect3DDevice8_GetDepthStencilSurface(p,a) (p)->GetDepthStencilSurface(a) +#define IDirect3DDevice8_BeginScene(p) (p)->BeginScene() +#define IDirect3DDevice8_EndScene(p) (p)->EndScene() +#define IDirect3DDevice8_Clear(p,a,b,c,d,e,f) (p)->Clear(a,b,c,d,e,f) +#define IDirect3DDevice8_SetTransform(p,a,b) (p)->SetTransform(a,b) +#define IDirect3DDevice8_GetTransform(p,a,b) (p)->GetTransform(a,b) +#define IDirect3DDevice8_MultiplyTransform(p,a,b) (p)->MultiplyTransform(a,b) +#define IDirect3DDevice8_SetViewport(p,a) (p)->SetViewport(a) +#define IDirect3DDevice8_GetViewport(p,a) (p)->GetViewport(a) +#define IDirect3DDevice8_SetMaterial(p,a) (p)->SetMaterial(a) +#define IDirect3DDevice8_GetMaterial(p,a) (p)->GetMaterial(a) +#define IDirect3DDevice8_SetLight(p,a,b) (p)->SetLight(a,b) +#define IDirect3DDevice8_GetLight(p,a,b) (p)->GetLight(a,b) +#define IDirect3DDevice8_LightEnable(p,a,b) (p)->LightEnable(a,b) +#define IDirect3DDevice8_GetLightEnable(p,a,b) (p)->GetLightEnable(a,b) +#define IDirect3DDevice8_SetClipPlane(p,a,b) (p)->SetClipPlane(a,b) +#define IDirect3DDevice8_GetClipPlane(p,a,b) (p)->GetClipPlane(a,b) +#define IDirect3DDevice8_SetRenderState(p,a,b) (p)->SetRenderState(a,b) +#define IDirect3DDevice8_GetRenderState(p,a,b) (p)->GetRenderState(a,b) +#define IDirect3DDevice8_BeginStateBlock(p) (p)->BeginStateBlock() +#define IDirect3DDevice8_EndStateBlock(p,a) (p)->EndStateBlock(a) +#define IDirect3DDevice8_ApplyStateBlock(p,a) (p)->ApplyStateBlock(a) +#define IDirect3DDevice8_CaptureStateBlock(p,a) (p)->CaptureStateBlock(a) +#define IDirect3DDevice8_DeleteStateBlock(p,a) (p)->DeleteStateBlock(a) +#define IDirect3DDevice8_CreateStateBlock(p,a,b) (p)->CreateStateBlock(a,b) +#define IDirect3DDevice8_SetClipStatus(p,a) (p)->SetClipStatus(a) +#define IDirect3DDevice8_GetClipStatus(p,a) (p)->GetClipStatus(a) +#define IDirect3DDevice8_GetTexture(p,a,b) (p)->GetTexture(a,b) +#define IDirect3DDevice8_SetTexture(p,a,b) (p)->SetTexture(a,b) +#define IDirect3DDevice8_GetTextureStageState(p,a,b,c) (p)->GetTextureStageState(a,b,c) +#define IDirect3DDevice8_SetTextureStageState(p,a,b,c) (p)->SetTextureStageState(a,b,c) +#define IDirect3DDevice8_ValidateDevice(p,a) (p)->ValidateDevice(a) +#define IDirect3DDevice8_GetInfo(p,a,b,c) (p)->GetInfo(a,b,c) +#define IDirect3DDevice8_SetPaletteEntries(p,a,b) (p)->SetPaletteEntries(a,b) +#define IDirect3DDevice8_GetPaletteEntries(p,a,b) (p)->GetPaletteEntries(a,b) +#define IDirect3DDevice8_SetCurrentTexturePalette(p,a) (p)->SetCurrentTexturePalette(a) +#define IDirect3DDevice8_GetCurrentTexturePalette(p,a) (p)->GetCurrentTexturePalette(a) +#define IDirect3DDevice8_DrawPrimitive(p,a,b,c) (p)->DrawPrimitive(a,b,c) +#define IDirect3DDevice8_DrawIndexedPrimitive(p,a,b,c,d,e) (p)->DrawIndexedPrimitive(a,b,c,d,e) +#define IDirect3DDevice8_DrawPrimitiveUP(p,a,b,c,d) (p)->DrawPrimitiveUP(a,b,c,d) +#define IDirect3DDevice8_DrawIndexedPrimitiveUP(p,a,b,c,d,e,f,g,h) (p)->DrawIndexedPrimitiveUP(a,b,c,d,e,f,g,h) +#define IDirect3DDevice8_ProcessVertices(p,a,b,c,d,e) (p)->ProcessVertices(a,b,c,d,e) +#define IDirect3DDevice8_CreateVertexShader(p,a,b,c,d) (p)->CreateVertexShader(a,b,c,d) +#define IDirect3DDevice8_SetVertexShader(p,a) (p)->SetVertexShader(a) +#define IDirect3DDevice8_GetVertexShader(p,a) (p)->GetVertexShader(a) +#define IDirect3DDevice8_DeleteVertexShader(p,a) (p)->DeleteVertexShader(a) +#define IDirect3DDevice8_SetVertexShaderConstant(p,a,b,c) (p)->SetVertexShaderConstant(a,b,c) +#define IDirect3DDevice8_GetVertexShaderConstant(p,a,b,c) (p)->GetVertexShaderConstant(a,b,c) +#define IDirect3DDevice8_GetVertexShaderDeclaration(p,a,b,c) (p)->GetVertexShaderDeclaration(a,b,c) +#define IDirect3DDevice8_GetVertexShaderFunction(p,a,b,c) (p)->GetVertexShaderFunction(a,b,c) +#define IDirect3DDevice8_SetStreamSource(p,a,b,c) (p)->SetStreamSource(a,b,c) +#define IDirect3DDevice8_GetStreamSource(p,a,b,c) (p)->GetStreamSource(a,b,c) +#define IDirect3DDevice8_SetIndices(p,a,b) (p)->SetIndices(a,b) +#define IDirect3DDevice8_GetIndices(p,a,b) (p)->GetIndices(a,b) +#define IDirect3DDevice8_CreatePixelShader(p,a,b) (p)->CreatePixelShader(a,b) +#define IDirect3DDevice8_SetPixelShader(p,a) (p)->SetPixelShader(a) +#define IDirect3DDevice8_GetPixelShader(p,a) (p)->GetPixelShader(a) +#define IDirect3DDevice8_DeletePixelShader(p,a) (p)->DeletePixelShader(a) +#define IDirect3DDevice8_SetPixelShaderConstant(p,a,b,c) (p)->SetPixelShaderConstant(a,b,c) +#define IDirect3DDevice8_GetPixelShaderConstant(p,a,b,c) (p)->GetPixelShaderConstant(a,b,c) +#define IDirect3DDevice8_GetPixelShaderFunction(p,a,b,c) (p)->GetPixelShaderFunction(a,b,c) +#define IDirect3DDevice8_DrawRectPatch(p,a,b,c) (p)->DrawRectPatch(a,b,c) +#define IDirect3DDevice8_DrawTriPatch(p,a,b,c) (p)->DrawTriPatch(a,b,c) +#define IDirect3DDevice8_DeletePatch(p,a) (p)->DeletePatch(a) +#endif + + + +#undef INTERFACE +#define INTERFACE IDirect3DSwapChain8 + +DECLARE_INTERFACE_(IDirect3DSwapChain8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DSwapChain8 methods ***/ + STDMETHOD(Present)(THIS_ CONST RECT* pSourceRect,CONST RECT* pDestRect,HWND hDestWindowOverride,CONST RGNDATA* pDirtyRegion) PURE; + STDMETHOD(GetBackBuffer)(THIS_ UINT BackBuffer,D3DBACKBUFFER_TYPE Type,IDirect3DSurface8** ppBackBuffer) PURE; +}; + +typedef struct IDirect3DSwapChain8 *LPDIRECT3DSWAPCHAIN8, *PDIRECT3DSWAPCHAIN8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DSwapChain8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DSwapChain8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DSwapChain8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DSwapChain8_Present(p,a,b,c,d) (p)->lpVtbl->Present(p,a,b,c,d) +#define IDirect3DSwapChain8_GetBackBuffer(p,a,b,c) (p)->lpVtbl->GetBackBuffer(p,a,b,c) +#else +#define IDirect3DSwapChain8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DSwapChain8_AddRef(p) (p)->AddRef() +#define IDirect3DSwapChain8_Release(p) (p)->Release() +#define IDirect3DSwapChain8_Present(p,a,b,c,d) (p)->Present(a,b,c,d) +#define IDirect3DSwapChain8_GetBackBuffer(p,a,b,c) (p)->GetBackBuffer(a,b,c) +#endif + + + +#undef INTERFACE +#define INTERFACE IDirect3DResource8 + +DECLARE_INTERFACE_(IDirect3DResource8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DResource8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; +}; + +typedef struct IDirect3DResource8 *LPDIRECT3DRESOURCE8, *PDIRECT3DRESOURCE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DResource8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DResource8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DResource8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DResource8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DResource8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DResource8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DResource8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DResource8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DResource8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DResource8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DResource8_GetType(p) (p)->lpVtbl->GetType(p) +#else +#define IDirect3DResource8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DResource8_AddRef(p) (p)->AddRef() +#define IDirect3DResource8_Release(p) (p)->Release() +#define IDirect3DResource8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DResource8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DResource8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DResource8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DResource8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DResource8_GetPriority(p) (p)->GetPriority() +#define IDirect3DResource8_PreLoad(p) (p)->PreLoad() +#define IDirect3DResource8_GetType(p) (p)->GetType() +#endif + + + + +#undef INTERFACE +#define INTERFACE IDirect3DBaseTexture8 + +DECLARE_INTERFACE_(IDirect3DBaseTexture8, IDirect3DResource8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DResource8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD_(DWORD, SetLOD)(THIS_ DWORD LODNew) PURE; + STDMETHOD_(DWORD, GetLOD)(THIS) PURE; + STDMETHOD_(DWORD, GetLevelCount)(THIS) PURE; +}; + +typedef struct IDirect3DBaseTexture8 *LPDIRECT3DBASETEXTURE8, *PDIRECT3DBASETEXTURE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DBaseTexture8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DBaseTexture8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DBaseTexture8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DBaseTexture8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DBaseTexture8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DBaseTexture8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DBaseTexture8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DBaseTexture8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DBaseTexture8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DBaseTexture8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DBaseTexture8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DBaseTexture8_SetLOD(p,a) (p)->lpVtbl->SetLOD(p,a) +#define IDirect3DBaseTexture8_GetLOD(p) (p)->lpVtbl->GetLOD(p) +#define IDirect3DBaseTexture8_GetLevelCount(p) (p)->lpVtbl->GetLevelCount(p) +#else +#define IDirect3DBaseTexture8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DBaseTexture8_AddRef(p) (p)->AddRef() +#define IDirect3DBaseTexture8_Release(p) (p)->Release() +#define IDirect3DBaseTexture8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DBaseTexture8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DBaseTexture8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DBaseTexture8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DBaseTexture8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DBaseTexture8_GetPriority(p) (p)->GetPriority() +#define IDirect3DBaseTexture8_PreLoad(p) (p)->PreLoad() +#define IDirect3DBaseTexture8_GetType(p) (p)->GetType() +#define IDirect3DBaseTexture8_SetLOD(p,a) (p)->SetLOD(a) +#define IDirect3DBaseTexture8_GetLOD(p) (p)->GetLOD() +#define IDirect3DBaseTexture8_GetLevelCount(p) (p)->GetLevelCount() +#endif + + + + + +#undef INTERFACE +#define INTERFACE IDirect3DTexture8 + +DECLARE_INTERFACE_(IDirect3DTexture8, IDirect3DBaseTexture8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DBaseTexture8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD_(DWORD, SetLOD)(THIS_ DWORD LODNew) PURE; + STDMETHOD_(DWORD, GetLOD)(THIS) PURE; + STDMETHOD_(DWORD, GetLevelCount)(THIS) PURE; + STDMETHOD(GetLevelDesc)(THIS_ UINT Level,D3DSURFACE_DESC *pDesc) PURE; + STDMETHOD(GetSurfaceLevel)(THIS_ UINT Level,IDirect3DSurface8** ppSurfaceLevel) PURE; + STDMETHOD(LockRect)(THIS_ UINT Level,D3DLOCKED_RECT* pLockedRect,CONST RECT* pRect,DWORD Flags) PURE; + STDMETHOD(UnlockRect)(THIS_ UINT Level) PURE; + STDMETHOD(AddDirtyRect)(THIS_ CONST RECT* pDirtyRect) PURE; +}; + +typedef struct IDirect3DTexture8 *LPDIRECT3DTEXTURE8, *PDIRECT3DTEXTURE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DTexture8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DTexture8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DTexture8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DTexture8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DTexture8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DTexture8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DTexture8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DTexture8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DTexture8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DTexture8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DTexture8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DTexture8_SetLOD(p,a) (p)->lpVtbl->SetLOD(p,a) +#define IDirect3DTexture8_GetLOD(p) (p)->lpVtbl->GetLOD(p) +#define IDirect3DTexture8_GetLevelCount(p) (p)->lpVtbl->GetLevelCount(p) +#define IDirect3DTexture8_GetLevelDesc(p,a,b) (p)->lpVtbl->GetLevelDesc(p,a,b) +#define IDirect3DTexture8_GetSurfaceLevel(p,a,b) (p)->lpVtbl->GetSurfaceLevel(p,a,b) +#define IDirect3DTexture8_LockRect(p,a,b,c,d) (p)->lpVtbl->LockRect(p,a,b,c,d) +#define IDirect3DTexture8_UnlockRect(p,a) (p)->lpVtbl->UnlockRect(p,a) +#define IDirect3DTexture8_AddDirtyRect(p,a) (p)->lpVtbl->AddDirtyRect(p,a) +#else +#define IDirect3DTexture8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DTexture8_AddRef(p) (p)->AddRef() +#define IDirect3DTexture8_Release(p) (p)->Release() +#define IDirect3DTexture8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DTexture8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DTexture8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DTexture8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DTexture8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DTexture8_GetPriority(p) (p)->GetPriority() +#define IDirect3DTexture8_PreLoad(p) (p)->PreLoad() +#define IDirect3DTexture8_GetType(p) (p)->GetType() +#define IDirect3DTexture8_SetLOD(p,a) (p)->SetLOD(a) +#define IDirect3DTexture8_GetLOD(p) (p)->GetLOD() +#define IDirect3DTexture8_GetLevelCount(p) (p)->GetLevelCount() +#define IDirect3DTexture8_GetLevelDesc(p,a,b) (p)->GetLevelDesc(a,b) +#define IDirect3DTexture8_GetSurfaceLevel(p,a,b) (p)->GetSurfaceLevel(a,b) +#define IDirect3DTexture8_LockRect(p,a,b,c,d) (p)->LockRect(a,b,c,d) +#define IDirect3DTexture8_UnlockRect(p,a) (p)->UnlockRect(a) +#define IDirect3DTexture8_AddDirtyRect(p,a) (p)->AddDirtyRect(a) +#endif + + + + + +#undef INTERFACE +#define INTERFACE IDirect3DVolumeTexture8 + +DECLARE_INTERFACE_(IDirect3DVolumeTexture8, IDirect3DBaseTexture8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DBaseTexture8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD_(DWORD, SetLOD)(THIS_ DWORD LODNew) PURE; + STDMETHOD_(DWORD, GetLOD)(THIS) PURE; + STDMETHOD_(DWORD, GetLevelCount)(THIS) PURE; + STDMETHOD(GetLevelDesc)(THIS_ UINT Level,D3DVOLUME_DESC *pDesc) PURE; + STDMETHOD(GetVolumeLevel)(THIS_ UINT Level,IDirect3DVolume8** ppVolumeLevel) PURE; + STDMETHOD(LockBox)(THIS_ UINT Level,D3DLOCKED_BOX* pLockedVolume,CONST D3DBOX* pBox,DWORD Flags) PURE; + STDMETHOD(UnlockBox)(THIS_ UINT Level) PURE; + STDMETHOD(AddDirtyBox)(THIS_ CONST D3DBOX* pDirtyBox) PURE; +}; + +typedef struct IDirect3DVolumeTexture8 *LPDIRECT3DVOLUMETEXTURE8, *PDIRECT3DVOLUMETEXTURE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DVolumeTexture8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DVolumeTexture8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DVolumeTexture8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DVolumeTexture8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DVolumeTexture8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DVolumeTexture8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DVolumeTexture8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DVolumeTexture8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DVolumeTexture8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DVolumeTexture8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DVolumeTexture8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DVolumeTexture8_SetLOD(p,a) (p)->lpVtbl->SetLOD(p,a) +#define IDirect3DVolumeTexture8_GetLOD(p) (p)->lpVtbl->GetLOD(p) +#define IDirect3DVolumeTexture8_GetLevelCount(p) (p)->lpVtbl->GetLevelCount(p) +#define IDirect3DVolumeTexture8_GetLevelDesc(p,a,b) (p)->lpVtbl->GetLevelDesc(p,a,b) +#define IDirect3DVolumeTexture8_GetVolumeLevel(p,a,b) (p)->lpVtbl->GetVolumeLevel(p,a,b) +#define IDirect3DVolumeTexture8_LockBox(p,a,b,c,d) (p)->lpVtbl->LockBox(p,a,b,c,d) +#define IDirect3DVolumeTexture8_UnlockBox(p,a) (p)->lpVtbl->UnlockBox(p,a) +#define IDirect3DVolumeTexture8_AddDirtyBox(p,a) (p)->lpVtbl->AddDirtyBox(p,a) +#else +#define IDirect3DVolumeTexture8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DVolumeTexture8_AddRef(p) (p)->AddRef() +#define IDirect3DVolumeTexture8_Release(p) (p)->Release() +#define IDirect3DVolumeTexture8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DVolumeTexture8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DVolumeTexture8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DVolumeTexture8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DVolumeTexture8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DVolumeTexture8_GetPriority(p) (p)->GetPriority() +#define IDirect3DVolumeTexture8_PreLoad(p) (p)->PreLoad() +#define IDirect3DVolumeTexture8_GetType(p) (p)->GetType() +#define IDirect3DVolumeTexture8_SetLOD(p,a) (p)->SetLOD(a) +#define IDirect3DVolumeTexture8_GetLOD(p) (p)->GetLOD() +#define IDirect3DVolumeTexture8_GetLevelCount(p) (p)->GetLevelCount() +#define IDirect3DVolumeTexture8_GetLevelDesc(p,a,b) (p)->GetLevelDesc(a,b) +#define IDirect3DVolumeTexture8_GetVolumeLevel(p,a,b) (p)->GetVolumeLevel(a,b) +#define IDirect3DVolumeTexture8_LockBox(p,a,b,c,d) (p)->LockBox(a,b,c,d) +#define IDirect3DVolumeTexture8_UnlockBox(p,a) (p)->UnlockBox(a) +#define IDirect3DVolumeTexture8_AddDirtyBox(p,a) (p)->AddDirtyBox(a) +#endif + + + + + +#undef INTERFACE +#define INTERFACE IDirect3DCubeTexture8 + +DECLARE_INTERFACE_(IDirect3DCubeTexture8, IDirect3DBaseTexture8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DBaseTexture8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD_(DWORD, SetLOD)(THIS_ DWORD LODNew) PURE; + STDMETHOD_(DWORD, GetLOD)(THIS) PURE; + STDMETHOD_(DWORD, GetLevelCount)(THIS) PURE; + STDMETHOD(GetLevelDesc)(THIS_ UINT Level,D3DSURFACE_DESC *pDesc) PURE; + STDMETHOD(GetCubeMapSurface)(THIS_ D3DCUBEMAP_FACES FaceType,UINT Level,IDirect3DSurface8** ppCubeMapSurface) PURE; + STDMETHOD(LockRect)(THIS_ D3DCUBEMAP_FACES FaceType,UINT Level,D3DLOCKED_RECT* pLockedRect,CONST RECT* pRect,DWORD Flags) PURE; + STDMETHOD(UnlockRect)(THIS_ D3DCUBEMAP_FACES FaceType,UINT Level) PURE; + STDMETHOD(AddDirtyRect)(THIS_ D3DCUBEMAP_FACES FaceType,CONST RECT* pDirtyRect) PURE; +}; + +typedef struct IDirect3DCubeTexture8 *LPDIRECT3DCUBETEXTURE8, *PDIRECT3DCUBETEXTURE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DCubeTexture8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DCubeTexture8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DCubeTexture8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DCubeTexture8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DCubeTexture8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DCubeTexture8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DCubeTexture8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DCubeTexture8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DCubeTexture8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DCubeTexture8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DCubeTexture8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DCubeTexture8_SetLOD(p,a) (p)->lpVtbl->SetLOD(p,a) +#define IDirect3DCubeTexture8_GetLOD(p) (p)->lpVtbl->GetLOD(p) +#define IDirect3DCubeTexture8_GetLevelCount(p) (p)->lpVtbl->GetLevelCount(p) +#define IDirect3DCubeTexture8_GetLevelDesc(p,a,b) (p)->lpVtbl->GetLevelDesc(p,a,b) +#define IDirect3DCubeTexture8_GetCubeMapSurface(p,a,b,c) (p)->lpVtbl->GetCubeMapSurface(p,a,b,c) +#define IDirect3DCubeTexture8_LockRect(p,a,b,c,d,e) (p)->lpVtbl->LockRect(p,a,b,c,d,e) +#define IDirect3DCubeTexture8_UnlockRect(p,a,b) (p)->lpVtbl->UnlockRect(p,a,b) +#define IDirect3DCubeTexture8_AddDirtyRect(p,a,b) (p)->lpVtbl->AddDirtyRect(p,a,b) +#else +#define IDirect3DCubeTexture8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DCubeTexture8_AddRef(p) (p)->AddRef() +#define IDirect3DCubeTexture8_Release(p) (p)->Release() +#define IDirect3DCubeTexture8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DCubeTexture8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DCubeTexture8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DCubeTexture8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DCubeTexture8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DCubeTexture8_GetPriority(p) (p)->GetPriority() +#define IDirect3DCubeTexture8_PreLoad(p) (p)->PreLoad() +#define IDirect3DCubeTexture8_GetType(p) (p)->GetType() +#define IDirect3DCubeTexture8_SetLOD(p,a) (p)->SetLOD(a) +#define IDirect3DCubeTexture8_GetLOD(p) (p)->GetLOD() +#define IDirect3DCubeTexture8_GetLevelCount(p) (p)->GetLevelCount() +#define IDirect3DCubeTexture8_GetLevelDesc(p,a,b) (p)->GetLevelDesc(a,b) +#define IDirect3DCubeTexture8_GetCubeMapSurface(p,a,b,c) (p)->GetCubeMapSurface(a,b,c) +#define IDirect3DCubeTexture8_LockRect(p,a,b,c,d,e) (p)->LockRect(a,b,c,d,e) +#define IDirect3DCubeTexture8_UnlockRect(p,a,b) (p)->UnlockRect(a,b) +#define IDirect3DCubeTexture8_AddDirtyRect(p,a,b) (p)->AddDirtyRect(a,b) +#endif + + + + +#undef INTERFACE +#define INTERFACE IDirect3DVertexBuffer8 + +DECLARE_INTERFACE_(IDirect3DVertexBuffer8, IDirect3DResource8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DResource8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD(Lock)(THIS_ UINT OffsetToLock,UINT SizeToLock,BYTE** ppbData,DWORD Flags) PURE; + STDMETHOD(Unlock)(THIS) PURE; + STDMETHOD(GetDesc)(THIS_ D3DVERTEXBUFFER_DESC *pDesc) PURE; +}; + +typedef struct IDirect3DVertexBuffer8 *LPDIRECT3DVERTEXBUFFER8, *PDIRECT3DVERTEXBUFFER8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DVertexBuffer8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DVertexBuffer8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DVertexBuffer8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DVertexBuffer8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DVertexBuffer8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DVertexBuffer8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DVertexBuffer8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DVertexBuffer8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DVertexBuffer8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DVertexBuffer8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DVertexBuffer8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DVertexBuffer8_Lock(p,a,b,c,d) (p)->lpVtbl->Lock(p,a,b,c,d) +#define IDirect3DVertexBuffer8_Unlock(p) (p)->lpVtbl->Unlock(p) +#define IDirect3DVertexBuffer8_GetDesc(p,a) (p)->lpVtbl->GetDesc(p,a) +#else +#define IDirect3DVertexBuffer8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DVertexBuffer8_AddRef(p) (p)->AddRef() +#define IDirect3DVertexBuffer8_Release(p) (p)->Release() +#define IDirect3DVertexBuffer8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DVertexBuffer8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DVertexBuffer8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DVertexBuffer8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DVertexBuffer8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DVertexBuffer8_GetPriority(p) (p)->GetPriority() +#define IDirect3DVertexBuffer8_PreLoad(p) (p)->PreLoad() +#define IDirect3DVertexBuffer8_GetType(p) (p)->GetType() +#define IDirect3DVertexBuffer8_Lock(p,a,b,c,d) (p)->Lock(a,b,c,d) +#define IDirect3DVertexBuffer8_Unlock(p) (p)->Unlock() +#define IDirect3DVertexBuffer8_GetDesc(p,a) (p)->GetDesc(a) +#endif + + + + +#undef INTERFACE +#define INTERFACE IDirect3DIndexBuffer8 + +DECLARE_INTERFACE_(IDirect3DIndexBuffer8, IDirect3DResource8) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DResource8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD_(DWORD, SetPriority)(THIS_ DWORD PriorityNew) PURE; + STDMETHOD_(DWORD, GetPriority)(THIS) PURE; + STDMETHOD_(void, PreLoad)(THIS) PURE; + STDMETHOD_(D3DRESOURCETYPE, GetType)(THIS) PURE; + STDMETHOD(Lock)(THIS_ UINT OffsetToLock,UINT SizeToLock,BYTE** ppbData,DWORD Flags) PURE; + STDMETHOD(Unlock)(THIS) PURE; + STDMETHOD(GetDesc)(THIS_ D3DINDEXBUFFER_DESC *pDesc) PURE; +}; + +typedef struct IDirect3DIndexBuffer8 *LPDIRECT3DINDEXBUFFER8, *PDIRECT3DINDEXBUFFER8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DIndexBuffer8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DIndexBuffer8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DIndexBuffer8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DIndexBuffer8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DIndexBuffer8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DIndexBuffer8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DIndexBuffer8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DIndexBuffer8_SetPriority(p,a) (p)->lpVtbl->SetPriority(p,a) +#define IDirect3DIndexBuffer8_GetPriority(p) (p)->lpVtbl->GetPriority(p) +#define IDirect3DIndexBuffer8_PreLoad(p) (p)->lpVtbl->PreLoad(p) +#define IDirect3DIndexBuffer8_GetType(p) (p)->lpVtbl->GetType(p) +#define IDirect3DIndexBuffer8_Lock(p,a,b,c,d) (p)->lpVtbl->Lock(p,a,b,c,d) +#define IDirect3DIndexBuffer8_Unlock(p) (p)->lpVtbl->Unlock(p) +#define IDirect3DIndexBuffer8_GetDesc(p,a) (p)->lpVtbl->GetDesc(p,a) +#else +#define IDirect3DIndexBuffer8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DIndexBuffer8_AddRef(p) (p)->AddRef() +#define IDirect3DIndexBuffer8_Release(p) (p)->Release() +#define IDirect3DIndexBuffer8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DIndexBuffer8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DIndexBuffer8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DIndexBuffer8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DIndexBuffer8_SetPriority(p,a) (p)->SetPriority(a) +#define IDirect3DIndexBuffer8_GetPriority(p) (p)->GetPriority() +#define IDirect3DIndexBuffer8_PreLoad(p) (p)->PreLoad() +#define IDirect3DIndexBuffer8_GetType(p) (p)->GetType() +#define IDirect3DIndexBuffer8_Lock(p,a,b,c,d) (p)->Lock(a,b,c,d) +#define IDirect3DIndexBuffer8_Unlock(p) (p)->Unlock() +#define IDirect3DIndexBuffer8_GetDesc(p,a) (p)->GetDesc(a) +#endif + + + + +#undef INTERFACE +#define INTERFACE IDirect3DSurface8 + +DECLARE_INTERFACE_(IDirect3DSurface8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DSurface8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD(GetContainer)(THIS_ REFIID riid,void** ppContainer) PURE; + STDMETHOD(GetDesc)(THIS_ D3DSURFACE_DESC *pDesc) PURE; + STDMETHOD(LockRect)(THIS_ D3DLOCKED_RECT* pLockedRect,CONST RECT* pRect,DWORD Flags) PURE; + STDMETHOD(UnlockRect)(THIS) PURE; +}; + +typedef struct IDirect3DSurface8 *LPDIRECT3DSURFACE8, *PDIRECT3DSURFACE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DSurface8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DSurface8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DSurface8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DSurface8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DSurface8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DSurface8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DSurface8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DSurface8_GetContainer(p,a,b) (p)->lpVtbl->GetContainer(p,a,b) +#define IDirect3DSurface8_GetDesc(p,a) (p)->lpVtbl->GetDesc(p,a) +#define IDirect3DSurface8_LockRect(p,a,b,c) (p)->lpVtbl->LockRect(p,a,b,c) +#define IDirect3DSurface8_UnlockRect(p) (p)->lpVtbl->UnlockRect(p) +#else +#define IDirect3DSurface8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DSurface8_AddRef(p) (p)->AddRef() +#define IDirect3DSurface8_Release(p) (p)->Release() +#define IDirect3DSurface8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DSurface8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DSurface8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DSurface8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DSurface8_GetContainer(p,a,b) (p)->GetContainer(a,b) +#define IDirect3DSurface8_GetDesc(p,a) (p)->GetDesc(a) +#define IDirect3DSurface8_LockRect(p,a,b,c) (p)->LockRect(a,b,c) +#define IDirect3DSurface8_UnlockRect(p) (p)->UnlockRect() +#endif + + + + +#undef INTERFACE +#define INTERFACE IDirect3DVolume8 + +DECLARE_INTERFACE_(IDirect3DVolume8, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, void** ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirect3DVolume8 methods ***/ + STDMETHOD(GetDevice)(THIS_ IDirect3DDevice8** ppDevice) PURE; + STDMETHOD(SetPrivateData)(THIS_ REFGUID refguid,CONST void* pData,DWORD SizeOfData,DWORD Flags) PURE; + STDMETHOD(GetPrivateData)(THIS_ REFGUID refguid,void* pData,DWORD* pSizeOfData) PURE; + STDMETHOD(FreePrivateData)(THIS_ REFGUID refguid) PURE; + STDMETHOD(GetContainer)(THIS_ REFIID riid,void** ppContainer) PURE; + STDMETHOD(GetDesc)(THIS_ D3DVOLUME_DESC *pDesc) PURE; + STDMETHOD(LockBox)(THIS_ D3DLOCKED_BOX * pLockedVolume,CONST D3DBOX* pBox,DWORD Flags) PURE; + STDMETHOD(UnlockBox)(THIS) PURE; +}; + +typedef struct IDirect3DVolume8 *LPDIRECT3DVOLUME8, *PDIRECT3DVOLUME8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirect3DVolume8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirect3DVolume8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirect3DVolume8_Release(p) (p)->lpVtbl->Release(p) +#define IDirect3DVolume8_GetDevice(p,a) (p)->lpVtbl->GetDevice(p,a) +#define IDirect3DVolume8_SetPrivateData(p,a,b,c,d) (p)->lpVtbl->SetPrivateData(p,a,b,c,d) +#define IDirect3DVolume8_GetPrivateData(p,a,b,c) (p)->lpVtbl->GetPrivateData(p,a,b,c) +#define IDirect3DVolume8_FreePrivateData(p,a) (p)->lpVtbl->FreePrivateData(p,a) +#define IDirect3DVolume8_GetContainer(p,a,b) (p)->lpVtbl->GetContainer(p,a,b) +#define IDirect3DVolume8_GetDesc(p,a) (p)->lpVtbl->GetDesc(p,a) +#define IDirect3DVolume8_LockBox(p,a,b,c) (p)->lpVtbl->LockBox(p,a,b,c) +#define IDirect3DVolume8_UnlockBox(p) (p)->lpVtbl->UnlockBox(p) +#else +#define IDirect3DVolume8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirect3DVolume8_AddRef(p) (p)->AddRef() +#define IDirect3DVolume8_Release(p) (p)->Release() +#define IDirect3DVolume8_GetDevice(p,a) (p)->GetDevice(a) +#define IDirect3DVolume8_SetPrivateData(p,a,b,c,d) (p)->SetPrivateData(a,b,c,d) +#define IDirect3DVolume8_GetPrivateData(p,a,b,c) (p)->GetPrivateData(a,b,c) +#define IDirect3DVolume8_FreePrivateData(p,a) (p)->FreePrivateData(a) +#define IDirect3DVolume8_GetContainer(p,a,b) (p)->GetContainer(a,b) +#define IDirect3DVolume8_GetDesc(p,a) (p)->GetDesc(a) +#define IDirect3DVolume8_LockBox(p,a,b,c) (p)->LockBox(a,b,c) +#define IDirect3DVolume8_UnlockBox(p) (p)->UnlockBox() +#endif + +/**************************************************************************** + * Flags for SetPrivateData method on all D3D8 interfaces + * + * The passed pointer is an IUnknown ptr. The SizeOfData argument to SetPrivateData + * must be set to sizeof(IUnknown*). Direct3D will call AddRef through this + * pointer and Release when the private data is destroyed. The data will be + * destroyed when another SetPrivateData with the same GUID is set, when + * FreePrivateData is called, or when the D3D8 object is freed. + ****************************************************************************/ +#define D3DSPD_IUNKNOWN 0x00000001L + +/**************************************************************************** + * + * Parameter for IDirect3D8 Enum and GetCaps8 functions to get the info for + * the current mode only. + * + ****************************************************************************/ + +#define D3DCURRENT_DISPLAY_MODE 0x00EFFFFFL + +/**************************************************************************** + * + * Flags for IDirect3D8::CreateDevice's BehaviorFlags + * + ****************************************************************************/ + +#define D3DCREATE_FPU_PRESERVE 0x00000002L +#define D3DCREATE_MULTITHREADED 0x00000004L + +#define D3DCREATE_PUREDEVICE 0x00000010L +#define D3DCREATE_SOFTWARE_VERTEXPROCESSING 0x00000020L +#define D3DCREATE_HARDWARE_VERTEXPROCESSING 0x00000040L +#define D3DCREATE_MIXED_VERTEXPROCESSING 0x00000080L + +#define D3DCREATE_DISABLE_DRIVER_MANAGEMENT 0x00000100L + + +/**************************************************************************** + * + * Parameter for IDirect3D8::CreateDevice's iAdapter + * + ****************************************************************************/ + +#define D3DADAPTER_DEFAULT 0 + +/**************************************************************************** + * + * Flags for IDirect3D8::EnumAdapters + * + ****************************************************************************/ + +#define D3DENUM_NO_WHQL_LEVEL 0x00000002L + +/**************************************************************************** + * + * Maximum number of back-buffers supported in DX8 + * + ****************************************************************************/ + +#define D3DPRESENT_BACK_BUFFERS_MAX 3L + +/**************************************************************************** + * + * Flags for IDirect3DDevice8::SetGammaRamp + * + ****************************************************************************/ + +#define D3DSGR_NO_CALIBRATION 0x00000000L +#define D3DSGR_CALIBRATE 0x00000001L + +/**************************************************************************** + * + * Flags for IDirect3DDevice8::SetCursorPosition + * + ****************************************************************************/ + +#define D3DCURSOR_IMMEDIATE_UPDATE 0x00000001L + +/**************************************************************************** + * + * Flags for DrawPrimitive/DrawIndexedPrimitive + * Also valid for Begin/BeginIndexed + * Also valid for VertexBuffer::CreateVertexBuffer + ****************************************************************************/ + + +/* + * DirectDraw error codes + */ +#define _FACD3D 0x876 +#define MAKE_D3DHRESULT( code ) MAKE_HRESULT( 1, _FACD3D, code ) + +/* + * Direct3D Errors + */ +#define D3D_OK S_OK + +#define D3DERR_WRONGTEXTUREFORMAT MAKE_D3DHRESULT(2072) +#define D3DERR_UNSUPPORTEDCOLOROPERATION MAKE_D3DHRESULT(2073) +#define D3DERR_UNSUPPORTEDCOLORARG MAKE_D3DHRESULT(2074) +#define D3DERR_UNSUPPORTEDALPHAOPERATION MAKE_D3DHRESULT(2075) +#define D3DERR_UNSUPPORTEDALPHAARG MAKE_D3DHRESULT(2076) +#define D3DERR_TOOMANYOPERATIONS MAKE_D3DHRESULT(2077) +#define D3DERR_CONFLICTINGTEXTUREFILTER MAKE_D3DHRESULT(2078) +#define D3DERR_UNSUPPORTEDFACTORVALUE MAKE_D3DHRESULT(2079) +#define D3DERR_CONFLICTINGRENDERSTATE MAKE_D3DHRESULT(2081) +#define D3DERR_UNSUPPORTEDTEXTUREFILTER MAKE_D3DHRESULT(2082) +#define D3DERR_CONFLICTINGTEXTUREPALETTE MAKE_D3DHRESULT(2086) +#define D3DERR_DRIVERINTERNALERROR MAKE_D3DHRESULT(2087) + +#define D3DERR_NOTFOUND MAKE_D3DHRESULT(2150) +#define D3DERR_MOREDATA MAKE_D3DHRESULT(2151) +#define D3DERR_DEVICELOST MAKE_D3DHRESULT(2152) +#define D3DERR_DEVICENOTRESET MAKE_D3DHRESULT(2153) +#define D3DERR_NOTAVAILABLE MAKE_D3DHRESULT(2154) +#define D3DERR_OUTOFVIDEOMEMORY MAKE_D3DHRESULT(380) +#define D3DERR_INVALIDDEVICE MAKE_D3DHRESULT(2155) +#define D3DERR_INVALIDCALL MAKE_D3DHRESULT(2156) +#define D3DERR_DRIVERINVALIDCALL MAKE_D3DHRESULT(2157) + +#ifdef __cplusplus +}; +#endif + +#endif /* (DIRECT3D_VERSION >= 0x0800) */ +#endif /* _D3D_H_ */ + diff --git a/plugins/ADK/d3d8/includes/d3d8caps.h b/plugins/ADK/d3d8/includes/d3d8caps.h new file mode 100644 index 0000000..6af8e6c --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3d8caps.h @@ -0,0 +1,364 @@ +/*==========================================================================; + * + * Copyright (C) Microsoft Corporation. All Rights Reserved. + * + * File: d3d8caps.h + * Content: Direct3D capabilities include file + * + ***************************************************************************/ + +#ifndef _D3D8CAPS_H +#define _D3D8CAPS_H + +#ifndef DIRECT3D_VERSION +#define DIRECT3D_VERSION 0x0800 +#endif //DIRECT3D_VERSION + +// include this file content only if compiling for DX8 interfaces +#if(DIRECT3D_VERSION >= 0x0800) + +#if defined(_X86_) || defined(_IA64_) +#pragma pack(4) +#endif + +typedef struct _D3DCAPS8 +{ + /* Device Info */ + D3DDEVTYPE DeviceType; + UINT AdapterOrdinal; + + /* Caps from DX7 Draw */ + DWORD Caps; + DWORD Caps2; + DWORD Caps3; + DWORD PresentationIntervals; + + /* Cursor Caps */ + DWORD CursorCaps; + + /* 3D Device Caps */ + DWORD DevCaps; + + DWORD PrimitiveMiscCaps; + DWORD RasterCaps; + DWORD ZCmpCaps; + DWORD SrcBlendCaps; + DWORD DestBlendCaps; + DWORD AlphaCmpCaps; + DWORD ShadeCaps; + DWORD TextureCaps; + DWORD TextureFilterCaps; // D3DPTFILTERCAPS for IDirect3DTexture8's + DWORD CubeTextureFilterCaps; // D3DPTFILTERCAPS for IDirect3DCubeTexture8's + DWORD VolumeTextureFilterCaps; // D3DPTFILTERCAPS for IDirect3DVolumeTexture8's + DWORD TextureAddressCaps; // D3DPTADDRESSCAPS for IDirect3DTexture8's + DWORD VolumeTextureAddressCaps; // D3DPTADDRESSCAPS for IDirect3DVolumeTexture8's + + DWORD LineCaps; // D3DLINECAPS + + DWORD MaxTextureWidth, MaxTextureHeight; + DWORD MaxVolumeExtent; + + DWORD MaxTextureRepeat; + DWORD MaxTextureAspectRatio; + DWORD MaxAnisotropy; + float MaxVertexW; + + float GuardBandLeft; + float GuardBandTop; + float GuardBandRight; + float GuardBandBottom; + + float ExtentsAdjust; + DWORD StencilCaps; + + DWORD FVFCaps; + DWORD TextureOpCaps; + DWORD MaxTextureBlendStages; + DWORD MaxSimultaneousTextures; + + DWORD VertexProcessingCaps; + DWORD MaxActiveLights; + DWORD MaxUserClipPlanes; + DWORD MaxVertexBlendMatrices; + DWORD MaxVertexBlendMatrixIndex; + + float MaxPointSize; + + DWORD MaxPrimitiveCount; // max number of primitives per DrawPrimitive call + DWORD MaxVertexIndex; + DWORD MaxStreams; + DWORD MaxStreamStride; // max stride for SetStreamSource + + DWORD VertexShaderVersion; + DWORD MaxVertexShaderConst; // number of vertex shader constant registers + + DWORD PixelShaderVersion; + float MaxPixelShaderValue; // max value of pixel shader arithmetic component + +} D3DCAPS8; + +// +// BIT DEFINES FOR D3DCAPS8 DWORD MEMBERS +// + +// +// Caps +// +#define D3DCAPS_READ_SCANLINE 0x00020000L + +// +// Caps2 +// +#define D3DCAPS2_NO2DDURING3DSCENE 0x00000002L +#define D3DCAPS2_FULLSCREENGAMMA 0x00020000L +#define D3DCAPS2_CANRENDERWINDOWED 0x00080000L +#define D3DCAPS2_CANCALIBRATEGAMMA 0x00100000L +#define D3DCAPS2_RESERVED 0x02000000L +#define D3DCAPS2_CANMANAGERESOURCE 0x10000000L +#define D3DCAPS2_DYNAMICTEXTURES 0x20000000L + +// +// Caps3 +// +#define D3DCAPS3_RESERVED 0x8000001fL + +// Indicates that the device can respect the ALPHABLENDENABLE render state +// when fullscreen while using the FLIP or DISCARD swap effect. +// COPY and COPYVSYNC swap effects work whether or not this flag is set. +#define D3DCAPS3_ALPHA_FULLSCREEN_FLIP_OR_DISCARD 0x00000020L + +// +// PresentationIntervals +// +#define D3DPRESENT_INTERVAL_DEFAULT 0x00000000L +#define D3DPRESENT_INTERVAL_ONE 0x00000001L +#define D3DPRESENT_INTERVAL_TWO 0x00000002L +#define D3DPRESENT_INTERVAL_THREE 0x00000004L +#define D3DPRESENT_INTERVAL_FOUR 0x00000008L +#define D3DPRESENT_INTERVAL_IMMEDIATE 0x80000000L + +// +// CursorCaps +// +// Driver supports HW color cursor in at least hi-res modes(height >=400) +#define D3DCURSORCAPS_COLOR 0x00000001L +// Driver supports HW cursor also in low-res modes(height < 400) +#define D3DCURSORCAPS_LOWRES 0x00000002L + +// +// DevCaps +// +#define D3DDEVCAPS_EXECUTESYSTEMMEMORY 0x00000010L /* Device can use execute buffers from system memory */ +#define D3DDEVCAPS_EXECUTEVIDEOMEMORY 0x00000020L /* Device can use execute buffers from video memory */ +#define D3DDEVCAPS_TLVERTEXSYSTEMMEMORY 0x00000040L /* Device can use TL buffers from system memory */ +#define D3DDEVCAPS_TLVERTEXVIDEOMEMORY 0x00000080L /* Device can use TL buffers from video memory */ +#define D3DDEVCAPS_TEXTURESYSTEMMEMORY 0x00000100L /* Device can texture from system memory */ +#define D3DDEVCAPS_TEXTUREVIDEOMEMORY 0x00000200L /* Device can texture from device memory */ +#define D3DDEVCAPS_DRAWPRIMTLVERTEX 0x00000400L /* Device can draw TLVERTEX primitives */ +#define D3DDEVCAPS_CANRENDERAFTERFLIP 0x00000800L /* Device can render without waiting for flip to complete */ +#define D3DDEVCAPS_TEXTURENONLOCALVIDMEM 0x00001000L /* Device can texture from nonlocal video memory */ +#define D3DDEVCAPS_DRAWPRIMITIVES2 0x00002000L /* Device can support DrawPrimitives2 */ +#define D3DDEVCAPS_SEPARATETEXTUREMEMORIES 0x00004000L /* Device is texturing from separate memory pools */ +#define D3DDEVCAPS_DRAWPRIMITIVES2EX 0x00008000L /* Device can support Extended DrawPrimitives2 i.e. DX7 compliant driver*/ +#define D3DDEVCAPS_HWTRANSFORMANDLIGHT 0x00010000L /* Device can support transformation and lighting in hardware and DRAWPRIMITIVES2EX must be also */ +#define D3DDEVCAPS_CANBLTSYSTONONLOCAL 0x00020000L /* Device supports a Tex Blt from system memory to non-local vidmem */ +#define D3DDEVCAPS_HWRASTERIZATION 0x00080000L /* Device has HW acceleration for rasterization */ +#define D3DDEVCAPS_PUREDEVICE 0x00100000L /* Device supports D3DCREATE_PUREDEVICE */ +#define D3DDEVCAPS_QUINTICRTPATCHES 0x00200000L /* Device supports quintic Beziers and BSplines */ +#define D3DDEVCAPS_RTPATCHES 0x00400000L /* Device supports Rect and Tri patches */ +#define D3DDEVCAPS_RTPATCHHANDLEZERO 0x00800000L /* Indicates that RT Patches may be drawn efficiently using handle 0 */ +#define D3DDEVCAPS_NPATCHES 0x01000000L /* Device supports N-Patches */ + +// +// PrimitiveMiscCaps +// +#define D3DPMISCCAPS_MASKZ 0x00000002L +#define D3DPMISCCAPS_LINEPATTERNREP 0x00000004L +#define D3DPMISCCAPS_CULLNONE 0x00000010L +#define D3DPMISCCAPS_CULLCW 0x00000020L +#define D3DPMISCCAPS_CULLCCW 0x00000040L +#define D3DPMISCCAPS_COLORWRITEENABLE 0x00000080L +#define D3DPMISCCAPS_CLIPPLANESCALEDPOINTS 0x00000100L /* Device correctly clips scaled points to clip planes */ +#define D3DPMISCCAPS_CLIPTLVERTS 0x00000200L /* device will clip post-transformed vertex primitives */ +#define D3DPMISCCAPS_TSSARGTEMP 0x00000400L /* device supports D3DTA_TEMP for temporary register */ +#define D3DPMISCCAPS_BLENDOP 0x00000800L /* device supports D3DRS_BLENDOP */ +#define D3DPMISCCAPS_NULLREFERENCE 0x00001000L /* Reference Device that doesnt render */ + +// +// LineCaps +// +#define D3DLINECAPS_TEXTURE 0x00000001L +#define D3DLINECAPS_ZTEST 0x00000002L +#define D3DLINECAPS_BLEND 0x00000004L +#define D3DLINECAPS_ALPHACMP 0x00000008L +#define D3DLINECAPS_FOG 0x00000010L + +// +// RasterCaps +// +#define D3DPRASTERCAPS_DITHER 0x00000001L +#define D3DPRASTERCAPS_PAT 0x00000008L +#define D3DPRASTERCAPS_ZTEST 0x00000010L +#define D3DPRASTERCAPS_FOGVERTEX 0x00000080L +#define D3DPRASTERCAPS_FOGTABLE 0x00000100L +#define D3DPRASTERCAPS_ANTIALIASEDGES 0x00001000L +#define D3DPRASTERCAPS_MIPMAPLODBIAS 0x00002000L +#define D3DPRASTERCAPS_ZBIAS 0x00004000L +#define D3DPRASTERCAPS_ZBUFFERLESSHSR 0x00008000L +#define D3DPRASTERCAPS_FOGRANGE 0x00010000L +#define D3DPRASTERCAPS_ANISOTROPY 0x00020000L +#define D3DPRASTERCAPS_WBUFFER 0x00040000L +#define D3DPRASTERCAPS_WFOG 0x00100000L +#define D3DPRASTERCAPS_ZFOG 0x00200000L +#define D3DPRASTERCAPS_COLORPERSPECTIVE 0x00400000L /* Device iterates colors perspective correct */ +#define D3DPRASTERCAPS_STRETCHBLTMULTISAMPLE 0x00800000L + +// +// ZCmpCaps, AlphaCmpCaps +// +#define D3DPCMPCAPS_NEVER 0x00000001L +#define D3DPCMPCAPS_LESS 0x00000002L +#define D3DPCMPCAPS_EQUAL 0x00000004L +#define D3DPCMPCAPS_LESSEQUAL 0x00000008L +#define D3DPCMPCAPS_GREATER 0x00000010L +#define D3DPCMPCAPS_NOTEQUAL 0x00000020L +#define D3DPCMPCAPS_GREATEREQUAL 0x00000040L +#define D3DPCMPCAPS_ALWAYS 0x00000080L + +// +// SourceBlendCaps, DestBlendCaps +// +#define D3DPBLENDCAPS_ZERO 0x00000001L +#define D3DPBLENDCAPS_ONE 0x00000002L +#define D3DPBLENDCAPS_SRCCOLOR 0x00000004L +#define D3DPBLENDCAPS_INVSRCCOLOR 0x00000008L +#define D3DPBLENDCAPS_SRCALPHA 0x00000010L +#define D3DPBLENDCAPS_INVSRCALPHA 0x00000020L +#define D3DPBLENDCAPS_DESTALPHA 0x00000040L +#define D3DPBLENDCAPS_INVDESTALPHA 0x00000080L +#define D3DPBLENDCAPS_DESTCOLOR 0x00000100L +#define D3DPBLENDCAPS_INVDESTCOLOR 0x00000200L +#define D3DPBLENDCAPS_SRCALPHASAT 0x00000400L +#define D3DPBLENDCAPS_BOTHSRCALPHA 0x00000800L +#define D3DPBLENDCAPS_BOTHINVSRCALPHA 0x00001000L + +// +// ShadeCaps +// +#define D3DPSHADECAPS_COLORGOURAUDRGB 0x00000008L +#define D3DPSHADECAPS_SPECULARGOURAUDRGB 0x00000200L +#define D3DPSHADECAPS_ALPHAGOURAUDBLEND 0x00004000L +#define D3DPSHADECAPS_FOGGOURAUD 0x00080000L + +// +// TextureCaps +// +#define D3DPTEXTURECAPS_PERSPECTIVE 0x00000001L /* Perspective-correct texturing is supported */ +#define D3DPTEXTURECAPS_POW2 0x00000002L /* Power-of-2 texture dimensions are required - applies to non-Cube/Volume textures only. */ +#define D3DPTEXTURECAPS_ALPHA 0x00000004L /* Alpha in texture pixels is supported */ +#define D3DPTEXTURECAPS_SQUAREONLY 0x00000020L /* Only square textures are supported */ +#define D3DPTEXTURECAPS_TEXREPEATNOTSCALEDBYSIZE 0x00000040L /* Texture indices are not scaled by the texture size prior to interpolation */ +#define D3DPTEXTURECAPS_ALPHAPALETTE 0x00000080L /* Device can draw alpha from texture palettes */ +// Device can use non-POW2 textures if: +// 1) D3DTEXTURE_ADDRESS is set to CLAMP for this texture's stage +// 2) D3DRS_WRAP(N) is zero for this texture's coordinates +// 3) mip mapping is not enabled (use magnification filter only) +#define D3DPTEXTURECAPS_NONPOW2CONDITIONAL 0x00000100L +#define D3DPTEXTURECAPS_PROJECTED 0x00000400L /* Device can do D3DTTFF_PROJECTED */ +#define D3DPTEXTURECAPS_CUBEMAP 0x00000800L /* Device can do cubemap textures */ +#define D3DPTEXTURECAPS_VOLUMEMAP 0x00002000L /* Device can do volume textures */ +#define D3DPTEXTURECAPS_MIPMAP 0x00004000L /* Device can do mipmapped textures */ +#define D3DPTEXTURECAPS_MIPVOLUMEMAP 0x00008000L /* Device can do mipmapped volume textures */ +#define D3DPTEXTURECAPS_MIPCUBEMAP 0x00010000L /* Device can do mipmapped cube maps */ +#define D3DPTEXTURECAPS_CUBEMAP_POW2 0x00020000L /* Device requires that cubemaps be power-of-2 dimension */ +#define D3DPTEXTURECAPS_VOLUMEMAP_POW2 0x00040000L /* Device requires that volume maps be power-of-2 dimension */ + +// +// TextureFilterCaps +// +#define D3DPTFILTERCAPS_MINFPOINT 0x00000100L /* Min Filter */ +#define D3DPTFILTERCAPS_MINFLINEAR 0x00000200L +#define D3DPTFILTERCAPS_MINFANISOTROPIC 0x00000400L +#define D3DPTFILTERCAPS_MIPFPOINT 0x00010000L /* Mip Filter */ +#define D3DPTFILTERCAPS_MIPFLINEAR 0x00020000L +#define D3DPTFILTERCAPS_MAGFPOINT 0x01000000L /* Mag Filter */ +#define D3DPTFILTERCAPS_MAGFLINEAR 0x02000000L +#define D3DPTFILTERCAPS_MAGFANISOTROPIC 0x04000000L +#define D3DPTFILTERCAPS_MAGFAFLATCUBIC 0x08000000L +#define D3DPTFILTERCAPS_MAGFGAUSSIANCUBIC 0x10000000L + +// +// TextureAddressCaps +// +#define D3DPTADDRESSCAPS_WRAP 0x00000001L +#define D3DPTADDRESSCAPS_MIRROR 0x00000002L +#define D3DPTADDRESSCAPS_CLAMP 0x00000004L +#define D3DPTADDRESSCAPS_BORDER 0x00000008L +#define D3DPTADDRESSCAPS_INDEPENDENTUV 0x00000010L +#define D3DPTADDRESSCAPS_MIRRORONCE 0x00000020L + +// +// StencilCaps +// +#define D3DSTENCILCAPS_KEEP 0x00000001L +#define D3DSTENCILCAPS_ZERO 0x00000002L +#define D3DSTENCILCAPS_REPLACE 0x00000004L +#define D3DSTENCILCAPS_INCRSAT 0x00000008L +#define D3DSTENCILCAPS_DECRSAT 0x00000010L +#define D3DSTENCILCAPS_INVERT 0x00000020L +#define D3DSTENCILCAPS_INCR 0x00000040L +#define D3DSTENCILCAPS_DECR 0x00000080L + +// +// TextureOpCaps +// +#define D3DTEXOPCAPS_DISABLE 0x00000001L +#define D3DTEXOPCAPS_SELECTARG1 0x00000002L +#define D3DTEXOPCAPS_SELECTARG2 0x00000004L +#define D3DTEXOPCAPS_MODULATE 0x00000008L +#define D3DTEXOPCAPS_MODULATE2X 0x00000010L +#define D3DTEXOPCAPS_MODULATE4X 0x00000020L +#define D3DTEXOPCAPS_ADD 0x00000040L +#define D3DTEXOPCAPS_ADDSIGNED 0x00000080L +#define D3DTEXOPCAPS_ADDSIGNED2X 0x00000100L +#define D3DTEXOPCAPS_SUBTRACT 0x00000200L +#define D3DTEXOPCAPS_ADDSMOOTH 0x00000400L +#define D3DTEXOPCAPS_BLENDDIFFUSEALPHA 0x00000800L +#define D3DTEXOPCAPS_BLENDTEXTUREALPHA 0x00001000L +#define D3DTEXOPCAPS_BLENDFACTORALPHA 0x00002000L +#define D3DTEXOPCAPS_BLENDTEXTUREALPHAPM 0x00004000L +#define D3DTEXOPCAPS_BLENDCURRENTALPHA 0x00008000L +#define D3DTEXOPCAPS_PREMODULATE 0x00010000L +#define D3DTEXOPCAPS_MODULATEALPHA_ADDCOLOR 0x00020000L +#define D3DTEXOPCAPS_MODULATECOLOR_ADDALPHA 0x00040000L +#define D3DTEXOPCAPS_MODULATEINVALPHA_ADDCOLOR 0x00080000L +#define D3DTEXOPCAPS_MODULATEINVCOLOR_ADDALPHA 0x00100000L +#define D3DTEXOPCAPS_BUMPENVMAP 0x00200000L +#define D3DTEXOPCAPS_BUMPENVMAPLUMINANCE 0x00400000L +#define D3DTEXOPCAPS_DOTPRODUCT3 0x00800000L +#define D3DTEXOPCAPS_MULTIPLYADD 0x01000000L +#define D3DTEXOPCAPS_LERP 0x02000000L + +// +// FVFCaps +// +#define D3DFVFCAPS_TEXCOORDCOUNTMASK 0x0000ffffL /* mask for texture coordinate count field */ +#define D3DFVFCAPS_DONOTSTRIPELEMENTS 0x00080000L /* Device prefers that vertex elements not be stripped */ +#define D3DFVFCAPS_PSIZE 0x00100000L /* Device can receive point size */ + +// +// VertexProcessingCaps +// +#define D3DVTXPCAPS_TEXGEN 0x00000001L /* device can do texgen */ +#define D3DVTXPCAPS_MATERIALSOURCE7 0x00000002L /* device can do DX7-level colormaterialsource ops */ +#define D3DVTXPCAPS_DIRECTIONALLIGHTS 0x00000008L /* device can do directional lights */ +#define D3DVTXPCAPS_POSITIONALLIGHTS 0x00000010L /* device can do positional lights (includes point and spot) */ +#define D3DVTXPCAPS_LOCALVIEWER 0x00000020L /* device can do local viewer */ +#define D3DVTXPCAPS_TWEENING 0x00000040L /* device can do vertex tweening */ +#define D3DVTXPCAPS_NO_VSDT_UBYTE4 0x00000080L /* device does not support D3DVSDT_UBYTE4 */ + +#pragma pack() + +#endif /* (DIRECT3D_VERSION >= 0x0800) */ +#endif /* _D3D8CAPS_H_ */ + diff --git a/plugins/ADK/d3d8/includes/d3d8types.h b/plugins/ADK/d3d8/includes/d3d8types.h new file mode 100644 index 0000000..5d622af --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3d8types.h @@ -0,0 +1,1684 @@ +/*==========================================================================; + * + * Copyright (C) Microsoft Corporation. All Rights Reserved. + * + * File: d3d8types.h + * Content: Direct3D capabilities include file + * + ***************************************************************************/ + +#ifndef _D3D8TYPES_H_ +#define _D3D8TYPES_H_ + +#ifndef DIRECT3D_VERSION +#define DIRECT3D_VERSION 0x0800 +#endif //DIRECT3D_VERSION + +// include this file content only if compiling for DX8 interfaces +#if(DIRECT3D_VERSION >= 0x0800) + +#include + +#if _MSC_VER >= 1200 +#pragma warning(push) +#endif +#pragma warning(disable:4201) // anonymous unions warning +#if defined(_X86_) || defined(_IA64_) +#pragma pack(4) +#endif + +// D3DCOLOR is equivalent to D3DFMT_A8R8G8B8 +#ifndef D3DCOLOR_DEFINED +typedef DWORD D3DCOLOR; +#define D3DCOLOR_DEFINED +#endif + +// maps unsigned 8 bits/channel to D3DCOLOR +#define D3DCOLOR_ARGB(a,r,g,b) \ + ((D3DCOLOR)((((a)&0xff)<<24)|(((r)&0xff)<<16)|(((g)&0xff)<<8)|((b)&0xff))) +#define D3DCOLOR_RGBA(r,g,b,a) D3DCOLOR_ARGB(a,r,g,b) +#define D3DCOLOR_XRGB(r,g,b) D3DCOLOR_ARGB(0xff,r,g,b) + +// maps floating point channels (0.f to 1.f range) to D3DCOLOR +#define D3DCOLOR_COLORVALUE(r,g,b,a) \ + D3DCOLOR_RGBA((DWORD)((r)*255.f),(DWORD)((g)*255.f),(DWORD)((b)*255.f),(DWORD)((a)*255.f)) + + +#ifndef D3DVECTOR_DEFINED +typedef struct _D3DVECTOR { + float x; + float y; + float z; +} D3DVECTOR; +#define D3DVECTOR_DEFINED +#endif + +#ifndef D3DCOLORVALUE_DEFINED +typedef struct _D3DCOLORVALUE { + float r; + float g; + float b; + float a; +} D3DCOLORVALUE; +#define D3DCOLORVALUE_DEFINED +#endif + +#ifndef D3DRECT_DEFINED +typedef struct _D3DRECT { + LONG x1; + LONG y1; + LONG x2; + LONG y2; +} D3DRECT; +#define D3DRECT_DEFINED +#endif + +#ifndef D3DMATRIX_DEFINED +typedef struct _D3DMATRIX { + union { + struct { + float _11, _12, _13, _14; + float _21, _22, _23, _24; + float _31, _32, _33, _34; + float _41, _42, _43, _44; + + }; + float m[4][4]; + }; +} D3DMATRIX; +#define D3DMATRIX_DEFINED +#endif + +typedef struct _D3DVIEWPORT8 { + DWORD X; + DWORD Y; /* Viewport Top left */ + DWORD Width; + DWORD Height; /* Viewport Dimensions */ + float MinZ; /* Min/max of clip Volume */ + float MaxZ; +} D3DVIEWPORT8; + +/* + * Values for clip fields. + */ + +// Max number of user clipping planes, supported in D3D. +#define D3DMAXUSERCLIPPLANES 32 + +// These bits could be ORed together to use with D3DRS_CLIPPLANEENABLE +// +#define D3DCLIPPLANE0 (1 << 0) +#define D3DCLIPPLANE1 (1 << 1) +#define D3DCLIPPLANE2 (1 << 2) +#define D3DCLIPPLANE3 (1 << 3) +#define D3DCLIPPLANE4 (1 << 4) +#define D3DCLIPPLANE5 (1 << 5) + +// The following bits are used in the ClipUnion and ClipIntersection +// members of the D3DCLIPSTATUS8 +// + +#define D3DCS_LEFT 0x00000001L +#define D3DCS_RIGHT 0x00000002L +#define D3DCS_TOP 0x00000004L +#define D3DCS_BOTTOM 0x00000008L +#define D3DCS_FRONT 0x00000010L +#define D3DCS_BACK 0x00000020L +#define D3DCS_PLANE0 0x00000040L +#define D3DCS_PLANE1 0x00000080L +#define D3DCS_PLANE2 0x00000100L +#define D3DCS_PLANE3 0x00000200L +#define D3DCS_PLANE4 0x00000400L +#define D3DCS_PLANE5 0x00000800L + +#define D3DCS_ALL (D3DCS_LEFT | \ + D3DCS_RIGHT | \ + D3DCS_TOP | \ + D3DCS_BOTTOM | \ + D3DCS_FRONT | \ + D3DCS_BACK | \ + D3DCS_PLANE0 | \ + D3DCS_PLANE1 | \ + D3DCS_PLANE2 | \ + D3DCS_PLANE3 | \ + D3DCS_PLANE4 | \ + D3DCS_PLANE5) + +typedef struct _D3DCLIPSTATUS8 { + DWORD ClipUnion; + DWORD ClipIntersection; +} D3DCLIPSTATUS8; + +typedef struct _D3DMATERIAL8 { + D3DCOLORVALUE Diffuse; /* Diffuse color RGBA */ + D3DCOLORVALUE Ambient; /* Ambient color RGB */ + D3DCOLORVALUE Specular; /* Specular 'shininess' */ + D3DCOLORVALUE Emissive; /* Emissive color RGB */ + float Power; /* Sharpness if specular highlight */ +} D3DMATERIAL8; + +typedef enum _D3DLIGHTTYPE { + D3DLIGHT_POINT = 1, + D3DLIGHT_SPOT = 2, + D3DLIGHT_DIRECTIONAL = 3, + D3DLIGHT_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DLIGHTTYPE; + +typedef struct _D3DLIGHT8 { + D3DLIGHTTYPE Type; /* Type of light source */ + D3DCOLORVALUE Diffuse; /* Diffuse color of light */ + D3DCOLORVALUE Specular; /* Specular color of light */ + D3DCOLORVALUE Ambient; /* Ambient color of light */ + D3DVECTOR Position; /* Position in world space */ + D3DVECTOR Direction; /* Direction in world space */ + float Range; /* Cutoff range */ + float Falloff; /* Falloff */ + float Attenuation0; /* Constant attenuation */ + float Attenuation1; /* Linear attenuation */ + float Attenuation2; /* Quadratic attenuation */ + float Theta; /* Inner angle of spotlight cone */ + float Phi; /* Outer angle of spotlight cone */ +} D3DLIGHT8; + +/* + * Options for clearing + */ +#define D3DCLEAR_TARGET 0x00000001l /* Clear target surface */ +#define D3DCLEAR_ZBUFFER 0x00000002l /* Clear target z buffer */ +#define D3DCLEAR_STENCIL 0x00000004l /* Clear stencil planes */ + +/* + * The following defines the rendering states + */ + +typedef enum _D3DSHADEMODE { + D3DSHADE_FLAT = 1, + D3DSHADE_GOURAUD = 2, + D3DSHADE_PHONG = 3, + D3DSHADE_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DSHADEMODE; + +typedef enum _D3DFILLMODE { + D3DFILL_POINT = 1, + D3DFILL_WIREFRAME = 2, + D3DFILL_SOLID = 3, + D3DFILL_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DFILLMODE; + +typedef struct _D3DLINEPATTERN { + WORD wRepeatFactor; + WORD wLinePattern; +} D3DLINEPATTERN; + +typedef enum _D3DBLEND { + D3DBLEND_ZERO = 1, + D3DBLEND_ONE = 2, + D3DBLEND_SRCCOLOR = 3, + D3DBLEND_INVSRCCOLOR = 4, + D3DBLEND_SRCALPHA = 5, + D3DBLEND_INVSRCALPHA = 6, + D3DBLEND_DESTALPHA = 7, + D3DBLEND_INVDESTALPHA = 8, + D3DBLEND_DESTCOLOR = 9, + D3DBLEND_INVDESTCOLOR = 10, + D3DBLEND_SRCALPHASAT = 11, + D3DBLEND_BOTHSRCALPHA = 12, + D3DBLEND_BOTHINVSRCALPHA = 13, + D3DBLEND_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DBLEND; + +typedef enum _D3DBLENDOP { + D3DBLENDOP_ADD = 1, + D3DBLENDOP_SUBTRACT = 2, + D3DBLENDOP_REVSUBTRACT = 3, + D3DBLENDOP_MIN = 4, + D3DBLENDOP_MAX = 5, + D3DBLENDOP_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DBLENDOP; + +typedef enum _D3DTEXTUREADDRESS { + D3DTADDRESS_WRAP = 1, + D3DTADDRESS_MIRROR = 2, + D3DTADDRESS_CLAMP = 3, + D3DTADDRESS_BORDER = 4, + D3DTADDRESS_MIRRORONCE = 5, + D3DTADDRESS_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DTEXTUREADDRESS; + +typedef enum _D3DCULL { + D3DCULL_NONE = 1, + D3DCULL_CW = 2, + D3DCULL_CCW = 3, + D3DCULL_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DCULL; + +typedef enum _D3DCMPFUNC { + D3DCMP_NEVER = 1, + D3DCMP_LESS = 2, + D3DCMP_EQUAL = 3, + D3DCMP_LESSEQUAL = 4, + D3DCMP_GREATER = 5, + D3DCMP_NOTEQUAL = 6, + D3DCMP_GREATEREQUAL = 7, + D3DCMP_ALWAYS = 8, + D3DCMP_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DCMPFUNC; + +typedef enum _D3DSTENCILOP { + D3DSTENCILOP_KEEP = 1, + D3DSTENCILOP_ZERO = 2, + D3DSTENCILOP_REPLACE = 3, + D3DSTENCILOP_INCRSAT = 4, + D3DSTENCILOP_DECRSAT = 5, + D3DSTENCILOP_INVERT = 6, + D3DSTENCILOP_INCR = 7, + D3DSTENCILOP_DECR = 8, + D3DSTENCILOP_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DSTENCILOP; + +typedef enum _D3DFOGMODE { + D3DFOG_NONE = 0, + D3DFOG_EXP = 1, + D3DFOG_EXP2 = 2, + D3DFOG_LINEAR = 3, + D3DFOG_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DFOGMODE; + +typedef enum _D3DZBUFFERTYPE { + D3DZB_FALSE = 0, + D3DZB_TRUE = 1, // Z buffering + D3DZB_USEW = 2, // W buffering + D3DZB_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DZBUFFERTYPE; + +// Primitives supported by draw-primitive API +typedef enum _D3DPRIMITIVETYPE { + D3DPT_POINTLIST = 1, + D3DPT_LINELIST = 2, + D3DPT_LINESTRIP = 3, + D3DPT_TRIANGLELIST = 4, + D3DPT_TRIANGLESTRIP = 5, + D3DPT_TRIANGLEFAN = 6, + D3DPT_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DPRIMITIVETYPE; + +typedef enum _D3DTRANSFORMSTATETYPE { + D3DTS_VIEW = 2, + D3DTS_PROJECTION = 3, + D3DTS_TEXTURE0 = 16, + D3DTS_TEXTURE1 = 17, + D3DTS_TEXTURE2 = 18, + D3DTS_TEXTURE3 = 19, + D3DTS_TEXTURE4 = 20, + D3DTS_TEXTURE5 = 21, + D3DTS_TEXTURE6 = 22, + D3DTS_TEXTURE7 = 23, + D3DTS_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DTRANSFORMSTATETYPE; + +#define D3DTS_WORLDMATRIX(index) (D3DTRANSFORMSTATETYPE)(index + 256) +#define D3DTS_WORLD D3DTS_WORLDMATRIX(0) +#define D3DTS_WORLD1 D3DTS_WORLDMATRIX(1) +#define D3DTS_WORLD2 D3DTS_WORLDMATRIX(2) +#define D3DTS_WORLD3 D3DTS_WORLDMATRIX(3) + +typedef enum _D3DRENDERSTATETYPE { + D3DRS_ZENABLE = 7, /* D3DZBUFFERTYPE (or TRUE/FALSE for legacy) */ + D3DRS_FILLMODE = 8, /* D3DFILLMODE */ + D3DRS_SHADEMODE = 9, /* D3DSHADEMODE */ + D3DRS_LINEPATTERN = 10, /* D3DLINEPATTERN */ + D3DRS_ZWRITEENABLE = 14, /* TRUE to enable z writes */ + D3DRS_ALPHATESTENABLE = 15, /* TRUE to enable alpha tests */ + D3DRS_LASTPIXEL = 16, /* TRUE for last-pixel on lines */ + D3DRS_SRCBLEND = 19, /* D3DBLEND */ + D3DRS_DESTBLEND = 20, /* D3DBLEND */ + D3DRS_CULLMODE = 22, /* D3DCULL */ + D3DRS_ZFUNC = 23, /* D3DCMPFUNC */ + D3DRS_ALPHAREF = 24, /* D3DFIXED */ + D3DRS_ALPHAFUNC = 25, /* D3DCMPFUNC */ + D3DRS_DITHERENABLE = 26, /* TRUE to enable dithering */ + D3DRS_ALPHABLENDENABLE = 27, /* TRUE to enable alpha blending */ + D3DRS_FOGENABLE = 28, /* TRUE to enable fog blending */ + D3DRS_SPECULARENABLE = 29, /* TRUE to enable specular */ + D3DRS_ZVISIBLE = 30, /* TRUE to enable z checking */ + D3DRS_FOGCOLOR = 34, /* D3DCOLOR */ + D3DRS_FOGTABLEMODE = 35, /* D3DFOGMODE */ + D3DRS_FOGSTART = 36, /* Fog start (for both vertex and pixel fog) */ + D3DRS_FOGEND = 37, /* Fog end */ + D3DRS_FOGDENSITY = 38, /* Fog density */ + D3DRS_EDGEANTIALIAS = 40, /* TRUE to enable edge antialiasing */ + D3DRS_ZBIAS = 47, /* LONG Z bias */ + D3DRS_RANGEFOGENABLE = 48, /* Enables range-based fog */ + D3DRS_STENCILENABLE = 52, /* BOOL enable/disable stenciling */ + D3DRS_STENCILFAIL = 53, /* D3DSTENCILOP to do if stencil test fails */ + D3DRS_STENCILZFAIL = 54, /* D3DSTENCILOP to do if stencil test passes and Z test fails */ + D3DRS_STENCILPASS = 55, /* D3DSTENCILOP to do if both stencil and Z tests pass */ + D3DRS_STENCILFUNC = 56, /* D3DCMPFUNC fn. Stencil Test passes if ((ref & mask) stencilfn (stencil & mask)) is true */ + D3DRS_STENCILREF = 57, /* Reference value used in stencil test */ + D3DRS_STENCILMASK = 58, /* Mask value used in stencil test */ + D3DRS_STENCILWRITEMASK = 59, /* Write mask applied to values written to stencil buffer */ + D3DRS_TEXTUREFACTOR = 60, /* D3DCOLOR used for multi-texture blend */ + D3DRS_WRAP0 = 128, /* wrap for 1st texture coord. set */ + D3DRS_WRAP1 = 129, /* wrap for 2nd texture coord. set */ + D3DRS_WRAP2 = 130, /* wrap for 3rd texture coord. set */ + D3DRS_WRAP3 = 131, /* wrap for 4th texture coord. set */ + D3DRS_WRAP4 = 132, /* wrap for 5th texture coord. set */ + D3DRS_WRAP5 = 133, /* wrap for 6th texture coord. set */ + D3DRS_WRAP6 = 134, /* wrap for 7th texture coord. set */ + D3DRS_WRAP7 = 135, /* wrap for 8th texture coord. set */ + D3DRS_CLIPPING = 136, + D3DRS_LIGHTING = 137, + D3DRS_AMBIENT = 139, + D3DRS_FOGVERTEXMODE = 140, + D3DRS_COLORVERTEX = 141, + D3DRS_LOCALVIEWER = 142, + D3DRS_NORMALIZENORMALS = 143, + D3DRS_DIFFUSEMATERIALSOURCE = 145, + D3DRS_SPECULARMATERIALSOURCE = 146, + D3DRS_AMBIENTMATERIALSOURCE = 147, + D3DRS_EMISSIVEMATERIALSOURCE = 148, + D3DRS_VERTEXBLEND = 151, + D3DRS_CLIPPLANEENABLE = 152, + D3DRS_SOFTWAREVERTEXPROCESSING = 153, + D3DRS_POINTSIZE = 154, /* float point size */ + D3DRS_POINTSIZE_MIN = 155, /* float point size min threshold */ + D3DRS_POINTSPRITEENABLE = 156, /* BOOL point texture coord control */ + D3DRS_POINTSCALEENABLE = 157, /* BOOL point size scale enable */ + D3DRS_POINTSCALE_A = 158, /* float point attenuation A value */ + D3DRS_POINTSCALE_B = 159, /* float point attenuation B value */ + D3DRS_POINTSCALE_C = 160, /* float point attenuation C value */ + D3DRS_MULTISAMPLEANTIALIAS = 161, // BOOL - set to do FSAA with multisample buffer + D3DRS_MULTISAMPLEMASK = 162, // DWORD - per-sample enable/disable + D3DRS_PATCHEDGESTYLE = 163, // Sets whether patch edges will use float style tessellation + D3DRS_PATCHSEGMENTS = 164, // Number of segments per edge when drawing patches + D3DRS_DEBUGMONITORTOKEN = 165, // DEBUG ONLY - token to debug monitor + D3DRS_POINTSIZE_MAX = 166, /* float point size max threshold */ + D3DRS_INDEXEDVERTEXBLENDENABLE = 167, + D3DRS_COLORWRITEENABLE = 168, // per-channel write enable + D3DRS_TWEENFACTOR = 170, // float tween factor + D3DRS_BLENDOP = 171, // D3DBLENDOP setting + D3DRS_POSITIONORDER = 172, // NPatch position interpolation order. D3DORDER_LINEAR or D3DORDER_CUBIC (default) + D3DRS_NORMALORDER = 173, // NPatch normal interpolation order. D3DORDER_LINEAR (default) or D3DORDER_QUADRATIC + + D3DRS_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DRENDERSTATETYPE; + +// Values for material source +typedef enum _D3DMATERIALCOLORSOURCE +{ + D3DMCS_MATERIAL = 0, // Color from material is used + D3DMCS_COLOR1 = 1, // Diffuse vertex color is used + D3DMCS_COLOR2 = 2, // Specular vertex color is used + D3DMCS_FORCE_DWORD = 0x7fffffff, // force 32-bit size enum +} D3DMATERIALCOLORSOURCE; + +// Bias to apply to the texture coordinate set to apply a wrap to. +#define D3DRENDERSTATE_WRAPBIAS 128UL + +/* Flags to construct the WRAP render states */ +#define D3DWRAP_U 0x00000001L +#define D3DWRAP_V 0x00000002L +#define D3DWRAP_W 0x00000004L + +/* Flags to construct the WRAP render states for 1D thru 4D texture coordinates */ +#define D3DWRAPCOORD_0 0x00000001L // same as D3DWRAP_U +#define D3DWRAPCOORD_1 0x00000002L // same as D3DWRAP_V +#define D3DWRAPCOORD_2 0x00000004L // same as D3DWRAP_W +#define D3DWRAPCOORD_3 0x00000008L + +/* Flags to construct D3DRS_COLORWRITEENABLE */ +#define D3DCOLORWRITEENABLE_RED (1L<<0) +#define D3DCOLORWRITEENABLE_GREEN (1L<<1) +#define D3DCOLORWRITEENABLE_BLUE (1L<<2) +#define D3DCOLORWRITEENABLE_ALPHA (1L<<3) + +/* + * State enumerants for per-stage texture processing. + */ +typedef enum _D3DTEXTURESTAGESTATETYPE +{ + D3DTSS_COLOROP = 1, /* D3DTEXTUREOP - per-stage blending controls for color channels */ + D3DTSS_COLORARG1 = 2, /* D3DTA_* (texture arg) */ + D3DTSS_COLORARG2 = 3, /* D3DTA_* (texture arg) */ + D3DTSS_ALPHAOP = 4, /* D3DTEXTUREOP - per-stage blending controls for alpha channel */ + D3DTSS_ALPHAARG1 = 5, /* D3DTA_* (texture arg) */ + D3DTSS_ALPHAARG2 = 6, /* D3DTA_* (texture arg) */ + D3DTSS_BUMPENVMAT00 = 7, /* float (bump mapping matrix) */ + D3DTSS_BUMPENVMAT01 = 8, /* float (bump mapping matrix) */ + D3DTSS_BUMPENVMAT10 = 9, /* float (bump mapping matrix) */ + D3DTSS_BUMPENVMAT11 = 10, /* float (bump mapping matrix) */ + D3DTSS_TEXCOORDINDEX = 11, /* identifies which set of texture coordinates index this texture */ + D3DTSS_ADDRESSU = 13, /* D3DTEXTUREADDRESS for U coordinate */ + D3DTSS_ADDRESSV = 14, /* D3DTEXTUREADDRESS for V coordinate */ + D3DTSS_BORDERCOLOR = 15, /* D3DCOLOR */ + D3DTSS_MAGFILTER = 16, /* D3DTEXTUREFILTER filter to use for magnification */ + D3DTSS_MINFILTER = 17, /* D3DTEXTUREFILTER filter to use for minification */ + D3DTSS_MIPFILTER = 18, /* D3DTEXTUREFILTER filter to use between mipmaps during minification */ + D3DTSS_MIPMAPLODBIAS = 19, /* float Mipmap LOD bias */ + D3DTSS_MAXMIPLEVEL = 20, /* DWORD 0..(n-1) LOD index of largest map to use (0 == largest) */ + D3DTSS_MAXANISOTROPY = 21, /* DWORD maximum anisotropy */ + D3DTSS_BUMPENVLSCALE = 22, /* float scale for bump map luminance */ + D3DTSS_BUMPENVLOFFSET = 23, /* float offset for bump map luminance */ + D3DTSS_TEXTURETRANSFORMFLAGS = 24, /* D3DTEXTURETRANSFORMFLAGS controls texture transform */ + D3DTSS_ADDRESSW = 25, /* D3DTEXTUREADDRESS for W coordinate */ + D3DTSS_COLORARG0 = 26, /* D3DTA_* third arg for triadic ops */ + D3DTSS_ALPHAARG0 = 27, /* D3DTA_* third arg for triadic ops */ + D3DTSS_RESULTARG = 28, /* D3DTA_* arg for result (CURRENT or TEMP) */ + D3DTSS_FORCE_DWORD = 0x7fffffff, /* force 32-bit size enum */ +} D3DTEXTURESTAGESTATETYPE; + +// Values, used with D3DTSS_TEXCOORDINDEX, to specify that the vertex data(position +// and normal in the camera space) should be taken as texture coordinates +// Low 16 bits are used to specify texture coordinate index, to take the WRAP mode from +// +#define D3DTSS_TCI_PASSTHRU 0x00000000 +#define D3DTSS_TCI_CAMERASPACENORMAL 0x00010000 +#define D3DTSS_TCI_CAMERASPACEPOSITION 0x00020000 +#define D3DTSS_TCI_CAMERASPACEREFLECTIONVECTOR 0x00030000 + +/* + * Enumerations for COLOROP and ALPHAOP texture blending operations set in + * texture processing stage controls in D3DTSS. + */ +typedef enum _D3DTEXTUREOP +{ + // Control + D3DTOP_DISABLE = 1, // disables stage + D3DTOP_SELECTARG1 = 2, // the default + D3DTOP_SELECTARG2 = 3, + + // Modulate + D3DTOP_MODULATE = 4, // multiply args together + D3DTOP_MODULATE2X = 5, // multiply and 1 bit + D3DTOP_MODULATE4X = 6, // multiply and 2 bits + + // Add + D3DTOP_ADD = 7, // add arguments together + D3DTOP_ADDSIGNED = 8, // add with -0.5 bias + D3DTOP_ADDSIGNED2X = 9, // as above but left 1 bit + D3DTOP_SUBTRACT = 10, // Arg1 - Arg2, with no saturation + D3DTOP_ADDSMOOTH = 11, // add 2 args, subtract product + // Arg1 + Arg2 - Arg1*Arg2 + // = Arg1 + (1-Arg1)*Arg2 + + // Linear alpha blend: Arg1*(Alpha) + Arg2*(1-Alpha) + D3DTOP_BLENDDIFFUSEALPHA = 12, // iterated alpha + D3DTOP_BLENDTEXTUREALPHA = 13, // texture alpha + D3DTOP_BLENDFACTORALPHA = 14, // alpha from D3DRS_TEXTUREFACTOR + + // Linear alpha blend with pre-multiplied arg1 input: Arg1 + Arg2*(1-Alpha) + D3DTOP_BLENDTEXTUREALPHAPM = 15, // texture alpha + D3DTOP_BLENDCURRENTALPHA = 16, // by alpha of current color + + // Specular mapping + D3DTOP_PREMODULATE = 17, // modulate with next texture before use + D3DTOP_MODULATEALPHA_ADDCOLOR = 18, // Arg1.RGB + Arg1.A*Arg2.RGB + // COLOROP only + D3DTOP_MODULATECOLOR_ADDALPHA = 19, // Arg1.RGB*Arg2.RGB + Arg1.A + // COLOROP only + D3DTOP_MODULATEINVALPHA_ADDCOLOR = 20, // (1-Arg1.A)*Arg2.RGB + Arg1.RGB + // COLOROP only + D3DTOP_MODULATEINVCOLOR_ADDALPHA = 21, // (1-Arg1.RGB)*Arg2.RGB + Arg1.A + // COLOROP only + + // Bump mapping + D3DTOP_BUMPENVMAP = 22, // per pixel env map perturbation + D3DTOP_BUMPENVMAPLUMINANCE = 23, // with luminance channel + + // This can do either diffuse or specular bump mapping with correct input. + // Performs the function (Arg1.R*Arg2.R + Arg1.G*Arg2.G + Arg1.B*Arg2.B) + // where each component has been scaled and offset to make it signed. + // The result is replicated into all four (including alpha) channels. + // This is a valid COLOROP only. + D3DTOP_DOTPRODUCT3 = 24, + + // Triadic ops + D3DTOP_MULTIPLYADD = 25, // Arg0 + Arg1*Arg2 + D3DTOP_LERP = 26, // (Arg0)*Arg1 + (1-Arg0)*Arg2 + + D3DTOP_FORCE_DWORD = 0x7fffffff, +} D3DTEXTUREOP; + +/* + * Values for COLORARG0,1,2, ALPHAARG0,1,2, and RESULTARG texture blending + * operations set in texture processing stage controls in D3DRENDERSTATE. + */ +#define D3DTA_SELECTMASK 0x0000000f // mask for arg selector +#define D3DTA_DIFFUSE 0x00000000 // select diffuse color (read only) +#define D3DTA_CURRENT 0x00000001 // select stage destination register (read/write) +#define D3DTA_TEXTURE 0x00000002 // select texture color (read only) +#define D3DTA_TFACTOR 0x00000003 // select D3DRS_TEXTUREFACTOR (read only) +#define D3DTA_SPECULAR 0x00000004 // select specular color (read only) +#define D3DTA_TEMP 0x00000005 // select temporary register color (read/write) +#define D3DTA_COMPLEMENT 0x00000010 // take 1.0 - x (read modifier) +#define D3DTA_ALPHAREPLICATE 0x00000020 // replicate alpha to color components (read modifier) + +// +// Values for D3DTSS_***FILTER texture stage states +// +typedef enum _D3DTEXTUREFILTERTYPE +{ + D3DTEXF_NONE = 0, // filtering disabled (valid for mip filter only) + D3DTEXF_POINT = 1, // nearest + D3DTEXF_LINEAR = 2, // linear interpolation + D3DTEXF_ANISOTROPIC = 3, // anisotropic + D3DTEXF_FLATCUBIC = 4, // cubic + D3DTEXF_GAUSSIANCUBIC = 5, // different cubic kernel + D3DTEXF_FORCE_DWORD = 0x7fffffff, // force 32-bit size enum +} D3DTEXTUREFILTERTYPE; + +/* Bits for Flags in ProcessVertices call */ + +#define D3DPV_DONOTCOPYDATA (1 << 0) + +//------------------------------------------------------------------- + +// Flexible vertex format bits +// +#define D3DFVF_RESERVED0 0x001 +#define D3DFVF_POSITION_MASK 0x00E +#define D3DFVF_XYZ 0x002 +#define D3DFVF_XYZRHW 0x004 +#define D3DFVF_XYZB1 0x006 +#define D3DFVF_XYZB2 0x008 +#define D3DFVF_XYZB3 0x00a +#define D3DFVF_XYZB4 0x00c +#define D3DFVF_XYZB5 0x00e + +#define D3DFVF_NORMAL 0x010 +#define D3DFVF_PSIZE 0x020 +#define D3DFVF_DIFFUSE 0x040 +#define D3DFVF_SPECULAR 0x080 + +#define D3DFVF_TEXCOUNT_MASK 0xf00 +#define D3DFVF_TEXCOUNT_SHIFT 8 +#define D3DFVF_TEX0 0x000 +#define D3DFVF_TEX1 0x100 +#define D3DFVF_TEX2 0x200 +#define D3DFVF_TEX3 0x300 +#define D3DFVF_TEX4 0x400 +#define D3DFVF_TEX5 0x500 +#define D3DFVF_TEX6 0x600 +#define D3DFVF_TEX7 0x700 +#define D3DFVF_TEX8 0x800 + +#define D3DFVF_LASTBETA_UBYTE4 0x1000 + +#define D3DFVF_RESERVED2 0xE000 // 4 reserved bits + +//--------------------------------------------------------------------- +// Vertex Shaders +// + +/* + +Vertex Shader Declaration + +The declaration portion of a vertex shader defines the static external +interface of the shader. The information in the declaration includes: + +- Assignments of vertex shader input registers to data streams. These +assignments bind a specific vertex register to a single component within a +vertex stream. A vertex stream element is identified by a byte offset +within the stream and a type. The type specifies the arithmetic data type +plus the dimensionality (1, 2, 3, or 4 values). Stream data which is +less than 4 values are always expanded out to 4 values with zero or more +0.F values and one 1.F value. + +- Assignment of vertex shader input registers to implicit data from the +primitive tessellator. This controls the loading of vertex data which is +not loaded from a stream, but rather is generated during primitive +tessellation prior to the vertex shader. + +- Loading data into the constant memory at the time a shader is set as the +current shader. Each token specifies values for one or more contiguous 4 +DWORD constant registers. This allows the shader to update an arbitrary +subset of the constant memory, overwriting the device state (which +contains the current values of the constant memory). Note that these +values can be subsequently overwritten (between DrawPrimitive calls) +during the time a shader is bound to a device via the +SetVertexShaderConstant method. + + +Declaration arrays are single-dimensional arrays of DWORDs composed of +multiple tokens each of which is one or more DWORDs. The single-DWORD +token value 0xFFFFFFFF is a special token used to indicate the end of the +declaration array. The single DWORD token value 0x00000000 is a NOP token +with is ignored during the declaration parsing. Note that 0x00000000 is a +valid value for DWORDs following the first DWORD for multiple word tokens. + +[31:29] TokenType + 0x0 - NOP (requires all DWORD bits to be zero) + 0x1 - stream selector + 0x2 - stream data definition (map to vertex input memory) + 0x3 - vertex input memory from tessellator + 0x4 - constant memory from shader + 0x5 - extension + 0x6 - reserved + 0x7 - end-of-array (requires all DWORD bits to be 1) + +NOP Token (single DWORD token) + [31:29] 0x0 + [28:00] 0x0 + +Stream Selector (single DWORD token) + [31:29] 0x1 + [28] indicates whether this is a tessellator stream + [27:04] 0x0 + [03:00] stream selector (0..15) + +Stream Data Definition (single DWORD token) + Vertex Input Register Load + [31:29] 0x2 + [28] 0x0 + [27:20] 0x0 + [19:16] type (dimensionality and data type) + [15:04] 0x0 + [03:00] vertex register address (0..15) + Data Skip (no register load) + [31:29] 0x2 + [28] 0x1 + [27:20] 0x0 + [19:16] count of DWORDS to skip over (0..15) + [15:00] 0x0 + Vertex Input Memory from Tessellator Data (single DWORD token) + [31:29] 0x3 + [28] indicates whether data is normals or u/v + [27:24] 0x0 + [23:20] vertex register address (0..15) + [19:16] type (dimensionality) + [15:04] 0x0 + [03:00] vertex register address (0..15) + +Constant Memory from Shader (multiple DWORD token) + [31:29] 0x4 + [28:25] count of 4*DWORD constants to load (0..15) + [24:07] 0x0 + [06:00] constant memory address (0..95) + +Extension Token (single or multiple DWORD token) + [31:29] 0x5 + [28:24] count of additional DWORDs in token (0..31) + [23:00] extension-specific information + +End-of-array token (single DWORD token) + [31:29] 0x7 + [28:00] 0x1fffffff + +The stream selector token must be immediately followed by a contiguous set of stream data definition tokens. This token sequence fully defines that stream, including the set of elements within the stream, the order in which the elements appear, the type of each element, and the vertex register into which to load an element. +Streams are allowed to include data which is not loaded into a vertex register, thus allowing data which is not used for this shader to exist in the vertex stream. This skipped data is defined only by a count of DWORDs to skip over, since the type information is irrelevant. +The token sequence: +Stream Select: stream=0 +Stream Data Definition (Load): type=FLOAT3; register=3 +Stream Data Definition (Load): type=FLOAT3; register=4 +Stream Data Definition (Skip): count=2 +Stream Data Definition (Load): type=FLOAT2; register=7 + +defines stream zero to consist of 4 elements, 3 of which are loaded into registers and the fourth skipped over. Register 3 is loaded with the first three DWORDs in each vertex interpreted as FLOAT data. Register 4 is loaded with the 4th, 5th, and 6th DWORDs interpreted as FLOAT data. The next two DWORDs (7th and 8th) are skipped over and not loaded into any vertex input register. Register 7 is loaded with the 9th and 10th DWORDS interpreted as FLOAT data. +Placing of tokens other than NOPs between the Stream Selector and Stream Data Definition tokens is disallowed. + +*/ + +typedef enum _D3DVSD_TOKENTYPE +{ + D3DVSD_TOKEN_NOP = 0, // NOP or extension + D3DVSD_TOKEN_STREAM, // stream selector + D3DVSD_TOKEN_STREAMDATA, // stream data definition (map to vertex input memory) + D3DVSD_TOKEN_TESSELLATOR, // vertex input memory from tessellator + D3DVSD_TOKEN_CONSTMEM, // constant memory from shader + D3DVSD_TOKEN_EXT, // extension + D3DVSD_TOKEN_END = 7, // end-of-array (requires all DWORD bits to be 1) + D3DVSD_FORCE_DWORD = 0x7fffffff,// force 32-bit size enum +} D3DVSD_TOKENTYPE; + +#define D3DVSD_TOKENTYPESHIFT 29 +#define D3DVSD_TOKENTYPEMASK (7 << D3DVSD_TOKENTYPESHIFT) + +#define D3DVSD_STREAMNUMBERSHIFT 0 +#define D3DVSD_STREAMNUMBERMASK (0xF << D3DVSD_STREAMNUMBERSHIFT) + +#define D3DVSD_DATALOADTYPESHIFT 28 +#define D3DVSD_DATALOADTYPEMASK (0x1 << D3DVSD_DATALOADTYPESHIFT) + +#define D3DVSD_DATATYPESHIFT 16 +#define D3DVSD_DATATYPEMASK (0xF << D3DVSD_DATATYPESHIFT) + +#define D3DVSD_SKIPCOUNTSHIFT 16 +#define D3DVSD_SKIPCOUNTMASK (0xF << D3DVSD_SKIPCOUNTSHIFT) + +#define D3DVSD_VERTEXREGSHIFT 0 +#define D3DVSD_VERTEXREGMASK (0x1F << D3DVSD_VERTEXREGSHIFT) + +#define D3DVSD_VERTEXREGINSHIFT 20 +#define D3DVSD_VERTEXREGINMASK (0xF << D3DVSD_VERTEXREGINSHIFT) + +#define D3DVSD_CONSTCOUNTSHIFT 25 +#define D3DVSD_CONSTCOUNTMASK (0xF << D3DVSD_CONSTCOUNTSHIFT) + +#define D3DVSD_CONSTADDRESSSHIFT 0 +#define D3DVSD_CONSTADDRESSMASK (0x7F << D3DVSD_CONSTADDRESSSHIFT) + +#define D3DVSD_CONSTRSSHIFT 16 +#define D3DVSD_CONSTRSMASK (0x1FFF << D3DVSD_CONSTRSSHIFT) + +#define D3DVSD_EXTCOUNTSHIFT 24 +#define D3DVSD_EXTCOUNTMASK (0x1F << D3DVSD_EXTCOUNTSHIFT) + +#define D3DVSD_EXTINFOSHIFT 0 +#define D3DVSD_EXTINFOMASK (0xFFFFFF << D3DVSD_EXTINFOSHIFT) + +#define D3DVSD_MAKETOKENTYPE(tokenType) ((tokenType << D3DVSD_TOKENTYPESHIFT) & D3DVSD_TOKENTYPEMASK) + +// macros for generation of CreateVertexShader Declaration token array + +// Set current stream +// _StreamNumber [0..(MaxStreams-1)] stream to get data from +// +#define D3DVSD_STREAM( _StreamNumber ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_STREAM) | (_StreamNumber)) + +// Set tessellator stream +// +#define D3DVSD_STREAMTESSSHIFT 28 +#define D3DVSD_STREAMTESSMASK (1 << D3DVSD_STREAMTESSSHIFT) +#define D3DVSD_STREAM_TESS( ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_STREAM) | (D3DVSD_STREAMTESSMASK)) + +// bind single vertex register to vertex element from vertex stream +// +// _VertexRegister [0..15] address of the vertex register +// _Type [D3DVSDT_*] dimensionality and arithmetic data type + +#define D3DVSD_REG( _VertexRegister, _Type ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_STREAMDATA) | \ + ((_Type) << D3DVSD_DATATYPESHIFT) | (_VertexRegister)) + +// Skip _DWORDCount DWORDs in vertex +// +#define D3DVSD_SKIP( _DWORDCount ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_STREAMDATA) | 0x10000000 | \ + ((_DWORDCount) << D3DVSD_SKIPCOUNTSHIFT)) + +// load data into vertex shader constant memory +// +// _ConstantAddress [0..95] - address of constant array to begin filling data +// _Count [0..15] - number of constant vectors to load (4 DWORDs each) +// followed by 4*_Count DWORDS of data +// +#define D3DVSD_CONST( _ConstantAddress, _Count ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_CONSTMEM) | \ + ((_Count) << D3DVSD_CONSTCOUNTSHIFT) | (_ConstantAddress)) + +// enable tessellator generated normals +// +// _VertexRegisterIn [0..15] address of vertex register whose input stream +// will be used in normal computation +// _VertexRegisterOut [0..15] address of vertex register to output the normal to +// +#define D3DVSD_TESSNORMAL( _VertexRegisterIn, _VertexRegisterOut ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_TESSELLATOR) | \ + ((_VertexRegisterIn) << D3DVSD_VERTEXREGINSHIFT) | \ + ((0x02) << D3DVSD_DATATYPESHIFT) | (_VertexRegisterOut)) + +// enable tessellator generated surface parameters +// +// _VertexRegister [0..15] address of vertex register to output parameters +// +#define D3DVSD_TESSUV( _VertexRegister ) \ + (D3DVSD_MAKETOKENTYPE(D3DVSD_TOKEN_TESSELLATOR) | 0x10000000 | \ + ((0x01) << D3DVSD_DATATYPESHIFT) | (_VertexRegister)) + +// Generates END token +// +#define D3DVSD_END() 0xFFFFFFFF + +// Generates NOP token +#define D3DVSD_NOP() 0x00000000 + +// bit declarations for _Type fields +#define D3DVSDT_FLOAT1 0x00 // 1D float expanded to (value, 0., 0., 1.) +#define D3DVSDT_FLOAT2 0x01 // 2D float expanded to (value, value, 0., 1.) +#define D3DVSDT_FLOAT3 0x02 // 3D float expanded to (value, value, value, 1.) +#define D3DVSDT_FLOAT4 0x03 // 4D float +#define D3DVSDT_D3DCOLOR 0x04 // 4D packed unsigned bytes mapped to 0. to 1. range + // Input is in D3DCOLOR format (ARGB) expanded to (R, G, B, A) +#define D3DVSDT_UBYTE4 0x05 // 4D unsigned byte +#define D3DVSDT_SHORT2 0x06 // 2D signed short expanded to (value, value, 0., 1.) +#define D3DVSDT_SHORT4 0x07 // 4D signed short + +// assignments of vertex input registers for fixed function vertex shader +// +#define D3DVSDE_POSITION 0 +#define D3DVSDE_BLENDWEIGHT 1 +#define D3DVSDE_BLENDINDICES 2 +#define D3DVSDE_NORMAL 3 +#define D3DVSDE_PSIZE 4 +#define D3DVSDE_DIFFUSE 5 +#define D3DVSDE_SPECULAR 6 +#define D3DVSDE_TEXCOORD0 7 +#define D3DVSDE_TEXCOORD1 8 +#define D3DVSDE_TEXCOORD2 9 +#define D3DVSDE_TEXCOORD3 10 +#define D3DVSDE_TEXCOORD4 11 +#define D3DVSDE_TEXCOORD5 12 +#define D3DVSDE_TEXCOORD6 13 +#define D3DVSDE_TEXCOORD7 14 +#define D3DVSDE_POSITION2 15 +#define D3DVSDE_NORMAL2 16 + +// Maximum supported number of texture coordinate sets +#define D3DDP_MAXTEXCOORD 8 + + +// +// Instruction Token Bit Definitions +// +#define D3DSI_OPCODE_MASK 0x0000FFFF + +typedef enum _D3DSHADER_INSTRUCTION_OPCODE_TYPE +{ + D3DSIO_NOP = 0, // PS/VS + D3DSIO_MOV , // PS/VS + D3DSIO_ADD , // PS/VS + D3DSIO_SUB , // PS + D3DSIO_MAD , // PS/VS + D3DSIO_MUL , // PS/VS + D3DSIO_RCP , // VS + D3DSIO_RSQ , // VS + D3DSIO_DP3 , // PS/VS + D3DSIO_DP4 , // PS/VS + D3DSIO_MIN , // VS + D3DSIO_MAX , // VS + D3DSIO_SLT , // VS + D3DSIO_SGE , // VS + D3DSIO_EXP , // VS + D3DSIO_LOG , // VS + D3DSIO_LIT , // VS + D3DSIO_DST , // VS + D3DSIO_LRP , // PS + D3DSIO_FRC , // VS + D3DSIO_M4x4 , // VS + D3DSIO_M4x3 , // VS + D3DSIO_M3x4 , // VS + D3DSIO_M3x3 , // VS + D3DSIO_M3x2 , // VS + + D3DSIO_TEXCOORD = 64, // PS + D3DSIO_TEXKILL , // PS + D3DSIO_TEX , // PS + D3DSIO_TEXBEM , // PS + D3DSIO_TEXBEML , // PS + D3DSIO_TEXREG2AR , // PS + D3DSIO_TEXREG2GB , // PS + D3DSIO_TEXM3x2PAD , // PS + D3DSIO_TEXM3x2TEX , // PS + D3DSIO_TEXM3x3PAD , // PS + D3DSIO_TEXM3x3TEX , // PS + D3DSIO_TEXM3x3DIFF , // PS + D3DSIO_TEXM3x3SPEC , // PS + D3DSIO_TEXM3x3VSPEC , // PS + D3DSIO_EXPP , // VS + D3DSIO_LOGP , // VS + D3DSIO_CND , // PS + D3DSIO_DEF , // PS + D3DSIO_TEXREG2RGB , // PS + D3DSIO_TEXDP3TEX , // PS + D3DSIO_TEXM3x2DEPTH , // PS + D3DSIO_TEXDP3 , // PS + D3DSIO_TEXM3x3 , // PS + D3DSIO_TEXDEPTH , // PS + D3DSIO_CMP , // PS + D3DSIO_BEM , // PS + + D3DSIO_PHASE = 0xFFFD, + D3DSIO_COMMENT = 0xFFFE, + D3DSIO_END = 0xFFFF, + + D3DSIO_FORCE_DWORD = 0x7fffffff, // force 32-bit size enum +} D3DSHADER_INSTRUCTION_OPCODE_TYPE; + +// +// Co-Issue Instruction Modifier - if set then this instruction is to be +// issued in parallel with the previous instruction(s) for which this bit +// is not set. +// +#define D3DSI_COISSUE 0x40000000 + +// +// Parameter Token Bit Definitions +// +#define D3DSP_REGNUM_MASK 0x00001FFF + +// destination parameter write mask +#define D3DSP_WRITEMASK_0 0x00010000 // Component 0 (X;Red) +#define D3DSP_WRITEMASK_1 0x00020000 // Component 1 (Y;Green) +#define D3DSP_WRITEMASK_2 0x00040000 // Component 2 (Z;Blue) +#define D3DSP_WRITEMASK_3 0x00080000 // Component 3 (W;Alpha) +#define D3DSP_WRITEMASK_ALL 0x000F0000 // All Components + +// destination parameter modifiers +#define D3DSP_DSTMOD_SHIFT 20 +#define D3DSP_DSTMOD_MASK 0x00F00000 + +typedef enum _D3DSHADER_PARAM_DSTMOD_TYPE +{ + D3DSPDM_NONE = 0<>8)&0xFF) +#define D3DSHADER_VERSION_MINOR(_Version) (((_Version)>>0)&0xFF) + +// destination/source parameter register type +#define D3DSI_COMMENTSIZE_SHIFT 16 +#define D3DSI_COMMENTSIZE_MASK 0x7FFF0000 +#define D3DSHADER_COMMENT(_DWordSize) \ + ((((_DWordSize)<= 1200 +#pragma warning(pop) +#else +#pragma warning(default:4201) +#endif + +#endif /* (DIRECT3D_VERSION >= 0x0800) */ +#endif /* _D3D8TYPES(P)_H_ */ + diff --git a/plugins/ADK/d3d8/includes/d3dx8.h b/plugins/ADK/d3d8/includes/d3dx8.h new file mode 100644 index 0000000..31927a2 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8.h @@ -0,0 +1,45 @@ +/////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8.h +// Content: D3DX utility library +// +/////////////////////////////////////////////////////////////////////////// + +#ifndef __D3DX8_H__ +#define __D3DX8_H__ + +#include "d3d8.h" +#include + +#ifndef D3DXINLINE +#ifdef _MSC_VER + #if (_MSC_VER >= 1200) + #define D3DXINLINE __forceinline + #else + #define D3DXINLINE __inline + #endif +#else + #ifdef __cplusplus + #define D3DXINLINE inline + #else + #define D3DXINLINE + #endif +#endif +#endif + + +#define D3DX_DEFAULT ULONG_MAX +#define D3DX_DEFAULT_FLOAT FLT_MAX + +#include "d3dx8math.h" +#include "d3dx8core.h" +#include "d3dx8tex.h" +#include "d3dx8mesh.h" +#include "d3dx8shape.h" +#include "d3dx8effect.h" + + +#endif //__D3DX8_H__ + diff --git a/plugins/ADK/d3d8/includes/d3dx8core.h b/plugins/ADK/d3d8/includes/d3dx8core.h new file mode 100644 index 0000000..46552a9 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8core.h @@ -0,0 +1,563 @@ +/////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8core.h +// Content: D3DX core types and functions +// +/////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8CORE_H__ +#define __D3DX8CORE_H__ + + + +/////////////////////////////////////////////////////////////////////////// +// ID3DXBuffer: +// ------------ +// The buffer object is used by D3DX to return arbitrary size data. +// +// GetBufferPointer - +// Returns a pointer to the beginning of the buffer. +// +// GetBufferSize - +// Returns the size of the buffer, in bytes. +/////////////////////////////////////////////////////////////////////////// + +typedef interface ID3DXBuffer ID3DXBuffer; +typedef interface ID3DXBuffer *LPD3DXBUFFER; + +// {932E6A7E-C68E-45dd-A7BF-53D19C86DB1F} +DEFINE_GUID(IID_ID3DXBuffer, +0x932e6a7e, 0xc68e, 0x45dd, 0xa7, 0xbf, 0x53, 0xd1, 0x9c, 0x86, 0xdb, 0x1f); + +#undef INTERFACE +#define INTERFACE ID3DXBuffer + +DECLARE_INTERFACE_(ID3DXBuffer, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXBuffer + STDMETHOD_(LPVOID, GetBufferPointer)(THIS) PURE; + STDMETHOD_(DWORD, GetBufferSize)(THIS) PURE; +}; + + + +/////////////////////////////////////////////////////////////////////////// +// ID3DXFont: +// ---------- +// Font objects contain the textures and resources needed to render +// a specific font on a specific device. +// +// Begin - +// Prepartes device for drawing text. This is optional.. if DrawText +// is called outside of Begin/End, it will call Begin and End for you. +// +// DrawText - +// Draws formatted text on a D3D device. Some parameters are +// surprisingly similar to those of GDI's DrawText function. See GDI +// documentation for a detailed description of these parameters. +// +// End - +// Restores device state to how it was when Begin was called. +// +// OnLostDevice, OnResetDevice - +// Call OnLostDevice() on this object before calling Reset() on the +// device, so that this object can release any stateblocks and video +// memory resources. After Reset(), the call OnResetDevice(). +// +/////////////////////////////////////////////////////////////////////////// + +typedef interface ID3DXFont ID3DXFont; +typedef interface ID3DXFont *LPD3DXFONT; + + +// {89FAD6A5-024D-49af-8FE7-F51123B85E25} +DEFINE_GUID( IID_ID3DXFont, +0x89fad6a5, 0x24d, 0x49af, 0x8f, 0xe7, 0xf5, 0x11, 0x23, 0xb8, 0x5e, 0x25); + + +#undef INTERFACE +#define INTERFACE ID3DXFont + +DECLARE_INTERFACE_(ID3DXFont, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXFont + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(GetLogFont)(THIS_ LOGFONT* pLogFont) PURE; + + STDMETHOD(Begin)(THIS) PURE; + STDMETHOD_(INT, DrawTextA)(THIS_ LPCSTR pString, INT Count, LPRECT pRect, DWORD Format, D3DCOLOR Color) PURE; + STDMETHOD_(INT, DrawTextW)(THIS_ LPCWSTR pString, INT Count, LPRECT pRect, DWORD Format, D3DCOLOR Color) PURE; + STDMETHOD(End)(THIS) PURE; + + STDMETHOD(OnLostDevice)(THIS) PURE; + STDMETHOD(OnResetDevice)(THIS) PURE; +}; + +#ifndef DrawText +#ifdef UNICODE +#define DrawText DrawTextW +#else +#define DrawText DrawTextA +#endif +#endif + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +HRESULT WINAPI + D3DXCreateFont( + LPDIRECT3DDEVICE8 pDevice, + HFONT hFont, + LPD3DXFONT* ppFont); + + +HRESULT WINAPI + D3DXCreateFontIndirect( + LPDIRECT3DDEVICE8 pDevice, + CONST LOGFONT* pLogFont, + LPD3DXFONT* ppFont); + +#ifdef __cplusplus +} +#endif //__cplusplus + + + + +/////////////////////////////////////////////////////////////////////////// +// ID3DXSprite: +// ------------ +// This object intends to provide an easy way to drawing sprites using D3D. +// +// Begin - +// Prepares device for drawing sprites +// +// Draw, DrawAffine, DrawTransform - +// Draws a sprite in screen-space. Before transformation, the sprite is +// the size of SrcRect, with its top-left corner at the origin (0,0). +// The color and alpha channels are modulated by Color. +// +// End - +// Restores device state to how it was when Begin was called. +// +// OnLostDevice, OnResetDevice - +// Call OnLostDevice() on this object before calling Reset() on the +// device, so that this object can release any stateblocks and video +// memory resources. After Reset(), the call OnResetDevice(). +/////////////////////////////////////////////////////////////////////////// + +typedef interface ID3DXSprite ID3DXSprite; +typedef interface ID3DXSprite *LPD3DXSPRITE; + + +// {13D69D15-F9B0-4e0f-B39E-C91EB33F6CE7} +DEFINE_GUID( IID_ID3DXSprite, +0x13d69d15, 0xf9b0, 0x4e0f, 0xb3, 0x9e, 0xc9, 0x1e, 0xb3, 0x3f, 0x6c, 0xe7); + + +#undef INTERFACE +#define INTERFACE ID3DXSprite + +DECLARE_INTERFACE_(ID3DXSprite, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXSprite + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + + STDMETHOD(Begin)(THIS) PURE; + + STDMETHOD(Draw)(THIS_ LPDIRECT3DTEXTURE8 pSrcTexture, + CONST RECT* pSrcRect, CONST D3DXVECTOR2* pScaling, + CONST D3DXVECTOR2* pRotationCenter, FLOAT Rotation, + CONST D3DXVECTOR2* pTranslation, D3DCOLOR Color) PURE; + + STDMETHOD(DrawTransform)(THIS_ LPDIRECT3DTEXTURE8 pSrcTexture, + CONST RECT* pSrcRect, CONST D3DXMATRIX* pTransform, + D3DCOLOR Color) PURE; + + STDMETHOD(End)(THIS) PURE; + + STDMETHOD(OnLostDevice)(THIS) PURE; + STDMETHOD(OnResetDevice)(THIS) PURE; +}; + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + + +HRESULT WINAPI + D3DXCreateSprite( + LPDIRECT3DDEVICE8 pDevice, + LPD3DXSPRITE* ppSprite); + +#ifdef __cplusplus +} +#endif //__cplusplus + + + + +/////////////////////////////////////////////////////////////////////////// +// ID3DXRenderToSurface: +// --------------------- +// This object abstracts rendering to surfaces. These surfaces do not +// necessarily need to be render targets. If they are not, a compatible +// render target is used, and the result copied into surface at end scene. +// +// BeginScene, EndScene - +// Call BeginScene() and EndScene() at the beginning and ending of your +// scene. These calls will setup and restore render targets, viewports, +// etc.. +// +// OnLostDevice, OnResetDevice - +// Call OnLostDevice() on this object before calling Reset() on the +// device, so that this object can release any stateblocks and video +// memory resources. After Reset(), the call OnResetDevice(). +/////////////////////////////////////////////////////////////////////////// + +typedef struct _D3DXRTS_DESC +{ + UINT Width; + UINT Height; + D3DFORMAT Format; + BOOL DepthStencil; + D3DFORMAT DepthStencilFormat; + +} D3DXRTS_DESC; + + +typedef interface ID3DXRenderToSurface ID3DXRenderToSurface; +typedef interface ID3DXRenderToSurface *LPD3DXRENDERTOSURFACE; + + +// {82DF5B90-E34E-496e-AC1C-62117A6A5913} +DEFINE_GUID( IID_ID3DXRenderToSurface, +0x82df5b90, 0xe34e, 0x496e, 0xac, 0x1c, 0x62, 0x11, 0x7a, 0x6a, 0x59, 0x13); + + +#undef INTERFACE +#define INTERFACE ID3DXRenderToSurface + +DECLARE_INTERFACE_(ID3DXRenderToSurface, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXRenderToSurface + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(GetDesc)(THIS_ D3DXRTS_DESC* pDesc) PURE; + + STDMETHOD(BeginScene)(THIS_ LPDIRECT3DSURFACE8 pSurface, CONST D3DVIEWPORT8* pViewport) PURE; + STDMETHOD(EndScene)(THIS) PURE; + + STDMETHOD(OnLostDevice)(THIS) PURE; + STDMETHOD(OnResetDevice)(THIS) PURE; +}; + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +HRESULT WINAPI + D3DXCreateRenderToSurface( + LPDIRECT3DDEVICE8 pDevice, + UINT Width, + UINT Height, + D3DFORMAT Format, + BOOL DepthStencil, + D3DFORMAT DepthStencilFormat, + LPD3DXRENDERTOSURFACE* ppRenderToSurface); + +#ifdef __cplusplus +} +#endif //__cplusplus + + + +/////////////////////////////////////////////////////////////////////////// +// ID3DXRenderToEnvMap: +// -------------------- +// This object abstracts rendering to environment maps. These surfaces +// do not necessarily need to be render targets. If they are not, a +// compatible render target is used, and the result copied into the +// environment map at end scene. +// +// BeginCube, BeginSphere, BeginHemisphere, BeginParabolic - +// This function initiates the rendering of the environment map. As +// parameters, you pass the textures in which will get filled in with +// the resulting environment map. +// +// Face - +// Call this function to initiate the drawing of each face. For each +// environment map, you will call this six times.. once for each face +// in D3DCUBEMAP_FACES. +// +// End - +// This will restore all render targets, and if needed compose all the +// rendered faces into the environment map surfaces. +// +// OnLostDevice, OnResetDevice - +// Call OnLostDevice() on this object before calling Reset() on the +// device, so that this object can release any stateblocks and video +// memory resources. After Reset(), the call OnResetDevice(). +/////////////////////////////////////////////////////////////////////////// + +typedef struct _D3DXRTE_DESC +{ + UINT Size; + D3DFORMAT Format; + BOOL DepthStencil; + D3DFORMAT DepthStencilFormat; +} D3DXRTE_DESC; + + +typedef interface ID3DXRenderToEnvMap ID3DXRenderToEnvMap; +typedef interface ID3DXRenderToEnvMap *LPD3DXRenderToEnvMap; + +// {4E42C623-9451-44b7-8C86-ABCCDE5D52C8} +DEFINE_GUID( IID_ID3DXRenderToEnvMap, +0x4e42c623, 0x9451, 0x44b7, 0x8c, 0x86, 0xab, 0xcc, 0xde, 0x5d, 0x52, 0xc8); + + +#undef INTERFACE +#define INTERFACE ID3DXRenderToEnvMap + +DECLARE_INTERFACE_(ID3DXRenderToEnvMap, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXRenderToEnvMap + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(GetDesc)(THIS_ D3DXRTE_DESC* pDesc) PURE; + + STDMETHOD(BeginCube)(THIS_ + LPDIRECT3DCUBETEXTURE8 pCubeTex) PURE; + + STDMETHOD(BeginSphere)(THIS_ + LPDIRECT3DTEXTURE8 pTex) PURE; + + STDMETHOD(BeginHemisphere)(THIS_ + LPDIRECT3DTEXTURE8 pTexZPos, + LPDIRECT3DTEXTURE8 pTexZNeg) PURE; + + STDMETHOD(BeginParabolic)(THIS_ + LPDIRECT3DTEXTURE8 pTexZPos, + LPDIRECT3DTEXTURE8 pTexZNeg) PURE; + + STDMETHOD(Face)(THIS_ D3DCUBEMAP_FACES Face) PURE; + STDMETHOD(End)(THIS) PURE; + + STDMETHOD(OnLostDevice)(THIS) PURE; + STDMETHOD(OnResetDevice)(THIS) PURE; +}; + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +HRESULT WINAPI + D3DXCreateRenderToEnvMap( + LPDIRECT3DDEVICE8 pDevice, + UINT Size, + D3DFORMAT Format, + BOOL DepthStencil, + D3DFORMAT DepthStencilFormat, + LPD3DXRenderToEnvMap* ppRenderToEnvMap); + +#ifdef __cplusplus +} +#endif //__cplusplus + + + +/////////////////////////////////////////////////////////////////////////// +// Shader assemblers: +/////////////////////////////////////////////////////////////////////////// + +//------------------------------------------------------------------------- +// D3DXASM flags: +// -------------- +// +// D3DXASM_DEBUG +// Generate debug info. +// +// D3DXASM_SKIPVALIDATION +// Do not validate the generated code against known capabilities and +// constraints. This option is only recommended when assembling shaders +// you KNOW will work. (ie. have assembled before without this option.) +//------------------------------------------------------------------------- + +#define D3DXASM_DEBUG (1 << 0) +#define D3DXASM_SKIPVALIDATION (1 << 1) + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +//------------------------------------------------------------------------- +// D3DXAssembleShader: +// ------------------- +// Assembles an ascii description of a vertex or pixel shader into +// binary form. +// +// Parameters: +// pSrcFile +// Source file name +// hSrcModule +// Module handle. if NULL, current module will be used. +// pSrcResource +// Resource name in module +// pSrcData +// Pointer to source code +// SrcDataLen +// Size of source code, in bytes +// Flags +// D3DXASM_xxx flags +// ppConstants +// Returns an ID3DXBuffer object containing constant declarations. +// ppCompiledShader +// Returns an ID3DXBuffer object containing the object code. +// ppCompilationErrors +// Returns an ID3DXBuffer object containing ascii error messages +//------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXAssembleShaderFromFileA( + LPCSTR pSrcFile, + DWORD Flags, + LPD3DXBUFFER* ppConstants, + LPD3DXBUFFER* ppCompiledShader, + LPD3DXBUFFER* ppCompilationErrors); + +HRESULT WINAPI + D3DXAssembleShaderFromFileW( + LPCWSTR pSrcFile, + DWORD Flags, + LPD3DXBUFFER* ppConstants, + LPD3DXBUFFER* ppCompiledShader, + LPD3DXBUFFER* ppCompilationErrors); + +#ifdef UNICODE +#define D3DXAssembleShaderFromFile D3DXAssembleShaderFromFileW +#else +#define D3DXAssembleShaderFromFile D3DXAssembleShaderFromFileA +#endif + +HRESULT WINAPI + D3DXAssembleShaderFromResourceA( + HMODULE hSrcModule, + LPCSTR pSrcResource, + DWORD Flags, + LPD3DXBUFFER* ppConstants, + LPD3DXBUFFER* ppCompiledShader, + LPD3DXBUFFER* ppCompilationErrors); + +HRESULT WINAPI + D3DXAssembleShaderFromResourceW( + HMODULE hSrcModule, + LPCWSTR pSrcResource, + DWORD Flags, + LPD3DXBUFFER* ppConstants, + LPD3DXBUFFER* ppCompiledShader, + LPD3DXBUFFER* ppCompilationErrors); + +#ifdef UNICODE +#define D3DXAssembleShaderFromResource D3DXAssembleShaderFromResourceW +#else +#define D3DXAssembleShaderFromResource D3DXAssembleShaderFromResourceA +#endif + +HRESULT WINAPI + D3DXAssembleShader( + LPCVOID pSrcData, + UINT SrcDataLen, + DWORD Flags, + LPD3DXBUFFER* ppConstants, + LPD3DXBUFFER* ppCompiledShader, + LPD3DXBUFFER* ppCompilationErrors); + + +#ifdef __cplusplus +} +#endif //__cplusplus + + + +/////////////////////////////////////////////////////////////////////////// +// Misc APIs: +/////////////////////////////////////////////////////////////////////////// + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +//------------------------------------------------------------------------- +// D3DXGetErrorString: +// ------------------ +// Returns the error string for given an hresult. Interprets all D3DX and +// D3D hresults. +// +// Parameters: +// hr +// The error code to be deciphered. +// pBuffer +// Pointer to the buffer to be filled in. +// BufferLen +// Count of characters in buffer. Any error message longer than this +// length will be truncated to fit. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXGetErrorStringA( + HRESULT hr, + LPSTR pBuffer, + UINT BufferLen); + +HRESULT WINAPI + D3DXGetErrorStringW( + HRESULT hr, + LPWSTR pBuffer, + UINT BufferLen); + +#ifdef UNICODE +#define D3DXGetErrorString D3DXGetErrorStringW +#else +#define D3DXGetErrorString D3DXGetErrorStringA +#endif + + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif //__D3DX8CORE_H__ diff --git a/plugins/ADK/d3d8/includes/d3dx8effect.h b/plugins/ADK/d3d8/includes/d3dx8effect.h new file mode 100644 index 0000000..97c44df --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8effect.h @@ -0,0 +1,226 @@ +/////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8effect.h +// Content: D3DX effect types and functions +// +/////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8EFFECT_H__ +#define __D3DX8EFFECT_H__ + + +#define D3DXFX_DONOTSAVESTATE (1 << 0) + + +typedef enum _D3DXPARAMETERTYPE +{ + D3DXPT_DWORD = 0, + D3DXPT_FLOAT = 1, + D3DXPT_VECTOR = 2, + D3DXPT_MATRIX = 3, + D3DXPT_TEXTURE = 4, + D3DXPT_VERTEXSHADER = 5, + D3DXPT_PIXELSHADER = 6, + D3DXPT_CONSTANT = 7, + D3DXPT_STRING = 8, + D3DXPT_FORCE_DWORD = 0x7fffffff /* force 32-bit size enum */ + +} D3DXPARAMETERTYPE; + + +typedef struct _D3DXEFFECT_DESC +{ + UINT Parameters; + UINT Techniques; + +} D3DXEFFECT_DESC; + + +typedef struct _D3DXPARAMETER_DESC +{ + LPCSTR Name; + LPCSTR Index; + D3DXPARAMETERTYPE Type; + +} D3DXPARAMETER_DESC; + + +typedef struct _D3DXTECHNIQUE_DESC +{ + LPCSTR Name; + LPCSTR Index; + UINT Passes; + +} D3DXTECHNIQUE_DESC; + + +typedef struct _D3DXPASS_DESC +{ + LPCSTR Name; + LPCSTR Index; + +} D3DXPASS_DESC; + + + +////////////////////////////////////////////////////////////////////////////// +// ID3DXEffect /////////////////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + +typedef interface ID3DXEffect ID3DXEffect; +typedef interface ID3DXEffect *LPD3DXEFFECT; + +// {648B1CEB-8D4E-4d66-B6FA-E44969E82E89} +DEFINE_GUID( IID_ID3DXEffect, +0x648b1ceb, 0x8d4e, 0x4d66, 0xb6, 0xfa, 0xe4, 0x49, 0x69, 0xe8, 0x2e, 0x89); + + +#undef INTERFACE +#define INTERFACE ID3DXEffect + +DECLARE_INTERFACE_(ID3DXEffect, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXEffect + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(GetDesc)(THIS_ D3DXEFFECT_DESC* pDesc) PURE; + STDMETHOD(GetParameterDesc)(THIS_ LPCSTR pParameter, D3DXPARAMETER_DESC* pDesc) PURE; + STDMETHOD(GetTechniqueDesc)(THIS_ LPCSTR pTechnique, D3DXTECHNIQUE_DESC* pDesc) PURE; + STDMETHOD(GetPassDesc)(THIS_ LPCSTR pTechnique, LPCSTR pPass, D3DXPASS_DESC* pDesc) PURE; + STDMETHOD(FindNextValidTechnique)(THIS_ LPCSTR pTechnique, D3DXTECHNIQUE_DESC* pDesc) PURE; + STDMETHOD(CloneEffect)(THIS_ LPDIRECT3DDEVICE8 pDevice, LPD3DXEFFECT* ppEffect) PURE; + STDMETHOD(GetCompiledEffect)(THIS_ LPD3DXBUFFER* ppCompiledEffect) PURE; + + STDMETHOD(SetTechnique)(THIS_ LPCSTR pTechnique) PURE; + STDMETHOD(GetTechnique)(THIS_ LPCSTR* ppTechnique) PURE; + + STDMETHOD(SetDword)(THIS_ LPCSTR pParameter, DWORD dw) PURE; + STDMETHOD(GetDword)(THIS_ LPCSTR pParameter, DWORD* pdw) PURE; + STDMETHOD(SetFloat)(THIS_ LPCSTR pParameter, FLOAT f) PURE; + STDMETHOD(GetFloat)(THIS_ LPCSTR pParameter, FLOAT* pf) PURE; + STDMETHOD(SetVector)(THIS_ LPCSTR pParameter, CONST D3DXVECTOR4* pVector) PURE; + STDMETHOD(GetVector)(THIS_ LPCSTR pParameter, D3DXVECTOR4* pVector) PURE; + STDMETHOD(SetMatrix)(THIS_ LPCSTR pParameter, CONST D3DXMATRIX* pMatrix) PURE; + STDMETHOD(GetMatrix)(THIS_ LPCSTR pParameter, D3DXMATRIX* pMatrix) PURE; + STDMETHOD(SetTexture)(THIS_ LPCSTR pParameter, LPDIRECT3DBASETEXTURE8 pTexture) PURE; + STDMETHOD(GetTexture)(THIS_ LPCSTR pParameter, LPDIRECT3DBASETEXTURE8 *ppTexture) PURE; + STDMETHOD(SetVertexShader)(THIS_ LPCSTR pParameter, DWORD Handle) PURE; + STDMETHOD(GetVertexShader)(THIS_ LPCSTR pParameter, DWORD* pHandle) PURE; + STDMETHOD(SetPixelShader)(THIS_ LPCSTR pParameter, DWORD Handle) PURE; + STDMETHOD(GetPixelShader)(THIS_ LPCSTR pParameter, DWORD* pHandle) PURE; + STDMETHOD(SetString)(THIS_ LPCSTR pParameter, LPCSTR pString) PURE; + STDMETHOD(GetString)(THIS_ LPCSTR pParameter, LPCSTR* ppString) PURE; + STDMETHOD_(BOOL, IsParameterUsed)(THIS_ LPCSTR pParameter) PURE; + + STDMETHOD(Validate)(THIS) PURE; + STDMETHOD(Begin)(THIS_ UINT *pPasses, DWORD Flags) PURE; + STDMETHOD(Pass)(THIS_ UINT Pass) PURE; + STDMETHOD(End)(THIS) PURE; + STDMETHOD(OnLostDevice)(THIS) PURE; + STDMETHOD(OnResetDevice)(THIS) PURE; +}; + + + +////////////////////////////////////////////////////////////////////////////// +// APIs ////////////////////////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + + +//---------------------------------------------------------------------------- +// D3DXCreateEffect: +// ----------------- +// Creates an effect from an ascii or binaray effect description. +// +// Parameters: +// pDevice +// Pointer of the device on which to create the effect +// pSrcFile +// Name of the file containing the effect description +// hSrcModule +// Module handle. if NULL, current module will be used. +// pSrcResource +// Resource name in module +// pSrcData +// Pointer to effect description +// SrcDataSize +// Size of the effect description in bytes +// ppEffect +// Returns a buffer containing created effect. +// ppCompilationErrors +// Returns a buffer containing any error messages which occurred during +// compile. Or NULL if you do not care about the error messages. +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXCreateEffectFromFileA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + LPD3DXEFFECT* ppEffect, + LPD3DXBUFFER* ppCompilationErrors); + +HRESULT WINAPI + D3DXCreateEffectFromFileW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + LPD3DXEFFECT* ppEffect, + LPD3DXBUFFER* ppCompilationErrors); + +#ifdef UNICODE +#define D3DXCreateEffectFromFile D3DXCreateEffectFromFileW +#else +#define D3DXCreateEffectFromFile D3DXCreateEffectFromFileA +#endif + + +HRESULT WINAPI + D3DXCreateEffectFromResourceA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + LPD3DXEFFECT* ppEffect, + LPD3DXBUFFER* ppCompilationErrors); + +HRESULT WINAPI + D3DXCreateEffectFromResourceW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + LPD3DXEFFECT* ppEffect, + LPD3DXBUFFER* ppCompilationErrors); + +#ifdef UNICODE +#define D3DXCreateEffectFromResource D3DXCreateEffectFromResourceW +#else +#define D3DXCreateEffectFromResource D3DXCreateEffectFromResourceA +#endif + + +HRESULT WINAPI + D3DXCreateEffect( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + LPD3DXEFFECT* ppEffect, + LPD3DXBUFFER* ppCompilationErrors); + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif //__D3DX8EFFECT_H__ diff --git a/plugins/ADK/d3d8/includes/d3dx8math.h b/plugins/ADK/d3d8/includes/d3dx8math.h new file mode 100644 index 0000000..9c8f203 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8math.h @@ -0,0 +1,1215 @@ +////////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8math.h +// Content: D3DX math types and functions +// +////////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8MATH_H__ +#define __D3DX8MATH_H__ + +#include +#pragma warning(disable:4201) // anonymous unions warning + + + +//=========================================================================== +// +// General purpose utilities +// +//=========================================================================== +#define D3DX_PI ((FLOAT) 3.141592654f) +#define D3DX_1BYPI ((FLOAT) 0.318309886f) + +#define D3DXToRadian( degree ) ((degree) * (D3DX_PI / 180.0f)) +#define D3DXToDegree( radian ) ((radian) * (180.0f / D3DX_PI)) + + + +//=========================================================================== +// +// Vectors +// +//=========================================================================== + +//-------------------------- +// 2D Vector +//-------------------------- +typedef struct D3DXVECTOR2 +{ +#ifdef __cplusplus +public: + D3DXVECTOR2() {}; + D3DXVECTOR2( CONST FLOAT * ); + D3DXVECTOR2( FLOAT x, FLOAT y ); + + // casting + operator FLOAT* (); + operator CONST FLOAT* () const; + + // assignment operators + D3DXVECTOR2& operator += ( CONST D3DXVECTOR2& ); + D3DXVECTOR2& operator -= ( CONST D3DXVECTOR2& ); + D3DXVECTOR2& operator *= ( FLOAT ); + D3DXVECTOR2& operator /= ( FLOAT ); + + // unary operators + D3DXVECTOR2 operator + () const; + D3DXVECTOR2 operator - () const; + + // binary operators + D3DXVECTOR2 operator + ( CONST D3DXVECTOR2& ) const; + D3DXVECTOR2 operator - ( CONST D3DXVECTOR2& ) const; + D3DXVECTOR2 operator * ( FLOAT ) const; + D3DXVECTOR2 operator / ( FLOAT ) const; + + friend D3DXVECTOR2 operator * ( FLOAT, CONST D3DXVECTOR2& ); + + BOOL operator == ( CONST D3DXVECTOR2& ) const; + BOOL operator != ( CONST D3DXVECTOR2& ) const; + + +public: +#endif //__cplusplus + FLOAT x, y; +} D3DXVECTOR2, *LPD3DXVECTOR2; + + +//-------------------------- +// 3D Vector +//-------------------------- +#ifdef __cplusplus +typedef struct D3DXVECTOR3 : public D3DVECTOR +{ +public: + D3DXVECTOR3() {}; + D3DXVECTOR3( CONST FLOAT * ); + D3DXVECTOR3( CONST D3DVECTOR& ); + D3DXVECTOR3( FLOAT x, FLOAT y, FLOAT z ); + + // casting + operator FLOAT* (); + operator CONST FLOAT* () const; + + // assignment operators + D3DXVECTOR3& operator += ( CONST D3DXVECTOR3& ); + D3DXVECTOR3& operator -= ( CONST D3DXVECTOR3& ); + D3DXVECTOR3& operator *= ( FLOAT ); + D3DXVECTOR3& operator /= ( FLOAT ); + + // unary operators + D3DXVECTOR3 operator + () const; + D3DXVECTOR3 operator - () const; + + // binary operators + D3DXVECTOR3 operator + ( CONST D3DXVECTOR3& ) const; + D3DXVECTOR3 operator - ( CONST D3DXVECTOR3& ) const; + D3DXVECTOR3 operator * ( FLOAT ) const; + D3DXVECTOR3 operator / ( FLOAT ) const; + + friend D3DXVECTOR3 operator * ( FLOAT, CONST struct D3DXVECTOR3& ); + + BOOL operator == ( CONST D3DXVECTOR3& ) const; + BOOL operator != ( CONST D3DXVECTOR3& ) const; + +} D3DXVECTOR3, *LPD3DXVECTOR3; + +#else //!__cplusplus +typedef struct _D3DVECTOR D3DXVECTOR3, *LPD3DXVECTOR3; +#endif //!__cplusplus + + +//-------------------------- +// 4D Vector +//-------------------------- +typedef struct D3DXVECTOR4 +{ +#ifdef __cplusplus +public: + D3DXVECTOR4() {}; + D3DXVECTOR4( CONST FLOAT* ); + D3DXVECTOR4( FLOAT x, FLOAT y, FLOAT z, FLOAT w ); + + // casting + operator FLOAT* (); + operator CONST FLOAT* () const; + + // assignment operators + D3DXVECTOR4& operator += ( CONST D3DXVECTOR4& ); + D3DXVECTOR4& operator -= ( CONST D3DXVECTOR4& ); + D3DXVECTOR4& operator *= ( FLOAT ); + D3DXVECTOR4& operator /= ( FLOAT ); + + // unary operators + D3DXVECTOR4 operator + () const; + D3DXVECTOR4 operator - () const; + + // binary operators + D3DXVECTOR4 operator + ( CONST D3DXVECTOR4& ) const; + D3DXVECTOR4 operator - ( CONST D3DXVECTOR4& ) const; + D3DXVECTOR4 operator * ( FLOAT ) const; + D3DXVECTOR4 operator / ( FLOAT ) const; + + friend D3DXVECTOR4 operator * ( FLOAT, CONST D3DXVECTOR4& ); + + BOOL operator == ( CONST D3DXVECTOR4& ) const; + BOOL operator != ( CONST D3DXVECTOR4& ) const; + +public: +#endif //__cplusplus + FLOAT x, y, z, w; +} D3DXVECTOR4, *LPD3DXVECTOR4; + + +//=========================================================================== +// +// Matrices +// +//=========================================================================== +#ifdef __cplusplus +typedef struct D3DXMATRIX : public D3DMATRIX +{ +public: + D3DXMATRIX() {}; + D3DXMATRIX( CONST FLOAT * ); + D3DXMATRIX( CONST D3DMATRIX& ); + D3DXMATRIX( FLOAT _11, FLOAT _12, FLOAT _13, FLOAT _14, + FLOAT _21, FLOAT _22, FLOAT _23, FLOAT _24, + FLOAT _31, FLOAT _32, FLOAT _33, FLOAT _34, + FLOAT _41, FLOAT _42, FLOAT _43, FLOAT _44 ); + + + // access grants + FLOAT& operator () ( UINT Row, UINT Col ); + FLOAT operator () ( UINT Row, UINT Col ) const; + + // casting operators + operator FLOAT* (); + operator CONST FLOAT* () const; + + // assignment operators + D3DXMATRIX& operator *= ( CONST D3DXMATRIX& ); + D3DXMATRIX& operator += ( CONST D3DXMATRIX& ); + D3DXMATRIX& operator -= ( CONST D3DXMATRIX& ); + D3DXMATRIX& operator *= ( FLOAT ); + D3DXMATRIX& operator /= ( FLOAT ); + + // unary operators + D3DXMATRIX operator + () const; + D3DXMATRIX operator - () const; + + // binary operators + D3DXMATRIX operator * ( CONST D3DXMATRIX& ) const; + D3DXMATRIX operator + ( CONST D3DXMATRIX& ) const; + D3DXMATRIX operator - ( CONST D3DXMATRIX& ) const; + D3DXMATRIX operator * ( FLOAT ) const; + D3DXMATRIX operator / ( FLOAT ) const; + + friend D3DXMATRIX operator * ( FLOAT, CONST D3DXMATRIX& ); + + BOOL operator == ( CONST D3DXMATRIX& ) const; + BOOL operator != ( CONST D3DXMATRIX& ) const; + +} D3DXMATRIX, *LPD3DXMATRIX; + +#else //!__cplusplus +typedef struct _D3DMATRIX D3DXMATRIX, *LPD3DXMATRIX; +#endif //!__cplusplus + +//=========================================================================== +// +// Aligned Matrices +// +// This class helps keep matrices 16-byte aligned as preferred by P4 cpus. +// It aligns matrices on the stack and on the heap or in global scope. +// It does this using __declspec(align(16)) which works on VC7 and on VC 6 +// with the processor pack. Unfortunately there is no way to detect the +// latter so this is turned on only on VC7. On other compilers this is the +// the same as D3DXMATRIX. +// Using this class on a compiler that does not actually do the alignment +// can be dangerous since it will not expose bugs that ignore alignment. +// E.g if an object of this class in inside a struct or class, and some code +// memcopys data in it assuming tight packing. This could break on a compiler +// that eventually start aligning the matrix. +// +//=========================================================================== +#ifdef __cplusplus +typedef struct _D3DXMATRIXA16 : public D3DXMATRIX +{ + _D3DXMATRIXA16() {} + _D3DXMATRIXA16( CONST FLOAT * f): D3DXMATRIX(f) {} + _D3DXMATRIXA16( CONST D3DMATRIX& m): D3DXMATRIX(m) {} + _D3DXMATRIXA16( FLOAT _11, FLOAT _12, FLOAT _13, FLOAT _14, + FLOAT _21, FLOAT _22, FLOAT _23, FLOAT _24, + FLOAT _31, FLOAT _32, FLOAT _33, FLOAT _34, + FLOAT _41, FLOAT _42, FLOAT _43, FLOAT _44 ) : + D3DXMATRIX(_11, _12, _13, _14, + _21, _22, _23, _24, + _31, _32, _33, _34, + _41, _42, _43, _44) {} + void* operator new(size_t s) + { + LPBYTE p = ::new BYTE[s + 16]; + if (p) + { + BYTE offset = (BYTE)(16 - ((UINT_PTR)p & 15)); + p += offset; + p[-1] = offset; + } + return p; + }; + + void* operator new[](size_t s) + { + LPBYTE p = ::new BYTE[s + 16]; + if (p) + { + BYTE offset = (BYTE)(16 - ((UINT_PTR)p & 15)); + p += offset; + p[-1] = offset; + } + return p; + }; + + // This is NOT a virtual operator. If you cast + // to D3DXMATRIX, do not delete using that + void operator delete(void* p) + { + if(p) + { + BYTE* pb = static_cast(p); + pb -= pb[-1]; + ::delete [] pb; + } + }; + + // This is NOT a virtual operator. If you cast + // to D3DXMATRIX, do not delete using that + void operator delete[](void* p) + { + if(p) + { + BYTE* pb = static_cast(p); + pb -= pb[-1]; + ::delete [] pb; + } + }; + + struct _D3DXMATRIXA16& operator=(CONST D3DXMATRIX& rhs) + { + memcpy(&_11, &rhs, sizeof(D3DXMATRIX)); + return *this; + }; +} _D3DXMATRIXA16; + +#else //!__cplusplus +typedef D3DXMATRIX _D3DXMATRIXA16; +#endif //!__cplusplus + +#if _MSC_VER >= 1300 // VC7 +#define _ALIGN_16 __declspec(align(16)) +#else +#define _ALIGN_16 // Earlier compiler may not understand this, do nothing. +#endif + +#define D3DXMATRIXA16 _ALIGN_16 _D3DXMATRIXA16 + +typedef D3DXMATRIXA16 *LPD3DXMATRIXA16; + +//=========================================================================== +// +// Quaternions +// +//=========================================================================== +typedef struct D3DXQUATERNION +{ +#ifdef __cplusplus +public: + D3DXQUATERNION() {} + D3DXQUATERNION( CONST FLOAT * ); + D3DXQUATERNION( FLOAT x, FLOAT y, FLOAT z, FLOAT w ); + + // casting + operator FLOAT* (); + operator CONST FLOAT* () const; + + // assignment operators + D3DXQUATERNION& operator += ( CONST D3DXQUATERNION& ); + D3DXQUATERNION& operator -= ( CONST D3DXQUATERNION& ); + D3DXQUATERNION& operator *= ( CONST D3DXQUATERNION& ); + D3DXQUATERNION& operator *= ( FLOAT ); + D3DXQUATERNION& operator /= ( FLOAT ); + + // unary operators + D3DXQUATERNION operator + () const; + D3DXQUATERNION operator - () const; + + // binary operators + D3DXQUATERNION operator + ( CONST D3DXQUATERNION& ) const; + D3DXQUATERNION operator - ( CONST D3DXQUATERNION& ) const; + D3DXQUATERNION operator * ( CONST D3DXQUATERNION& ) const; + D3DXQUATERNION operator * ( FLOAT ) const; + D3DXQUATERNION operator / ( FLOAT ) const; + + friend D3DXQUATERNION operator * (FLOAT, CONST D3DXQUATERNION& ); + + BOOL operator == ( CONST D3DXQUATERNION& ) const; + BOOL operator != ( CONST D3DXQUATERNION& ) const; + +#endif //__cplusplus + FLOAT x, y, z, w; +} D3DXQUATERNION, *LPD3DXQUATERNION; + + +//=========================================================================== +// +// Planes +// +//=========================================================================== +typedef struct D3DXPLANE +{ +#ifdef __cplusplus +public: + D3DXPLANE() {} + D3DXPLANE( CONST FLOAT* ); + D3DXPLANE( FLOAT a, FLOAT b, FLOAT c, FLOAT d ); + + // casting + operator FLOAT* (); + operator CONST FLOAT* () const; + + // unary operators + D3DXPLANE operator + () const; + D3DXPLANE operator - () const; + + // binary operators + BOOL operator == ( CONST D3DXPLANE& ) const; + BOOL operator != ( CONST D3DXPLANE& ) const; + +#endif //__cplusplus + FLOAT a, b, c, d; +} D3DXPLANE, *LPD3DXPLANE; + + +//=========================================================================== +// +// Colors +// +//=========================================================================== + +typedef struct D3DXCOLOR +{ +#ifdef __cplusplus +public: + D3DXCOLOR() {} + D3DXCOLOR( DWORD argb ); + D3DXCOLOR( CONST FLOAT * ); + D3DXCOLOR( CONST D3DCOLORVALUE& ); + D3DXCOLOR( FLOAT r, FLOAT g, FLOAT b, FLOAT a ); + + // casting + operator DWORD () const; + + operator FLOAT* (); + operator CONST FLOAT* () const; + + operator D3DCOLORVALUE* (); + operator CONST D3DCOLORVALUE* () const; + + operator D3DCOLORVALUE& (); + operator CONST D3DCOLORVALUE& () const; + + // assignment operators + D3DXCOLOR& operator += ( CONST D3DXCOLOR& ); + D3DXCOLOR& operator -= ( CONST D3DXCOLOR& ); + D3DXCOLOR& operator *= ( FLOAT ); + D3DXCOLOR& operator /= ( FLOAT ); + + // unary operators + D3DXCOLOR operator + () const; + D3DXCOLOR operator - () const; + + // binary operators + D3DXCOLOR operator + ( CONST D3DXCOLOR& ) const; + D3DXCOLOR operator - ( CONST D3DXCOLOR& ) const; + D3DXCOLOR operator * ( FLOAT ) const; + D3DXCOLOR operator / ( FLOAT ) const; + + friend D3DXCOLOR operator * (FLOAT, CONST D3DXCOLOR& ); + + BOOL operator == ( CONST D3DXCOLOR& ) const; + BOOL operator != ( CONST D3DXCOLOR& ) const; + +#endif //__cplusplus + FLOAT r, g, b, a; +} D3DXCOLOR, *LPD3DXCOLOR; + + + +//=========================================================================== +// +// D3DX math functions: +// +// NOTE: +// * All these functions can take the same object as in and out parameters. +// +// * Out parameters are typically also returned as return values, so that +// the output of one function may be used as a parameter to another. +// +//=========================================================================== + +//-------------------------- +// 2D Vector +//-------------------------- + +// inline + +FLOAT D3DXVec2Length + ( CONST D3DXVECTOR2 *pV ); + +FLOAT D3DXVec2LengthSq + ( CONST D3DXVECTOR2 *pV ); + +FLOAT D3DXVec2Dot + ( CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +// Z component of ((x1,y1,0) cross (x2,y2,0)) +FLOAT D3DXVec2CCW + ( CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +D3DXVECTOR2* D3DXVec2Add + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +D3DXVECTOR2* D3DXVec2Subtract + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +// Minimize each component. x = min(x1, x2), y = min(y1, y2) +D3DXVECTOR2* D3DXVec2Minimize + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +// Maximize each component. x = max(x1, x2), y = max(y1, y2) +D3DXVECTOR2* D3DXVec2Maximize + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ); + +D3DXVECTOR2* D3DXVec2Scale + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV, FLOAT s ); + +// Linear interpolation. V1 + s(V2-V1) +D3DXVECTOR2* D3DXVec2Lerp + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2, + FLOAT s ); + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +D3DXVECTOR2* WINAPI D3DXVec2Normalize + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV ); + +// Hermite interpolation between position V1, tangent T1 (when s == 0) +// and position V2, tangent T2 (when s == 1). +D3DXVECTOR2* WINAPI D3DXVec2Hermite + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pT1, + CONST D3DXVECTOR2 *pV2, CONST D3DXVECTOR2 *pT2, FLOAT s ); + +// CatmullRom interpolation between V1 (when s == 0) and V2 (when s == 1) +D3DXVECTOR2* WINAPI D3DXVec2CatmullRom + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV0, CONST D3DXVECTOR2 *pV1, + CONST D3DXVECTOR2 *pV2, CONST D3DXVECTOR2 *pV3, FLOAT s ); + +// Barycentric coordinates. V1 + f(V2-V1) + g(V3-V1) +D3DXVECTOR2* WINAPI D3DXVec2BaryCentric + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2, + CONST D3DXVECTOR2 *pV3, FLOAT f, FLOAT g); + +// Transform (x, y, 0, 1) by matrix. +D3DXVECTOR4* WINAPI D3DXVec2Transform + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR2 *pV, CONST D3DXMATRIX *pM ); + +// Transform (x, y, 0, 1) by matrix, project result back into w=1. +D3DXVECTOR2* WINAPI D3DXVec2TransformCoord + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV, CONST D3DXMATRIX *pM ); + +// Transform (x, y, 0, 0) by matrix. +D3DXVECTOR2* WINAPI D3DXVec2TransformNormal + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV, CONST D3DXMATRIX *pM ); + +#ifdef __cplusplus +} +#endif + + +//-------------------------- +// 3D Vector +//-------------------------- + +// inline + +FLOAT D3DXVec3Length + ( CONST D3DXVECTOR3 *pV ); + +FLOAT D3DXVec3LengthSq + ( CONST D3DXVECTOR3 *pV ); + +FLOAT D3DXVec3Dot + ( CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +D3DXVECTOR3* D3DXVec3Cross + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +D3DXVECTOR3* D3DXVec3Add + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +D3DXVECTOR3* D3DXVec3Subtract + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +// Minimize each component. x = min(x1, x2), y = min(y1, y2), ... +D3DXVECTOR3* D3DXVec3Minimize + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +// Maximize each component. x = max(x1, x2), y = max(y1, y2), ... +D3DXVECTOR3* D3DXVec3Maximize + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ); + +D3DXVECTOR3* D3DXVec3Scale + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, FLOAT s); + +// Linear interpolation. V1 + s(V2-V1) +D3DXVECTOR3* D3DXVec3Lerp + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2, + FLOAT s ); + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +D3DXVECTOR3* WINAPI D3DXVec3Normalize + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV ); + +// Hermite interpolation between position V1, tangent T1 (when s == 0) +// and position V2, tangent T2 (when s == 1). +D3DXVECTOR3* WINAPI D3DXVec3Hermite + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pT1, + CONST D3DXVECTOR3 *pV2, CONST D3DXVECTOR3 *pT2, FLOAT s ); + +// CatmullRom interpolation between V1 (when s == 0) and V2 (when s == 1) +D3DXVECTOR3* WINAPI D3DXVec3CatmullRom + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV0, CONST D3DXVECTOR3 *pV1, + CONST D3DXVECTOR3 *pV2, CONST D3DXVECTOR3 *pV3, FLOAT s ); + +// Barycentric coordinates. V1 + f(V2-V1) + g(V3-V1) +D3DXVECTOR3* WINAPI D3DXVec3BaryCentric + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2, + CONST D3DXVECTOR3 *pV3, FLOAT f, FLOAT g); + +// Transform (x, y, z, 1) by matrix. +D3DXVECTOR4* WINAPI D3DXVec3Transform + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR3 *pV, CONST D3DXMATRIX *pM ); + +// Transform (x, y, z, 1) by matrix, project result back into w=1. +D3DXVECTOR3* WINAPI D3DXVec3TransformCoord + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, CONST D3DXMATRIX *pM ); + +// Transform (x, y, z, 0) by matrix. If you transforming a normal by a +// non-affine matrix, the matrix you pass to this function should be the +// transpose of the inverse of the matrix you would use to transform a coord. +D3DXVECTOR3* WINAPI D3DXVec3TransformNormal + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, CONST D3DXMATRIX *pM ); + +// Project vector from object space into screen space +D3DXVECTOR3* WINAPI D3DXVec3Project + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, CONST D3DVIEWPORT8 *pViewport, + CONST D3DXMATRIX *pProjection, CONST D3DXMATRIX *pView, CONST D3DXMATRIX *pWorld); + +// Project vector from screen space into object space +D3DXVECTOR3* WINAPI D3DXVec3Unproject + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, CONST D3DVIEWPORT8 *pViewport, + CONST D3DXMATRIX *pProjection, CONST D3DXMATRIX *pView, CONST D3DXMATRIX *pWorld); + +#ifdef __cplusplus +} +#endif + + + +//-------------------------- +// 4D Vector +//-------------------------- + +// inline + +FLOAT D3DXVec4Length + ( CONST D3DXVECTOR4 *pV ); + +FLOAT D3DXVec4LengthSq + ( CONST D3DXVECTOR4 *pV ); + +FLOAT D3DXVec4Dot + ( CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2 ); + +D3DXVECTOR4* D3DXVec4Add + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2); + +D3DXVECTOR4* D3DXVec4Subtract + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2); + +// Minimize each component. x = min(x1, x2), y = min(y1, y2), ... +D3DXVECTOR4* D3DXVec4Minimize + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2); + +// Maximize each component. x = max(x1, x2), y = max(y1, y2), ... +D3DXVECTOR4* D3DXVec4Maximize + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2); + +D3DXVECTOR4* D3DXVec4Scale + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV, FLOAT s); + +// Linear interpolation. V1 + s(V2-V1) +D3DXVECTOR4* D3DXVec4Lerp + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2, + FLOAT s ); + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +// Cross-product in 4 dimensions. +D3DXVECTOR4* WINAPI D3DXVec4Cross + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2, + CONST D3DXVECTOR4 *pV3); + +D3DXVECTOR4* WINAPI D3DXVec4Normalize + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV ); + +// Hermite interpolation between position V1, tangent T1 (when s == 0) +// and position V2, tangent T2 (when s == 1). +D3DXVECTOR4* WINAPI D3DXVec4Hermite + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pT1, + CONST D3DXVECTOR4 *pV2, CONST D3DXVECTOR4 *pT2, FLOAT s ); + +// CatmullRom interpolation between V1 (when s == 0) and V2 (when s == 1) +D3DXVECTOR4* WINAPI D3DXVec4CatmullRom + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV0, CONST D3DXVECTOR4 *pV1, + CONST D3DXVECTOR4 *pV2, CONST D3DXVECTOR4 *pV3, FLOAT s ); + +// Barycentric coordinates. V1 + f(V2-V1) + g(V3-V1) +D3DXVECTOR4* WINAPI D3DXVec4BaryCentric + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2, + CONST D3DXVECTOR4 *pV3, FLOAT f, FLOAT g); + +// Transform vector by matrix. +D3DXVECTOR4* WINAPI D3DXVec4Transform + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV, CONST D3DXMATRIX *pM ); + +#ifdef __cplusplus +} +#endif + + +//-------------------------- +// 4D Matrix +//-------------------------- + +// inline + +D3DXMATRIX* D3DXMatrixIdentity + ( D3DXMATRIX *pOut ); + +BOOL D3DXMatrixIsIdentity + ( CONST D3DXMATRIX *pM ); + + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +FLOAT WINAPI D3DXMatrixfDeterminant + ( CONST D3DXMATRIX *pM ); + +D3DXMATRIX* WINAPI D3DXMatrixTranspose + ( D3DXMATRIX *pOut, CONST D3DXMATRIX *pM ); + +// Matrix multiplication. The result represents the transformation M2 +// followed by the transformation M1. (Out = M1 * M2) +D3DXMATRIX* WINAPI D3DXMatrixMultiply + ( D3DXMATRIX *pOut, CONST D3DXMATRIX *pM1, CONST D3DXMATRIX *pM2 ); + +// Matrix multiplication, followed by a transpose. (Out = T(M1 * M2)) +D3DXMATRIX* WINAPI D3DXMatrixMultiplyTranspose + ( D3DXMATRIX *pOut, CONST D3DXMATRIX *pM1, CONST D3DXMATRIX *pM2 ); + +// Calculate inverse of matrix. Inversion my fail, in which case NULL will +// be returned. The determinant of pM is also returned it pfDeterminant +// is non-NULL. +D3DXMATRIX* WINAPI D3DXMatrixInverse + ( D3DXMATRIX *pOut, FLOAT *pDeterminant, CONST D3DXMATRIX *pM ); + +// Build a matrix which scales by (sx, sy, sz) +D3DXMATRIX* WINAPI D3DXMatrixScaling + ( D3DXMATRIX *pOut, FLOAT sx, FLOAT sy, FLOAT sz ); + +// Build a matrix which translates by (x, y, z) +D3DXMATRIX* WINAPI D3DXMatrixTranslation + ( D3DXMATRIX *pOut, FLOAT x, FLOAT y, FLOAT z ); + +// Build a matrix which rotates around the X axis +D3DXMATRIX* WINAPI D3DXMatrixRotationX + ( D3DXMATRIX *pOut, FLOAT Angle ); + +// Build a matrix which rotates around the Y axis +D3DXMATRIX* WINAPI D3DXMatrixRotationY + ( D3DXMATRIX *pOut, FLOAT Angle ); + +// Build a matrix which rotates around the Z axis +D3DXMATRIX* WINAPI D3DXMatrixRotationZ + ( D3DXMATRIX *pOut, FLOAT Angle ); + +// Build a matrix which rotates around an arbitrary axis +D3DXMATRIX* WINAPI D3DXMatrixRotationAxis + ( D3DXMATRIX *pOut, CONST D3DXVECTOR3 *pV, FLOAT Angle ); + +// Build a matrix from a quaternion +D3DXMATRIX* WINAPI D3DXMatrixRotationQuaternion + ( D3DXMATRIX *pOut, CONST D3DXQUATERNION *pQ); + +// Yaw around the Y axis, a pitch around the X axis, +// and a roll around the Z axis. +D3DXMATRIX* WINAPI D3DXMatrixRotationYawPitchRoll + ( D3DXMATRIX *pOut, FLOAT Yaw, FLOAT Pitch, FLOAT Roll ); + + +// Build transformation matrix. NULL arguments are treated as identity. +// Mout = Msc-1 * Msr-1 * Ms * Msr * Msc * Mrc-1 * Mr * Mrc * Mt +D3DXMATRIX* WINAPI D3DXMatrixTransformation + ( D3DXMATRIX *pOut, CONST D3DXVECTOR3 *pScalingCenter, + CONST D3DXQUATERNION *pScalingRotation, CONST D3DXVECTOR3 *pScaling, + CONST D3DXVECTOR3 *pRotationCenter, CONST D3DXQUATERNION *pRotation, + CONST D3DXVECTOR3 *pTranslation); + +// Build affine transformation matrix. NULL arguments are treated as identity. +// Mout = Ms * Mrc-1 * Mr * Mrc * Mt +D3DXMATRIX* WINAPI D3DXMatrixAffineTransformation + ( D3DXMATRIX *pOut, FLOAT Scaling, CONST D3DXVECTOR3 *pRotationCenter, + CONST D3DXQUATERNION *pRotation, CONST D3DXVECTOR3 *pTranslation); + +// Build a lookat matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixLookAtRH + ( D3DXMATRIX *pOut, CONST D3DXVECTOR3 *pEye, CONST D3DXVECTOR3 *pAt, + CONST D3DXVECTOR3 *pUp ); + +// Build a lookat matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixLookAtLH + ( D3DXMATRIX *pOut, CONST D3DXVECTOR3 *pEye, CONST D3DXVECTOR3 *pAt, + CONST D3DXVECTOR3 *pUp ); + +// Build a perspective projection matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveRH + ( D3DXMATRIX *pOut, FLOAT w, FLOAT h, FLOAT zn, FLOAT zf ); + +// Build a perspective projection matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveLH + ( D3DXMATRIX *pOut, FLOAT w, FLOAT h, FLOAT zn, FLOAT zf ); + +// Build a perspective projection matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveFovRH + ( D3DXMATRIX *pOut, FLOAT fovy, FLOAT Aspect, FLOAT zn, FLOAT zf ); + +// Build a perspective projection matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveFovLH + ( D3DXMATRIX *pOut, FLOAT fovy, FLOAT Aspect, FLOAT zn, FLOAT zf ); + +// Build a perspective projection matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveOffCenterRH + ( D3DXMATRIX *pOut, FLOAT l, FLOAT r, FLOAT b, FLOAT t, FLOAT zn, + FLOAT zf ); + +// Build a perspective projection matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixPerspectiveOffCenterLH + ( D3DXMATRIX *pOut, FLOAT l, FLOAT r, FLOAT b, FLOAT t, FLOAT zn, + FLOAT zf ); + +// Build an ortho projection matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixOrthoRH + ( D3DXMATRIX *pOut, FLOAT w, FLOAT h, FLOAT zn, FLOAT zf ); + +// Build an ortho projection matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixOrthoLH + ( D3DXMATRIX *pOut, FLOAT w, FLOAT h, FLOAT zn, FLOAT zf ); + +// Build an ortho projection matrix. (right-handed) +D3DXMATRIX* WINAPI D3DXMatrixOrthoOffCenterRH + ( D3DXMATRIX *pOut, FLOAT l, FLOAT r, FLOAT b, FLOAT t, FLOAT zn, + FLOAT zf ); + +// Build an ortho projection matrix. (left-handed) +D3DXMATRIX* WINAPI D3DXMatrixOrthoOffCenterLH + ( D3DXMATRIX *pOut, FLOAT l, FLOAT r, FLOAT b, FLOAT t, FLOAT zn, + FLOAT zf ); + +// Build a matrix which flattens geometry into a plane, as if casting +// a shadow from a light. +D3DXMATRIX* WINAPI D3DXMatrixShadow + ( D3DXMATRIX *pOut, CONST D3DXVECTOR4 *pLight, + CONST D3DXPLANE *pPlane ); + +// Build a matrix which reflects the coordinate system about a plane +D3DXMATRIX* WINAPI D3DXMatrixReflect + ( D3DXMATRIX *pOut, CONST D3DXPLANE *pPlane ); + +#ifdef __cplusplus +} +#endif + + +//-------------------------- +// Quaternion +//-------------------------- + +// inline + +FLOAT D3DXQuaternionLength + ( CONST D3DXQUATERNION *pQ ); + +// Length squared, or "norm" +FLOAT D3DXQuaternionLengthSq + ( CONST D3DXQUATERNION *pQ ); + +FLOAT D3DXQuaternionDot + ( CONST D3DXQUATERNION *pQ1, CONST D3DXQUATERNION *pQ2 ); + +// (0, 0, 0, 1) +D3DXQUATERNION* D3DXQuaternionIdentity + ( D3DXQUATERNION *pOut ); + +BOOL D3DXQuaternionIsIdentity + ( CONST D3DXQUATERNION *pQ ); + +// (-x, -y, -z, w) +D3DXQUATERNION* D3DXQuaternionConjugate + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ); + + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +// Compute a quaternin's axis and angle of rotation. Expects unit quaternions. +void WINAPI D3DXQuaternionToAxisAngle + ( CONST D3DXQUATERNION *pQ, D3DXVECTOR3 *pAxis, FLOAT *pAngle ); + +// Build a quaternion from a rotation matrix. +D3DXQUATERNION* WINAPI D3DXQuaternionRotationMatrix + ( D3DXQUATERNION *pOut, CONST D3DXMATRIX *pM); + +// Rotation about arbitrary axis. +D3DXQUATERNION* WINAPI D3DXQuaternionRotationAxis + ( D3DXQUATERNION *pOut, CONST D3DXVECTOR3 *pV, FLOAT Angle ); + +// Yaw around the Y axis, a pitch around the X axis, +// and a roll around the Z axis. +D3DXQUATERNION* WINAPI D3DXQuaternionRotationYawPitchRoll + ( D3DXQUATERNION *pOut, FLOAT Yaw, FLOAT Pitch, FLOAT Roll ); + +// Quaternion multiplication. The result represents the rotation Q2 +// followed by the rotation Q1. (Out = Q2 * Q1) +D3DXQUATERNION* WINAPI D3DXQuaternionMultiply + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ1, + CONST D3DXQUATERNION *pQ2 ); + +D3DXQUATERNION* WINAPI D3DXQuaternionNormalize + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ); + +// Conjugate and re-norm +D3DXQUATERNION* WINAPI D3DXQuaternionInverse + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ); + +// Expects unit quaternions. +// if q = (cos(theta), sin(theta) * v); ln(q) = (0, theta * v) +D3DXQUATERNION* WINAPI D3DXQuaternionLn + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ); + +// Expects pure quaternions. (w == 0) w is ignored in calculation. +// if q = (0, theta * v); exp(q) = (cos(theta), sin(theta) * v) +D3DXQUATERNION* WINAPI D3DXQuaternionExp + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ); + +// Spherical linear interpolation between Q1 (t == 0) and Q2 (t == 1). +// Expects unit quaternions. +D3DXQUATERNION* WINAPI D3DXQuaternionSlerp + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ1, + CONST D3DXQUATERNION *pQ2, FLOAT t ); + +// Spherical quadrangle interpolation. +// Slerp(Slerp(Q1, C, t), Slerp(A, B, t), 2t(1-t)) +D3DXQUATERNION* WINAPI D3DXQuaternionSquad + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ1, + CONST D3DXQUATERNION *pA, CONST D3DXQUATERNION *pB, + CONST D3DXQUATERNION *pC, FLOAT t ); + +// Setup control points for spherical quadrangle interpolation +// from Q1 to Q2. The control points are chosen in such a way +// to ensure the continuity of tangents with adjacent segments. +void WINAPI D3DXQuaternionSquadSetup + ( D3DXQUATERNION *pAOut, D3DXQUATERNION *pBOut, D3DXQUATERNION *pCOut, + CONST D3DXQUATERNION *pQ0, CONST D3DXQUATERNION *pQ1, + CONST D3DXQUATERNION *pQ2, CONST D3DXQUATERNION *pQ3 ); + +// Barycentric interpolation. +// Slerp(Slerp(Q1, Q2, f+g), Slerp(Q1, Q3, f+g), g/(f+g)) +D3DXQUATERNION* WINAPI D3DXQuaternionBaryCentric + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ1, + CONST D3DXQUATERNION *pQ2, CONST D3DXQUATERNION *pQ3, + FLOAT f, FLOAT g ); + +#ifdef __cplusplus +} +#endif + + +//-------------------------- +// Plane +//-------------------------- + +// inline + +// ax + by + cz + dw +FLOAT D3DXPlaneDot + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR4 *pV); + +// ax + by + cz + d +FLOAT D3DXPlaneDotCoord + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR3 *pV); + +// ax + by + cz +FLOAT D3DXPlaneDotNormal + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR3 *pV); + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +// Normalize plane (so that |a,b,c| == 1) +D3DXPLANE* WINAPI D3DXPlaneNormalize + ( D3DXPLANE *pOut, CONST D3DXPLANE *pP); + +// Find the intersection between a plane and a line. If the line is +// parallel to the plane, NULL is returned. +D3DXVECTOR3* WINAPI D3DXPlaneIntersectLine + ( D3DXVECTOR3 *pOut, CONST D3DXPLANE *pP, CONST D3DXVECTOR3 *pV1, + CONST D3DXVECTOR3 *pV2); + +// Construct a plane from a point and a normal +D3DXPLANE* WINAPI D3DXPlaneFromPointNormal + ( D3DXPLANE *pOut, CONST D3DXVECTOR3 *pPoint, CONST D3DXVECTOR3 *pNormal); + +// Construct a plane from 3 points +D3DXPLANE* WINAPI D3DXPlaneFromPoints + ( D3DXPLANE *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2, + CONST D3DXVECTOR3 *pV3); + +// Transform a plane by a matrix. The vector (a,b,c) must be normal. +// M should be the inverse transpose of the transformation desired. +D3DXPLANE* WINAPI D3DXPlaneTransform + ( D3DXPLANE *pOut, CONST D3DXPLANE *pP, CONST D3DXMATRIX *pM ); + +#ifdef __cplusplus +} +#endif + + +//-------------------------- +// Color +//-------------------------- + +// inline + +// (1-r, 1-g, 1-b, a) +D3DXCOLOR* D3DXColorNegative + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC); + +D3DXCOLOR* D3DXColorAdd + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2); + +D3DXCOLOR* D3DXColorSubtract + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2); + +D3DXCOLOR* D3DXColorScale + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC, FLOAT s); + +// (r1*r2, g1*g2, b1*b2, a1*a2) +D3DXCOLOR* D3DXColorModulate + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2); + +// Linear interpolation of r,g,b, and a. C1 + s(C2-C1) +D3DXCOLOR* D3DXColorLerp + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2, FLOAT s); + +// non-inline +#ifdef __cplusplus +extern "C" { +#endif + +// Interpolate r,g,b between desaturated color and color. +// DesaturatedColor + s(Color - DesaturatedColor) +D3DXCOLOR* WINAPI D3DXColorAdjustSaturation + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC, FLOAT s); + +// Interpolate r,g,b between 50% grey and color. Grey + s(Color - Grey) +D3DXCOLOR* WINAPI D3DXColorAdjustContrast + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC, FLOAT c); + +#ifdef __cplusplus +} +#endif + + + + +//-------------------------- +// Misc +//-------------------------- + +#ifdef __cplusplus +extern "C" { +#endif + +// Calculate Fresnel term given the cosine of theta (likely obtained by +// taking the dot of two normals), and the refraction index of the material. +FLOAT WINAPI D3DXFresnelTerm + (FLOAT CosTheta, FLOAT RefractionIndex); + +#ifdef __cplusplus +} +#endif + + + +//=========================================================================== +// +// Matrix Stack +// +//=========================================================================== + +typedef interface ID3DXMatrixStack ID3DXMatrixStack; +typedef interface ID3DXMatrixStack *LPD3DXMATRIXSTACK; + +// {E3357330-CC5E-11d2-A434-00A0C90629A8} +DEFINE_GUID( IID_ID3DXMatrixStack, +0xe3357330, 0xcc5e, 0x11d2, 0xa4, 0x34, 0x0, 0xa0, 0xc9, 0x6, 0x29, 0xa8); + + +#undef INTERFACE +#define INTERFACE ID3DXMatrixStack + +DECLARE_INTERFACE_(ID3DXMatrixStack, IUnknown) +{ + // + // IUnknown methods + // + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + // + // ID3DXMatrixStack methods + // + + // Pops the top of the stack, returns the current top + // *after* popping the top. + STDMETHOD(Pop)(THIS) PURE; + + // Pushes the stack by one, duplicating the current matrix. + STDMETHOD(Push)(THIS) PURE; + + // Loads identity in the current matrix. + STDMETHOD(LoadIdentity)(THIS) PURE; + + // Loads the given matrix into the current matrix + STDMETHOD(LoadMatrix)(THIS_ CONST D3DXMATRIX* pM ) PURE; + + // Right-Multiplies the given matrix to the current matrix. + // (transformation is about the current world origin) + STDMETHOD(MultMatrix)(THIS_ CONST D3DXMATRIX* pM ) PURE; + + // Left-Multiplies the given matrix to the current matrix + // (transformation is about the local origin of the object) + STDMETHOD(MultMatrixLocal)(THIS_ CONST D3DXMATRIX* pM ) PURE; + + // Right multiply the current matrix with the computed rotation + // matrix, counterclockwise about the given axis with the given angle. + // (rotation is about the current world origin) + STDMETHOD(RotateAxis) + (THIS_ CONST D3DXVECTOR3* pV, FLOAT Angle) PURE; + + // Left multiply the current matrix with the computed rotation + // matrix, counterclockwise about the given axis with the given angle. + // (rotation is about the local origin of the object) + STDMETHOD(RotateAxisLocal) + (THIS_ CONST D3DXVECTOR3* pV, FLOAT Angle) PURE; + + // Right multiply the current matrix with the computed rotation + // matrix. All angles are counterclockwise. (rotation is about the + // current world origin) + + // The rotation is composed of a yaw around the Y axis, a pitch around + // the X axis, and a roll around the Z axis. + STDMETHOD(RotateYawPitchRoll) + (THIS_ FLOAT Yaw, FLOAT Pitch, FLOAT Roll) PURE; + + // Left multiply the current matrix with the computed rotation + // matrix. All angles are counterclockwise. (rotation is about the + // local origin of the object) + + // The rotation is composed of a yaw around the Y axis, a pitch around + // the X axis, and a roll around the Z axis. + STDMETHOD(RotateYawPitchRollLocal) + (THIS_ FLOAT Yaw, FLOAT Pitch, FLOAT Roll) PURE; + + // Right multiply the current matrix with the computed scale + // matrix. (transformation is about the current world origin) + STDMETHOD(Scale)(THIS_ FLOAT x, FLOAT y, FLOAT z) PURE; + + // Left multiply the current matrix with the computed scale + // matrix. (transformation is about the local origin of the object) + STDMETHOD(ScaleLocal)(THIS_ FLOAT x, FLOAT y, FLOAT z) PURE; + + // Right multiply the current matrix with the computed translation + // matrix. (transformation is about the current world origin) + STDMETHOD(Translate)(THIS_ FLOAT x, FLOAT y, FLOAT z ) PURE; + + // Left multiply the current matrix with the computed translation + // matrix. (transformation is about the local origin of the object) + STDMETHOD(TranslateLocal)(THIS_ FLOAT x, FLOAT y, FLOAT z) PURE; + + // Obtain the current matrix at the top of the stack + STDMETHOD_(D3DXMATRIX*, GetTop)(THIS) PURE; +}; + +#ifdef __cplusplus +extern "C" { +#endif + +HRESULT WINAPI + D3DXCreateMatrixStack( + DWORD Flags, + LPD3DXMATRIXSTACK* ppStack); + +#ifdef __cplusplus +} +#endif + +#include "d3dx8math.inl" + +#pragma warning(default:4201) + +#endif // __D3DX8MATH_H__ diff --git a/plugins/ADK/d3d8/includes/d3dx8math.inl b/plugins/ADK/d3d8/includes/d3dx8math.inl new file mode 100644 index 0000000..a64e5c5 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8math.inl @@ -0,0 +1,1757 @@ +////////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8math.inl +// Content: D3DX math inline functions +// +////////////////////////////////////////////////////////////////////////////// + +#ifndef __D3DX8MATH_INL__ +#define __D3DX8MATH_INL__ + + +//=========================================================================== +// +// Inline Class Methods +// +//=========================================================================== + +#ifdef __cplusplus + +//-------------------------- +// 2D Vector +//-------------------------- + +D3DXINLINE +D3DXVECTOR2::D3DXVECTOR2( CONST FLOAT *pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + x = pf[0]; + y = pf[1]; +} + +D3DXINLINE +D3DXVECTOR2::D3DXVECTOR2( FLOAT fx, FLOAT fy ) +{ + x = fx; + y = fy; +} + +// casting +D3DXINLINE +D3DXVECTOR2::operator FLOAT* () +{ + return (FLOAT *) &x; +} + +D3DXINLINE +D3DXVECTOR2::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &x; +} + +// assignment operators +D3DXINLINE D3DXVECTOR2& +D3DXVECTOR2::operator += ( CONST D3DXVECTOR2& v ) +{ + x += v.x; + y += v.y; + return *this; +} + +D3DXINLINE D3DXVECTOR2& +D3DXVECTOR2::operator -= ( CONST D3DXVECTOR2& v ) +{ + x -= v.x; + y -= v.y; + return *this; +} + +D3DXINLINE D3DXVECTOR2& +D3DXVECTOR2::operator *= ( FLOAT f ) +{ + x *= f; + y *= f; + return *this; +} + +D3DXINLINE D3DXVECTOR2& +D3DXVECTOR2::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + x *= fInv; + y *= fInv; + return *this; +} + +// unary operators +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator - () const +{ + return D3DXVECTOR2(-x, -y); +} + +// binary operators +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator + ( CONST D3DXVECTOR2& v ) const +{ + return D3DXVECTOR2(x + v.x, y + v.y); +} + +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator - ( CONST D3DXVECTOR2& v ) const +{ + return D3DXVECTOR2(x - v.x, y - v.y); +} + +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator * ( FLOAT f ) const +{ + return D3DXVECTOR2(x * f, y * f); +} + +D3DXINLINE D3DXVECTOR2 +D3DXVECTOR2::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXVECTOR2(x * fInv, y * fInv); +} + + +D3DXINLINE D3DXVECTOR2 +operator * ( FLOAT f, CONST D3DXVECTOR2& v ) +{ + return D3DXVECTOR2(f * v.x, f * v.y); +} + +D3DXINLINE BOOL +D3DXVECTOR2::operator == ( CONST D3DXVECTOR2& v ) const +{ + return x == v.x && y == v.y; +} + +D3DXINLINE BOOL +D3DXVECTOR2::operator != ( CONST D3DXVECTOR2& v ) const +{ + return x != v.x || y != v.y; +} + + + + +//-------------------------- +// 3D Vector +//-------------------------- +D3DXINLINE +D3DXVECTOR3::D3DXVECTOR3( CONST FLOAT *pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + x = pf[0]; + y = pf[1]; + z = pf[2]; +} + +D3DXINLINE +D3DXVECTOR3::D3DXVECTOR3( CONST D3DVECTOR& v ) +{ + x = v.x; + y = v.y; + z = v.z; +} + +D3DXINLINE +D3DXVECTOR3::D3DXVECTOR3( FLOAT fx, FLOAT fy, FLOAT fz ) +{ + x = fx; + y = fy; + z = fz; +} + + +// casting +D3DXINLINE +D3DXVECTOR3::operator FLOAT* () +{ + return (FLOAT *) &x; +} + +D3DXINLINE +D3DXVECTOR3::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &x; +} + + +// assignment operators +D3DXINLINE D3DXVECTOR3& +D3DXVECTOR3::operator += ( CONST D3DXVECTOR3& v ) +{ + x += v.x; + y += v.y; + z += v.z; + return *this; +} + +D3DXINLINE D3DXVECTOR3& +D3DXVECTOR3::operator -= ( CONST D3DXVECTOR3& v ) +{ + x -= v.x; + y -= v.y; + z -= v.z; + return *this; +} + +D3DXINLINE D3DXVECTOR3& +D3DXVECTOR3::operator *= ( FLOAT f ) +{ + x *= f; + y *= f; + z *= f; + return *this; +} + +D3DXINLINE D3DXVECTOR3& +D3DXVECTOR3::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + x *= fInv; + y *= fInv; + z *= fInv; + return *this; +} + + +// unary operators +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator - () const +{ + return D3DXVECTOR3(-x, -y, -z); +} + + +// binary operators +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator + ( CONST D3DXVECTOR3& v ) const +{ + return D3DXVECTOR3(x + v.x, y + v.y, z + v.z); +} + +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator - ( CONST D3DXVECTOR3& v ) const +{ + return D3DXVECTOR3(x - v.x, y - v.y, z - v.z); +} + +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator * ( FLOAT f ) const +{ + return D3DXVECTOR3(x * f, y * f, z * f); +} + +D3DXINLINE D3DXVECTOR3 +D3DXVECTOR3::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXVECTOR3(x * fInv, y * fInv, z * fInv); +} + + +D3DXINLINE D3DXVECTOR3 +operator * ( FLOAT f, CONST struct D3DXVECTOR3& v ) +{ + return D3DXVECTOR3(f * v.x, f * v.y, f * v.z); +} + + +D3DXINLINE BOOL +D3DXVECTOR3::operator == ( CONST D3DXVECTOR3& v ) const +{ + return x == v.x && y == v.y && z == v.z; +} + +D3DXINLINE BOOL +D3DXVECTOR3::operator != ( CONST D3DXVECTOR3& v ) const +{ + return x != v.x || y != v.y || z != v.z; +} + + + +//-------------------------- +// 4D Vector +//-------------------------- +D3DXINLINE +D3DXVECTOR4::D3DXVECTOR4( CONST FLOAT *pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + x = pf[0]; + y = pf[1]; + z = pf[2]; + w = pf[3]; +} + +D3DXINLINE +D3DXVECTOR4::D3DXVECTOR4( FLOAT fx, FLOAT fy, FLOAT fz, FLOAT fw ) +{ + x = fx; + y = fy; + z = fz; + w = fw; +} + + +// casting +D3DXINLINE +D3DXVECTOR4::operator FLOAT* () +{ + return (FLOAT *) &x; +} + +D3DXINLINE +D3DXVECTOR4::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &x; +} + + +// assignment operators +D3DXINLINE D3DXVECTOR4& +D3DXVECTOR4::operator += ( CONST D3DXVECTOR4& v ) +{ + x += v.x; + y += v.y; + z += v.z; + w += v.w; + return *this; +} + +D3DXINLINE D3DXVECTOR4& +D3DXVECTOR4::operator -= ( CONST D3DXVECTOR4& v ) +{ + x -= v.x; + y -= v.y; + z -= v.z; + w -= v.w; + return *this; +} + +D3DXINLINE D3DXVECTOR4& +D3DXVECTOR4::operator *= ( FLOAT f ) +{ + x *= f; + y *= f; + z *= f; + w *= f; + return *this; +} + +D3DXINLINE D3DXVECTOR4& +D3DXVECTOR4::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + x *= fInv; + y *= fInv; + z *= fInv; + w *= fInv; + return *this; +} + + +// unary operators +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator - () const +{ + return D3DXVECTOR4(-x, -y, -z, -w); +} + + +// binary operators +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator + ( CONST D3DXVECTOR4& v ) const +{ + return D3DXVECTOR4(x + v.x, y + v.y, z + v.z, w + v.w); +} + +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator - ( CONST D3DXVECTOR4& v ) const +{ + return D3DXVECTOR4(x - v.x, y - v.y, z - v.z, w - v.w); +} + +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator * ( FLOAT f ) const +{ + return D3DXVECTOR4(x * f, y * f, z * f, w * f); +} + +D3DXINLINE D3DXVECTOR4 +D3DXVECTOR4::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXVECTOR4(x * fInv, y * fInv, z * fInv, w * fInv); +} + + +D3DXINLINE D3DXVECTOR4 +operator * ( FLOAT f, CONST D3DXVECTOR4& v ) +{ + return D3DXVECTOR4(f * v.x, f * v.y, f * v.z, f * v.w); +} + + +D3DXINLINE BOOL +D3DXVECTOR4::operator == ( CONST D3DXVECTOR4& v ) const +{ + return x == v.x && y == v.y && z == v.z && w == v.w; +} + +D3DXINLINE BOOL +D3DXVECTOR4::operator != ( CONST D3DXVECTOR4& v ) const +{ + return x != v.x || y != v.y || z != v.z || w != v.w; +} + + +//-------------------------- +// Matrix +//-------------------------- +D3DXINLINE +D3DXMATRIX::D3DXMATRIX( CONST FLOAT* pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + memcpy(&_11, pf, sizeof(D3DXMATRIX)); +} + +D3DXINLINE +D3DXMATRIX::D3DXMATRIX( CONST D3DMATRIX& mat ) +{ + memcpy(&_11, &mat, sizeof(D3DXMATRIX)); +} + +D3DXINLINE +D3DXMATRIX::D3DXMATRIX( FLOAT f11, FLOAT f12, FLOAT f13, FLOAT f14, + FLOAT f21, FLOAT f22, FLOAT f23, FLOAT f24, + FLOAT f31, FLOAT f32, FLOAT f33, FLOAT f34, + FLOAT f41, FLOAT f42, FLOAT f43, FLOAT f44 ) +{ + _11 = f11; _12 = f12; _13 = f13; _14 = f14; + _21 = f21; _22 = f22; _23 = f23; _24 = f24; + _31 = f31; _32 = f32; _33 = f33; _34 = f34; + _41 = f41; _42 = f42; _43 = f43; _44 = f44; +} + + + +// access grants +D3DXINLINE FLOAT& +D3DXMATRIX::operator () ( UINT iRow, UINT iCol ) +{ + return m[iRow][iCol]; +} + +D3DXINLINE FLOAT +D3DXMATRIX::operator () ( UINT iRow, UINT iCol ) const +{ + return m[iRow][iCol]; +} + + +// casting operators +D3DXINLINE +D3DXMATRIX::operator FLOAT* () +{ + return (FLOAT *) &_11; +} + +D3DXINLINE +D3DXMATRIX::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &_11; +} + + +// assignment operators +D3DXINLINE D3DXMATRIX& +D3DXMATRIX::operator *= ( CONST D3DXMATRIX& mat ) +{ + D3DXMatrixMultiply(this, this, &mat); + return *this; +} + +D3DXINLINE D3DXMATRIX& +D3DXMATRIX::operator += ( CONST D3DXMATRIX& mat ) +{ + _11 += mat._11; _12 += mat._12; _13 += mat._13; _14 += mat._14; + _21 += mat._21; _22 += mat._22; _23 += mat._23; _24 += mat._24; + _31 += mat._31; _32 += mat._32; _33 += mat._33; _34 += mat._34; + _41 += mat._41; _42 += mat._42; _43 += mat._43; _44 += mat._44; + return *this; +} + +D3DXINLINE D3DXMATRIX& +D3DXMATRIX::operator -= ( CONST D3DXMATRIX& mat ) +{ + _11 -= mat._11; _12 -= mat._12; _13 -= mat._13; _14 -= mat._14; + _21 -= mat._21; _22 -= mat._22; _23 -= mat._23; _24 -= mat._24; + _31 -= mat._31; _32 -= mat._32; _33 -= mat._33; _34 -= mat._34; + _41 -= mat._41; _42 -= mat._42; _43 -= mat._43; _44 -= mat._44; + return *this; +} + +D3DXINLINE D3DXMATRIX& +D3DXMATRIX::operator *= ( FLOAT f ) +{ + _11 *= f; _12 *= f; _13 *= f; _14 *= f; + _21 *= f; _22 *= f; _23 *= f; _24 *= f; + _31 *= f; _32 *= f; _33 *= f; _34 *= f; + _41 *= f; _42 *= f; _43 *= f; _44 *= f; + return *this; +} + +D3DXINLINE D3DXMATRIX& +D3DXMATRIX::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + _11 *= fInv; _12 *= fInv; _13 *= fInv; _14 *= fInv; + _21 *= fInv; _22 *= fInv; _23 *= fInv; _24 *= fInv; + _31 *= fInv; _32 *= fInv; _33 *= fInv; _34 *= fInv; + _41 *= fInv; _42 *= fInv; _43 *= fInv; _44 *= fInv; + return *this; +} + + +// unary operators +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator - () const +{ + return D3DXMATRIX(-_11, -_12, -_13, -_14, + -_21, -_22, -_23, -_24, + -_31, -_32, -_33, -_34, + -_41, -_42, -_43, -_44); +} + + +// binary operators +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator * ( CONST D3DXMATRIX& mat ) const +{ + D3DXMATRIX matT; + D3DXMatrixMultiply(&matT, this, &mat); + return matT; +} + +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator + ( CONST D3DXMATRIX& mat ) const +{ + return D3DXMATRIX(_11 + mat._11, _12 + mat._12, _13 + mat._13, _14 + mat._14, + _21 + mat._21, _22 + mat._22, _23 + mat._23, _24 + mat._24, + _31 + mat._31, _32 + mat._32, _33 + mat._33, _34 + mat._34, + _41 + mat._41, _42 + mat._42, _43 + mat._43, _44 + mat._44); +} + +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator - ( CONST D3DXMATRIX& mat ) const +{ + return D3DXMATRIX(_11 - mat._11, _12 - mat._12, _13 - mat._13, _14 - mat._14, + _21 - mat._21, _22 - mat._22, _23 - mat._23, _24 - mat._24, + _31 - mat._31, _32 - mat._32, _33 - mat._33, _34 - mat._34, + _41 - mat._41, _42 - mat._42, _43 - mat._43, _44 - mat._44); +} + +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator * ( FLOAT f ) const +{ + return D3DXMATRIX(_11 * f, _12 * f, _13 * f, _14 * f, + _21 * f, _22 * f, _23 * f, _24 * f, + _31 * f, _32 * f, _33 * f, _34 * f, + _41 * f, _42 * f, _43 * f, _44 * f); +} + +D3DXINLINE D3DXMATRIX +D3DXMATRIX::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXMATRIX(_11 * fInv, _12 * fInv, _13 * fInv, _14 * fInv, + _21 * fInv, _22 * fInv, _23 * fInv, _24 * fInv, + _31 * fInv, _32 * fInv, _33 * fInv, _34 * fInv, + _41 * fInv, _42 * fInv, _43 * fInv, _44 * fInv); +} + + +D3DXINLINE D3DXMATRIX +operator * ( FLOAT f, CONST D3DXMATRIX& mat ) +{ + return D3DXMATRIX(f * mat._11, f * mat._12, f * mat._13, f * mat._14, + f * mat._21, f * mat._22, f * mat._23, f * mat._24, + f * mat._31, f * mat._32, f * mat._33, f * mat._34, + f * mat._41, f * mat._42, f * mat._43, f * mat._44); +} + + +D3DXINLINE BOOL +D3DXMATRIX::operator == ( CONST D3DXMATRIX& mat ) const +{ + return 0 == memcmp(this, &mat, sizeof(D3DXMATRIX)); +} + +D3DXINLINE BOOL +D3DXMATRIX::operator != ( CONST D3DXMATRIX& mat ) const +{ + return 0 != memcmp(this, &mat, sizeof(D3DXMATRIX)); +} + + + +//-------------------------- +// Quaternion +//-------------------------- + +D3DXINLINE +D3DXQUATERNION::D3DXQUATERNION( CONST FLOAT* pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + x = pf[0]; + y = pf[1]; + z = pf[2]; + w = pf[3]; +} + +D3DXINLINE +D3DXQUATERNION::D3DXQUATERNION( FLOAT fx, FLOAT fy, FLOAT fz, FLOAT fw ) +{ + x = fx; + y = fy; + z = fz; + w = fw; +} + + +// casting +D3DXINLINE +D3DXQUATERNION::operator FLOAT* () +{ + return (FLOAT *) &x; +} + +D3DXINLINE +D3DXQUATERNION::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &x; +} + + +// assignment operators +D3DXINLINE D3DXQUATERNION& +D3DXQUATERNION::operator += ( CONST D3DXQUATERNION& q ) +{ + x += q.x; + y += q.y; + z += q.z; + w += q.w; + return *this; +} + +D3DXINLINE D3DXQUATERNION& +D3DXQUATERNION::operator -= ( CONST D3DXQUATERNION& q ) +{ + x -= q.x; + y -= q.y; + z -= q.z; + w -= q.w; + return *this; +} + +D3DXINLINE D3DXQUATERNION& +D3DXQUATERNION::operator *= ( CONST D3DXQUATERNION& q ) +{ + D3DXQuaternionMultiply(this, this, &q); + return *this; +} + +D3DXINLINE D3DXQUATERNION& +D3DXQUATERNION::operator *= ( FLOAT f ) +{ + x *= f; + y *= f; + z *= f; + w *= f; + return *this; +} + +D3DXINLINE D3DXQUATERNION& +D3DXQUATERNION::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + x *= fInv; + y *= fInv; + z *= fInv; + w *= fInv; + return *this; +} + + +// unary operators +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator - () const +{ + return D3DXQUATERNION(-x, -y, -z, -w); +} + + +// binary operators +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator + ( CONST D3DXQUATERNION& q ) const +{ + return D3DXQUATERNION(x + q.x, y + q.y, z + q.z, w + q.w); +} + +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator - ( CONST D3DXQUATERNION& q ) const +{ + return D3DXQUATERNION(x - q.x, y - q.y, z - q.z, w - q.w); +} + +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator * ( CONST D3DXQUATERNION& q ) const +{ + D3DXQUATERNION qT; + D3DXQuaternionMultiply(&qT, this, &q); + return qT; +} + +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator * ( FLOAT f ) const +{ + return D3DXQUATERNION(x * f, y * f, z * f, w * f); +} + +D3DXINLINE D3DXQUATERNION +D3DXQUATERNION::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXQUATERNION(x * fInv, y * fInv, z * fInv, w * fInv); +} + + +D3DXINLINE D3DXQUATERNION +operator * (FLOAT f, CONST D3DXQUATERNION& q ) +{ + return D3DXQUATERNION(f * q.x, f * q.y, f * q.z, f * q.w); +} + + +D3DXINLINE BOOL +D3DXQUATERNION::operator == ( CONST D3DXQUATERNION& q ) const +{ + return x == q.x && y == q.y && z == q.z && w == q.w; +} + +D3DXINLINE BOOL +D3DXQUATERNION::operator != ( CONST D3DXQUATERNION& q ) const +{ + return x != q.x || y != q.y || z != q.z || w != q.w; +} + + + +//-------------------------- +// Plane +//-------------------------- + +D3DXINLINE +D3DXPLANE::D3DXPLANE( CONST FLOAT* pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + a = pf[0]; + b = pf[1]; + c = pf[2]; + d = pf[3]; +} + +D3DXINLINE +D3DXPLANE::D3DXPLANE( FLOAT fa, FLOAT fb, FLOAT fc, FLOAT fd ) +{ + a = fa; + b = fb; + c = fc; + d = fd; +} + + +// casting +D3DXINLINE +D3DXPLANE::operator FLOAT* () +{ + return (FLOAT *) &a; +} + +D3DXINLINE +D3DXPLANE::operator CONST FLOAT* () const +{ + return (CONST FLOAT *) &a; +} + + +// unary operators +D3DXINLINE D3DXPLANE +D3DXPLANE::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXPLANE +D3DXPLANE::operator - () const +{ + return D3DXPLANE(-a, -b, -c, -d); +} + + +// binary operators +D3DXINLINE BOOL +D3DXPLANE::operator == ( CONST D3DXPLANE& p ) const +{ + return a == p.a && b == p.b && c == p.c && d == p.d; +} + +D3DXINLINE BOOL +D3DXPLANE::operator != ( CONST D3DXPLANE& p ) const +{ + return a != p.a || b != p.b || c != p.c || d != p.d; +} + + + + +//-------------------------- +// Color +//-------------------------- + +D3DXINLINE +D3DXCOLOR::D3DXCOLOR( DWORD dw ) +{ + CONST FLOAT f = 1.0f / 255.0f; + r = f * (FLOAT) (unsigned char) (dw >> 16); + g = f * (FLOAT) (unsigned char) (dw >> 8); + b = f * (FLOAT) (unsigned char) (dw >> 0); + a = f * (FLOAT) (unsigned char) (dw >> 24); +} + +D3DXINLINE +D3DXCOLOR::D3DXCOLOR( CONST FLOAT* pf ) +{ +#ifdef D3DX_DEBUG + if(!pf) + return; +#endif + + r = pf[0]; + g = pf[1]; + b = pf[2]; + a = pf[3]; +} + +D3DXINLINE +D3DXCOLOR::D3DXCOLOR( CONST D3DCOLORVALUE& c ) +{ + r = c.r; + g = c.g; + b = c.b; + a = c.a; +} + +D3DXINLINE +D3DXCOLOR::D3DXCOLOR( FLOAT fr, FLOAT fg, FLOAT fb, FLOAT fa ) +{ + r = fr; + g = fg; + b = fb; + a = fa; +} + + +// casting +D3DXINLINE +D3DXCOLOR::operator DWORD () const +{ + DWORD dwR = r >= 1.0f ? 0xff : r <= 0.0f ? 0x00 : (DWORD) (r * 255.0f + 0.5f); + DWORD dwG = g >= 1.0f ? 0xff : g <= 0.0f ? 0x00 : (DWORD) (g * 255.0f + 0.5f); + DWORD dwB = b >= 1.0f ? 0xff : b <= 0.0f ? 0x00 : (DWORD) (b * 255.0f + 0.5f); + DWORD dwA = a >= 1.0f ? 0xff : a <= 0.0f ? 0x00 : (DWORD) (a * 255.0f + 0.5f); + + return (dwA << 24) | (dwR << 16) | (dwG << 8) | dwB; +} + + +D3DXINLINE +D3DXCOLOR::operator FLOAT * () +{ + return (FLOAT *) &r; +} + +D3DXINLINE +D3DXCOLOR::operator CONST FLOAT * () const +{ + return (CONST FLOAT *) &r; +} + + +D3DXINLINE +D3DXCOLOR::operator D3DCOLORVALUE * () +{ + return (D3DCOLORVALUE *) &r; +} + +D3DXINLINE +D3DXCOLOR::operator CONST D3DCOLORVALUE * () const +{ + return (CONST D3DCOLORVALUE *) &r; +} + + +D3DXINLINE +D3DXCOLOR::operator D3DCOLORVALUE& () +{ + return *((D3DCOLORVALUE *) &r); +} + +D3DXINLINE +D3DXCOLOR::operator CONST D3DCOLORVALUE& () const +{ + return *((CONST D3DCOLORVALUE *) &r); +} + + +// assignment operators +D3DXINLINE D3DXCOLOR& +D3DXCOLOR::operator += ( CONST D3DXCOLOR& c ) +{ + r += c.r; + g += c.g; + b += c.b; + a += c.a; + return *this; +} + +D3DXINLINE D3DXCOLOR& +D3DXCOLOR::operator -= ( CONST D3DXCOLOR& c ) +{ + r -= c.r; + g -= c.g; + b -= c.b; + a -= c.a; + return *this; +} + +D3DXINLINE D3DXCOLOR& +D3DXCOLOR::operator *= ( FLOAT f ) +{ + r *= f; + g *= f; + b *= f; + a *= f; + return *this; +} + +D3DXINLINE D3DXCOLOR& +D3DXCOLOR::operator /= ( FLOAT f ) +{ + FLOAT fInv = 1.0f / f; + r *= fInv; + g *= fInv; + b *= fInv; + a *= fInv; + return *this; +} + + +// unary operators +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator + () const +{ + return *this; +} + +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator - () const +{ + return D3DXCOLOR(-r, -g, -b, -a); +} + + +// binary operators +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator + ( CONST D3DXCOLOR& c ) const +{ + return D3DXCOLOR(r + c.r, g + c.g, b + c.b, a + c.a); +} + +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator - ( CONST D3DXCOLOR& c ) const +{ + return D3DXCOLOR(r - c.r, g - c.g, b - c.b, a - c.a); +} + +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator * ( FLOAT f ) const +{ + return D3DXCOLOR(r * f, g * f, b * f, a * f); +} + +D3DXINLINE D3DXCOLOR +D3DXCOLOR::operator / ( FLOAT f ) const +{ + FLOAT fInv = 1.0f / f; + return D3DXCOLOR(r * fInv, g * fInv, b * fInv, a * fInv); +} + + +D3DXINLINE D3DXCOLOR +operator * (FLOAT f, CONST D3DXCOLOR& c ) +{ + return D3DXCOLOR(f * c.r, f * c.g, f * c.b, f * c.a); +} + + +D3DXINLINE BOOL +D3DXCOLOR::operator == ( CONST D3DXCOLOR& c ) const +{ + return r == c.r && g == c.g && b == c.b && a == c.a; +} + +D3DXINLINE BOOL +D3DXCOLOR::operator != ( CONST D3DXCOLOR& c ) const +{ + return r != c.r || g != c.g || b != c.b || a != c.a; +} + + +#endif //__cplusplus + + + +//=========================================================================== +// +// Inline functions +// +//=========================================================================== + + +//-------------------------- +// 2D Vector +//-------------------------- + +D3DXINLINE FLOAT D3DXVec2Length + ( CONST D3DXVECTOR2 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + +#ifdef __cplusplus + return sqrtf(pV->x * pV->x + pV->y * pV->y); +#else + return (FLOAT) sqrt(pV->x * pV->x + pV->y * pV->y); +#endif +} + +D3DXINLINE FLOAT D3DXVec2LengthSq + ( CONST D3DXVECTOR2 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + + return pV->x * pV->x + pV->y * pV->y; +} + +D3DXINLINE FLOAT D3DXVec2Dot + ( CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pV1 || !pV2) + return 0.0f; +#endif + + return pV1->x * pV2->x + pV1->y * pV2->y; +} + +D3DXINLINE FLOAT D3DXVec2CCW + ( CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pV1 || !pV2) + return 0.0f; +#endif + + return pV1->x * pV2->y - pV1->y * pV2->x; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Add + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + pV2->x; + pOut->y = pV1->y + pV2->y; + return pOut; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Subtract + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x - pV2->x; + pOut->y = pV1->y - pV2->y; + return pOut; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Minimize + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x < pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y < pV2->y ? pV1->y : pV2->y; + return pOut; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Maximize + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x > pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y > pV2->y ? pV1->y : pV2->y; + return pOut; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Scale + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV, FLOAT s ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV) + return NULL; +#endif + + pOut->x = pV->x * s; + pOut->y = pV->y * s; + return pOut; +} + +D3DXINLINE D3DXVECTOR2* D3DXVec2Lerp + ( D3DXVECTOR2 *pOut, CONST D3DXVECTOR2 *pV1, CONST D3DXVECTOR2 *pV2, + FLOAT s ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + s * (pV2->x - pV1->x); + pOut->y = pV1->y + s * (pV2->y - pV1->y); + return pOut; +} + + +//-------------------------- +// 3D Vector +//-------------------------- + +D3DXINLINE FLOAT D3DXVec3Length + ( CONST D3DXVECTOR3 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + +#ifdef __cplusplus + return sqrtf(pV->x * pV->x + pV->y * pV->y + pV->z * pV->z); +#else + return (FLOAT) sqrt(pV->x * pV->x + pV->y * pV->y + pV->z * pV->z); +#endif +} + +D3DXINLINE FLOAT D3DXVec3LengthSq + ( CONST D3DXVECTOR3 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + + return pV->x * pV->x + pV->y * pV->y + pV->z * pV->z; +} + +D3DXINLINE FLOAT D3DXVec3Dot + ( CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pV1 || !pV2) + return 0.0f; +#endif + + return pV1->x * pV2->x + pV1->y * pV2->y + pV1->z * pV2->z; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Cross + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ + D3DXVECTOR3 v; + +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + v.x = pV1->y * pV2->z - pV1->z * pV2->y; + v.y = pV1->z * pV2->x - pV1->x * pV2->z; + v.z = pV1->x * pV2->y - pV1->y * pV2->x; + + *pOut = v; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Add + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + pV2->x; + pOut->y = pV1->y + pV2->y; + pOut->z = pV1->z + pV2->z; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Subtract + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x - pV2->x; + pOut->y = pV1->y - pV2->y; + pOut->z = pV1->z - pV2->z; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Minimize + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x < pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y < pV2->y ? pV1->y : pV2->y; + pOut->z = pV1->z < pV2->z ? pV1->z : pV2->z; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Maximize + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x > pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y > pV2->y ? pV1->y : pV2->y; + pOut->z = pV1->z > pV2->z ? pV1->z : pV2->z; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Scale + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV, FLOAT s) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV) + return NULL; +#endif + + pOut->x = pV->x * s; + pOut->y = pV->y * s; + pOut->z = pV->z * s; + return pOut; +} + +D3DXINLINE D3DXVECTOR3* D3DXVec3Lerp + ( D3DXVECTOR3 *pOut, CONST D3DXVECTOR3 *pV1, CONST D3DXVECTOR3 *pV2, + FLOAT s ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + s * (pV2->x - pV1->x); + pOut->y = pV1->y + s * (pV2->y - pV1->y); + pOut->z = pV1->z + s * (pV2->z - pV1->z); + return pOut; +} + + +//-------------------------- +// 4D Vector +//-------------------------- + +D3DXINLINE FLOAT D3DXVec4Length + ( CONST D3DXVECTOR4 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + +#ifdef __cplusplus + return sqrtf(pV->x * pV->x + pV->y * pV->y + pV->z * pV->z + pV->w * pV->w); +#else + return (FLOAT) sqrt(pV->x * pV->x + pV->y * pV->y + pV->z * pV->z + pV->w * pV->w); +#endif +} + +D3DXINLINE FLOAT D3DXVec4LengthSq + ( CONST D3DXVECTOR4 *pV ) +{ +#ifdef D3DX_DEBUG + if(!pV) + return 0.0f; +#endif + + return pV->x * pV->x + pV->y * pV->y + pV->z * pV->z + pV->w * pV->w; +} + +D3DXINLINE FLOAT D3DXVec4Dot + ( CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2 ) +{ +#ifdef D3DX_DEBUG + if(!pV1 || !pV2) + return 0.0f; +#endif + + return pV1->x * pV2->x + pV1->y * pV2->y + pV1->z * pV2->z + pV1->w * pV2->w; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Add + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + pV2->x; + pOut->y = pV1->y + pV2->y; + pOut->z = pV1->z + pV2->z; + pOut->w = pV1->w + pV2->w; + return pOut; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Subtract + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x - pV2->x; + pOut->y = pV1->y - pV2->y; + pOut->z = pV1->z - pV2->z; + pOut->w = pV1->w - pV2->w; + return pOut; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Minimize + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x < pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y < pV2->y ? pV1->y : pV2->y; + pOut->z = pV1->z < pV2->z ? pV1->z : pV2->z; + pOut->w = pV1->w < pV2->w ? pV1->w : pV2->w; + return pOut; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Maximize + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x > pV2->x ? pV1->x : pV2->x; + pOut->y = pV1->y > pV2->y ? pV1->y : pV2->y; + pOut->z = pV1->z > pV2->z ? pV1->z : pV2->z; + pOut->w = pV1->w > pV2->w ? pV1->w : pV2->w; + return pOut; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Scale + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV, FLOAT s) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV) + return NULL; +#endif + + pOut->x = pV->x * s; + pOut->y = pV->y * s; + pOut->z = pV->z * s; + pOut->w = pV->w * s; + return pOut; +} + +D3DXINLINE D3DXVECTOR4* D3DXVec4Lerp + ( D3DXVECTOR4 *pOut, CONST D3DXVECTOR4 *pV1, CONST D3DXVECTOR4 *pV2, + FLOAT s ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pV1 || !pV2) + return NULL; +#endif + + pOut->x = pV1->x + s * (pV2->x - pV1->x); + pOut->y = pV1->y + s * (pV2->y - pV1->y); + pOut->z = pV1->z + s * (pV2->z - pV1->z); + pOut->w = pV1->w + s * (pV2->w - pV1->w); + return pOut; +} + + +//-------------------------- +// 4D Matrix +//-------------------------- + +D3DXINLINE D3DXMATRIX* D3DXMatrixIdentity + ( D3DXMATRIX *pOut ) +{ +#ifdef D3DX_DEBUG + if(!pOut) + return NULL; +#endif + + pOut->m[0][1] = pOut->m[0][2] = pOut->m[0][3] = + pOut->m[1][0] = pOut->m[1][2] = pOut->m[1][3] = + pOut->m[2][0] = pOut->m[2][1] = pOut->m[2][3] = + pOut->m[3][0] = pOut->m[3][1] = pOut->m[3][2] = 0.0f; + + pOut->m[0][0] = pOut->m[1][1] = pOut->m[2][2] = pOut->m[3][3] = 1.0f; + return pOut; +} + + +D3DXINLINE BOOL D3DXMatrixIsIdentity + ( CONST D3DXMATRIX *pM ) +{ +#ifdef D3DX_DEBUG + if(!pM) + return FALSE; +#endif + + return pM->m[0][0] == 1.0f && pM->m[0][1] == 0.0f && pM->m[0][2] == 0.0f && pM->m[0][3] == 0.0f && + pM->m[1][0] == 0.0f && pM->m[1][1] == 1.0f && pM->m[1][2] == 0.0f && pM->m[1][3] == 0.0f && + pM->m[2][0] == 0.0f && pM->m[2][1] == 0.0f && pM->m[2][2] == 1.0f && pM->m[2][3] == 0.0f && + pM->m[3][0] == 0.0f && pM->m[3][1] == 0.0f && pM->m[3][2] == 0.0f && pM->m[3][3] == 1.0f; +} + + +//-------------------------- +// Quaternion +//-------------------------- + +D3DXINLINE FLOAT D3DXQuaternionLength + ( CONST D3DXQUATERNION *pQ ) +{ +#ifdef D3DX_DEBUG + if(!pQ) + return 0.0f; +#endif + +#ifdef __cplusplus + return sqrtf(pQ->x * pQ->x + pQ->y * pQ->y + pQ->z * pQ->z + pQ->w * pQ->w); +#else + return (FLOAT) sqrt(pQ->x * pQ->x + pQ->y * pQ->y + pQ->z * pQ->z + pQ->w * pQ->w); +#endif +} + +D3DXINLINE FLOAT D3DXQuaternionLengthSq + ( CONST D3DXQUATERNION *pQ ) +{ +#ifdef D3DX_DEBUG + if(!pQ) + return 0.0f; +#endif + + return pQ->x * pQ->x + pQ->y * pQ->y + pQ->z * pQ->z + pQ->w * pQ->w; +} + +D3DXINLINE FLOAT D3DXQuaternionDot + ( CONST D3DXQUATERNION *pQ1, CONST D3DXQUATERNION *pQ2 ) +{ +#ifdef D3DX_DEBUG + if(!pQ1 || !pQ2) + return 0.0f; +#endif + + return pQ1->x * pQ2->x + pQ1->y * pQ2->y + pQ1->z * pQ2->z + pQ1->w * pQ2->w; +} + + +D3DXINLINE D3DXQUATERNION* D3DXQuaternionIdentity + ( D3DXQUATERNION *pOut ) +{ +#ifdef D3DX_DEBUG + if(!pOut) + return NULL; +#endif + + pOut->x = pOut->y = pOut->z = 0.0f; + pOut->w = 1.0f; + return pOut; +} + +D3DXINLINE BOOL D3DXQuaternionIsIdentity + ( CONST D3DXQUATERNION *pQ ) +{ +#ifdef D3DX_DEBUG + if(!pQ) + return FALSE; +#endif + + return pQ->x == 0.0f && pQ->y == 0.0f && pQ->z == 0.0f && pQ->w == 1.0f; +} + + +D3DXINLINE D3DXQUATERNION* D3DXQuaternionConjugate + ( D3DXQUATERNION *pOut, CONST D3DXQUATERNION *pQ ) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pQ) + return NULL; +#endif + + pOut->x = -pQ->x; + pOut->y = -pQ->y; + pOut->z = -pQ->z; + pOut->w = pQ->w; + return pOut; +} + + +//-------------------------- +// Plane +//-------------------------- + +D3DXINLINE FLOAT D3DXPlaneDot + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR4 *pV) +{ +#ifdef D3DX_DEBUG + if(!pP || !pV) + return 0.0f; +#endif + + return pP->a * pV->x + pP->b * pV->y + pP->c * pV->z + pP->d * pV->w; +} + +D3DXINLINE FLOAT D3DXPlaneDotCoord + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR3 *pV) +{ +#ifdef D3DX_DEBUG + if(!pP || !pV) + return 0.0f; +#endif + + return pP->a * pV->x + pP->b * pV->y + pP->c * pV->z + pP->d; +} + +D3DXINLINE FLOAT D3DXPlaneDotNormal + ( CONST D3DXPLANE *pP, CONST D3DXVECTOR3 *pV) +{ +#ifdef D3DX_DEBUG + if(!pP || !pV) + return 0.0f; +#endif + + return pP->a * pV->x + pP->b * pV->y + pP->c * pV->z; +} + + +//-------------------------- +// Color +//-------------------------- + +D3DXINLINE D3DXCOLOR* D3DXColorNegative + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC) + return NULL; +#endif + + pOut->r = 1.0f - pC->r; + pOut->g = 1.0f - pC->g; + pOut->b = 1.0f - pC->b; + pOut->a = pC->a; + return pOut; +} + +D3DXINLINE D3DXCOLOR* D3DXColorAdd + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC1 || !pC2) + return NULL; +#endif + + pOut->r = pC1->r + pC2->r; + pOut->g = pC1->g + pC2->g; + pOut->b = pC1->b + pC2->b; + pOut->a = pC1->a + pC2->a; + return pOut; +} + +D3DXINLINE D3DXCOLOR* D3DXColorSubtract + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC1 || !pC2) + return NULL; +#endif + + pOut->r = pC1->r - pC2->r; + pOut->g = pC1->g - pC2->g; + pOut->b = pC1->b - pC2->b; + pOut->a = pC1->a - pC2->a; + return pOut; +} + +D3DXINLINE D3DXCOLOR* D3DXColorScale + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC, FLOAT s) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC) + return NULL; +#endif + + pOut->r = pC->r * s; + pOut->g = pC->g * s; + pOut->b = pC->b * s; + pOut->a = pC->a * s; + return pOut; +} + +D3DXINLINE D3DXCOLOR* D3DXColorModulate + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC1 || !pC2) + return NULL; +#endif + + pOut->r = pC1->r * pC2->r; + pOut->g = pC1->g * pC2->g; + pOut->b = pC1->b * pC2->b; + pOut->a = pC1->a * pC2->a; + return pOut; +} + +D3DXINLINE D3DXCOLOR* D3DXColorLerp + (D3DXCOLOR *pOut, CONST D3DXCOLOR *pC1, CONST D3DXCOLOR *pC2, FLOAT s) +{ +#ifdef D3DX_DEBUG + if(!pOut || !pC1 || !pC2) + return NULL; +#endif + + pOut->r = pC1->r + s * (pC2->r - pC1->r); + pOut->g = pC1->g + s * (pC2->g - pC1->g); + pOut->b = pC1->b + s * (pC2->b - pC1->b); + pOut->a = pC1->a + s * (pC2->a - pC1->a); + return pOut; +} + + +#endif // __D3DX8MATH_INL__ diff --git a/plugins/ADK/d3d8/includes/d3dx8mesh.h b/plugins/ADK/d3d8/includes/d3dx8mesh.h new file mode 100644 index 0000000..5408cd3 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8mesh.h @@ -0,0 +1,760 @@ +////////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8mesh.h +// Content: D3DX mesh types and functions +// +////////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8MESH_H__ +#define __D3DX8MESH_H__ + +#include "dxfile.h" // defines LPDIRECTXFILEDATA + +// {2A835771-BF4D-43f4-8E14-82A809F17D8A} +DEFINE_GUID(IID_ID3DXBaseMesh, +0x2a835771, 0xbf4d, 0x43f4, 0x8e, 0x14, 0x82, 0xa8, 0x9, 0xf1, 0x7d, 0x8a); + +// {CCAE5C3B-4DD1-4d0f-997E-4684CA64557F} +DEFINE_GUID(IID_ID3DXMesh, +0xccae5c3b, 0x4dd1, 0x4d0f, 0x99, 0x7e, 0x46, 0x84, 0xca, 0x64, 0x55, 0x7f); + +// {19FBE386-C282-4659-97BD-CB869B084A6C} +DEFINE_GUID(IID_ID3DXPMesh, +0x19fbe386, 0xc282, 0x4659, 0x97, 0xbd, 0xcb, 0x86, 0x9b, 0x8, 0x4a, 0x6c); + +// {4E3CA05C-D4FF-4d11-8A02-16459E08F6F4} +DEFINE_GUID(IID_ID3DXSPMesh, +0x4e3ca05c, 0xd4ff, 0x4d11, 0x8a, 0x2, 0x16, 0x45, 0x9e, 0x8, 0xf6, 0xf4); + +// {8DB06ECC-EBFC-408a-9404-3074B4773515} +DEFINE_GUID(IID_ID3DXSkinMesh, +0x8db06ecc, 0xebfc, 0x408a, 0x94, 0x4, 0x30, 0x74, 0xb4, 0x77, 0x35, 0x15); + +// Mesh options - lower 3 bytes only, upper byte used by _D3DXMESHOPT option flags +enum _D3DXMESH { + D3DXMESH_32BIT = 0x001, // If set, then use 32 bit indices, if not set use 16 bit indices. + D3DXMESH_DONOTCLIP = 0x002, // Use D3DUSAGE_DONOTCLIP for VB & IB. + D3DXMESH_POINTS = 0x004, // Use D3DUSAGE_POINTS for VB & IB. + D3DXMESH_RTPATCHES = 0x008, // Use D3DUSAGE_RTPATCHES for VB & IB. + D3DXMESH_NPATCHES = 0x4000,// Use D3DUSAGE_NPATCHES for VB & IB. + D3DXMESH_VB_SYSTEMMEM = 0x010, // Use D3DPOOL_SYSTEMMEM for VB. Overrides D3DXMESH_MANAGEDVERTEXBUFFER + D3DXMESH_VB_MANAGED = 0x020, // Use D3DPOOL_MANAGED for VB. + D3DXMESH_VB_WRITEONLY = 0x040, // Use D3DUSAGE_WRITEONLY for VB. + D3DXMESH_VB_DYNAMIC = 0x080, // Use D3DUSAGE_DYNAMIC for VB. + D3DXMESH_VB_SOFTWAREPROCESSING = 0x8000, // Use D3DUSAGE_SOFTWAREPROCESSING for VB. + D3DXMESH_IB_SYSTEMMEM = 0x100, // Use D3DPOOL_SYSTEMMEM for IB. Overrides D3DXMESH_MANAGEDINDEXBUFFER + D3DXMESH_IB_MANAGED = 0x200, // Use D3DPOOL_MANAGED for IB. + D3DXMESH_IB_WRITEONLY = 0x400, // Use D3DUSAGE_WRITEONLY for IB. + D3DXMESH_IB_DYNAMIC = 0x800, // Use D3DUSAGE_DYNAMIC for IB. + D3DXMESH_IB_SOFTWAREPROCESSING= 0x10000, // Use D3DUSAGE_SOFTWAREPROCESSING for IB. + + D3DXMESH_VB_SHARE = 0x1000, // Valid for Clone* calls only, forces cloned mesh/pmesh to share vertex buffer + + D3DXMESH_USEHWONLY = 0x2000, // Valid for ID3DXSkinMesh::ConvertToBlendedMesh + + // Helper options + D3DXMESH_SYSTEMMEM = 0x110, // D3DXMESH_VB_SYSTEMMEM | D3DXMESH_IB_SYSTEMMEM + D3DXMESH_MANAGED = 0x220, // D3DXMESH_VB_MANAGED | D3DXMESH_IB_MANAGED + D3DXMESH_WRITEONLY = 0x440, // D3DXMESH_VB_WRITEONLY | D3DXMESH_IB_WRITEONLY + D3DXMESH_DYNAMIC = 0x880, // D3DXMESH_VB_DYNAMIC | D3DXMESH_IB_DYNAMIC + D3DXMESH_SOFTWAREPROCESSING = 0x18000, // D3DXMESH_VB_SOFTWAREPROCESSING | D3DXMESH_IB_SOFTWAREPROCESSING + +}; + +// option field values for specifying min value in D3DXGeneratePMesh and D3DXSimplifyMesh +enum _D3DXMESHSIMP +{ + D3DXMESHSIMP_VERTEX = 0x1, + D3DXMESHSIMP_FACE = 0x2, + +}; + +enum _MAX_FVF_DECL_SIZE +{ + MAX_FVF_DECL_SIZE = 20 +}; + +typedef struct ID3DXBaseMesh *LPD3DXBASEMESH; +typedef struct ID3DXMesh *LPD3DXMESH; +typedef struct ID3DXPMesh *LPD3DXPMESH; +typedef struct ID3DXSPMesh *LPD3DXSPMESH; +typedef struct ID3DXSkinMesh *LPD3DXSKINMESH; + +typedef struct _D3DXATTRIBUTERANGE +{ + DWORD AttribId; + DWORD FaceStart; + DWORD FaceCount; + DWORD VertexStart; + DWORD VertexCount; +} D3DXATTRIBUTERANGE; + +typedef D3DXATTRIBUTERANGE* LPD3DXATTRIBUTERANGE; + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus +struct D3DXMATERIAL +{ + D3DMATERIAL8 MatD3D; + LPSTR pTextureFilename; +}; +typedef struct D3DXMATERIAL *LPD3DXMATERIAL; +#ifdef __cplusplus +} +#endif //__cplusplus + +typedef struct _D3DXATTRIBUTEWEIGHTS +{ + FLOAT Position; + FLOAT Boundary; + FLOAT Normal; + FLOAT Diffuse; + FLOAT Specular; + FLOAT Tex[8]; +} D3DXATTRIBUTEWEIGHTS; + +typedef D3DXATTRIBUTEWEIGHTS* LPD3DXATTRIBUTEWEIGHTS; + +enum _D3DXWELDEPSILONSFLAGS +{ + D3DXWELDEPSILONS_WELDALL = 0x1, // weld all vertices marked by adjacency as being overlapping + + D3DXWELDEPSILONS_WELDPARTIALMATCHES = 0x2, // if a given vertex component is within epsilon, modify partial matched + // vertices so that both components identical AND if all components "equal" + // remove one of the vertices + D3DXWELDEPSILONS_DONOTREMOVEVERTICES = 0x4, // instructs weld to only allow modifications to vertices and not removal + // ONLY valid if D3DXWELDEPSILONS_WELDPARTIALMATCHES is set + // useful to modify vertices to be equal, but not allow vertices to be removed +}; + +typedef struct _D3DXWELDEPSILONS +{ + FLOAT SkinWeights; + FLOAT Normal; + FLOAT Tex[8]; + DWORD Flags; +} D3DXWELDEPSILONS; + +typedef D3DXWELDEPSILONS* LPD3DXWELDEPSILONS; + + +#undef INTERFACE +#define INTERFACE ID3DXBaseMesh + +DECLARE_INTERFACE_(ID3DXBaseMesh, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXBaseMesh + STDMETHOD(DrawSubset)(THIS_ DWORD AttribId) PURE; + STDMETHOD_(DWORD, GetNumFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetNumVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetFVF)(THIS) PURE; + STDMETHOD(GetDeclaration)(THIS_ DWORD Declaration[MAX_FVF_DECL_SIZE]) PURE; + STDMETHOD_(DWORD, GetOptions)(THIS) PURE; + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(CloneMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(CloneMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(GetVertexBuffer)(THIS_ LPDIRECT3DVERTEXBUFFER8* ppVB) PURE; + STDMETHOD(GetIndexBuffer)(THIS_ LPDIRECT3DINDEXBUFFER8* ppIB) PURE; + STDMETHOD(LockVertexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockVertexBuffer)(THIS) PURE; + STDMETHOD(LockIndexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockIndexBuffer)(THIS) PURE; + STDMETHOD(GetAttributeTable)( + THIS_ D3DXATTRIBUTERANGE *pAttribTable, DWORD* pAttribTableSize) PURE; + + STDMETHOD(ConvertPointRepsToAdjacency)(THIS_ CONST DWORD* pPRep, DWORD* pAdjacency) PURE; + STDMETHOD(ConvertAdjacencyToPointReps)(THIS_ CONST DWORD* pAdjacency, DWORD* pPRep) PURE; + STDMETHOD(GenerateAdjacency)(THIS_ FLOAT Epsilon, DWORD* pAdjacency) PURE; +}; + + +#undef INTERFACE +#define INTERFACE ID3DXMesh + +DECLARE_INTERFACE_(ID3DXMesh, ID3DXBaseMesh) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXBaseMesh + STDMETHOD(DrawSubset)(THIS_ DWORD AttribId) PURE; + STDMETHOD_(DWORD, GetNumFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetNumVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetFVF)(THIS) PURE; + STDMETHOD(GetDeclaration)(THIS_ DWORD Declaration[MAX_FVF_DECL_SIZE]) PURE; + STDMETHOD_(DWORD, GetOptions)(THIS) PURE; + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(CloneMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(CloneMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(GetVertexBuffer)(THIS_ LPDIRECT3DVERTEXBUFFER8* ppVB) PURE; + STDMETHOD(GetIndexBuffer)(THIS_ LPDIRECT3DINDEXBUFFER8* ppIB) PURE; + STDMETHOD(LockVertexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockVertexBuffer)(THIS) PURE; + STDMETHOD(LockIndexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockIndexBuffer)(THIS) PURE; + STDMETHOD(GetAttributeTable)( + THIS_ D3DXATTRIBUTERANGE *pAttribTable, DWORD* pAttribTableSize) PURE; + + STDMETHOD(ConvertPointRepsToAdjacency)(THIS_ CONST DWORD* pPRep, DWORD* pAdjacency) PURE; + STDMETHOD(ConvertAdjacencyToPointReps)(THIS_ CONST DWORD* pAdjacency, DWORD* pPRep) PURE; + STDMETHOD(GenerateAdjacency)(THIS_ FLOAT Epsilon, DWORD* pAdjacency) PURE; + + // ID3DXMesh + STDMETHOD(LockAttributeBuffer)(THIS_ DWORD Flags, DWORD** ppData) PURE; + STDMETHOD(UnlockAttributeBuffer)(THIS) PURE; + STDMETHOD(Optimize)(THIS_ DWORD Flags, CONST DWORD* pAdjacencyIn, DWORD* pAdjacencyOut, + DWORD* pFaceRemap, LPD3DXBUFFER *ppVertexRemap, + LPD3DXMESH* ppOptMesh) PURE; + STDMETHOD(OptimizeInplace)(THIS_ DWORD Flags, CONST DWORD* pAdjacencyIn, DWORD* pAdjacencyOut, + DWORD* pFaceRemap, LPD3DXBUFFER *ppVertexRemap) PURE; + +}; + + +#undef INTERFACE +#define INTERFACE ID3DXPMesh + +DECLARE_INTERFACE_(ID3DXPMesh, ID3DXBaseMesh) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXBaseMesh + STDMETHOD(DrawSubset)(THIS_ DWORD AttribId) PURE; + STDMETHOD_(DWORD, GetNumFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetNumVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetFVF)(THIS) PURE; + STDMETHOD(GetDeclaration)(THIS_ DWORD Declaration[MAX_FVF_DECL_SIZE]) PURE; + STDMETHOD_(DWORD, GetOptions)(THIS) PURE; + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(CloneMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(CloneMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3DDevice, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(GetVertexBuffer)(THIS_ LPDIRECT3DVERTEXBUFFER8* ppVB) PURE; + STDMETHOD(GetIndexBuffer)(THIS_ LPDIRECT3DINDEXBUFFER8* ppIB) PURE; + STDMETHOD(LockVertexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockVertexBuffer)(THIS) PURE; + STDMETHOD(LockIndexBuffer)(THIS_ DWORD Flags, BYTE** ppData) PURE; + STDMETHOD(UnlockIndexBuffer)(THIS) PURE; + STDMETHOD(GetAttributeTable)( + THIS_ D3DXATTRIBUTERANGE *pAttribTable, DWORD* pAttribTableSize) PURE; + + STDMETHOD(ConvertPointRepsToAdjacency)(THIS_ CONST DWORD* pPRep, DWORD* pAdjacency) PURE; + STDMETHOD(ConvertAdjacencyToPointReps)(THIS_ CONST DWORD* pAdjacency, DWORD* pPRep) PURE; + STDMETHOD(GenerateAdjacency)(THIS_ FLOAT Epsilon, DWORD* pAdjacency) PURE; + + // ID3DXPMesh + STDMETHOD(ClonePMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3D, LPD3DXPMESH* ppCloneMesh) PURE; + STDMETHOD(ClonePMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3D, LPD3DXPMESH* ppCloneMesh) PURE; + STDMETHOD(SetNumFaces)(THIS_ DWORD Faces) PURE; + STDMETHOD(SetNumVertices)(THIS_ DWORD Vertices) PURE; + STDMETHOD_(DWORD, GetMaxFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetMinFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetMaxVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetMinVertices)(THIS) PURE; + STDMETHOD(Save)(THIS_ IStream *pStream, LPD3DXMATERIAL pMaterials, DWORD NumMaterials) PURE; + + STDMETHOD(Optimize)(THIS_ DWORD Flags, DWORD* pAdjacencyOut, + DWORD* pFaceRemap, LPD3DXBUFFER *ppVertexRemap, + LPD3DXMESH* ppOptMesh) PURE; + + STDMETHOD(OptimizeBaseLOD)(THIS_ DWORD Flags, DWORD* pFaceRemap) PURE; + STDMETHOD(TrimByFaces)(THIS_ DWORD NewFacesMin, DWORD NewFacesMax, DWORD *rgiFaceRemap, DWORD *rgiVertRemap) PURE; + STDMETHOD(TrimByVertices)(THIS_ DWORD NewVerticesMin, DWORD NewVerticesMax, DWORD *rgiFaceRemap, DWORD *rgiVertRemap) PURE; + + STDMETHOD(GetAdjacency)(THIS_ DWORD* pAdjacency) PURE; +}; + + +#undef INTERFACE +#define INTERFACE ID3DXSPMesh + +DECLARE_INTERFACE_(ID3DXSPMesh, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXSPMesh + STDMETHOD_(DWORD, GetNumFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetNumVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetFVF)(THIS) PURE; + STDMETHOD(GetDeclaration)(THIS_ DWORD Declaration[MAX_FVF_DECL_SIZE]) PURE; + STDMETHOD_(DWORD, GetOptions)(THIS) PURE; + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(CloneMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3D, DWORD *pAdjacencyOut, DWORD *pVertexRemapOut, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(CloneMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3DDevice, DWORD *pAdjacencyOut, DWORD *pVertexRemapOut, LPD3DXMESH* ppCloneMesh) PURE; + STDMETHOD(ClonePMeshFVF)(THIS_ DWORD Options, + DWORD FVF, LPDIRECT3DDEVICE8 pD3D, DWORD *pVertexRemapOut, LPD3DXPMESH* ppCloneMesh) PURE; + STDMETHOD(ClonePMesh)(THIS_ DWORD Options, + CONST DWORD *pDeclaration, LPDIRECT3DDEVICE8 pD3D, DWORD *pVertexRemapOut, LPD3DXPMESH* ppCloneMesh) PURE; + STDMETHOD(ReduceFaces)(THIS_ DWORD Faces) PURE; + STDMETHOD(ReduceVertices)(THIS_ DWORD Vertices) PURE; + STDMETHOD_(DWORD, GetMaxFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetMaxVertices)(THIS) PURE; + STDMETHOD(GetVertexAttributeWeights)(THIS_ LPD3DXATTRIBUTEWEIGHTS pVertexAttributeWeights) PURE; + STDMETHOD(GetVertexWeights)(THIS_ FLOAT *pVertexWeights) PURE; +}; + +#define UNUSED16 (0xffff) +#define UNUSED32 (0xffffffff) + +// ID3DXMesh::Optimize options - upper byte only, lower 3 bytes used from _D3DXMESH option flags +enum _D3DXMESHOPT { + D3DXMESHOPT_COMPACT = 0x01000000, + D3DXMESHOPT_ATTRSORT = 0x02000000, + D3DXMESHOPT_VERTEXCACHE = 0x04000000, + D3DXMESHOPT_STRIPREORDER = 0x08000000, + D3DXMESHOPT_IGNOREVERTS = 0x10000000, // optimize faces only, don't touch vertices + D3DXMESHOPT_SHAREVB = 0x1000, // same as D3DXMESH_VB_SHARE +}; + +// Subset of the mesh that has the same attribute and bone combination. +// This subset can be rendered in a single draw call +typedef struct _D3DXBONECOMBINATION +{ + DWORD AttribId; + DWORD FaceStart; + DWORD FaceCount; + DWORD VertexStart; + DWORD VertexCount; + DWORD* BoneId; +} D3DXBONECOMBINATION, *LPD3DXBONECOMBINATION; + + +#undef INTERFACE +#define INTERFACE ID3DXSkinMesh + +DECLARE_INTERFACE_(ID3DXSkinMesh, IUnknown) +{ + // IUnknown + STDMETHOD(QueryInterface)(THIS_ REFIID iid, LPVOID *ppv) PURE; + STDMETHOD_(ULONG, AddRef)(THIS) PURE; + STDMETHOD_(ULONG, Release)(THIS) PURE; + + // ID3DXMesh + STDMETHOD_(DWORD, GetNumFaces)(THIS) PURE; + STDMETHOD_(DWORD, GetNumVertices)(THIS) PURE; + STDMETHOD_(DWORD, GetFVF)(THIS) PURE; + STDMETHOD(GetDeclaration)(THIS_ DWORD Declaration[MAX_FVF_DECL_SIZE]) PURE; + STDMETHOD_(DWORD, GetOptions)(THIS) PURE; + STDMETHOD(GetDevice)(THIS_ LPDIRECT3DDEVICE8* ppDevice) PURE; + STDMETHOD(GetVertexBuffer)(THIS_ LPDIRECT3DVERTEXBUFFER8* ppVB) PURE; + STDMETHOD(GetIndexBuffer)(THIS_ LPDIRECT3DINDEXBUFFER8* ppIB) PURE; + STDMETHOD(LockVertexBuffer)(THIS_ DWORD flags, BYTE** ppData) PURE; + STDMETHOD(UnlockVertexBuffer)(THIS) PURE; + STDMETHOD(LockIndexBuffer)(THIS_ DWORD flags, BYTE** ppData) PURE; + STDMETHOD(UnlockIndexBuffer)(THIS) PURE; + STDMETHOD(LockAttributeBuffer)(THIS_ DWORD flags, DWORD** ppData) PURE; + STDMETHOD(UnlockAttributeBuffer)(THIS) PURE; + // ID3DXSkinMesh + STDMETHOD_(DWORD, GetNumBones)(THIS) PURE; + STDMETHOD(GetOriginalMesh)(THIS_ LPD3DXMESH* ppMesh) PURE; + STDMETHOD(SetBoneInfluence)(THIS_ DWORD bone, DWORD numInfluences, CONST DWORD* vertices, CONST FLOAT* weights) PURE; + STDMETHOD_(DWORD, GetNumBoneInfluences)(THIS_ DWORD bone) PURE; + STDMETHOD(GetBoneInfluence)(THIS_ DWORD bone, DWORD* vertices, FLOAT* weights) PURE; + STDMETHOD(GetMaxVertexInfluences)(THIS_ DWORD* maxVertexInfluences) PURE; + STDMETHOD(GetMaxFaceInfluences)(THIS_ DWORD* maxFaceInfluences) PURE; + + STDMETHOD(ConvertToBlendedMesh)(THIS_ DWORD Options, + CONST LPDWORD pAdjacencyIn, + LPDWORD pAdjacencyOut, + DWORD* pNumBoneCombinations, + LPD3DXBUFFER* ppBoneCombinationTable, + DWORD* pFaceRemap, + LPD3DXBUFFER *ppVertexRemap, + LPD3DXMESH* ppMesh) PURE; + + STDMETHOD(ConvertToIndexedBlendedMesh)(THIS_ DWORD Options, + CONST LPDWORD pAdjacencyIn, + DWORD paletteSize, + LPDWORD pAdjacencyOut, + DWORD* pNumBoneCombinations, + LPD3DXBUFFER* ppBoneCombinationTable, + DWORD* pFaceRemap, + LPD3DXBUFFER *ppVertexRemap, + LPD3DXMESH* ppMesh) PURE; + + STDMETHOD(GenerateSkinnedMesh)(THIS_ DWORD Options, + FLOAT minWeight, + CONST LPDWORD pAdjacencyIn, + LPDWORD pAdjacencyOut, + DWORD* pFaceRemap, + LPD3DXBUFFER *ppVertexRemap, + LPD3DXMESH* ppMesh) PURE; + STDMETHOD(UpdateSkinnedMesh)(THIS_ CONST D3DXMATRIX* pBoneTransforms, CONST D3DXMATRIX* pBoneInvTransforms, LPD3DXMESH pMesh) PURE; +}; + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +HRESULT WINAPI + D3DXCreateMesh( + DWORD NumFaces, + DWORD NumVertices, + DWORD Options, + CONST DWORD *pDeclaration, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXMESH* ppMesh); + +HRESULT WINAPI + D3DXCreateMeshFVF( + DWORD NumFaces, + DWORD NumVertices, + DWORD Options, + DWORD FVF, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXMESH* ppMesh); + +HRESULT WINAPI + D3DXCreateSPMesh( + LPD3DXMESH pMesh, + CONST DWORD* pAdjacency, + CONST LPD3DXATTRIBUTEWEIGHTS pVertexAttributeWeights, + CONST FLOAT *pVertexWeights, + LPD3DXSPMESH* ppSMesh); + +// clean a mesh up for simplification, try to make manifold +HRESULT WINAPI + D3DXCleanMesh( + LPD3DXMESH pMeshIn, + CONST DWORD* pAdjacencyIn, + LPD3DXMESH* ppMeshOut, + DWORD* pAdjacencyOut, + LPD3DXBUFFER* ppErrorsAndWarnings); + +HRESULT WINAPI + D3DXValidMesh( + LPD3DXMESH pMeshIn, + CONST DWORD* pAdjacency, + LPD3DXBUFFER* ppErrorsAndWarnings); + +HRESULT WINAPI + D3DXGeneratePMesh( + LPD3DXMESH pMesh, + CONST DWORD* pAdjacency, + CONST LPD3DXATTRIBUTEWEIGHTS pVertexAttributeWeights, + CONST FLOAT *pVertexWeights, + DWORD MinValue, + DWORD Options, + LPD3DXPMESH* ppPMesh); + +HRESULT WINAPI + D3DXSimplifyMesh( + LPD3DXMESH pMesh, + CONST DWORD* pAdjacency, + CONST LPD3DXATTRIBUTEWEIGHTS pVertexAttributeWeights, + CONST FLOAT *pVertexWeights, + DWORD MinValue, + DWORD Options, + LPD3DXMESH* ppMesh); + +HRESULT WINAPI + D3DXComputeBoundingSphere( + PVOID pPointsFVF, + DWORD NumVertices, + DWORD FVF, + D3DXVECTOR3 *pCenter, + FLOAT *pRadius); + +HRESULT WINAPI + D3DXComputeBoundingBox( + PVOID pPointsFVF, + DWORD NumVertices, + DWORD FVF, + D3DXVECTOR3 *pMin, + D3DXVECTOR3 *pMax); + +HRESULT WINAPI + D3DXComputeNormals( + LPD3DXBASEMESH pMesh, + CONST DWORD *pAdjacency); + +HRESULT WINAPI + D3DXCreateBuffer( + DWORD NumBytes, + LPD3DXBUFFER *ppBuffer); + + +HRESULT WINAPI + D3DXLoadMeshFromX( + LPSTR pFilename, + DWORD Options, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXBUFFER *ppAdjacency, + LPD3DXBUFFER *ppMaterials, + DWORD *pNumMaterials, + LPD3DXMESH *ppMesh); + +HRESULT WINAPI + D3DXLoadMeshFromXInMemory( + PBYTE Memory, + DWORD SizeOfMemory, + DWORD Options, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXBUFFER *ppAdjacency, + LPD3DXBUFFER *ppMaterials, + DWORD *pNumMaterials, + LPD3DXMESH *ppMesh); + +HRESULT WINAPI + D3DXLoadMeshFromXResource( + HMODULE Module, + LPCTSTR Name, + LPCTSTR Type, + DWORD Options, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXBUFFER *ppAdjacency, + LPD3DXBUFFER *ppMaterials, + DWORD *pNumMaterials, + LPD3DXMESH *ppMesh); + +HRESULT WINAPI + D3DXSaveMeshToX( + LPSTR pFilename, + LPD3DXMESH pMesh, + CONST DWORD* pAdjacency, + CONST LPD3DXMATERIAL pMaterials, + DWORD NumMaterials, + DWORD Format + ); + +HRESULT WINAPI + D3DXCreatePMeshFromStream( + IStream *pStream, + DWORD Options, + LPDIRECT3DDEVICE8 pD3DDevice, + LPD3DXBUFFER *ppMaterials, + DWORD* pNumMaterials, + LPD3DXPMESH *ppPMesh); + +HRESULT WINAPI + D3DXCreateSkinMesh( + DWORD NumFaces, + DWORD NumVertices, + DWORD NumBones, + DWORD Options, + CONST DWORD *pDeclaration, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXSKINMESH* ppSkinMesh); + +HRESULT WINAPI + D3DXCreateSkinMeshFVF( + DWORD NumFaces, + DWORD NumVertices, + DWORD NumBones, + DWORD Options, + DWORD FVF, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXSKINMESH* ppSkinMesh); + +HRESULT WINAPI + D3DXCreateSkinMeshFromMesh( + LPD3DXMESH pMesh, + DWORD numBones, + LPD3DXSKINMESH* ppSkinMesh); + +HRESULT WINAPI + D3DXLoadMeshFromXof( + LPDIRECTXFILEDATA pXofObjMesh, + DWORD Options, + LPDIRECT3DDEVICE8 pD3DDevice, + LPD3DXBUFFER *ppAdjacency, + LPD3DXBUFFER *ppMaterials, + DWORD *pNumMaterials, + LPD3DXMESH *ppMesh); + +HRESULT WINAPI + D3DXLoadSkinMeshFromXof( + LPDIRECTXFILEDATA pxofobjMesh, + DWORD Options, + LPDIRECT3DDEVICE8 pD3D, + LPD3DXBUFFER* ppAdjacency, + LPD3DXBUFFER* ppMaterials, + DWORD *pMatOut, + LPD3DXBUFFER* ppBoneNames, + LPD3DXBUFFER* ppBoneTransforms, + LPD3DXSKINMESH* ppMesh); + +HRESULT WINAPI + D3DXTessellateNPatches( + LPD3DXMESH pMeshIn, + CONST DWORD* pAdjacencyIn, + FLOAT NumSegs, + BOOL QuadraticInterpNormals, // if false use linear intrep for normals, if true use quadratic + LPD3DXMESH *ppMeshOut, + LPD3DXBUFFER *ppAdjacencyOut); + +UINT WINAPI + D3DXGetFVFVertexSize(DWORD FVF); + +HRESULT WINAPI + D3DXDeclaratorFromFVF( + DWORD FVF, + DWORD Declaration[MAX_FVF_DECL_SIZE]); + +HRESULT WINAPI + D3DXFVFFromDeclarator( + CONST DWORD *pDeclarator, + DWORD *pFVF); + +HRESULT WINAPI + D3DXWeldVertices( + CONST LPD3DXMESH pMesh, + LPD3DXWELDEPSILONS pEpsilons, + CONST DWORD *pAdjacencyIn, + DWORD *pAdjacencyOut, + DWORD* pFaceRemap, + LPD3DXBUFFER *ppVertexRemap); + +typedef struct _D3DXINTERSECTINFO +{ + DWORD FaceIndex; // index of face intersected + FLOAT U; // Barycentric Hit Coordinates + FLOAT V; // Barycentric Hit Coordinates + FLOAT Dist; // Ray-Intersection Parameter Distance +} D3DXINTERSECTINFO, *LPD3DXINTERSECTINFO; + + +HRESULT WINAPI + D3DXIntersect( + LPD3DXBASEMESH pMesh, + CONST D3DXVECTOR3 *pRayPos, + CONST D3DXVECTOR3 *pRayDir, + BOOL *pHit, // True if any faces were intersected + DWORD *pFaceIndex, // index of closest face intersected + FLOAT *pU, // Barycentric Hit Coordinates + FLOAT *pV, // Barycentric Hit Coordinates + FLOAT *pDist, // Ray-Intersection Parameter Distance + LPD3DXBUFFER *ppAllHits, // Array of D3DXINTERSECTINFOs for all hits (not just closest) + DWORD *pCountOfHits); // Number of entries in AllHits array + +HRESULT WINAPI + D3DXIntersectSubset( + LPD3DXBASEMESH pMesh, + DWORD AttribId, + CONST D3DXVECTOR3 *pRayPos, + CONST D3DXVECTOR3 *pRayDir, + BOOL *pHit, // True if any faces were intersected + DWORD *pFaceIndex, // index of closest face intersected + FLOAT *pU, // Barycentric Hit Coordinates + FLOAT *pV, // Barycentric Hit Coordinates + FLOAT *pDist, // Ray-Intersection Parameter Distance + LPD3DXBUFFER *ppAllHits, // Array of D3DXINTERSECTINFOs for all hits (not just closest) + DWORD *pCountOfHits); // Number of entries in AllHits array + + +HRESULT WINAPI D3DXSplitMesh + ( + CONST LPD3DXMESH pMeshIn, + CONST DWORD *pAdjacencyIn, + CONST DWORD MaxSize, + CONST DWORD Options, + DWORD *pMeshesOut, + LPD3DXBUFFER *ppMeshArrayOut, + LPD3DXBUFFER *ppAdjacencyArrayOut, + LPD3DXBUFFER *ppFaceRemapArrayOut, + LPD3DXBUFFER *ppVertRemapArrayOut + ); + +BOOL D3DXIntersectTri +( + CONST D3DXVECTOR3 *p0, // Triangle vertex 0 position + CONST D3DXVECTOR3 *p1, // Triangle vertex 1 position + CONST D3DXVECTOR3 *p2, // Triangle vertex 2 position + CONST D3DXVECTOR3 *pRayPos, // Ray origin + CONST D3DXVECTOR3 *pRayDir, // Ray direction + FLOAT *pU, // Barycentric Hit Coordinates + FLOAT *pV, // Barycentric Hit Coordinates + FLOAT *pDist); // Ray-Intersection Parameter Distance + +BOOL WINAPI + D3DXSphereBoundProbe( + CONST D3DXVECTOR3 *pCenter, + FLOAT Radius, + CONST D3DXVECTOR3 *pRayPosition, + CONST D3DXVECTOR3 *pRayDirection); + +BOOL WINAPI + D3DXBoxBoundProbe( + CONST D3DXVECTOR3 *pMin, + CONST D3DXVECTOR3 *pMax, + CONST D3DXVECTOR3 *pRayPosition, + CONST D3DXVECTOR3 *pRayDirection); + +enum _D3DXERR { + D3DXERR_CANNOTMODIFYINDEXBUFFER = MAKE_DDHRESULT(2900), + D3DXERR_INVALIDMESH = MAKE_DDHRESULT(2901), + D3DXERR_CANNOTATTRSORT = MAKE_DDHRESULT(2902), + D3DXERR_SKINNINGNOTSUPPORTED = MAKE_DDHRESULT(2903), + D3DXERR_TOOMANYINFLUENCES = MAKE_DDHRESULT(2904), + D3DXERR_INVALIDDATA = MAKE_DDHRESULT(2905), + D3DXERR_LOADEDMESHASNODATA = MAKE_DDHRESULT(2906), +}; + + +#define D3DX_COMP_TANGENT_NONE 0xFFFFFFFF + +HRESULT WINAPI D3DXComputeTangent(LPD3DXMESH InMesh, + DWORD TexStage, + LPD3DXMESH OutMesh, + DWORD TexStageUVec, + DWORD TexStageVVec, + DWORD Wrap, + DWORD *Adjacency); + +HRESULT WINAPI +D3DXConvertMeshSubsetToSingleStrip +( + LPD3DXBASEMESH MeshIn, + DWORD AttribId, + DWORD IBOptions, + LPDIRECT3DINDEXBUFFER8 *ppIndexBuffer, + DWORD *pNumIndices +); + +HRESULT WINAPI +D3DXConvertMeshSubsetToStrips +( + LPD3DXBASEMESH MeshIn, + DWORD AttribId, + DWORD IBOptions, + LPDIRECT3DINDEXBUFFER8 *ppIndexBuffer, + DWORD *pNumIndices, + LPD3DXBUFFER *ppStripLengths, + DWORD *pNumStrips +); + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif //__D3DX8MESH_H__ + + diff --git a/plugins/ADK/d3d8/includes/d3dx8shape.h b/plugins/ADK/d3d8/includes/d3dx8shape.h new file mode 100644 index 0000000..b7ab637 --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8shape.h @@ -0,0 +1,220 @@ +/////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8shapes.h +// Content: D3DX simple shapes +// +/////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8SHAPES_H__ +#define __D3DX8SHAPES_H__ + +/////////////////////////////////////////////////////////////////////////// +// Functions: +/////////////////////////////////////////////////////////////////////////// + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + + +//------------------------------------------------------------------------- +// D3DXCreatePolygon: +// ------------------ +// Creates a mesh containing an n-sided polygon. The polygon is centered +// at the origin. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// Length Length of each side. +// Sides Number of sides the polygon has. (Must be >= 3) +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreatePolygon( + LPDIRECT3DDEVICE8 pDevice, + FLOAT Length, + UINT Sides, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateBox: +// -------------- +// Creates a mesh containing an axis-aligned box. The box is centered at +// the origin. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// Width Width of box (along X-axis) +// Height Height of box (along Y-axis) +// Depth Depth of box (along Z-axis) +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateBox( + LPDIRECT3DDEVICE8 pDevice, + FLOAT Width, + FLOAT Height, + FLOAT Depth, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateCylinder: +// ------------------- +// Creates a mesh containing a cylinder. The generated cylinder is +// centered at the origin, and its axis is aligned with the Z-axis. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// Radius1 Radius at -Z end (should be >= 0.0f) +// Radius2 Radius at +Z end (should be >= 0.0f) +// Length Length of cylinder (along Z-axis) +// Slices Number of slices about the main axis +// Stacks Number of stacks along the main axis +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateCylinder( + LPDIRECT3DDEVICE8 pDevice, + FLOAT Radius1, + FLOAT Radius2, + FLOAT Length, + UINT Slices, + UINT Stacks, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateSphere: +// ----------------- +// Creates a mesh containing a sphere. The sphere is centered at the +// origin. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// Radius Radius of the sphere (should be >= 0.0f) +// Slices Number of slices about the main axis +// Stacks Number of stacks along the main axis +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateSphere( + LPDIRECT3DDEVICE8 pDevice, + FLOAT Radius, + UINT Slices, + UINT Stacks, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateTorus: +// ---------------- +// Creates a mesh containing a torus. The generated torus is centered at +// the origin, and its axis is aligned with the Z-axis. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// InnerRadius Inner radius of the torus (should be >= 0.0f) +// OuterRadius Outer radius of the torue (should be >= 0.0f) +// Sides Number of sides in a cross-section (must be >= 3) +// Rings Number of rings making up the torus (must be >= 3) +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateTorus( + LPDIRECT3DDEVICE8 pDevice, + FLOAT InnerRadius, + FLOAT OuterRadius, + UINT Sides, + UINT Rings, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateTeapot: +// ----------------- +// Creates a mesh containing a teapot. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// ppMesh The mesh object which will be created +// ppAdjacency Returns a buffer containing adjacency info. Can be NULL. +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateTeapot( + LPDIRECT3DDEVICE8 pDevice, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency); + + +//------------------------------------------------------------------------- +// D3DXCreateText: +// --------------- +// Creates a mesh containing the specified text using the font associated +// with the device context. +// +// Parameters: +// +// pDevice The D3D device with which the mesh is going to be used. +// hDC Device context, with desired font selected +// pText Text to generate +// Deviation Maximum chordal deviation from true font outlines +// Extrusion Amount to extrude text in -Z direction +// ppMesh The mesh object which will be created +// pGlyphMetrics Address of buffer to receive glyph metric data (or NULL) +//------------------------------------------------------------------------- +HRESULT WINAPI + D3DXCreateTextA( + LPDIRECT3DDEVICE8 pDevice, + HDC hDC, + LPCSTR pText, + FLOAT Deviation, + FLOAT Extrusion, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency, + LPGLYPHMETRICSFLOAT pGlyphMetrics); + +HRESULT WINAPI + D3DXCreateTextW( + LPDIRECT3DDEVICE8 pDevice, + HDC hDC, + LPCWSTR pText, + FLOAT Deviation, + FLOAT Extrusion, + LPD3DXMESH* ppMesh, + LPD3DXBUFFER* ppAdjacency, + LPGLYPHMETRICSFLOAT pGlyphMetrics); + +#ifdef UNICODE +#define D3DXCreateText D3DXCreateTextW +#else +#define D3DXCreateText D3DXCreateTextA +#endif + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif //__D3DX8SHAPES_H__ diff --git a/plugins/ADK/d3d8/includes/d3dx8tex.h b/plugins/ADK/d3d8/includes/d3dx8tex.h new file mode 100644 index 0000000..dd9fe9d --- /dev/null +++ b/plugins/ADK/d3d8/includes/d3dx8tex.h @@ -0,0 +1,1592 @@ +////////////////////////////////////////////////////////////////////////////// +// +// Copyright (C) Microsoft Corporation. All Rights Reserved. +// +// File: d3dx8tex.h +// Content: D3DX texturing APIs +// +////////////////////////////////////////////////////////////////////////////// + +#include "d3dx8.h" + +#ifndef __D3DX8TEX_H__ +#define __D3DX8TEX_H__ + + +//---------------------------------------------------------------------------- +// D3DX_FILTER flags: +// ------------------ +// +// A valid filter must contain one of these values: +// +// D3DX_FILTER_NONE +// No scaling or filtering will take place. Pixels outside the bounds +// of the source image are assumed to be transparent black. +// D3DX_FILTER_POINT +// Each destination pixel is computed by sampling the nearest pixel +// from the source image. +// D3DX_FILTER_LINEAR +// Each destination pixel is computed by linearly interpolating between +// the nearest pixels in the source image. This filter works best +// when the scale on each axis is less than 2. +// D3DX_FILTER_TRIANGLE +// Every pixel in the source image contributes equally to the +// destination image. This is the slowest of all the filters. +// D3DX_FILTER_BOX +// Each pixel is computed by averaging a 2x2(x2) box pixels from +// the source image. Only works when the dimensions of the +// destination are half those of the source. (as with mip maps) +// +// And can be OR'd with any of these optional flags: +// +// D3DX_FILTER_MIRROR_U +// Indicates that pixels off the edge of the texture on the U-axis +// should be mirrored, not wraped. +// D3DX_FILTER_MIRROR_V +// Indicates that pixels off the edge of the texture on the V-axis +// should be mirrored, not wraped. +// D3DX_FILTER_MIRROR_W +// Indicates that pixels off the edge of the texture on the W-axis +// should be mirrored, not wraped. +// D3DX_FILTER_MIRROR +// Same as specifying D3DX_FILTER_MIRROR_U | D3DX_FILTER_MIRROR_V | +// D3DX_FILTER_MIRROR_V +// D3DX_FILTER_DITHER +// Dithers the resulting image. +// +//---------------------------------------------------------------------------- + +#define D3DX_FILTER_NONE (1 << 0) +#define D3DX_FILTER_POINT (2 << 0) +#define D3DX_FILTER_LINEAR (3 << 0) +#define D3DX_FILTER_TRIANGLE (4 << 0) +#define D3DX_FILTER_BOX (5 << 0) + +#define D3DX_FILTER_MIRROR_U (1 << 16) +#define D3DX_FILTER_MIRROR_V (2 << 16) +#define D3DX_FILTER_MIRROR_W (4 << 16) +#define D3DX_FILTER_MIRROR (7 << 16) +#define D3DX_FILTER_DITHER (8 << 16) + + +//---------------------------------------------------------------------------- +// D3DX_NORMALMAP flags: +// --------------------- +// These flags are used to control how D3DXComputeNormalMap generates normal +// maps. Any number of these flags may be OR'd together in any combination. +// +// D3DX_NORMALMAP_MIRROR_U +// Indicates that pixels off the edge of the texture on the U-axis +// should be mirrored, not wraped. +// D3DX_NORMALMAP_MIRROR_V +// Indicates that pixels off the edge of the texture on the V-axis +// should be mirrored, not wraped. +// D3DX_NORMALMAP_MIRROR +// Same as specifying D3DX_NORMALMAP_MIRROR_U | D3DX_NORMALMAP_MIRROR_V +// D3DX_NORMALMAP_INVERTSIGN +// Inverts the direction of each normal +// D3DX_NORMALMAP_COMPUTE_OCCLUSION +// Compute the per pixel Occlusion term and encodes it into the alpha. +// An Alpha of 1 means that the pixel is not obscured in anyway, and +// an alpha of 0 would mean that the pixel is completly obscured. +// +//---------------------------------------------------------------------------- + +//---------------------------------------------------------------------------- + +#define D3DX_NORMALMAP_MIRROR_U (1 << 16) +#define D3DX_NORMALMAP_MIRROR_V (2 << 16) +#define D3DX_NORMALMAP_MIRROR (3 << 16) +#define D3DX_NORMALMAP_INVERTSIGN (8 << 16) +#define D3DX_NORMALMAP_COMPUTE_OCCLUSION (16 << 16) + + + + +//---------------------------------------------------------------------------- +// D3DX_CHANNEL flags: +// ------------------- +// These flags are used by functions which operate on or more channels +// in a texture. +// +// D3DX_CHANNEL_RED +// Indicates the red channel should be used +// D3DX_CHANNEL_BLUE +// Indicates the blue channel should be used +// D3DX_CHANNEL_GREEN +// Indicates the green channel should be used +// D3DX_CHANNEL_ALPHA +// Indicates the alpha channel should be used +// D3DX_CHANNEL_LUMINANCE +// Indicates the luminaces of the red green and blue channels should be +// used. +// +//---------------------------------------------------------------------------- + +#define D3DX_CHANNEL_RED (1 << 0) +#define D3DX_CHANNEL_BLUE (1 << 1) +#define D3DX_CHANNEL_GREEN (1 << 2) +#define D3DX_CHANNEL_ALPHA (1 << 3) +#define D3DX_CHANNEL_LUMINANCE (1 << 4) + + + + +//---------------------------------------------------------------------------- +// D3DXIMAGE_FILEFORMAT: +// --------------------- +// This enum is used to describe supported image file formats. +// +//---------------------------------------------------------------------------- + +typedef enum _D3DXIMAGE_FILEFORMAT +{ + D3DXIFF_BMP = 0, + D3DXIFF_JPG = 1, + D3DXIFF_TGA = 2, + D3DXIFF_PNG = 3, + D3DXIFF_DDS = 4, + D3DXIFF_PPM = 5, + D3DXIFF_DIB = 6, + D3DXIFF_FORCE_DWORD = 0x7fffffff + +} D3DXIMAGE_FILEFORMAT; + + +//---------------------------------------------------------------------------- +// LPD3DXFILL2D and LPD3DXFILL3D: +// ------------------------------ +// Function types used by the texture fill functions. +// +// Parameters: +// pOut +// Pointer to a vector which the function uses to return its result. +// X,Y,Z,W will be mapped to R,G,B,A respectivly. +// pTexCoord +// Pointer to a vector containing the coordinates of the texel currently +// being evaluated. Textures and VolumeTexture texcoord components +// range from 0 to 1. CubeTexture texcoord component range from -1 to 1. +// pTexelSize +// Pointer to a vector containing the dimensions of the current texel. +// pData +// Pointer to user data. +// +//---------------------------------------------------------------------------- + +typedef VOID (*LPD3DXFILL2D)(D3DXVECTOR4 *pOut, D3DXVECTOR2 *pTexCoord, D3DXVECTOR2 *pTexelSize, LPVOID pData); +typedef VOID (*LPD3DXFILL3D)(D3DXVECTOR4 *pOut, D3DXVECTOR3 *pTexCoord, D3DXVECTOR3 *pTexelSize, LPVOID pData); + + + +//---------------------------------------------------------------------------- +// D3DXIMAGE_INFO: +// --------------- +// This structure is used to return a rough description of what the +// the original contents of an image file looked like. +// +// Width +// Width of original image in pixels +// Height +// Height of original image in pixels +// Depth +// Depth of original image in pixels +// MipLevels +// Number of mip levels in original image +// Format +// D3D format which most closely describes the data in original image +// ResourceType +// D3DRESOURCETYPE representing the type of texture stored in the file. +// D3DRTYPE_TEXTURE, D3DRTYPE_VOLUMETEXTURE, or D3DRTYPE_CUBETEXTURE. +// ImageFileFormat +// D3DXIMAGE_FILEFORMAT representing the format of the image file. +// +//---------------------------------------------------------------------------- + +typedef struct _D3DXIMAGE_INFO +{ + UINT Width; + UINT Height; + UINT Depth; + UINT MipLevels; + D3DFORMAT Format; + D3DRESOURCETYPE ResourceType; + D3DXIMAGE_FILEFORMAT ImageFileFormat; + +} D3DXIMAGE_INFO; + + + + + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + + + +////////////////////////////////////////////////////////////////////////////// +// Image File APIs /////////////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// +; +//---------------------------------------------------------------------------- +// GetImageInfoFromFile/Resource: +// ------------------------------ +// Fills in a D3DXIMAGE_INFO struct with information about an image file. +// +// Parameters: +// pSrcFile +// File name of the source image. +// pSrcModule +// Module where resource is located, or NULL for module associated +// with image the os used to create the current process. +// pSrcResource +// Resource name +// pSrcData +// Pointer to file in memory. +// SrcDataSize +// Size in bytes of file in memory. +// pSrcInfo +// Pointer to a D3DXIMAGE_INFO structure to be filled in with the +// description of the data in the source image file. +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXGetImageInfoFromFileA( + LPCSTR pSrcFile, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXGetImageInfoFromFileW( + LPCWSTR pSrcFile, + D3DXIMAGE_INFO* pSrcInfo); + +#ifdef UNICODE +#define D3DXGetImageInfoFromFile D3DXGetImageInfoFromFileW +#else +#define D3DXGetImageInfoFromFile D3DXGetImageInfoFromFileA +#endif + + +HRESULT WINAPI + D3DXGetImageInfoFromResourceA( + HMODULE hSrcModule, + LPCSTR pSrcResource, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXGetImageInfoFromResourceW( + HMODULE hSrcModule, + LPCWSTR pSrcResource, + D3DXIMAGE_INFO* pSrcInfo); + +#ifdef UNICODE +#define D3DXGetImageInfoFromResource D3DXGetImageInfoFromResourceW +#else +#define D3DXGetImageInfoFromResource D3DXGetImageInfoFromResourceA +#endif + + +HRESULT WINAPI + D3DXGetImageInfoFromFileInMemory( + LPCVOID pSrcData, + UINT SrcDataSize, + D3DXIMAGE_INFO* pSrcInfo); + + + + +////////////////////////////////////////////////////////////////////////////// +// Load/Save Surface APIs //////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + +//---------------------------------------------------------------------------- +// D3DXLoadSurfaceFromFile/Resource: +// --------------------------------- +// Load surface from a file or resource +// +// Parameters: +// pDestSurface +// Destination surface, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestRect +// Destination rectangle, or NULL for entire surface +// pSrcFile +// File name of the source image. +// pSrcModule +// Module where resource is located, or NULL for module associated +// with image the os used to create the current process. +// pSrcResource +// Resource name +// pSrcData +// Pointer to file in memory. +// SrcDataSize +// Size in bytes of file in memory. +// pSrcRect +// Source rectangle, or NULL for entire image +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// pSrcInfo +// Pointer to a D3DXIMAGE_INFO structure to be filled in with the +// description of the data in the source image file, or NULL. +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadSurfaceFromFileA( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + LPCSTR pSrcFile, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXLoadSurfaceFromFileW( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + LPCWSTR pSrcFile, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +#ifdef UNICODE +#define D3DXLoadSurfaceFromFile D3DXLoadSurfaceFromFileW +#else +#define D3DXLoadSurfaceFromFile D3DXLoadSurfaceFromFileA +#endif + + + +HRESULT WINAPI + D3DXLoadSurfaceFromResourceA( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + HMODULE hSrcModule, + LPCSTR pSrcResource, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXLoadSurfaceFromResourceW( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + + +#ifdef UNICODE +#define D3DXLoadSurfaceFromResource D3DXLoadSurfaceFromResourceW +#else +#define D3DXLoadSurfaceFromResource D3DXLoadSurfaceFromResourceA +#endif + + + +HRESULT WINAPI + D3DXLoadSurfaceFromFileInMemory( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + LPCVOID pSrcData, + UINT SrcDataSize, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + + + +//---------------------------------------------------------------------------- +// D3DXLoadSurfaceFromSurface: +// --------------------------- +// Load surface from another surface (with color conversion) +// +// Parameters: +// pDestSurface +// Destination surface, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestRect +// Destination rectangle, or NULL for entire surface +// pSrcSurface +// Source surface +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcRect +// Source rectangle, or NULL for entire surface +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadSurfaceFromSurface( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + LPDIRECT3DSURFACE8 pSrcSurface, + CONST PALETTEENTRY* pSrcPalette, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey); + + +//---------------------------------------------------------------------------- +// D3DXLoadSurfaceFromMemory: +// -------------------------- +// Load surface from memory. +// +// Parameters: +// pDestSurface +// Destination surface, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestRect +// Destination rectangle, or NULL for entire surface +// pSrcMemory +// Pointer to the top-left corner of the source image in memory +// SrcFormat +// Pixel format of the source image. +// SrcPitch +// Pitch of source image, in bytes. For DXT formats, this number +// should represent the width of one row of cells, in bytes. +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcRect +// Source rectangle. +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadSurfaceFromMemory( + LPDIRECT3DSURFACE8 pDestSurface, + CONST PALETTEENTRY* pDestPalette, + CONST RECT* pDestRect, + LPCVOID pSrcMemory, + D3DFORMAT SrcFormat, + UINT SrcPitch, + CONST PALETTEENTRY* pSrcPalette, + CONST RECT* pSrcRect, + DWORD Filter, + D3DCOLOR ColorKey); + + +//---------------------------------------------------------------------------- +// D3DXSaveSurfaceToFile: +// ---------------------- +// Save a surface to a image file. +// +// Parameters: +// pDestFile +// File name of the destination file +// DestFormat +// D3DXIMAGE_FILEFORMAT specifying file format to use when saving. +// pSrcSurface +// Source surface, containing the image to be saved +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcRect +// Source rectangle, or NULL for the entire image +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXSaveSurfaceToFileA( + LPCSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DSURFACE8 pSrcSurface, + CONST PALETTEENTRY* pSrcPalette, + CONST RECT* pSrcRect); + +HRESULT WINAPI + D3DXSaveSurfaceToFileW( + LPCWSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DSURFACE8 pSrcSurface, + CONST PALETTEENTRY* pSrcPalette, + CONST RECT* pSrcRect); + +#ifdef UNICODE +#define D3DXSaveSurfaceToFile D3DXSaveSurfaceToFileW +#else +#define D3DXSaveSurfaceToFile D3DXSaveSurfaceToFileA +#endif + + + + +////////////////////////////////////////////////////////////////////////////// +// Load/Save Volume APIs ///////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + +//---------------------------------------------------------------------------- +// D3DXLoadVolumeFromFile/Resource: +// -------------------------------- +// Load volume from a file or resource +// +// Parameters: +// pDestVolume +// Destination volume, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestBox +// Destination box, or NULL for entire volume +// pSrcFile +// File name of the source image. +// pSrcModule +// Module where resource is located, or NULL for module associated +// with image the os used to create the current process. +// pSrcResource +// Resource name +// pSrcData +// Pointer to file in memory. +// SrcDataSize +// Size in bytes of file in memory. +// pSrcBox +// Source box, or NULL for entire image +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// pSrcInfo +// Pointer to a D3DXIMAGE_INFO structure to be filled in with the +// description of the data in the source image file, or NULL. +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadVolumeFromFileA( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + LPCSTR pSrcFile, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXLoadVolumeFromFileW( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + LPCWSTR pSrcFile, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +#ifdef UNICODE +#define D3DXLoadVolumeFromFile D3DXLoadVolumeFromFileW +#else +#define D3DXLoadVolumeFromFile D3DXLoadVolumeFromFileA +#endif + + +HRESULT WINAPI + D3DXLoadVolumeFromResourceA( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + HMODULE hSrcModule, + LPCSTR pSrcResource, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +HRESULT WINAPI + D3DXLoadVolumeFromResourceW( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + +#ifdef UNICODE +#define D3DXLoadVolumeFromResource D3DXLoadVolumeFromResourceW +#else +#define D3DXLoadVolumeFromResource D3DXLoadVolumeFromResourceA +#endif + + + +HRESULT WINAPI + D3DXLoadVolumeFromFileInMemory( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + LPCVOID pSrcData, + UINT SrcDataSize, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo); + + + +//---------------------------------------------------------------------------- +// D3DXLoadVolumeFromVolume: +// ------------------------- +// Load volume from another volume (with color conversion) +// +// Parameters: +// pDestVolume +// Destination volume, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestBox +// Destination box, or NULL for entire volume +// pSrcVolume +// Source volume +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcBox +// Source box, or NULL for entire volume +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadVolumeFromVolume( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + LPDIRECT3DVOLUME8 pSrcVolume, + CONST PALETTEENTRY* pSrcPalette, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey); + + + +//---------------------------------------------------------------------------- +// D3DXLoadVolumeFromMemory: +// ------------------------- +// Load volume from memory. +// +// Parameters: +// pDestVolume +// Destination volume, which will receive the image. +// pDestPalette +// Destination palette of 256 colors, or NULL +// pDestBox +// Destination box, or NULL for entire volume +// pSrcMemory +// Pointer to the top-left corner of the source volume in memory +// SrcFormat +// Pixel format of the source volume. +// SrcRowPitch +// Pitch of source image, in bytes. For DXT formats, this number +// should represent the size of one row of cells, in bytes. +// SrcSlicePitch +// Pitch of source image, in bytes. For DXT formats, this number +// should represent the size of one slice of cells, in bytes. +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcBox +// Source box. +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXLoadVolumeFromMemory( + LPDIRECT3DVOLUME8 pDestVolume, + CONST PALETTEENTRY* pDestPalette, + CONST D3DBOX* pDestBox, + LPCVOID pSrcMemory, + D3DFORMAT SrcFormat, + UINT SrcRowPitch, + UINT SrcSlicePitch, + CONST PALETTEENTRY* pSrcPalette, + CONST D3DBOX* pSrcBox, + DWORD Filter, + D3DCOLOR ColorKey); + + + +//---------------------------------------------------------------------------- +// D3DXSaveVolumeToFile: +// --------------------- +// Save a volume to a image file. +// +// Parameters: +// pDestFile +// File name of the destination file +// DestFormat +// D3DXIMAGE_FILEFORMAT specifying file format to use when saving. +// pSrcVolume +// Source volume, containing the image to be saved +// pSrcPalette +// Source palette of 256 colors, or NULL +// pSrcBox +// Source box, or NULL for the entire volume +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXSaveVolumeToFileA( + LPCSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DVOLUME8 pSrcVolume, + CONST PALETTEENTRY* pSrcPalette, + CONST D3DBOX* pSrcBox); + +HRESULT WINAPI + D3DXSaveVolumeToFileW( + LPCWSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DVOLUME8 pSrcVolume, + CONST PALETTEENTRY* pSrcPalette, + CONST D3DBOX* pSrcBox); + +#ifdef UNICODE +#define D3DXSaveVolumeToFile D3DXSaveVolumeToFileW +#else +#define D3DXSaveVolumeToFile D3DXSaveVolumeToFileA +#endif + + + + +////////////////////////////////////////////////////////////////////////////// +// Create/Save Texture APIs ////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + +//---------------------------------------------------------------------------- +// D3DXCheckTextureRequirements: +// ----------------------------- +// Checks texture creation parameters. If parameters are invalid, this +// function returns corrected parameters. +// +// Parameters: +// +// pDevice +// The D3D device to be used +// pWidth, pHeight, pDepth, pSize +// Desired size in pixels, or NULL. Returns corrected size. +// pNumMipLevels +// Number of desired mipmap levels, or NULL. Returns corrected number. +// Usage +// Texture usage flags +// pFormat +// Desired pixel format, or NULL. Returns corrected format. +// Pool +// Memory pool to be used to create texture +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXCheckTextureRequirements( + LPDIRECT3DDEVICE8 pDevice, + UINT* pWidth, + UINT* pHeight, + UINT* pNumMipLevels, + DWORD Usage, + D3DFORMAT* pFormat, + D3DPOOL Pool); + +HRESULT WINAPI + D3DXCheckCubeTextureRequirements( + LPDIRECT3DDEVICE8 pDevice, + UINT* pSize, + UINT* pNumMipLevels, + DWORD Usage, + D3DFORMAT* pFormat, + D3DPOOL Pool); + +HRESULT WINAPI + D3DXCheckVolumeTextureRequirements( + LPDIRECT3DDEVICE8 pDevice, + UINT* pWidth, + UINT* pHeight, + UINT* pDepth, + UINT* pNumMipLevels, + DWORD Usage, + D3DFORMAT* pFormat, + D3DPOOL Pool); + + +//---------------------------------------------------------------------------- +// D3DXCreateTexture: +// ------------------ +// Create an empty texture +// +// Parameters: +// +// pDevice +// The D3D device with which the texture is going to be used. +// Width, Height, Depth, Size +// size in pixels; these must be non-zero +// MipLevels +// number of mip levels desired; if zero or D3DX_DEFAULT, a complete +// mipmap chain will be created. +// Usage +// Texture usage flags +// Format +// Pixel format. +// Pool +// Memory pool to be used to create texture +// ppTexture, ppCubeTexture, ppVolumeTexture +// The texture object that will be created +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXCreateTexture( + LPDIRECT3DDEVICE8 pDevice, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateCubeTexture( + LPDIRECT3DDEVICE8 pDevice, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTexture( + LPDIRECT3DDEVICE8 pDevice, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + + + +//---------------------------------------------------------------------------- +// D3DXCreateTextureFromFile/Resource: +// ----------------------------------- +// Create a texture object from a file or resource. +// +// Parameters: +// +// pDevice +// The D3D device with which the texture is going to be used. +// pSrcFile +// File name. +// hSrcModule +// Module handle. if NULL, current module will be used. +// pSrcResource +// Resource name in module +// pvSrcData +// Pointer to file in memory. +// SrcDataSize +// Size in bytes of file in memory. +// Width, Height, Depth, Size +// Size in pixels; if zero or D3DX_DEFAULT, the size will be taken +// from the file. +// MipLevels +// Number of mip levels; if zero or D3DX_DEFAULT, a complete mipmap +// chain will be created. +// Usage +// Texture usage flags +// Format +// Desired pixel format. If D3DFMT_UNKNOWN, the format will be +// taken from the file. +// Pool +// Memory pool to be used to create texture +// Filter +// D3DX_FILTER flags controlling how the image is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_TRIANGLE. +// MipFilter +// D3DX_FILTER flags controlling how each miplevel is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_BOX, +// ColorKey +// Color to replace with transparent black, or 0 to disable colorkey. +// This is always a 32-bit ARGB color, independent of the source image +// format. Alpha is significant, and should usually be set to FF for +// opaque colorkeys. (ex. Opaque black == 0xff000000) +// pSrcInfo +// Pointer to a D3DXIMAGE_INFO structure to be filled in with the +// description of the data in the source image file, or NULL. +// pPalette +// 256 color palette to be filled in, or NULL +// ppTexture, ppCubeTexture, ppVolumeTexture +// The texture object that will be created +// +//---------------------------------------------------------------------------- + + +// FromFile + +HRESULT WINAPI + D3DXCreateTextureFromFileA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateTextureFromFileW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + LPDIRECT3DTEXTURE8* ppTexture); + +#ifdef UNICODE +#define D3DXCreateTextureFromFile D3DXCreateTextureFromFileW +#else +#define D3DXCreateTextureFromFile D3DXCreateTextureFromFileA +#endif + + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +#ifdef UNICODE +#define D3DXCreateCubeTextureFromFile D3DXCreateCubeTextureFromFileW +#else +#define D3DXCreateCubeTextureFromFile D3DXCreateCubeTextureFromFileA +#endif + + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +#ifdef UNICODE +#define D3DXCreateVolumeTextureFromFile D3DXCreateVolumeTextureFromFileW +#else +#define D3DXCreateVolumeTextureFromFile D3DXCreateVolumeTextureFromFileA +#endif + + +// FromResource + +HRESULT WINAPI + D3DXCreateTextureFromResourceA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateTextureFromResourceW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + LPDIRECT3DTEXTURE8* ppTexture); + +#ifdef UNICODE +#define D3DXCreateTextureFromResource D3DXCreateTextureFromResourceW +#else +#define D3DXCreateTextureFromResource D3DXCreateTextureFromResourceA +#endif + + +HRESULT WINAPI + D3DXCreateCubeTextureFromResourceA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromResourceW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +#ifdef UNICODE +#define D3DXCreateCubeTextureFromResource D3DXCreateCubeTextureFromResourceW +#else +#define D3DXCreateCubeTextureFromResource D3DXCreateCubeTextureFromResourceA +#endif + + +HRESULT WINAPI + D3DXCreateVolumeTextureFromResourceA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromResourceW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +#ifdef UNICODE +#define D3DXCreateVolumeTextureFromResource D3DXCreateVolumeTextureFromResourceW +#else +#define D3DXCreateVolumeTextureFromResource D3DXCreateVolumeTextureFromResourceA +#endif + + +// FromFileEx + +HRESULT WINAPI + D3DXCreateTextureFromFileExA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateTextureFromFileExW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DTEXTURE8* ppTexture); + +#ifdef UNICODE +#define D3DXCreateTextureFromFileEx D3DXCreateTextureFromFileExW +#else +#define D3DXCreateTextureFromFileEx D3DXCreateTextureFromFileExA +#endif + + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileExA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileExW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +#ifdef UNICODE +#define D3DXCreateCubeTextureFromFileEx D3DXCreateCubeTextureFromFileExW +#else +#define D3DXCreateCubeTextureFromFileEx D3DXCreateCubeTextureFromFileExA +#endif + + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileExA( + LPDIRECT3DDEVICE8 pDevice, + LPCSTR pSrcFile, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileExW( + LPDIRECT3DDEVICE8 pDevice, + LPCWSTR pSrcFile, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +#ifdef UNICODE +#define D3DXCreateVolumeTextureFromFileEx D3DXCreateVolumeTextureFromFileExW +#else +#define D3DXCreateVolumeTextureFromFileEx D3DXCreateVolumeTextureFromFileExA +#endif + + +// FromResourceEx + +HRESULT WINAPI + D3DXCreateTextureFromResourceExA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateTextureFromResourceExW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DTEXTURE8* ppTexture); + +#ifdef UNICODE +#define D3DXCreateTextureFromResourceEx D3DXCreateTextureFromResourceExW +#else +#define D3DXCreateTextureFromResourceEx D3DXCreateTextureFromResourceExA +#endif + + +HRESULT WINAPI + D3DXCreateCubeTextureFromResourceExA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromResourceExW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +#ifdef UNICODE +#define D3DXCreateCubeTextureFromResourceEx D3DXCreateCubeTextureFromResourceExW +#else +#define D3DXCreateCubeTextureFromResourceEx D3DXCreateCubeTextureFromResourceExA +#endif + + +HRESULT WINAPI + D3DXCreateVolumeTextureFromResourceExA( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCSTR pSrcResource, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromResourceExW( + LPDIRECT3DDEVICE8 pDevice, + HMODULE hSrcModule, + LPCWSTR pSrcResource, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + +#ifdef UNICODE +#define D3DXCreateVolumeTextureFromResourceEx D3DXCreateVolumeTextureFromResourceExW +#else +#define D3DXCreateVolumeTextureFromResourceEx D3DXCreateVolumeTextureFromResourceExA +#endif + + +// FromFileInMemory + +HRESULT WINAPI + D3DXCreateTextureFromFileInMemory( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileInMemory( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileInMemory( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + + +// FromFileInMemoryEx + +HRESULT WINAPI + D3DXCreateTextureFromFileInMemoryEx( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + UINT Width, + UINT Height, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DTEXTURE8* ppTexture); + +HRESULT WINAPI + D3DXCreateCubeTextureFromFileInMemoryEx( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + UINT Size, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DCUBETEXTURE8* ppCubeTexture); + +HRESULT WINAPI + D3DXCreateVolumeTextureFromFileInMemoryEx( + LPDIRECT3DDEVICE8 pDevice, + LPCVOID pSrcData, + UINT SrcDataSize, + UINT Width, + UINT Height, + UINT Depth, + UINT MipLevels, + DWORD Usage, + D3DFORMAT Format, + D3DPOOL Pool, + DWORD Filter, + DWORD MipFilter, + D3DCOLOR ColorKey, + D3DXIMAGE_INFO* pSrcInfo, + PALETTEENTRY* pPalette, + LPDIRECT3DVOLUMETEXTURE8* ppVolumeTexture); + + + +//---------------------------------------------------------------------------- +// D3DXSaveTextureToFile: +// ---------------------- +// Save a texture to a file. +// +// Parameters: +// pDestFile +// File name of the destination file +// DestFormat +// D3DXIMAGE_FILEFORMAT specifying file format to use when saving. +// pSrcTexture +// Source texture, containing the image to be saved +// pSrcPalette +// Source palette of 256 colors, or NULL +// +//---------------------------------------------------------------------------- + + +HRESULT WINAPI + D3DXSaveTextureToFileA( + LPCSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DBASETEXTURE8 pSrcTexture, + CONST PALETTEENTRY* pSrcPalette); + +HRESULT WINAPI + D3DXSaveTextureToFileW( + LPCWSTR pDestFile, + D3DXIMAGE_FILEFORMAT DestFormat, + LPDIRECT3DBASETEXTURE8 pSrcTexture, + CONST PALETTEENTRY* pSrcPalette); + +#ifdef UNICODE +#define D3DXSaveTextureToFile D3DXSaveTextureToFileW +#else +#define D3DXSaveTextureToFile D3DXSaveTextureToFileA +#endif + + + + +////////////////////////////////////////////////////////////////////////////// +// Misc Texture APIs ///////////////////////////////////////////////////////// +////////////////////////////////////////////////////////////////////////////// + +//---------------------------------------------------------------------------- +// D3DXFilterTexture: +// ------------------ +// Filters mipmaps levels of a texture. +// +// Parameters: +// pBaseTexture +// The texture object to be filtered +// pPalette +// 256 color palette to be used, or NULL for non-palettized formats +// SrcLevel +// The level whose image is used to generate the subsequent levels. +// Filter +// D3DX_FILTER flags controlling how each miplevel is filtered. +// Or D3DX_DEFAULT for D3DX_FILTER_BOX, +// +//---------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXFilterTexture( + LPDIRECT3DBASETEXTURE8 pBaseTexture, + CONST PALETTEENTRY* pPalette, + UINT SrcLevel, + DWORD Filter); + +#define D3DXFilterCubeTexture D3DXFilterTexture +#define D3DXFilterVolumeTexture D3DXFilterTexture + + + +//---------------------------------------------------------------------------- +// D3DXFillTexture: +// ---------------- +// Uses a user provided function to fill each texel of each mip level of a +// given texture. +// +// Paramters: +// pTexture, pCubeTexture, pVolumeTexture +// Pointer to the texture to be filled. +// pFunction +// Pointer to user provided evalutor function which will be used to +// compute the value of each texel. +// pData +// Pointer to an arbitrary block of user defined data. This pointer +// will be passed to the function provided in pFunction +//----------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXFillTexture( + LPDIRECT3DTEXTURE8 pTexture, + LPD3DXFILL2D pFunction, + LPVOID pData); + +HRESULT WINAPI + D3DXFillCubeTexture( + LPDIRECT3DCUBETEXTURE8 pCubeTexture, + LPD3DXFILL3D pFunction, + LPVOID pData); + +HRESULT WINAPI + D3DXFillVolumeTexture( + LPDIRECT3DVOLUMETEXTURE8 pVolumeTexture, + LPD3DXFILL3D pFunction, + LPVOID pData); + + + +//---------------------------------------------------------------------------- +// D3DXComputeNormalMap: +// --------------------- +// Converts a height map into a normal map. The (x,y,z) components of each +// normal are mapped to the (r,g,b) channels of the output texture. +// +// Parameters +// pTexture +// Pointer to the destination texture +// pSrcTexture +// Pointer to the source heightmap texture +// pSrcPalette +// Source palette of 256 colors, or NULL +// Flags +// D3DX_NORMALMAP flags +// Channel +// D3DX_CHANNEL specifying source of height information +// Amplitude +// The constant value which the height information is multiplied by. +//--------------------------------------------------------------------------- + +HRESULT WINAPI + D3DXComputeNormalMap( + LPDIRECT3DTEXTURE8 pTexture, + LPDIRECT3DTEXTURE8 pSrcTexture, + CONST PALETTEENTRY* pSrcPalette, + DWORD Flags, + DWORD Channel, + FLOAT Amplitude); + + + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif //__D3DX8TEX_H__ diff --git a/plugins/ADK/d3d8/includes/dinput.h b/plugins/ADK/d3d8/includes/dinput.h new file mode 100644 index 0000000..5aac256 --- /dev/null +++ b/plugins/ADK/d3d8/includes/dinput.h @@ -0,0 +1,4417 @@ +/**************************************************************************** + * + * Copyright (C) 1996-2000 Microsoft Corporation. All Rights Reserved. + * + * File: dinput.h + * Content: DirectInput include file + * + ****************************************************************************/ + +#ifndef __DINPUT_INCLUDED__ +#define __DINPUT_INCLUDED__ + +#ifndef DIJ_RINGZERO + +#ifdef _WIN32 +#define COM_NO_WINDOWS_H +#include +#endif + +#endif /* DIJ_RINGZERO */ + +#ifdef __cplusplus +extern "C" { +#endif + + + + + +/* + * To build applications for older versions of DirectInput + * + * #define DIRECTINPUT_VERSION [ 0x0300 | 0x0500 | 0x0700 ] + * + * before #include . By default, #include + * will produce a DirectX 8-compatible header file. + * + */ + +#define DIRECTINPUT_HEADER_VERSION 0x0800 +#ifndef DIRECTINPUT_VERSION +#define DIRECTINPUT_VERSION DIRECTINPUT_HEADER_VERSION +#pragma message(__FILE__ ": DIRECTINPUT_VERSION undefined. Defaulting to version 0x0800") +#endif + +#ifndef DIJ_RINGZERO + +/**************************************************************************** + * + * Class IDs + * + ****************************************************************************/ + +DEFINE_GUID(CLSID_DirectInput, 0x25E609E0,0xB259,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(CLSID_DirectInputDevice, 0x25E609E1,0xB259,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +DEFINE_GUID(CLSID_DirectInput8, 0x25E609E4,0xB259,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(CLSID_DirectInputDevice8,0x25E609E5,0xB259,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +/**************************************************************************** + * + * Interfaces + * + ****************************************************************************/ + +DEFINE_GUID(IID_IDirectInputA, 0x89521360,0xAA8A,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInputW, 0x89521361,0xAA8A,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInput2A, 0x5944E662,0xAA8A,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInput2W, 0x5944E663,0xAA8A,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInput7A, 0x9A4CB684,0x236D,0x11D3,0x8E,0x9D,0x00,0xC0,0x4F,0x68,0x44,0xAE); +DEFINE_GUID(IID_IDirectInput7W, 0x9A4CB685,0x236D,0x11D3,0x8E,0x9D,0x00,0xC0,0x4F,0x68,0x44,0xAE); +DEFINE_GUID(IID_IDirectInput8A, 0xBF798030,0x483A,0x4DA2,0xAA,0x99,0x5D,0x64,0xED,0x36,0x97,0x00); +DEFINE_GUID(IID_IDirectInput8W, 0xBF798031,0x483A,0x4DA2,0xAA,0x99,0x5D,0x64,0xED,0x36,0x97,0x00); +DEFINE_GUID(IID_IDirectInputDeviceA, 0x5944E680,0xC92E,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInputDeviceW, 0x5944E681,0xC92E,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInputDevice2A,0x5944E682,0xC92E,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInputDevice2W,0x5944E683,0xC92E,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(IID_IDirectInputDevice7A,0x57D7C6BC,0x2356,0x11D3,0x8E,0x9D,0x00,0xC0,0x4F,0x68,0x44,0xAE); +DEFINE_GUID(IID_IDirectInputDevice7W,0x57D7C6BD,0x2356,0x11D3,0x8E,0x9D,0x00,0xC0,0x4F,0x68,0x44,0xAE); +DEFINE_GUID(IID_IDirectInputDevice8A,0x54D41080,0xDC15,0x4833,0xA4,0x1B,0x74,0x8F,0x73,0xA3,0x81,0x79); +DEFINE_GUID(IID_IDirectInputDevice8W,0x54D41081,0xDC15,0x4833,0xA4,0x1B,0x74,0x8F,0x73,0xA3,0x81,0x79); +DEFINE_GUID(IID_IDirectInputEffect, 0xE7E1F7C0,0x88D2,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); + +/**************************************************************************** + * + * Predefined object types + * + ****************************************************************************/ + +DEFINE_GUID(GUID_XAxis, 0xA36D02E0,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_YAxis, 0xA36D02E1,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_ZAxis, 0xA36D02E2,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_RxAxis, 0xA36D02F4,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_RyAxis, 0xA36D02F5,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_RzAxis, 0xA36D02E3,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_Slider, 0xA36D02E4,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +DEFINE_GUID(GUID_Button, 0xA36D02F0,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_Key, 0x55728220,0xD33C,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +DEFINE_GUID(GUID_POV, 0xA36D02F2,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +DEFINE_GUID(GUID_Unknown, 0xA36D02F3,0xC9F3,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +/**************************************************************************** + * + * Predefined product GUIDs + * + ****************************************************************************/ + +DEFINE_GUID(GUID_SysMouse, 0x6F1D2B60,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_SysKeyboard,0x6F1D2B61,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_Joystick ,0x6F1D2B70,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_SysMouseEm, 0x6F1D2B80,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_SysMouseEm2,0x6F1D2B81,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_SysKeyboardEm, 0x6F1D2B82,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); +DEFINE_GUID(GUID_SysKeyboardEm2,0x6F1D2B83,0xD5A0,0x11CF,0xBF,0xC7,0x44,0x45,0x53,0x54,0x00,0x00); + +/**************************************************************************** + * + * Predefined force feedback effects + * + ****************************************************************************/ + +DEFINE_GUID(GUID_ConstantForce, 0x13541C20,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_RampForce, 0x13541C21,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Square, 0x13541C22,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Sine, 0x13541C23,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Triangle, 0x13541C24,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_SawtoothUp, 0x13541C25,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_SawtoothDown, 0x13541C26,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Spring, 0x13541C27,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Damper, 0x13541C28,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Inertia, 0x13541C29,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_Friction, 0x13541C2A,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); +DEFINE_GUID(GUID_CustomForce, 0x13541C2B,0x8E33,0x11D0,0x9A,0xD0,0x00,0xA0,0xC9,0xA0,0x6E,0x35); + +#endif /* DIJ_RINGZERO */ + +/**************************************************************************** + * + * Interfaces and Structures... + * + ****************************************************************************/ + +#if(DIRECTINPUT_VERSION >= 0x0500) + +/**************************************************************************** + * + * IDirectInputEffect + * + ****************************************************************************/ + +#define DIEFT_ALL 0x00000000 + +#define DIEFT_CONSTANTFORCE 0x00000001 +#define DIEFT_RAMPFORCE 0x00000002 +#define DIEFT_PERIODIC 0x00000003 +#define DIEFT_CONDITION 0x00000004 +#define DIEFT_CUSTOMFORCE 0x00000005 +#define DIEFT_HARDWARE 0x000000FF +#define DIEFT_FFATTACK 0x00000200 +#define DIEFT_FFFADE 0x00000400 +#define DIEFT_SATURATION 0x00000800 +#define DIEFT_POSNEGCOEFFICIENTS 0x00001000 +#define DIEFT_POSNEGSATURATION 0x00002000 +#define DIEFT_DEADBAND 0x00004000 +#define DIEFT_STARTDELAY 0x00008000 +#define DIEFT_GETTYPE(n) LOBYTE(n) + +#define DI_DEGREES 100 +#define DI_FFNOMINALMAX 10000 +#define DI_SECONDS 1000000 + +typedef struct DICONSTANTFORCE { + LONG lMagnitude; +} DICONSTANTFORCE, *LPDICONSTANTFORCE; +typedef const DICONSTANTFORCE *LPCDICONSTANTFORCE; + +typedef struct DIRAMPFORCE { + LONG lStart; + LONG lEnd; +} DIRAMPFORCE, *LPDIRAMPFORCE; +typedef const DIRAMPFORCE *LPCDIRAMPFORCE; + +typedef struct DIPERIODIC { + DWORD dwMagnitude; + LONG lOffset; + DWORD dwPhase; + DWORD dwPeriod; +} DIPERIODIC, *LPDIPERIODIC; +typedef const DIPERIODIC *LPCDIPERIODIC; + +typedef struct DICONDITION { + LONG lOffset; + LONG lPositiveCoefficient; + LONG lNegativeCoefficient; + DWORD dwPositiveSaturation; + DWORD dwNegativeSaturation; + LONG lDeadBand; +} DICONDITION, *LPDICONDITION; +typedef const DICONDITION *LPCDICONDITION; + +typedef struct DICUSTOMFORCE { + DWORD cChannels; + DWORD dwSamplePeriod; + DWORD cSamples; + LPLONG rglForceData; +} DICUSTOMFORCE, *LPDICUSTOMFORCE; +typedef const DICUSTOMFORCE *LPCDICUSTOMFORCE; + + +typedef struct DIENVELOPE { + DWORD dwSize; /* sizeof(DIENVELOPE) */ + DWORD dwAttackLevel; + DWORD dwAttackTime; /* Microseconds */ + DWORD dwFadeLevel; + DWORD dwFadeTime; /* Microseconds */ +} DIENVELOPE, *LPDIENVELOPE; +typedef const DIENVELOPE *LPCDIENVELOPE; + + +/* This structure is defined for DirectX 5.0 compatibility */ +typedef struct DIEFFECT_DX5 { + DWORD dwSize; /* sizeof(DIEFFECT_DX5) */ + DWORD dwFlags; /* DIEFF_* */ + DWORD dwDuration; /* Microseconds */ + DWORD dwSamplePeriod; /* Microseconds */ + DWORD dwGain; + DWORD dwTriggerButton; /* or DIEB_NOTRIGGER */ + DWORD dwTriggerRepeatInterval; /* Microseconds */ + DWORD cAxes; /* Number of axes */ + LPDWORD rgdwAxes; /* Array of axes */ + LPLONG rglDirection; /* Array of directions */ + LPDIENVELOPE lpEnvelope; /* Optional */ + DWORD cbTypeSpecificParams; /* Size of params */ + LPVOID lpvTypeSpecificParams; /* Pointer to params */ +} DIEFFECT_DX5, *LPDIEFFECT_DX5; +typedef const DIEFFECT_DX5 *LPCDIEFFECT_DX5; + +typedef struct DIEFFECT { + DWORD dwSize; /* sizeof(DIEFFECT) */ + DWORD dwFlags; /* DIEFF_* */ + DWORD dwDuration; /* Microseconds */ + DWORD dwSamplePeriod; /* Microseconds */ + DWORD dwGain; + DWORD dwTriggerButton; /* or DIEB_NOTRIGGER */ + DWORD dwTriggerRepeatInterval; /* Microseconds */ + DWORD cAxes; /* Number of axes */ + LPDWORD rgdwAxes; /* Array of axes */ + LPLONG rglDirection; /* Array of directions */ + LPDIENVELOPE lpEnvelope; /* Optional */ + DWORD cbTypeSpecificParams; /* Size of params */ + LPVOID lpvTypeSpecificParams; /* Pointer to params */ +#if(DIRECTINPUT_VERSION >= 0x0600) + DWORD dwStartDelay; /* Microseconds */ +#endif /* DIRECTINPUT_VERSION >= 0x0600 */ +} DIEFFECT, *LPDIEFFECT; +typedef DIEFFECT DIEFFECT_DX6; +typedef LPDIEFFECT LPDIEFFECT_DX6; +typedef const DIEFFECT *LPCDIEFFECT; + + +#if(DIRECTINPUT_VERSION >= 0x0700) +#ifndef DIJ_RINGZERO +typedef struct DIFILEEFFECT{ + DWORD dwSize; + GUID GuidEffect; + LPCDIEFFECT lpDiEffect; + CHAR szFriendlyName[MAX_PATH]; +}DIFILEEFFECT, *LPDIFILEEFFECT; +typedef const DIFILEEFFECT *LPCDIFILEEFFECT; +typedef BOOL (FAR PASCAL * LPDIENUMEFFECTSINFILECALLBACK)(LPCDIFILEEFFECT , LPVOID); +#endif /* DIJ_RINGZERO */ +#endif /* DIRECTINPUT_VERSION >= 0x0700 */ + +#define DIEFF_OBJECTIDS 0x00000001 +#define DIEFF_OBJECTOFFSETS 0x00000002 +#define DIEFF_CARTESIAN 0x00000010 +#define DIEFF_POLAR 0x00000020 +#define DIEFF_SPHERICAL 0x00000040 + +#define DIEP_DURATION 0x00000001 +#define DIEP_SAMPLEPERIOD 0x00000002 +#define DIEP_GAIN 0x00000004 +#define DIEP_TRIGGERBUTTON 0x00000008 +#define DIEP_TRIGGERREPEATINTERVAL 0x00000010 +#define DIEP_AXES 0x00000020 +#define DIEP_DIRECTION 0x00000040 +#define DIEP_ENVELOPE 0x00000080 +#define DIEP_TYPESPECIFICPARAMS 0x00000100 +#if(DIRECTINPUT_VERSION >= 0x0600) +#define DIEP_STARTDELAY 0x00000200 +#define DIEP_ALLPARAMS_DX5 0x000001FF +#define DIEP_ALLPARAMS 0x000003FF +#else /* DIRECTINPUT_VERSION < 0x0600 */ +#define DIEP_ALLPARAMS 0x000001FF +#endif /* DIRECTINPUT_VERSION < 0x0600 */ +#define DIEP_START 0x20000000 +#define DIEP_NORESTART 0x40000000 +#define DIEP_NODOWNLOAD 0x80000000 +#define DIEB_NOTRIGGER 0xFFFFFFFF + +#define DIES_SOLO 0x00000001 +#define DIES_NODOWNLOAD 0x80000000 + +#define DIEGES_PLAYING 0x00000001 +#define DIEGES_EMULATED 0x00000002 + +typedef struct DIEFFESCAPE { + DWORD dwSize; + DWORD dwCommand; + LPVOID lpvInBuffer; + DWORD cbInBuffer; + LPVOID lpvOutBuffer; + DWORD cbOutBuffer; +} DIEFFESCAPE, *LPDIEFFESCAPE; + +#ifndef DIJ_RINGZERO + +#undef INTERFACE +#define INTERFACE IDirectInputEffect + +DECLARE_INTERFACE_(IDirectInputEffect, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputEffect methods ***/ + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + STDMETHOD(GetEffectGuid)(THIS_ LPGUID) PURE; + STDMETHOD(GetParameters)(THIS_ LPDIEFFECT,DWORD) PURE; + STDMETHOD(SetParameters)(THIS_ LPCDIEFFECT,DWORD) PURE; + STDMETHOD(Start)(THIS_ DWORD,DWORD) PURE; + STDMETHOD(Stop)(THIS) PURE; + STDMETHOD(GetEffectStatus)(THIS_ LPDWORD) PURE; + STDMETHOD(Download)(THIS) PURE; + STDMETHOD(Unload)(THIS) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; +}; + +typedef struct IDirectInputEffect *LPDIRECTINPUTEFFECT; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInputEffect_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInputEffect_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInputEffect_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInputEffect_Initialize(p,a,b,c) (p)->lpVtbl->Initialize(p,a,b,c) +#define IDirectInputEffect_GetEffectGuid(p,a) (p)->lpVtbl->GetEffectGuid(p,a) +#define IDirectInputEffect_GetParameters(p,a,b) (p)->lpVtbl->GetParameters(p,a,b) +#define IDirectInputEffect_SetParameters(p,a,b) (p)->lpVtbl->SetParameters(p,a,b) +#define IDirectInputEffect_Start(p,a,b) (p)->lpVtbl->Start(p,a,b) +#define IDirectInputEffect_Stop(p) (p)->lpVtbl->Stop(p) +#define IDirectInputEffect_GetEffectStatus(p,a) (p)->lpVtbl->GetEffectStatus(p,a) +#define IDirectInputEffect_Download(p) (p)->lpVtbl->Download(p) +#define IDirectInputEffect_Unload(p) (p)->lpVtbl->Unload(p) +#define IDirectInputEffect_Escape(p,a) (p)->lpVtbl->Escape(p,a) +#else +#define IDirectInputEffect_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInputEffect_AddRef(p) (p)->AddRef() +#define IDirectInputEffect_Release(p) (p)->Release() +#define IDirectInputEffect_Initialize(p,a,b,c) (p)->Initialize(a,b,c) +#define IDirectInputEffect_GetEffectGuid(p,a) (p)->GetEffectGuid(a) +#define IDirectInputEffect_GetParameters(p,a,b) (p)->GetParameters(a,b) +#define IDirectInputEffect_SetParameters(p,a,b) (p)->SetParameters(a,b) +#define IDirectInputEffect_Start(p,a,b) (p)->Start(a,b) +#define IDirectInputEffect_Stop(p) (p)->Stop() +#define IDirectInputEffect_GetEffectStatus(p,a) (p)->GetEffectStatus(a) +#define IDirectInputEffect_Download(p) (p)->Download() +#define IDirectInputEffect_Unload(p) (p)->Unload() +#define IDirectInputEffect_Escape(p,a) (p)->Escape(a) +#endif + +#endif /* DIJ_RINGZERO */ + +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +/**************************************************************************** + * + * IDirectInputDevice + * + ****************************************************************************/ + +#if DIRECTINPUT_VERSION <= 0x700 +#define DIDEVTYPE_DEVICE 1 +#define DIDEVTYPE_MOUSE 2 +#define DIDEVTYPE_KEYBOARD 3 +#define DIDEVTYPE_JOYSTICK 4 + +#else +#define DI8DEVCLASS_ALL 0 +#define DI8DEVCLASS_DEVICE 1 +#define DI8DEVCLASS_POINTER 2 +#define DI8DEVCLASS_KEYBOARD 3 +#define DI8DEVCLASS_GAMECTRL 4 + +#define DI8DEVTYPE_DEVICE 0x11 +#define DI8DEVTYPE_MOUSE 0x12 +#define DI8DEVTYPE_KEYBOARD 0x13 +#define DI8DEVTYPE_JOYSTICK 0x14 +#define DI8DEVTYPE_GAMEPAD 0x15 +#define DI8DEVTYPE_DRIVING 0x16 +#define DI8DEVTYPE_FLIGHT 0x17 +#define DI8DEVTYPE_1STPERSON 0x18 +#define DI8DEVTYPE_DEVICECTRL 0x19 +#define DI8DEVTYPE_SCREENPOINTER 0x1A +#define DI8DEVTYPE_REMOTE 0x1B +#define DI8DEVTYPE_SUPPLEMENTAL 0x1C +#endif /* DIRECTINPUT_VERSION <= 0x700 */ + +#define DIDEVTYPE_HID 0x00010000 + +#if DIRECTINPUT_VERSION <= 0x700 +#define DIDEVTYPEMOUSE_UNKNOWN 1 +#define DIDEVTYPEMOUSE_TRADITIONAL 2 +#define DIDEVTYPEMOUSE_FINGERSTICK 3 +#define DIDEVTYPEMOUSE_TOUCHPAD 4 +#define DIDEVTYPEMOUSE_TRACKBALL 5 + +#define DIDEVTYPEKEYBOARD_UNKNOWN 0 +#define DIDEVTYPEKEYBOARD_PCXT 1 +#define DIDEVTYPEKEYBOARD_OLIVETTI 2 +#define DIDEVTYPEKEYBOARD_PCAT 3 +#define DIDEVTYPEKEYBOARD_PCENH 4 +#define DIDEVTYPEKEYBOARD_NOKIA1050 5 +#define DIDEVTYPEKEYBOARD_NOKIA9140 6 +#define DIDEVTYPEKEYBOARD_NEC98 7 +#define DIDEVTYPEKEYBOARD_NEC98LAPTOP 8 +#define DIDEVTYPEKEYBOARD_NEC98106 9 +#define DIDEVTYPEKEYBOARD_JAPAN106 10 +#define DIDEVTYPEKEYBOARD_JAPANAX 11 +#define DIDEVTYPEKEYBOARD_J3100 12 + +#define DIDEVTYPEJOYSTICK_UNKNOWN 1 +#define DIDEVTYPEJOYSTICK_TRADITIONAL 2 +#define DIDEVTYPEJOYSTICK_FLIGHTSTICK 3 +#define DIDEVTYPEJOYSTICK_GAMEPAD 4 +#define DIDEVTYPEJOYSTICK_RUDDER 5 +#define DIDEVTYPEJOYSTICK_WHEEL 6 +#define DIDEVTYPEJOYSTICK_HEADTRACKER 7 + +#else +#define DI8DEVTYPEMOUSE_UNKNOWN 1 +#define DI8DEVTYPEMOUSE_TRADITIONAL 2 +#define DI8DEVTYPEMOUSE_FINGERSTICK 3 +#define DI8DEVTYPEMOUSE_TOUCHPAD 4 +#define DI8DEVTYPEMOUSE_TRACKBALL 5 +#define DI8DEVTYPEMOUSE_ABSOLUTE 6 + +#define DI8DEVTYPEKEYBOARD_UNKNOWN 0 +#define DI8DEVTYPEKEYBOARD_PCXT 1 +#define DI8DEVTYPEKEYBOARD_OLIVETTI 2 +#define DI8DEVTYPEKEYBOARD_PCAT 3 +#define DI8DEVTYPEKEYBOARD_PCENH 4 +#define DI8DEVTYPEKEYBOARD_NOKIA1050 5 +#define DI8DEVTYPEKEYBOARD_NOKIA9140 6 +#define DI8DEVTYPEKEYBOARD_NEC98 7 +#define DI8DEVTYPEKEYBOARD_NEC98LAPTOP 8 +#define DI8DEVTYPEKEYBOARD_NEC98106 9 +#define DI8DEVTYPEKEYBOARD_JAPAN106 10 +#define DI8DEVTYPEKEYBOARD_JAPANAX 11 +#define DI8DEVTYPEKEYBOARD_J3100 12 + +#define DI8DEVTYPE_LIMITEDGAMESUBTYPE 1 + +#define DI8DEVTYPEJOYSTICK_LIMITED DI8DEVTYPE_LIMITEDGAMESUBTYPE +#define DI8DEVTYPEJOYSTICK_STANDARD 2 + +#define DI8DEVTYPEGAMEPAD_LIMITED DI8DEVTYPE_LIMITEDGAMESUBTYPE +#define DI8DEVTYPEGAMEPAD_STANDARD 2 +#define DI8DEVTYPEGAMEPAD_TILT 3 + +#define DI8DEVTYPEDRIVING_LIMITED DI8DEVTYPE_LIMITEDGAMESUBTYPE +#define DI8DEVTYPEDRIVING_COMBINEDPEDALS 2 +#define DI8DEVTYPEDRIVING_DUALPEDALS 3 +#define DI8DEVTYPEDRIVING_THREEPEDALS 4 +#define DI8DEVTYPEDRIVING_HANDHELD 5 + +#define DI8DEVTYPEFLIGHT_LIMITED DI8DEVTYPE_LIMITEDGAMESUBTYPE +#define DI8DEVTYPEFLIGHT_STICK 2 +#define DI8DEVTYPEFLIGHT_YOKE 3 +#define DI8DEVTYPEFLIGHT_RC 4 + +#define DI8DEVTYPE1STPERSON_LIMITED DI8DEVTYPE_LIMITEDGAMESUBTYPE +#define DI8DEVTYPE1STPERSON_UNKNOWN 2 +#define DI8DEVTYPE1STPERSON_SIXDOF 3 +#define DI8DEVTYPE1STPERSON_SHOOTER 4 + +#define DI8DEVTYPESCREENPTR_UNKNOWN 2 +#define DI8DEVTYPESCREENPTR_LIGHTGUN 3 +#define DI8DEVTYPESCREENPTR_LIGHTPEN 4 +#define DI8DEVTYPESCREENPTR_TOUCH 5 + +#define DI8DEVTYPEREMOTE_UNKNOWN 2 + +#define DI8DEVTYPEDEVICECTRL_UNKNOWN 2 +#define DI8DEVTYPEDEVICECTRL_COMMSSELECTION 3 +#define DI8DEVTYPEDEVICECTRL_COMMSSELECTION_HARDWIRED 4 + +#define DI8DEVTYPESUPPLEMENTAL_UNKNOWN 2 +#define DI8DEVTYPESUPPLEMENTAL_2NDHANDCONTROLLER 3 +#define DI8DEVTYPESUPPLEMENTAL_HEADTRACKER 4 +#define DI8DEVTYPESUPPLEMENTAL_HANDTRACKER 5 +#define DI8DEVTYPESUPPLEMENTAL_SHIFTSTICKGATE 6 +#define DI8DEVTYPESUPPLEMENTAL_SHIFTER 7 +#define DI8DEVTYPESUPPLEMENTAL_THROTTLE 8 +#define DI8DEVTYPESUPPLEMENTAL_SPLITTHROTTLE 9 +#define DI8DEVTYPESUPPLEMENTAL_COMBINEDPEDALS 10 +#define DI8DEVTYPESUPPLEMENTAL_DUALPEDALS 11 +#define DI8DEVTYPESUPPLEMENTAL_THREEPEDALS 12 +#define DI8DEVTYPESUPPLEMENTAL_RUDDERPEDALS 13 +#endif /* DIRECTINPUT_VERSION <= 0x700 */ + +#define GET_DIDEVICE_TYPE(dwDevType) LOBYTE(dwDevType) +#define GET_DIDEVICE_SUBTYPE(dwDevType) HIBYTE(dwDevType) + +#if(DIRECTINPUT_VERSION >= 0x0500) +/* This structure is defined for DirectX 3.0 compatibility */ +typedef struct DIDEVCAPS_DX3 { + DWORD dwSize; + DWORD dwFlags; + DWORD dwDevType; + DWORD dwAxes; + DWORD dwButtons; + DWORD dwPOVs; +} DIDEVCAPS_DX3, *LPDIDEVCAPS_DX3; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +typedef struct DIDEVCAPS { + DWORD dwSize; + DWORD dwFlags; + DWORD dwDevType; + DWORD dwAxes; + DWORD dwButtons; + DWORD dwPOVs; +#if(DIRECTINPUT_VERSION >= 0x0500) + DWORD dwFFSamplePeriod; + DWORD dwFFMinTimeResolution; + DWORD dwFirmwareRevision; + DWORD dwHardwareRevision; + DWORD dwFFDriverVersion; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +} DIDEVCAPS, *LPDIDEVCAPS; + +#define DIDC_ATTACHED 0x00000001 +#define DIDC_POLLEDDEVICE 0x00000002 +#define DIDC_EMULATED 0x00000004 +#define DIDC_POLLEDDATAFORMAT 0x00000008 +#if(DIRECTINPUT_VERSION >= 0x0500) +#define DIDC_FORCEFEEDBACK 0x00000100 +#define DIDC_FFATTACK 0x00000200 +#define DIDC_FFFADE 0x00000400 +#define DIDC_SATURATION 0x00000800 +#define DIDC_POSNEGCOEFFICIENTS 0x00001000 +#define DIDC_POSNEGSATURATION 0x00002000 +#define DIDC_DEADBAND 0x00004000 +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +#define DIDC_STARTDELAY 0x00008000 +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIDC_ALIAS 0x00010000 +#define DIDC_PHANTOM 0x00020000 +#endif /* DIRECTINPUT_VERSION >= 0x050a */ +#if(DIRECTINPUT_VERSION >= 0x0800) +#define DIDC_HIDDEN 0x00040000 +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +#define DIDFT_ALL 0x00000000 + +#define DIDFT_RELAXIS 0x00000001 +#define DIDFT_ABSAXIS 0x00000002 +#define DIDFT_AXIS 0x00000003 + +#define DIDFT_PSHBUTTON 0x00000004 +#define DIDFT_TGLBUTTON 0x00000008 +#define DIDFT_BUTTON 0x0000000C + +#define DIDFT_POV 0x00000010 +#define DIDFT_COLLECTION 0x00000040 +#define DIDFT_NODATA 0x00000080 + +#define DIDFT_ANYINSTANCE 0x00FFFF00 +#define DIDFT_INSTANCEMASK DIDFT_ANYINSTANCE +#define DIDFT_MAKEINSTANCE(n) ((WORD)(n) << 8) +#define DIDFT_GETTYPE(n) LOBYTE(n) +#define DIDFT_GETINSTANCE(n) LOWORD((n) >> 8) +#define DIDFT_FFACTUATOR 0x01000000 +#define DIDFT_FFEFFECTTRIGGER 0x02000000 +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIDFT_OUTPUT 0x10000000 +#define DIDFT_VENDORDEFINED 0x04000000 +#define DIDFT_ALIAS 0x08000000 +#endif /* DIRECTINPUT_VERSION >= 0x050a */ +#ifndef DIDFT_OPTIONAL +#define DIDFT_OPTIONAL 0x80000000 +#endif + +#define DIDFT_ENUMCOLLECTION(n) ((WORD)(n) << 8) +#define DIDFT_NOCOLLECTION 0x00FFFF00 + +#ifndef DIJ_RINGZERO + +typedef struct _DIOBJECTDATAFORMAT { + const GUID *pguid; + DWORD dwOfs; + DWORD dwType; + DWORD dwFlags; +} DIOBJECTDATAFORMAT, *LPDIOBJECTDATAFORMAT; +typedef const DIOBJECTDATAFORMAT *LPCDIOBJECTDATAFORMAT; + +typedef struct _DIDATAFORMAT { + DWORD dwSize; + DWORD dwObjSize; + DWORD dwFlags; + DWORD dwDataSize; + DWORD dwNumObjs; + LPDIOBJECTDATAFORMAT rgodf; +} DIDATAFORMAT, *LPDIDATAFORMAT; +typedef const DIDATAFORMAT *LPCDIDATAFORMAT; + +#define DIDF_ABSAXIS 0x00000001 +#define DIDF_RELAXIS 0x00000002 + +#ifdef __cplusplus +extern "C" { +#endif +extern const DIDATAFORMAT c_dfDIMouse; + +#if(DIRECTINPUT_VERSION >= 0x0700) +extern const DIDATAFORMAT c_dfDIMouse2; +#endif /* DIRECTINPUT_VERSION >= 0x0700 */ + +extern const DIDATAFORMAT c_dfDIKeyboard; + +#if(DIRECTINPUT_VERSION >= 0x0500) +extern const DIDATAFORMAT c_dfDIJoystick; +extern const DIDATAFORMAT c_dfDIJoystick2; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +#ifdef __cplusplus +}; +#endif + + +#if DIRECTINPUT_VERSION > 0x0700 + +typedef struct _DIACTIONA { + UINT_PTR uAppData; + DWORD dwSemantic; + OPTIONAL DWORD dwFlags; + OPTIONAL union { + LPCSTR lptszActionName; + UINT uResIdString; + }; + OPTIONAL GUID guidInstance; + OPTIONAL DWORD dwObjID; + OPTIONAL DWORD dwHow; +} DIACTIONA, *LPDIACTIONA ; +typedef struct _DIACTIONW { + UINT_PTR uAppData; + DWORD dwSemantic; + OPTIONAL DWORD dwFlags; + OPTIONAL union { + LPCWSTR lptszActionName; + UINT uResIdString; + }; + OPTIONAL GUID guidInstance; + OPTIONAL DWORD dwObjID; + OPTIONAL DWORD dwHow; +} DIACTIONW, *LPDIACTIONW ; +#ifdef UNICODE +typedef DIACTIONW DIACTION; +typedef LPDIACTIONW LPDIACTION; +#else +typedef DIACTIONA DIACTION; +typedef LPDIACTIONA LPDIACTION; +#endif // UNICODE + +typedef const DIACTIONA *LPCDIACTIONA; +typedef const DIACTIONW *LPCDIACTIONW; +#ifdef UNICODE +typedef DIACTIONW DIACTION; +typedef LPCDIACTIONW LPCDIACTION; +#else +typedef DIACTIONA DIACTION; +typedef LPCDIACTIONA LPCDIACTION; +#endif // UNICODE +typedef const DIACTION *LPCDIACTION; + + +#define DIA_FORCEFEEDBACK 0x00000001 +#define DIA_APPMAPPED 0x00000002 +#define DIA_APPNOMAP 0x00000004 +#define DIA_NORANGE 0x00000008 +#define DIA_APPFIXED 0x00000010 + +#define DIAH_UNMAPPED 0x00000000 +#define DIAH_USERCONFIG 0x00000001 +#define DIAH_APPREQUESTED 0x00000002 +#define DIAH_HWAPP 0x00000004 +#define DIAH_HWDEFAULT 0x00000008 +#define DIAH_DEFAULT 0x00000020 +#define DIAH_ERROR 0x80000000 + +typedef struct _DIACTIONFORMATA { + DWORD dwSize; + DWORD dwActionSize; + DWORD dwDataSize; + DWORD dwNumActions; + LPDIACTIONA rgoAction; + GUID guidActionMap; + DWORD dwGenre; + DWORD dwBufferSize; + OPTIONAL LONG lAxisMin; + OPTIONAL LONG lAxisMax; + OPTIONAL HINSTANCE hInstString; + FILETIME ftTimeStamp; + DWORD dwCRC; + CHAR tszActionMap[MAX_PATH]; +} DIACTIONFORMATA, *LPDIACTIONFORMATA; +typedef struct _DIACTIONFORMATW { + DWORD dwSize; + DWORD dwActionSize; + DWORD dwDataSize; + DWORD dwNumActions; + LPDIACTIONW rgoAction; + GUID guidActionMap; + DWORD dwGenre; + DWORD dwBufferSize; + OPTIONAL LONG lAxisMin; + OPTIONAL LONG lAxisMax; + OPTIONAL HINSTANCE hInstString; + FILETIME ftTimeStamp; + DWORD dwCRC; + WCHAR tszActionMap[MAX_PATH]; +} DIACTIONFORMATW, *LPDIACTIONFORMATW; +#ifdef UNICODE +typedef DIACTIONFORMATW DIACTIONFORMAT; +typedef LPDIACTIONFORMATW LPDIACTIONFORMAT; +#else +typedef DIACTIONFORMATA DIACTIONFORMAT; +typedef LPDIACTIONFORMATA LPDIACTIONFORMAT; +#endif // UNICODE +typedef const DIACTIONFORMATA *LPCDIACTIONFORMATA; +typedef const DIACTIONFORMATW *LPCDIACTIONFORMATW; +#ifdef UNICODE +typedef DIACTIONFORMATW DIACTIONFORMAT; +typedef LPCDIACTIONFORMATW LPCDIACTIONFORMAT; +#else +typedef DIACTIONFORMATA DIACTIONFORMAT; +typedef LPCDIACTIONFORMATA LPCDIACTIONFORMAT; +#endif // UNICODE +typedef const DIACTIONFORMAT *LPCDIACTIONFORMAT; + +#define DIAFTS_NEWDEVICELOW 0xFFFFFFFF +#define DIAFTS_NEWDEVICEHIGH 0xFFFFFFFF +#define DIAFTS_UNUSEDDEVICELOW 0x00000000 +#define DIAFTS_UNUSEDDEVICEHIGH 0x00000000 + +#define DIDBAM_DEFAULT 0x00000000 +#define DIDBAM_PRESERVE 0x00000001 +#define DIDBAM_INITIALIZE 0x00000002 +#define DIDBAM_HWDEFAULTS 0x00000004 + +#define DIDSAM_DEFAULT 0x00000000 +#define DIDSAM_NOUSER 0x00000001 +#define DIDSAM_FORCESAVE 0x00000002 + +#define DICD_DEFAULT 0x00000000 +#define DICD_EDIT 0x00000001 + +/* + * The following definition is normally defined in d3dtypes.h + */ +#ifndef D3DCOLOR_DEFINED +typedef DWORD D3DCOLOR; +#define D3DCOLOR_DEFINED +#endif + +typedef struct _DICOLORSET{ + DWORD dwSize; + D3DCOLOR cTextFore; + D3DCOLOR cTextHighlight; + D3DCOLOR cCalloutLine; + D3DCOLOR cCalloutHighlight; + D3DCOLOR cBorder; + D3DCOLOR cControlFill; + D3DCOLOR cHighlightFill; + D3DCOLOR cAreaFill; +} DICOLORSET, *LPDICOLORSET; +typedef const DICOLORSET *LPCDICOLORSET; + + +typedef struct _DICONFIGUREDEVICESPARAMSA{ + DWORD dwSize; + DWORD dwcUsers; + LPSTR lptszUserNames; + DWORD dwcFormats; + LPDIACTIONFORMATA lprgFormats; + HWND hwnd; + DICOLORSET dics; + IUnknown FAR * lpUnkDDSTarget; +} DICONFIGUREDEVICESPARAMSA, *LPDICONFIGUREDEVICESPARAMSA; +typedef struct _DICONFIGUREDEVICESPARAMSW{ + DWORD dwSize; + DWORD dwcUsers; + LPWSTR lptszUserNames; + DWORD dwcFormats; + LPDIACTIONFORMATW lprgFormats; + HWND hwnd; + DICOLORSET dics; + IUnknown FAR * lpUnkDDSTarget; +} DICONFIGUREDEVICESPARAMSW, *LPDICONFIGUREDEVICESPARAMSW; +#ifdef UNICODE +typedef DICONFIGUREDEVICESPARAMSW DICONFIGUREDEVICESPARAMS; +typedef LPDICONFIGUREDEVICESPARAMSW LPDICONFIGUREDEVICESPARAMS; +#else +typedef DICONFIGUREDEVICESPARAMSA DICONFIGUREDEVICESPARAMS; +typedef LPDICONFIGUREDEVICESPARAMSA LPDICONFIGUREDEVICESPARAMS; +#endif // UNICODE +typedef const DICONFIGUREDEVICESPARAMSA *LPCDICONFIGUREDEVICESPARAMSA; +typedef const DICONFIGUREDEVICESPARAMSW *LPCDICONFIGUREDEVICESPARAMSW; +#ifdef UNICODE +typedef DICONFIGUREDEVICESPARAMSW DICONFIGUREDEVICESPARAMS; +typedef LPCDICONFIGUREDEVICESPARAMSW LPCDICONFIGUREDEVICESPARAMS; +#else +typedef DICONFIGUREDEVICESPARAMSA DICONFIGUREDEVICESPARAMS; +typedef LPCDICONFIGUREDEVICESPARAMSA LPCDICONFIGUREDEVICESPARAMS; +#endif // UNICODE +typedef const DICONFIGUREDEVICESPARAMS *LPCDICONFIGUREDEVICESPARAMS; + + +#define DIDIFT_CONFIGURATION 0x00000001 +#define DIDIFT_OVERLAY 0x00000002 + +#define DIDAL_CENTERED 0x00000000 +#define DIDAL_LEFTALIGNED 0x00000001 +#define DIDAL_RIGHTALIGNED 0x00000002 +#define DIDAL_MIDDLE 0x00000000 +#define DIDAL_TOPALIGNED 0x00000004 +#define DIDAL_BOTTOMALIGNED 0x00000008 + +typedef struct _DIDEVICEIMAGEINFOA { + CHAR tszImagePath[MAX_PATH]; + DWORD dwFlags; + // These are valid if DIDIFT_OVERLAY is present in dwFlags. + DWORD dwViewID; + RECT rcOverlay; + DWORD dwObjID; + DWORD dwcValidPts; + POINT rgptCalloutLine[5]; + RECT rcCalloutRect; + DWORD dwTextAlign; +} DIDEVICEIMAGEINFOA, *LPDIDEVICEIMAGEINFOA; +typedef struct _DIDEVICEIMAGEINFOW { + WCHAR tszImagePath[MAX_PATH]; + DWORD dwFlags; + // These are valid if DIDIFT_OVERLAY is present in dwFlags. + DWORD dwViewID; + RECT rcOverlay; + DWORD dwObjID; + DWORD dwcValidPts; + POINT rgptCalloutLine[5]; + RECT rcCalloutRect; + DWORD dwTextAlign; +} DIDEVICEIMAGEINFOW, *LPDIDEVICEIMAGEINFOW; +#ifdef UNICODE +typedef DIDEVICEIMAGEINFOW DIDEVICEIMAGEINFO; +typedef LPDIDEVICEIMAGEINFOW LPDIDEVICEIMAGEINFO; +#else +typedef DIDEVICEIMAGEINFOA DIDEVICEIMAGEINFO; +typedef LPDIDEVICEIMAGEINFOA LPDIDEVICEIMAGEINFO; +#endif // UNICODE +typedef const DIDEVICEIMAGEINFOA *LPCDIDEVICEIMAGEINFOA; +typedef const DIDEVICEIMAGEINFOW *LPCDIDEVICEIMAGEINFOW; +#ifdef UNICODE +typedef DIDEVICEIMAGEINFOW DIDEVICEIMAGEINFO; +typedef LPCDIDEVICEIMAGEINFOW LPCDIDEVICEIMAGEINFO; +#else +typedef DIDEVICEIMAGEINFOA DIDEVICEIMAGEINFO; +typedef LPCDIDEVICEIMAGEINFOA LPCDIDEVICEIMAGEINFO; +#endif // UNICODE +typedef const DIDEVICEIMAGEINFO *LPCDIDEVICEIMAGEINFO; + +typedef struct _DIDEVICEIMAGEINFOHEADERA { + DWORD dwSize; + DWORD dwSizeImageInfo; + DWORD dwcViews; + DWORD dwcButtons; + DWORD dwcAxes; + DWORD dwcPOVs; + DWORD dwBufferSize; + DWORD dwBufferUsed; + LPDIDEVICEIMAGEINFOA lprgImageInfoArray; +} DIDEVICEIMAGEINFOHEADERA, *LPDIDEVICEIMAGEINFOHEADERA; +typedef struct _DIDEVICEIMAGEINFOHEADERW { + DWORD dwSize; + DWORD dwSizeImageInfo; + DWORD dwcViews; + DWORD dwcButtons; + DWORD dwcAxes; + DWORD dwcPOVs; + DWORD dwBufferSize; + DWORD dwBufferUsed; + LPDIDEVICEIMAGEINFOW lprgImageInfoArray; +} DIDEVICEIMAGEINFOHEADERW, *LPDIDEVICEIMAGEINFOHEADERW; +#ifdef UNICODE +typedef DIDEVICEIMAGEINFOHEADERW DIDEVICEIMAGEINFOHEADER; +typedef LPDIDEVICEIMAGEINFOHEADERW LPDIDEVICEIMAGEINFOHEADER; +#else +typedef DIDEVICEIMAGEINFOHEADERA DIDEVICEIMAGEINFOHEADER; +typedef LPDIDEVICEIMAGEINFOHEADERA LPDIDEVICEIMAGEINFOHEADER; +#endif // UNICODE +typedef const DIDEVICEIMAGEINFOHEADERA *LPCDIDEVICEIMAGEINFOHEADERA; +typedef const DIDEVICEIMAGEINFOHEADERW *LPCDIDEVICEIMAGEINFOHEADERW; +#ifdef UNICODE +typedef DIDEVICEIMAGEINFOHEADERW DIDEVICEIMAGEINFOHEADER; +typedef LPCDIDEVICEIMAGEINFOHEADERW LPCDIDEVICEIMAGEINFOHEADER; +#else +typedef DIDEVICEIMAGEINFOHEADERA DIDEVICEIMAGEINFOHEADER; +typedef LPCDIDEVICEIMAGEINFOHEADERA LPCDIDEVICEIMAGEINFOHEADER; +#endif // UNICODE +typedef const DIDEVICEIMAGEINFOHEADER *LPCDIDEVICEIMAGEINFOHEADER; + +#endif /* DIRECTINPUT_VERSION > 0x0700 */ + +#if(DIRECTINPUT_VERSION >= 0x0500) +/* These structures are defined for DirectX 3.0 compatibility */ + +typedef struct DIDEVICEOBJECTINSTANCE_DX3A { + DWORD dwSize; + GUID guidType; + DWORD dwOfs; + DWORD dwType; + DWORD dwFlags; + CHAR tszName[MAX_PATH]; +} DIDEVICEOBJECTINSTANCE_DX3A, *LPDIDEVICEOBJECTINSTANCE_DX3A; +typedef struct DIDEVICEOBJECTINSTANCE_DX3W { + DWORD dwSize; + GUID guidType; + DWORD dwOfs; + DWORD dwType; + DWORD dwFlags; + WCHAR tszName[MAX_PATH]; +} DIDEVICEOBJECTINSTANCE_DX3W, *LPDIDEVICEOBJECTINSTANCE_DX3W; +#ifdef UNICODE +typedef DIDEVICEOBJECTINSTANCE_DX3W DIDEVICEOBJECTINSTANCE_DX3; +typedef LPDIDEVICEOBJECTINSTANCE_DX3W LPDIDEVICEOBJECTINSTANCE_DX3; +#else +typedef DIDEVICEOBJECTINSTANCE_DX3A DIDEVICEOBJECTINSTANCE_DX3; +typedef LPDIDEVICEOBJECTINSTANCE_DX3A LPDIDEVICEOBJECTINSTANCE_DX3; +#endif // UNICODE +typedef const DIDEVICEOBJECTINSTANCE_DX3A *LPCDIDEVICEOBJECTINSTANCE_DX3A; +typedef const DIDEVICEOBJECTINSTANCE_DX3W *LPCDIDEVICEOBJECTINSTANCE_DX3W; +typedef const DIDEVICEOBJECTINSTANCE_DX3 *LPCDIDEVICEOBJECTINSTANCE_DX3; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +typedef struct DIDEVICEOBJECTINSTANCEA { + DWORD dwSize; + GUID guidType; + DWORD dwOfs; + DWORD dwType; + DWORD dwFlags; + CHAR tszName[MAX_PATH]; +#if(DIRECTINPUT_VERSION >= 0x0500) + DWORD dwFFMaxForce; + DWORD dwFFForceResolution; + WORD wCollectionNumber; + WORD wDesignatorIndex; + WORD wUsagePage; + WORD wUsage; + DWORD dwDimension; + WORD wExponent; + WORD wReportId; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +} DIDEVICEOBJECTINSTANCEA, *LPDIDEVICEOBJECTINSTANCEA; +typedef struct DIDEVICEOBJECTINSTANCEW { + DWORD dwSize; + GUID guidType; + DWORD dwOfs; + DWORD dwType; + DWORD dwFlags; + WCHAR tszName[MAX_PATH]; +#if(DIRECTINPUT_VERSION >= 0x0500) + DWORD dwFFMaxForce; + DWORD dwFFForceResolution; + WORD wCollectionNumber; + WORD wDesignatorIndex; + WORD wUsagePage; + WORD wUsage; + DWORD dwDimension; + WORD wExponent; + WORD wReportId; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +} DIDEVICEOBJECTINSTANCEW, *LPDIDEVICEOBJECTINSTANCEW; +#ifdef UNICODE +typedef DIDEVICEOBJECTINSTANCEW DIDEVICEOBJECTINSTANCE; +typedef LPDIDEVICEOBJECTINSTANCEW LPDIDEVICEOBJECTINSTANCE; +#else +typedef DIDEVICEOBJECTINSTANCEA DIDEVICEOBJECTINSTANCE; +typedef LPDIDEVICEOBJECTINSTANCEA LPDIDEVICEOBJECTINSTANCE; +#endif // UNICODE +typedef const DIDEVICEOBJECTINSTANCEA *LPCDIDEVICEOBJECTINSTANCEA; +typedef const DIDEVICEOBJECTINSTANCEW *LPCDIDEVICEOBJECTINSTANCEW; +typedef const DIDEVICEOBJECTINSTANCE *LPCDIDEVICEOBJECTINSTANCE; + +typedef BOOL (FAR PASCAL * LPDIENUMDEVICEOBJECTSCALLBACKA)(LPCDIDEVICEOBJECTINSTANCEA, LPVOID); +typedef BOOL (FAR PASCAL * LPDIENUMDEVICEOBJECTSCALLBACKW)(LPCDIDEVICEOBJECTINSTANCEW, LPVOID); +#ifdef UNICODE +#define LPDIENUMDEVICEOBJECTSCALLBACK LPDIENUMDEVICEOBJECTSCALLBACKW +#else +#define LPDIENUMDEVICEOBJECTSCALLBACK LPDIENUMDEVICEOBJECTSCALLBACKA +#endif // !UNICODE + +#if(DIRECTINPUT_VERSION >= 0x0500) +#define DIDOI_FFACTUATOR 0x00000001 +#define DIDOI_FFEFFECTTRIGGER 0x00000002 +#define DIDOI_POLLED 0x00008000 +#define DIDOI_ASPECTPOSITION 0x00000100 +#define DIDOI_ASPECTVELOCITY 0x00000200 +#define DIDOI_ASPECTACCEL 0x00000300 +#define DIDOI_ASPECTFORCE 0x00000400 +#define DIDOI_ASPECTMASK 0x00000F00 +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIDOI_GUIDISUSAGE 0x00010000 +#endif /* DIRECTINPUT_VERSION >= 0x050a */ + +typedef struct DIPROPHEADER { + DWORD dwSize; + DWORD dwHeaderSize; + DWORD dwObj; + DWORD dwHow; +} DIPROPHEADER, *LPDIPROPHEADER; +typedef const DIPROPHEADER *LPCDIPROPHEADER; + +#define DIPH_DEVICE 0 +#define DIPH_BYOFFSET 1 +#define DIPH_BYID 2 +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIPH_BYUSAGE 3 +#endif /* DIRECTINPUT_VERSION >= 0x050a */ + +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIMAKEUSAGEDWORD(UsagePage, Usage) \ + (DWORD)MAKELONG(Usage, UsagePage) +#endif /* DIRECTINPUT_VERSION >= 0x050a */ + +typedef struct DIPROPDWORD { + DIPROPHEADER diph; + DWORD dwData; +} DIPROPDWORD, *LPDIPROPDWORD; +typedef const DIPROPDWORD *LPCDIPROPDWORD; + +#if(DIRECTINPUT_VERSION >= 0x0800) +typedef struct DIPROPPOINTER { + DIPROPHEADER diph; + UINT_PTR uData; +} DIPROPPOINTER, *LPDIPROPPOINTER; +typedef const DIPROPPOINTER *LPCDIPROPPOINTER; +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +typedef struct DIPROPRANGE { + DIPROPHEADER diph; + LONG lMin; + LONG lMax; +} DIPROPRANGE, *LPDIPROPRANGE; +typedef const DIPROPRANGE *LPCDIPROPRANGE; + +#define DIPROPRANGE_NOMIN ((LONG)0x80000000) +#define DIPROPRANGE_NOMAX ((LONG)0x7FFFFFFF) + +#if(DIRECTINPUT_VERSION >= 0x050a) +typedef struct DIPROPCAL { + DIPROPHEADER diph; + LONG lMin; + LONG lCenter; + LONG lMax; +} DIPROPCAL, *LPDIPROPCAL; +typedef const DIPROPCAL *LPCDIPROPCAL; + +typedef struct DIPROPCALPOV { + DIPROPHEADER diph; + LONG lMin[5]; + LONG lMax[5]; +} DIPROPCALPOV, *LPDIPROPCALPOV; +typedef const DIPROPCALPOV *LPCDIPROPCALPOV; + +typedef struct DIPROPGUIDANDPATH { + DIPROPHEADER diph; + GUID guidClass; + WCHAR wszPath[MAX_PATH]; +} DIPROPGUIDANDPATH, *LPDIPROPGUIDANDPATH; +typedef const DIPROPGUIDANDPATH *LPCDIPROPGUIDANDPATH; + +typedef struct DIPROPSTRING { + DIPROPHEADER diph; + WCHAR wsz[MAX_PATH]; +} DIPROPSTRING, *LPDIPROPSTRING; +typedef const DIPROPSTRING *LPCDIPROPSTRING; + +#endif /* DIRECTINPUT_VERSION >= 0x050a */ + +#if(DIRECTINPUT_VERSION >= 0x0800) +#define MAXCPOINTSNUM 8 + +typedef struct _CPOINT +{ + LONG lP; // raw value + DWORD dwLog; // logical_value / max_logical_value * 10000 +} CPOINT, *PCPOINT; + +typedef struct DIPROPCPOINTS { + DIPROPHEADER diph; + DWORD dwCPointsNum; + CPOINT cp[MAXCPOINTSNUM]; +} DIPROPCPOINTS, *LPDIPROPCPOINTS; +typedef const DIPROPCPOINTS *LPCDIPROPCPOINTS; +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + + +#ifdef __cplusplus +#define MAKEDIPROP(prop) (*(const GUID *)(prop)) +#else +#define MAKEDIPROP(prop) ((REFGUID)(prop)) +#endif + +#define DIPROP_BUFFERSIZE MAKEDIPROP(1) + +#define DIPROP_AXISMODE MAKEDIPROP(2) + +#define DIPROPAXISMODE_ABS 0 +#define DIPROPAXISMODE_REL 1 + +#define DIPROP_GRANULARITY MAKEDIPROP(3) + +#define DIPROP_RANGE MAKEDIPROP(4) + +#define DIPROP_DEADZONE MAKEDIPROP(5) + +#define DIPROP_SATURATION MAKEDIPROP(6) + +#define DIPROP_FFGAIN MAKEDIPROP(7) + +#define DIPROP_FFLOAD MAKEDIPROP(8) + +#define DIPROP_AUTOCENTER MAKEDIPROP(9) + +#define DIPROPAUTOCENTER_OFF 0 +#define DIPROPAUTOCENTER_ON 1 + +#define DIPROP_CALIBRATIONMODE MAKEDIPROP(10) + +#define DIPROPCALIBRATIONMODE_COOKED 0 +#define DIPROPCALIBRATIONMODE_RAW 1 + +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIPROP_CALIBRATION MAKEDIPROP(11) + +#define DIPROP_GUIDANDPATH MAKEDIPROP(12) + +#define DIPROP_INSTANCENAME MAKEDIPROP(13) + +#define DIPROP_PRODUCTNAME MAKEDIPROP(14) +#endif /* DIRECTINPUT_VERSION >= 0x050a */ + +#if(DIRECTINPUT_VERSION >= 0x05b2) +#define DIPROP_JOYSTICKID MAKEDIPROP(15) + +#define DIPROP_GETPORTDISPLAYNAME MAKEDIPROP(16) + +#endif /* DIRECTINPUT_VERSION >= 0x05b2 */ + +#if(DIRECTINPUT_VERSION >= 0x0700) +#define DIPROP_PHYSICALRANGE MAKEDIPROP(18) + +#define DIPROP_LOGICALRANGE MAKEDIPROP(19) +#endif /* DIRECTINPUT_VERSION >= 0x0700 */ + +#if(DIRECTINPUT_VERSION >= 0x0800) +#define DIPROP_KEYNAME MAKEDIPROP(20) + +#define DIPROP_CPOINTS MAKEDIPROP(21) + +#define DIPROP_APPDATA MAKEDIPROP(22) + +#define DIPROP_SCANCODE MAKEDIPROP(23) + +#define DIPROP_VIDPID MAKEDIPROP(24) + +#define DIPROP_USERNAME MAKEDIPROP(25) + +#define DIPROP_TYPENAME MAKEDIPROP(26) +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + + +typedef struct DIDEVICEOBJECTDATA_DX3 { + DWORD dwOfs; + DWORD dwData; + DWORD dwTimeStamp; + DWORD dwSequence; +} DIDEVICEOBJECTDATA_DX3, *LPDIDEVICEOBJECTDATA_DX3; +typedef const DIDEVICEOBJECTDATA_DX3 *LPCDIDEVICEOBJECTDATA_DX; + +typedef struct DIDEVICEOBJECTDATA { + DWORD dwOfs; + DWORD dwData; + DWORD dwTimeStamp; + DWORD dwSequence; +#if(DIRECTINPUT_VERSION >= 0x0800) + UINT_PTR uAppData; +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ +} DIDEVICEOBJECTDATA, *LPDIDEVICEOBJECTDATA; +typedef const DIDEVICEOBJECTDATA *LPCDIDEVICEOBJECTDATA; + +#define DIGDD_PEEK 0x00000001 + +#define DISEQUENCE_COMPARE(dwSequence1, cmp, dwSequence2) \ + ((int)((dwSequence1) - (dwSequence2)) cmp 0) +#define DISCL_EXCLUSIVE 0x00000001 +#define DISCL_NONEXCLUSIVE 0x00000002 +#define DISCL_FOREGROUND 0x00000004 +#define DISCL_BACKGROUND 0x00000008 +#define DISCL_NOWINKEY 0x00000010 + +#if(DIRECTINPUT_VERSION >= 0x0500) +/* These structures are defined for DirectX 3.0 compatibility */ + +typedef struct DIDEVICEINSTANCE_DX3A { + DWORD dwSize; + GUID guidInstance; + GUID guidProduct; + DWORD dwDevType; + CHAR tszInstanceName[MAX_PATH]; + CHAR tszProductName[MAX_PATH]; +} DIDEVICEINSTANCE_DX3A, *LPDIDEVICEINSTANCE_DX3A; +typedef struct DIDEVICEINSTANCE_DX3W { + DWORD dwSize; + GUID guidInstance; + GUID guidProduct; + DWORD dwDevType; + WCHAR tszInstanceName[MAX_PATH]; + WCHAR tszProductName[MAX_PATH]; +} DIDEVICEINSTANCE_DX3W, *LPDIDEVICEINSTANCE_DX3W; +#ifdef UNICODE +typedef DIDEVICEINSTANCE_DX3W DIDEVICEINSTANCE_DX3; +typedef LPDIDEVICEINSTANCE_DX3W LPDIDEVICEINSTANCE_DX3; +#else +typedef DIDEVICEINSTANCE_DX3A DIDEVICEINSTANCE_DX3; +typedef LPDIDEVICEINSTANCE_DX3A LPDIDEVICEINSTANCE_DX3; +#endif // UNICODE +typedef const DIDEVICEINSTANCE_DX3A *LPCDIDEVICEINSTANCE_DX3A; +typedef const DIDEVICEINSTANCE_DX3W *LPCDIDEVICEINSTANCE_DX3W; +typedef const DIDEVICEINSTANCE_DX3 *LPCDIDEVICEINSTANCE_DX3; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +typedef struct DIDEVICEINSTANCEA { + DWORD dwSize; + GUID guidInstance; + GUID guidProduct; + DWORD dwDevType; + CHAR tszInstanceName[MAX_PATH]; + CHAR tszProductName[MAX_PATH]; +#if(DIRECTINPUT_VERSION >= 0x0500) + GUID guidFFDriver; + WORD wUsagePage; + WORD wUsage; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +} DIDEVICEINSTANCEA, *LPDIDEVICEINSTANCEA; +typedef struct DIDEVICEINSTANCEW { + DWORD dwSize; + GUID guidInstance; + GUID guidProduct; + DWORD dwDevType; + WCHAR tszInstanceName[MAX_PATH]; + WCHAR tszProductName[MAX_PATH]; +#if(DIRECTINPUT_VERSION >= 0x0500) + GUID guidFFDriver; + WORD wUsagePage; + WORD wUsage; +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +} DIDEVICEINSTANCEW, *LPDIDEVICEINSTANCEW; +#ifdef UNICODE +typedef DIDEVICEINSTANCEW DIDEVICEINSTANCE; +typedef LPDIDEVICEINSTANCEW LPDIDEVICEINSTANCE; +#else +typedef DIDEVICEINSTANCEA DIDEVICEINSTANCE; +typedef LPDIDEVICEINSTANCEA LPDIDEVICEINSTANCE; +#endif // UNICODE + +typedef const DIDEVICEINSTANCEA *LPCDIDEVICEINSTANCEA; +typedef const DIDEVICEINSTANCEW *LPCDIDEVICEINSTANCEW; +#ifdef UNICODE +typedef DIDEVICEINSTANCEW DIDEVICEINSTANCE; +typedef LPCDIDEVICEINSTANCEW LPCDIDEVICEINSTANCE; +#else +typedef DIDEVICEINSTANCEA DIDEVICEINSTANCE; +typedef LPCDIDEVICEINSTANCEA LPCDIDEVICEINSTANCE; +#endif // UNICODE +typedef const DIDEVICEINSTANCE *LPCDIDEVICEINSTANCE; + +#undef INTERFACE +#define INTERFACE IDirectInputDeviceW + +DECLARE_INTERFACE_(IDirectInputDeviceW, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDeviceW methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEW,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEW) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; +}; + +typedef struct IDirectInputDeviceW *LPDIRECTINPUTDEVICEW; + +#undef INTERFACE +#define INTERFACE IDirectInputDeviceA + +DECLARE_INTERFACE_(IDirectInputDeviceA, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDeviceA methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEA,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEA) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; +}; + +typedef struct IDirectInputDeviceA *LPDIRECTINPUTDEVICEA; + +#ifdef UNICODE +#define IID_IDirectInputDevice IID_IDirectInputDeviceW +#define IDirectInputDevice IDirectInputDeviceW +#define IDirectInputDeviceVtbl IDirectInputDeviceWVtbl +#else +#define IID_IDirectInputDevice IID_IDirectInputDeviceA +#define IDirectInputDevice IDirectInputDeviceA +#define IDirectInputDeviceVtbl IDirectInputDeviceAVtbl +#endif +typedef struct IDirectInputDevice *LPDIRECTINPUTDEVICE; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInputDevice_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInputDevice_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInputDevice_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInputDevice_GetCapabilities(p,a) (p)->lpVtbl->GetCapabilities(p,a) +#define IDirectInputDevice_EnumObjects(p,a,b,c) (p)->lpVtbl->EnumObjects(p,a,b,c) +#define IDirectInputDevice_GetProperty(p,a,b) (p)->lpVtbl->GetProperty(p,a,b) +#define IDirectInputDevice_SetProperty(p,a,b) (p)->lpVtbl->SetProperty(p,a,b) +#define IDirectInputDevice_Acquire(p) (p)->lpVtbl->Acquire(p) +#define IDirectInputDevice_Unacquire(p) (p)->lpVtbl->Unacquire(p) +#define IDirectInputDevice_GetDeviceState(p,a,b) (p)->lpVtbl->GetDeviceState(p,a,b) +#define IDirectInputDevice_GetDeviceData(p,a,b,c,d) (p)->lpVtbl->GetDeviceData(p,a,b,c,d) +#define IDirectInputDevice_SetDataFormat(p,a) (p)->lpVtbl->SetDataFormat(p,a) +#define IDirectInputDevice_SetEventNotification(p,a) (p)->lpVtbl->SetEventNotification(p,a) +#define IDirectInputDevice_SetCooperativeLevel(p,a,b) (p)->lpVtbl->SetCooperativeLevel(p,a,b) +#define IDirectInputDevice_GetObjectInfo(p,a,b,c) (p)->lpVtbl->GetObjectInfo(p,a,b,c) +#define IDirectInputDevice_GetDeviceInfo(p,a) (p)->lpVtbl->GetDeviceInfo(p,a) +#define IDirectInputDevice_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInputDevice_Initialize(p,a,b,c) (p)->lpVtbl->Initialize(p,a,b,c) +#else +#define IDirectInputDevice_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInputDevice_AddRef(p) (p)->AddRef() +#define IDirectInputDevice_Release(p) (p)->Release() +#define IDirectInputDevice_GetCapabilities(p,a) (p)->GetCapabilities(a) +#define IDirectInputDevice_EnumObjects(p,a,b,c) (p)->EnumObjects(a,b,c) +#define IDirectInputDevice_GetProperty(p,a,b) (p)->GetProperty(a,b) +#define IDirectInputDevice_SetProperty(p,a,b) (p)->SetProperty(a,b) +#define IDirectInputDevice_Acquire(p) (p)->Acquire() +#define IDirectInputDevice_Unacquire(p) (p)->Unacquire() +#define IDirectInputDevice_GetDeviceState(p,a,b) (p)->GetDeviceState(a,b) +#define IDirectInputDevice_GetDeviceData(p,a,b,c,d) (p)->GetDeviceData(a,b,c,d) +#define IDirectInputDevice_SetDataFormat(p,a) (p)->SetDataFormat(a) +#define IDirectInputDevice_SetEventNotification(p,a) (p)->SetEventNotification(a) +#define IDirectInputDevice_SetCooperativeLevel(p,a,b) (p)->SetCooperativeLevel(a,b) +#define IDirectInputDevice_GetObjectInfo(p,a,b,c) (p)->GetObjectInfo(a,b,c) +#define IDirectInputDevice_GetDeviceInfo(p,a) (p)->GetDeviceInfo(a) +#define IDirectInputDevice_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInputDevice_Initialize(p,a,b,c) (p)->Initialize(a,b,c) +#endif + +#endif /* DIJ_RINGZERO */ + + +#if(DIRECTINPUT_VERSION >= 0x0500) + +#define DISFFC_RESET 0x00000001 +#define DISFFC_STOPALL 0x00000002 +#define DISFFC_PAUSE 0x00000004 +#define DISFFC_CONTINUE 0x00000008 +#define DISFFC_SETACTUATORSON 0x00000010 +#define DISFFC_SETACTUATORSOFF 0x00000020 + +#define DIGFFS_EMPTY 0x00000001 +#define DIGFFS_STOPPED 0x00000002 +#define DIGFFS_PAUSED 0x00000004 +#define DIGFFS_ACTUATORSON 0x00000010 +#define DIGFFS_ACTUATORSOFF 0x00000020 +#define DIGFFS_POWERON 0x00000040 +#define DIGFFS_POWEROFF 0x00000080 +#define DIGFFS_SAFETYSWITCHON 0x00000100 +#define DIGFFS_SAFETYSWITCHOFF 0x00000200 +#define DIGFFS_USERFFSWITCHON 0x00000400 +#define DIGFFS_USERFFSWITCHOFF 0x00000800 +#define DIGFFS_DEVICELOST 0x80000000 + +#ifndef DIJ_RINGZERO + +typedef struct DIEFFECTINFOA { + DWORD dwSize; + GUID guid; + DWORD dwEffType; + DWORD dwStaticParams; + DWORD dwDynamicParams; + CHAR tszName[MAX_PATH]; +} DIEFFECTINFOA, *LPDIEFFECTINFOA; +typedef struct DIEFFECTINFOW { + DWORD dwSize; + GUID guid; + DWORD dwEffType; + DWORD dwStaticParams; + DWORD dwDynamicParams; + WCHAR tszName[MAX_PATH]; +} DIEFFECTINFOW, *LPDIEFFECTINFOW; +#ifdef UNICODE +typedef DIEFFECTINFOW DIEFFECTINFO; +typedef LPDIEFFECTINFOW LPDIEFFECTINFO; +#else +typedef DIEFFECTINFOA DIEFFECTINFO; +typedef LPDIEFFECTINFOA LPDIEFFECTINFO; +#endif // UNICODE +typedef const DIEFFECTINFOA *LPCDIEFFECTINFOA; +typedef const DIEFFECTINFOW *LPCDIEFFECTINFOW; +typedef const DIEFFECTINFO *LPCDIEFFECTINFO; + +#define DISDD_CONTINUE 0x00000001 + +typedef BOOL (FAR PASCAL * LPDIENUMEFFECTSCALLBACKA)(LPCDIEFFECTINFOA, LPVOID); +typedef BOOL (FAR PASCAL * LPDIENUMEFFECTSCALLBACKW)(LPCDIEFFECTINFOW, LPVOID); +#ifdef UNICODE +#define LPDIENUMEFFECTSCALLBACK LPDIENUMEFFECTSCALLBACKW +#else +#define LPDIENUMEFFECTSCALLBACK LPDIENUMEFFECTSCALLBACKA +#endif // !UNICODE +typedef BOOL (FAR PASCAL * LPDIENUMCREATEDEFFECTOBJECTSCALLBACK)(LPDIRECTINPUTEFFECT, LPVOID); + +#undef INTERFACE +#define INTERFACE IDirectInputDevice2W + +DECLARE_INTERFACE_(IDirectInputDevice2W, IDirectInputDeviceW) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDeviceW methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEW,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEW) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + + /*** IDirectInputDevice2W methods ***/ + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOW,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; +}; + +typedef struct IDirectInputDevice2W *LPDIRECTINPUTDEVICE2W; + +#undef INTERFACE +#define INTERFACE IDirectInputDevice2A + +DECLARE_INTERFACE_(IDirectInputDevice2A, IDirectInputDeviceA) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDeviceA methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEA,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEA) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + + /*** IDirectInputDevice2A methods ***/ + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOA,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; +}; + +typedef struct IDirectInputDevice2A *LPDIRECTINPUTDEVICE2A; + +#ifdef UNICODE +#define IID_IDirectInputDevice2 IID_IDirectInputDevice2W +#define IDirectInputDevice2 IDirectInputDevice2W +#define IDirectInputDevice2Vtbl IDirectInputDevice2WVtbl +#else +#define IID_IDirectInputDevice2 IID_IDirectInputDevice2A +#define IDirectInputDevice2 IDirectInputDevice2A +#define IDirectInputDevice2Vtbl IDirectInputDevice2AVtbl +#endif +typedef struct IDirectInputDevice2 *LPDIRECTINPUTDEVICE2; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInputDevice2_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInputDevice2_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInputDevice2_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInputDevice2_GetCapabilities(p,a) (p)->lpVtbl->GetCapabilities(p,a) +#define IDirectInputDevice2_EnumObjects(p,a,b,c) (p)->lpVtbl->EnumObjects(p,a,b,c) +#define IDirectInputDevice2_GetProperty(p,a,b) (p)->lpVtbl->GetProperty(p,a,b) +#define IDirectInputDevice2_SetProperty(p,a,b) (p)->lpVtbl->SetProperty(p,a,b) +#define IDirectInputDevice2_Acquire(p) (p)->lpVtbl->Acquire(p) +#define IDirectInputDevice2_Unacquire(p) (p)->lpVtbl->Unacquire(p) +#define IDirectInputDevice2_GetDeviceState(p,a,b) (p)->lpVtbl->GetDeviceState(p,a,b) +#define IDirectInputDevice2_GetDeviceData(p,a,b,c,d) (p)->lpVtbl->GetDeviceData(p,a,b,c,d) +#define IDirectInputDevice2_SetDataFormat(p,a) (p)->lpVtbl->SetDataFormat(p,a) +#define IDirectInputDevice2_SetEventNotification(p,a) (p)->lpVtbl->SetEventNotification(p,a) +#define IDirectInputDevice2_SetCooperativeLevel(p,a,b) (p)->lpVtbl->SetCooperativeLevel(p,a,b) +#define IDirectInputDevice2_GetObjectInfo(p,a,b,c) (p)->lpVtbl->GetObjectInfo(p,a,b,c) +#define IDirectInputDevice2_GetDeviceInfo(p,a) (p)->lpVtbl->GetDeviceInfo(p,a) +#define IDirectInputDevice2_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInputDevice2_Initialize(p,a,b,c) (p)->lpVtbl->Initialize(p,a,b,c) +#define IDirectInputDevice2_CreateEffect(p,a,b,c,d) (p)->lpVtbl->CreateEffect(p,a,b,c,d) +#define IDirectInputDevice2_EnumEffects(p,a,b,c) (p)->lpVtbl->EnumEffects(p,a,b,c) +#define IDirectInputDevice2_GetEffectInfo(p,a,b) (p)->lpVtbl->GetEffectInfo(p,a,b) +#define IDirectInputDevice2_GetForceFeedbackState(p,a) (p)->lpVtbl->GetForceFeedbackState(p,a) +#define IDirectInputDevice2_SendForceFeedbackCommand(p,a) (p)->lpVtbl->SendForceFeedbackCommand(p,a) +#define IDirectInputDevice2_EnumCreatedEffectObjects(p,a,b,c) (p)->lpVtbl->EnumCreatedEffectObjects(p,a,b,c) +#define IDirectInputDevice2_Escape(p,a) (p)->lpVtbl->Escape(p,a) +#define IDirectInputDevice2_Poll(p) (p)->lpVtbl->Poll(p) +#define IDirectInputDevice2_SendDeviceData(p,a,b,c,d) (p)->lpVtbl->SendDeviceData(p,a,b,c,d) +#else +#define IDirectInputDevice2_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInputDevice2_AddRef(p) (p)->AddRef() +#define IDirectInputDevice2_Release(p) (p)->Release() +#define IDirectInputDevice2_GetCapabilities(p,a) (p)->GetCapabilities(a) +#define IDirectInputDevice2_EnumObjects(p,a,b,c) (p)->EnumObjects(a,b,c) +#define IDirectInputDevice2_GetProperty(p,a,b) (p)->GetProperty(a,b) +#define IDirectInputDevice2_SetProperty(p,a,b) (p)->SetProperty(a,b) +#define IDirectInputDevice2_Acquire(p) (p)->Acquire() +#define IDirectInputDevice2_Unacquire(p) (p)->Unacquire() +#define IDirectInputDevice2_GetDeviceState(p,a,b) (p)->GetDeviceState(a,b) +#define IDirectInputDevice2_GetDeviceData(p,a,b,c,d) (p)->GetDeviceData(a,b,c,d) +#define IDirectInputDevice2_SetDataFormat(p,a) (p)->SetDataFormat(a) +#define IDirectInputDevice2_SetEventNotification(p,a) (p)->SetEventNotification(a) +#define IDirectInputDevice2_SetCooperativeLevel(p,a,b) (p)->SetCooperativeLevel(a,b) +#define IDirectInputDevice2_GetObjectInfo(p,a,b,c) (p)->GetObjectInfo(a,b,c) +#define IDirectInputDevice2_GetDeviceInfo(p,a) (p)->GetDeviceInfo(a) +#define IDirectInputDevice2_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInputDevice2_Initialize(p,a,b,c) (p)->Initialize(a,b,c) +#define IDirectInputDevice2_CreateEffect(p,a,b,c,d) (p)->CreateEffect(a,b,c,d) +#define IDirectInputDevice2_EnumEffects(p,a,b,c) (p)->EnumEffects(a,b,c) +#define IDirectInputDevice2_GetEffectInfo(p,a,b) (p)->GetEffectInfo(a,b) +#define IDirectInputDevice2_GetForceFeedbackState(p,a) (p)->GetForceFeedbackState(a) +#define IDirectInputDevice2_SendForceFeedbackCommand(p,a) (p)->SendForceFeedbackCommand(a) +#define IDirectInputDevice2_EnumCreatedEffectObjects(p,a,b,c) (p)->EnumCreatedEffectObjects(a,b,c) +#define IDirectInputDevice2_Escape(p,a) (p)->Escape(a) +#define IDirectInputDevice2_Poll(p) (p)->Poll() +#define IDirectInputDevice2_SendDeviceData(p,a,b,c,d) (p)->SendDeviceData(a,b,c,d) +#endif + +#endif /* DIJ_RINGZERO */ + +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ + +#if(DIRECTINPUT_VERSION >= 0x0700) +#define DIFEF_DEFAULT 0x00000000 +#define DIFEF_INCLUDENONSTANDARD 0x00000001 +#define DIFEF_MODIFYIFNEEDED 0x00000010 + +#ifndef DIJ_RINGZERO + +#undef INTERFACE +#define INTERFACE IDirectInputDevice7W + +DECLARE_INTERFACE_(IDirectInputDevice7W, IDirectInputDevice2W) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDevice2W methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEW,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEW) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOW,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + + /*** IDirectInputDevice7W methods ***/ + STDMETHOD(EnumEffectsInFile)(THIS_ LPCWSTR,LPDIENUMEFFECTSINFILECALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(WriteEffectToFile)(THIS_ LPCWSTR,DWORD,LPDIFILEEFFECT,DWORD) PURE; +}; + +typedef struct IDirectInputDevice7W *LPDIRECTINPUTDEVICE7W; + +#undef INTERFACE +#define INTERFACE IDirectInputDevice7A + +DECLARE_INTERFACE_(IDirectInputDevice7A, IDirectInputDevice2A) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDevice2A methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEA,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEA) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOA,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + + /*** IDirectInputDevice7A methods ***/ + STDMETHOD(EnumEffectsInFile)(THIS_ LPCSTR,LPDIENUMEFFECTSINFILECALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(WriteEffectToFile)(THIS_ LPCSTR,DWORD,LPDIFILEEFFECT,DWORD) PURE; +}; + +typedef struct IDirectInputDevice7A *LPDIRECTINPUTDEVICE7A; + +#ifdef UNICODE +#define IID_IDirectInputDevice7 IID_IDirectInputDevice7W +#define IDirectInputDevice7 IDirectInputDevice7W +#define IDirectInputDevice7Vtbl IDirectInputDevice7WVtbl +#else +#define IID_IDirectInputDevice7 IID_IDirectInputDevice7A +#define IDirectInputDevice7 IDirectInputDevice7A +#define IDirectInputDevice7Vtbl IDirectInputDevice7AVtbl +#endif +typedef struct IDirectInputDevice7 *LPDIRECTINPUTDEVICE7; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInputDevice7_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInputDevice7_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInputDevice7_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInputDevice7_GetCapabilities(p,a) (p)->lpVtbl->GetCapabilities(p,a) +#define IDirectInputDevice7_EnumObjects(p,a,b,c) (p)->lpVtbl->EnumObjects(p,a,b,c) +#define IDirectInputDevice7_GetProperty(p,a,b) (p)->lpVtbl->GetProperty(p,a,b) +#define IDirectInputDevice7_SetProperty(p,a,b) (p)->lpVtbl->SetProperty(p,a,b) +#define IDirectInputDevice7_Acquire(p) (p)->lpVtbl->Acquire(p) +#define IDirectInputDevice7_Unacquire(p) (p)->lpVtbl->Unacquire(p) +#define IDirectInputDevice7_GetDeviceState(p,a,b) (p)->lpVtbl->GetDeviceState(p,a,b) +#define IDirectInputDevice7_GetDeviceData(p,a,b,c,d) (p)->lpVtbl->GetDeviceData(p,a,b,c,d) +#define IDirectInputDevice7_SetDataFormat(p,a) (p)->lpVtbl->SetDataFormat(p,a) +#define IDirectInputDevice7_SetEventNotification(p,a) (p)->lpVtbl->SetEventNotification(p,a) +#define IDirectInputDevice7_SetCooperativeLevel(p,a,b) (p)->lpVtbl->SetCooperativeLevel(p,a,b) +#define IDirectInputDevice7_GetObjectInfo(p,a,b,c) (p)->lpVtbl->GetObjectInfo(p,a,b,c) +#define IDirectInputDevice7_GetDeviceInfo(p,a) (p)->lpVtbl->GetDeviceInfo(p,a) +#define IDirectInputDevice7_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInputDevice7_Initialize(p,a,b,c) (p)->lpVtbl->Initialize(p,a,b,c) +#define IDirectInputDevice7_CreateEffect(p,a,b,c,d) (p)->lpVtbl->CreateEffect(p,a,b,c,d) +#define IDirectInputDevice7_EnumEffects(p,a,b,c) (p)->lpVtbl->EnumEffects(p,a,b,c) +#define IDirectInputDevice7_GetEffectInfo(p,a,b) (p)->lpVtbl->GetEffectInfo(p,a,b) +#define IDirectInputDevice7_GetForceFeedbackState(p,a) (p)->lpVtbl->GetForceFeedbackState(p,a) +#define IDirectInputDevice7_SendForceFeedbackCommand(p,a) (p)->lpVtbl->SendForceFeedbackCommand(p,a) +#define IDirectInputDevice7_EnumCreatedEffectObjects(p,a,b,c) (p)->lpVtbl->EnumCreatedEffectObjects(p,a,b,c) +#define IDirectInputDevice7_Escape(p,a) (p)->lpVtbl->Escape(p,a) +#define IDirectInputDevice7_Poll(p) (p)->lpVtbl->Poll(p) +#define IDirectInputDevice7_SendDeviceData(p,a,b,c,d) (p)->lpVtbl->SendDeviceData(p,a,b,c,d) +#define IDirectInputDevice7_EnumEffectsInFile(p,a,b,c,d) (p)->lpVtbl->EnumEffectsInFile(p,a,b,c,d) +#define IDirectInputDevice7_WriteEffectToFile(p,a,b,c,d) (p)->lpVtbl->WriteEffectToFile(p,a,b,c,d) +#else +#define IDirectInputDevice7_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInputDevice7_AddRef(p) (p)->AddRef() +#define IDirectInputDevice7_Release(p) (p)->Release() +#define IDirectInputDevice7_GetCapabilities(p,a) (p)->GetCapabilities(a) +#define IDirectInputDevice7_EnumObjects(p,a,b,c) (p)->EnumObjects(a,b,c) +#define IDirectInputDevice7_GetProperty(p,a,b) (p)->GetProperty(a,b) +#define IDirectInputDevice7_SetProperty(p,a,b) (p)->SetProperty(a,b) +#define IDirectInputDevice7_Acquire(p) (p)->Acquire() +#define IDirectInputDevice7_Unacquire(p) (p)->Unacquire() +#define IDirectInputDevice7_GetDeviceState(p,a,b) (p)->GetDeviceState(a,b) +#define IDirectInputDevice7_GetDeviceData(p,a,b,c,d) (p)->GetDeviceData(a,b,c,d) +#define IDirectInputDevice7_SetDataFormat(p,a) (p)->SetDataFormat(a) +#define IDirectInputDevice7_SetEventNotification(p,a) (p)->SetEventNotification(a) +#define IDirectInputDevice7_SetCooperativeLevel(p,a,b) (p)->SetCooperativeLevel(a,b) +#define IDirectInputDevice7_GetObjectInfo(p,a,b,c) (p)->GetObjectInfo(a,b,c) +#define IDirectInputDevice7_GetDeviceInfo(p,a) (p)->GetDeviceInfo(a) +#define IDirectInputDevice7_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInputDevice7_Initialize(p,a,b,c) (p)->Initialize(a,b,c) +#define IDirectInputDevice7_CreateEffect(p,a,b,c,d) (p)->CreateEffect(a,b,c,d) +#define IDirectInputDevice7_EnumEffects(p,a,b,c) (p)->EnumEffects(a,b,c) +#define IDirectInputDevice7_GetEffectInfo(p,a,b) (p)->GetEffectInfo(a,b) +#define IDirectInputDevice7_GetForceFeedbackState(p,a) (p)->GetForceFeedbackState(a) +#define IDirectInputDevice7_SendForceFeedbackCommand(p,a) (p)->SendForceFeedbackCommand(a) +#define IDirectInputDevice7_EnumCreatedEffectObjects(p,a,b,c) (p)->EnumCreatedEffectObjects(a,b,c) +#define IDirectInputDevice7_Escape(p,a) (p)->Escape(a) +#define IDirectInputDevice7_Poll(p) (p)->Poll() +#define IDirectInputDevice7_SendDeviceData(p,a,b,c,d) (p)->SendDeviceData(a,b,c,d) +#define IDirectInputDevice7_EnumEffectsInFile(p,a,b,c,d) (p)->EnumEffectsInFile(a,b,c,d) +#define IDirectInputDevice7_WriteEffectToFile(p,a,b,c,d) (p)->WriteEffectToFile(a,b,c,d) +#endif + +#endif /* DIJ_RINGZERO */ + +#endif /* DIRECTINPUT_VERSION >= 0x0700 */ + +#if(DIRECTINPUT_VERSION >= 0x0800) + +#ifndef DIJ_RINGZERO + +#undef INTERFACE +#define INTERFACE IDirectInputDevice8W + +DECLARE_INTERFACE_(IDirectInputDevice8W, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDevice8W methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEW,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEW) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOW,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(EnumEffectsInFile)(THIS_ LPCWSTR,LPDIENUMEFFECTSINFILECALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(WriteEffectToFile)(THIS_ LPCWSTR,DWORD,LPDIFILEEFFECT,DWORD) PURE; + STDMETHOD(BuildActionMap)(THIS_ LPDIACTIONFORMATW,LPCWSTR,DWORD) PURE; + STDMETHOD(SetActionMap)(THIS_ LPDIACTIONFORMATW,LPCWSTR,DWORD) PURE; + STDMETHOD(GetImageInfo)(THIS_ LPDIDEVICEIMAGEINFOHEADERW) PURE; +}; + +typedef struct IDirectInputDevice8W *LPDIRECTINPUTDEVICE8W; + +#undef INTERFACE +#define INTERFACE IDirectInputDevice8A + +DECLARE_INTERFACE_(IDirectInputDevice8A, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputDevice8A methods ***/ + STDMETHOD(GetCapabilities)(THIS_ LPDIDEVCAPS) PURE; + STDMETHOD(EnumObjects)(THIS_ LPDIENUMDEVICEOBJECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetProperty)(THIS_ REFGUID,LPDIPROPHEADER) PURE; + STDMETHOD(SetProperty)(THIS_ REFGUID,LPCDIPROPHEADER) PURE; + STDMETHOD(Acquire)(THIS) PURE; + STDMETHOD(Unacquire)(THIS) PURE; + STDMETHOD(GetDeviceState)(THIS_ DWORD,LPVOID) PURE; + STDMETHOD(GetDeviceData)(THIS_ DWORD,LPDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(SetDataFormat)(THIS_ LPCDIDATAFORMAT) PURE; + STDMETHOD(SetEventNotification)(THIS_ HANDLE) PURE; + STDMETHOD(SetCooperativeLevel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(GetObjectInfo)(THIS_ LPDIDEVICEOBJECTINSTANCEA,DWORD,DWORD) PURE; + STDMETHOD(GetDeviceInfo)(THIS_ LPDIDEVICEINSTANCEA) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD,REFGUID) PURE; + STDMETHOD(CreateEffect)(THIS_ REFGUID,LPCDIEFFECT,LPDIRECTINPUTEFFECT *,LPUNKNOWN) PURE; + STDMETHOD(EnumEffects)(THIS_ LPDIENUMEFFECTSCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetEffectInfo)(THIS_ LPDIEFFECTINFOA,REFGUID) PURE; + STDMETHOD(GetForceFeedbackState)(THIS_ LPDWORD) PURE; + STDMETHOD(SendForceFeedbackCommand)(THIS_ DWORD) PURE; + STDMETHOD(EnumCreatedEffectObjects)(THIS_ LPDIENUMCREATEDEFFECTOBJECTSCALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(Escape)(THIS_ LPDIEFFESCAPE) PURE; + STDMETHOD(Poll)(THIS) PURE; + STDMETHOD(SendDeviceData)(THIS_ DWORD,LPCDIDEVICEOBJECTDATA,LPDWORD,DWORD) PURE; + STDMETHOD(EnumEffectsInFile)(THIS_ LPCSTR,LPDIENUMEFFECTSINFILECALLBACK,LPVOID,DWORD) PURE; + STDMETHOD(WriteEffectToFile)(THIS_ LPCSTR,DWORD,LPDIFILEEFFECT,DWORD) PURE; + STDMETHOD(BuildActionMap)(THIS_ LPDIACTIONFORMATA,LPCSTR,DWORD) PURE; + STDMETHOD(SetActionMap)(THIS_ LPDIACTIONFORMATA,LPCSTR,DWORD) PURE; + STDMETHOD(GetImageInfo)(THIS_ LPDIDEVICEIMAGEINFOHEADERA) PURE; +}; + +typedef struct IDirectInputDevice8A *LPDIRECTINPUTDEVICE8A; + +#ifdef UNICODE +#define IID_IDirectInputDevice8 IID_IDirectInputDevice8W +#define IDirectInputDevice8 IDirectInputDevice8W +#define IDirectInputDevice8Vtbl IDirectInputDevice8WVtbl +#else +#define IID_IDirectInputDevice8 IID_IDirectInputDevice8A +#define IDirectInputDevice8 IDirectInputDevice8A +#define IDirectInputDevice8Vtbl IDirectInputDevice8AVtbl +#endif +typedef struct IDirectInputDevice8 *LPDIRECTINPUTDEVICE8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInputDevice8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInputDevice8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInputDevice8_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInputDevice8_GetCapabilities(p,a) (p)->lpVtbl->GetCapabilities(p,a) +#define IDirectInputDevice8_EnumObjects(p,a,b,c) (p)->lpVtbl->EnumObjects(p,a,b,c) +#define IDirectInputDevice8_GetProperty(p,a,b) (p)->lpVtbl->GetProperty(p,a,b) +#define IDirectInputDevice8_SetProperty(p,a,b) (p)->lpVtbl->SetProperty(p,a,b) +#define IDirectInputDevice8_Acquire(p) (p)->lpVtbl->Acquire(p) +#define IDirectInputDevice8_Unacquire(p) (p)->lpVtbl->Unacquire(p) +#define IDirectInputDevice8_GetDeviceState(p,a,b) (p)->lpVtbl->GetDeviceState(p,a,b) +#define IDirectInputDevice8_GetDeviceData(p,a,b,c,d) (p)->lpVtbl->GetDeviceData(p,a,b,c,d) +#define IDirectInputDevice8_SetDataFormat(p,a) (p)->lpVtbl->SetDataFormat(p,a) +#define IDirectInputDevice8_SetEventNotification(p,a) (p)->lpVtbl->SetEventNotification(p,a) +#define IDirectInputDevice8_SetCooperativeLevel(p,a,b) (p)->lpVtbl->SetCooperativeLevel(p,a,b) +#define IDirectInputDevice8_GetObjectInfo(p,a,b,c) (p)->lpVtbl->GetObjectInfo(p,a,b,c) +#define IDirectInputDevice8_GetDeviceInfo(p,a) (p)->lpVtbl->GetDeviceInfo(p,a) +#define IDirectInputDevice8_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInputDevice8_Initialize(p,a,b,c) (p)->lpVtbl->Initialize(p,a,b,c) +#define IDirectInputDevice8_CreateEffect(p,a,b,c,d) (p)->lpVtbl->CreateEffect(p,a,b,c,d) +#define IDirectInputDevice8_EnumEffects(p,a,b,c) (p)->lpVtbl->EnumEffects(p,a,b,c) +#define IDirectInputDevice8_GetEffectInfo(p,a,b) (p)->lpVtbl->GetEffectInfo(p,a,b) +#define IDirectInputDevice8_GetForceFeedbackState(p,a) (p)->lpVtbl->GetForceFeedbackState(p,a) +#define IDirectInputDevice8_SendForceFeedbackCommand(p,a) (p)->lpVtbl->SendForceFeedbackCommand(p,a) +#define IDirectInputDevice8_EnumCreatedEffectObjects(p,a,b,c) (p)->lpVtbl->EnumCreatedEffectObjects(p,a,b,c) +#define IDirectInputDevice8_Escape(p,a) (p)->lpVtbl->Escape(p,a) +#define IDirectInputDevice8_Poll(p) (p)->lpVtbl->Poll(p) +#define IDirectInputDevice8_SendDeviceData(p,a,b,c,d) (p)->lpVtbl->SendDeviceData(p,a,b,c,d) +#define IDirectInputDevice8_EnumEffectsInFile(p,a,b,c,d) (p)->lpVtbl->EnumEffectsInFile(p,a,b,c,d) +#define IDirectInputDevice8_WriteEffectToFile(p,a,b,c,d) (p)->lpVtbl->WriteEffectToFile(p,a,b,c,d) +#define IDirectInputDevice8_BuildActionMap(p,a,b,c) (p)->lpVtbl->BuildActionMap(p,a,b,c) +#define IDirectInputDevice8_SetActionMap(p,a,b,c) (p)->lpVtbl->SetActionMap(p,a,b,c) +#define IDirectInputDevice8_GetImageInfo(p,a) (p)->lpVtbl->GetImageInfo(p,a) +#else +#define IDirectInputDevice8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInputDevice8_AddRef(p) (p)->AddRef() +#define IDirectInputDevice8_Release(p) (p)->Release() +#define IDirectInputDevice8_GetCapabilities(p,a) (p)->GetCapabilities(a) +#define IDirectInputDevice8_EnumObjects(p,a,b,c) (p)->EnumObjects(a,b,c) +#define IDirectInputDevice8_GetProperty(p,a,b) (p)->GetProperty(a,b) +#define IDirectInputDevice8_SetProperty(p,a,b) (p)->SetProperty(a,b) +#define IDirectInputDevice8_Acquire(p) (p)->Acquire() +#define IDirectInputDevice8_Unacquire(p) (p)->Unacquire() +#define IDirectInputDevice8_GetDeviceState(p,a,b) (p)->GetDeviceState(a,b) +#define IDirectInputDevice8_GetDeviceData(p,a,b,c,d) (p)->GetDeviceData(a,b,c,d) +#define IDirectInputDevice8_SetDataFormat(p,a) (p)->SetDataFormat(a) +#define IDirectInputDevice8_SetEventNotification(p,a) (p)->SetEventNotification(a) +#define IDirectInputDevice8_SetCooperativeLevel(p,a,b) (p)->SetCooperativeLevel(a,b) +#define IDirectInputDevice8_GetObjectInfo(p,a,b,c) (p)->GetObjectInfo(a,b,c) +#define IDirectInputDevice8_GetDeviceInfo(p,a) (p)->GetDeviceInfo(a) +#define IDirectInputDevice8_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInputDevice8_Initialize(p,a,b,c) (p)->Initialize(a,b,c) +#define IDirectInputDevice8_CreateEffect(p,a,b,c,d) (p)->CreateEffect(a,b,c,d) +#define IDirectInputDevice8_EnumEffects(p,a,b,c) (p)->EnumEffects(a,b,c) +#define IDirectInputDevice8_GetEffectInfo(p,a,b) (p)->GetEffectInfo(a,b) +#define IDirectInputDevice8_GetForceFeedbackState(p,a) (p)->GetForceFeedbackState(a) +#define IDirectInputDevice8_SendForceFeedbackCommand(p,a) (p)->SendForceFeedbackCommand(a) +#define IDirectInputDevice8_EnumCreatedEffectObjects(p,a,b,c) (p)->EnumCreatedEffectObjects(a,b,c) +#define IDirectInputDevice8_Escape(p,a) (p)->Escape(a) +#define IDirectInputDevice8_Poll(p) (p)->Poll() +#define IDirectInputDevice8_SendDeviceData(p,a,b,c,d) (p)->SendDeviceData(a,b,c,d) +#define IDirectInputDevice8_EnumEffectsInFile(p,a,b,c,d) (p)->EnumEffectsInFile(a,b,c,d) +#define IDirectInputDevice8_WriteEffectToFile(p,a,b,c,d) (p)->WriteEffectToFile(a,b,c,d) +#define IDirectInputDevice8_BuildActionMap(p,a,b,c) (p)->BuildActionMap(a,b,c) +#define IDirectInputDevice8_SetActionMap(p,a,b,c) (p)->SetActionMap(a,b,c) +#define IDirectInputDevice8_GetImageInfo(p,a) (p)->GetImageInfo(a) +#endif + +#endif /* DIJ_RINGZERO */ + +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +/**************************************************************************** + * + * Mouse + * + ****************************************************************************/ + +#ifndef DIJ_RINGZERO + +typedef struct _DIMOUSESTATE { + LONG lX; + LONG lY; + LONG lZ; + BYTE rgbButtons[4]; +} DIMOUSESTATE, *LPDIMOUSESTATE; + +#if DIRECTINPUT_VERSION >= 0x0700 +typedef struct _DIMOUSESTATE2 { + LONG lX; + LONG lY; + LONG lZ; + BYTE rgbButtons[8]; +} DIMOUSESTATE2, *LPDIMOUSESTATE2; +#endif + + +#define DIMOFS_X FIELD_OFFSET(DIMOUSESTATE, lX) +#define DIMOFS_Y FIELD_OFFSET(DIMOUSESTATE, lY) +#define DIMOFS_Z FIELD_OFFSET(DIMOUSESTATE, lZ) +#define DIMOFS_BUTTON0 (FIELD_OFFSET(DIMOUSESTATE, rgbButtons) + 0) +#define DIMOFS_BUTTON1 (FIELD_OFFSET(DIMOUSESTATE, rgbButtons) + 1) +#define DIMOFS_BUTTON2 (FIELD_OFFSET(DIMOUSESTATE, rgbButtons) + 2) +#define DIMOFS_BUTTON3 (FIELD_OFFSET(DIMOUSESTATE, rgbButtons) + 3) +#if (DIRECTINPUT_VERSION >= 0x0700) +#define DIMOFS_BUTTON4 (FIELD_OFFSET(DIMOUSESTATE2, rgbButtons) + 4) +#define DIMOFS_BUTTON5 (FIELD_OFFSET(DIMOUSESTATE2, rgbButtons) + 5) +#define DIMOFS_BUTTON6 (FIELD_OFFSET(DIMOUSESTATE2, rgbButtons) + 6) +#define DIMOFS_BUTTON7 (FIELD_OFFSET(DIMOUSESTATE2, rgbButtons) + 7) +#endif +#endif /* DIJ_RINGZERO */ + +/**************************************************************************** + * + * Keyboard + * + ****************************************************************************/ + +#ifndef DIJ_RINGZERO + +/**************************************************************************** + * + * DirectInput keyboard scan codes + * + ****************************************************************************/ +#define DIK_ESCAPE 0x01 +#define DIK_1 0x02 +#define DIK_2 0x03 +#define DIK_3 0x04 +#define DIK_4 0x05 +#define DIK_5 0x06 +#define DIK_6 0x07 +#define DIK_7 0x08 +#define DIK_8 0x09 +#define DIK_9 0x0A +#define DIK_0 0x0B +#define DIK_MINUS 0x0C /* - on main keyboard */ +#define DIK_EQUALS 0x0D +#define DIK_BACK 0x0E /* backspace */ +#define DIK_TAB 0x0F +#define DIK_Q 0x10 +#define DIK_W 0x11 +#define DIK_E 0x12 +#define DIK_R 0x13 +#define DIK_T 0x14 +#define DIK_Y 0x15 +#define DIK_U 0x16 +#define DIK_I 0x17 +#define DIK_O 0x18 +#define DIK_P 0x19 +#define DIK_LBRACKET 0x1A +#define DIK_RBRACKET 0x1B +#define DIK_RETURN 0x1C /* Enter on main keyboard */ +#define DIK_LCONTROL 0x1D +#define DIK_A 0x1E +#define DIK_S 0x1F +#define DIK_D 0x20 +#define DIK_F 0x21 +#define DIK_G 0x22 +#define DIK_H 0x23 +#define DIK_J 0x24 +#define DIK_K 0x25 +#define DIK_L 0x26 +#define DIK_SEMICOLON 0x27 +#define DIK_APOSTROPHE 0x28 +#define DIK_GRAVE 0x29 /* accent grave */ +#define DIK_LSHIFT 0x2A +#define DIK_BACKSLASH 0x2B +#define DIK_Z 0x2C +#define DIK_X 0x2D +#define DIK_C 0x2E +#define DIK_V 0x2F +#define DIK_B 0x30 +#define DIK_N 0x31 +#define DIK_M 0x32 +#define DIK_COMMA 0x33 +#define DIK_PERIOD 0x34 /* . on main keyboard */ +#define DIK_SLASH 0x35 /* / on main keyboard */ +#define DIK_RSHIFT 0x36 +#define DIK_MULTIPLY 0x37 /* * on numeric keypad */ +#define DIK_LMENU 0x38 /* left Alt */ +#define DIK_SPACE 0x39 +#define DIK_CAPITAL 0x3A +#define DIK_F1 0x3B +#define DIK_F2 0x3C +#define DIK_F3 0x3D +#define DIK_F4 0x3E +#define DIK_F5 0x3F +#define DIK_F6 0x40 +#define DIK_F7 0x41 +#define DIK_F8 0x42 +#define DIK_F9 0x43 +#define DIK_F10 0x44 +#define DIK_NUMLOCK 0x45 +#define DIK_SCROLL 0x46 /* Scroll Lock */ +#define DIK_NUMPAD7 0x47 +#define DIK_NUMPAD8 0x48 +#define DIK_NUMPAD9 0x49 +#define DIK_SUBTRACT 0x4A /* - on numeric keypad */ +#define DIK_NUMPAD4 0x4B +#define DIK_NUMPAD5 0x4C +#define DIK_NUMPAD6 0x4D +#define DIK_ADD 0x4E /* + on numeric keypad */ +#define DIK_NUMPAD1 0x4F +#define DIK_NUMPAD2 0x50 +#define DIK_NUMPAD3 0x51 +#define DIK_NUMPAD0 0x52 +#define DIK_DECIMAL 0x53 /* . on numeric keypad */ +#define DIK_OEM_102 0x56 /* <> or \| on RT 102-key keyboard (Non-U.S.) */ +#define DIK_F11 0x57 +#define DIK_F12 0x58 +#define DIK_F13 0x64 /* (NEC PC98) */ +#define DIK_F14 0x65 /* (NEC PC98) */ +#define DIK_F15 0x66 /* (NEC PC98) */ +#define DIK_KANA 0x70 /* (Japanese keyboard) */ +#define DIK_ABNT_C1 0x73 /* /? on Brazilian keyboard */ +#define DIK_CONVERT 0x79 /* (Japanese keyboard) */ +#define DIK_NOCONVERT 0x7B /* (Japanese keyboard) */ +#define DIK_YEN 0x7D /* (Japanese keyboard) */ +#define DIK_ABNT_C2 0x7E /* Numpad . on Brazilian keyboard */ +#define DIK_NUMPADEQUALS 0x8D /* = on numeric keypad (NEC PC98) */ +#define DIK_PREVTRACK 0x90 /* Previous Track (DIK_CIRCUMFLEX on Japanese keyboard) */ +#define DIK_AT 0x91 /* (NEC PC98) */ +#define DIK_COLON 0x92 /* (NEC PC98) */ +#define DIK_UNDERLINE 0x93 /* (NEC PC98) */ +#define DIK_KANJI 0x94 /* (Japanese keyboard) */ +#define DIK_STOP 0x95 /* (NEC PC98) */ +#define DIK_AX 0x96 /* (Japan AX) */ +#define DIK_UNLABELED 0x97 /* (J3100) */ +#define DIK_NEXTTRACK 0x99 /* Next Track */ +#define DIK_NUMPADENTER 0x9C /* Enter on numeric keypad */ +#define DIK_RCONTROL 0x9D +#define DIK_MUTE 0xA0 /* Mute */ +#define DIK_CALCULATOR 0xA1 /* Calculator */ +#define DIK_PLAYPAUSE 0xA2 /* Play / Pause */ +#define DIK_MEDIASTOP 0xA4 /* Media Stop */ +#define DIK_VOLUMEDOWN 0xAE /* Volume - */ +#define DIK_VOLUMEUP 0xB0 /* Volume + */ +#define DIK_WEBHOME 0xB2 /* Web home */ +#define DIK_NUMPADCOMMA 0xB3 /* , on numeric keypad (NEC PC98) */ +#define DIK_DIVIDE 0xB5 /* / on numeric keypad */ +#define DIK_SYSRQ 0xB7 +#define DIK_RMENU 0xB8 /* right Alt */ +#define DIK_PAUSE 0xC5 /* Pause */ +#define DIK_HOME 0xC7 /* Home on arrow keypad */ +#define DIK_UP 0xC8 /* UpArrow on arrow keypad */ +#define DIK_PRIOR 0xC9 /* PgUp on arrow keypad */ +#define DIK_LEFT 0xCB /* LeftArrow on arrow keypad */ +#define DIK_RIGHT 0xCD /* RightArrow on arrow keypad */ +#define DIK_END 0xCF /* End on arrow keypad */ +#define DIK_DOWN 0xD0 /* DownArrow on arrow keypad */ +#define DIK_NEXT 0xD1 /* PgDn on arrow keypad */ +#define DIK_INSERT 0xD2 /* Insert on arrow keypad */ +#define DIK_DELETE 0xD3 /* Delete on arrow keypad */ +#define DIK_LWIN 0xDB /* Left Windows key */ +#define DIK_RWIN 0xDC /* Right Windows key */ +#define DIK_APPS 0xDD /* AppMenu key */ +#define DIK_POWER 0xDE /* System Power */ +#define DIK_SLEEP 0xDF /* System Sleep */ +#define DIK_WAKE 0xE3 /* System Wake */ +#define DIK_WEBSEARCH 0xE5 /* Web Search */ +#define DIK_WEBFAVORITES 0xE6 /* Web Favorites */ +#define DIK_WEBREFRESH 0xE7 /* Web Refresh */ +#define DIK_WEBSTOP 0xE8 /* Web Stop */ +#define DIK_WEBFORWARD 0xE9 /* Web Forward */ +#define DIK_WEBBACK 0xEA /* Web Back */ +#define DIK_MYCOMPUTER 0xEB /* My Computer */ +#define DIK_MAIL 0xEC /* Mail */ +#define DIK_MEDIASELECT 0xED /* Media Select */ + +/* + * Alternate names for keys, to facilitate transition from DOS. + */ +#define DIK_BACKSPACE DIK_BACK /* backspace */ +#define DIK_NUMPADSTAR DIK_MULTIPLY /* * on numeric keypad */ +#define DIK_LALT DIK_LMENU /* left Alt */ +#define DIK_CAPSLOCK DIK_CAPITAL /* CapsLock */ +#define DIK_NUMPADMINUS DIK_SUBTRACT /* - on numeric keypad */ +#define DIK_NUMPADPLUS DIK_ADD /* + on numeric keypad */ +#define DIK_NUMPADPERIOD DIK_DECIMAL /* . on numeric keypad */ +#define DIK_NUMPADSLASH DIK_DIVIDE /* / on numeric keypad */ +#define DIK_RALT DIK_RMENU /* right Alt */ +#define DIK_UPARROW DIK_UP /* UpArrow on arrow keypad */ +#define DIK_PGUP DIK_PRIOR /* PgUp on arrow keypad */ +#define DIK_LEFTARROW DIK_LEFT /* LeftArrow on arrow keypad */ +#define DIK_RIGHTARROW DIK_RIGHT /* RightArrow on arrow keypad */ +#define DIK_DOWNARROW DIK_DOWN /* DownArrow on arrow keypad */ +#define DIK_PGDN DIK_NEXT /* PgDn on arrow keypad */ + +/* + * Alternate names for keys originally not used on US keyboards. + */ +#define DIK_CIRCUMFLEX DIK_PREVTRACK /* Japanese keyboard */ + +#endif /* DIJ_RINGZERO */ + +/**************************************************************************** + * + * Joystick + * + ****************************************************************************/ + +#ifndef DIJ_RINGZERO + +typedef struct DIJOYSTATE { + LONG lX; /* x-axis position */ + LONG lY; /* y-axis position */ + LONG lZ; /* z-axis position */ + LONG lRx; /* x-axis rotation */ + LONG lRy; /* y-axis rotation */ + LONG lRz; /* z-axis rotation */ + LONG rglSlider[2]; /* extra axes positions */ + DWORD rgdwPOV[4]; /* POV directions */ + BYTE rgbButtons[32]; /* 32 buttons */ +} DIJOYSTATE, *LPDIJOYSTATE; + +typedef struct DIJOYSTATE2 { + LONG lX; /* x-axis position */ + LONG lY; /* y-axis position */ + LONG lZ; /* z-axis position */ + LONG lRx; /* x-axis rotation */ + LONG lRy; /* y-axis rotation */ + LONG lRz; /* z-axis rotation */ + LONG rglSlider[2]; /* extra axes positions */ + DWORD rgdwPOV[4]; /* POV directions */ + BYTE rgbButtons[128]; /* 128 buttons */ + LONG lVX; /* x-axis velocity */ + LONG lVY; /* y-axis velocity */ + LONG lVZ; /* z-axis velocity */ + LONG lVRx; /* x-axis angular velocity */ + LONG lVRy; /* y-axis angular velocity */ + LONG lVRz; /* z-axis angular velocity */ + LONG rglVSlider[2]; /* extra axes velocities */ + LONG lAX; /* x-axis acceleration */ + LONG lAY; /* y-axis acceleration */ + LONG lAZ; /* z-axis acceleration */ + LONG lARx; /* x-axis angular acceleration */ + LONG lARy; /* y-axis angular acceleration */ + LONG lARz; /* z-axis angular acceleration */ + LONG rglASlider[2]; /* extra axes accelerations */ + LONG lFX; /* x-axis force */ + LONG lFY; /* y-axis force */ + LONG lFZ; /* z-axis force */ + LONG lFRx; /* x-axis torque */ + LONG lFRy; /* y-axis torque */ + LONG lFRz; /* z-axis torque */ + LONG rglFSlider[2]; /* extra axes forces */ +} DIJOYSTATE2, *LPDIJOYSTATE2; + +#define DIJOFS_X FIELD_OFFSET(DIJOYSTATE, lX) +#define DIJOFS_Y FIELD_OFFSET(DIJOYSTATE, lY) +#define DIJOFS_Z FIELD_OFFSET(DIJOYSTATE, lZ) +#define DIJOFS_RX FIELD_OFFSET(DIJOYSTATE, lRx) +#define DIJOFS_RY FIELD_OFFSET(DIJOYSTATE, lRy) +#define DIJOFS_RZ FIELD_OFFSET(DIJOYSTATE, lRz) +#define DIJOFS_SLIDER(n) (FIELD_OFFSET(DIJOYSTATE, rglSlider) + \ + (n) * sizeof(LONG)) +#define DIJOFS_POV(n) (FIELD_OFFSET(DIJOYSTATE, rgdwPOV) + \ + (n) * sizeof(DWORD)) +#define DIJOFS_BUTTON(n) (FIELD_OFFSET(DIJOYSTATE, rgbButtons) + (n)) +#define DIJOFS_BUTTON0 DIJOFS_BUTTON(0) +#define DIJOFS_BUTTON1 DIJOFS_BUTTON(1) +#define DIJOFS_BUTTON2 DIJOFS_BUTTON(2) +#define DIJOFS_BUTTON3 DIJOFS_BUTTON(3) +#define DIJOFS_BUTTON4 DIJOFS_BUTTON(4) +#define DIJOFS_BUTTON5 DIJOFS_BUTTON(5) +#define DIJOFS_BUTTON6 DIJOFS_BUTTON(6) +#define DIJOFS_BUTTON7 DIJOFS_BUTTON(7) +#define DIJOFS_BUTTON8 DIJOFS_BUTTON(8) +#define DIJOFS_BUTTON9 DIJOFS_BUTTON(9) +#define DIJOFS_BUTTON10 DIJOFS_BUTTON(10) +#define DIJOFS_BUTTON11 DIJOFS_BUTTON(11) +#define DIJOFS_BUTTON12 DIJOFS_BUTTON(12) +#define DIJOFS_BUTTON13 DIJOFS_BUTTON(13) +#define DIJOFS_BUTTON14 DIJOFS_BUTTON(14) +#define DIJOFS_BUTTON15 DIJOFS_BUTTON(15) +#define DIJOFS_BUTTON16 DIJOFS_BUTTON(16) +#define DIJOFS_BUTTON17 DIJOFS_BUTTON(17) +#define DIJOFS_BUTTON18 DIJOFS_BUTTON(18) +#define DIJOFS_BUTTON19 DIJOFS_BUTTON(19) +#define DIJOFS_BUTTON20 DIJOFS_BUTTON(20) +#define DIJOFS_BUTTON21 DIJOFS_BUTTON(21) +#define DIJOFS_BUTTON22 DIJOFS_BUTTON(22) +#define DIJOFS_BUTTON23 DIJOFS_BUTTON(23) +#define DIJOFS_BUTTON24 DIJOFS_BUTTON(24) +#define DIJOFS_BUTTON25 DIJOFS_BUTTON(25) +#define DIJOFS_BUTTON26 DIJOFS_BUTTON(26) +#define DIJOFS_BUTTON27 DIJOFS_BUTTON(27) +#define DIJOFS_BUTTON28 DIJOFS_BUTTON(28) +#define DIJOFS_BUTTON29 DIJOFS_BUTTON(29) +#define DIJOFS_BUTTON30 DIJOFS_BUTTON(30) +#define DIJOFS_BUTTON31 DIJOFS_BUTTON(31) + + +#endif /* DIJ_RINGZERO */ + +/**************************************************************************** + * + * IDirectInput + * + ****************************************************************************/ + +#ifndef DIJ_RINGZERO + +#define DIENUM_STOP 0 +#define DIENUM_CONTINUE 1 + +typedef BOOL (FAR PASCAL * LPDIENUMDEVICESCALLBACKA)(LPCDIDEVICEINSTANCEA, LPVOID); +typedef BOOL (FAR PASCAL * LPDIENUMDEVICESCALLBACKW)(LPCDIDEVICEINSTANCEW, LPVOID); +#ifdef UNICODE +#define LPDIENUMDEVICESCALLBACK LPDIENUMDEVICESCALLBACKW +#else +#define LPDIENUMDEVICESCALLBACK LPDIENUMDEVICESCALLBACKA +#endif // !UNICODE +typedef BOOL (FAR PASCAL * LPDICONFIGUREDEVICESCALLBACK)(IUnknown FAR *, LPVOID); + +#define DIEDFL_ALLDEVICES 0x00000000 +#define DIEDFL_ATTACHEDONLY 0x00000001 +#if(DIRECTINPUT_VERSION >= 0x0500) +#define DIEDFL_FORCEFEEDBACK 0x00000100 +#endif /* DIRECTINPUT_VERSION >= 0x0500 */ +#if(DIRECTINPUT_VERSION >= 0x050a) +#define DIEDFL_INCLUDEALIASES 0x00010000 +#define DIEDFL_INCLUDEPHANTOMS 0x00020000 +#endif /* DIRECTINPUT_VERSION >= 0x050a */ +#if(DIRECTINPUT_VERSION >= 0x0800) +#define DIEDFL_INCLUDEHIDDEN 0x00040000 +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + + +#if(DIRECTINPUT_VERSION >= 0x0800) +typedef BOOL (FAR PASCAL * LPDIENUMDEVICESBYSEMANTICSCBA)(LPCDIDEVICEINSTANCEA, LPDIRECTINPUTDEVICE8A, DWORD, DWORD, LPVOID); +typedef BOOL (FAR PASCAL * LPDIENUMDEVICESBYSEMANTICSCBW)(LPCDIDEVICEINSTANCEW, LPDIRECTINPUTDEVICE8W, DWORD, DWORD, LPVOID); +#ifdef UNICODE +#define LPDIENUMDEVICESBYSEMANTICSCB LPDIENUMDEVICESBYSEMANTICSCBW +#else +#define LPDIENUMDEVICESBYSEMANTICSCB LPDIENUMDEVICESBYSEMANTICSCBA +#endif // !UNICODE +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +#if(DIRECTINPUT_VERSION >= 0x0800) +#define DIEDBS_MAPPEDPRI1 0x00000001 +#define DIEDBS_MAPPEDPRI2 0x00000002 +#define DIEDBS_RECENTDEVICE 0x00000010 +#define DIEDBS_NEWDEVICE 0x00000020 +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +#if(DIRECTINPUT_VERSION >= 0x0800) +#define DIEDBSFL_ATTACHEDONLY 0x00000000 +#define DIEDBSFL_THISUSER 0x00000010 +#define DIEDBSFL_FORCEFEEDBACK DIEDFL_FORCEFEEDBACK +#define DIEDBSFL_AVAILABLEDEVICES 0x00001000 +#define DIEDBSFL_MULTIMICEKEYBOARDS 0x00002000 +#define DIEDBSFL_NONGAMINGDEVICES 0x00004000 +#define DIEDBSFL_VALID 0x00007110 +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +#undef INTERFACE +#define INTERFACE IDirectInputW + +DECLARE_INTERFACE_(IDirectInputW, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputW methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEW *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; +}; + +typedef struct IDirectInputW *LPDIRECTINPUTW; + +#undef INTERFACE +#define INTERFACE IDirectInputA + +DECLARE_INTERFACE_(IDirectInputA, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputA methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEA *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; +}; + +typedef struct IDirectInputA *LPDIRECTINPUTA; + +#ifdef UNICODE +#define IID_IDirectInput IID_IDirectInputW +#define IDirectInput IDirectInputW +#define IDirectInputVtbl IDirectInputWVtbl +#else +#define IID_IDirectInput IID_IDirectInputA +#define IDirectInput IDirectInputA +#define IDirectInputVtbl IDirectInputAVtbl +#endif +typedef struct IDirectInput *LPDIRECTINPUT; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInput_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInput_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInput_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInput_CreateDevice(p,a,b,c) (p)->lpVtbl->CreateDevice(p,a,b,c) +#define IDirectInput_EnumDevices(p,a,b,c,d) (p)->lpVtbl->EnumDevices(p,a,b,c,d) +#define IDirectInput_GetDeviceStatus(p,a) (p)->lpVtbl->GetDeviceStatus(p,a) +#define IDirectInput_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInput_Initialize(p,a,b) (p)->lpVtbl->Initialize(p,a,b) +#else +#define IDirectInput_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInput_AddRef(p) (p)->AddRef() +#define IDirectInput_Release(p) (p)->Release() +#define IDirectInput_CreateDevice(p,a,b,c) (p)->CreateDevice(a,b,c) +#define IDirectInput_EnumDevices(p,a,b,c,d) (p)->EnumDevices(a,b,c,d) +#define IDirectInput_GetDeviceStatus(p,a) (p)->GetDeviceStatus(a) +#define IDirectInput_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInput_Initialize(p,a,b) (p)->Initialize(a,b) +#endif + +#undef INTERFACE +#define INTERFACE IDirectInput2W + +DECLARE_INTERFACE_(IDirectInput2W, IDirectInputW) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputW methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEW *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + + /*** IDirectInput2W methods ***/ + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCWSTR,LPGUID) PURE; +}; + +typedef struct IDirectInput2W *LPDIRECTINPUT2W; + +#undef INTERFACE +#define INTERFACE IDirectInput2A + +DECLARE_INTERFACE_(IDirectInput2A, IDirectInputA) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInputA methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEA *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + + /*** IDirectInput2A methods ***/ + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCSTR,LPGUID) PURE; +}; + +typedef struct IDirectInput2A *LPDIRECTINPUT2A; + +#ifdef UNICODE +#define IID_IDirectInput2 IID_IDirectInput2W +#define IDirectInput2 IDirectInput2W +#define IDirectInput2Vtbl IDirectInput2WVtbl +#else +#define IID_IDirectInput2 IID_IDirectInput2A +#define IDirectInput2 IDirectInput2A +#define IDirectInput2Vtbl IDirectInput2AVtbl +#endif +typedef struct IDirectInput2 *LPDIRECTINPUT2; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInput2_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInput2_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInput2_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInput2_CreateDevice(p,a,b,c) (p)->lpVtbl->CreateDevice(p,a,b,c) +#define IDirectInput2_EnumDevices(p,a,b,c,d) (p)->lpVtbl->EnumDevices(p,a,b,c,d) +#define IDirectInput2_GetDeviceStatus(p,a) (p)->lpVtbl->GetDeviceStatus(p,a) +#define IDirectInput2_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInput2_Initialize(p,a,b) (p)->lpVtbl->Initialize(p,a,b) +#define IDirectInput2_FindDevice(p,a,b,c) (p)->lpVtbl->FindDevice(p,a,b,c) +#else +#define IDirectInput2_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInput2_AddRef(p) (p)->AddRef() +#define IDirectInput2_Release(p) (p)->Release() +#define IDirectInput2_CreateDevice(p,a,b,c) (p)->CreateDevice(a,b,c) +#define IDirectInput2_EnumDevices(p,a,b,c,d) (p)->EnumDevices(a,b,c,d) +#define IDirectInput2_GetDeviceStatus(p,a) (p)->GetDeviceStatus(a) +#define IDirectInput2_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInput2_Initialize(p,a,b) (p)->Initialize(a,b) +#define IDirectInput2_FindDevice(p,a,b,c) (p)->FindDevice(a,b,c) +#endif + + +#undef INTERFACE +#define INTERFACE IDirectInput7W + +DECLARE_INTERFACE_(IDirectInput7W, IDirectInput2W) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInput2W methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEW *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCWSTR,LPGUID) PURE; + + /*** IDirectInput7W methods ***/ + STDMETHOD(CreateDeviceEx)(THIS_ REFGUID,REFIID,LPVOID *,LPUNKNOWN) PURE; +}; + +typedef struct IDirectInput7W *LPDIRECTINPUT7W; + +#undef INTERFACE +#define INTERFACE IDirectInput7A + +DECLARE_INTERFACE_(IDirectInput7A, IDirectInput2A) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInput2A methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICEA *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCSTR,LPGUID) PURE; + + /*** IDirectInput7A methods ***/ + STDMETHOD(CreateDeviceEx)(THIS_ REFGUID,REFIID,LPVOID *,LPUNKNOWN) PURE; +}; + +typedef struct IDirectInput7A *LPDIRECTINPUT7A; + +#ifdef UNICODE +#define IID_IDirectInput7 IID_IDirectInput7W +#define IDirectInput7 IDirectInput7W +#define IDirectInput7Vtbl IDirectInput7WVtbl +#else +#define IID_IDirectInput7 IID_IDirectInput7A +#define IDirectInput7 IDirectInput7A +#define IDirectInput7Vtbl IDirectInput7AVtbl +#endif +typedef struct IDirectInput7 *LPDIRECTINPUT7; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInput7_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInput7_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInput7_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInput7_CreateDevice(p,a,b,c) (p)->lpVtbl->CreateDevice(p,a,b,c) +#define IDirectInput7_EnumDevices(p,a,b,c,d) (p)->lpVtbl->EnumDevices(p,a,b,c,d) +#define IDirectInput7_GetDeviceStatus(p,a) (p)->lpVtbl->GetDeviceStatus(p,a) +#define IDirectInput7_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInput7_Initialize(p,a,b) (p)->lpVtbl->Initialize(p,a,b) +#define IDirectInput7_FindDevice(p,a,b,c) (p)->lpVtbl->FindDevice(p,a,b,c) +#define IDirectInput7_CreateDeviceEx(p,a,b,c,d) (p)->lpVtbl->CreateDeviceEx(p,a,b,c,d) +#else +#define IDirectInput7_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInput7_AddRef(p) (p)->AddRef() +#define IDirectInput7_Release(p) (p)->Release() +#define IDirectInput7_CreateDevice(p,a,b,c) (p)->CreateDevice(a,b,c) +#define IDirectInput7_EnumDevices(p,a,b,c,d) (p)->EnumDevices(a,b,c,d) +#define IDirectInput7_GetDeviceStatus(p,a) (p)->GetDeviceStatus(a) +#define IDirectInput7_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInput7_Initialize(p,a,b) (p)->Initialize(a,b) +#define IDirectInput7_FindDevice(p,a,b,c) (p)->FindDevice(a,b,c) +#define IDirectInput7_CreateDeviceEx(p,a,b,c,d) (p)->CreateDeviceEx(a,b,c,d) +#endif + +#if(DIRECTINPUT_VERSION >= 0x0800) +#undef INTERFACE +#define INTERFACE IDirectInput8W + +DECLARE_INTERFACE_(IDirectInput8W, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInput8W methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICE8W *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKW,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCWSTR,LPGUID) PURE; + STDMETHOD(EnumDevicesBySemantics)(THIS_ LPCWSTR,LPDIACTIONFORMATW,LPDIENUMDEVICESBYSEMANTICSCBW,LPVOID,DWORD) PURE; + STDMETHOD(ConfigureDevices)(THIS_ LPDICONFIGUREDEVICESCALLBACK,LPDICONFIGUREDEVICESPARAMSW,DWORD,LPVOID) PURE; +}; + +typedef struct IDirectInput8W *LPDIRECTINPUT8W; + +#undef INTERFACE +#define INTERFACE IDirectInput8A + +DECLARE_INTERFACE_(IDirectInput8A, IUnknown) +{ + /*** IUnknown methods ***/ + STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID * ppvObj) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; + + /*** IDirectInput8A methods ***/ + STDMETHOD(CreateDevice)(THIS_ REFGUID,LPDIRECTINPUTDEVICE8A *,LPUNKNOWN) PURE; + STDMETHOD(EnumDevices)(THIS_ DWORD,LPDIENUMDEVICESCALLBACKA,LPVOID,DWORD) PURE; + STDMETHOD(GetDeviceStatus)(THIS_ REFGUID) PURE; + STDMETHOD(RunControlPanel)(THIS_ HWND,DWORD) PURE; + STDMETHOD(Initialize)(THIS_ HINSTANCE,DWORD) PURE; + STDMETHOD(FindDevice)(THIS_ REFGUID,LPCSTR,LPGUID) PURE; + STDMETHOD(EnumDevicesBySemantics)(THIS_ LPCSTR,LPDIACTIONFORMATA,LPDIENUMDEVICESBYSEMANTICSCBA,LPVOID,DWORD) PURE; + STDMETHOD(ConfigureDevices)(THIS_ LPDICONFIGUREDEVICESCALLBACK,LPDICONFIGUREDEVICESPARAMSA,DWORD,LPVOID) PURE; +}; + +typedef struct IDirectInput8A *LPDIRECTINPUT8A; + +#ifdef UNICODE +#define IID_IDirectInput8 IID_IDirectInput8W +#define IDirectInput8 IDirectInput8W +#define IDirectInput8Vtbl IDirectInput8WVtbl +#else +#define IID_IDirectInput8 IID_IDirectInput8A +#define IDirectInput8 IDirectInput8A +#define IDirectInput8Vtbl IDirectInput8AVtbl +#endif +typedef struct IDirectInput8 *LPDIRECTINPUT8; + +#if !defined(__cplusplus) || defined(CINTERFACE) +#define IDirectInput8_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) +#define IDirectInput8_AddRef(p) (p)->lpVtbl->AddRef(p) +#define IDirectInput8_Release(p) (p)->lpVtbl->Release(p) +#define IDirectInput8_CreateDevice(p,a,b,c) (p)->lpVtbl->CreateDevice(p,a,b,c) +#define IDirectInput8_EnumDevices(p,a,b,c,d) (p)->lpVtbl->EnumDevices(p,a,b,c,d) +#define IDirectInput8_GetDeviceStatus(p,a) (p)->lpVtbl->GetDeviceStatus(p,a) +#define IDirectInput8_RunControlPanel(p,a,b) (p)->lpVtbl->RunControlPanel(p,a,b) +#define IDirectInput8_Initialize(p,a,b) (p)->lpVtbl->Initialize(p,a,b) +#define IDirectInput8_FindDevice(p,a,b,c) (p)->lpVtbl->FindDevice(p,a,b,c) +#define IDirectInput8_EnumDevicesBySemantics(p,a,b,c,d,e) (p)->lpVtbl->EnumDevicesBySemantics(p,a,b,c,d,e) +#define IDirectInput8_ConfigureDevices(p,a,b,c,d) (p)->lpVtbl->ConfigureDevices(p,a,b,c,d) +#else +#define IDirectInput8_QueryInterface(p,a,b) (p)->QueryInterface(a,b) +#define IDirectInput8_AddRef(p) (p)->AddRef() +#define IDirectInput8_Release(p) (p)->Release() +#define IDirectInput8_CreateDevice(p,a,b,c) (p)->CreateDevice(a,b,c) +#define IDirectInput8_EnumDevices(p,a,b,c,d) (p)->EnumDevices(a,b,c,d) +#define IDirectInput8_GetDeviceStatus(p,a) (p)->GetDeviceStatus(a) +#define IDirectInput8_RunControlPanel(p,a,b) (p)->RunControlPanel(a,b) +#define IDirectInput8_Initialize(p,a,b) (p)->Initialize(a,b) +#define IDirectInput8_FindDevice(p,a,b,c) (p)->FindDevice(a,b,c) +#define IDirectInput8_EnumDevicesBySemantics(p,a,b,c,d,e) (p)->EnumDevicesBySemantics(a,b,c,d,e) +#define IDirectInput8_ConfigureDevices(p,a,b,c,d) (p)->ConfigureDevices(a,b,c,d) +#endif +#endif /* DIRECTINPUT_VERSION >= 0x0800 */ + +#if DIRECTINPUT_VERSION > 0x0700 + +extern HRESULT WINAPI DirectInput8Create(HINSTANCE hinst, DWORD dwVersion, REFIID riidltf, LPVOID *ppvOut, LPUNKNOWN punkOuter); + +#else +extern HRESULT WINAPI DirectInputCreateA(HINSTANCE hinst, DWORD dwVersion, LPDIRECTINPUTA *ppDI, LPUNKNOWN punkOuter); +extern HRESULT WINAPI DirectInputCreateW(HINSTANCE hinst, DWORD dwVersion, LPDIRECTINPUTW *ppDI, LPUNKNOWN punkOuter); +#ifdef UNICODE +#define DirectInputCreate DirectInputCreateW +#else +#define DirectInputCreate DirectInputCreateA +#endif // !UNICODE + +extern HRESULT WINAPI DirectInputCreateEx(HINSTANCE hinst, DWORD dwVersion, REFIID riidltf, LPVOID *ppvOut, LPUNKNOWN punkOuter); + +#endif /* DIRECTINPUT_VERSION > 0x700 */ + +#endif /* DIJ_RINGZERO */ + + +/**************************************************************************** + * + * Return Codes + * + ****************************************************************************/ + +/* + * The operation completed successfully. + */ +#define DI_OK S_OK + +/* + * The device exists but is not currently attached. + */ +#define DI_NOTATTACHED S_FALSE + +/* + * The device buffer overflowed. Some input was lost. + */ +#define DI_BUFFEROVERFLOW S_FALSE + +/* + * The change in device properties had no effect. + */ +#define DI_PROPNOEFFECT S_FALSE + +/* + * The operation had no effect. + */ +#define DI_NOEFFECT S_FALSE + +/* + * The device is a polled device. As a result, device buffering + * will not collect any data and event notifications will not be + * signalled until GetDeviceState is called. + */ +#define DI_POLLEDDEVICE ((HRESULT)0x00000002L) + +/* + * The parameters of the effect were successfully updated by + * IDirectInputEffect::SetParameters, but the effect was not + * downloaded because the device is not exclusively acquired + * or because the DIEP_NODOWNLOAD flag was passed. + */ +#define DI_DOWNLOADSKIPPED ((HRESULT)0x00000003L) + +/* + * The parameters of the effect were successfully updated by + * IDirectInputEffect::SetParameters, but in order to change + * the parameters, the effect needed to be restarted. + */ +#define DI_EFFECTRESTARTED ((HRESULT)0x00000004L) + +/* + * The parameters of the effect were successfully updated by + * IDirectInputEffect::SetParameters, but some of them were + * beyond the capabilities of the device and were truncated. + */ +#define DI_TRUNCATED ((HRESULT)0x00000008L) + +/* + * The settings have been successfully applied but could not be + * persisted. + */ +#define DI_SETTINGSNOTSAVED ((HRESULT)0x0000000BL) + +/* + * Equal to DI_EFFECTRESTARTED | DI_TRUNCATED. + */ +#define DI_TRUNCATEDANDRESTARTED ((HRESULT)0x0000000CL) + +/* + * A SUCCESS code indicating that settings cannot be modified. + */ +#define DI_WRITEPROTECT ((HRESULT)0x00000013L) + +/* + * The application requires a newer version of DirectInput. + */ +#define DIERR_OLDDIRECTINPUTVERSION \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_OLD_WIN_VERSION) + +/* + * The application was written for an unsupported prerelease version + * of DirectInput. + */ +#define DIERR_BETADIRECTINPUTVERSION \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_RMODE_APP) + +/* + * The object could not be created due to an incompatible driver version + * or mismatched or incomplete driver components. + */ +#define DIERR_BADDRIVERVER \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_BAD_DRIVER_LEVEL) + +/* + * The device or device instance or effect is not registered with DirectInput. + */ +#define DIERR_DEVICENOTREG REGDB_E_CLASSNOTREG + +/* + * The requested object does not exist. + */ +#define DIERR_NOTFOUND \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_FILE_NOT_FOUND) + +/* + * The requested object does not exist. + */ +#define DIERR_OBJECTNOTFOUND \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_FILE_NOT_FOUND) + +/* + * An invalid parameter was passed to the returning function, + * or the object was not in a state that admitted the function + * to be called. + */ +#define DIERR_INVALIDPARAM E_INVALIDARG + +/* + * The specified interface is not supported by the object + */ +#define DIERR_NOINTERFACE E_NOINTERFACE + +/* + * An undetermined error occured inside the DInput subsystem + */ +#define DIERR_GENERIC E_FAIL + +/* + * The DInput subsystem couldn't allocate sufficient memory to complete the + * caller's request. + */ +#define DIERR_OUTOFMEMORY E_OUTOFMEMORY + +/* + * The function called is not supported at this time + */ +#define DIERR_UNSUPPORTED E_NOTIMPL + +/* + * This object has not been initialized + */ +#define DIERR_NOTINITIALIZED \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_NOT_READY) + +/* + * This object is already initialized + */ +#define DIERR_ALREADYINITIALIZED \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_ALREADY_INITIALIZED) + +/* + * This object does not support aggregation + */ +#define DIERR_NOAGGREGATION CLASS_E_NOAGGREGATION + +/* + * Another app has a higher priority level, preventing this call from + * succeeding. + */ +#define DIERR_OTHERAPPHASPRIO E_ACCESSDENIED + +/* + * Access to the device has been lost. It must be re-acquired. + */ +#define DIERR_INPUTLOST \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_READ_FAULT) + +/* + * The operation cannot be performed while the device is acquired. + */ +#define DIERR_ACQUIRED \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_BUSY) + +/* + * The operation cannot be performed unless the device is acquired. + */ +#define DIERR_NOTACQUIRED \ + MAKE_HRESULT(SEVERITY_ERROR, FACILITY_WIN32, ERROR_INVALID_ACCESS) + +/* + * The specified property cannot be changed. + */ +#define DIERR_READONLY E_ACCESSDENIED + +/* + * The device already has an event notification associated with it. + */ +#define DIERR_HANDLEEXISTS E_ACCESSDENIED + +/* + * Data is not yet available. + */ +#ifndef E_PENDING +#define E_PENDING 0x8000000AL +#endif + +/* + * Unable to IDirectInputJoyConfig_Acquire because the user + * does not have sufficient privileges to change the joystick + * configuration. + */ +#define DIERR_INSUFFICIENTPRIVS 0x80040200L + +/* + * The device is full. + */ +#define DIERR_DEVICEFULL 0x80040201L + +/* + * Not all the requested information fit into the buffer. + */ +#define DIERR_MOREDATA 0x80040202L + +/* + * The effect is not downloaded. + */ +#define DIERR_NOTDOWNLOADED 0x80040203L + +/* + * The device cannot be reinitialized because there are still effects + * attached to it. + */ +#define DIERR_HASEFFECTS 0x80040204L + +/* + * The operation cannot be performed unless the device is acquired + * in DISCL_EXCLUSIVE mode. + */ +#define DIERR_NOTEXCLUSIVEACQUIRED 0x80040205L + +/* + * The effect could not be downloaded because essential information + * is missing. For example, no axes have been associated with the + * effect, or no type-specific information has been created. + */ +#define DIERR_INCOMPLETEEFFECT 0x80040206L + +/* + * Attempted to read buffered device data from a device that is + * not buffered. + */ +#define DIERR_NOTBUFFERED 0x80040207L + +/* + * An attempt was made to modify parameters of an effect while it is + * playing. Not all hardware devices support altering the parameters + * of an effect while it is playing. + */ +#define DIERR_EFFECTPLAYING 0x80040208L + +/* + * The operation could not be completed because the device is not + * plugged in. + */ +#define DIERR_UNPLUGGED 0x80040209L + +/* + * SendDeviceData failed because more information was requested + * to be sent than can be sent to the device. Some devices have + * restrictions on how much data can be sent to them. (For example, + * there might be a limit on the number of buttons that can be + * pressed at once.) + */ +#define DIERR_REPORTFULL 0x8004020AL + + +/* + * A mapper file function failed because reading or writing the user or IHV + * settings file failed. + */ +#define DIERR_MAPFILEFAIL 0x8004020BL + + +/*--- DINPUT Mapper Definitions: New for Dx8 ---*/ + + +/*--- Keyboard + Physical Keyboard Device ---*/ + +#define DIKEYBOARD_ESCAPE 0x81000401 +#define DIKEYBOARD_1 0x81000402 +#define DIKEYBOARD_2 0x81000403 +#define DIKEYBOARD_3 0x81000404 +#define DIKEYBOARD_4 0x81000405 +#define DIKEYBOARD_5 0x81000406 +#define DIKEYBOARD_6 0x81000407 +#define DIKEYBOARD_7 0x81000408 +#define DIKEYBOARD_8 0x81000409 +#define DIKEYBOARD_9 0x8100040A +#define DIKEYBOARD_0 0x8100040B +#define DIKEYBOARD_MINUS 0x8100040C /* - on main keyboard */ +#define DIKEYBOARD_EQUALS 0x8100040D +#define DIKEYBOARD_BACK 0x8100040E /* backspace */ +#define DIKEYBOARD_TAB 0x8100040F +#define DIKEYBOARD_Q 0x81000410 +#define DIKEYBOARD_W 0x81000411 +#define DIKEYBOARD_E 0x81000412 +#define DIKEYBOARD_R 0x81000413 +#define DIKEYBOARD_T 0x81000414 +#define DIKEYBOARD_Y 0x81000415 +#define DIKEYBOARD_U 0x81000416 +#define DIKEYBOARD_I 0x81000417 +#define DIKEYBOARD_O 0x81000418 +#define DIKEYBOARD_P 0x81000419 +#define DIKEYBOARD_LBRACKET 0x8100041A +#define DIKEYBOARD_RBRACKET 0x8100041B +#define DIKEYBOARD_RETURN 0x8100041C /* Enter on main keyboard */ +#define DIKEYBOARD_LCONTROL 0x8100041D +#define DIKEYBOARD_A 0x8100041E +#define DIKEYBOARD_S 0x8100041F +#define DIKEYBOARD_D 0x81000420 +#define DIKEYBOARD_F 0x81000421 +#define DIKEYBOARD_G 0x81000422 +#define DIKEYBOARD_H 0x81000423 +#define DIKEYBOARD_J 0x81000424 +#define DIKEYBOARD_K 0x81000425 +#define DIKEYBOARD_L 0x81000426 +#define DIKEYBOARD_SEMICOLON 0x81000427 +#define DIKEYBOARD_APOSTROPHE 0x81000428 +#define DIKEYBOARD_GRAVE 0x81000429 /* accent grave */ +#define DIKEYBOARD_LSHIFT 0x8100042A +#define DIKEYBOARD_BACKSLASH 0x8100042B +#define DIKEYBOARD_Z 0x8100042C +#define DIKEYBOARD_X 0x8100042D +#define DIKEYBOARD_C 0x8100042E +#define DIKEYBOARD_V 0x8100042F +#define DIKEYBOARD_B 0x81000430 +#define DIKEYBOARD_N 0x81000431 +#define DIKEYBOARD_M 0x81000432 +#define DIKEYBOARD_COMMA 0x81000433 +#define DIKEYBOARD_PERIOD 0x81000434 /* . on main keyboard */ +#define DIKEYBOARD_SLASH 0x81000435 /* / on main keyboard */ +#define DIKEYBOARD_RSHIFT 0x81000436 +#define DIKEYBOARD_MULTIPLY 0x81000437 /* * on numeric keypad */ +#define DIKEYBOARD_LMENU 0x81000438 /* left Alt */ +#define DIKEYBOARD_SPACE 0x81000439 +#define DIKEYBOARD_CAPITAL 0x8100043A +#define DIKEYBOARD_F1 0x8100043B +#define DIKEYBOARD_F2 0x8100043C +#define DIKEYBOARD_F3 0x8100043D +#define DIKEYBOARD_F4 0x8100043E +#define DIKEYBOARD_F5 0x8100043F +#define DIKEYBOARD_F6 0x81000440 +#define DIKEYBOARD_F7 0x81000441 +#define DIKEYBOARD_F8 0x81000442 +#define DIKEYBOARD_F9 0x81000443 +#define DIKEYBOARD_F10 0x81000444 +#define DIKEYBOARD_NUMLOCK 0x81000445 +#define DIKEYBOARD_SCROLL 0x81000446 /* Scroll Lock */ +#define DIKEYBOARD_NUMPAD7 0x81000447 +#define DIKEYBOARD_NUMPAD8 0x81000448 +#define DIKEYBOARD_NUMPAD9 0x81000449 +#define DIKEYBOARD_SUBTRACT 0x8100044A /* - on numeric keypad */ +#define DIKEYBOARD_NUMPAD4 0x8100044B +#define DIKEYBOARD_NUMPAD5 0x8100044C +#define DIKEYBOARD_NUMPAD6 0x8100044D +#define DIKEYBOARD_ADD 0x8100044E /* + on numeric keypad */ +#define DIKEYBOARD_NUMPAD1 0x8100044F +#define DIKEYBOARD_NUMPAD2 0x81000450 +#define DIKEYBOARD_NUMPAD3 0x81000451 +#define DIKEYBOARD_NUMPAD0 0x81000452 +#define DIKEYBOARD_DECIMAL 0x81000453 /* . on numeric keypad */ +#define DIKEYBOARD_OEM_102 0x81000456 /* <> or \| on RT 102-key keyboard (Non-U.S.) */ +#define DIKEYBOARD_F11 0x81000457 +#define DIKEYBOARD_F12 0x81000458 +#define DIKEYBOARD_F13 0x81000464 /* (NEC PC98) */ +#define DIKEYBOARD_F14 0x81000465 /* (NEC PC98) */ +#define DIKEYBOARD_F15 0x81000466 /* (NEC PC98) */ +#define DIKEYBOARD_KANA 0x81000470 /* (Japanese keyboard) */ +#define DIKEYBOARD_ABNT_C1 0x81000473 /* /? on Brazilian keyboard */ +#define DIKEYBOARD_CONVERT 0x81000479 /* (Japanese keyboard) */ +#define DIKEYBOARD_NOCONVERT 0x8100047B /* (Japanese keyboard) */ +#define DIKEYBOARD_YEN 0x8100047D /* (Japanese keyboard) */ +#define DIKEYBOARD_ABNT_C2 0x8100047E /* Numpad . on Brazilian keyboard */ +#define DIKEYBOARD_NUMPADEQUALS 0x8100048D /* = on numeric keypad (NEC PC98) */ +#define DIKEYBOARD_PREVTRACK 0x81000490 /* Previous Track (DIK_CIRCUMFLEX on Japanese keyboard) */ +#define DIKEYBOARD_AT 0x81000491 /* (NEC PC98) */ +#define DIKEYBOARD_COLON 0x81000492 /* (NEC PC98) */ +#define DIKEYBOARD_UNDERLINE 0x81000493 /* (NEC PC98) */ +#define DIKEYBOARD_KANJI 0x81000494 /* (Japanese keyboard) */ +#define DIKEYBOARD_STOP 0x81000495 /* (NEC PC98) */ +#define DIKEYBOARD_AX 0x81000496 /* (Japan AX) */ +#define DIKEYBOARD_UNLABELED 0x81000497 /* (J3100) */ +#define DIKEYBOARD_NEXTTRACK 0x81000499 /* Next Track */ +#define DIKEYBOARD_NUMPADENTER 0x8100049C /* Enter on numeric keypad */ +#define DIKEYBOARD_RCONTROL 0x8100049D +#define DIKEYBOARD_MUTE 0x810004A0 /* Mute */ +#define DIKEYBOARD_CALCULATOR 0x810004A1 /* Calculator */ +#define DIKEYBOARD_PLAYPAUSE 0x810004A2 /* Play / Pause */ +#define DIKEYBOARD_MEDIASTOP 0x810004A4 /* Media Stop */ +#define DIKEYBOARD_VOLUMEDOWN 0x810004AE /* Volume - */ +#define DIKEYBOARD_VOLUMEUP 0x810004B0 /* Volume + */ +#define DIKEYBOARD_WEBHOME 0x810004B2 /* Web home */ +#define DIKEYBOARD_NUMPADCOMMA 0x810004B3 /* , on numeric keypad (NEC PC98) */ +#define DIKEYBOARD_DIVIDE 0x810004B5 /* / on numeric keypad */ +#define DIKEYBOARD_SYSRQ 0x810004B7 +#define DIKEYBOARD_RMENU 0x810004B8 /* right Alt */ +#define DIKEYBOARD_PAUSE 0x810004C5 /* Pause */ +#define DIKEYBOARD_HOME 0x810004C7 /* Home on arrow keypad */ +#define DIKEYBOARD_UP 0x810004C8 /* UpArrow on arrow keypad */ +#define DIKEYBOARD_PRIOR 0x810004C9 /* PgUp on arrow keypad */ +#define DIKEYBOARD_LEFT 0x810004CB /* LeftArrow on arrow keypad */ +#define DIKEYBOARD_RIGHT 0x810004CD /* RightArrow on arrow keypad */ +#define DIKEYBOARD_END 0x810004CF /* End on arrow keypad */ +#define DIKEYBOARD_DOWN 0x810004D0 /* DownArrow on arrow keypad */ +#define DIKEYBOARD_NEXT 0x810004D1 /* PgDn on arrow keypad */ +#define DIKEYBOARD_INSERT 0x810004D2 /* Insert on arrow keypad */ +#define DIKEYBOARD_DELETE 0x810004D3 /* Delete on arrow keypad */ +#define DIKEYBOARD_LWIN 0x810004DB /* Left Windows key */ +#define DIKEYBOARD_RWIN 0x810004DC /* Right Windows key */ +#define DIKEYBOARD_APPS 0x810004DD /* AppMenu key */ +#define DIKEYBOARD_POWER 0x810004DE /* System Power */ +#define DIKEYBOARD_SLEEP 0x810004DF /* System Sleep */ +#define DIKEYBOARD_WAKE 0x810004E3 /* System Wake */ +#define DIKEYBOARD_WEBSEARCH 0x810004E5 /* Web Search */ +#define DIKEYBOARD_WEBFAVORITES 0x810004E6 /* Web Favorites */ +#define DIKEYBOARD_WEBREFRESH 0x810004E7 /* Web Refresh */ +#define DIKEYBOARD_WEBSTOP 0x810004E8 /* Web Stop */ +#define DIKEYBOARD_WEBFORWARD 0x810004E9 /* Web Forward */ +#define DIKEYBOARD_WEBBACK 0x810004EA /* Web Back */ +#define DIKEYBOARD_MYCOMPUTER 0x810004EB /* My Computer */ +#define DIKEYBOARD_MAIL 0x810004EC /* Mail */ +#define DIKEYBOARD_MEDIASELECT 0x810004ED /* Media Select */ + + +/*--- MOUSE + Physical Mouse Device ---*/ + +#define DIMOUSE_XAXISAB (0x82000200 |DIMOFS_X ) /* X Axis-absolute: Some mice natively report absolute coordinates */ +#define DIMOUSE_YAXISAB (0x82000200 |DIMOFS_Y ) /* Y Axis-absolute: Some mice natively report absolute coordinates */ +#define DIMOUSE_XAXIS (0x82000300 |DIMOFS_X ) /* X Axis */ +#define DIMOUSE_YAXIS (0x82000300 |DIMOFS_Y ) /* Y Axis */ +#define DIMOUSE_WHEEL (0x82000300 |DIMOFS_Z ) /* Z Axis */ +#define DIMOUSE_BUTTON0 (0x82000400 |DIMOFS_BUTTON0) /* Button 0 */ +#define DIMOUSE_BUTTON1 (0x82000400 |DIMOFS_BUTTON1) /* Button 1 */ +#define DIMOUSE_BUTTON2 (0x82000400 |DIMOFS_BUTTON2) /* Button 2 */ +#define DIMOUSE_BUTTON3 (0x82000400 |DIMOFS_BUTTON3) /* Button 3 */ +#define DIMOUSE_BUTTON4 (0x82000400 |DIMOFS_BUTTON4) /* Button 4 */ +#define DIMOUSE_BUTTON5 (0x82000400 |DIMOFS_BUTTON5) /* Button 5 */ +#define DIMOUSE_BUTTON6 (0x82000400 |DIMOFS_BUTTON6) /* Button 6 */ +#define DIMOUSE_BUTTON7 (0x82000400 |DIMOFS_BUTTON7) /* Button 7 */ + + +/*--- VOICE + Physical Dplay Voice Device ---*/ + +#define DIVOICE_CHANNEL1 0x83000401 +#define DIVOICE_CHANNEL2 0x83000402 +#define DIVOICE_CHANNEL3 0x83000403 +#define DIVOICE_CHANNEL4 0x83000404 +#define DIVOICE_CHANNEL5 0x83000405 +#define DIVOICE_CHANNEL6 0x83000406 +#define DIVOICE_CHANNEL7 0x83000407 +#define DIVOICE_CHANNEL8 0x83000408 +#define DIVOICE_TEAM 0x83000409 +#define DIVOICE_ALL 0x8300040A +#define DIVOICE_RECORDMUTE 0x8300040B +#define DIVOICE_PLAYBACKMUTE 0x8300040C +#define DIVOICE_TRANSMIT 0x8300040D + +#define DIVOICE_VOICECOMMAND 0x83000410 + + +/*--- Driving Simulator - Racing + Vehicle control is primary objective ---*/ +#define DIVIRTUAL_DRIVING_RACE 0x01000000 +#define DIAXIS_DRIVINGR_STEER 0x01008A01 /* Steering */ +#define DIAXIS_DRIVINGR_ACCELERATE 0x01039202 /* Accelerate */ +#define DIAXIS_DRIVINGR_BRAKE 0x01041203 /* Brake-Axis */ +#define DIBUTTON_DRIVINGR_SHIFTUP 0x01000C01 /* Shift to next higher gear */ +#define DIBUTTON_DRIVINGR_SHIFTDOWN 0x01000C02 /* Shift to next lower gear */ +#define DIBUTTON_DRIVINGR_VIEW 0x01001C03 /* Cycle through view options */ +#define DIBUTTON_DRIVINGR_MENU 0x010004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIAXIS_DRIVINGR_ACCEL_AND_BRAKE 0x01014A04 /* Some devices combine accelerate and brake in a single axis */ +#define DIHATSWITCH_DRIVINGR_GLANCE 0x01004601 /* Look around */ +#define DIBUTTON_DRIVINGR_BRAKE 0x01004C04 /* Brake-button */ +#define DIBUTTON_DRIVINGR_DASHBOARD 0x01004405 /* Select next dashboard option */ +#define DIBUTTON_DRIVINGR_AIDS 0x01004406 /* Driver correction aids */ +#define DIBUTTON_DRIVINGR_MAP 0x01004407 /* Display Driving Map */ +#define DIBUTTON_DRIVINGR_BOOST 0x01004408 /* Turbo Boost */ +#define DIBUTTON_DRIVINGR_PIT 0x01004409 /* Pit stop notification */ +#define DIBUTTON_DRIVINGR_ACCELERATE_LINK 0x0103D4E0 /* Fallback Accelerate button */ +#define DIBUTTON_DRIVINGR_STEER_LEFT_LINK 0x0100CCE4 /* Fallback Steer Left button */ +#define DIBUTTON_DRIVINGR_STEER_RIGHT_LINK 0x0100CCEC /* Fallback Steer Right button */ +#define DIBUTTON_DRIVINGR_GLANCE_LEFT_LINK 0x0107C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_DRIVINGR_GLANCE_RIGHT_LINK 0x0107C4EC /* Fallback Glance Right button */ +#define DIBUTTON_DRIVINGR_DEVICE 0x010044FE /* Show input device and controls */ +#define DIBUTTON_DRIVINGR_PAUSE 0x010044FC /* Start / Pause / Restart game */ + +/*--- Driving Simulator - Combat + Combat from within a vehicle is primary objective ---*/ +#define DIVIRTUAL_DRIVING_COMBAT 0x02000000 +#define DIAXIS_DRIVINGC_STEER 0x02008A01 /* Steering */ +#define DIAXIS_DRIVINGC_ACCELERATE 0x02039202 /* Accelerate */ +#define DIAXIS_DRIVINGC_BRAKE 0x02041203 /* Brake-axis */ +#define DIBUTTON_DRIVINGC_FIRE 0x02000C01 /* Fire */ +#define DIBUTTON_DRIVINGC_WEAPONS 0x02000C02 /* Select next weapon */ +#define DIBUTTON_DRIVINGC_TARGET 0x02000C03 /* Select next available target */ +#define DIBUTTON_DRIVINGC_MENU 0x020004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIAXIS_DRIVINGC_ACCEL_AND_BRAKE 0x02014A04 /* Some devices combine accelerate and brake in a single axis */ +#define DIHATSWITCH_DRIVINGC_GLANCE 0x02004601 /* Look around */ +#define DIBUTTON_DRIVINGC_SHIFTUP 0x02004C04 /* Shift to next higher gear */ +#define DIBUTTON_DRIVINGC_SHIFTDOWN 0x02004C05 /* Shift to next lower gear */ +#define DIBUTTON_DRIVINGC_DASHBOARD 0x02004406 /* Select next dashboard option */ +#define DIBUTTON_DRIVINGC_AIDS 0x02004407 /* Driver correction aids */ +#define DIBUTTON_DRIVINGC_BRAKE 0x02004C08 /* Brake-button */ +#define DIBUTTON_DRIVINGC_FIRESECONDARY 0x02004C09 /* Alternative fire button */ +#define DIBUTTON_DRIVINGC_ACCELERATE_LINK 0x0203D4E0 /* Fallback Accelerate button */ +#define DIBUTTON_DRIVINGC_STEER_LEFT_LINK 0x0200CCE4 /* Fallback Steer Left button */ +#define DIBUTTON_DRIVINGC_STEER_RIGHT_LINK 0x0200CCEC /* Fallback Steer Right button */ +#define DIBUTTON_DRIVINGC_GLANCE_LEFT_LINK 0x0207C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_DRIVINGC_GLANCE_RIGHT_LINK 0x0207C4EC /* Fallback Glance Right button */ +#define DIBUTTON_DRIVINGC_DEVICE 0x020044FE /* Show input device and controls */ +#define DIBUTTON_DRIVINGC_PAUSE 0x020044FC /* Start / Pause / Restart game */ + +/*--- Driving Simulator - Tank + Combat from withing a tank is primary objective ---*/ +#define DIVIRTUAL_DRIVING_TANK 0x03000000 +#define DIAXIS_DRIVINGT_STEER 0x03008A01 /* Turn tank left / right */ +#define DIAXIS_DRIVINGT_BARREL 0x03010202 /* Raise / lower barrel */ +#define DIAXIS_DRIVINGT_ACCELERATE 0x03039203 /* Accelerate */ +#define DIAXIS_DRIVINGT_ROTATE 0x03020204 /* Turn barrel left / right */ +#define DIBUTTON_DRIVINGT_FIRE 0x03000C01 /* Fire */ +#define DIBUTTON_DRIVINGT_WEAPONS 0x03000C02 /* Select next weapon */ +#define DIBUTTON_DRIVINGT_TARGET 0x03000C03 /* Selects next available target */ +#define DIBUTTON_DRIVINGT_MENU 0x030004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_DRIVINGT_GLANCE 0x03004601 /* Look around */ +#define DIAXIS_DRIVINGT_BRAKE 0x03045205 /* Brake-axis */ +#define DIAXIS_DRIVINGT_ACCEL_AND_BRAKE 0x03014A06 /* Some devices combine accelerate and brake in a single axis */ +#define DIBUTTON_DRIVINGT_VIEW 0x03005C04 /* Cycle through view options */ +#define DIBUTTON_DRIVINGT_DASHBOARD 0x03005C05 /* Select next dashboard option */ +#define DIBUTTON_DRIVINGT_BRAKE 0x03004C06 /* Brake-button */ +#define DIBUTTON_DRIVINGT_FIRESECONDARY 0x03004C07 /* Alternative fire button */ +#define DIBUTTON_DRIVINGT_ACCELERATE_LINK 0x0303D4E0 /* Fallback Accelerate button */ +#define DIBUTTON_DRIVINGT_STEER_LEFT_LINK 0x0300CCE4 /* Fallback Steer Left button */ +#define DIBUTTON_DRIVINGT_STEER_RIGHT_LINK 0x0300CCEC /* Fallback Steer Right button */ +#define DIBUTTON_DRIVINGT_BARREL_UP_LINK 0x030144E0 /* Fallback Barrel up button */ +#define DIBUTTON_DRIVINGT_BARREL_DOWN_LINK 0x030144E8 /* Fallback Barrel down button */ +#define DIBUTTON_DRIVINGT_ROTATE_LEFT_LINK 0x030244E4 /* Fallback Rotate left button */ +#define DIBUTTON_DRIVINGT_ROTATE_RIGHT_LINK 0x030244EC /* Fallback Rotate right button */ +#define DIBUTTON_DRIVINGT_GLANCE_LEFT_LINK 0x0307C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_DRIVINGT_GLANCE_RIGHT_LINK 0x0307C4EC /* Fallback Glance Right button */ +#define DIBUTTON_DRIVINGT_DEVICE 0x030044FE /* Show input device and controls */ +#define DIBUTTON_DRIVINGT_PAUSE 0x030044FC /* Start / Pause / Restart game */ + +/*--- Flight Simulator - Civilian + Plane control is the primary objective ---*/ +#define DIVIRTUAL_FLYING_CIVILIAN 0x04000000 +#define DIAXIS_FLYINGC_BANK 0x04008A01 /* Roll ship left / right */ +#define DIAXIS_FLYINGC_PITCH 0x04010A02 /* Nose up / down */ +#define DIAXIS_FLYINGC_THROTTLE 0x04039203 /* Throttle */ +#define DIBUTTON_FLYINGC_VIEW 0x04002401 /* Cycle through view options */ +#define DIBUTTON_FLYINGC_DISPLAY 0x04002402 /* Select next dashboard / heads up display option */ +#define DIBUTTON_FLYINGC_GEAR 0x04002C03 /* Gear up / down */ +#define DIBUTTON_FLYINGC_MENU 0x040004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_FLYINGC_GLANCE 0x04004601 /* Look around */ +#define DIAXIS_FLYINGC_BRAKE 0x04046A04 /* Apply Brake */ +#define DIAXIS_FLYINGC_RUDDER 0x04025205 /* Yaw ship left/right */ +#define DIAXIS_FLYINGC_FLAPS 0x04055A06 /* Flaps */ +#define DIBUTTON_FLYINGC_FLAPSUP 0x04006404 /* Increment stepping up until fully retracted */ +#define DIBUTTON_FLYINGC_FLAPSDOWN 0x04006405 /* Decrement stepping down until fully extended */ +#define DIBUTTON_FLYINGC_BRAKE_LINK 0x04046CE0 /* Fallback brake button */ +#define DIBUTTON_FLYINGC_FASTER_LINK 0x0403D4E0 /* Fallback throttle up button */ +#define DIBUTTON_FLYINGC_SLOWER_LINK 0x0403D4E8 /* Fallback throttle down button */ +#define DIBUTTON_FLYINGC_GLANCE_LEFT_LINK 0x0407C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_FLYINGC_GLANCE_RIGHT_LINK 0x0407C4EC /* Fallback Glance Right button */ +#define DIBUTTON_FLYINGC_GLANCE_UP_LINK 0x0407C4E0 /* Fallback Glance Up button */ +#define DIBUTTON_FLYINGC_GLANCE_DOWN_LINK 0x0407C4E8 /* Fallback Glance Down button */ +#define DIBUTTON_FLYINGC_DEVICE 0x040044FE /* Show input device and controls */ +#define DIBUTTON_FLYINGC_PAUSE 0x040044FC /* Start / Pause / Restart game */ + +/*--- Flight Simulator - Military + Aerial combat is the primary objective ---*/ +#define DIVIRTUAL_FLYING_MILITARY 0x05000000 +#define DIAXIS_FLYINGM_BANK 0x05008A01 /* Bank - Roll ship left / right */ +#define DIAXIS_FLYINGM_PITCH 0x05010A02 /* Pitch - Nose up / down */ +#define DIAXIS_FLYINGM_THROTTLE 0x05039203 /* Throttle - faster / slower */ +#define DIBUTTON_FLYINGM_FIRE 0x05000C01 /* Fire */ +#define DIBUTTON_FLYINGM_WEAPONS 0x05000C02 /* Select next weapon */ +#define DIBUTTON_FLYINGM_TARGET 0x05000C03 /* Selects next available target */ +#define DIBUTTON_FLYINGM_MENU 0x050004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_FLYINGM_GLANCE 0x05004601 /* Look around */ +#define DIBUTTON_FLYINGM_COUNTER 0x05005C04 /* Activate counter measures */ +#define DIAXIS_FLYINGM_RUDDER 0x05024A04 /* Rudder - Yaw ship left/right */ +#define DIAXIS_FLYINGM_BRAKE 0x05046205 /* Brake-axis */ +#define DIBUTTON_FLYINGM_VIEW 0x05006405 /* Cycle through view options */ +#define DIBUTTON_FLYINGM_DISPLAY 0x05006406 /* Select next dashboard option */ +#define DIAXIS_FLYINGM_FLAPS 0x05055206 /* Flaps */ +#define DIBUTTON_FLYINGM_FLAPSUP 0x05005407 /* Increment stepping up until fully retracted */ +#define DIBUTTON_FLYINGM_FLAPSDOWN 0x05005408 /* Decrement stepping down until fully extended */ +#define DIBUTTON_FLYINGM_FIRESECONDARY 0x05004C09 /* Alternative fire button */ +#define DIBUTTON_FLYINGM_GEAR 0x0500640A /* Gear up / down */ +#define DIBUTTON_FLYINGM_BRAKE_LINK 0x050464E0 /* Fallback brake button */ +#define DIBUTTON_FLYINGM_FASTER_LINK 0x0503D4E0 /* Fallback throttle up button */ +#define DIBUTTON_FLYINGM_SLOWER_LINK 0x0503D4E8 /* Fallback throttle down button */ +#define DIBUTTON_FLYINGM_GLANCE_LEFT_LINK 0x0507C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_FLYINGM_GLANCE_RIGHT_LINK 0x0507C4EC /* Fallback Glance Right button */ +#define DIBUTTON_FLYINGM_GLANCE_UP_LINK 0x0507C4E0 /* Fallback Glance Up button */ +#define DIBUTTON_FLYINGM_GLANCE_DOWN_LINK 0x0507C4E8 /* Fallback Glance Down button */ +#define DIBUTTON_FLYINGM_DEVICE 0x050044FE /* Show input device and controls */ +#define DIBUTTON_FLYINGM_PAUSE 0x050044FC /* Start / Pause / Restart game */ + +/*--- Flight Simulator - Combat Helicopter + Combat from helicopter is primary objective ---*/ +#define DIVIRTUAL_FLYING_HELICOPTER 0x06000000 +#define DIAXIS_FLYINGH_BANK 0x06008A01 /* Bank - Roll ship left / right */ +#define DIAXIS_FLYINGH_PITCH 0x06010A02 /* Pitch - Nose up / down */ +#define DIAXIS_FLYINGH_COLLECTIVE 0x06018A03 /* Collective - Blade pitch/power */ +#define DIBUTTON_FLYINGH_FIRE 0x06001401 /* Fire */ +#define DIBUTTON_FLYINGH_WEAPONS 0x06001402 /* Select next weapon */ +#define DIBUTTON_FLYINGH_TARGET 0x06001403 /* Selects next available target */ +#define DIBUTTON_FLYINGH_MENU 0x060004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_FLYINGH_GLANCE 0x06004601 /* Look around */ +#define DIAXIS_FLYINGH_TORQUE 0x06025A04 /* Torque - Rotate ship around left / right axis */ +#define DIAXIS_FLYINGH_THROTTLE 0x0603DA05 /* Throttle */ +#define DIBUTTON_FLYINGH_COUNTER 0x06005404 /* Activate counter measures */ +#define DIBUTTON_FLYINGH_VIEW 0x06006405 /* Cycle through view options */ +#define DIBUTTON_FLYINGH_GEAR 0x06006406 /* Gear up / down */ +#define DIBUTTON_FLYINGH_FIRESECONDARY 0x06004C07 /* Alternative fire button */ +#define DIBUTTON_FLYINGH_FASTER_LINK 0x0603DCE0 /* Fallback throttle up button */ +#define DIBUTTON_FLYINGH_SLOWER_LINK 0x0603DCE8 /* Fallback throttle down button */ +#define DIBUTTON_FLYINGH_GLANCE_LEFT_LINK 0x0607C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_FLYINGH_GLANCE_RIGHT_LINK 0x0607C4EC /* Fallback Glance Right button */ +#define DIBUTTON_FLYINGH_GLANCE_UP_LINK 0x0607C4E0 /* Fallback Glance Up button */ +#define DIBUTTON_FLYINGH_GLANCE_DOWN_LINK 0x0607C4E8 /* Fallback Glance Down button */ +#define DIBUTTON_FLYINGH_DEVICE 0x060044FE /* Show input device and controls */ +#define DIBUTTON_FLYINGH_PAUSE 0x060044FC /* Start / Pause / Restart game */ + +/*--- Space Simulator - Combat + Space Simulator with weapons ---*/ +#define DIVIRTUAL_SPACESIM 0x07000000 +#define DIAXIS_SPACESIM_LATERAL 0x07008201 /* Move ship left / right */ +#define DIAXIS_SPACESIM_MOVE 0x07010202 /* Move ship forward/backward */ +#define DIAXIS_SPACESIM_THROTTLE 0x07038203 /* Throttle - Engine speed */ +#define DIBUTTON_SPACESIM_FIRE 0x07000401 /* Fire */ +#define DIBUTTON_SPACESIM_WEAPONS 0x07000402 /* Select next weapon */ +#define DIBUTTON_SPACESIM_TARGET 0x07000403 /* Selects next available target */ +#define DIBUTTON_SPACESIM_MENU 0x070004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_SPACESIM_GLANCE 0x07004601 /* Look around */ +#define DIAXIS_SPACESIM_CLIMB 0x0701C204 /* Climb - Pitch ship up/down */ +#define DIAXIS_SPACESIM_ROTATE 0x07024205 /* Rotate - Turn ship left/right */ +#define DIBUTTON_SPACESIM_VIEW 0x07004404 /* Cycle through view options */ +#define DIBUTTON_SPACESIM_DISPLAY 0x07004405 /* Select next dashboard / heads up display option */ +#define DIBUTTON_SPACESIM_RAISE 0x07004406 /* Raise ship while maintaining current pitch */ +#define DIBUTTON_SPACESIM_LOWER 0x07004407 /* Lower ship while maintaining current pitch */ +#define DIBUTTON_SPACESIM_GEAR 0x07004408 /* Gear up / down */ +#define DIBUTTON_SPACESIM_FIRESECONDARY 0x07004409 /* Alternative fire button */ +#define DIBUTTON_SPACESIM_LEFT_LINK 0x0700C4E4 /* Fallback move left button */ +#define DIBUTTON_SPACESIM_RIGHT_LINK 0x0700C4EC /* Fallback move right button */ +#define DIBUTTON_SPACESIM_FORWARD_LINK 0x070144E0 /* Fallback move forward button */ +#define DIBUTTON_SPACESIM_BACKWARD_LINK 0x070144E8 /* Fallback move backwards button */ +#define DIBUTTON_SPACESIM_FASTER_LINK 0x0703C4E0 /* Fallback throttle up button */ +#define DIBUTTON_SPACESIM_SLOWER_LINK 0x0703C4E8 /* Fallback throttle down button */ +#define DIBUTTON_SPACESIM_TURN_LEFT_LINK 0x070244E4 /* Fallback turn left button */ +#define DIBUTTON_SPACESIM_TURN_RIGHT_LINK 0x070244EC /* Fallback turn right button */ +#define DIBUTTON_SPACESIM_GLANCE_LEFT_LINK 0x0707C4E4 /* Fallback Glance Left button */ +#define DIBUTTON_SPACESIM_GLANCE_RIGHT_LINK 0x0707C4EC /* Fallback Glance Right button */ +#define DIBUTTON_SPACESIM_GLANCE_UP_LINK 0x0707C4E0 /* Fallback Glance Up button */ +#define DIBUTTON_SPACESIM_GLANCE_DOWN_LINK 0x0707C4E8 /* Fallback Glance Down button */ +#define DIBUTTON_SPACESIM_DEVICE 0x070044FE /* Show input device and controls */ +#define DIBUTTON_SPACESIM_PAUSE 0x070044FC /* Start / Pause / Restart game */ + +/*--- Fighting - First Person + Hand to Hand combat is primary objective ---*/ +#define DIVIRTUAL_FIGHTING_HAND2HAND 0x08000000 +#define DIAXIS_FIGHTINGH_LATERAL 0x08008201 /* Sidestep left/right */ +#define DIAXIS_FIGHTINGH_MOVE 0x08010202 /* Move forward/backward */ +#define DIBUTTON_FIGHTINGH_PUNCH 0x08000401 /* Punch */ +#define DIBUTTON_FIGHTINGH_KICK 0x08000402 /* Kick */ +#define DIBUTTON_FIGHTINGH_BLOCK 0x08000403 /* Block */ +#define DIBUTTON_FIGHTINGH_CROUCH 0x08000404 /* Crouch */ +#define DIBUTTON_FIGHTINGH_JUMP 0x08000405 /* Jump */ +#define DIBUTTON_FIGHTINGH_SPECIAL1 0x08000406 /* Apply first special move */ +#define DIBUTTON_FIGHTINGH_SPECIAL2 0x08000407 /* Apply second special move */ +#define DIBUTTON_FIGHTINGH_MENU 0x080004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_FIGHTINGH_SELECT 0x08004408 /* Select special move */ +#define DIHATSWITCH_FIGHTINGH_SLIDE 0x08004601 /* Look around */ +#define DIBUTTON_FIGHTINGH_DISPLAY 0x08004409 /* Shows next on-screen display option */ +#define DIAXIS_FIGHTINGH_ROTATE 0x08024203 /* Rotate - Turn body left/right */ +#define DIBUTTON_FIGHTINGH_DODGE 0x0800440A /* Dodge */ +#define DIBUTTON_FIGHTINGH_LEFT_LINK 0x0800C4E4 /* Fallback left sidestep button */ +#define DIBUTTON_FIGHTINGH_RIGHT_LINK 0x0800C4EC /* Fallback right sidestep button */ +#define DIBUTTON_FIGHTINGH_FORWARD_LINK 0x080144E0 /* Fallback forward button */ +#define DIBUTTON_FIGHTINGH_BACKWARD_LINK 0x080144E8 /* Fallback backward button */ +#define DIBUTTON_FIGHTINGH_DEVICE 0x080044FE /* Show input device and controls */ +#define DIBUTTON_FIGHTINGH_PAUSE 0x080044FC /* Start / Pause / Restart game */ + +/*--- Fighting - First Person Shooting + Navigation and combat are primary objectives ---*/ +#define DIVIRTUAL_FIGHTING_FPS 0x09000000 +#define DIAXIS_FPS_ROTATE 0x09008201 /* Rotate character left/right */ +#define DIAXIS_FPS_MOVE 0x09010202 /* Move forward/backward */ +#define DIBUTTON_FPS_FIRE 0x09000401 /* Fire */ +#define DIBUTTON_FPS_WEAPONS 0x09000402 /* Select next weapon */ +#define DIBUTTON_FPS_APPLY 0x09000403 /* Use item */ +#define DIBUTTON_FPS_SELECT 0x09000404 /* Select next inventory item */ +#define DIBUTTON_FPS_CROUCH 0x09000405 /* Crouch/ climb down/ swim down */ +#define DIBUTTON_FPS_JUMP 0x09000406 /* Jump/ climb up/ swim up */ +#define DIAXIS_FPS_LOOKUPDOWN 0x09018203 /* Look up / down */ +#define DIBUTTON_FPS_STRAFE 0x09000407 /* Enable strafing while active */ +#define DIBUTTON_FPS_MENU 0x090004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_FPS_GLANCE 0x09004601 /* Look around */ +#define DIBUTTON_FPS_DISPLAY 0x09004408 /* Shows next on-screen display option/ map */ +#define DIAXIS_FPS_SIDESTEP 0x09024204 /* Sidestep */ +#define DIBUTTON_FPS_DODGE 0x09004409 /* Dodge */ +#define DIBUTTON_FPS_GLANCEL 0x0900440A /* Glance Left */ +#define DIBUTTON_FPS_GLANCER 0x0900440B /* Glance Right */ +#define DIBUTTON_FPS_FIRESECONDARY 0x0900440C /* Alternative fire button */ +#define DIBUTTON_FPS_ROTATE_LEFT_LINK 0x0900C4E4 /* Fallback rotate left button */ +#define DIBUTTON_FPS_ROTATE_RIGHT_LINK 0x0900C4EC /* Fallback rotate right button */ +#define DIBUTTON_FPS_FORWARD_LINK 0x090144E0 /* Fallback forward button */ +#define DIBUTTON_FPS_BACKWARD_LINK 0x090144E8 /* Fallback backward button */ +#define DIBUTTON_FPS_GLANCE_UP_LINK 0x0901C4E0 /* Fallback look up button */ +#define DIBUTTON_FPS_GLANCE_DOWN_LINK 0x0901C4E8 /* Fallback look down button */ +#define DIBUTTON_FPS_STEP_LEFT_LINK 0x090244E4 /* Fallback step left button */ +#define DIBUTTON_FPS_STEP_RIGHT_LINK 0x090244EC /* Fallback step right button */ +#define DIBUTTON_FPS_DEVICE 0x090044FE /* Show input device and controls */ +#define DIBUTTON_FPS_PAUSE 0x090044FC /* Start / Pause / Restart game */ + +/*--- Fighting - Third Person action + Perspective of camera is behind the main character ---*/ +#define DIVIRTUAL_FIGHTING_THIRDPERSON 0x0A000000 +#define DIAXIS_TPS_TURN 0x0A020201 /* Turn left/right */ +#define DIAXIS_TPS_MOVE 0x0A010202 /* Move forward/backward */ +#define DIBUTTON_TPS_RUN 0x0A000401 /* Run or walk toggle switch */ +#define DIBUTTON_TPS_ACTION 0x0A000402 /* Action Button */ +#define DIBUTTON_TPS_SELECT 0x0A000403 /* Select next weapon */ +#define DIBUTTON_TPS_USE 0x0A000404 /* Use inventory item currently selected */ +#define DIBUTTON_TPS_JUMP 0x0A000405 /* Character Jumps */ +#define DIBUTTON_TPS_MENU 0x0A0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_TPS_GLANCE 0x0A004601 /* Look around */ +#define DIBUTTON_TPS_VIEW 0x0A004406 /* Select camera view */ +#define DIBUTTON_TPS_STEPLEFT 0x0A004407 /* Character takes a left step */ +#define DIBUTTON_TPS_STEPRIGHT 0x0A004408 /* Character takes a right step */ +#define DIAXIS_TPS_STEP 0x0A00C203 /* Character steps left/right */ +#define DIBUTTON_TPS_DODGE 0x0A004409 /* Character dodges or ducks */ +#define DIBUTTON_TPS_INVENTORY 0x0A00440A /* Cycle through inventory */ +#define DIBUTTON_TPS_TURN_LEFT_LINK 0x0A0244E4 /* Fallback turn left button */ +#define DIBUTTON_TPS_TURN_RIGHT_LINK 0x0A0244EC /* Fallback turn right button */ +#define DIBUTTON_TPS_FORWARD_LINK 0x0A0144E0 /* Fallback forward button */ +#define DIBUTTON_TPS_BACKWARD_LINK 0x0A0144E8 /* Fallback backward button */ +#define DIBUTTON_TPS_GLANCE_UP_LINK 0x0A07C4E0 /* Fallback look up button */ +#define DIBUTTON_TPS_GLANCE_DOWN_LINK 0x0A07C4E8 /* Fallback look down button */ +#define DIBUTTON_TPS_GLANCE_LEFT_LINK 0x0A07C4E4 /* Fallback glance up button */ +#define DIBUTTON_TPS_GLANCE_RIGHT_LINK 0x0A07C4EC /* Fallback glance right button */ +#define DIBUTTON_TPS_DEVICE 0x0A0044FE /* Show input device and controls */ +#define DIBUTTON_TPS_PAUSE 0x0A0044FC /* Start / Pause / Restart game */ + +/*--- Strategy - Role Playing + Navigation and problem solving are primary actions ---*/ +#define DIVIRTUAL_STRATEGY_ROLEPLAYING 0x0B000000 +#define DIAXIS_STRATEGYR_LATERAL 0x0B008201 /* sidestep - left/right */ +#define DIAXIS_STRATEGYR_MOVE 0x0B010202 /* move forward/backward */ +#define DIBUTTON_STRATEGYR_GET 0x0B000401 /* Acquire item */ +#define DIBUTTON_STRATEGYR_APPLY 0x0B000402 /* Use selected item */ +#define DIBUTTON_STRATEGYR_SELECT 0x0B000403 /* Select nextitem */ +#define DIBUTTON_STRATEGYR_ATTACK 0x0B000404 /* Attack */ +#define DIBUTTON_STRATEGYR_CAST 0x0B000405 /* Cast Spell */ +#define DIBUTTON_STRATEGYR_CROUCH 0x0B000406 /* Crouch */ +#define DIBUTTON_STRATEGYR_JUMP 0x0B000407 /* Jump */ +#define DIBUTTON_STRATEGYR_MENU 0x0B0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_STRATEGYR_GLANCE 0x0B004601 /* Look around */ +#define DIBUTTON_STRATEGYR_MAP 0x0B004408 /* Cycle through map options */ +#define DIBUTTON_STRATEGYR_DISPLAY 0x0B004409 /* Shows next on-screen display option */ +#define DIAXIS_STRATEGYR_ROTATE 0x0B024203 /* Turn body left/right */ +#define DIBUTTON_STRATEGYR_LEFT_LINK 0x0B00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_STRATEGYR_RIGHT_LINK 0x0B00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_STRATEGYR_FORWARD_LINK 0x0B0144E0 /* Fallback move forward button */ +#define DIBUTTON_STRATEGYR_BACK_LINK 0x0B0144E8 /* Fallback move backward button */ +#define DIBUTTON_STRATEGYR_ROTATE_LEFT_LINK 0x0B0244E4 /* Fallback turn body left button */ +#define DIBUTTON_STRATEGYR_ROTATE_RIGHT_LINK 0x0B0244EC /* Fallback turn body right button */ +#define DIBUTTON_STRATEGYR_DEVICE 0x0B0044FE /* Show input device and controls */ +#define DIBUTTON_STRATEGYR_PAUSE 0x0B0044FC /* Start / Pause / Restart game */ + +/*--- Strategy - Turn based + Navigation and problem solving are primary actions ---*/ +#define DIVIRTUAL_STRATEGY_TURN 0x0C000000 +#define DIAXIS_STRATEGYT_LATERAL 0x0C008201 /* Sidestep left/right */ +#define DIAXIS_STRATEGYT_MOVE 0x0C010202 /* Move forward/backwards */ +#define DIBUTTON_STRATEGYT_SELECT 0x0C000401 /* Select unit or object */ +#define DIBUTTON_STRATEGYT_INSTRUCT 0x0C000402 /* Cycle through instructions */ +#define DIBUTTON_STRATEGYT_APPLY 0x0C000403 /* Apply selected instruction */ +#define DIBUTTON_STRATEGYT_TEAM 0x0C000404 /* Select next team / cycle through all */ +#define DIBUTTON_STRATEGYT_TURN 0x0C000405 /* Indicate turn over */ +#define DIBUTTON_STRATEGYT_MENU 0x0C0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_STRATEGYT_ZOOM 0x0C004406 /* Zoom - in / out */ +#define DIBUTTON_STRATEGYT_MAP 0x0C004407 /* cycle through map options */ +#define DIBUTTON_STRATEGYT_DISPLAY 0x0C004408 /* shows next on-screen display options */ +#define DIBUTTON_STRATEGYT_LEFT_LINK 0x0C00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_STRATEGYT_RIGHT_LINK 0x0C00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_STRATEGYT_FORWARD_LINK 0x0C0144E0 /* Fallback move forward button */ +#define DIBUTTON_STRATEGYT_BACK_LINK 0x0C0144E8 /* Fallback move back button */ +#define DIBUTTON_STRATEGYT_DEVICE 0x0C0044FE /* Show input device and controls */ +#define DIBUTTON_STRATEGYT_PAUSE 0x0C0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Hunting + Hunting ---*/ +#define DIVIRTUAL_SPORTS_HUNTING 0x0D000000 +#define DIAXIS_HUNTING_LATERAL 0x0D008201 /* sidestep left/right */ +#define DIAXIS_HUNTING_MOVE 0x0D010202 /* move forward/backwards */ +#define DIBUTTON_HUNTING_FIRE 0x0D000401 /* Fire selected weapon */ +#define DIBUTTON_HUNTING_AIM 0x0D000402 /* Select aim/move */ +#define DIBUTTON_HUNTING_WEAPON 0x0D000403 /* Select next weapon */ +#define DIBUTTON_HUNTING_BINOCULAR 0x0D000404 /* Look through Binoculars */ +#define DIBUTTON_HUNTING_CALL 0x0D000405 /* Make animal call */ +#define DIBUTTON_HUNTING_MAP 0x0D000406 /* View Map */ +#define DIBUTTON_HUNTING_SPECIAL 0x0D000407 /* Special game operation */ +#define DIBUTTON_HUNTING_MENU 0x0D0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_HUNTING_GLANCE 0x0D004601 /* Look around */ +#define DIBUTTON_HUNTING_DISPLAY 0x0D004408 /* show next on-screen display option */ +#define DIAXIS_HUNTING_ROTATE 0x0D024203 /* Turn body left/right */ +#define DIBUTTON_HUNTING_CROUCH 0x0D004409 /* Crouch/ Climb / Swim down */ +#define DIBUTTON_HUNTING_JUMP 0x0D00440A /* Jump/ Climb up / Swim up */ +#define DIBUTTON_HUNTING_FIRESECONDARY 0x0D00440B /* Alternative fire button */ +#define DIBUTTON_HUNTING_LEFT_LINK 0x0D00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_HUNTING_RIGHT_LINK 0x0D00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_HUNTING_FORWARD_LINK 0x0D0144E0 /* Fallback move forward button */ +#define DIBUTTON_HUNTING_BACK_LINK 0x0D0144E8 /* Fallback move back button */ +#define DIBUTTON_HUNTING_ROTATE_LEFT_LINK 0x0D0244E4 /* Fallback turn body left button */ +#define DIBUTTON_HUNTING_ROTATE_RIGHT_LINK 0x0D0244EC /* Fallback turn body right button */ +#define DIBUTTON_HUNTING_DEVICE 0x0D0044FE /* Show input device and controls */ +#define DIBUTTON_HUNTING_PAUSE 0x0D0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Fishing + Catching Fish is primary objective ---*/ +#define DIVIRTUAL_SPORTS_FISHING 0x0E000000 +#define DIAXIS_FISHING_LATERAL 0x0E008201 /* sidestep left/right */ +#define DIAXIS_FISHING_MOVE 0x0E010202 /* move forward/backwards */ +#define DIBUTTON_FISHING_CAST 0x0E000401 /* Cast line */ +#define DIBUTTON_FISHING_TYPE 0x0E000402 /* Select cast type */ +#define DIBUTTON_FISHING_BINOCULAR 0x0E000403 /* Look through Binocular */ +#define DIBUTTON_FISHING_BAIT 0x0E000404 /* Select type of Bait */ +#define DIBUTTON_FISHING_MAP 0x0E000405 /* View Map */ +#define DIBUTTON_FISHING_MENU 0x0E0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_FISHING_GLANCE 0x0E004601 /* Look around */ +#define DIBUTTON_FISHING_DISPLAY 0x0E004406 /* Show next on-screen display option */ +#define DIAXIS_FISHING_ROTATE 0x0E024203 /* Turn character left / right */ +#define DIBUTTON_FISHING_CROUCH 0x0E004407 /* Crouch/ Climb / Swim down */ +#define DIBUTTON_FISHING_JUMP 0x0E004408 /* Jump/ Climb up / Swim up */ +#define DIBUTTON_FISHING_LEFT_LINK 0x0E00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_FISHING_RIGHT_LINK 0x0E00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_FISHING_FORWARD_LINK 0x0E0144E0 /* Fallback move forward button */ +#define DIBUTTON_FISHING_BACK_LINK 0x0E0144E8 /* Fallback move back button */ +#define DIBUTTON_FISHING_ROTATE_LEFT_LINK 0x0E0244E4 /* Fallback turn body left button */ +#define DIBUTTON_FISHING_ROTATE_RIGHT_LINK 0x0E0244EC /* Fallback turn body right button */ +#define DIBUTTON_FISHING_DEVICE 0x0E0044FE /* Show input device and controls */ +#define DIBUTTON_FISHING_PAUSE 0x0E0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Baseball - Batting + Batter control is primary objective ---*/ +#define DIVIRTUAL_SPORTS_BASEBALL_BAT 0x0F000000 +#define DIAXIS_BASEBALLB_LATERAL 0x0F008201 /* Aim left / right */ +#define DIAXIS_BASEBALLB_MOVE 0x0F010202 /* Aim up / down */ +#define DIBUTTON_BASEBALLB_SELECT 0x0F000401 /* cycle through swing options */ +#define DIBUTTON_BASEBALLB_NORMAL 0x0F000402 /* normal swing */ +#define DIBUTTON_BASEBALLB_POWER 0x0F000403 /* swing for the fence */ +#define DIBUTTON_BASEBALLB_BUNT 0x0F000404 /* bunt */ +#define DIBUTTON_BASEBALLB_STEAL 0x0F000405 /* Base runner attempts to steal a base */ +#define DIBUTTON_BASEBALLB_BURST 0x0F000406 /* Base runner invokes burst of speed */ +#define DIBUTTON_BASEBALLB_SLIDE 0x0F000407 /* Base runner slides into base */ +#define DIBUTTON_BASEBALLB_CONTACT 0x0F000408 /* Contact swing */ +#define DIBUTTON_BASEBALLB_MENU 0x0F0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_BASEBALLB_NOSTEAL 0x0F004409 /* Base runner goes back to a base */ +#define DIBUTTON_BASEBALLB_BOX 0x0F00440A /* Enter or exit batting box */ +#define DIBUTTON_BASEBALLB_LEFT_LINK 0x0F00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_BASEBALLB_RIGHT_LINK 0x0F00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_BASEBALLB_FORWARD_LINK 0x0F0144E0 /* Fallback move forward button */ +#define DIBUTTON_BASEBALLB_BACK_LINK 0x0F0144E8 /* Fallback move back button */ +#define DIBUTTON_BASEBALLB_DEVICE 0x0F0044FE /* Show input device and controls */ +#define DIBUTTON_BASEBALLB_PAUSE 0x0F0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Baseball - Pitching + Pitcher control is primary objective ---*/ +#define DIVIRTUAL_SPORTS_BASEBALL_PITCH 0x10000000 +#define DIAXIS_BASEBALLP_LATERAL 0x10008201 /* Aim left / right */ +#define DIAXIS_BASEBALLP_MOVE 0x10010202 /* Aim up / down */ +#define DIBUTTON_BASEBALLP_SELECT 0x10000401 /* cycle through pitch selections */ +#define DIBUTTON_BASEBALLP_PITCH 0x10000402 /* throw pitch */ +#define DIBUTTON_BASEBALLP_BASE 0x10000403 /* select base to throw to */ +#define DIBUTTON_BASEBALLP_THROW 0x10000404 /* throw to base */ +#define DIBUTTON_BASEBALLP_FAKE 0x10000405 /* Fake a throw to a base */ +#define DIBUTTON_BASEBALLP_MENU 0x100004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_BASEBALLP_WALK 0x10004406 /* Throw intentional walk / pitch out */ +#define DIBUTTON_BASEBALLP_LOOK 0x10004407 /* Look at runners on bases */ +#define DIBUTTON_BASEBALLP_LEFT_LINK 0x1000C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_BASEBALLP_RIGHT_LINK 0x1000C4EC /* Fallback sidestep right button */ +#define DIBUTTON_BASEBALLP_FORWARD_LINK 0x100144E0 /* Fallback move forward button */ +#define DIBUTTON_BASEBALLP_BACK_LINK 0x100144E8 /* Fallback move back button */ +#define DIBUTTON_BASEBALLP_DEVICE 0x100044FE /* Show input device and controls */ +#define DIBUTTON_BASEBALLP_PAUSE 0x100044FC /* Start / Pause / Restart game */ + +/*--- Sports - Baseball - Fielding + Fielder control is primary objective ---*/ +#define DIVIRTUAL_SPORTS_BASEBALL_FIELD 0x11000000 +#define DIAXIS_BASEBALLF_LATERAL 0x11008201 /* Aim left / right */ +#define DIAXIS_BASEBALLF_MOVE 0x11010202 /* Aim up / down */ +#define DIBUTTON_BASEBALLF_NEAREST 0x11000401 /* Switch to fielder nearest to the ball */ +#define DIBUTTON_BASEBALLF_THROW1 0x11000402 /* Make conservative throw */ +#define DIBUTTON_BASEBALLF_THROW2 0x11000403 /* Make aggressive throw */ +#define DIBUTTON_BASEBALLF_BURST 0x11000404 /* Invoke burst of speed */ +#define DIBUTTON_BASEBALLF_JUMP 0x11000405 /* Jump to catch ball */ +#define DIBUTTON_BASEBALLF_DIVE 0x11000406 /* Dive to catch ball */ +#define DIBUTTON_BASEBALLF_MENU 0x110004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_BASEBALLF_SHIFTIN 0x11004407 /* Shift the infield positioning */ +#define DIBUTTON_BASEBALLF_SHIFTOUT 0x11004408 /* Shift the outfield positioning */ +#define DIBUTTON_BASEBALLF_AIM_LEFT_LINK 0x1100C4E4 /* Fallback aim left button */ +#define DIBUTTON_BASEBALLF_AIM_RIGHT_LINK 0x1100C4EC /* Fallback aim right button */ +#define DIBUTTON_BASEBALLF_FORWARD_LINK 0x110144E0 /* Fallback move forward button */ +#define DIBUTTON_BASEBALLF_BACK_LINK 0x110144E8 /* Fallback move back button */ +#define DIBUTTON_BASEBALLF_DEVICE 0x110044FE /* Show input device and controls */ +#define DIBUTTON_BASEBALLF_PAUSE 0x110044FC /* Start / Pause / Restart game */ + +/*--- Sports - Basketball - Offense + Offense ---*/ +#define DIVIRTUAL_SPORTS_BASKETBALL_OFFENSE 0x12000000 +#define DIAXIS_BBALLO_LATERAL 0x12008201 /* left / right */ +#define DIAXIS_BBALLO_MOVE 0x12010202 /* up / down */ +#define DIBUTTON_BBALLO_SHOOT 0x12000401 /* shoot basket */ +#define DIBUTTON_BBALLO_DUNK 0x12000402 /* dunk basket */ +#define DIBUTTON_BBALLO_PASS 0x12000403 /* throw pass */ +#define DIBUTTON_BBALLO_FAKE 0x12000404 /* fake shot or pass */ +#define DIBUTTON_BBALLO_SPECIAL 0x12000405 /* apply special move */ +#define DIBUTTON_BBALLO_PLAYER 0x12000406 /* select next player */ +#define DIBUTTON_BBALLO_BURST 0x12000407 /* invoke burst */ +#define DIBUTTON_BBALLO_CALL 0x12000408 /* call for ball / pass to me */ +#define DIBUTTON_BBALLO_MENU 0x120004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_BBALLO_GLANCE 0x12004601 /* scroll view */ +#define DIBUTTON_BBALLO_SCREEN 0x12004409 /* Call for screen */ +#define DIBUTTON_BBALLO_PLAY 0x1200440A /* Call for specific offensive play */ +#define DIBUTTON_BBALLO_JAB 0x1200440B /* Initiate fake drive to basket */ +#define DIBUTTON_BBALLO_POST 0x1200440C /* Perform post move */ +#define DIBUTTON_BBALLO_TIMEOUT 0x1200440D /* Time Out */ +#define DIBUTTON_BBALLO_SUBSTITUTE 0x1200440E /* substitute one player for another */ +#define DIBUTTON_BBALLO_LEFT_LINK 0x1200C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_BBALLO_RIGHT_LINK 0x1200C4EC /* Fallback sidestep right button */ +#define DIBUTTON_BBALLO_FORWARD_LINK 0x120144E0 /* Fallback move forward button */ +#define DIBUTTON_BBALLO_BACK_LINK 0x120144E8 /* Fallback move back button */ +#define DIBUTTON_BBALLO_DEVICE 0x120044FE /* Show input device and controls */ +#define DIBUTTON_BBALLO_PAUSE 0x120044FC /* Start / Pause / Restart game */ + +/*--- Sports - Basketball - Defense + Defense ---*/ +#define DIVIRTUAL_SPORTS_BASKETBALL_DEFENSE 0x13000000 +#define DIAXIS_BBALLD_LATERAL 0x13008201 /* left / right */ +#define DIAXIS_BBALLD_MOVE 0x13010202 /* up / down */ +#define DIBUTTON_BBALLD_JUMP 0x13000401 /* jump to block shot */ +#define DIBUTTON_BBALLD_STEAL 0x13000402 /* attempt to steal ball */ +#define DIBUTTON_BBALLD_FAKE 0x13000403 /* fake block or steal */ +#define DIBUTTON_BBALLD_SPECIAL 0x13000404 /* apply special move */ +#define DIBUTTON_BBALLD_PLAYER 0x13000405 /* select next player */ +#define DIBUTTON_BBALLD_BURST 0x13000406 /* invoke burst */ +#define DIBUTTON_BBALLD_PLAY 0x13000407 /* call for specific defensive play */ +#define DIBUTTON_BBALLD_MENU 0x130004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_BBALLD_GLANCE 0x13004601 /* scroll view */ +#define DIBUTTON_BBALLD_TIMEOUT 0x13004408 /* Time Out */ +#define DIBUTTON_BBALLD_SUBSTITUTE 0x13004409 /* substitute one player for another */ +#define DIBUTTON_BBALLD_LEFT_LINK 0x1300C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_BBALLD_RIGHT_LINK 0x1300C4EC /* Fallback sidestep right button */ +#define DIBUTTON_BBALLD_FORWARD_LINK 0x130144E0 /* Fallback move forward button */ +#define DIBUTTON_BBALLD_BACK_LINK 0x130144E8 /* Fallback move back button */ +#define DIBUTTON_BBALLD_DEVICE 0x130044FE /* Show input device and controls */ +#define DIBUTTON_BBALLD_PAUSE 0x130044FC /* Start / Pause / Restart game */ + +/*--- Sports - Football - Play + Play selection ---*/ +#define DIVIRTUAL_SPORTS_FOOTBALL_FIELD 0x14000000 +#define DIBUTTON_FOOTBALLP_PLAY 0x14000401 /* cycle through available plays */ +#define DIBUTTON_FOOTBALLP_SELECT 0x14000402 /* select play */ +#define DIBUTTON_FOOTBALLP_HELP 0x14000403 /* Bring up pop-up help */ +#define DIBUTTON_FOOTBALLP_MENU 0x140004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_FOOTBALLP_DEVICE 0x140044FE /* Show input device and controls */ +#define DIBUTTON_FOOTBALLP_PAUSE 0x140044FC /* Start / Pause / Restart game */ + +/*--- Sports - Football - QB + Offense: Quarterback / Kicker ---*/ +#define DIVIRTUAL_SPORTS_FOOTBALL_QBCK 0x15000000 +#define DIAXIS_FOOTBALLQ_LATERAL 0x15008201 /* Move / Aim: left / right */ +#define DIAXIS_FOOTBALLQ_MOVE 0x15010202 /* Move / Aim: up / down */ +#define DIBUTTON_FOOTBALLQ_SELECT 0x15000401 /* Select */ +#define DIBUTTON_FOOTBALLQ_SNAP 0x15000402 /* snap ball - start play */ +#define DIBUTTON_FOOTBALLQ_JUMP 0x15000403 /* jump over defender */ +#define DIBUTTON_FOOTBALLQ_SLIDE 0x15000404 /* Dive/Slide */ +#define DIBUTTON_FOOTBALLQ_PASS 0x15000405 /* throws pass to receiver */ +#define DIBUTTON_FOOTBALLQ_FAKE 0x15000406 /* pump fake pass or fake kick */ +#define DIBUTTON_FOOTBALLQ_MENU 0x150004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_FOOTBALLQ_FAKESNAP 0x15004407 /* Fake snap */ +#define DIBUTTON_FOOTBALLQ_MOTION 0x15004408 /* Send receivers in motion */ +#define DIBUTTON_FOOTBALLQ_AUDIBLE 0x15004409 /* Change offensive play at line of scrimmage */ +#define DIBUTTON_FOOTBALLQ_LEFT_LINK 0x1500C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_FOOTBALLQ_RIGHT_LINK 0x1500C4EC /* Fallback sidestep right button */ +#define DIBUTTON_FOOTBALLQ_FORWARD_LINK 0x150144E0 /* Fallback move forward button */ +#define DIBUTTON_FOOTBALLQ_BACK_LINK 0x150144E8 /* Fallback move back button */ +#define DIBUTTON_FOOTBALLQ_DEVICE 0x150044FE /* Show input device and controls */ +#define DIBUTTON_FOOTBALLQ_PAUSE 0x150044FC /* Start / Pause / Restart game */ + +/*--- Sports - Football - Offense + Offense - Runner ---*/ +#define DIVIRTUAL_SPORTS_FOOTBALL_OFFENSE 0x16000000 +#define DIAXIS_FOOTBALLO_LATERAL 0x16008201 /* Move / Aim: left / right */ +#define DIAXIS_FOOTBALLO_MOVE 0x16010202 /* Move / Aim: up / down */ +#define DIBUTTON_FOOTBALLO_JUMP 0x16000401 /* jump or hurdle over defender */ +#define DIBUTTON_FOOTBALLO_LEFTARM 0x16000402 /* holds out left arm */ +#define DIBUTTON_FOOTBALLO_RIGHTARM 0x16000403 /* holds out right arm */ +#define DIBUTTON_FOOTBALLO_THROW 0x16000404 /* throw pass or lateral ball to another runner */ +#define DIBUTTON_FOOTBALLO_SPIN 0x16000405 /* Spin to avoid defenders */ +#define DIBUTTON_FOOTBALLO_MENU 0x160004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_FOOTBALLO_JUKE 0x16004406 /* Use special move to avoid defenders */ +#define DIBUTTON_FOOTBALLO_SHOULDER 0x16004407 /* Lower shoulder to run over defenders */ +#define DIBUTTON_FOOTBALLO_TURBO 0x16004408 /* Speed burst past defenders */ +#define DIBUTTON_FOOTBALLO_DIVE 0x16004409 /* Dive over defenders */ +#define DIBUTTON_FOOTBALLO_ZOOM 0x1600440A /* Zoom view in / out */ +#define DIBUTTON_FOOTBALLO_SUBSTITUTE 0x1600440B /* substitute one player for another */ +#define DIBUTTON_FOOTBALLO_LEFT_LINK 0x1600C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_FOOTBALLO_RIGHT_LINK 0x1600C4EC /* Fallback sidestep right button */ +#define DIBUTTON_FOOTBALLO_FORWARD_LINK 0x160144E0 /* Fallback move forward button */ +#define DIBUTTON_FOOTBALLO_BACK_LINK 0x160144E8 /* Fallback move back button */ +#define DIBUTTON_FOOTBALLO_DEVICE 0x160044FE /* Show input device and controls */ +#define DIBUTTON_FOOTBALLO_PAUSE 0x160044FC /* Start / Pause / Restart game */ + +/*--- Sports - Football - Defense + Defense ---*/ +#define DIVIRTUAL_SPORTS_FOOTBALL_DEFENSE 0x17000000 +#define DIAXIS_FOOTBALLD_LATERAL 0x17008201 /* Move / Aim: left / right */ +#define DIAXIS_FOOTBALLD_MOVE 0x17010202 /* Move / Aim: up / down */ +#define DIBUTTON_FOOTBALLD_PLAY 0x17000401 /* cycle through available plays */ +#define DIBUTTON_FOOTBALLD_SELECT 0x17000402 /* select player closest to the ball */ +#define DIBUTTON_FOOTBALLD_JUMP 0x17000403 /* jump to intercept or block */ +#define DIBUTTON_FOOTBALLD_TACKLE 0x17000404 /* tackler runner */ +#define DIBUTTON_FOOTBALLD_FAKE 0x17000405 /* hold down to fake tackle or intercept */ +#define DIBUTTON_FOOTBALLD_SUPERTACKLE 0x17000406 /* Initiate special tackle */ +#define DIBUTTON_FOOTBALLD_MENU 0x170004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_FOOTBALLD_SPIN 0x17004407 /* Spin to beat offensive line */ +#define DIBUTTON_FOOTBALLD_SWIM 0x17004408 /* Swim to beat the offensive line */ +#define DIBUTTON_FOOTBALLD_BULLRUSH 0x17004409 /* Bull rush the offensive line */ +#define DIBUTTON_FOOTBALLD_RIP 0x1700440A /* Rip the offensive line */ +#define DIBUTTON_FOOTBALLD_AUDIBLE 0x1700440B /* Change defensive play at the line of scrimmage */ +#define DIBUTTON_FOOTBALLD_ZOOM 0x1700440C /* Zoom view in / out */ +#define DIBUTTON_FOOTBALLD_SUBSTITUTE 0x1700440D /* substitute one player for another */ +#define DIBUTTON_FOOTBALLD_LEFT_LINK 0x1700C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_FOOTBALLD_RIGHT_LINK 0x1700C4EC /* Fallback sidestep right button */ +#define DIBUTTON_FOOTBALLD_FORWARD_LINK 0x170144E0 /* Fallback move forward button */ +#define DIBUTTON_FOOTBALLD_BACK_LINK 0x170144E8 /* Fallback move back button */ +#define DIBUTTON_FOOTBALLD_DEVICE 0x170044FE /* Show input device and controls */ +#define DIBUTTON_FOOTBALLD_PAUSE 0x170044FC /* Start / Pause / Restart game */ + +/*--- Sports - Golf + ---*/ +#define DIVIRTUAL_SPORTS_GOLF 0x18000000 +#define DIAXIS_GOLF_LATERAL 0x18008201 /* Move / Aim: left / right */ +#define DIAXIS_GOLF_MOVE 0x18010202 /* Move / Aim: up / down */ +#define DIBUTTON_GOLF_SWING 0x18000401 /* swing club */ +#define DIBUTTON_GOLF_SELECT 0x18000402 /* cycle between: club / swing strength / ball arc / ball spin */ +#define DIBUTTON_GOLF_UP 0x18000403 /* increase selection */ +#define DIBUTTON_GOLF_DOWN 0x18000404 /* decrease selection */ +#define DIBUTTON_GOLF_TERRAIN 0x18000405 /* shows terrain detail */ +#define DIBUTTON_GOLF_FLYBY 0x18000406 /* view the hole via a flyby */ +#define DIBUTTON_GOLF_MENU 0x180004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_GOLF_SCROLL 0x18004601 /* scroll view */ +#define DIBUTTON_GOLF_ZOOM 0x18004407 /* Zoom view in / out */ +#define DIBUTTON_GOLF_TIMEOUT 0x18004408 /* Call for time out */ +#define DIBUTTON_GOLF_SUBSTITUTE 0x18004409 /* substitute one player for another */ +#define DIBUTTON_GOLF_LEFT_LINK 0x1800C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_GOLF_RIGHT_LINK 0x1800C4EC /* Fallback sidestep right button */ +#define DIBUTTON_GOLF_FORWARD_LINK 0x180144E0 /* Fallback move forward button */ +#define DIBUTTON_GOLF_BACK_LINK 0x180144E8 /* Fallback move back button */ +#define DIBUTTON_GOLF_DEVICE 0x180044FE /* Show input device and controls */ +#define DIBUTTON_GOLF_PAUSE 0x180044FC /* Start / Pause / Restart game */ + +/*--- Sports - Hockey - Offense + Offense ---*/ +#define DIVIRTUAL_SPORTS_HOCKEY_OFFENSE 0x19000000 +#define DIAXIS_HOCKEYO_LATERAL 0x19008201 /* Move / Aim: left / right */ +#define DIAXIS_HOCKEYO_MOVE 0x19010202 /* Move / Aim: up / down */ +#define DIBUTTON_HOCKEYO_SHOOT 0x19000401 /* Shoot */ +#define DIBUTTON_HOCKEYO_PASS 0x19000402 /* pass the puck */ +#define DIBUTTON_HOCKEYO_BURST 0x19000403 /* invoke speed burst */ +#define DIBUTTON_HOCKEYO_SPECIAL 0x19000404 /* invoke special move */ +#define DIBUTTON_HOCKEYO_FAKE 0x19000405 /* hold down to fake pass or kick */ +#define DIBUTTON_HOCKEYO_MENU 0x190004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_HOCKEYO_SCROLL 0x19004601 /* scroll view */ +#define DIBUTTON_HOCKEYO_ZOOM 0x19004406 /* Zoom view in / out */ +#define DIBUTTON_HOCKEYO_STRATEGY 0x19004407 /* Invoke coaching menu for strategy help */ +#define DIBUTTON_HOCKEYO_TIMEOUT 0x19004408 /* Call for time out */ +#define DIBUTTON_HOCKEYO_SUBSTITUTE 0x19004409 /* substitute one player for another */ +#define DIBUTTON_HOCKEYO_LEFT_LINK 0x1900C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_HOCKEYO_RIGHT_LINK 0x1900C4EC /* Fallback sidestep right button */ +#define DIBUTTON_HOCKEYO_FORWARD_LINK 0x190144E0 /* Fallback move forward button */ +#define DIBUTTON_HOCKEYO_BACK_LINK 0x190144E8 /* Fallback move back button */ +#define DIBUTTON_HOCKEYO_DEVICE 0x190044FE /* Show input device and controls */ +#define DIBUTTON_HOCKEYO_PAUSE 0x190044FC /* Start / Pause / Restart game */ + +/*--- Sports - Hockey - Defense + Defense ---*/ +#define DIVIRTUAL_SPORTS_HOCKEY_DEFENSE 0x1A000000 +#define DIAXIS_HOCKEYD_LATERAL 0x1A008201 /* Move / Aim: left / right */ +#define DIAXIS_HOCKEYD_MOVE 0x1A010202 /* Move / Aim: up / down */ +#define DIBUTTON_HOCKEYD_PLAYER 0x1A000401 /* control player closest to the puck */ +#define DIBUTTON_HOCKEYD_STEAL 0x1A000402 /* attempt steal */ +#define DIBUTTON_HOCKEYD_BURST 0x1A000403 /* speed burst or body check */ +#define DIBUTTON_HOCKEYD_BLOCK 0x1A000404 /* block puck */ +#define DIBUTTON_HOCKEYD_FAKE 0x1A000405 /* hold down to fake tackle or intercept */ +#define DIBUTTON_HOCKEYD_MENU 0x1A0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_HOCKEYD_SCROLL 0x1A004601 /* scroll view */ +#define DIBUTTON_HOCKEYD_ZOOM 0x1A004406 /* Zoom view in / out */ +#define DIBUTTON_HOCKEYD_STRATEGY 0x1A004407 /* Invoke coaching menu for strategy help */ +#define DIBUTTON_HOCKEYD_TIMEOUT 0x1A004408 /* Call for time out */ +#define DIBUTTON_HOCKEYD_SUBSTITUTE 0x1A004409 /* substitute one player for another */ +#define DIBUTTON_HOCKEYD_LEFT_LINK 0x1A00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_HOCKEYD_RIGHT_LINK 0x1A00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_HOCKEYD_FORWARD_LINK 0x1A0144E0 /* Fallback move forward button */ +#define DIBUTTON_HOCKEYD_BACK_LINK 0x1A0144E8 /* Fallback move back button */ +#define DIBUTTON_HOCKEYD_DEVICE 0x1A0044FE /* Show input device and controls */ +#define DIBUTTON_HOCKEYD_PAUSE 0x1A0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Hockey - Goalie + Goal tending ---*/ +#define DIVIRTUAL_SPORTS_HOCKEY_GOALIE 0x1B000000 +#define DIAXIS_HOCKEYG_LATERAL 0x1B008201 /* Move / Aim: left / right */ +#define DIAXIS_HOCKEYG_MOVE 0x1B010202 /* Move / Aim: up / down */ +#define DIBUTTON_HOCKEYG_PASS 0x1B000401 /* pass puck */ +#define DIBUTTON_HOCKEYG_POKE 0x1B000402 /* poke / check / hack */ +#define DIBUTTON_HOCKEYG_STEAL 0x1B000403 /* attempt steal */ +#define DIBUTTON_HOCKEYG_BLOCK 0x1B000404 /* block puck */ +#define DIBUTTON_HOCKEYG_MENU 0x1B0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_HOCKEYG_SCROLL 0x1B004601 /* scroll view */ +#define DIBUTTON_HOCKEYG_ZOOM 0x1B004405 /* Zoom view in / out */ +#define DIBUTTON_HOCKEYG_STRATEGY 0x1B004406 /* Invoke coaching menu for strategy help */ +#define DIBUTTON_HOCKEYG_TIMEOUT 0x1B004407 /* Call for time out */ +#define DIBUTTON_HOCKEYG_SUBSTITUTE 0x1B004408 /* substitute one player for another */ +#define DIBUTTON_HOCKEYG_LEFT_LINK 0x1B00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_HOCKEYG_RIGHT_LINK 0x1B00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_HOCKEYG_FORWARD_LINK 0x1B0144E0 /* Fallback move forward button */ +#define DIBUTTON_HOCKEYG_BACK_LINK 0x1B0144E8 /* Fallback move back button */ +#define DIBUTTON_HOCKEYG_DEVICE 0x1B0044FE /* Show input device and controls */ +#define DIBUTTON_HOCKEYG_PAUSE 0x1B0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Mountain Biking + ---*/ +#define DIVIRTUAL_SPORTS_BIKING_MOUNTAIN 0x1C000000 +#define DIAXIS_BIKINGM_TURN 0x1C008201 /* left / right */ +#define DIAXIS_BIKINGM_PEDAL 0x1C010202 /* Pedal faster / slower / brake */ +#define DIBUTTON_BIKINGM_JUMP 0x1C000401 /* jump over obstacle */ +#define DIBUTTON_BIKINGM_CAMERA 0x1C000402 /* switch camera view */ +#define DIBUTTON_BIKINGM_SPECIAL1 0x1C000403 /* perform first special move */ +#define DIBUTTON_BIKINGM_SELECT 0x1C000404 /* Select */ +#define DIBUTTON_BIKINGM_SPECIAL2 0x1C000405 /* perform second special move */ +#define DIBUTTON_BIKINGM_MENU 0x1C0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_BIKINGM_SCROLL 0x1C004601 /* scroll view */ +#define DIBUTTON_BIKINGM_ZOOM 0x1C004406 /* Zoom view in / out */ +#define DIAXIS_BIKINGM_BRAKE 0x1C044203 /* Brake axis */ +#define DIBUTTON_BIKINGM_LEFT_LINK 0x1C00C4E4 /* Fallback turn left button */ +#define DIBUTTON_BIKINGM_RIGHT_LINK 0x1C00C4EC /* Fallback turn right button */ +#define DIBUTTON_BIKINGM_FASTER_LINK 0x1C0144E0 /* Fallback pedal faster button */ +#define DIBUTTON_BIKINGM_SLOWER_LINK 0x1C0144E8 /* Fallback pedal slower button */ +#define DIBUTTON_BIKINGM_BRAKE_BUTTON_LINK 0x1C0444E8 /* Fallback brake button */ +#define DIBUTTON_BIKINGM_DEVICE 0x1C0044FE /* Show input device and controls */ +#define DIBUTTON_BIKINGM_PAUSE 0x1C0044FC /* Start / Pause / Restart game */ + +/*--- Sports: Skiing / Snowboarding / Skateboarding + ---*/ +#define DIVIRTUAL_SPORTS_SKIING 0x1D000000 +#define DIAXIS_SKIING_TURN 0x1D008201 /* left / right */ +#define DIAXIS_SKIING_SPEED 0x1D010202 /* faster / slower */ +#define DIBUTTON_SKIING_JUMP 0x1D000401 /* Jump */ +#define DIBUTTON_SKIING_CROUCH 0x1D000402 /* crouch down */ +#define DIBUTTON_SKIING_CAMERA 0x1D000403 /* switch camera view */ +#define DIBUTTON_SKIING_SPECIAL1 0x1D000404 /* perform first special move */ +#define DIBUTTON_SKIING_SELECT 0x1D000405 /* Select */ +#define DIBUTTON_SKIING_SPECIAL2 0x1D000406 /* perform second special move */ +#define DIBUTTON_SKIING_MENU 0x1D0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_SKIING_GLANCE 0x1D004601 /* scroll view */ +#define DIBUTTON_SKIING_ZOOM 0x1D004407 /* Zoom view in / out */ +#define DIBUTTON_SKIING_LEFT_LINK 0x1D00C4E4 /* Fallback turn left button */ +#define DIBUTTON_SKIING_RIGHT_LINK 0x1D00C4EC /* Fallback turn right button */ +#define DIBUTTON_SKIING_FASTER_LINK 0x1D0144E0 /* Fallback increase speed button */ +#define DIBUTTON_SKIING_SLOWER_LINK 0x1D0144E8 /* Fallback decrease speed button */ +#define DIBUTTON_SKIING_DEVICE 0x1D0044FE /* Show input device and controls */ +#define DIBUTTON_SKIING_PAUSE 0x1D0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Soccer - Offense + Offense ---*/ +#define DIVIRTUAL_SPORTS_SOCCER_OFFENSE 0x1E000000 +#define DIAXIS_SOCCERO_LATERAL 0x1E008201 /* Move / Aim: left / right */ +#define DIAXIS_SOCCERO_MOVE 0x1E010202 /* Move / Aim: up / down */ +#define DIAXIS_SOCCERO_BEND 0x1E018203 /* Bend to soccer shot/pass */ +#define DIBUTTON_SOCCERO_SHOOT 0x1E000401 /* Shoot the ball */ +#define DIBUTTON_SOCCERO_PASS 0x1E000402 /* Pass */ +#define DIBUTTON_SOCCERO_FAKE 0x1E000403 /* Fake */ +#define DIBUTTON_SOCCERO_PLAYER 0x1E000404 /* Select next player */ +#define DIBUTTON_SOCCERO_SPECIAL1 0x1E000405 /* Apply special move */ +#define DIBUTTON_SOCCERO_SELECT 0x1E000406 /* Select special move */ +#define DIBUTTON_SOCCERO_MENU 0x1E0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_SOCCERO_GLANCE 0x1E004601 /* scroll view */ +#define DIBUTTON_SOCCERO_SUBSTITUTE 0x1E004407 /* Substitute one player for another */ +#define DIBUTTON_SOCCERO_SHOOTLOW 0x1E004408 /* Shoot the ball low */ +#define DIBUTTON_SOCCERO_SHOOTHIGH 0x1E004409 /* Shoot the ball high */ +#define DIBUTTON_SOCCERO_PASSTHRU 0x1E00440A /* Make a thru pass */ +#define DIBUTTON_SOCCERO_SPRINT 0x1E00440B /* Sprint / turbo boost */ +#define DIBUTTON_SOCCERO_CONTROL 0x1E00440C /* Obtain control of the ball */ +#define DIBUTTON_SOCCERO_HEAD 0x1E00440D /* Attempt to head the ball */ +#define DIBUTTON_SOCCERO_LEFT_LINK 0x1E00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_SOCCERO_RIGHT_LINK 0x1E00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_SOCCERO_FORWARD_LINK 0x1E0144E0 /* Fallback move forward button */ +#define DIBUTTON_SOCCERO_BACK_LINK 0x1E0144E8 /* Fallback move back button */ +#define DIBUTTON_SOCCERO_DEVICE 0x1E0044FE /* Show input device and controls */ +#define DIBUTTON_SOCCERO_PAUSE 0x1E0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Soccer - Defense + Defense ---*/ +#define DIVIRTUAL_SPORTS_SOCCER_DEFENSE 0x1F000000 +#define DIAXIS_SOCCERD_LATERAL 0x1F008201 /* Move / Aim: left / right */ +#define DIAXIS_SOCCERD_MOVE 0x1F010202 /* Move / Aim: up / down */ +#define DIBUTTON_SOCCERD_BLOCK 0x1F000401 /* Attempt to block shot */ +#define DIBUTTON_SOCCERD_STEAL 0x1F000402 /* Attempt to steal ball */ +#define DIBUTTON_SOCCERD_FAKE 0x1F000403 /* Fake a block or a steal */ +#define DIBUTTON_SOCCERD_PLAYER 0x1F000404 /* Select next player */ +#define DIBUTTON_SOCCERD_SPECIAL 0x1F000405 /* Apply special move */ +#define DIBUTTON_SOCCERD_SELECT 0x1F000406 /* Select special move */ +#define DIBUTTON_SOCCERD_SLIDE 0x1F000407 /* Attempt a slide tackle */ +#define DIBUTTON_SOCCERD_MENU 0x1F0004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_SOCCERD_GLANCE 0x1F004601 /* scroll view */ +#define DIBUTTON_SOCCERD_FOUL 0x1F004408 /* Initiate a foul / hard-foul */ +#define DIBUTTON_SOCCERD_HEAD 0x1F004409 /* Attempt a Header */ +#define DIBUTTON_SOCCERD_CLEAR 0x1F00440A /* Attempt to clear the ball down the field */ +#define DIBUTTON_SOCCERD_GOALIECHARGE 0x1F00440B /* Make the goalie charge out of the box */ +#define DIBUTTON_SOCCERD_SUBSTITUTE 0x1F00440C /* Substitute one player for another */ +#define DIBUTTON_SOCCERD_LEFT_LINK 0x1F00C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_SOCCERD_RIGHT_LINK 0x1F00C4EC /* Fallback sidestep right button */ +#define DIBUTTON_SOCCERD_FORWARD_LINK 0x1F0144E0 /* Fallback move forward button */ +#define DIBUTTON_SOCCERD_BACK_LINK 0x1F0144E8 /* Fallback move back button */ +#define DIBUTTON_SOCCERD_DEVICE 0x1F0044FE /* Show input device and controls */ +#define DIBUTTON_SOCCERD_PAUSE 0x1F0044FC /* Start / Pause / Restart game */ + +/*--- Sports - Racquet + Tennis - Table-Tennis - Squash ---*/ +#define DIVIRTUAL_SPORTS_RACQUET 0x20000000 +#define DIAXIS_RACQUET_LATERAL 0x20008201 /* Move / Aim: left / right */ +#define DIAXIS_RACQUET_MOVE 0x20010202 /* Move / Aim: up / down */ +#define DIBUTTON_RACQUET_SWING 0x20000401 /* Swing racquet */ +#define DIBUTTON_RACQUET_BACKSWING 0x20000402 /* Swing backhand */ +#define DIBUTTON_RACQUET_SMASH 0x20000403 /* Smash shot */ +#define DIBUTTON_RACQUET_SPECIAL 0x20000404 /* Special shot */ +#define DIBUTTON_RACQUET_SELECT 0x20000405 /* Select special shot */ +#define DIBUTTON_RACQUET_MENU 0x200004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_RACQUET_GLANCE 0x20004601 /* scroll view */ +#define DIBUTTON_RACQUET_TIMEOUT 0x20004406 /* Call for time out */ +#define DIBUTTON_RACQUET_SUBSTITUTE 0x20004407 /* Substitute one player for another */ +#define DIBUTTON_RACQUET_LEFT_LINK 0x2000C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_RACQUET_RIGHT_LINK 0x2000C4EC /* Fallback sidestep right button */ +#define DIBUTTON_RACQUET_FORWARD_LINK 0x200144E0 /* Fallback move forward button */ +#define DIBUTTON_RACQUET_BACK_LINK 0x200144E8 /* Fallback move back button */ +#define DIBUTTON_RACQUET_DEVICE 0x200044FE /* Show input device and controls */ +#define DIBUTTON_RACQUET_PAUSE 0x200044FC /* Start / Pause / Restart game */ + +/*--- Arcade- 2D + Side to Side movement ---*/ +#define DIVIRTUAL_ARCADE_SIDE2SIDE 0x21000000 +#define DIAXIS_ARCADES_LATERAL 0x21008201 /* left / right */ +#define DIAXIS_ARCADES_MOVE 0x21010202 /* up / down */ +#define DIBUTTON_ARCADES_THROW 0x21000401 /* throw object */ +#define DIBUTTON_ARCADES_CARRY 0x21000402 /* carry object */ +#define DIBUTTON_ARCADES_ATTACK 0x21000403 /* attack */ +#define DIBUTTON_ARCADES_SPECIAL 0x21000404 /* apply special move */ +#define DIBUTTON_ARCADES_SELECT 0x21000405 /* select special move */ +#define DIBUTTON_ARCADES_MENU 0x210004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_ARCADES_VIEW 0x21004601 /* scroll view left / right / up / down */ +#define DIBUTTON_ARCADES_LEFT_LINK 0x2100C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_ARCADES_RIGHT_LINK 0x2100C4EC /* Fallback sidestep right button */ +#define DIBUTTON_ARCADES_FORWARD_LINK 0x210144E0 /* Fallback move forward button */ +#define DIBUTTON_ARCADES_BACK_LINK 0x210144E8 /* Fallback move back button */ +#define DIBUTTON_ARCADES_VIEW_UP_LINK 0x2107C4E0 /* Fallback scroll view up button */ +#define DIBUTTON_ARCADES_VIEW_DOWN_LINK 0x2107C4E8 /* Fallback scroll view down button */ +#define DIBUTTON_ARCADES_VIEW_LEFT_LINK 0x2107C4E4 /* Fallback scroll view left button */ +#define DIBUTTON_ARCADES_VIEW_RIGHT_LINK 0x2107C4EC /* Fallback scroll view right button */ +#define DIBUTTON_ARCADES_DEVICE 0x210044FE /* Show input device and controls */ +#define DIBUTTON_ARCADES_PAUSE 0x210044FC /* Start / Pause / Restart game */ + +/*--- Arcade - Platform Game + Character moves around on screen ---*/ +#define DIVIRTUAL_ARCADE_PLATFORM 0x22000000 +#define DIAXIS_ARCADEP_LATERAL 0x22008201 /* Left / right */ +#define DIAXIS_ARCADEP_MOVE 0x22010202 /* Up / down */ +#define DIBUTTON_ARCADEP_JUMP 0x22000401 /* Jump */ +#define DIBUTTON_ARCADEP_FIRE 0x22000402 /* Fire */ +#define DIBUTTON_ARCADEP_CROUCH 0x22000403 /* Crouch */ +#define DIBUTTON_ARCADEP_SPECIAL 0x22000404 /* Apply special move */ +#define DIBUTTON_ARCADEP_SELECT 0x22000405 /* Select special move */ +#define DIBUTTON_ARCADEP_MENU 0x220004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_ARCADEP_VIEW 0x22004601 /* Scroll view */ +#define DIBUTTON_ARCADEP_FIRESECONDARY 0x22004406 /* Alternative fire button */ +#define DIBUTTON_ARCADEP_LEFT_LINK 0x2200C4E4 /* Fallback sidestep left button */ +#define DIBUTTON_ARCADEP_RIGHT_LINK 0x2200C4EC /* Fallback sidestep right button */ +#define DIBUTTON_ARCADEP_FORWARD_LINK 0x220144E0 /* Fallback move forward button */ +#define DIBUTTON_ARCADEP_BACK_LINK 0x220144E8 /* Fallback move back button */ +#define DIBUTTON_ARCADEP_VIEW_UP_LINK 0x2207C4E0 /* Fallback scroll view up button */ +#define DIBUTTON_ARCADEP_VIEW_DOWN_LINK 0x2207C4E8 /* Fallback scroll view down button */ +#define DIBUTTON_ARCADEP_VIEW_LEFT_LINK 0x2207C4E4 /* Fallback scroll view left button */ +#define DIBUTTON_ARCADEP_VIEW_RIGHT_LINK 0x2207C4EC /* Fallback scroll view right button */ +#define DIBUTTON_ARCADEP_DEVICE 0x220044FE /* Show input device and controls */ +#define DIBUTTON_ARCADEP_PAUSE 0x220044FC /* Start / Pause / Restart game */ + +/*--- CAD - 2D Object Control + Controls to select and move objects in 2D ---*/ +#define DIVIRTUAL_CAD_2DCONTROL 0x23000000 +#define DIAXIS_2DCONTROL_LATERAL 0x23008201 /* Move view left / right */ +#define DIAXIS_2DCONTROL_MOVE 0x23010202 /* Move view up / down */ +#define DIAXIS_2DCONTROL_INOUT 0x23018203 /* Zoom - in / out */ +#define DIBUTTON_2DCONTROL_SELECT 0x23000401 /* Select Object */ +#define DIBUTTON_2DCONTROL_SPECIAL1 0x23000402 /* Do first special operation */ +#define DIBUTTON_2DCONTROL_SPECIAL 0x23000403 /* Select special operation */ +#define DIBUTTON_2DCONTROL_SPECIAL2 0x23000404 /* Do second special operation */ +#define DIBUTTON_2DCONTROL_MENU 0x230004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_2DCONTROL_HATSWITCH 0x23004601 /* Hat switch */ +#define DIAXIS_2DCONTROL_ROTATEZ 0x23024204 /* Rotate view clockwise / counterclockwise */ +#define DIBUTTON_2DCONTROL_DISPLAY 0x23004405 /* Shows next on-screen display options */ +#define DIBUTTON_2DCONTROL_DEVICE 0x230044FE /* Show input device and controls */ +#define DIBUTTON_2DCONTROL_PAUSE 0x230044FC /* Start / Pause / Restart game */ + +/*--- CAD - 3D object control + Controls to select and move objects within a 3D environment ---*/ +#define DIVIRTUAL_CAD_3DCONTROL 0x24000000 +#define DIAXIS_3DCONTROL_LATERAL 0x24008201 /* Move view left / right */ +#define DIAXIS_3DCONTROL_MOVE 0x24010202 /* Move view up / down */ +#define DIAXIS_3DCONTROL_INOUT 0x24018203 /* Zoom - in / out */ +#define DIBUTTON_3DCONTROL_SELECT 0x24000401 /* Select Object */ +#define DIBUTTON_3DCONTROL_SPECIAL1 0x24000402 /* Do first special operation */ +#define DIBUTTON_3DCONTROL_SPECIAL 0x24000403 /* Select special operation */ +#define DIBUTTON_3DCONTROL_SPECIAL2 0x24000404 /* Do second special operation */ +#define DIBUTTON_3DCONTROL_MENU 0x240004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_3DCONTROL_HATSWITCH 0x24004601 /* Hat switch */ +#define DIAXIS_3DCONTROL_ROTATEX 0x24034204 /* Rotate view forward or up / backward or down */ +#define DIAXIS_3DCONTROL_ROTATEY 0x2402C205 /* Rotate view clockwise / counterclockwise */ +#define DIAXIS_3DCONTROL_ROTATEZ 0x24024206 /* Rotate view left / right */ +#define DIBUTTON_3DCONTROL_DISPLAY 0x24004405 /* Show next on-screen display options */ +#define DIBUTTON_3DCONTROL_DEVICE 0x240044FE /* Show input device and controls */ +#define DIBUTTON_3DCONTROL_PAUSE 0x240044FC /* Start / Pause / Restart game */ + +/*--- CAD - 3D Navigation - Fly through + Controls for 3D modeling ---*/ +#define DIVIRTUAL_CAD_FLYBY 0x25000000 +#define DIAXIS_CADF_LATERAL 0x25008201 /* move view left / right */ +#define DIAXIS_CADF_MOVE 0x25010202 /* move view up / down */ +#define DIAXIS_CADF_INOUT 0x25018203 /* in / out */ +#define DIBUTTON_CADF_SELECT 0x25000401 /* Select Object */ +#define DIBUTTON_CADF_SPECIAL1 0x25000402 /* do first special operation */ +#define DIBUTTON_CADF_SPECIAL 0x25000403 /* Select special operation */ +#define DIBUTTON_CADF_SPECIAL2 0x25000404 /* do second special operation */ +#define DIBUTTON_CADF_MENU 0x250004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_CADF_HATSWITCH 0x25004601 /* Hat switch */ +#define DIAXIS_CADF_ROTATEX 0x25034204 /* Rotate view forward or up / backward or down */ +#define DIAXIS_CADF_ROTATEY 0x2502C205 /* Rotate view clockwise / counterclockwise */ +#define DIAXIS_CADF_ROTATEZ 0x25024206 /* Rotate view left / right */ +#define DIBUTTON_CADF_DISPLAY 0x25004405 /* shows next on-screen display options */ +#define DIBUTTON_CADF_DEVICE 0x250044FE /* Show input device and controls */ +#define DIBUTTON_CADF_PAUSE 0x250044FC /* Start / Pause / Restart game */ + +/*--- CAD - 3D Model Control + Controls for 3D modeling ---*/ +#define DIVIRTUAL_CAD_MODEL 0x26000000 +#define DIAXIS_CADM_LATERAL 0x26008201 /* move view left / right */ +#define DIAXIS_CADM_MOVE 0x26010202 /* move view up / down */ +#define DIAXIS_CADM_INOUT 0x26018203 /* in / out */ +#define DIBUTTON_CADM_SELECT 0x26000401 /* Select Object */ +#define DIBUTTON_CADM_SPECIAL1 0x26000402 /* do first special operation */ +#define DIBUTTON_CADM_SPECIAL 0x26000403 /* Select special operation */ +#define DIBUTTON_CADM_SPECIAL2 0x26000404 /* do second special operation */ +#define DIBUTTON_CADM_MENU 0x260004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIHATSWITCH_CADM_HATSWITCH 0x26004601 /* Hat switch */ +#define DIAXIS_CADM_ROTATEX 0x26034204 /* Rotate view forward or up / backward or down */ +#define DIAXIS_CADM_ROTATEY 0x2602C205 /* Rotate view clockwise / counterclockwise */ +#define DIAXIS_CADM_ROTATEZ 0x26024206 /* Rotate view left / right */ +#define DIBUTTON_CADM_DISPLAY 0x26004405 /* shows next on-screen display options */ +#define DIBUTTON_CADM_DEVICE 0x260044FE /* Show input device and controls */ +#define DIBUTTON_CADM_PAUSE 0x260044FC /* Start / Pause / Restart game */ + +/*--- Control - Media Equipment + Remote ---*/ +#define DIVIRTUAL_REMOTE_CONTROL 0x27000000 +#define DIAXIS_REMOTE_SLIDER 0x27050201 /* Slider for adjustment: volume / color / bass / etc */ +#define DIBUTTON_REMOTE_MUTE 0x27000401 /* Set volume on current device to zero */ +#define DIBUTTON_REMOTE_SELECT 0x27000402 /* Next/previous: channel/ track / chapter / picture / station */ +#define DIBUTTON_REMOTE_PLAY 0x27002403 /* Start or pause entertainment on current device */ +#define DIBUTTON_REMOTE_CUE 0x27002404 /* Move through current media */ +#define DIBUTTON_REMOTE_REVIEW 0x27002405 /* Move through current media */ +#define DIBUTTON_REMOTE_CHANGE 0x27002406 /* Select next device */ +#define DIBUTTON_REMOTE_RECORD 0x27002407 /* Start recording the current media */ +#define DIBUTTON_REMOTE_MENU 0x270004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIAXIS_REMOTE_SLIDER2 0x27054202 /* Slider for adjustment: volume */ +#define DIBUTTON_REMOTE_TV 0x27005C08 /* Select TV */ +#define DIBUTTON_REMOTE_CABLE 0x27005C09 /* Select cable box */ +#define DIBUTTON_REMOTE_CD 0x27005C0A /* Select CD player */ +#define DIBUTTON_REMOTE_VCR 0x27005C0B /* Select VCR */ +#define DIBUTTON_REMOTE_TUNER 0x27005C0C /* Select tuner */ +#define DIBUTTON_REMOTE_DVD 0x27005C0D /* Select DVD player */ +#define DIBUTTON_REMOTE_ADJUST 0x27005C0E /* Enter device adjustment menu */ +#define DIBUTTON_REMOTE_DIGIT0 0x2700540F /* Digit 0 */ +#define DIBUTTON_REMOTE_DIGIT1 0x27005410 /* Digit 1 */ +#define DIBUTTON_REMOTE_DIGIT2 0x27005411 /* Digit 2 */ +#define DIBUTTON_REMOTE_DIGIT3 0x27005412 /* Digit 3 */ +#define DIBUTTON_REMOTE_DIGIT4 0x27005413 /* Digit 4 */ +#define DIBUTTON_REMOTE_DIGIT5 0x27005414 /* Digit 5 */ +#define DIBUTTON_REMOTE_DIGIT6 0x27005415 /* Digit 6 */ +#define DIBUTTON_REMOTE_DIGIT7 0x27005416 /* Digit 7 */ +#define DIBUTTON_REMOTE_DIGIT8 0x27005417 /* Digit 8 */ +#define DIBUTTON_REMOTE_DIGIT9 0x27005418 /* Digit 9 */ +#define DIBUTTON_REMOTE_DEVICE 0x270044FE /* Show input device and controls */ +#define DIBUTTON_REMOTE_PAUSE 0x270044FC /* Start / Pause / Restart game */ + +/*--- Control- Web + Help or Browser ---*/ +#define DIVIRTUAL_BROWSER_CONTROL 0x28000000 +#define DIAXIS_BROWSER_LATERAL 0x28008201 /* Move on screen pointer */ +#define DIAXIS_BROWSER_MOVE 0x28010202 /* Move on screen pointer */ +#define DIBUTTON_BROWSER_SELECT 0x28000401 /* Select current item */ +#define DIAXIS_BROWSER_VIEW 0x28018203 /* Move view up/down */ +#define DIBUTTON_BROWSER_REFRESH 0x28000402 /* Refresh */ +#define DIBUTTON_BROWSER_MENU 0x280004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_BROWSER_SEARCH 0x28004403 /* Use search tool */ +#define DIBUTTON_BROWSER_STOP 0x28004404 /* Cease current update */ +#define DIBUTTON_BROWSER_HOME 0x28004405 /* Go directly to "home" location */ +#define DIBUTTON_BROWSER_FAVORITES 0x28004406 /* Mark current site as favorite */ +#define DIBUTTON_BROWSER_NEXT 0x28004407 /* Select Next page */ +#define DIBUTTON_BROWSER_PREVIOUS 0x28004408 /* Select Previous page */ +#define DIBUTTON_BROWSER_HISTORY 0x28004409 /* Show/Hide History */ +#define DIBUTTON_BROWSER_PRINT 0x2800440A /* Print current page */ +#define DIBUTTON_BROWSER_DEVICE 0x280044FE /* Show input device and controls */ +#define DIBUTTON_BROWSER_PAUSE 0x280044FC /* Start / Pause / Restart game */ + +/*--- Driving Simulator - Giant Walking Robot + Walking tank with weapons ---*/ +#define DIVIRTUAL_DRIVING_MECHA 0x29000000 +#define DIAXIS_MECHA_STEER 0x29008201 /* Turns mecha left/right */ +#define DIAXIS_MECHA_TORSO 0x29010202 /* Tilts torso forward/backward */ +#define DIAXIS_MECHA_ROTATE 0x29020203 /* Turns torso left/right */ +#define DIAXIS_MECHA_THROTTLE 0x29038204 /* Engine Speed */ +#define DIBUTTON_MECHA_FIRE 0x29000401 /* Fire */ +#define DIBUTTON_MECHA_WEAPONS 0x29000402 /* Select next weapon group */ +#define DIBUTTON_MECHA_TARGET 0x29000403 /* Select closest enemy available target */ +#define DIBUTTON_MECHA_REVERSE 0x29000404 /* Toggles throttle in/out of reverse */ +#define DIBUTTON_MECHA_ZOOM 0x29000405 /* Zoom in/out targeting reticule */ +#define DIBUTTON_MECHA_JUMP 0x29000406 /* Fires jump jets */ +#define DIBUTTON_MECHA_MENU 0x290004FD /* Show menu options */ +/*--- Priority 2 controls ---*/ + +#define DIBUTTON_MECHA_CENTER 0x29004407 /* Center torso to legs */ +#define DIHATSWITCH_MECHA_GLANCE 0x29004601 /* Look around */ +#define DIBUTTON_MECHA_VIEW 0x29004408 /* Cycle through view options */ +#define DIBUTTON_MECHA_FIRESECONDARY 0x29004409 /* Alternative fire button */ +#define DIBUTTON_MECHA_LEFT_LINK 0x2900C4E4 /* Fallback steer left button */ +#define DIBUTTON_MECHA_RIGHT_LINK 0x2900C4EC /* Fallback steer right button */ +#define DIBUTTON_MECHA_FORWARD_LINK 0x290144E0 /* Fallback tilt torso forward button */ +#define DIBUTTON_MECHA_BACK_LINK 0x290144E8 /* Fallback tilt toroso backward button */ +#define DIBUTTON_MECHA_ROTATE_LEFT_LINK 0x290244E4 /* Fallback rotate toroso right button */ +#define DIBUTTON_MECHA_ROTATE_RIGHT_LINK 0x290244EC /* Fallback rotate torso left button */ +#define DIBUTTON_MECHA_FASTER_LINK 0x2903C4E0 /* Fallback increase engine speed */ +#define DIBUTTON_MECHA_SLOWER_LINK 0x2903C4E8 /* Fallback decrease engine speed */ +#define DIBUTTON_MECHA_DEVICE 0x290044FE /* Show input device and controls */ +#define DIBUTTON_MECHA_PAUSE 0x290044FC /* Start / Pause / Restart game */ + +/* + * "ANY" semantics can be used as a last resort to get mappings for actions + * that match nothing in the chosen virtual genre. These semantics will be + * mapped at a lower priority that virtual genre semantics. Also, hardware + * vendors will not be able to provide sensible mappings for these unless + * they provide application specific mappings. + */ +#define DIAXIS_ANY_X_1 0xFF00C201 +#define DIAXIS_ANY_X_2 0xFF00C202 +#define DIAXIS_ANY_Y_1 0xFF014201 +#define DIAXIS_ANY_Y_2 0xFF014202 +#define DIAXIS_ANY_Z_1 0xFF01C201 +#define DIAXIS_ANY_Z_2 0xFF01C202 +#define DIAXIS_ANY_R_1 0xFF024201 +#define DIAXIS_ANY_R_2 0xFF024202 +#define DIAXIS_ANY_U_1 0xFF02C201 +#define DIAXIS_ANY_U_2 0xFF02C202 +#define DIAXIS_ANY_V_1 0xFF034201 +#define DIAXIS_ANY_V_2 0xFF034202 +#define DIAXIS_ANY_A_1 0xFF03C201 +#define DIAXIS_ANY_A_2 0xFF03C202 +#define DIAXIS_ANY_B_1 0xFF044201 +#define DIAXIS_ANY_B_2 0xFF044202 +#define DIAXIS_ANY_C_1 0xFF04C201 +#define DIAXIS_ANY_C_2 0xFF04C202 +#define DIAXIS_ANY_S_1 0xFF054201 +#define DIAXIS_ANY_S_2 0xFF054202 + +#define DIAXIS_ANY_1 0xFF004201 +#define DIAXIS_ANY_2 0xFF004202 +#define DIAXIS_ANY_3 0xFF004203 +#define DIAXIS_ANY_4 0xFF004204 + +#define DIPOV_ANY_1 0xFF004601 +#define DIPOV_ANY_2 0xFF004602 +#define DIPOV_ANY_3 0xFF004603 +#define DIPOV_ANY_4 0xFF004604 + +#define DIBUTTON_ANY(instance) ( 0xFF004400 | instance ) + + +#ifdef __cplusplus +}; +#endif + +#endif /* __DINPUT_INCLUDED__ */ + +/**************************************************************************** + * + * Definitions for non-IDirectInput (VJoyD) features defined more recently + * than the current sdk files + * + ****************************************************************************/ + +#ifdef _INC_MMSYSTEM +#ifndef MMNOJOY + +#ifndef __VJOYDX_INCLUDED__ +#define __VJOYDX_INCLUDED__ + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * Flag to indicate that the dwReserved2 field of the JOYINFOEX structure + * contains mini-driver specific data to be passed by VJoyD to the mini- + * driver instead of doing a poll. + */ +#define JOY_PASSDRIVERDATA 0x10000000l + +/* + * Informs the joystick driver that the configuration has been changed + * and should be reloaded from the registery. + * dwFlags is reserved and should be set to zero + */ +WINMMAPI MMRESULT WINAPI joyConfigChanged( DWORD dwFlags ); + +#ifndef DIJ_RINGZERO +/* + * Invoke the joystick control panel directly, using the passed window handle + * as the parent of the dialog. This API is only supported for compatibility + * purposes; new applications should use the RunControlPanel method of a + * device interface for a game controller. + * The API is called by using the function pointer returned by + * GetProcAddress( hCPL, TEXT("ShowJoyCPL") ) where hCPL is a HMODULE returned + * by LoadLibrary( TEXT("joy.cpl") ). The typedef is provided to allow + * declaration and casting of an appropriately typed variable. + */ +void WINAPI ShowJoyCPL( HWND hWnd ); +typedef void (WINAPI* LPFNSHOWJOYCPL)( HWND hWnd ); +#endif /* DIJ_RINGZERO */ + + +/* + * Hardware Setting indicating that the device is a headtracker + */ +#define JOY_HWS_ISHEADTRACKER 0x02000000l + +/* + * Hardware Setting indicating that the VxD is used to replace + * the standard analog polling + */ +#define JOY_HWS_ISGAMEPORTDRIVER 0x04000000l + +/* + * Hardware Setting indicating that the driver needs a standard + * gameport in order to communicate with the device. + */ +#define JOY_HWS_ISANALOGPORTDRIVER 0x08000000l + +/* + * Hardware Setting indicating that VJoyD should not load this + * driver, it will be loaded externally and will register with + * VJoyD of it's own accord. + */ +#define JOY_HWS_AUTOLOAD 0x10000000l + +/* + * Hardware Setting indicating that the driver acquires any + * resources needed without needing a devnode through VJoyD. + */ +#define JOY_HWS_NODEVNODE 0x20000000l + + +/* + * Hardware Setting indicating that the device is a gameport bus + */ +#define JOY_HWS_ISGAMEPORTBUS 0x80000000l +#define JOY_HWS_GAMEPORTBUSBUSY 0x00000001l + +/* + * Usage Setting indicating that the settings are volatile and + * should be removed if still present on a reboot. + */ +#define JOY_US_VOLATILE 0x00000008L + +#ifdef __cplusplus +}; +#endif + +#endif /* __VJOYDX_INCLUDED__ */ + +#endif /* not MMNOJOY */ +#endif /* _INC_MMSYSTEM */ + +/**************************************************************************** + * + * Definitions for non-IDirectInput (VJoyD) features defined more recently + * than the current ddk files + * + ****************************************************************************/ + +#ifndef DIJ_RINGZERO + +#ifdef _INC_MMDDK +#ifndef MMNOJOYDEV + +#ifndef __VJOYDXD_INCLUDED__ +#define __VJOYDXD_INCLUDED__ +/* + * Poll type in which the do_other field of the JOYOEMPOLLDATA + * structure contains mini-driver specific data passed from an app. + */ +#define JOY_OEMPOLL_PASSDRIVERDATA 7 + +#endif /* __VJOYDXD_INCLUDED__ */ + +#endif /* not MMNOJOYDEV */ +#endif /* _INC_MMDDK */ + +#endif /* DIJ_RINGZERO */ + diff --git a/plugins/ADK/d3d8/includes/dxerr8.h b/plugins/ADK/d3d8/includes/dxerr8.h new file mode 100644 index 0000000..8b7813d --- /dev/null +++ b/plugins/ADK/d3d8/includes/dxerr8.h @@ -0,0 +1,100 @@ +/*==========================================================================; + * + * + * File: dxerr8.h + * Content: DirectX Error Library Include File + * + ****************************************************************************/ + +#ifndef _DXERR8_H_ +#define _DXERR8_H_ + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +// +// DXGetErrorString8 +// +// Desc: Converts a DirectX HRESULT to a string +// +// Args: HRESULT hr Can be any error code from +// D3D8 D3DX8 DDRAW DPLAY8 DMUSIC DSOUND DINPUT DSHOW +// +// Return: Converted string +// +const char* WINAPI DXGetErrorString8A(HRESULT hr); +const WCHAR* WINAPI DXGetErrorString8W(HRESULT hr); + +#ifdef UNICODE +#define DXGetErrorString8 DXGetErrorString8W +#else +#define DXGetErrorString8 DXGetErrorString8A +#endif + + +// +// DXGetErrorDescription8 +// +// Desc: Returns a string description of a DirectX HRESULT +// +// Args: HRESULT hr Can be any error code from +// D3D8 D3DX8 DDRAW DPLAY8 DMUSIC DSOUND DINPUT DSHOW +// +// Return: String description +// +const char* WINAPI DXGetErrorDescription8A(HRESULT hr); +const WCHAR* WINAPI DXGetErrorDescription8W(HRESULT hr); + +#ifdef UNICODE + #define DXGetErrorDescription8 DXGetErrorDescription8W +#else + #define DXGetErrorDescription8 DXGetErrorDescription8A +#endif + + +// +// DXTrace +// +// Desc: Outputs a formatted error message to the debug stream +// +// Args: CHAR* strFile The current file, typically passed in using the +// __FILE__ macro. +// DWORD dwLine The current line number, typically passed in using the +// __LINE__ macro. +// HRESULT hr An HRESULT that will be traced to the debug stream. +// CHAR* strMsg A string that will be traced to the debug stream (may be NULL) +// BOOL bPopMsgBox If TRUE, then a message box will popup also containing the passed info. +// +// Return: The hr that was passed in. +// +HRESULT WINAPI DXTraceA( const char* strFile, DWORD dwLine, HRESULT hr, const char* strMsg, BOOL bPopMsgBox ); +HRESULT WINAPI DXTraceW( const char* strFile, DWORD dwLine, HRESULT hr, const WCHAR* strMsg, BOOL bPopMsgBox ); + +#ifdef UNICODE +#define DXTrace DXTraceW +#else +#define DXTrace DXTraceA +#endif + + +// +// Helper macros +// +#if defined(DEBUG) | defined(_DEBUG) +#define DXTRACE_MSG(str) DXTrace( __FILE__, (DWORD)__LINE__, 0, str, FALSE ) +#define DXTRACE_ERR(str,hr) DXTrace( __FILE__, (DWORD)__LINE__, hr, str, TRUE ) +#define DXTRACE_ERR_NOMSGBOX(str,hr) DXTrace( __FILE__, (DWORD)__LINE__, hr, str, FALSE ) +#else +#define DXTRACE_MSG(str) (0L) +#define DXTRACE_ERR(str,hr) (hr) +#define DXTRACE_ERR_NOMSGBOX(str,hr) (hr) +#endif + + +#ifdef __cplusplus +} +#endif //__cplusplus + +#endif // _DXERR8_H_ + diff --git a/plugins/ADK/d3d8/includes/dxfile.h b/plugins/ADK/d3d8/includes/dxfile.h new file mode 100644 index 0000000..8b5995a --- /dev/null +++ b/plugins/ADK/d3d8/includes/dxfile.h @@ -0,0 +1,240 @@ +/*************************************************************************** + * + * Copyright (C) 1998-1999 Microsoft Corporation. All Rights Reserved. + * + * File: dxfile.h + * + * Content: DirectX File public header file + * + ***************************************************************************/ + +#ifndef __DXFILE_H__ +#define __DXFILE_H__ + +#ifdef __cplusplus +extern "C" { +#endif + +typedef DWORD DXFILEFORMAT; + +#define DXFILEFORMAT_BINARY 0 +#define DXFILEFORMAT_TEXT 1 +#define DXFILEFORMAT_COMPRESSED 2 + +typedef DWORD DXFILELOADOPTIONS; + +#define DXFILELOAD_FROMFILE 0x00L +#define DXFILELOAD_FROMRESOURCE 0x01L +#define DXFILELOAD_FROMMEMORY 0x02L +#define DXFILELOAD_FROMSTREAM 0x04L +#define DXFILELOAD_FROMURL 0x08L + +typedef struct _DXFILELOADRESOURCE { + HMODULE hModule; + LPCTSTR lpName; + LPCTSTR lpType; +}DXFILELOADRESOURCE, *LPDXFILELOADRESOURCE; + +typedef struct _DXFILELOADMEMORY { + LPVOID lpMemory; + DWORD dSize; +}DXFILELOADMEMORY, *LPDXFILELOADMEMORY; + +/* + * DirectX File object types. + */ + +#ifndef WIN_TYPES +#define WIN_TYPES(itype, ptype) typedef interface itype *LP##ptype, **LPLP##ptype +#endif + +WIN_TYPES(IDirectXFile, DIRECTXFILE); +WIN_TYPES(IDirectXFileEnumObject, DIRECTXFILEENUMOBJECT); +WIN_TYPES(IDirectXFileSaveObject, DIRECTXFILESAVEOBJECT); +WIN_TYPES(IDirectXFileObject, DIRECTXFILEOBJECT); +WIN_TYPES(IDirectXFileData, DIRECTXFILEDATA); +WIN_TYPES(IDirectXFileDataReference, DIRECTXFILEDATAREFERENCE); +WIN_TYPES(IDirectXFileBinary, DIRECTXFILEBINARY); + +/* + * API for creating IDirectXFile interface. + */ + +STDAPI DirectXFileCreate(LPDIRECTXFILE *lplpDirectXFile); + +/* + * The methods for IUnknown + */ + +#define IUNKNOWN_METHODS(kind) \ + STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID *ppvObj) kind; \ + STDMETHOD_(ULONG, AddRef) (THIS) kind; \ + STDMETHOD_(ULONG, Release) (THIS) kind + +/* + * The methods for IDirectXFileObject + */ + +#define IDIRECTXFILEOBJECT_METHODS(kind) \ + STDMETHOD(GetName) (THIS_ LPSTR, LPDWORD) kind; \ + STDMETHOD(GetId) (THIS_ LPGUID) kind + +/* + * DirectX File interfaces. + */ + +#undef INTERFACE +#define INTERFACE IDirectXFile + +DECLARE_INTERFACE_(IDirectXFile, IUnknown) +{ + IUNKNOWN_METHODS(PURE); + STDMETHOD(CreateEnumObject) (THIS_ LPVOID, DXFILELOADOPTIONS, + LPDIRECTXFILEENUMOBJECT *) PURE; + STDMETHOD(CreateSaveObject) (THIS_ LPCSTR, DXFILEFORMAT, + LPDIRECTXFILESAVEOBJECT *) PURE; + STDMETHOD(RegisterTemplates) (THIS_ LPVOID, DWORD) PURE; +}; + +#undef INTERFACE +#define INTERFACE IDirectXFileEnumObject + +DECLARE_INTERFACE_(IDirectXFileEnumObject, IUnknown) +{ + IUNKNOWN_METHODS(PURE); + STDMETHOD(GetNextDataObject) (THIS_ LPDIRECTXFILEDATA *) PURE; + STDMETHOD(GetDataObjectById) (THIS_ REFGUID, LPDIRECTXFILEDATA *) PURE; + STDMETHOD(GetDataObjectByName) (THIS_ LPCSTR, LPDIRECTXFILEDATA *) PURE; +}; + +#undef INTERFACE +#define INTERFACE IDirectXFileSaveObject + +DECLARE_INTERFACE_(IDirectXFileSaveObject, IUnknown) +{ + IUNKNOWN_METHODS(PURE); + STDMETHOD(SaveTemplates) (THIS_ DWORD, const GUID **) PURE; + STDMETHOD(CreateDataObject) (THIS_ REFGUID, LPCSTR, const GUID *, + DWORD, LPVOID, LPDIRECTXFILEDATA *) PURE; + STDMETHOD(SaveData) (THIS_ LPDIRECTXFILEDATA) PURE; +}; + + +#undef INTERFACE +#define INTERFACE IDirectXFileObject + +DECLARE_INTERFACE_(IDirectXFileObject, IUnknown) +{ + IUNKNOWN_METHODS(PURE); + IDIRECTXFILEOBJECT_METHODS(PURE); +}; + +#undef INTERFACE +#define INTERFACE IDirectXFileData + +DECLARE_INTERFACE_(IDirectXFileData, IDirectXFileObject) +{ + IUNKNOWN_METHODS(PURE); + IDIRECTXFILEOBJECT_METHODS(PURE); + + STDMETHOD(GetData) (THIS_ LPCSTR, DWORD *, void **) PURE; + STDMETHOD(GetType) (THIS_ const GUID **) PURE; + STDMETHOD(GetNextObject) (THIS_ LPDIRECTXFILEOBJECT *) PURE; + STDMETHOD(AddDataObject) (THIS_ LPDIRECTXFILEDATA) PURE; + STDMETHOD(AddDataReference) (THIS_ LPCSTR, const GUID *) PURE; + STDMETHOD(AddBinaryObject) (THIS_ LPCSTR, const GUID *, LPCSTR, LPVOID, DWORD) PURE; +}; + +#undef INTERFACE +#define INTERFACE IDirectXFileDataReference + +DECLARE_INTERFACE_(IDirectXFileDataReference, IDirectXFileObject) +{ + IUNKNOWN_METHODS(PURE); + IDIRECTXFILEOBJECT_METHODS(PURE); + + STDMETHOD(Resolve) (THIS_ LPDIRECTXFILEDATA *) PURE; +}; + +#undef INTERFACE +#define INTERFACE IDirectXFileBinary + +DECLARE_INTERFACE_(IDirectXFileBinary, IDirectXFileObject) +{ + IUNKNOWN_METHODS(PURE); + IDIRECTXFILEOBJECT_METHODS(PURE); + + STDMETHOD(GetSize) (THIS_ DWORD *) PURE; + STDMETHOD(GetMimeType) (THIS_ LPCSTR *) PURE; + STDMETHOD(Read) (THIS_ LPVOID, DWORD, LPDWORD) PURE; +}; + +/* + * DirectXFile Object Class Id (for CoCreateInstance()) + */ + +DEFINE_GUID(CLSID_CDirectXFile, 0x4516ec43, 0x8f20, 0x11d0, 0x9b, 0x6d, 0x00, 0x00, 0xc0, 0x78, 0x1b, 0xc3); + +/* + * DirectX File Interface GUIDs. + */ + +DEFINE_GUID(IID_IDirectXFile, 0x3d82ab40, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileEnumObject, 0x3d82ab41, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileSaveObject, 0x3d82ab42, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileObject, 0x3d82ab43, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileData, 0x3d82ab44, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileDataReference, 0x3d82ab45, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); +DEFINE_GUID(IID_IDirectXFileBinary, 0x3d82ab46, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); + +/* + * DirectX File Header template's GUID. + */ + +DEFINE_GUID(TID_DXFILEHeader, 0x3d82ab43, 0x62da, 0x11cf, 0xab, 0x39, 0x0, 0x20, 0xaf, 0x71, 0xe4, 0x33); + + +/* + * DirectX File errors. + */ + +#define _FACDD 0x876 +#define MAKE_DDHRESULT( code ) MAKE_HRESULT( 1, _FACDD, code ) + +#define DXFILE_OK 0 + +#define DXFILEERR_BADOBJECT MAKE_DDHRESULT(850) +#define DXFILEERR_BADVALUE MAKE_DDHRESULT(851) +#define DXFILEERR_BADTYPE MAKE_DDHRESULT(852) +#define DXFILEERR_BADSTREAMHANDLE MAKE_DDHRESULT(853) +#define DXFILEERR_BADALLOC MAKE_DDHRESULT(854) +#define DXFILEERR_NOTFOUND MAKE_DDHRESULT(855) +#define DXFILEERR_NOTDONEYET MAKE_DDHRESULT(856) +#define DXFILEERR_FILENOTFOUND MAKE_DDHRESULT(857) +#define DXFILEERR_RESOURCENOTFOUND MAKE_DDHRESULT(858) +#define DXFILEERR_URLNOTFOUND MAKE_DDHRESULT(859) +#define DXFILEERR_BADRESOURCE MAKE_DDHRESULT(860) +#define DXFILEERR_BADFILETYPE MAKE_DDHRESULT(861) +#define DXFILEERR_BADFILEVERSION MAKE_DDHRESULT(862) +#define DXFILEERR_BADFILEFLOATSIZE MAKE_DDHRESULT(863) +#define DXFILEERR_BADFILECOMPRESSIONTYPE MAKE_DDHRESULT(864) +#define DXFILEERR_BADFILE MAKE_DDHRESULT(865) +#define DXFILEERR_PARSEERROR MAKE_DDHRESULT(866) +#define DXFILEERR_NOTEMPLATE MAKE_DDHRESULT(867) +#define DXFILEERR_BADARRAYSIZE MAKE_DDHRESULT(868) +#define DXFILEERR_BADDATAREFERENCE MAKE_DDHRESULT(869) +#define DXFILEERR_INTERNALERROR MAKE_DDHRESULT(870) +#define DXFILEERR_NOMOREOBJECTS MAKE_DDHRESULT(871) +#define DXFILEERR_BADINTRINSICS MAKE_DDHRESULT(872) +#define DXFILEERR_NOMORESTREAMHANDLES MAKE_DDHRESULT(873) +#define DXFILEERR_NOMOREDATA MAKE_DDHRESULT(874) +#define DXFILEERR_BADCACHEFILE MAKE_DDHRESULT(875) +#define DXFILEERR_NOINTERNET MAKE_DDHRESULT(876) + + +#ifdef __cplusplus +}; +#endif + +#endif /* _DXFILE_H_ */ + \ No newline at end of file diff --git a/plugins/ADK/d3d8/lib/DxErr8.lib b/plugins/ADK/d3d8/lib/DxErr8.lib new file mode 100644 index 0000000000000000000000000000000000000000..c22ccde6c023a6f942954ddcc11b2fc715f7d024 GIT binary patch literal 1083572 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 SpPsh!!t2wwCyF1)w*3#Z+;>|5 delta 180749 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 z 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