import_obj.ts 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. function import_obj_run(path: string, replace_existing: bool = true) {
  2. let i: split_type_t = context_raw.split_by;
  3. let is_udim: bool = i == split_type_t.UDIM;
  4. let split_code: i32 =
  5. (i == split_type_t.OBJECT || is_udim) ? char_code_at("o", 0) :
  6. i == split_type_t.GROUP ? char_code_at("g", 0) :
  7. char_code_at("u", 0); // usemtl
  8. let b: buffer_t = data_get_blob(path);
  9. if (is_udim) {
  10. let part: any = krom_io_obj_parse(b, split_code, 0, is_udim);
  11. let name: string = part.name;
  12. for (let i: i32 = 0; i < part.udims.length; ++i) {
  13. if (part.udims[i].length == 0) {
  14. continue;
  15. }
  16. let u: i32 = i % part.udims_u;
  17. let v: i32 = math_floor(i / part.udims_u);
  18. part.name = name + "." + (1000 + v * 10 + u + 1);
  19. part.inda = part.udims[i];
  20. i == 0 ? (replace_existing ? import_mesh_make_mesh(part, path) : import_mesh_add_mesh(part)) : import_mesh_add_mesh(part);
  21. }
  22. }
  23. else {
  24. let parts: any[] = [];
  25. let part: any = krom_io_obj_parse(b, split_code, 0, false);
  26. array_push(parts, part);
  27. while (part.has_next) {
  28. part = krom_io_obj_parse(b, split_code, part.pos, false);
  29. // This part does not contain faces (may contain lines only)
  30. if (part.inda.length == 0) {
  31. continue;
  32. }
  33. array_push(parts, part);
  34. }
  35. if (context_raw.split_by == split_type_t.MATERIAL) {
  36. let posa0: i16_array_t;
  37. let posa1: i16_array_t;
  38. let nora0: i16_array_t;
  39. let nora1: i16_array_t;
  40. let texa0: i16_array_t;
  41. let texa1: i16_array_t;
  42. let inda0: u32_array_t;
  43. let inda1: u32_array_t;
  44. // Merge to single object per material
  45. for (let i: i32 = 0; i < parts.length; ++i) {
  46. let j: i32 = i + 1;
  47. while (j < parts.length) {
  48. if (parts[i].name == parts[j].name) {
  49. posa0 = parts[i].posa;
  50. posa1 = parts[j].posa;
  51. nora0 = parts[i].nora;
  52. nora1 = parts[j].nora;
  53. texa0 = parts[i].texa != null ? parts[i].texa : null;
  54. texa1 = parts[j].texa != null ? parts[j].texa : null;
  55. inda0 = parts[i].inda;
  56. inda1 = parts[j].inda;
  57. let voff: i32 = math_floor(posa0.length / 4);
  58. // Repack merged positions
  59. let posa32: f32_array_t = f32_array_create(math_floor(posa0.length / 4) * 3 + math_floor(posa1.length / 4) * 3);
  60. for (let k: i32 = 0; k < math_floor(posa0.length / 4); ++k) {
  61. posa32[k * 3 ] = posa0[k * 4 ] / 32767 * parts[i].scale_pos;
  62. posa32[k * 3 + 1] = posa0[k * 4 + 1] / 32767 * parts[i].scale_pos;
  63. posa32[k * 3 + 2] = posa0[k * 4 + 2] / 32767 * parts[i].scale_pos;
  64. }
  65. for (let k: i32 = 0; k < math_floor(posa1.length / 4); ++k) {
  66. posa32[voff * 3 + k * 3 ] = posa1[k * 4 ] / 32767 * parts[j].scale_pos;
  67. posa32[voff * 3 + k * 3 + 1] = posa1[k * 4 + 1] / 32767 * parts[j].scale_pos;
  68. posa32[voff * 3 + k * 3 + 2] = posa1[k * 4 + 2] / 32767 * parts[j].scale_pos;
  69. }
  70. let scale_pos: f32 = 0.0;
  71. for (let k: i32 = 0; k < posa32.length; ++k) {
  72. let f: f32 = math_abs(posa32[k]);
  73. if (scale_pos < f) {
  74. scale_pos = f;
  75. }
  76. }
  77. let inv: f32 = 32767 * (1 / scale_pos);
  78. let posa: i16_array_t = i16_array_create(posa0.length + posa1.length);
  79. for (let k: i32 = 0; k < math_floor(posa.length / 4); ++k) {
  80. posa[k * 4 ] = math_floor(posa32[k * 3 ] * inv);
  81. posa[k * 4 + 1] = math_floor(posa32[k * 3 + 1] * inv);
  82. posa[k * 4 + 2] = math_floor(posa32[k * 3 + 2] * inv);
  83. }
  84. for (let k: i32 = 0; k < math_floor(posa0.length / 4); ++k) {
  85. posa[k * 4 + 3] = posa0[k * 4 + 3];
  86. }
  87. for (let k: i32 = 0; k < math_floor(posa1.length / 4); ++k) {
  88. posa[posa0.length + k * 4 + 3] = posa1[k * 4 + 3];
  89. }
  90. // Merge normals and uvs
  91. let nora: i16_array_t = i16_array_create(nora0.length + nora1.length);
  92. let texa: i16_array_t = (texa0 != null && texa1 != null) ? i16_array_create(texa0.length + texa1.length) : null;
  93. let inda: u32_array_t = u32_array_create(inda0.length + inda1.length);
  94. nora.set(nora0);
  95. nora.set(nora1, nora0.length);
  96. if (texa != null) {
  97. texa.set(texa0);
  98. texa.set(texa1, texa0.length);
  99. }
  100. inda.set(inda0);
  101. for (let k: i32 = 0; k < inda1.length; ++k) {
  102. inda[k + inda0.length] = inda1[k] + voff;
  103. }
  104. parts[i].posa = posa;
  105. parts[i].nora = nora;
  106. parts[i].texa = texa;
  107. parts[i].inda = inda;
  108. parts[i].scale_pos = scale_pos;
  109. array_splice(parts, j, 1);
  110. }
  111. else {
  112. j++;
  113. }
  114. }
  115. }
  116. }
  117. replace_existing ? import_mesh_make_mesh(parts[0], path) : import_mesh_add_mesh(parts[0]);
  118. for (let i: i32 = 1; i < parts.length; ++i) {
  119. import_mesh_add_mesh(parts[i]);
  120. }
  121. }
  122. data_delete_blob(path);
  123. }