blockbench/lib/wintersky.umd.js
JannisX11 ab2f3e2661 Fix wintersky issue
(Issue with particle direction in locator space)
Update language bundle
2021-02-24 18:28:58 +01:00

2 lines
58 KiB
JavaScript

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("three"),require("molangjs"),require("tinycolor2")):"function"==typeof define&&define.amd?define(["three","molangjs","tinycolor2"],e):(t="undefined"!=typeof globalThis?globalThis:t||self).Wintersky=e(t.THREE,t.Molang,t.tinycolor)}(this,(function(t,e,i){"use strict";function a(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var r=a(e),s=a(i);const o={emitters:[],space:new t.Object3D,updateFacingRotation(t){o.emitters.forEach((e=>{e.updateFacingRotation(t)}))},fetchTexture:null,global_options:{max_emitter_particles:3e4,tick_rate:30,loop_mode:"auto",parent_mode:"world",get scale(){return o.global_options._scale},set scale(t){o.global_options._scale=t,o.emitters.forEach((e=>{e.local_space.scale.set(t,t,t),e.global_space.scale.set(t,t,t)}))},_scale:1}},n="";function l(t){return"string"==typeof t&&"#"==t[0]?t.length<9&&(t="#ff"+t.substr(1,6)):t=new s.default(t).toHex8String(),"#"+t.substr(3,6)+t.substr(1,2)}class c{constructor(e,i=0){this.texture=new t.Texture(new Image),this.texture.image.onload=()=>{this.texture.needsUpdate=!0,"function"==typeof this.onTextureUpdate&&this.onTextureUpdate()},this.reset(),this.onTextureUpdate=null,e&&e.particle_effect?this.setFromJSON(e):"object"==typeof e&&Object.assign(this,e),i.path&&this.set("file_path",i.path)}reset(){for(var e in this.texture.image.src=n,this.texture.magFilter=t.NearestFilter,this.texture.minFilter=t.NearestFilter,c.types){var i,a=c.types[e];switch(a.type){case"string":case"molang":i="";break;case"number":i=0;break;case"boolean":i=!1;break;case"color":i="#ffffff";break;case"object":i={}}if(a.array){if(this[e]=[],a.dimensions)for(var r=0;r<a.dimensions;r++)"object"==a.type&&(i={}),this[e].push(i)}else this[e]=i}return this.emitter_rate_mode="steady",this.emitter_lifetime_mode="looping",this.emitter_shape_mode="point",this.particle_appearance_facing_camera_mode="rotate_xyz",this.particle_appearance_material="particles_alpha",this.particle_direction_mode="outwards",this.particle_motion_mode="dynamic",this.particle_rotation_mode="dynamic",this.particle_texture_mode="static",this.particle_lifetime_mode="time",this.particle_color_mode="static",this.emitter_rate_rate="1",this.emitter_rate_maximum="100",this.emitter_lifetime_active_time="1",this.particle_appearance_size=["0.2","0.2"],this.particle_lifetime_max_lifetime="1",this.particle_texture_size=[16,16],this}set(t,e){if(null!=c.types[t]&&null!=e&&null!=e)return c.types[t].array&&e instanceof Array?("molang"==c.types[t].type&&(e=e.map((t=>t.toString()))),this[t].splice(0,1/0,...e)):"string"==typeof this[t]?this[t]=e.toString():"number"==c.types[t].type&&"number"==typeof e?this[t]=e:"boolean"==c.types[t].type&&(this[t]=!!e),this}setFromJSON(t){var e=t.particle_effect.components,i=t.particle_effect.curves,a=t.particle_effect.description;if(a&&a.identifier&&(this.identifier=a.identifier),a&&a.basic_render_parameters&&(this.set("particle_texture_path",a.basic_render_parameters.texture),this.set("particle_appearance_material",a.basic_render_parameters.material)),i)for(var r in i){var o=i[r],n={id:r,mode:o.type,input:(o.input||0).toString(),range:(o.horizontal_range||0).toString(),nodes:[]};o.nodes&&o.nodes.length&&o.nodes.forEach((t=>{t=parseFloat(t)||0,n.nodes.push(t)})),this.curves[r]=n}if(e){function c(t){return e["minecraft:"+t]}if(c("emitter_initialization")){var p=c("emitter_initialization").creation_expression,m=c("emitter_initialization").per_update_expression;"string"==typeof p&&(this.variables_creation_vars=p.replace(/;+$/,"").split(";")),"string"==typeof m&&(this.variables_tick_vars=m.replace(/;+$/,"").split(";"))}c("emitter_local_space")&&(this.space_local_position=c("emitter_local_space").position,this.space_local_rotation=c("emitter_local_space").rotation,this.space_local_velocity=c("emitter_local_space").velocity),c("emitter_rate_steady")&&(this.set("emitter_rate_mode","steady"),this.set("emitter_rate_rate",c("emitter_rate_steady").spawn_rate),this.set("emitter_rate_maximum",c("emitter_rate_steady").max_particles)),c("emitter_rate_instant")&&(this.set("emitter_rate_mode","instant"),this.set("emitter_rate_amount",c("emitter_rate_instant").num_particles)),c("emitter_lifetime_once")&&(this.set("emitter_lifetime_mode","once"),this.set("emitter_lifetime_active_time",c("emitter_lifetime_once").active_time)),c("emitter_lifetime_looping")&&(this.set("emitter_lifetime_mode","looping"),this.set("emitter_lifetime_active_time",c("emitter_lifetime_looping").active_time),this.set("emitter_lifetime_sleep_time",c("emitter_lifetime_looping").sleep_time)),c("emitter_lifetime_expression")&&(this.set("emitter_lifetime_mode","expression"),this.set("emitter_lifetime_activation",c("emitter_lifetime_expression").activation_expression),this.set("emitter_lifetime_expiration",c("emitter_lifetime_expression").expiration_expression));var h,_=c("emitter_shape_point")||c("emitter_shape_custom");if(_&&(this.set("emitter_shape_mode","point"),this.set("emitter_shape_offset",_.offset)),c("emitter_shape_sphere")&&(_=c("emitter_shape_sphere"),this.set("emitter_shape_mode","sphere"),this.set("emitter_shape_offset",_.offset),this.set("emitter_shape_radius",_.radius),this.set("emitter_shape_surface_only",_.surface_only)),c("emitter_shape_box")&&(_=c("emitter_shape_box"),this.set("emitter_shape_mode","box"),this.set("emitter_shape_offset",_.offset),this.set("emitter_shape_half_dimensions",_.half_dimensions),this.set("emitter_shape_surface_only",_.surface_only)),c("emitter_shape_disc")){switch(_=c("emitter_shape_disc"),this.set("emitter_shape_mode","disc"),this.set("emitter_shape_offset",_.offset),_.plane_normal){case"x":this.set("emitter_shape_plane_normal",[1,0,0]);break;case"y":this.set("emitter_shape_plane_normal",[0,1,0]);break;case"z":this.set("emitter_shape_plane_normal",[0,0,1]);break;default:this.set("emitter_shape_plane_normal",_.plane_normal)}this.set("emitter_shape_radius",_.radius),this.set("emitter_shape_surface_only",_.surface_only)}if(c("emitter_shape_entity_aabb")&&(this.set("emitter_shape_mode","entity_aabb"),this.set("emitter_shape_surface_only",c("emitter_shape_entity_aabb").surface_only),_=c("emitter_shape_entity_aabb")),_&&_.direction&&("inwards"==_.direction||"outwards"==_.direction?this.set("particle_direction_mode",_.direction):(this.set("particle_direction_mode","direction"),this.set("particle_direction_direction",_.direction))),c("particle_initial_spin")&&(this.set("particle_rotation_initial_rotation",c("particle_initial_spin").rotation),this.set("particle_rotation_rotation_rate",c("particle_initial_spin").rotation_rate)),c("particle_kill_plane")&&this.set("particle_lifetime_kill_plane",c("particle_kill_plane")),c("particle_motion_dynamic")){let t=c("particle_motion_dynamic").linear_acceleration,e=c("particle_motion_dynamic").linear_drag_coefficient,i=c("particle_motion_dynamic").rotation_acceleration,a=c("particle_motion_dynamic").rotation_drag_coefficient;null==t&&null==e||(this.set("particle_motion_mode","dynamic"),this.set("particle_motion_linear_acceleration",t),this.set("particle_motion_linear_drag_coefficient",e),this.set("particle_motion_linear_speed",1)),null==t&&null==e||(this.set("particle_rotation_mode","dynamic"),this.set("particle_rotation_rotation_acceleration",i),this.set("particle_rotation_rotation_drag_coefficient",a))}if(c("particle_motion_parametric")){let t=c("particle_motion_parametric").relative_position,e=c("particle_motion_parametric").direction,i=c("particle_motion_parametric").rotation;null==t&&null==e||(this.set("particle_motion_mode","parametric"),this.set("particle_motion_relative_position",t),this.set("particle_motion_direction",e)),null!=i&&(this.set("particle_rotation_mode","parametric"),this.set("particle_rotation_rotation",i))}if(c("particle_motion_collision")&&(this.set("particle_collision_enabled",c("particle_motion_collision").enabled),this.set("particle_collision_collision_drag",c("particle_motion_collision").collision_drag),this.set("particle_collision_coefficient_of_restitution",c("particle_motion_collision").coefficient_of_restitution),this.set("particle_collision_collision_radius",c("particle_motion_collision").collision_radius),this.set("particle_collision_expire_on_contact",c("particle_motion_collision").expire_on_contact)),void 0!==c("particle_initial_speed"))"object"!=typeof(h=c("particle_initial_speed"))?this.set("particle_motion_linear_speed",h):(this.set("particle_direction_mode","direction"),this.set("particle_direction_direction",c("particle_initial_speed")),this.set("particle_motion_linear_speed",1));if(c("particle_lifetime_expression")&&(this.set("particle_lifetime_mode","expression"),c("particle_lifetime_expression").expiration_expression?(this.set("particle_lifetime_mode","expression"),this.set("particle_lifetime_expiration_expression",c("particle_lifetime_expression").expiration_expression)):(this.set("particle_lifetime_mode","time"),this.set("particle_lifetime_max_lifetime",c("particle_lifetime_expression").max_lifetime))),c("particle_expire_if_in_blocks")instanceof Array&&this.set("particle_lifetime_expire_in",c("particle_expire_if_in_blocks")),c("particle_expire_if_not_in_blocks")instanceof Array&&this.set("particle_lifetime_expire_outside",c("particle_expire_if_not_in_blocks")),c("particle_appearance_billboard")){this.set("particle_appearance_size",c("particle_appearance_billboard").size),this.set("particle_appearance_facing_camera_mode",c("particle_appearance_billboard").facing_camera_mode);var f=c("particle_appearance_billboard").uv;f&&(f.texture_width&&this.set("particle_texture_size",[f.texture_width,f.texture_height]),f.flipbook?(this.set("particle_texture_mode","animated"),this.set("particle_texture_uv",f.flipbook.base_UV),this.set("particle_texture_uv_size",f.flipbook.size_UV),this.set("particle_texture_uv_step",f.flipbook.step_UV),this.set("particle_texture_frames_per_second",f.flipbook.frames_per_second),this.set("particle_texture_max_frame",f.flipbook.max_frame),this.set("particle_texture_stretch_to_lifetime",f.flipbook.stretch_to_lifetime),this.set("particle_texture_loop",f.flipbook.loop)):(this.set("particle_texture_mode","static"),this.set("particle_texture_uv",f.uv),this.set("particle_texture_uv_size",f.uv_size)))}if(c("particle_appearance_lighting")&&this.set("particle_color_light",!0),c("particle_appearance_tinting"))if("string"==typeof(h=c("particle_appearance_tinting").color))this.set("particle_color_static",l(h));else if(h instanceof Array&&h.length>=3)if((typeof h[0]+typeof h[1]+typeof h[2]+typeof h[3]).includes("string"))this.set("particle_color_mode","expression"),this.set("particle_color_expression",h);else{this.set("particle_color_mode","static");var d=new s.default({r:255*h[0],g:255*h[1],b:255*h[2],a:h[3]}).toHex8String();this.set("particle_color_static",d)}else if("object"==typeof h){this.set("particle_color_mode","gradient"),this.set("particle_color_interpolant",h.interpolant);let t=[];if(h.gradient instanceof Array){let e=100/(h.gradient.length-1);h.gradient.forEach(((i,a)=>{i=l(i);var r=e*a;t.push({percent:r,color:i})}))}else if("object"==typeof h.gradient){let e=0;for(var g in h.gradient)e=Math.max(parseFloat(g),e);for(var g in this.set("particle_color_range",e),h.gradient){d=l(h.gradient[g]);var A=parseFloat(g)/e*100;t.push({color:d,percent:A})}}this.set("particle_color_gradient",t)}}return this.updateTexture(),this}updateTexture(){let t=t=>{if(!t)switch(this.particle_texture_path){case"textures/particle/particles":t="";break;case"textures/flame_atlas":case"textures/particle/flame_atlas":t="";break;case"textures/particle/soul":t="";break;case"textures/particle/campfire_smoke":t="";break;default:t=n}this.texture.image.src=t};if("function"==typeof o.fetchTexture){let e=o.fetchTexture(this);e instanceof Promise?e.then((e=>{t(e)})):t(e)}else t();return this}}c.types={identifier:{type:"string"},file_path:{type:"string"},curves:{type:"object"},space_local_position:{type:"boolean"},space_local_rotation:{type:"boolean"},space_local_velocity:{type:"boolean"},variables_creation_vars:{type:"string",array:!0},variables_tick_vars:{type:"string",array:!0},emitter_rate_mode:{type:"string"},emitter_rate_rate:{type:"molang"},emitter_rate_amount:{type:"molang"},emitter_rate_maximum:{type:"molang"},emitter_lifetime_mode:{type:"string"},emitter_lifetime_active_time:{type:"molang"},emitter_lifetime_sleep_time:{type:"molang"},emitter_lifetime_activation:{type:"molang"},emitter_lifetime_expiration:{type:"molang"},emitter_shape_mode:{type:"string"},emitter_shape_offset:{type:"molang",array:!0,dimensions:3},emitter_shape_radius:{type:"molang"},emitter_shape_half_dimensions:{type:"molang",array:!0,dimensions:3},emitter_shape_plane_normal:{type:"molang",array:!0,dimensions:3},emitter_shape_surface_only:{type:"boolean"},particle_appearance_size:{type:"molang",array:!0,dimensions:2},particle_appearance_facing_camera_mode:{type:"string"},particle_appearance_material:{type:"string"},particle_direction_mode:{type:"string"},particle_direction_direction:{type:"molang",array:!0,dimensions:3},particle_motion_mode:{type:"string"},particle_motion_linear_speed:{type:"molang"},particle_motion_linear_acceleration:{type:"molang",array:!0,dimensions:3},particle_motion_linear_drag_coefficient:{type:"molang"},particle_motion_relative_position:{type:"molang",array:!0,dimensions:3},particle_motion_direction:{type:"molang",array:!0,dimensions:3},particle_rotation_mode:{type:"string"},particle_rotation_initial_rotation:{type:"molang"},particle_rotation_rotation_rate:{type:"molang"},particle_rotation_rotation_acceleration:{type:"molang"},particle_rotation_rotation_drag_coefficient:{type:"molang"},particle_rotation_rotation:{type:"molang"},particle_lifetime_mode:{type:"string"},particle_lifetime_max_lifetime:{type:"molang"},particle_lifetime_kill_plane:{type:"number",array:!0,dimensions:4},particle_lifetime_expiration_expression:{type:"molang"},particle_lifetime_expire_in:{type:"string",array:!0},particle_lifetime_expire_outside:{type:"string",array:!0},particle_texture_size:{type:"number",array:!0,dimensions:2},particle_texture_height:{type:"number"},particle_texture_path:{type:"string"},particle_texture_mode:{type:"string"},particle_texture_uv:{type:"molang",array:!0,dimensions:2},particle_texture_uv_size:{type:"molang",array:!0,dimensions:2},particle_texture_uv_step:{type:"molang",array:!0,dimensions:2},particle_texture_frames_per_second:{type:"number"},particle_texture_max_frame:{type:"molang"},particle_texture_stretch_to_lifetime:{type:"boolean"},particle_texture_loop:{type:"boolean"},particle_color_mode:{type:"string"},particle_color_static:{type:"color"},particle_color_interpolant:{type:"molang"},particle_color_range:{type:"number"},particle_color_gradient:{type:"object",array:!0},particle_color_expression:{type:"molang",array:!0,dimensions:4},particle_color_light:{type:"boolean"},particle_collision_enabled:{type:"molang"},particle_collision_collision_drag:{type:"number"},particle_collision_coefficient_of_restitution:{type:"number"},particle_collision_collision_radius:{type:"number"},particle_collision_expire_on_contact:{type:"boolean"}},o.Config=c;const p={roundTo(t,e){var i=Math.pow(10,e);return Math.round(t*i)/i},randomab:(t,e)=>t+Math.random()*(e-t),radToDeg:t=>t/Math.PI*180,degToRad:t=>Math.PI/(180/t),clamp:(t,e,i)=>(t>i&&(t=i),(t<e||isNaN(t))&&(t=e),t),roundTo(t,e){var i=Math.pow(10,e);return Math.round(t*i)/i},getRandomEuler:()=>new t.Euler(p.randomab(-Math.PI,Math.PI),p.randomab(-Math.PI,Math.PI),p.randomab(-Math.PI,Math.PI))},m={x:new t.Vector3(1,0,0),y:new t.Vector3(0,1,0),z:new t.Vector3(0,0,1),n:new t.Vector3(0,0,0)};function h(t,e){let i=t.indexOf(e);i>=0&&t.splice(i,1)}const _={r:255,r:255,b:255,a:1},f=(new t.Plane).setComponents(0,1,0,0);class d{constructor(e){this.emitter=e,this.geometry=new t.PlaneBufferGeometry(2,2),this.material=this.emitter.material,this.mesh=new t.Mesh(this.geometry,this.material),this.position=this.mesh.position;let i=new Float32Array(16).fill(1);this.geometry.setAttribute("clr",new t.BufferAttribute(i,4)),this.speed=new t.Vector3,this.acceleration=new t.Vector3,this.add()}params(){var t=this.emitter.params();return t["variable.particle_lifetime"]=this.lifetime,t["variable.particle_age"]=this.age,t["variable.particle_random_1"]=this.random_vars[0],t["variable.particle_random_2"]=this.random_vars[1],t["variable.particle_random_3"]=this.random_vars[2],t["variable.particle_random_4"]=this.random_vars[3],t}add(){this.emitter.particles.includes(this)||(this.emitter.particles.push(this),this.emitter.config.space_local_position&&this.emitter.local_space.parent?this.emitter.local_space.add(this.mesh):this.emitter.global_space.add(this.mesh)),this.age=this.loop_time=0,this.current_frame=0,this.random_vars=[Math.random(),Math.random(),Math.random(),Math.random()];var e=this.params();this.position.set(0,0,0),this.lifetime=this.emitter.calculate(this.emitter.config.particle_lifetime_max_lifetime,e),this.initial_rotation=this.emitter.calculate(this.emitter.config.particle_rotation_initial_rotation,e),this.rotation_rate=this.emitter.calculate(this.emitter.config.particle_rotation_rotation_rate,e),this.rotation=0;var i=this.emitter.config.emitter_shape_surface_only;if("box"===this.emitter.config.emitter_shape_mode){var a=this.emitter.calculate(this.emitter.config.emitter_shape_half_dimensions,e);if(this.position.x=p.randomab(-a.x,a.x),this.position.y=p.randomab(-a.y,a.y),this.position.z=p.randomab(-a.z,a.z),i){var r=Math.floor(p.randomab(0,3)),s=Math.floor(p.randomab(0,2));this.position.setComponent(r,a.getComponent(r)*(s?1:-1))}}else if("entity_aabb"===this.emitter.config.emitter_shape_mode){a=new t.Vector3(.5,1,.5);if(this.position.x=p.randomab(-a.x,a.x),this.position.y=p.randomab(-a.y,a.y),this.position.z=p.randomab(-a.z,a.z),i){r=Math.floor(p.randomab(0,3)),s=Math.floor(p.randomab(0,2));this.position.setComponent(r,a.getComponent(r)*(s?1:-1))}}else if("sphere"===this.emitter.config.emitter_shape_mode){var n=this.emitter.calculate(this.emitter.config.emitter_shape_radius,e);this.position.x=i?n:n*Math.random(),this.position.applyEuler(p.getRandomEuler())}else if("disc"===this.emitter.config.emitter_shape_mode){n=this.emitter.calculate(this.emitter.config.emitter_shape_radius,e);var l=Math.random()*Math.PI*2,c=i?n:n*Math.sqrt(Math.random());this.position.x=c*Math.cos(l),this.position.z=c*Math.sin(l);var h=this.emitter.calculate(this.emitter.config.emitter_shape_plane_normal,e);if(!h.equals(m.n)){var _=(new t.Quaternion).setFromUnitVectors(m.y,h);this.position.applyQuaternion(_)}}this.speed.set(0,0,0);var f=this.emitter.config.particle_direction_mode;"inwards"==f||"outwards"==f?"point"===this.emitter.config.emitter_shape_mode?this.speed.set(1,0,0).applyEuler(p.getRandomEuler()):(this.speed.copy(this.position).normalize(),"inwards"==f&&this.speed.negate()):this.speed=this.emitter.calculate(this.emitter.config.particle_direction_direction,e).normalize();var d=this.emitter.calculate(this.emitter.config.particle_motion_linear_speed,e);if(this.speed.x*=d,this.speed.y*=d,this.speed.z*=d,this.position.add(this.emitter.calculate(this.emitter.config.emitter_shape_offset,e)),"locator"==this.emitter.parent_mode?(this.position.x*=-1,this.position.y*=-1,this.speed.x*=-1,this.speed.y*=-1):this.emitter.config.space_local_position&&!this.emitter.config.space_local_rotation&&(this.speed.x*=-1,this.speed.z*=-1),this.emitter.local_space.parent&&("locator"==this.emitter.parent_mode&&this.speed.applyQuaternion(this.emitter.local_space.getWorldQuaternion(new t.Quaternion)),this.emitter.config.space_local_rotation||this.position.applyQuaternion(this.emitter.local_space.getWorldQuaternion(new t.Quaternion)),!this.emitter.config.space_local_position)){let e=this.emitter.local_space.getWorldPosition(new t.Vector3);this.position.addScaledVector(e,1/o.global_options._scale)}return this.setFrame(0),this.tick()}tick(e){var i=this.params();let a=1/o.global_options.tick_rate;if(this.age+=a,this.loop_time+=a,"time"===this.emitter.config.particle_lifetime_mode?this.age>this.lifetime&&this.remove():this.emitter.calculate(this.emitter.config.particle_lifetime_expiration_expression,i)&&this.remove(),"dynamic"===this.emitter.config.particle_motion_mode){var r=this.emitter.calculate(this.emitter.config.particle_motion_linear_drag_coefficient,i);if(this.acceleration.copy(this.emitter.calculate(this.emitter.config.particle_motion_linear_acceleration,i)),this.emitter.config.space_local_position?"locator"==this.emitter.parent_mode&&(this.acceleration.x*=-1,this.acceleration.y*=-1):"world"!=this.emitter.parent_mode&&(this.acceleration.x*=-1,this.acceleration.z*=-1),this.acceleration.addScaledVector(this.speed,-r),this.speed.addScaledVector(this.acceleration,a),this.position.addScaledVector(this.speed,a),this.emitter.config.particle_lifetime_kill_plane.find((t=>t))){var n=this.emitter.calculate(this.emitter.config.particle_lifetime_kill_plane,i),l=(new t.Vector3).copy(this.position).addScaledVector(this.speed,-a),c=new t.Line3(l,this.position);if(n.intersectsLine(c))return this.remove(),this}if(!this.emitter.config.particle_collision_enabled&&this.emitter.config.particle_collision_collision_radius||this.emitter.calculate(this.emitter.config.particle_collision_enabled,i)){let e=this.emitter.config.particle_collision_collision_drag,i=this.emitter.config.particle_collision_coefficient_of_restitution,r=this.emitter.config.particle_collision_collision_radius,s=f,o=new t.Sphere(this.position,r),n=(new t.Vector3).copy(this.position).addScaledVector(this.speed,-a),l=new t.Line3(n,this.position),c=s.intersectsLine(l);if(c&&s.intersectLine(l,this.position),c||s.intersectsSphere(o)){if(this.emitter.config.particle_collision_expire_on_contact)return this.remove(),this;this.position.y=r*Math.sign(n.y),this.speed.reflect(s.normal),this.speed.y*=i,this.speed.x=Math.sign(this.speed.x)*p.clamp(Math.abs(this.speed.x)-e*a,0,1/0),this.speed.z=Math.sign(this.speed.z)*p.clamp(Math.abs(this.speed.z)-e*a,0,1/0)}}}else"parametric"!==this.emitter.config.particle_motion_mode||e||(this.emitter.config.particle_motion_relative_position.join("").length&&this.position.copy(this.emitter.calculate(this.emitter.config.particle_motion_relative_position,i)),this.emitter.config.particle_motion_direction.join("").length&&this.speed.copy(this.emitter.calculate(this.emitter.config.particle_motion_direction,i)),this.emitter.config.space_local_position&&"locator"==this.emitter.parent_mode&&(this.position.x*=-1,this.position.y*=-1));if("dynamic"===this.emitter.config.particle_rotation_mode){var m=this.emitter.calculate(this.emitter.config.particle_rotation_rotation_drag_coefficient,i),h=this.emitter.calculate(this.emitter.config.particle_rotation_rotation_acceleration,i);h+=-m*this.rotation_rate,this.rotation_rate+=h*a,this.rotation=p.degToRad(this.initial_rotation+this.rotation_rate*this.age)}else"parametric"===this.emitter.config.particle_rotation_mode&&(this.rotation=p.degToRad(this.emitter.calculate(this.emitter.config.particle_rotation_rotation,i)));if(!e){var d=this.emitter.calculate(this.emitter.config.particle_appearance_size,i);if(this.mesh.scale.x=d.x||1e-4,this.mesh.scale.y=d.y||1e-4,"animated"===this.emitter.config.particle_texture_mode){var g=this.emitter.calculate(this.emitter.config.particle_texture_max_frame,i);if(this.emitter.config.particle_texture_stretch_to_lifetime&&g)var A=g/this.lifetime;else A=this.emitter.calculate(this.emitter.config.particle_texture_frames_per_second,i);Math.floor(this.loop_time*A)>this.current_frame&&(this.current_frame=Math.floor(this.loop_time*A),g&&this.current_frame>g?this.emitter.config.particle_texture_loop&&(this.current_frame=0,this.loop_time=0,this.setFrame(this.current_frame)):this.setFrame(this.current_frame))}else this.setFrame(0);if("expression"===this.emitter.config.particle_color_mode){var u=this.emitter.calculate(this.emitter.config.particle_color_expression,i,"array");this.setColor(...u)}else if("gradient"===this.emitter.config.particle_color_mode){var y=this.emitter.calculate(this.emitter.config.particle_color_interpolant,i),v=this.emitter.calculate(this.emitter.config.particle_color_range,i);u=function(t,e){let i=0;if(t.forEach(((t,a)=>{t.percent<=e&&(i=a)})),t[i]&&!t[i+1])return s.default(t[i].color).toRgb();if(!t[i]&&t[i+1])return s.default(t[i+1].color).toRgb();if(t[i]&&t[i+1]){var a=(e-t[i].percent)/(t[i+1].percent-t[i].percent);return s.default.mix(t[i].color,t[i+1].color,100*a).toRgb()}return _}(this.emitter.config.particle_color_gradient,y/v*100);this.setColor(u.r/255,u.g/255,u.b/255,u.a)}else{u=s.default(this.emitter.config.particle_color_static).toRgb();this.setColor(u.r/255,u.g/255,u.b/255,u.a)}}return this}remove(){return h(this.emitter.particles,this),this.mesh.parent&&this.mesh.parent.remove(this.mesh),this.emitter.dead_particles.push(this),this}setColor(t,e,i,a=1){let r=this.geometry.getAttribute("clr");r.array.set([t,e,i,a,t,e,i,a,t,e,i,a,t,e,i,a]),r.needsUpdate=!0}setFrame(t){var e=this.params(),i=this.emitter.calculate(this.emitter.config.particle_texture_uv,e),a=this.emitter.calculate(this.emitter.config.particle_texture_uv_size,e);if(t){var r=this.emitter.calculate(this.emitter.config.particle_texture_uv_step,e);i.addScaledVector(r,t)}this.setUV(i.x,i.y,a.x||this.emitter.config.particle_texture_size[0],a.y||this.emitter.config.particle_texture_size[1])}setUV(t,e,i,a){let r=this.geometry.getAttribute("uv");i=(t+i-0)/this.emitter.config.particle_texture_size[0],a=(e+a-0)/this.emitter.config.particle_texture_size[1],t=(t+(i>0?0:-0))/this.emitter.config.particle_texture_size[0],e=(e+(a>0?0:-0))/this.emitter.config.particle_texture_size[1],r.array.set([t,1-e,i,1-e,t,1-a,i,1-a]),r.needsUpdate=!0}}o.Particle=d;const g=new t.Vector3,A=["particles_alpha","particles_blend","particles_opaque"];return o.Emitter=class{constructor(e,i=0){o.emitters.push(this),this.config=e instanceof c?e:new c(e,i),this.Molang=new r.default,this.Molang.variableHandler=(e,i)=>this.creation_values[e]||this.tick_values[e]||this.config.curves[e]&&function(e,i,a){var r=e.Molang.parse(i.input,a);if((r=r/e.Molang.parse(i.range,a)||0)===1/0&&(r=0),"linear"==i.mode){r*=c=i.nodes.length-1;var s=Math.floor(r),o=r%1,n=i.nodes[s+1]-i.nodes[s];return i.nodes[s]+n*o}if("catmull_rom"==i.mode){var l=[];i.nodes.forEach(((e,i)=>{l.push(new t.Vector2(i-1,e))}));var c,p=new t.SplineCurve(l),m=(1+(r*=c=i.nodes.length-3))/(c+2);return p.getPoint(m).y}}(this,this.config.curves[e],i);let a=o.global_options._scale;this.local_space=new t.Object3D,this.local_space.scale.set(a,a,a),this.global_space=new t.Object3D,this.global_space.scale.set(a,a,a),this.material=new t.ShaderMaterial({uniforms:{map:{type:"t",value:this.config.texture},materialType:{type:"int",value:1}},vertexShader:"#define GLSLIFY 1\nattribute vec4 clr;varying vec2 vUv;varying vec4 vColor;void main(){vColor=clr;vUv=uv;vec4 mvPosition=modelViewMatrix*vec4(position,1.0);gl_Position=projectionMatrix*mvPosition;}",fragmentShader:"#define GLSLIFY 1\nvarying vec2 vUv;varying vec4 vColor;uniform sampler2D map;uniform int materialType;void main(void){vec4 tColor=texture2D(map,vUv);if(materialType==0){if(tColor.a<0.05)discard;}else if(materialType==1){tColor.a=tColor.a*vColor.a;}else{tColor.a=1.0;}gl_FragColor=vec4(tColor.rgb*vColor.rgb,tColor.a);}",vertexColors:t.FaceColors,transparent:!0,alphaTest:.2}),this.particles=[],this.dead_particles=[],this.age=0,this.view_age=0,this.enabled=!1,this.loop_mode=i.loop_mode||o.global_options.loop_mode,this.parent_mode=i.parent_mode||o.global_options.parent_mode,this.random_vars=[Math.random(),Math.random(),Math.random(),Math.random()],this.tick_variables={},this.tick_values={},this.creation_variables={},this.creation_values={},this.updateMaterial()}clone(){let t=new o.Emitter(this.config);return t.loop_mode=this.loop_mode,t}params(){var t={"variable.entity_scale":1};return t["variable.emitter_lifetime"]=this.active_time,t["variable.emitter_age"]=this.age,t["variable.emitter_random_1"]=this.random_vars[0],t["variable.emitter_random_2"]=this.random_vars[1],t["variable.emitter_random_3"]=this.random_vars[2],t["variable.emitter_random_4"]=this.random_vars[3],t}calculate(e,i,a){let r=t=>this.Molang.parse(t,i);var s;return e instanceof Array?"array"==a?(s=[],e.forEach((t=>{s.push(r(t))}))):4===e.length?s=(new t.Plane).setComponents(r(e[0]),r(e[1]),r(e[2]),r(e[3])):3===e.length?s=new t.Vector3(r(e[0]),r(e[1]),r(e[2])):2===e.length&&(s=new t.Vector2(r(e[0]),r(e[1]))):"color"==a||(s=r(e)),s}updateConfig(){this.updateMaterial()}updateMaterial(){this.config.updateTexture()}updateFacingRotation(e){const i=new t.Quaternion,a=new t.Vector3;this.particles.forEach((t=>{switch(this.config.particle_appearance_facing_camera_mode){case"lookat_xyz":t.mesh.lookAt(e.position);break;case"lookat_y":var r=a.copy(e.position);g.set(0,0,0),t.mesh.localToWorld(g),r.y=g.y,t.mesh.lookAt(r);break;case"rotate_xyz":t.mesh.rotation.copy(e.rotation);break;case"rotate_y":t.mesh.rotation.copy(e.rotation),t.mesh.rotation.reorder("YXZ"),t.mesh.rotation.x=t.mesh.rotation.z=0;break;case"direction_x":var s=i.setFromUnitVectors(m.x,a.copy(t.speed).normalize());t.mesh.rotation.setFromQuaternion(s);break;case"direction_y":s=i.setFromUnitVectors(m.y,a.copy(t.speed).normalize());t.mesh.rotation.setFromQuaternion(s);break;case"direction_z":s=i.setFromUnitVectors(m.z,a.copy(t.speed).normalize());t.mesh.rotation.setFromQuaternion(s)}t.mesh.rotation.z+=t.rotation||0}))}start(){this.age=0,this.view_age=0,this.enabled=!0,this.initialized=!0,o.space.add(this.global_space);var t=this.params();for(var e of(this.active_time=this.calculate(this.config.emitter_lifetime_active_time,t),this.sleep_time=this.calculate(this.config.emitter_lifetime_sleep_time,t),this.random_vars=[Math.random(),Math.random(),Math.random(),Math.random()],this.creation_values={},this.config.variables_creation_vars)){let[t,i]=e.split(/\s*=(.+)/);i&&(i=i.replace(/^\s*=\s*/,""),this.creation_values[t]=this.Molang.parse(i))}return"instant"===this.config.emitter_rate_mode&&this.spawnParticles(this.calculate(this.config.emitter_rate_amount,t)),this}tick(t){let e=this.params(),{tick_rate:i}=o.global_options;for(var a of(this.tick_values={},this.config.variables_tick_vars)){let[t,e]=a.split(/\s*=(.+)/);e&&(e=e.replace(/^\s*=\s*/,""),this.tick_values[t]=this.Molang.parse(e))}if(this.enabled&&"steady"===this.config.emitter_rate_mode){var r=this.calculate(this.config.emitter_rate_rate,e)/i,s=1/r;r=Math.round(this.age*i)%Math.round(s)==0?Math.ceil(r):Math.floor(r),this.spawnParticles(r)}return t||(this.material.uniforms.materialType.value=A.indexOf(this.config.particle_appearance_material)),this.particles.forEach((e=>{e.tick(t)})),this.age+=1/i,this.view_age+=1/i,"expression"===this.config.emitter_lifetime_mode?(this.enabled&&this.calculate(this.config.emitter_lifetime_expiration,e)&&this.stop(),!this.enabled&&this.calculate(this.config.emitter_lifetime_activation,e)&&this.start()):"looping"==this.loop_mode||"auto"==this.loop_mode&&"looping"==this.config.emitter_lifetime_mode?(this.enabled&&p.roundTo(this.age,5)>=this.active_time&&this.stop(),!this.enabled&&p.roundTo(this.age,5)>=this.sleep_time&&this.start()):this.enabled&&p.roundTo(this.age,5)>=this.active_time&&this.stop(),this}stop(t=!1){return this.enabled=!1,this.age=0,t&&this.particles.slice().forEach((t=>{t.remove()})),this}jumpTo(t){let{tick_rate:e}=o.global_options,i=Math.round(this.view_age*e),a=Math.round(t*e);if("once"!=this.loop_mode&&(a=Math.clamp(a,0,Math.round(this.active_time*e)-1)),i!=a){for(a<i?this.stop(!0).start():this.initialized||this.start();Math.round(this.view_age*e)<a-1;)this.tick(!0);return this.tick(!1),this}}playLoop(){return this.initialized&&0!=this.age||this.start(),this.paused=!1,clearInterval(this.tick_interval),this.tick_interval=setInterval((()=>{this.tick()}),1e3/o.global_options.tick_rate),this}toggleLoop(){return this.paused=!this.paused,this.paused?(clearInterval(this.tick_interval),delete this.tick_interval):this.playLoop(),this}stopLoop(){return clearInterval(this.tick_interval),delete this.tick_interval,this.stop(!0),this.paused=!0,this}spawnParticles(t){if(!t)return this;if("steady"==this.config.emitter_rate_mode){var e=this.calculate(this.config.emitter_rate_maximum,this.params())||0;e=p.clamp(e,0,o.global_options.max_emitter_particles),t=p.clamp(t,0,e-this.particles.length)}else t=p.clamp(t,0,o.global_options.max_emitter_particles-this.particles.length);for(var i=0;i<t;i++){if(this.dead_particles.length)var a=this.dead_particles.pop();else a=new d(this);a.add()}return t}delete(){[...this.particles,...this.dead_particles].forEach((t=>{t.mesh.parent&&t.mesh.parent.remove(t.mesh)})),this.particles.splice(0,1/0),this.dead_particles.splice(0,1/0),this.local_space.parent&&this.local_space.parent.remove(this.local_space),this.global_space.parent&&this.global_space.parent.remove(this.global_space),h(o.emitters,this)}},o}));