phantasmal-world/2.09a30c40490fa50171aa.js

1 line
20 KiB
JavaScript
Raw Normal View History

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