2023-01-01 02:06:02 +01:00
|
|
|
function readObj(path, flipUV = false) {
|
2022-12-12 09:08:03 +01:00
|
|
|
if(!file_exists(path)) return noone;
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
var _VB = [];
|
|
|
|
var _VBT = [];
|
2022-12-12 09:08:03 +01:00
|
|
|
var _VBN = [];
|
2022-01-13 05:24:03 +01:00
|
|
|
var mats = [];
|
2022-12-12 09:08:03 +01:00
|
|
|
var matIndex = [];
|
2022-12-18 03:20:38 +01:00
|
|
|
var use_normal = true;
|
2022-01-13 05:24:03 +01:00
|
|
|
var v = ds_list_create();
|
|
|
|
var vt = ds_list_create();
|
2022-12-12 09:08:03 +01:00
|
|
|
var vn = ds_list_create();
|
2022-01-13 05:24:03 +01:00
|
|
|
var f = ds_list_create();
|
|
|
|
var ft = ds_list_create();
|
2022-12-12 09:08:03 +01:00
|
|
|
var fn = ds_list_create();
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
var file = file_text_open_read(path);
|
|
|
|
while(!file_text_eof(file)) {
|
|
|
|
var l = file_text_readln(file);
|
|
|
|
l = string_replace_all(l, "\n", "");
|
|
|
|
|
|
|
|
var sep = string_splice(l, " ");
|
|
|
|
if(array_length(sep) == 0 || sep[0] == "") continue;
|
|
|
|
|
|
|
|
switch(sep[0]) {
|
|
|
|
case "v" :
|
|
|
|
ds_list_add(v, [ toNumber(sep[1]), toNumber(sep[2]), toNumber(sep[3]) ]);
|
|
|
|
break;
|
|
|
|
case "vt" :
|
2023-01-01 02:06:02 +01:00
|
|
|
if(flipUV)
|
|
|
|
ds_list_add(vt, [ 1 + toNumber(sep[1]), -toNumber(sep[2]) ]);
|
|
|
|
else
|
|
|
|
ds_list_add(vt, [ toNumber(sep[1]), toNumber(sep[2]) ]);
|
2022-12-12 09:08:03 +01:00
|
|
|
break;
|
|
|
|
case "vn" :
|
|
|
|
ds_list_add(vn, [ toNumber(sep[1]), toNumber(sep[2]), toNumber(sep[3]) ]);
|
2022-01-13 05:24:03 +01:00
|
|
|
break;
|
|
|
|
case "f" :
|
|
|
|
var f1 = string_splice(sep[1], "/");
|
|
|
|
var f2 = string_splice(sep[2], "/");
|
|
|
|
var f3 = string_splice(sep[3], "/");
|
|
|
|
|
|
|
|
ds_list_add(f, [f1[0], f2[0], f3[0]]);
|
|
|
|
ds_list_add(ft, [f1[1], f2[1], f3[1]]);
|
2022-12-18 03:20:38 +01:00
|
|
|
if(array_length(f1) > 2) ds_list_add(fn, [f1[2], f2[2], f3[2]]);
|
|
|
|
else {
|
|
|
|
ds_list_add(fn, [0, 0, 0]);
|
|
|
|
use_normal = false;
|
|
|
|
}
|
2022-01-13 05:24:03 +01:00
|
|
|
break;
|
|
|
|
case "usemtl" :
|
2023-01-01 02:06:02 +01:00
|
|
|
var mname = string_replace_all(sep[1], "\n", "");
|
|
|
|
mname = string_replace_all(mname, "\r", "");
|
|
|
|
|
|
|
|
array_push_unique(mats, mname);
|
|
|
|
array_push(matIndex, array_find(mats, mname));
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
if(!ds_list_empty(f)) {
|
|
|
|
array_push(_VB, f);
|
|
|
|
array_push(_VBT, ft);
|
2022-12-12 09:08:03 +01:00
|
|
|
array_push(_VBN, fn);
|
2022-01-13 05:24:03 +01:00
|
|
|
f = ds_list_create();
|
|
|
|
ft = ds_list_create();
|
2022-12-12 09:08:03 +01:00
|
|
|
fn = ds_list_create();
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!ds_list_empty(f)) {
|
|
|
|
array_push(_VB, f);
|
|
|
|
array_push(_VBT, ft);
|
2022-12-12 09:08:03 +01:00
|
|
|
array_push(_VBN, fn);
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
file_text_close(file);
|
|
|
|
|
2022-12-12 09:08:03 +01:00
|
|
|
#region centralize vertex
|
|
|
|
var cv = [0, 0, 0];
|
|
|
|
var vertex = ds_list_size(v);
|
|
|
|
for( var i = 0; i < vertex; i++ ) {
|
|
|
|
var _v = v[| i];
|
|
|
|
cv[0] += _v[0];
|
|
|
|
cv[1] += _v[1];
|
|
|
|
cv[2] += _v[2];
|
|
|
|
}
|
|
|
|
|
|
|
|
cv[0] /= vertex;
|
|
|
|
cv[1] /= vertex;
|
|
|
|
cv[2] /= vertex;
|
|
|
|
|
|
|
|
for( var i = 0; i < ds_list_size(v); i++ ) {
|
|
|
|
v[| i][0] -= cv[0];
|
|
|
|
v[| i][1] -= cv[1];
|
|
|
|
v[| i][2] -= cv[2];
|
|
|
|
}
|
|
|
|
#endregion
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
var VBS = [];
|
|
|
|
for(var i = 0; i < array_length(_VB); i++) {
|
|
|
|
var VB = vertex_create_buffer();
|
2022-12-12 09:08:03 +01:00
|
|
|
vertex_begin(VB, FORMAT_PNT);
|
2022-01-13 05:24:03 +01:00
|
|
|
var face = _VB[i];
|
|
|
|
var facet = _VBT[i];
|
2022-12-12 09:08:03 +01:00
|
|
|
var facen = _VBN[i];
|
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
for(var j = 0; j < ds_list_size(face); j++) {
|
|
|
|
var _f = face[| j];
|
|
|
|
var _f1 = v[| _f[0] - 1];
|
|
|
|
var _f2 = v[| _f[1] - 1];
|
|
|
|
var _f3 = v[| _f[2] - 1];
|
|
|
|
|
|
|
|
var _ft = facet[| j];
|
|
|
|
var _ft1 = vt[| _ft[0] - 1];
|
|
|
|
var _ft2 = vt[| _ft[1] - 1];
|
|
|
|
var _ft3 = vt[| _ft[2] - 1];
|
|
|
|
|
2022-12-12 09:08:03 +01:00
|
|
|
var _fn = facen[| j];
|
2022-12-18 03:20:38 +01:00
|
|
|
var _fn1 = _fn[0]? vn[| _fn[0] - 1] : [0, 0, 0];
|
|
|
|
var _fn2 = _fn[1]? vn[| _fn[1] - 1] : [0, 0, 0];
|
|
|
|
var _fn3 = _fn[2]? vn[| _fn[2] - 1] : [0, 0, 0];
|
2022-12-12 09:08:03 +01:00
|
|
|
|
|
|
|
vertex_add_pnt(VB, _f1, _fn1, _ft1 );
|
|
|
|
vertex_add_pnt(VB, _f2, _fn2, _ft2 );
|
|
|
|
vertex_add_pnt(VB, _f3, _fn3, _ft3 );
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|
|
|
|
vertex_end(VB);
|
|
|
|
vertex_freeze(VB);
|
|
|
|
|
|
|
|
array_push(VBS, VB);
|
|
|
|
|
|
|
|
ds_list_destroy(face);
|
|
|
|
ds_list_destroy(facet);
|
|
|
|
}
|
|
|
|
|
|
|
|
ds_list_destroy(v);
|
|
|
|
ds_list_destroy(vt);
|
2022-12-12 09:08:03 +01:00
|
|
|
ds_list_destroy(vn);
|
|
|
|
ds_list_destroy(f);
|
|
|
|
ds_list_destroy(ft);
|
|
|
|
ds_list_destroy(fn);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-12-18 03:20:38 +01:00
|
|
|
return [ VBS, mats, matIndex, use_normal ];
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|