1 |
- var BABYLON;!(function(e){var t=(function(){function t(){this.materials=[],this.parseMTL=function(r,s,n){for(var i,a,o=s.split("\n"),l=0;l<o.length;l++){var u=o[l].trim();if(0!==u.length&&"#"!==u.charAt(0)){var p=u.indexOf(" "),h=p>=0?u.substring(0,p):u;h=h.toLowerCase();var m=p>=0?u.substring(p+1).trim():"";"newmtl"===h?(a&&this.materials.push(a),a=new e.StandardMaterial(m,r)):"kd"===h?(i=m.split(/\s+/,3),a.diffuseColor=e.Color3.FromArray(i)):"ka"===h?(i=m.split(/\s+/,3),a.ambientColor=e.Color3.FromArray(i)):"ks"===h?(i=m.split(/\s+/,3),a.specularColor=e.Color3.FromArray(i)):"ke"===h?(i=m.split(/\s+/,3),a.emissiveColor=e.Color3.FromArray(i)):"ns"===h?a.specularPower=m:"d"===h?a.alpha=m:"map_ka"===h?a.ambientTexture=t._getTexture(n,m,r):"map_kd"===h?a.diffuseTexture=t._getTexture(n,m,r):"map_ks"===h?a.specularTexture=t._getTexture(n,m,r):"map_ns"===h||("map_bump"===h?a.bumpTexture=t._getTexture(n,m,r):"map_d"===h&&(a.opacityTexture=t._getTexture(n,m,r)))}}this.materials.push(a)}}return t._getTexture=function(t,r,s){if(!r)return null;var n=t;if("file:"===t){var i=r.lastIndexOf("\\");-1===i&&(i=r.lastIndexOf("/")),n+=i>-1?r.substr(i+1):r}else n+=r;return new e.Texture(n,s)},t})();e.MTLFileLoader=t;var r=(function(){function r(){this.name="obj",this.extensions=".obj",this.obj=/^o/,this.group=/^g/,this.mtllib=/^mtllib /,this.usemtl=/^usemtl /,this.smooth=/^s /,this.vertexPattern=/v( +[\d|\.|\+|\-|e|E]+)( +[\d|\.|\+|\-|e|E]+)( +[\d|\.|\+|\-|e|E]+)/,this.normalPattern=/vn( +[\d|\.|\+|\-|e|E]+)( +[\d|\.|\+|\-|e|E]+)( +[\d|\.|\+|\-|e|E]+)/,this.uvPattern=/vt( +[\d|\.|\+|\-|e|E]+)( +[\d|\.|\+|\-|e|E]+)/,this.facePattern1=/f\s+(([\d]{1,}[\s]?){3,})+/,this.facePattern2=/f\s+((([\d]{1,}\/[\d]{1,}[\s]?){3,})+)/,this.facePattern3=/f\s+((([\d]{1,}\/[\d]{1,}\/[\d]{1,}[\s]?){3,})+)/,this.facePattern4=/f\s+((([\d]{1,}\/\/[\d]{1,}[\s]?){3,})+)/}return r.prototype._loadMTL=function(t,r,s){var n=e.Tools.BaseUrl+r+t;e.Tools.LoadFile(n,s,null,null,!1,(function(){console.warn("Error - Unable to load "+n)}))},r.prototype.importMesh=function(e,t,r,s,n,i,a){var o=this._parseSolid(e,t,r,s);return n&&o.forEach((function(e){n.push(e)})),!0},r.prototype.load=function(e,t,r){return this.importMesh(null,e,t,r,null,null,null)},r.prototype._parseSolid=function(s,n,i,a){for(var o,l=[],u=[],p=[],h=[],m=[],f=[],c=[],d=[],v=[],x=0,g=!1,T=[],_=[],I=[],P=[],b="",y="",F=new t,L=1,O=!0,w=function(e,t){e[t[0]]||(e[t[0]]={normals:[],idx:[]});var r=e[t[0]].normals.indexOf(t[1]);return-1===r?-1:e[t[0]].idx[r]},E=function(e,t){e[t[0]]||(e[t[0]]={normals:[],idx:[],uv:[]});var r=e[t[0]].normals.indexOf(t[1]);return 1!=r&&t[2]==e[t[0]].uv[r]?e[t[0]].idx[r]:-1},M=function(e,t,s,n,i,a){var o;o=r.OPTIMIZE_WITH_UV?E(v,[e,s,t]):w(v,[e,s]),-1==o?(m.push(f.length),f.push(n),c.push(i),d.push(a),v[e].normals.push(s),v[e].idx.push(x++),r.OPTIMIZE_WITH_UV&&v[e].uv.push(t)):m.push(o)},V=function(){for(var e=0;e<f.length;e++)T.push(f[e].x,f[e].y,f[e].z),_.push(d[e].x,d[e].y,d[e].z),I.push(c[e].x,c[e].y);f=[],d=[],c=[],v=[],x=0},A=function(e,t){t+1<e.length&&(P.push(e[0],e[t],e[t+1]),t+=1,A(e,t))},C=function(){h.length>0&&(o=h[h.length-1],V(),m.reverse(),o.indices=m.slice(),o.positions=T.slice(),o.normals=_.slice(),o.uvs=I.slice(),m=[],T=[],_=[],I=[])},B=i.split("\n"),N=0;N<B.length;N++){var U,k=B[N].trim();if(0!==k.length&&"#"!==k.charAt(0))if(null!==(U=this.vertexPattern.exec(k)))l.push(new e.Vector3(parseFloat(U[1]),parseFloat(U[2]),parseFloat(U[3])));else if(null!==(U=this.normalPattern.exec(k)))u.push(new e.Vector3(parseFloat(U[1]),parseFloat(U[2]),parseFloat(U[3])));else if(null!==(U=this.uvPattern.exec(k)))p.push(new e.Vector2(parseFloat(U[1]),parseFloat(U[2])));else if(null!==(U=this.facePattern3.exec(k)))!(function(e,t){A(e,t);for(var r=0;r<P.length;r++){var s=P[r].split("/"),n=parseInt(s[0])-1,i=parseInt(s[1])-1,a=parseInt(s[2])-1;M(n,i,a,l[n],p[i],u[a])}P=[]})(U[1].trim().split(" "),1);else if(null!==(U=this.facePattern4.exec(k)))!(function(t,r){A(t,r);for(var s=0;s<P.length;s++){var n=P[s].split("//"),i=parseInt(n[0])-1,a=parseInt(n[1])-1;M(i,1,a,l[i],e.Vector2.Zero(),u[a])}P=[]})(U[1].trim().split(" "),1);else if(null!==(U=this.facePattern2.exec(k)))!(function(t,r){A(t,r);for(var s=0;s<P.length;s++){var n=P[s].split("/"),i=parseInt(n[0])-1,a=parseInt(n[1])-1;M(i,a,0,l[i],p[a],e.Vector3.Up())}P=[]})(U[1].trim().split(" "),1);else if(null!==(U=this.facePattern1.exec(k)))!(function(t,r){A(t,r);for(var s=0;s<P.length;s++){var n=parseInt(P[s])-1;M(n,0,0,l[n],e.Vector2.Zero(),e.Vector3.Up())}P=[]})(U[1].trim().split(" "),1);else if(this.group.test(k)||this.obj.test(k)){var S={name:k.substring(2).trim(),indices:void 0,positions:void 0,normals:void 0,uvs:void 0,materialName:""};C(),h.push(S),g=!0,O=!0,L=1}else if(this.usemtl.test(k)){if(b=k.substring(7).trim(),!O){C();var S={name:"_mm"+L.toString(),indices:void 0,positions:void 0,normals:void 0,uvs:void 0,materialName:b};L++,h.push(S)}g&&O&&(h[h.length-1].materialName=b,O=!1)}else this.mtllib.test(k)?y=k.substring(7).trim():this.smooth.test(k)||console.log("Unhandled expression at line : "+k)}g&&(o=h[h.length-1],m.reverse(),V(),o.indices=m,o.positions=T,o.normals=_,o.uvs=I),g||(m.reverse(),V(),h.push({name:e.Geometry.RandomId(),indices:m,positions:T,normals:_,uvs:I,materialName:b}));for(var Z=[],j=[],H=0;H<h.length;H++){if(s&&h[H].name)if(s instanceof Array){if(-1==s.indexOf(h[H].name))continue}else if(h[H].name!==s)continue;o=h[H];var W=new e.Mesh(h[H].name,n);j.push(h[H].materialName);var Y=new e.VertexData;Y.positions=o.positions,Y.normals=o.normals,Y.uvs=o.uvs,Y.indices=o.indices,Y.applyToMesh(W),Z.push(W)}return""!==y&&this._loadMTL(y,a,(function(e){F.parseMTL(n,e,a);for(var t=0;t<F.materials.length;t++){for(var r,s=0,i=[];(r=j.indexOf(F.materials[t].name,s))>-1;)i.push(r),s=r+1;if(-1==r&&0==i.length)F.materials[t].dispose();else for(var o=0;o<i.length;o++)Z[i[o]].material=F.materials[t]}})),Z},r.OPTIMIZE_WITH_UV=!1,r})();e.OBJFileLoader=r,e.SceneLoader&&e.SceneLoader.RegisterPlugin(new r)})(BABYLON||(BABYLON={}));
|