phantasmal-world/2.b1070a6f6fa6c5cf2aec.js

1 line
29 KiB
JavaScript
Raw Normal View History

2020-01-06 06:19:08 +08:00
(window.webpackJsonp=window.webpackJsonp||[]).push([[2],{"0Xme":function(t,e,i){"use strict";i.d(e,"a",(function(){return a}));var s=i("sDu+"),n=i("jJhE"),r=(i("x1yY"),i("4VsB")),o=i("FXpb");class a extends s.a{constructor(t,e,i,s,n){super(n),this.element=Object(o.q)({className:`${e} core_Input`}),this._value=new r.a(this,t,this.set_value),this.value=this._value,this.input_element=Object(o.l)({className:`${s} core_Input_inner`}),this.input_element.type=i,this.input_element.addEventListener("change",()=>{this._value.set_val(this.get_value(),{silent:!1})}),n&&n.readonly&&this.set_attr("readOnly",!0),this.element.append(this.input_element)}set_enabled(t){super.set_enabled(t),this.input_element.disabled=!t}set_attr(t,e,i){if(null==e)return;const s=this.input_element,r=i||(t=>t);Object(n.a)(e)?(s[t]=r(e.val),this.disposable(e.observe(({value:e})=>s[t]=r(e)))):s[t]=r(e)}}},"488w":function(t,e,i){"use strict";i.d(e,"b",(function(){return l})),i.d(e,"a",(function(){return d}));var s=i("Womt"),n=i("tRdk"),r=i("kwt4"),o=i("vM2b");const a=new s.Vector3(0,1,0),h=new s.Vector2(0,0),u=new s.Vector3(0,0,0),c=new s.Quaternion(0,0,0,1),_=new s.Vector3(1,1,1);function l(t,e){new p(e).to_geometry_builder(t)}function d(t){return new p(new o.a).create_buffer_geometry(t)}class f{constructor(){this.vertices_stack=[]}put(t){this.vertices_stack.push(t)}get(t){const e=[];for(let i=this.vertices_stack.length-1;i>=0;i--){const s=this.vertices_stack[i][t];s&&e.push(s)}return e}}class p{constructor(t){this.vertices=new f,this.bone_id=0,this.builder=t}to_geometry_builder(t){this.object_to_geometry(t,void 0,new s.Matrix4)}create_buffer_geometry(t){return this.to_geometry_builder(t),this.builder.build()}object_to_geometry(t,e,i){const{no_translate:r,no_rotate:o,no_scale:a,hidden:h,break_child_trace:l,zxy_rotation_order:d,skip:f}=t.evaluation_flags,{position:p,rotation:b,scale:g}=t,m=new s.Euler(b.x,b.y,b.z,d?"ZXY":"ZYX"),w=(new s.Matrix4).compose(r?u:Object(n.a)(p),o?c:(new s.Quaternion).setFromEuler(m),a?_:Object(n.a)(g)).premultiply(i);let v;if(f?v=e:(v=new s.Bone,v.name=this.bone_id.toString(),v.position.set(p.x,p.y,p.z),v.setRotationFromEuler(m),v.scale.set(g.x,g.y,g.z),this.builder.add_bone(v),e&&e.add(v)),t.model&&!h&&this.model_to_geometry(t.model,w),this.bone_id++,!l)for(const e of t.children)this.object_to_geometry(e,v,w)}model_to_geometry(t,e){Object(r.b)(t)?this.njcm_model_to_geometry(t,e):this.xj_model_to_geometry(t,e)}njcm_model_to_geometry(t,e){const i=(new s.Matrix3).getNormalMatrix(e),r=t.vertices.map(t=>{const r=Object(n.a)(t.position),o=t.normal?Object(n.a)(t.normal):new s.Vector3(0,1,0);return r.applyMatrix4(e),o.applyMatrix3(i),{bone_id:this.bone_id,position:r,normal:o,bone_weight:t.bone_weight,bone_weight_status:t.bone_weight_status,calc_continue:t.calc_continue}});this.vertices.put(r);for(const e of t.meshes){const t=this.builder.index_count;for(let t=0;t<e.vertices.length;++t){const i=e.vertices[t],s=this.vertices.get(i.index);if(s.length){const n=s[0],r=n.normal||i.normal||a,o=this.builder.vertex_count;this.builder.add_vertex(n.position,r,e.has_tex_coords?i.tex_coords:h),t>=2&&(t%2==(e.clockwise_winding?1:0)?(this.builder.add_index(o-2),this.builder.add_index(o-1),this.builder.add_index(o)):(this.builder.add_index(o-2),this.builder.add_index(o),this.builder.add_index(o-1)));const u=[[0,0],[0,0],[0,0],[0,0]];for(let t=s.length-1;t>=0;t--){const e=s[t];u[e.bone_weight_status]=[e.bone_id,e.bone_weight]}const c=u.reduce((t,[,e])=>t+e,0);for(const[t,e]of u)this.builder.add_bone_weight(t,c>0?e/c:e)}}this.builder.add_group(t,this.builder.index_count-t,e.texture_id)}}xj_model_to_geometry(t,e){const i=this.builder.vertex_count,r=(new s.Matrix3).getNormalMatrix(e);for(const{position:i,normal:o,uv:a}of t.vertices){const t=Object(n.a)(i).applyMatrix4(e),u=(o?Object(n.a)(o):new s.Vector3(0,1,0)).applyMatrix3(r),c=a||h;this.builder.add_vertex(t,u,c)}let o;for(const e of t.meshes){const t=this.builder.index_count;let s=!1;for(let t=2;t<e.indices.length;++t){const n=i+e.indices[t-2],r=i+e.indices[t-1],o=i+e.indices[t],a=this.builder.get_positio