mirror of
https://github.com/DaanVandenBosch/phantasmal-world.git
synced 2025-04-05 15:28:29 +08:00
1 line
16 KiB
JavaScript
1 line
16 KiB
JavaScript
![]() |
(window.webpackJsonp=window.webpackJsonp||[]).push([[16],{496:function(e,t,i){"use strict";var n;i.d(t,"b",(function(){return n})),i.d(t,"a",(function(){return s})),function(e){e[e.RGBA_S3TC_DXT1=0]="RGBA_S3TC_DXT1",e[e.RGBA_S3TC_DXT3=1]="RGBA_S3TC_DXT3"}(n||(n={}));class s{constructor(e,t,i,n,s){this.gfx=e,this.format=t,this.width=i,this.height=n,this.data=s}upload(){null==this.gfx_texture&&(this.gfx_texture=this.gfx.create_texture(this.format,this.width,this.height,this.data))}destroy(){this.gfx.destroy_texture(this.gfx_texture)}}},517:function(e,t,i){"use strict";i.d(t,"b",(function(){return r})),i.d(t,"a",(function(){return o}));var n=i(136),s=i(463);function r(e){return new n.Vector3(e.x,e.y,e.z)}function o(e){return new s.c(e.x,e.y,e.z)}},545:function(e,t,i){"use strict";i.d(t,"b",(function(){return r})),i.d(t,"a",(function(){return o})),i.d(t,"c",(function(){return a}));var n=i(136),s=i(496);function r(e,t){let i,n;switch(t.format[1]){case 6:i=s.b.RGBA_S3TC_DXT1,n=t.width*t.height/2;break;case 7:i=s.b.RGBA_S3TC_DXT3,n=t.width*t.height;break;default:throw new Error(`Format ${t.format.join(", ")} not supported.`)}return new s.a(e,i,t.width,t.height,t.data.slice(0,n))}function o(e){return e.textures.map(a)}function a(e){let t,i;switch(e.format[1]){case 6:t=n.RGBA_S3TC_DXT1_Format,i=e.width*e.height/2;break;case 7:t=n.RGBA_S3TC_DXT3_Format,i=e.width*e.height;break;default:throw new Error(`Format ${e.format.join(", ")} not supported.`)}const s=new n.CompressedTexture([{data:new Uint8Array(e.data,0,i),width:e.width,height:e.height}],e.width,e.height,t);return s.minFilter=n.LinearFilter,s.wrapS=n.MirroredRepeatWrapping,s.wrapT=n.MirroredRepeatWrapping,s.needsUpdate=!0,s}},552:function(e,t,i){"use strict";i.d(t,"a",(function(){return r})),i.d(t,"b",(function(){return o}));var n=i(136),s=i(550);const r=30;function o(e,t){const i=t.interpolation===s.a.Spline?n.InterpolateSmooth:n.InterpolateLinear,o=[];return t.motion_data.forEach((t,a)=>{const h=e.get_bone(a);h&&t.tracks.forEach(({type:e,keyframes:t})=>{const c=[],d=[];for(const i of t)if(c.push(i.frame/r),e===s.b.Rotation){const e=h.evaluation_flags.zxy_rotation_order?"ZXY":"ZYX",t=(new n.Quaternion).setFromEuler(new n.Euler(i.value.x,i.value.y,i.value.z,e));d.push(t.x,t.y,t.z,t.w)}else d.push(i.value.x,i.value.y,i.value.z);if(e===s.b.Rotation)o.push(new n.QuaternionKeyframeTrack(`.bones[${a}].quaternion`,c,d,i));else{const t=e===s.b.Position?`.bones[${a}].position`:`.bones[${a}].scale`;o.push(new n.VectorKeyframeTrack(t,c,d,i))}})}),new n.AnimationClip("Animation",(t.frame_count-1)/r,o).optimize()}},584:function(e,t,i){"use strict";i.d(t,"a",(function(){return o}));var n=i(136),s=i(40);class r{constructor(){this.materials=[{alpha:!1,additive_blending:!1}],this.map=new Map}add_material(e,t=!1,i=!1){if(null==e)return 0;{const n=e<<2|(t?2:0)|(i?1:0);return Object(s.h)(this.map,n,()=>(this.materials.push({texture_id:e,alpha:t,additive_blending:i}),this.materials.length-1))}}get_materials(){return this.materials}}class o{constructor(){this.positions=[],this.normals=[],this.uvs=[],this.indices=[],this.bones=[],this.bone_indices=[],this.bone_weights=[],this.groups=[],this.material_map=new r}get vertex_count(){return this.positions.length/3}get index_count(){return this.indices.length}get_position(e){return new n.Vector3(this.positions[3*e],this.positions[3*e+1],this.positions[3*e+2])}get_normal(e){return new n.Vector3(this.normals[3*e],this.normals[3*e+1],this.normals[3*e+2])}add_vertex(e,t,i){this.positions.push(e.x,e.y,e.z),this.normals.push(t.x,t.y,t.z),this.uvs.push(i.x,i.y)}add_index(e){this.indices.push(e)}add_bone(e){this.bones.push(e)}add_bone_weight(e,t){this.bone_indices.push(e),this.bone_weights.push(t)}add_group(e,t,i,n=!1,s=!1){const r=this.groups[this.groups.length-1],o=this.material_map.add_material(i,n,s);r&&r.material_index===o?r.size+=t:this.groups.push({offset:e,size:t,material_index:o})}build(){const e=new n.BufferGeometry;let t;e.setAttribute("position",new n.Float32BufferAttribute(this.positions,3)),e.setAttribute("normal",new n.Float32BufferAttribute(thi
|