PlatformMesh.cpp 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  1. #include "PlatformMesh.h"
  2. #include "FTTUPtr.h"
  3. #include "CFTTRenderHelper.h"
  4. #include "CFTTShaderBuiltInConstants.h"
  5. #include "CFTTMaterialManager.h"
  6. static float g_f309C50[6] = {1.0, 1.0, 1.0, 0.0, 0.0, 0.0};
  7. //---------------------------------------------------------------------------------------------------------------------------------------------
  8. //0021B304 //^_^
  9. //单元测试等级: 游戏运行正常
  10. //单元测试内容: 1-5关
  11. //单元测试结果: 正常
  12. void PlatformMesh_Free(CFTTPlatformMesh *r0_pmesh) {
  13. r0_pmesh->pCFTTRenderHelper_94=NULL;
  14. //loc_21B32A
  15. for(int r5_i=0;r5_i<r0_pmesh->count_40;r5_i++){
  16. // /loc_21B31C
  17. FTT_pMtlL->ReleaseMaterial(r0_pmesh->uOPData_44.list_model[r5_i].tStr12_2.us_materialIndex_0);
  18. }
  19. delete[] ((char*)r0_pmesh);
  20. }
  21. //---------------------------------------------------------------------------------------------------------------------------------------------
  22. //0021B340 //^_^
  23. void PlatformMesh_PerMeshSetup(CFTTPlatformMesh const *pPlatformMesh1, CFTTVector32x4 const *pFTTVector32x42, CFTTVector32x4 const *pFTTVector32x43) {
  24. }
  25. //---------------------------------------------------------------------------------------------------------------------------------------------
  26. //0021b370 ^_^
  27. void PlatformMesh_Render(CFTTPlatformMesh* r0_pPlatformMesh1, int r1_i, unsigned short r2_us, unsigned int r3_u, unsigned int sp10_u)
  28. {
  29. CFTTModel_struct_14* r12_list_model = r0_pPlatformMesh1->uOPData_44.list_model;
  30. if (r2_us ==0xFFFF )
  31. r2_us = r12_list_model[r1_i].tStr12_2.us_materialIndex_0;
  32. if (r3_u == 0xFFFFFFFF)
  33. r3_u = r12_list_model[r1_i].tStr12_2.field_6;
  34. if (sp10_u == 0xFFFFFFFF)
  35. sp10_u = r12_list_model[r1_i].tStr12_2.field_2 *3;
  36. return ((CFTTRenderHelper*)r0_pPlatformMesh1->pCFTTRenderHelper_94.pType_0)->Render( &CFTTShaderBuiltInConstants::ms_matWorld, r2_us, r3_u,sp10_u);
  37. }
  38. //---------------------------------------------------------------------------------------------------------------------------------------------
  39. //0021b3c8 ^_^
  40. void PlatformMesh_PerMeshRestore(CFTTPlatformMesh const *pMesh) {
  41. }
  42. //---------------------------------------------------------------------------------------------------------------------------------------------
  43. //0021B3F0 //^_^
  44. void PlatformMesh_CreateVolatileResources(CFTTPlatformMesh *p_cfttplatformesh_r0_arg, bool b_r1_arg) {
  45. }
  46. //---------------------------------------------------------------------------------------------------------------------------------------------
  47. //0021B44A
  48. void PlatformMesh_DeleteVolatileResources(CFTTPlatformMesh *, bool) {
  49. }
  50. //---------------------------------------------------------------------------------------------------------------------------------------------
  51. //0021B452
  52. void PlatformMesh_CreateManagedResources(CFTTPlatformMesh *, bool) {
  53. // empty
  54. }
  55. //---------------------------------------------------------------------------------------------------------------------------------------------
  56. //0021B454
  57. void PlatformMesh_DeleteManagedResources(CFTTPlatformMesh *, bool) {
  58. // empty
  59. }
  60. //---------------------------------------------------------------------------------------------------------------------------------------------
  61. //0021B456 //^_^
  62. void PlatformMesh_SetVerts(CFTTPlatformMesh *p_cfttplatformesh_r0) {
  63. }
  64. //---------------------------------------------------------------------------------------------------------------------------------------------
  65. //0021b478 ^_^
  66. void PlatformMesh_SetIndices(CFTTPlatformMesh *pPlatformMesh1) {
  67. }
  68. //---------------------------------------------------------------------------------------------------------------------------------------------
  69. //0x0021b488 ^_- 测试8关无异常
  70. void PlatformMesh_ToModel(CFTTPlatformMesh* pfTTPlatformMesh1, TFTTModel* pfTTModel2, EMeshModelFlags eMeshModelFlags3)
  71. {
  72. //LOGE("PlatformMesh_ToModel ");
  73. //0021B488
  74. TFTTVertexDescriptor* pTFTTVertexDescriptor_r6 = pfTTPlatformMesh1->uOPData_3C.pTFTTVertexDescriptor;
  75. FTTGetFVFFromDescriptor(pTFTTVertexDescriptor_r6);
  76. pfTTModel2->field_12 = 0;
  77. //!!!!!!注意这里的除法 field_58 定义需要改为short
  78. int sp4 = pfTTPlatformMesh1->field_30 / (short)pfTTPlatformMesh1->field_58;
  79. pfTTModel2->dCount_C = sp4;
  80. void* pr12 = pfTTModel2 + 1;
  81. pfTTModel2->us_10 = pfTTPlatformMesh1->count_40;
  82. if (eMeshModelFlags3 & 1)
  83. {
  84. pfTTModel2->u_28.pfTTModel = (TFTTModel*)pr12;
  85. pfTTModel2->u_34.pdat = (ushort*)((int)pr12 + pfTTModel2->us_10 * 12);
  86. unsigned int u_r12 = (3 + pfTTModel2->us_10 * 2) & 0x3FFFC;
  87. char b_r7 = 0;
  88. unsigned int u_r3 = 0;
  89. //goto loc_21B4F4;
  90. //loc_21B4E4
  91. while (pfTTModel2->us_10 > b_r7)
  92. {
  93. CFTTModel_struct_14* p_list_model2_r1 = pfTTPlatformMesh1->uOPData_44.list_model;
  94. u_r3 = p_list_model2_r1[b_r7].tStr12_2.field_2 + u_r3;
  95. b_r7++;
  96. }
  97. unsigned int p_r0 = (int)pfTTModel2->u_34.pdat + u_r12;
  98. pfTTModel2->field_E = u_r3;
  99. pfTTModel2->u_24.index = p_r0;
  100. unsigned int sp10 = (3 + u_r3 * 6) & 0xFFFFFFFC;
  101. unsigned char b_r10 = 0;
  102. unsigned int u_r9 = 0;
  103. //loc_21B57A:
  104. while (b_r10 < pfTTModel2->us_10)
  105. {
  106. //21B522
  107. CFTTModel_struct_14* plistMode_r2 = pfTTPlatformMesh1->uOPData_44.list_model;
  108. unsigned short us_r7 = plistMode_r2[b_r10].field_0;
  109. TFTTModel_struct_C_1* pTFTTModel_struct_C_1_r8 = &pfTTModel2->u_28.list_C[b_r10];//r8
  110. pTFTTModel_struct_C_1_r8->field_8 = us_r7;
  111. pTFTTModel_struct_C_1_r8->field_4 = 0;
  112. int ir2 = plistMode_r2[b_r10].tStr12_2.field_2;
  113. pTFTTModel_struct_C_1_r8->field_0 = 0;
  114. pTFTTModel_struct_C_1_r8->field_6 = ir2;
  115. int i_r1 = plistMode_r2[b_r10].tStr12_2.field_6;
  116. unsigned short* pus_r0 = pfTTModel2->u_24.pusbuf;
  117. unsigned u_r2 = ((unsigned short)ir2)*6;
  118. ushort* pus_r3 = pfTTPlatformMesh1->uOPData_34.pusData;
  119. memcpy((void*) & pus_r0[u_r9], (void*)&pus_r3[i_r1], u_r2 );
  120. unsigned u_r1 = pTFTTModel_struct_C_1_r8->field_6;
  121. b_r10++;
  122. u_r1 *= 3;
  123. u_r9 += u_r1;
  124. }
  125. pr12 = (void*)((int)p_r0 + sp10);
  126. //loc_21B5B0:
  127. unsigned char b_lr = 0;
  128. unsigned short* pus_r1;
  129. while (b_lr < pfTTModel2->us_10)
  130. {
  131. //loc_21B596
  132. CFTTModel_struct_14* pCFTTModel_struct_14_r3 = pfTTPlatformMesh1->uOPData_44.list_model;
  133. pus_r1 = pfTTModel2->u_34.pdat;
  134. pfTTModel2->u_34.pdat[b_lr] = pCFTTModel_struct_14_r3[b_lr].tStr12_2.us_materialIndex_0;
  135. b_lr++;
  136. }
  137. }
  138. //loc_21B5BE:
  139. unsigned int u_lr = eMeshModelFlags3 & 2;
  140. if (u_lr)
  141. {
  142. pfTTModel2->u_1C.pusbuf = (ushort*)pr12;
  143. pr12 = (void*)((int)pr12 + 12 * sp4);
  144. }
  145. unsigned int sp8 = eMeshModelFlags3 & 4; //r1
  146. float f_s0 = 32767.0;
  147. if (sp8)
  148. {
  149. pfTTModel2->u_20.pusbuf =(ushort*)pr12;
  150. pr12 = (void*)((int)pr12 + 12 * sp4);
  151. }
  152. float f_s2 = 65535.0;
  153. unsigned sp14 = eMeshModelFlags3 & 8;
  154. float f_s4 = 0.0;
  155. if (sp14)
  156. {
  157. pfTTModel2->u_30.pusbuf = (ushort*)pr12;
  158. pr12 = (void*)((int)pr12 + 12 * sp4);
  159. }
  160. unsigned sp10 = eMeshModelFlags3 & 0x20;
  161. if (sp10)
  162. {
  163. pfTTModel2->u_38.pusbuf = (ushort*)pr12;
  164. pr12 = (void*)((int)pr12 + 4 * sp4);
  165. }
  166. unsigned sp18 = eMeshModelFlags3 & 0x40;
  167. if (sp18)
  168. {
  169. unsigned int u_r1 = (int)pr12 + 2 * sp4;
  170. pfTTModel2->pmodel_struct_C_2_40 = (TFTTModel_struct_C_2*)u_r1;
  171. pfTTModel2->pmodel_struct_C_3_3C =(TFTTModel_struct_C_3*) pr12;
  172. pr12 = (void*)((int)u_r1 + 16 * sp4);
  173. }
  174. unsigned int u_r2 = eMeshModelFlags3 & 0x10;
  175. unsigned int spC = u_r2;
  176. if (spC)
  177. pfTTModel2->u_2C.index = (int)pr12;
  178. //loc_21BA12:
  179. //LOGE("PlatformMesh_ToModel while b ");
  180. while (pTFTTVertexDescriptor_r6->field_0 != -1)
  181. {
  182. //loc_21B638:
  183. unsigned int u_r8 = 0;
  184. unsigned int u_r9 = 0;
  185. unsigned int u_r10 = 0;
  186. unsigned int u_r11 = 0;
  187. //goto loc_21BA0A;
  188. //loc_21BA0A:
  189. for (; u_r11 != sp4; u_r11++)
  190. {
  191. unsigned int* p_r12 = (unsigned int*)(pfTTPlatformMesh1->field_58 * u_r11
  192. + pfTTPlatformMesh1->uOPData_2C.pData + pTFTTVertexDescriptor_r6->field_C);
  193. switch (pTFTTVertexDescriptor_r6->field_4)
  194. {
  195. case 0:
  196. {
  197. // LOGE("PlatformMesh_ToModel switch 0 ");
  198. //loc_21B67C:
  199. if (u_lr)
  200. {
  201. if (pTFTTVertexDescriptor_r6->field_0 == 2)
  202. {
  203. //LOGE("PlatformMesh_ToModel switch 0 2 ");
  204. ((int*)(pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf))[0] = p_r12[0];
  205. ((int*)(pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf))[1] = p_r12[1];
  206. ((int*)(pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf))[2] = p_r12[2];
  207. }
  208. //loc_21B6B2
  209. if (pTFTTVertexDescriptor_r6->field_0 == 0x1A)
  210. {
  211. //LOGE("PlatformMesh_ToModel switch 0 1a ");
  212. int icount_r7 = 0;
  213. pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf[0] = (float)(((short*)p_r12)[0]) / (float)32767.0;
  214. pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf[1] = (float)(((short*)p_r12)[1]) / (float)32767.0;
  215. pfTTModel2->u_1C.pmodel_union_struct_2[u_r11].pfbuf[2] = (float)(((short*)p_r12)[2]) / (float)32767.0;
  216. //LOGE("PlatformMesh_ToModel switch 0 1a while begin ");
  217. //loc_21B72C
  218. while (icount_r7 != 0x3)
  219. {
  220. //loc_21B70E
  221. pfTTModel2->u_1C.pmodel_union_struct_2[u_r8].pfbuf[icount_r7] =
  222. pfTTPlatformMesh1->pfloat_array_68[icount_r7]
  223. + pfTTPlatformMesh1->pfloat_array_5C[icount_r7]*
  224. pfTTModel2->u_1C.pmodel_union_struct_2[u_r8].pfbuf[icount_r7];
  225. icount_r7++;
  226. }
  227. // LOGE("PlatformMesh_ToModel switch 0 1a end ");
  228. }
  229. }
  230. break;
  231. }
  232. case 1:
  233. {
  234. // LOGE("PlatformMesh_ToModel switch 1 ");
  235. if (sp18)
  236. {
  237. pfTTModel2->pmodel_struct_C_2_40[u_r11].pfloatArray[0] = (float)(((unsigned short*)p_r12)[0]) / (float)65535.0;
  238. pfTTModel2->pmodel_struct_C_2_40[u_r11].pfloatArray[1] = (float)(((unsigned short*)p_r12)[1]) / (float)65535.0;
  239. pfTTModel2->pmodel_struct_C_2_40[u_r11].pfloatArray[2] = (float)(((unsigned short*)p_r12)[2]) / (float)65535.0;
  240. pfTTModel2->pmodel_struct_C_2_40[u_r11].pfloatArray[3] = (float)(((unsigned short*)p_r12)[3]) / (float)65535.0;
  241. int icount_r2 = 0;
  242. float f_s6 = 0.0;
  243. //loc_21B7C8
  244. while (icount_r2 != 4)
  245. {
  246. //loc_21B7BC
  247. f_s6 += pfTTModel2->pmodel_struct_C_2_40[u_r10].pfloatArray[icount_r2++];
  248. }
  249. int icount_r7 = 0;
  250. //loc_21B7E4
  251. while (icount_r7 != 2)
  252. {
  253. //loc_21B7D0
  254. pfTTModel2->pmodel_struct_C_2_40[u_r9].pfloatArray[icount_r7] = pfTTModel2->pmodel_struct_C_2_40[u_r9].pfloatArray[icount_r7] / f_s6;
  255. icount_r7++;
  256. }
  257. }
  258. break;
  259. }
  260. case 2:
  261. {
  262. // LOGE("PlatformMesh_ToModel switch 2 ");
  263. //loc_21B880
  264. if (sp18!=0)
  265. {
  266. pfTTModel2->pmodel_struct_C_3_3C[u_r11].field_0 = ((char*)p_r12)[0];
  267. pfTTModel2->pmodel_struct_C_3_3C[u_r11].field_1 = ((char*)p_r12)[1];
  268. }
  269. break;
  270. }
  271. case 3:
  272. {
  273. // LOGE("PlatformMesh_ToModel switch 3 ");
  274. //loc_21B8A2
  275. if (sp8)
  276. {
  277. if (pTFTTVertexDescriptor_r6->field_0 == 2)
  278. {
  279. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[0] = ((float*)p_r12)[0];
  280. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[1] = ((float*)p_r12)[1];
  281. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[2] = ((float*)p_r12)[2];
  282. }
  283. //loc_21B8D6
  284. if (pTFTTVertexDescriptor_r6->field_0 == 0x1A)
  285. {
  286. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[0] = (float)(((short*)p_r12)[0]) / (float)32767.0;
  287. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[1] = (float)(((short*)p_r12)[1]) / (float)32767.0;
  288. pfTTModel2->u_20.pmodel_union_struct_2[u_r11].pfbuf[2] = (float)(((short*)p_r12)[2]) / (float)32767.0;
  289. }
  290. }
  291. break;
  292. }
  293. case 5:
  294. {
  295. // LOGE("PlatformMesh_ToModel switch 5 ");
  296. //loc_21B930
  297. if (spC)
  298. {
  299. int i_r7 = sp4;
  300. if (pTFTTVertexDescriptor_r6->field_8 != 1)
  301. i_r7 = 0;
  302. if (pTFTTVertexDescriptor_r6->field_0 == 1)
  303. {
  304. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[0] = p_r12[0];
  305. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[1] = p_r12[1];
  306. }
  307. //loc_21B968
  308. if (pTFTTVertexDescriptor_r6->field_0 == 0x19)
  309. {
  310. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[0]=(float)(((short*)p_r12)[0]) / (float) 32767.0;
  311. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[1]= (float)(((short*)p_r12)[1]) / (float)32767.0;
  312. CFTTVector32x4* pfttVector32x4 = &pfTTPlatformMesh1->pfTTVector32x4_74;
  313. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[0] =
  314. pfttVector32x4[pTFTTVertexDescriptor_r6->field_8].my[2] +
  315. pfttVector32x4[pTFTTVertexDescriptor_r6->field_8].my[0] *
  316. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[0];
  317. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[1] =
  318. pfttVector32x4[pTFTTVertexDescriptor_r6->field_8].my[3] +
  319. pfttVector32x4[pTFTTVertexDescriptor_r6->field_8].my[1] *
  320. pfTTModel2->u_2C.pmodel_union_struct_3[i_r7 + u_r11].pfbuf[1];
  321. }
  322. }
  323. break;
  324. }
  325. case 6:
  326. {
  327. //LOGE("PlatformMesh_ToModel switch 6 ");
  328. //loc_21B7EA
  329. if (sp14)
  330. {
  331. if (pTFTTVertexDescriptor_r6->field_0 == 2)
  332. {
  333. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[0] = ((float*)p_r12)[0];
  334. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[1] = ((float*)p_r12)[1];
  335. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[2] = ((float*)p_r12)[2];
  336. }
  337. //loc_21B820
  338. if (pTFTTVertexDescriptor_r6->field_0 == 0x1A)
  339. {
  340. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[0] = (float)(((short*)p_r12)[0]) / 32767.0;
  341. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[1] = (float)(((short*)p_r12)[1]) / 32767.0;
  342. pfTTModel2->u_30.pmodel_union_struct_2[u_r11].pfbuf[2] = (float)(((short*)p_r12)[2]) / 32767.0;
  343. }
  344. }
  345. break;
  346. }
  347. case 10:
  348. {
  349. // LOGE("PlatformMesh_ToModel switch 10 ");
  350. if (sp10)
  351. pfTTModel2->u_38.pibuf[u_r11] = p_r12[0];
  352. break;
  353. }
  354. default:
  355. break;
  356. }
  357. //def_21B662
  358. u_r8 += 1;
  359. u_r9 +=1;
  360. u_r10 += 1;//
  361. }
  362. pTFTTVertexDescriptor_r6++;
  363. }
  364. //LOGE("PlatformMesh_ToModel memcpy ");
  365. memcpy((void*)&pfTTModel2->float32x2_t_54, (void*)&pfTTPlatformMesh1->tPlatformModel_0.tfloat32x2_24, sizeof(float32x2_t));
  366. memcpy((void*)&pfTTModel2->float32x2_t_44, (void*)&pfTTPlatformMesh1->tPlatformModel_0.tfloat32x2_14, sizeof(float32x2_t)*2);
  367. //LOGE("PlatformMesh_ToModel memcpy end ");
  368. return;
  369. }
  370. //---------------------------------------------------------------------------------------------------------------------------------------------
  371. //0021BA38
  372. void PlatformMesh_FromModel(CFTTPlatformMesh *, CFTTPlatformMesh *, TFTTModel *, EMeshModelFlags) {
  373. }
  374. //---------------------------------------------------------------------------------------------------------------------------------------------
  375. /*
  376. 0021B304 PlatformMesh_Free
  377. 0021BA38 PlatformMesh_FromModel
  378. 0021B44A PlatformMesh_DeleteVolatileResources
  379. */