Socket
Socket
Sign inDemoInstall

@pixiv/three-vrm-springbone

Package Overview
Dependencies
Maintainers
5
Versions
58
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@pixiv/three-vrm-springbone - npm Package Compare versions

Comparing version 1.0.0-beta.15 to 1.0.0-beta.16

4

lib/three-vrm-springbone.min.js
/*! (c) 2020-2021 pixiv Inc. - https://github.com/pixiv/three-vrm/blob/release/LICENSE */
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("three")):"function"==typeof define&&define.amd?define(["exports","three"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).THREE_VRM_SPRINGBONE={},t.THREE)}(this,(function(t,e){"use strict";function i(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(i){if("default"!==i){var r=Object.getOwnPropertyDescriptor(t,i);Object.defineProperty(e,i,r.get?r:{enumerable:!0,get:function(){return t[i]}})}})),e.default=t,Object.freeze(e)}var r=i(e);class s{}const n=new r.Vector3,o=new r.Vector3;class a extends s{constructor(t){var e,i,s;super(),this.offset=null!==(e=null==t?void 0:t.offset)&&void 0!==e?e:new r.Vector3(0,0,0),this.tail=null!==(i=null==t?void 0:t.tail)&&void 0!==i?i:new r.Vector3(0,0,0),this.radius=null!==(s=null==t?void 0:t.radius)&&void 0!==s?s:0}get type(){return"capsule"}calculateCollision(t,e,i,r){n.copy(this.offset).applyMatrix4(t),o.copy(this.tail).applyMatrix4(t),o.sub(n);const s=o.lengthSq();r.copy(e).sub(n);const a=o.dot(r);a<=0||(s<=a||o.multiplyScalar(a/s),r.sub(o));const l=i+this.radius,h=r.length()-l;return r.normalize(),h}}class l extends s{constructor(t){var e,i;super(),this.offset=null!==(e=null==t?void 0:t.offset)&&void 0!==e?e:new r.Vector3(0,0,0),this.radius=null!==(i=null==t?void 0:t.radius)&&void 0!==i?i:0}get type(){return"sphere"}calculateCollision(t,e,i,r){r.copy(this.offset).applyMatrix4(t),r.negate().add(e);const s=i+this.radius,n=r.length()-s;return r.normalize(),n}}const h=new r.Vector3;class c extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentOffset=new r.Vector3,this._currentTail=new r.Vector3,this._shape=t,this._attrPos=new r.BufferAttribute(new Float32Array(396),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(264),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),this._currentTail.equals(this._shape.tail)||(this._currentTail.copy(this._shape.tail),t=!0),t&&this._buildPosition()}_buildPosition(){h.copy(this._currentTail).sub(this._currentOffset);const t=h.length()/this._currentRadius;for(let e=0;e<=16;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(e,-Math.sin(i),-Math.cos(i),0),this._attrPos.setXYZ(17+e,t+Math.sin(i),Math.cos(i),0),this._attrPos.setXYZ(34+e,-Math.sin(i),0,-Math.cos(i)),this._attrPos.setXYZ(51+e,t+Math.sin(i),0,Math.cos(i))}for(let e=0;e<32;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(68+e,0,Math.sin(i),Math.cos(i)),this._attrPos.setXYZ(100+e,t,Math.sin(i),Math.cos(i))}const e=Math.atan2(h.y,Math.sqrt(h.x*h.x+h.z*h.z)),i=-Math.atan2(h.z,h.x);this.rotateZ(e),this.rotateY(i),this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<34;t++){const e=(t+1)%34;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(68+2*t,34+t,34+e)}for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(136+2*t,68+t,68+e),this._attrIndex.setXY(200+2*t,100+t,100+e)}this._attrIndex.needsUpdate=!0}}class d extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentOffset=new r.Vector3,this._shape=t,this._attrPos=new r.BufferAttribute(new Float32Array(288),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(192),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.needsUpdate=!0}}class u extends r.Group{constructor(t){if(super(),this.matrixAutoUpdate=!1,this.collider=t,this.collider.shape instanceof l)this._geometry=new d(this.collider.shape);else{if(!(this.collider.shape instanceof a))throw new Error("VRMSpringBoneColliderHelper: Unknown collider shape type detected");this._geometry=new c(this.collider.shape)}const e=new r.LineBasicMaterial({color:16711935,depthTest:!1,depthWrite:!1});this._line=new r.LineSegments(this._geometry,e),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.collider.updateWorldMatrix(!0,!1),this.matrix.copy(this.collider.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class p extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentTail=new r.Vector3,this._springBone=t,this._attrPos=new r.BufferAttribute(new Float32Array(294),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(194),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._springBone.settings.hitRadius&&(this._currentRadius=this._springBone.settings.hitRadius,t=!0),this._currentTail.equals(this._springBone.initialLocalChildPosition)||(this._currentTail.copy(this._springBone.initialLocalChildPosition),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.setXYZ(96,0,0,0),this._attrPos.setXYZ(97,this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.setXY(192,96,97),this._attrIndex.needsUpdate=!0}}class _ extends r.Group{constructor(t){super(),this.matrixAutoUpdate=!1,this.springBone=t,this._geometry=new p(this.springBone);const e=new r.LineBasicMaterial({color:16776960,depthTest:!1,depthWrite:!1});this._line=new r.LineSegments(this._geometry,e),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.springBone.bone.updateWorldMatrix(!0,!1),this.matrix.copy(this.springBone.bone.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class f extends r.Object3D{constructor(t){super(),this.shape=t}}const x=new r.Vector3,g=new r.Vector3;const y=new r.Matrix4;function v(t){return t.invert?t.invert():t.getInverse(y.copy(t)),t}class M{constructor(t){this._inverseCache=new r.Matrix4,this._shouldUpdateInverse=!0,this.matrix=t;const e={set:(t,e,i)=>(this._shouldUpdateInverse=!0,t[e]=i,!0)};this._originalElements=t.elements,t.elements=new Proxy(t.elements,e)}get inverse(){return this._shouldUpdateInverse&&(this._inverseCache.copy(this.matrix),v(this._inverseCache),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const m=new r.Matrix4,w=new r.Quaternion,b=new r.Vector3,S=new r.Vector3,P=new r.Quaternion,R=new r.Matrix4,B=new r.Matrix4;class T{constructor(t,e,i={},s=[]){var n,o,a,l,h,c;this._currentTail=new r.Vector3,this._prevTail=new r.Vector3,this._nextTail=new r.Vector3,this._boneAxis=new r.Vector3,this._centerSpaceBoneLength=0,this._centerSpacePosition=new r.Vector3,this._center=null,this._parentWorldRotation=new r.Quaternion,this._initialLocalMatrix=new r.Matrix4,this._initialLocalRotation=new r.Quaternion,this._initialLocalChildPosition=new r.Vector3,this.bone=t,this.bone.matrixAutoUpdate=!1,this.child=e,this.settings={hitRadius:null!==(n=i.hitRadius)&&void 0!==n?n:0,stiffness:null!==(o=i.stiffness)&&void 0!==o?o:1,gravityPower:null!==(a=i.gravityPower)&&void 0!==a?a:0,gravityDir:null!==(h=null===(l=i.gravityDir)||void 0===l?void 0:l.clone())&&void 0!==h?h:new r.Vector3(0,-1,0),dragForce:null!==(c=i.dragForce)&&void 0!==c?c:.4},this.colliderGroups=s}get center(){return this._center}set center(t){var e;this._getMatrixCenterToWorld(R),this._currentTail.applyMatrix4(R),this._prevTail.applyMatrix4(R),this._nextTail.applyMatrix4(R),(null===(e=this._center)||void 0===e?void 0:e.userData.inverseCacheProxy)&&(this._center.userData.inverseCacheProxy.revert(),delete this._center.userData.inverseCacheProxy),this._center=t,this._center&&(this._center.userData.inverseCacheProxy||(this._center.userData.inverseCacheProxy=new M(this._center.matrixWorld))),this._getMatrixWorldToCenter(R),this._currentTail.applyMatrix4(R),this._prevTail.applyMatrix4(R),this._nextTail.applyMatrix4(R),R.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(R),this._centerSpaceBoneLength=b.copy(this._initialLocalChildPosition).applyMatrix4(R).sub(this._centerSpacePosition).length()}get initialLocalChildPosition(){return this._initialLocalChildPosition}get _parentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:m}setInitState(){this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld),this._initialLocalMatrix.copy(this.bone.matrix),this._initialLocalRotation.copy(this.bone.quaternion),this.child?this._initialLocalChildPosition.copy(this.child.position):this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(.07),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._nextTail.copy(this._currentTail),this._boneAxis.copy(this._initialLocalChildPosition).normalize(),this._centerSpaceBoneLength=b.copy(this._initialLocalChildPosition).applyMatrix4(this.bone.matrixWorld).sub(this._centerSpacePosition).length()}reset(){this.bone.quaternion.copy(this._initialLocalRotation),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix),this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._nextTail.copy(this._currentTail)}update(t){if(t<=0)return;var e,i;this.bone.parent?(e=this.bone.parent,i=this._parentWorldRotation,e.matrixWorld.decompose(x,i,g)):this._parentWorldRotation.copy(w),this._getMatrixWorldToCenter(R),R.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(R);const r=this._getMatrixWorldToCenter(B).multiply(this._parentMatrixWorld),s=S.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(r).sub(this._centerSpacePosition).normalize();this._nextTail.copy(this._currentTail).add(b.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(b.copy(s).multiplyScalar(this.settings.stiffness*t)).add(b.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t)),this._nextTail.sub(this._centerSpacePosition).normalize().multiplyScalar(this._centerSpaceBoneLength).add(this._centerSpacePosition),this._collision(this._nextTail),this._prevTail.copy(this._currentTail),this._currentTail.copy(this._nextTail);const n=v(R.copy(B.multiply(this._initialLocalMatrix))),o=P.setFromUnitVectors(this._boneAxis,b.copy(this._nextTail).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(o),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{this._getMatrixWorldToCenter(R),R.multiply(e.matrixWorld);const i=e.shape.calculateCollision(R,t,this.settings.hitRadius,b);i<0&&(t.add(b.multiplyScalar(-i)),t.sub(this._centerSpacePosition).normalize().multiplyScalar(this._centerSpaceBoneLength).add(this._centerSpacePosition))}))}))}_getMatrixCenterToWorld(t){return this._center?t.copy(this._center.matrixWorld):t.identity(),t}_getMatrixWorldToCenter(t){return this._center?t.copy(this._center.userData.inverseCacheProxy.inverse):t.identity(),t}}
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("three")):"function"==typeof define&&define.amd?define(["exports","three"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).THREE_VRM_SPRINGBONE={},t.THREE)}(this,(function(t,e){"use strict";function i(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach((function(i){if("default"!==i){var r=Object.getOwnPropertyDescriptor(t,i);Object.defineProperty(e,i,r.get?r:{enumerable:!0,get:function(){return t[i]}})}})),e.default=t,Object.freeze(e)}var r=i(e);class s{}const n=new r.Vector3,o=new r.Vector3;class a extends s{constructor(t){var e,i,s;super(),this.offset=null!==(e=null==t?void 0:t.offset)&&void 0!==e?e:new r.Vector3(0,0,0),this.tail=null!==(i=null==t?void 0:t.tail)&&void 0!==i?i:new r.Vector3(0,0,0),this.radius=null!==(s=null==t?void 0:t.radius)&&void 0!==s?s:0}get type(){return"capsule"}calculateCollision(t,e,i,r){n.copy(this.offset).applyMatrix4(t),o.copy(this.tail).applyMatrix4(t),o.sub(n);const s=o.lengthSq();r.copy(e).sub(n);const a=o.dot(r);a<=0||(s<=a||o.multiplyScalar(a/s),r.sub(o));const l=i+this.radius,h=r.length()-l;return r.normalize(),h}}class l extends s{constructor(t){var e,i;super(),this.offset=null!==(e=null==t?void 0:t.offset)&&void 0!==e?e:new r.Vector3(0,0,0),this.radius=null!==(i=null==t?void 0:t.radius)&&void 0!==i?i:0}get type(){return"sphere"}calculateCollision(t,e,i,r){r.copy(this.offset).applyMatrix4(t),r.negate().add(e);const s=i+this.radius,n=r.length()-s;return r.normalize(),n}}const h=new r.Vector3;class d extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentOffset=new r.Vector3,this._currentTail=new r.Vector3,this._shape=t,this._attrPos=new r.BufferAttribute(new Float32Array(396),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(264),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),this._currentTail.equals(this._shape.tail)||(this._currentTail.copy(this._shape.tail),t=!0),t&&this._buildPosition()}_buildPosition(){h.copy(this._currentTail).sub(this._currentOffset);const t=h.length()/this._currentRadius;for(let e=0;e<=16;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(e,-Math.sin(i),-Math.cos(i),0),this._attrPos.setXYZ(17+e,t+Math.sin(i),Math.cos(i),0),this._attrPos.setXYZ(34+e,-Math.sin(i),0,-Math.cos(i)),this._attrPos.setXYZ(51+e,t+Math.sin(i),0,Math.cos(i))}for(let e=0;e<32;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(68+e,0,Math.sin(i),Math.cos(i)),this._attrPos.setXYZ(100+e,t,Math.sin(i),Math.cos(i))}const e=Math.atan2(h.y,Math.sqrt(h.x*h.x+h.z*h.z)),i=-Math.atan2(h.z,h.x);this.rotateZ(e),this.rotateY(i),this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<34;t++){const e=(t+1)%34;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(68+2*t,34+t,34+e)}for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(136+2*t,68+t,68+e),this._attrIndex.setXY(200+2*t,100+t,100+e)}this._attrIndex.needsUpdate=!0}}class c extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentOffset=new r.Vector3,this._shape=t,this._attrPos=new r.BufferAttribute(new Float32Array(288),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(192),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.needsUpdate=!0}}class u extends r.Group{constructor(t){if(super(),this.matrixAutoUpdate=!1,this.collider=t,this.collider.shape instanceof l)this._geometry=new c(this.collider.shape);else{if(!(this.collider.shape instanceof a))throw new Error("VRMSpringBoneColliderHelper: Unknown collider shape type detected");this._geometry=new d(this.collider.shape)}const e=new r.LineBasicMaterial({color:16711935,depthTest:!1,depthWrite:!1});this._line=new r.LineSegments(this._geometry,e),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.collider.updateWorldMatrix(!0,!1),this.matrix.copy(this.collider.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class p extends r.BufferGeometry{constructor(t){super(),this._currentRadius=0,this._currentTail=new r.Vector3,this._springBone=t,this._attrPos=new r.BufferAttribute(new Float32Array(294),3),this.setAttribute("position",this._attrPos),this._attrIndex=new r.BufferAttribute(new Uint16Array(194),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._springBone.settings.hitRadius&&(this._currentRadius=this._springBone.settings.hitRadius,t=!0),this._currentTail.equals(this._springBone.initialLocalChildPosition)||(this._currentTail.copy(this._springBone.initialLocalChildPosition),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.setXYZ(96,0,0,0),this._attrPos.setXYZ(97,this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.setXY(192,96,97),this._attrIndex.needsUpdate=!0}}class _ extends r.Group{constructor(t){super(),this.matrixAutoUpdate=!1,this.springBone=t,this._geometry=new p(this.springBone);const e=new r.LineBasicMaterial({color:16776960,depthTest:!1,depthWrite:!1});this._line=new r.LineSegments(this._geometry,e),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.springBone.bone.updateWorldMatrix(!0,!1),this.matrix.copy(this.springBone.bone.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class f extends r.Object3D{constructor(t){super(),this.shape=t}}const g=new r.Matrix4;function v(t){return t.invert?t.invert():t.getInverse(g.copy(t)),t}class y{constructor(t){this._inverseCache=new r.Matrix4,this._shouldUpdateInverse=!0,this.matrix=t;const e={set:(t,e,i)=>(this._shouldUpdateInverse=!0,t[e]=i,!0)};this._originalElements=t.elements,t.elements=new Proxy(t.elements,e)}get inverse(){return this._shouldUpdateInverse&&(this._inverseCache.copy(this.matrix),v(this._inverseCache),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const x=new r.Matrix4,M=new r.Vector3,w=new r.Vector3,m=new r.Vector3,b=new r.Vector3,S=new r.Vector3,P=new r.Quaternion,R=new r.Matrix4,B=new r.Matrix4;class I{constructor(t,e,i={},s=[]){var n,o,a,l,h,d;this._currentTail=new r.Vector3,this._prevTail=new r.Vector3,this._boneAxis=new r.Vector3,this._worldSpaceBoneLength=0,this._center=null,this._initialLocalMatrix=new r.Matrix4,this._initialLocalRotation=new r.Quaternion,this._initialLocalChildPosition=new r.Vector3,this.bone=t,this.bone.matrixAutoUpdate=!1,this.child=e,this.settings={hitRadius:null!==(n=i.hitRadius)&&void 0!==n?n:0,stiffness:null!==(o=i.stiffness)&&void 0!==o?o:1,gravityPower:null!==(a=i.gravityPower)&&void 0!==a?a:0,gravityDir:null!==(h=null===(l=i.gravityDir)||void 0===l?void 0:l.clone())&&void 0!==h?h:new r.Vector3(0,-1,0),dragForce:null!==(d=i.dragForce)&&void 0!==d?d:.4},this.colliderGroups=s}get center(){return this._center}set center(t){var e;(null===(e=this._center)||void 0===e?void 0:e.userData.inverseCacheProxy)&&(this._center.userData.inverseCacheProxy.revert(),delete this._center.userData.inverseCacheProxy),this._center=t,this._center&&(this._center.userData.inverseCacheProxy||(this._center.userData.inverseCacheProxy=new y(this._center.matrixWorld)))}get initialLocalChildPosition(){return this._initialLocalChildPosition}get _parentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:x}setInitState(){this._initialLocalMatrix.copy(this.bone.matrix),this._initialLocalRotation.copy(this.bone.quaternion),this.child?this._initialLocalChildPosition.copy(this.child.position):this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(.07),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._boneAxis.copy(this._initialLocalChildPosition).normalize(),this._worldSpaceBoneLength=M.copy(this._initialLocalChildPosition).applyMatrix4(this.bone.matrixWorld).sub(w.setFromMatrixPosition(this.bone.matrixWorld)).length()}reset(){this.bone.quaternion.copy(this._initialLocalRotation),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail)}update(t){if(t<=0)return;m.setFromMatrixPosition(this.bone.matrixWorld);let e=this._getMatrixWorldToCenter(R);b.copy(m).applyMatrix4(e);const i=B.copy(e).multiply(this._parentMatrixWorld),r=w.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(i).sub(b).normalize(),s=this._getMatrixCenterToWorld(R);S.copy(this._currentTail).add(M.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(M.copy(r).multiplyScalar(this.settings.stiffness*t)).add(M.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t)).applyMatrix4(s),S.sub(m).normalize().multiplyScalar(this._worldSpaceBoneLength).add(m),this._collision(S),e=this._getMatrixWorldToCenter(R),this._prevTail.copy(this._currentTail),this._currentTail.copy(M.copy(S).applyMatrix4(e));const n=v(R.copy(this._parentMatrixWorld).multiply(this._initialLocalMatrix)),o=P.setFromUnitVectors(this._boneAxis,M.copy(S).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(o),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{const i=e.shape.calculateCollision(e.matrixWorld,t,this.settings.hitRadius,M);i<0&&(t.add(M.multiplyScalar(-i)),t.sub(m).normalize().multiplyScalar(this._worldSpaceBoneLength).add(m))}))}))}_getMatrixCenterToWorld(t){return this._center?t.copy(this._center.matrixWorld):t.identity(),t}_getMatrixWorldToCenter(t){return this._center?t.copy(this._center.userData.inverseCacheProxy.inverse):t.identity(),t}}
/*! *****************************************************************************

@@ -16,2 +16,2 @@ Copyright (c) Microsoft Corporation.

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */function I(t,e,i,r){return new(i||(i=Promise))((function(s,n){function o(t){try{l(r.next(t))}catch(t){n(t)}}function a(t){try{l(r.throw(t))}catch(t){n(t)}}function l(t){var e;t.done?s(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}l((r=r.apply(t,e||[])).next())}))}function C(t,e){const i=[];let r=t;for(;null!==r;)i.unshift(r),r=r.parent;i.forEach((t=>{e(t)}))}function V(t,e){t.children.forEach((t=>{e(t)||V(t,e)}))}class W{constructor(){this._springBones=new Set,this._objectSpringBonesMap=new Map}get springBones(){return this._springBones}get colliderGroups(){const t=new Set;return this._springBones.forEach((e=>{e.colliderGroups.forEach((e=>{t.add(e)}))})),Array.from(t)}get colliders(){const t=new Set;return this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{t.add(e)}))})),Array.from(t)}addSpringBone(t){this._springBones.add(t);let e=this._objectSpringBonesMap.get(t.bone);null==e&&(e=new Set,this._objectSpringBonesMap.set(t.bone,e)),e.add(t)}deleteSpringBone(t){this._springBones.delete(t);this._objectSpringBonesMap.get(t.bone).delete(t)}setInitState(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.reset()))}update(t){const e=new Set,i=new Set,r=new Set;for(const s of this._springBones)this._processSpringBone(s,e,i,r,(e=>e.update(t))),V(s.bone,(t=>{var e,i;return(null!==(i=null===(e=this._objectSpringBonesMap.get(t))||void 0===e?void 0:e.size)&&void 0!==i?i:0)>0||(t.updateWorldMatrix(!1,!1),!1)}))}_processSpringBone(t,e,i,r,s){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating springbones");e.add(t);const n=this._getDependencies(t);for(const t of n)C(t,(t=>{const n=this._objectSpringBonesMap.get(t);if(n)for(const t of n)this._processSpringBone(t,e,i,r,s);else r.has(t)||(t.updateWorldMatrix(!1,!1),r.add(t))}));t.bone.updateMatrix(),t.bone.updateWorldMatrix(!1,!1),s(t),r.add(t.bone),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class E{constructor(t,e){this.parser=t,this.jointHelperRoot=null==e?void 0:e.jointHelperRoot,this.colliderHelperRoot=null==e?void 0:e.colliderHelperRoot}get name(){return E.EXTENSION_NAME}afterRoot(t){return I(this,void 0,void 0,(function*(){t.userData.vrmSpringBoneManager=yield this._import(t)}))}_import(t){return I(this,void 0,void 0,(function*(){const e=yield this._v1Import(t);if(null!=e)return e;const i=yield this._v0Import(t);return null!=i?i:null}))}_v1Import(t){var e,i,s,n,o;return I(this,void 0,void 0,(function*(){const a=t.parser.json;if(!(-1!==(null===(e=a.extensionsUsed)||void 0===e?void 0:e.indexOf(E.EXTENSION_NAME))))return null;const l=new W,h=yield t.parser.getDependencies("node"),c=null===(i=a.extensions)||void 0===i?void 0:i[E.EXTENSION_NAME];if(!c)return null;if("1.0-beta"!==c.specVersion)return null;const d=null===(s=c.colliders)||void 0===s?void 0:s.map(((t,e)=>{var i,s,n,o,a;const l=h[t.node],c=t.shape;if(c.sphere)return this._importSphereCollider(l,{offset:(new r.Vector3).fromArray(null!==(i=c.sphere.offset)&&void 0!==i?i:[0,0,0]),radius:null!==(s=c.sphere.radius)&&void 0!==s?s:0});if(c.capsule)return this._importCapsuleCollider(l,{offset:(new r.Vector3).fromArray(null!==(n=c.capsule.offset)&&void 0!==n?n:[0,0,0]),radius:null!==(o=c.capsule.radius)&&void 0!==o?o:0,tail:(new r.Vector3).fromArray(null!==(a=c.capsule.tail)&&void 0!==a?a:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${e} has no valid shape`)})),u=null===(n=c.colliderGroups)||void 0===n?void 0:n.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==d?void 0:d[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${e} attempted to use a collider #${t} but not found`);return i})),name:t.name}}));return null===(o=c.springs)||void 0===o||o.forEach(((t,e)=>{var i;const s=t.joints,n=null===(i=t.colliderGroups)||void 0===i?void 0:i.map((t=>{const i=null==u?void 0:u[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i}));let o;s.forEach((t=>{var e;if(o){const i=o.node,s=h[i],a=t.node,c=h[a],d={hitRadius:o.hitRadius,dragForce:o.dragForce,gravityPower:o.gravityPower,stiffness:o.stiffness,gravityDir:(new r.Vector3).fromArray(null!==(e=o.gravityDir)&&void 0!==e?e:[0,1,0])},u=this._importJoint(s,c,d,n);l.addSpringBone(u)}o=t}))})),l.setInitState(),l}))}_v0Import(t){var e,i,s;return I(this,void 0,void 0,(function*(){const n=t.parser.json;if(!(-1!==(null===(e=n.extensionsUsed)||void 0===e?void 0:e.indexOf("VRM"))))return null;const o=null===(i=n.extensions)||void 0===i?void 0:i.VRM,a=null==o?void 0:o.secondaryAnimation;if(!a)return null;const l=null==a?void 0:a.boneGroups;if(!l)return null;const h=new W,c=yield t.parser.getDependencies("node"),d=null===(s=a.colliderGroups)||void 0===s?void 0:s.map((t=>{var e;const i=c[t.node];return{colliders:(null!==(e=t.colliders)&&void 0!==e?e:[]).map(((t,e)=>{var s,n,o;const a=new r.Vector3(0,0,0);return t.offset&&a.set(null!==(s=t.offset.x)&&void 0!==s?s:0,null!==(n=t.offset.y)&&void 0!==n?n:0,t.offset.z?-t.offset.z:0),this._importSphereCollider(i,{offset:a,radius:null!==(o=t.radius)&&void 0!==o?o:0})}))}}));return null==l||l.forEach(((t,e)=>{const i=t.bones;i&&i.forEach((i=>{var s,n,o,a;const l=c[i],u=new r.Vector3;t.gravityDir?u.set(null!==(s=t.gravityDir.x)&&void 0!==s?s:0,null!==(n=t.gravityDir.y)&&void 0!==n?n:0,null!==(o=t.gravityDir.z)&&void 0!==o?o:0):u.set(0,-1,0);const p={hitRadius:t.hitRadius,dragForce:t.dragForce,gravityPower:t.gravityPower,stiffness:t.stiffiness,gravityDir:u},_=null===(a=t.colliderGroups)||void 0===a?void 0:a.map((t=>{const i=null==d?void 0:d[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i}));l.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);h.addSpringBone(r)}))}))})),t.scene.updateMatrixWorld(),h.setInitState(),h}))}_importJoint(t,e,i,r){const s=new T(t,e,i,r);if(this.jointHelperRoot){const t=new _(s);this.jointHelperRoot.add(t),t.renderOrder=this.jointHelperRoot.renderOrder}return s}_importSphereCollider(t,e){const{offset:i,radius:r}=e,s=new l({offset:i,radius:r}),n=new f(s);if(t.add(n),this.colliderHelperRoot){const t=new u(n);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return n}_importCapsuleCollider(t,e){const{offset:i,radius:r,tail:s}=e,n=new a({offset:i,radius:r,tail:s}),o=new f(n);if(t.add(o),this.colliderHelperRoot){const t=new u(o);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return o}}E.EXTENSION_NAME="VRMC_springBone",t.VRMSpringBoneCollider=f,t.VRMSpringBoneColliderHelper=u,t.VRMSpringBoneColliderShape=s,t.VRMSpringBoneColliderShapeCapsule=a,t.VRMSpringBoneColliderShapeSphere=l,t.VRMSpringBoneJoint=T,t.VRMSpringBoneJointHelper=_,t.VRMSpringBoneLoaderPlugin=E,t.VRMSpringBoneManager=W,Object.defineProperty(t,"__esModule",{value:!0}),Object.assign(e,t)}));
***************************************************************************** */function T(t,e,i,r){return new(i||(i=Promise))((function(s,n){function o(t){try{l(r.next(t))}catch(t){n(t)}}function a(t){try{l(r.throw(t))}catch(t){n(t)}}function l(t){var e;t.done?s(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}l((r=r.apply(t,e||[])).next())}))}function V(t,e){const i=[];let r=t;for(;null!==r;)i.unshift(r),r=r.parent;i.forEach((t=>{e(t)}))}function C(t,e){t.children.forEach((t=>{e(t)||C(t,e)}))}class E{constructor(){this._springBones=new Set,this._objectSpringBonesMap=new Map}get springBones(){return this._springBones}get colliderGroups(){const t=new Set;return this._springBones.forEach((e=>{e.colliderGroups.forEach((e=>{t.add(e)}))})),Array.from(t)}get colliders(){const t=new Set;return this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{t.add(e)}))})),Array.from(t)}addSpringBone(t){this._springBones.add(t);let e=this._objectSpringBonesMap.get(t.bone);null==e&&(e=new Set,this._objectSpringBonesMap.set(t.bone,e)),e.add(t)}deleteSpringBone(t){this._springBones.delete(t);this._objectSpringBonesMap.get(t.bone).delete(t)}setInitState(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.reset()))}update(t){const e=new Set,i=new Set,r=new Set;for(const s of this._springBones)this._processSpringBone(s,e,i,r,(e=>e.update(t))),C(s.bone,(t=>{var e,i;return(null!==(i=null===(e=this._objectSpringBonesMap.get(t))||void 0===e?void 0:e.size)&&void 0!==i?i:0)>0||(t.updateWorldMatrix(!1,!1),!1)}))}_processSpringBone(t,e,i,r,s){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating springbones");e.add(t);const n=this._getDependencies(t);for(const t of n)V(t,(t=>{const n=this._objectSpringBonesMap.get(t);if(n)for(const t of n)this._processSpringBone(t,e,i,r,s);else r.has(t)||(t.updateWorldMatrix(!1,!1),r.add(t))}));t.bone.updateMatrix(),t.bone.updateWorldMatrix(!1,!1),s(t),r.add(t.bone),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),t.colliderGroups.forEach((t=>{t.colliders.forEach((t=>{e.add(t)}))})),e}}class O{constructor(t,e){this.parser=t,this.jointHelperRoot=null==e?void 0:e.jointHelperRoot,this.colliderHelperRoot=null==e?void 0:e.colliderHelperRoot}get name(){return O.EXTENSION_NAME}afterRoot(t){return T(this,void 0,void 0,(function*(){t.userData.vrmSpringBoneManager=yield this._import(t)}))}_import(t){return T(this,void 0,void 0,(function*(){const e=yield this._v1Import(t);if(null!=e)return e;const i=yield this._v0Import(t);return null!=i?i:null}))}_v1Import(t){var e,i,s,n,o;return T(this,void 0,void 0,(function*(){const a=t.parser.json;if(!(-1!==(null===(e=a.extensionsUsed)||void 0===e?void 0:e.indexOf(O.EXTENSION_NAME))))return null;const l=new E,h=yield t.parser.getDependencies("node"),d=null===(i=a.extensions)||void 0===i?void 0:i[O.EXTENSION_NAME];if(!d)return null;if("1.0-beta"!==d.specVersion)return null;const c=null===(s=d.colliders)||void 0===s?void 0:s.map(((t,e)=>{var i,s,n,o,a;const l=h[t.node],d=t.shape;if(d.sphere)return this._importSphereCollider(l,{offset:(new r.Vector3).fromArray(null!==(i=d.sphere.offset)&&void 0!==i?i:[0,0,0]),radius:null!==(s=d.sphere.radius)&&void 0!==s?s:0});if(d.capsule)return this._importCapsuleCollider(l,{offset:(new r.Vector3).fromArray(null!==(n=d.capsule.offset)&&void 0!==n?n:[0,0,0]),radius:null!==(o=d.capsule.radius)&&void 0!==o?o:0,tail:(new r.Vector3).fromArray(null!==(a=d.capsule.tail)&&void 0!==a?a:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${e} has no valid shape`)})),u=null===(n=d.colliderGroups)||void 0===n?void 0:n.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==c?void 0:c[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${e} attempted to use a collider #${t} but not found`);return i})),name:t.name}}));return null===(o=d.springs)||void 0===o||o.forEach(((t,e)=>{var i;const s=t.joints,n=null===(i=t.colliderGroups)||void 0===i?void 0:i.map((t=>{const i=null==u?void 0:u[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i})),o=null!=t.center?h[t.center]:void 0;let a;s.forEach((t=>{var e;if(a){const i=a.node,s=h[i],d=t.node,c=h[d],u={hitRadius:a.hitRadius,dragForce:a.dragForce,gravityPower:a.gravityPower,stiffness:a.stiffness,gravityDir:(new r.Vector3).fromArray(null!==(e=a.gravityDir)&&void 0!==e?e:[0,1,0])},p=this._importJoint(s,c,u,n);o&&(p.center=o),l.addSpringBone(p)}a=t}))})),l.setInitState(),l}))}_v0Import(t){var e,i,s;return T(this,void 0,void 0,(function*(){const n=t.parser.json;if(!(-1!==(null===(e=n.extensionsUsed)||void 0===e?void 0:e.indexOf("VRM"))))return null;const o=null===(i=n.extensions)||void 0===i?void 0:i.VRM,a=null==o?void 0:o.secondaryAnimation;if(!a)return null;const l=null==a?void 0:a.boneGroups;if(!l)return null;const h=new E,d=yield t.parser.getDependencies("node"),c=null===(s=a.colliderGroups)||void 0===s?void 0:s.map((t=>{var e;const i=d[t.node];return{colliders:(null!==(e=t.colliders)&&void 0!==e?e:[]).map(((t,e)=>{var s,n,o;const a=new r.Vector3(0,0,0);return t.offset&&a.set(null!==(s=t.offset.x)&&void 0!==s?s:0,null!==(n=t.offset.y)&&void 0!==n?n:0,t.offset.z?-t.offset.z:0),this._importSphereCollider(i,{offset:a,radius:null!==(o=t.radius)&&void 0!==o?o:0})}))}}));return null==l||l.forEach(((t,e)=>{const i=t.bones;i&&i.forEach((i=>{var s,n,o,a;const l=d[i],u=new r.Vector3;t.gravityDir?u.set(null!==(s=t.gravityDir.x)&&void 0!==s?s:0,null!==(n=t.gravityDir.y)&&void 0!==n?n:0,null!==(o=t.gravityDir.z)&&void 0!==o?o:0):u.set(0,-1,0);const p=null!=t.center?d[t.center]:void 0,_={hitRadius:t.hitRadius,dragForce:t.dragForce,gravityPower:t.gravityPower,stiffness:t.stiffiness,gravityDir:u},f=null===(a=t.colliderGroups)||void 0===a?void 0:a.map((t=>{const i=null==c?void 0:c[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i}));l.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,_,f);p&&(r.center=p),h.addSpringBone(r)}))}))})),t.scene.updateMatrixWorld(),h.setInitState(),h}))}_importJoint(t,e,i,r){const s=new I(t,e,i,r);if(this.jointHelperRoot){const t=new _(s);this.jointHelperRoot.add(t),t.renderOrder=this.jointHelperRoot.renderOrder}return s}_importSphereCollider(t,e){const{offset:i,radius:r}=e,s=new l({offset:i,radius:r}),n=new f(s);if(t.add(n),this.colliderHelperRoot){const t=new u(n);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return n}_importCapsuleCollider(t,e){const{offset:i,radius:r,tail:s}=e,n=new a({offset:i,radius:r,tail:s}),o=new f(n);if(t.add(o),this.colliderHelperRoot){const t=new u(o);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return o}}O.EXTENSION_NAME="VRMC_springBone",t.VRMSpringBoneCollider=f,t.VRMSpringBoneColliderHelper=u,t.VRMSpringBoneColliderShape=s,t.VRMSpringBoneColliderShapeCapsule=a,t.VRMSpringBoneColliderShapeSphere=l,t.VRMSpringBoneJoint=I,t.VRMSpringBoneJointHelper=_,t.VRMSpringBoneLoaderPlugin=O,t.VRMSpringBoneManager=E,Object.defineProperty(t,"__esModule",{value:!0}),Object.assign(e,t)}));
/*! (c) 2020-2021 pixiv Inc. - https://github.com/pixiv/three-vrm/blob/release/LICENSE */
import*as t from"three";class e{}const i=new t.Vector3,r=new t.Vector3;class s extends e{constructor(e){var i,r,s;super(),this.offset=null!==(i=null==e?void 0:e.offset)&&void 0!==i?i:new t.Vector3(0,0,0),this.tail=null!==(r=null==e?void 0:e.tail)&&void 0!==r?r:new t.Vector3(0,0,0),this.radius=null!==(s=null==e?void 0:e.radius)&&void 0!==s?s:0}get type(){return"capsule"}calculateCollision(t,e,s,n){i.copy(this.offset).applyMatrix4(t),r.copy(this.tail).applyMatrix4(t),r.sub(i);const o=r.lengthSq();n.copy(e).sub(i);const a=r.dot(n);a<=0||(o<=a||r.multiplyScalar(a/o),n.sub(r));const l=s+this.radius,h=n.length()-l;return n.normalize(),h}}class n extends e{constructor(e){var i,r;super(),this.offset=null!==(i=null==e?void 0:e.offset)&&void 0!==i?i:new t.Vector3(0,0,0),this.radius=null!==(r=null==e?void 0:e.radius)&&void 0!==r?r:0}get type(){return"sphere"}calculateCollision(t,e,i,r){r.copy(this.offset).applyMatrix4(t),r.negate().add(e);const s=i+this.radius,n=r.length()-s;return r.normalize(),n}}const o=new t.Vector3;class a extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentOffset=new t.Vector3,this._currentTail=new t.Vector3,this._shape=e,this._attrPos=new t.BufferAttribute(new Float32Array(396),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(264),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),this._currentTail.equals(this._shape.tail)||(this._currentTail.copy(this._shape.tail),t=!0),t&&this._buildPosition()}_buildPosition(){o.copy(this._currentTail).sub(this._currentOffset);const t=o.length()/this._currentRadius;for(let e=0;e<=16;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(e,-Math.sin(i),-Math.cos(i),0),this._attrPos.setXYZ(17+e,t+Math.sin(i),Math.cos(i),0),this._attrPos.setXYZ(34+e,-Math.sin(i),0,-Math.cos(i)),this._attrPos.setXYZ(51+e,t+Math.sin(i),0,Math.cos(i))}for(let e=0;e<32;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(68+e,0,Math.sin(i),Math.cos(i)),this._attrPos.setXYZ(100+e,t,Math.sin(i),Math.cos(i))}const e=Math.atan2(o.y,Math.sqrt(o.x*o.x+o.z*o.z)),i=-Math.atan2(o.z,o.x);this.rotateZ(e),this.rotateY(i),this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<34;t++){const e=(t+1)%34;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(68+2*t,34+t,34+e)}for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(136+2*t,68+t,68+e),this._attrIndex.setXY(200+2*t,100+t,100+e)}this._attrIndex.needsUpdate=!0}}class l extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentOffset=new t.Vector3,this._shape=e,this._attrPos=new t.BufferAttribute(new Float32Array(288),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(192),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.needsUpdate=!0}}class h extends t.Group{constructor(e){if(super(),this.matrixAutoUpdate=!1,this.collider=e,this.collider.shape instanceof n)this._geometry=new l(this.collider.shape);else{if(!(this.collider.shape instanceof s))throw new Error("VRMSpringBoneColliderHelper: Unknown collider shape type detected");this._geometry=new a(this.collider.shape)}const i=new t.LineBasicMaterial({color:16711935,depthTest:!1,depthWrite:!1});this._line=new t.LineSegments(this._geometry,i),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.collider.updateWorldMatrix(!0,!1),this.matrix.copy(this.collider.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class c extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentTail=new t.Vector3,this._springBone=e,this._attrPos=new t.BufferAttribute(new Float32Array(294),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(194),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._springBone.settings.hitRadius&&(this._currentRadius=this._springBone.settings.hitRadius,t=!0),this._currentTail.equals(this._springBone.initialLocalChildPosition)||(this._currentTail.copy(this._springBone.initialLocalChildPosition),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.setXYZ(96,0,0,0),this._attrPos.setXYZ(97,this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.setXY(192,96,97),this._attrIndex.needsUpdate=!0}}class d extends t.Group{constructor(e){super(),this.matrixAutoUpdate=!1,this.springBone=e,this._geometry=new c(this.springBone);const i=new t.LineBasicMaterial({color:16776960,depthTest:!1,depthWrite:!1});this._line=new t.LineSegments(this._geometry,i),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.springBone.bone.updateWorldMatrix(!0,!1),this.matrix.copy(this.springBone.bone.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class u extends t.Object3D{constructor(t){super(),this.shape=t}}const p=new t.Vector3,_=new t.Vector3;const f=new t.Matrix4;function x(t){return t.invert?t.invert():t.getInverse(f.copy(t)),t}class v{constructor(e){this._inverseCache=new t.Matrix4,this._shouldUpdateInverse=!0,this.matrix=e;const i={set:(t,e,i)=>(this._shouldUpdateInverse=!0,t[e]=i,!0)};this._originalElements=e.elements,e.elements=new Proxy(e.elements,i)}get inverse(){return this._shouldUpdateInverse&&(this._inverseCache.copy(this.matrix),x(this._inverseCache),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const y=new t.Matrix4,g=new t.Quaternion,m=new t.Vector3,M=new t.Vector3,w=new t.Quaternion,b=new t.Matrix4,P=new t.Matrix4;class S{constructor(e,i,r={},s=[]){var n,o,a,l,h,c;this._currentTail=new t.Vector3,this._prevTail=new t.Vector3,this._nextTail=new t.Vector3,this._boneAxis=new t.Vector3,this._centerSpaceBoneLength=0,this._centerSpacePosition=new t.Vector3,this._center=null,this._parentWorldRotation=new t.Quaternion,this._initialLocalMatrix=new t.Matrix4,this._initialLocalRotation=new t.Quaternion,this._initialLocalChildPosition=new t.Vector3,this.bone=e,this.bone.matrixAutoUpdate=!1,this.child=i,this.settings={hitRadius:null!==(n=r.hitRadius)&&void 0!==n?n:0,stiffness:null!==(o=r.stiffness)&&void 0!==o?o:1,gravityPower:null!==(a=r.gravityPower)&&void 0!==a?a:0,gravityDir:null!==(h=null===(l=r.gravityDir)||void 0===l?void 0:l.clone())&&void 0!==h?h:new t.Vector3(0,-1,0),dragForce:null!==(c=r.dragForce)&&void 0!==c?c:.4},this.colliderGroups=s}get center(){return this._center}set center(t){var e;this._getMatrixCenterToWorld(b),this._currentTail.applyMatrix4(b),this._prevTail.applyMatrix4(b),this._nextTail.applyMatrix4(b),(null===(e=this._center)||void 0===e?void 0:e.userData.inverseCacheProxy)&&(this._center.userData.inverseCacheProxy.revert(),delete this._center.userData.inverseCacheProxy),this._center=t,this._center&&(this._center.userData.inverseCacheProxy||(this._center.userData.inverseCacheProxy=new v(this._center.matrixWorld))),this._getMatrixWorldToCenter(b),this._currentTail.applyMatrix4(b),this._prevTail.applyMatrix4(b),this._nextTail.applyMatrix4(b),b.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(b),this._centerSpaceBoneLength=m.copy(this._initialLocalChildPosition).applyMatrix4(b).sub(this._centerSpacePosition).length()}get initialLocalChildPosition(){return this._initialLocalChildPosition}get _parentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:y}setInitState(){this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld),this._initialLocalMatrix.copy(this.bone.matrix),this._initialLocalRotation.copy(this.bone.quaternion),this.child?this._initialLocalChildPosition.copy(this.child.position):this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(.07),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._nextTail.copy(this._currentTail),this._boneAxis.copy(this._initialLocalChildPosition).normalize(),this._centerSpaceBoneLength=m.copy(this._initialLocalChildPosition).applyMatrix4(this.bone.matrixWorld).sub(this._centerSpacePosition).length()}reset(){this.bone.quaternion.copy(this._initialLocalRotation),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix),this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._nextTail.copy(this._currentTail)}update(t){if(t<=0)return;var e,i;this.bone.parent?(e=this.bone.parent,i=this._parentWorldRotation,e.matrixWorld.decompose(p,i,_)):this._parentWorldRotation.copy(g),this._getMatrixWorldToCenter(b),b.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(b);const r=this._getMatrixWorldToCenter(P).multiply(this._parentMatrixWorld),s=M.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(r).sub(this._centerSpacePosition).normalize();this._nextTail.copy(this._currentTail).add(m.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(m.copy(s).multiplyScalar(this.settings.stiffness*t)).add(m.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t)),this._nextTail.sub(this._centerSpacePosition).normalize().multiplyScalar(this._centerSpaceBoneLength).add(this._centerSpacePosition),this._collision(this._nextTail),this._prevTail.copy(this._currentTail),this._currentTail.copy(this._nextTail);const n=x(b.copy(P.multiply(this._initialLocalMatrix))),o=w.setFromUnitVectors(this._boneAxis,m.copy(this._nextTail).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(o),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{this._getMatrixWorldToCenter(b),b.multiply(e.matrixWorld);const i=e.shape.calculateCollision(b,t,this.settings.hitRadius,m);i<0&&(t.add(m.multiplyScalar(-i)),t.sub(this._centerSpacePosition).normalize().multiplyScalar(this._centerSpaceBoneLength).add(this._centerSpacePosition))}))}))}_getMatrixCenterToWorld(t){return this._center?t.copy(this._center.matrixWorld):t.identity(),t}_getMatrixWorldToCenter(t){return this._center?t.copy(this._center.userData.inverseCacheProxy.inverse):t.identity(),t}}
import*as t from"three";class e{}const i=new t.Vector3,r=new t.Vector3;class s extends e{constructor(e){var i,r,s;super(),this.offset=null!==(i=null==e?void 0:e.offset)&&void 0!==i?i:new t.Vector3(0,0,0),this.tail=null!==(r=null==e?void 0:e.tail)&&void 0!==r?r:new t.Vector3(0,0,0),this.radius=null!==(s=null==e?void 0:e.radius)&&void 0!==s?s:0}get type(){return"capsule"}calculateCollision(t,e,s,n){i.copy(this.offset).applyMatrix4(t),r.copy(this.tail).applyMatrix4(t),r.sub(i);const o=r.lengthSq();n.copy(e).sub(i);const a=r.dot(n);a<=0||(o<=a||r.multiplyScalar(a/o),n.sub(r));const l=s+this.radius,h=n.length()-l;return n.normalize(),h}}class n extends e{constructor(e){var i,r;super(),this.offset=null!==(i=null==e?void 0:e.offset)&&void 0!==i?i:new t.Vector3(0,0,0),this.radius=null!==(r=null==e?void 0:e.radius)&&void 0!==r?r:0}get type(){return"sphere"}calculateCollision(t,e,i,r){r.copy(this.offset).applyMatrix4(t),r.negate().add(e);const s=i+this.radius,n=r.length()-s;return r.normalize(),n}}const o=new t.Vector3;class a extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentOffset=new t.Vector3,this._currentTail=new t.Vector3,this._shape=e,this._attrPos=new t.BufferAttribute(new Float32Array(396),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(264),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),this._currentTail.equals(this._shape.tail)||(this._currentTail.copy(this._shape.tail),t=!0),t&&this._buildPosition()}_buildPosition(){o.copy(this._currentTail).sub(this._currentOffset);const t=o.length()/this._currentRadius;for(let e=0;e<=16;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(e,-Math.sin(i),-Math.cos(i),0),this._attrPos.setXYZ(17+e,t+Math.sin(i),Math.cos(i),0),this._attrPos.setXYZ(34+e,-Math.sin(i),0,-Math.cos(i)),this._attrPos.setXYZ(51+e,t+Math.sin(i),0,Math.cos(i))}for(let e=0;e<32;e++){const i=e/16*Math.PI;this._attrPos.setXYZ(68+e,0,Math.sin(i),Math.cos(i)),this._attrPos.setXYZ(100+e,t,Math.sin(i),Math.cos(i))}const e=Math.atan2(o.y,Math.sqrt(o.x*o.x+o.z*o.z)),i=-Math.atan2(o.z,o.x);this.rotateZ(e),this.rotateY(i),this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<34;t++){const e=(t+1)%34;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(68+2*t,34+t,34+e)}for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(136+2*t,68+t,68+e),this._attrIndex.setXY(200+2*t,100+t,100+e)}this._attrIndex.needsUpdate=!0}}class l extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentOffset=new t.Vector3,this._shape=e,this._attrPos=new t.BufferAttribute(new Float32Array(288),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(192),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._shape.radius&&(this._currentRadius=this._shape.radius,t=!0),this._currentOffset.equals(this._shape.offset)||(this._currentOffset.copy(this._shape.offset),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentOffset.x,this._currentOffset.y,this._currentOffset.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.needsUpdate=!0}}class h extends t.Group{constructor(e){if(super(),this.matrixAutoUpdate=!1,this.collider=e,this.collider.shape instanceof n)this._geometry=new l(this.collider.shape);else{if(!(this.collider.shape instanceof s))throw new Error("VRMSpringBoneColliderHelper: Unknown collider shape type detected");this._geometry=new a(this.collider.shape)}const i=new t.LineBasicMaterial({color:16711935,depthTest:!1,depthWrite:!1});this._line=new t.LineSegments(this._geometry,i),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.collider.updateWorldMatrix(!0,!1),this.matrix.copy(this.collider.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class d extends t.BufferGeometry{constructor(e){super(),this._currentRadius=0,this._currentTail=new t.Vector3,this._springBone=e,this._attrPos=new t.BufferAttribute(new Float32Array(294),3),this.setAttribute("position",this._attrPos),this._attrIndex=new t.BufferAttribute(new Uint16Array(194),1),this.setIndex(this._attrIndex),this._buildIndex(),this.update()}update(){let t=!1;this._currentRadius!==this._springBone.settings.hitRadius&&(this._currentRadius=this._springBone.settings.hitRadius,t=!0),this._currentTail.equals(this._springBone.initialLocalChildPosition)||(this._currentTail.copy(this._springBone.initialLocalChildPosition),t=!0),t&&this._buildPosition()}_buildPosition(){for(let t=0;t<32;t++){const e=t/16*Math.PI;this._attrPos.setXYZ(t,Math.cos(e),Math.sin(e),0),this._attrPos.setXYZ(32+t,0,Math.cos(e),Math.sin(e)),this._attrPos.setXYZ(64+t,Math.sin(e),0,Math.cos(e))}this.scale(this._currentRadius,this._currentRadius,this._currentRadius),this.translate(this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.setXYZ(96,0,0,0),this._attrPos.setXYZ(97,this._currentTail.x,this._currentTail.y,this._currentTail.z),this._attrPos.needsUpdate=!0}_buildIndex(){for(let t=0;t<32;t++){const e=(t+1)%32;this._attrIndex.setXY(2*t,t,e),this._attrIndex.setXY(64+2*t,32+t,32+e),this._attrIndex.setXY(128+2*t,64+t,64+e)}this._attrIndex.setXY(192,96,97),this._attrIndex.needsUpdate=!0}}class c extends t.Group{constructor(e){super(),this.matrixAutoUpdate=!1,this.springBone=e,this._geometry=new d(this.springBone);const i=new t.LineBasicMaterial({color:16776960,depthTest:!1,depthWrite:!1});this._line=new t.LineSegments(this._geometry,i),this.add(this._line)}dispose(){this._geometry.dispose()}updateMatrixWorld(t){this.springBone.bone.updateWorldMatrix(!0,!1),this.matrix.copy(this.springBone.bone.matrixWorld),this._geometry.update(),super.updateMatrixWorld(t)}}class u extends t.Object3D{constructor(t){super(),this.shape=t}}const p=new t.Matrix4;function _(t){return t.invert?t.invert():t.getInverse(p.copy(t)),t}class f{constructor(e){this._inverseCache=new t.Matrix4,this._shouldUpdateInverse=!0,this.matrix=e;const i={set:(t,e,i)=>(this._shouldUpdateInverse=!0,t[e]=i,!0)};this._originalElements=e.elements,e.elements=new Proxy(e.elements,i)}get inverse(){return this._shouldUpdateInverse&&(this._inverseCache.copy(this.matrix),_(this._inverseCache),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const v=new t.Matrix4,x=new t.Vector3,y=new t.Vector3,g=new t.Vector3,w=new t.Vector3,m=new t.Vector3,M=new t.Quaternion,b=new t.Matrix4,P=new t.Matrix4;class S{constructor(e,i,r={},s=[]){var n,o,a,l,h,d;this._currentTail=new t.Vector3,this._prevTail=new t.Vector3,this._boneAxis=new t.Vector3,this._worldSpaceBoneLength=0,this._center=null,this._initialLocalMatrix=new t.Matrix4,this._initialLocalRotation=new t.Quaternion,this._initialLocalChildPosition=new t.Vector3,this.bone=e,this.bone.matrixAutoUpdate=!1,this.child=i,this.settings={hitRadius:null!==(n=r.hitRadius)&&void 0!==n?n:0,stiffness:null!==(o=r.stiffness)&&void 0!==o?o:1,gravityPower:null!==(a=r.gravityPower)&&void 0!==a?a:0,gravityDir:null!==(h=null===(l=r.gravityDir)||void 0===l?void 0:l.clone())&&void 0!==h?h:new t.Vector3(0,-1,0),dragForce:null!==(d=r.dragForce)&&void 0!==d?d:.4},this.colliderGroups=s}get center(){return this._center}set center(t){var e;(null===(e=this._center)||void 0===e?void 0:e.userData.inverseCacheProxy)&&(this._center.userData.inverseCacheProxy.revert(),delete this._center.userData.inverseCacheProxy),this._center=t,this._center&&(this._center.userData.inverseCacheProxy||(this._center.userData.inverseCacheProxy=new f(this._center.matrixWorld)))}get initialLocalChildPosition(){return this._initialLocalChildPosition}get _parentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:v}setInitState(){this._initialLocalMatrix.copy(this.bone.matrix),this._initialLocalRotation.copy(this.bone.quaternion),this.child?this._initialLocalChildPosition.copy(this.child.position):this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(.07),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail),this._boneAxis.copy(this._initialLocalChildPosition).normalize(),this._worldSpaceBoneLength=x.copy(this._initialLocalChildPosition).applyMatrix4(this.bone.matrixWorld).sub(y.setFromMatrixPosition(this.bone.matrixWorld)).length()}reset(){this.bone.quaternion.copy(this._initialLocalRotation),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix),this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)),this._prevTail.copy(this._currentTail)}update(t){if(t<=0)return;g.setFromMatrixPosition(this.bone.matrixWorld);let e=this._getMatrixWorldToCenter(b);w.copy(g).applyMatrix4(e);const i=P.copy(e).multiply(this._parentMatrixWorld),r=y.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(i).sub(w).normalize(),s=this._getMatrixCenterToWorld(b);m.copy(this._currentTail).add(x.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(x.copy(r).multiplyScalar(this.settings.stiffness*t)).add(x.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t)).applyMatrix4(s),m.sub(g).normalize().multiplyScalar(this._worldSpaceBoneLength).add(g),this._collision(m),e=this._getMatrixWorldToCenter(b),this._prevTail.copy(this._currentTail),this._currentTail.copy(x.copy(m).applyMatrix4(e));const n=_(b.copy(this._parentMatrixWorld).multiply(this._initialLocalMatrix)),o=M.setFromUnitVectors(this._boneAxis,x.copy(m).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(o),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld,this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{const i=e.shape.calculateCollision(e.matrixWorld,t,this.settings.hitRadius,x);i<0&&(t.add(x.multiplyScalar(-i)),t.sub(g).normalize().multiplyScalar(this._worldSpaceBoneLength).add(g))}))}))}_getMatrixCenterToWorld(t){return this._center?t.copy(this._center.matrixWorld):t.identity(),t}_getMatrixWorldToCenter(t){return this._center?t.copy(this._center.userData.inverseCacheProxy.inverse):t.identity(),t}}
/*! *****************************************************************************

@@ -16,2 +16,2 @@ Copyright (c) Microsoft Corporation.

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */function T(t,e,i,r){return new(i||(i=Promise))((function(s,n){function o(t){try{l(r.next(t))}catch(t){n(t)}}function a(t){try{l(r.throw(t))}catch(t){n(t)}}function l(t){var e;t.done?s(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}l((r=r.apply(t,e||[])).next())}))}function R(t,e){const i=[];let r=t;for(;null!==r;)i.unshift(r),r=r.parent;i.forEach((t=>{e(t)}))}function B(t,e){t.children.forEach((t=>{e(t)||B(t,e)}))}class I{constructor(){this._springBones=new Set,this._objectSpringBonesMap=new Map}get springBones(){return this._springBones}get colliderGroups(){const t=new Set;return this._springBones.forEach((e=>{e.colliderGroups.forEach((e=>{t.add(e)}))})),Array.from(t)}get colliders(){const t=new Set;return this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{t.add(e)}))})),Array.from(t)}addSpringBone(t){this._springBones.add(t);let e=this._objectSpringBonesMap.get(t.bone);null==e&&(e=new Set,this._objectSpringBonesMap.set(t.bone,e)),e.add(t)}deleteSpringBone(t){this._springBones.delete(t);this._objectSpringBonesMap.get(t.bone).delete(t)}setInitState(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.reset()))}update(t){const e=new Set,i=new Set,r=new Set;for(const s of this._springBones)this._processSpringBone(s,e,i,r,(e=>e.update(t))),B(s.bone,(t=>{var e,i;return(null!==(i=null===(e=this._objectSpringBonesMap.get(t))||void 0===e?void 0:e.size)&&void 0!==i?i:0)>0||(t.updateWorldMatrix(!1,!1),!1)}))}_processSpringBone(t,e,i,r,s){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating springbones");e.add(t);const n=this._getDependencies(t);for(const t of n)R(t,(t=>{const n=this._objectSpringBonesMap.get(t);if(n)for(const t of n)this._processSpringBone(t,e,i,r,s);else r.has(t)||(t.updateWorldMatrix(!1,!1),r.add(t))}));t.bone.updateMatrix(),t.bone.updateWorldMatrix(!1,!1),s(t),r.add(t.bone),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class C{constructor(t,e){this.parser=t,this.jointHelperRoot=null==e?void 0:e.jointHelperRoot,this.colliderHelperRoot=null==e?void 0:e.colliderHelperRoot}get name(){return C.EXTENSION_NAME}afterRoot(t){return T(this,void 0,void 0,(function*(){t.userData.vrmSpringBoneManager=yield this._import(t)}))}_import(t){return T(this,void 0,void 0,(function*(){const e=yield this._v1Import(t);if(null!=e)return e;const i=yield this._v0Import(t);return null!=i?i:null}))}_v1Import(e){var i,r,s,n,o;return T(this,void 0,void 0,(function*(){const a=e.parser.json;if(!(-1!==(null===(i=a.extensionsUsed)||void 0===i?void 0:i.indexOf(C.EXTENSION_NAME))))return null;const l=new I,h=yield e.parser.getDependencies("node"),c=null===(r=a.extensions)||void 0===r?void 0:r[C.EXTENSION_NAME];if(!c)return null;if("1.0-beta"!==c.specVersion)return null;const d=null===(s=c.colliders)||void 0===s?void 0:s.map(((e,i)=>{var r,s,n,o,a;const l=h[e.node],c=e.shape;if(c.sphere)return this._importSphereCollider(l,{offset:(new t.Vector3).fromArray(null!==(r=c.sphere.offset)&&void 0!==r?r:[0,0,0]),radius:null!==(s=c.sphere.radius)&&void 0!==s?s:0});if(c.capsule)return this._importCapsuleCollider(l,{offset:(new t.Vector3).fromArray(null!==(n=c.capsule.offset)&&void 0!==n?n:[0,0,0]),radius:null!==(o=c.capsule.radius)&&void 0!==o?o:0,tail:(new t.Vector3).fromArray(null!==(a=c.capsule.tail)&&void 0!==a?a:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${i} has no valid shape`)})),u=null===(n=c.colliderGroups)||void 0===n?void 0:n.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==d?void 0:d[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${e} attempted to use a collider #${t} but not found`);return i})),name:t.name}}));return null===(o=c.springs)||void 0===o||o.forEach(((e,i)=>{var r;const s=e.joints,n=null===(r=e.colliderGroups)||void 0===r?void 0:r.map((t=>{const e=null==u?void 0:u[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e}));let o;s.forEach((e=>{var i;if(o){const r=o.node,s=h[r],a=e.node,c=h[a],d={hitRadius:o.hitRadius,dragForce:o.dragForce,gravityPower:o.gravityPower,stiffness:o.stiffness,gravityDir:(new t.Vector3).fromArray(null!==(i=o.gravityDir)&&void 0!==i?i:[0,1,0])},u=this._importJoint(s,c,d,n);l.addSpringBone(u)}o=e}))})),l.setInitState(),l}))}_v0Import(e){var i,r,s;return T(this,void 0,void 0,(function*(){const n=e.parser.json;if(!(-1!==(null===(i=n.extensionsUsed)||void 0===i?void 0:i.indexOf("VRM"))))return null;const o=null===(r=n.extensions)||void 0===r?void 0:r.VRM,a=null==o?void 0:o.secondaryAnimation;if(!a)return null;const l=null==a?void 0:a.boneGroups;if(!l)return null;const h=new I,c=yield e.parser.getDependencies("node"),d=null===(s=a.colliderGroups)||void 0===s?void 0:s.map((e=>{var i;const r=c[e.node];return{colliders:(null!==(i=e.colliders)&&void 0!==i?i:[]).map(((e,i)=>{var s,n,o;const a=new t.Vector3(0,0,0);return e.offset&&a.set(null!==(s=e.offset.x)&&void 0!==s?s:0,null!==(n=e.offset.y)&&void 0!==n?n:0,e.offset.z?-e.offset.z:0),this._importSphereCollider(r,{offset:a,radius:null!==(o=e.radius)&&void 0!==o?o:0})}))}}));return null==l||l.forEach(((e,i)=>{const r=e.bones;r&&r.forEach((r=>{var s,n,o,a;const l=c[r],u=new t.Vector3;e.gravityDir?u.set(null!==(s=e.gravityDir.x)&&void 0!==s?s:0,null!==(n=e.gravityDir.y)&&void 0!==n?n:0,null!==(o=e.gravityDir.z)&&void 0!==o?o:0):u.set(0,-1,0);const p={hitRadius:e.hitRadius,dragForce:e.dragForce,gravityPower:e.gravityPower,stiffness:e.stiffiness,gravityDir:u},_=null===(a=e.colliderGroups)||void 0===a?void 0:a.map((t=>{const e=null==d?void 0:d[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e}));l.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);h.addSpringBone(r)}))}))})),e.scene.updateMatrixWorld(),h.setInitState(),h}))}_importJoint(t,e,i,r){const s=new S(t,e,i,r);if(this.jointHelperRoot){const t=new d(s);this.jointHelperRoot.add(t),t.renderOrder=this.jointHelperRoot.renderOrder}return s}_importSphereCollider(t,e){const{offset:i,radius:r}=e,s=new n({offset:i,radius:r}),o=new u(s);if(t.add(o),this.colliderHelperRoot){const t=new h(o);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return o}_importCapsuleCollider(t,e){const{offset:i,radius:r,tail:n}=e,o=new s({offset:i,radius:r,tail:n}),a=new u(o);if(t.add(a),this.colliderHelperRoot){const t=new h(a);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return a}}C.EXTENSION_NAME="VRMC_springBone";export{u as VRMSpringBoneCollider,h as VRMSpringBoneColliderHelper,e as VRMSpringBoneColliderShape,s as VRMSpringBoneColliderShapeCapsule,n as VRMSpringBoneColliderShapeSphere,S as VRMSpringBoneJoint,d as VRMSpringBoneJointHelper,C as VRMSpringBoneLoaderPlugin,I as VRMSpringBoneManager};
***************************************************************************** */function B(t,e,i,r){return new(i||(i=Promise))((function(s,n){function o(t){try{l(r.next(t))}catch(t){n(t)}}function a(t){try{l(r.throw(t))}catch(t){n(t)}}function l(t){var e;t.done?s(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}l((r=r.apply(t,e||[])).next())}))}function R(t,e){const i=[];let r=t;for(;null!==r;)i.unshift(r),r=r.parent;i.forEach((t=>{e(t)}))}function I(t,e){t.children.forEach((t=>{e(t)||I(t,e)}))}class T{constructor(){this._springBones=new Set,this._objectSpringBonesMap=new Map}get springBones(){return this._springBones}get colliderGroups(){const t=new Set;return this._springBones.forEach((e=>{e.colliderGroups.forEach((e=>{t.add(e)}))})),Array.from(t)}get colliders(){const t=new Set;return this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{t.add(e)}))})),Array.from(t)}addSpringBone(t){this._springBones.add(t);let e=this._objectSpringBonesMap.get(t.bone);null==e&&(e=new Set,this._objectSpringBonesMap.set(t.bone,e)),e.add(t)}deleteSpringBone(t){this._springBones.delete(t);this._objectSpringBonesMap.get(t.bone).delete(t)}setInitState(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,t,e,i,(t=>t.reset()))}update(t){const e=new Set,i=new Set,r=new Set;for(const s of this._springBones)this._processSpringBone(s,e,i,r,(e=>e.update(t))),I(s.bone,(t=>{var e,i;return(null!==(i=null===(e=this._objectSpringBonesMap.get(t))||void 0===e?void 0:e.size)&&void 0!==i?i:0)>0||(t.updateWorldMatrix(!1,!1),!1)}))}_processSpringBone(t,e,i,r,s){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating springbones");e.add(t);const n=this._getDependencies(t);for(const t of n)R(t,(t=>{const n=this._objectSpringBonesMap.get(t);if(n)for(const t of n)this._processSpringBone(t,e,i,r,s);else r.has(t)||(t.updateWorldMatrix(!1,!1),r.add(t))}));t.bone.updateMatrix(),t.bone.updateWorldMatrix(!1,!1),s(t),r.add(t.bone),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),t.colliderGroups.forEach((t=>{t.colliders.forEach((t=>{e.add(t)}))})),e}}class C{constructor(t,e){this.parser=t,this.jointHelperRoot=null==e?void 0:e.jointHelperRoot,this.colliderHelperRoot=null==e?void 0:e.colliderHelperRoot}get name(){return C.EXTENSION_NAME}afterRoot(t){return B(this,void 0,void 0,(function*(){t.userData.vrmSpringBoneManager=yield this._import(t)}))}_import(t){return B(this,void 0,void 0,(function*(){const e=yield this._v1Import(t);if(null!=e)return e;const i=yield this._v0Import(t);return null!=i?i:null}))}_v1Import(e){var i,r,s,n,o;return B(this,void 0,void 0,(function*(){const a=e.parser.json;if(!(-1!==(null===(i=a.extensionsUsed)||void 0===i?void 0:i.indexOf(C.EXTENSION_NAME))))return null;const l=new T,h=yield e.parser.getDependencies("node"),d=null===(r=a.extensions)||void 0===r?void 0:r[C.EXTENSION_NAME];if(!d)return null;if("1.0-beta"!==d.specVersion)return null;const c=null===(s=d.colliders)||void 0===s?void 0:s.map(((e,i)=>{var r,s,n,o,a;const l=h[e.node],d=e.shape;if(d.sphere)return this._importSphereCollider(l,{offset:(new t.Vector3).fromArray(null!==(r=d.sphere.offset)&&void 0!==r?r:[0,0,0]),radius:null!==(s=d.sphere.radius)&&void 0!==s?s:0});if(d.capsule)return this._importCapsuleCollider(l,{offset:(new t.Vector3).fromArray(null!==(n=d.capsule.offset)&&void 0!==n?n:[0,0,0]),radius:null!==(o=d.capsule.radius)&&void 0!==o?o:0,tail:(new t.Vector3).fromArray(null!==(a=d.capsule.tail)&&void 0!==a?a:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${i} has no valid shape`)})),u=null===(n=d.colliderGroups)||void 0===n?void 0:n.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==c?void 0:c[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${e} attempted to use a collider #${t} but not found`);return i})),name:t.name}}));return null===(o=d.springs)||void 0===o||o.forEach(((e,i)=>{var r;const s=e.joints,n=null===(r=e.colliderGroups)||void 0===r?void 0:r.map((t=>{const e=null==u?void 0:u[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e})),o=null!=e.center?h[e.center]:void 0;let a;s.forEach((e=>{var i;if(a){const r=a.node,s=h[r],d=e.node,c=h[d],u={hitRadius:a.hitRadius,dragForce:a.dragForce,gravityPower:a.gravityPower,stiffness:a.stiffness,gravityDir:(new t.Vector3).fromArray(null!==(i=a.gravityDir)&&void 0!==i?i:[0,1,0])},p=this._importJoint(s,c,u,n);o&&(p.center=o),l.addSpringBone(p)}a=e}))})),l.setInitState(),l}))}_v0Import(e){var i,r,s;return B(this,void 0,void 0,(function*(){const n=e.parser.json;if(!(-1!==(null===(i=n.extensionsUsed)||void 0===i?void 0:i.indexOf("VRM"))))return null;const o=null===(r=n.extensions)||void 0===r?void 0:r.VRM,a=null==o?void 0:o.secondaryAnimation;if(!a)return null;const l=null==a?void 0:a.boneGroups;if(!l)return null;const h=new T,d=yield e.parser.getDependencies("node"),c=null===(s=a.colliderGroups)||void 0===s?void 0:s.map((e=>{var i;const r=d[e.node];return{colliders:(null!==(i=e.colliders)&&void 0!==i?i:[]).map(((e,i)=>{var s,n,o;const a=new t.Vector3(0,0,0);return e.offset&&a.set(null!==(s=e.offset.x)&&void 0!==s?s:0,null!==(n=e.offset.y)&&void 0!==n?n:0,e.offset.z?-e.offset.z:0),this._importSphereCollider(r,{offset:a,radius:null!==(o=e.radius)&&void 0!==o?o:0})}))}}));return null==l||l.forEach(((e,i)=>{const r=e.bones;r&&r.forEach((r=>{var s,n,o,a;const l=d[r],u=new t.Vector3;e.gravityDir?u.set(null!==(s=e.gravityDir.x)&&void 0!==s?s:0,null!==(n=e.gravityDir.y)&&void 0!==n?n:0,null!==(o=e.gravityDir.z)&&void 0!==o?o:0):u.set(0,-1,0);const p=null!=e.center?d[e.center]:void 0,_={hitRadius:e.hitRadius,dragForce:e.dragForce,gravityPower:e.gravityPower,stiffness:e.stiffiness,gravityDir:u},f=null===(a=e.colliderGroups)||void 0===a?void 0:a.map((t=>{const e=null==c?void 0:c[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e}));l.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,_,f);p&&(r.center=p),h.addSpringBone(r)}))}))})),e.scene.updateMatrixWorld(),h.setInitState(),h}))}_importJoint(t,e,i,r){const s=new S(t,e,i,r);if(this.jointHelperRoot){const t=new c(s);this.jointHelperRoot.add(t),t.renderOrder=this.jointHelperRoot.renderOrder}return s}_importSphereCollider(t,e){const{offset:i,radius:r}=e,s=new n({offset:i,radius:r}),o=new u(s);if(t.add(o),this.colliderHelperRoot){const t=new h(o);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return o}_importCapsuleCollider(t,e){const{offset:i,radius:r,tail:n}=e,o=new s({offset:i,radius:r,tail:n}),a=new u(o);if(t.add(a),this.colliderHelperRoot){const t=new h(a);this.colliderHelperRoot.add(t),t.renderOrder=this.colliderHelperRoot.renderOrder}return a}}C.EXTENSION_NAME="VRMC_springBone";export{u as VRMSpringBoneCollider,h as VRMSpringBoneColliderHelper,e as VRMSpringBoneColliderShape,s as VRMSpringBoneColliderShapeCapsule,n as VRMSpringBoneColliderShapeSphere,S as VRMSpringBoneJoint,c as VRMSpringBoneJointHelper,C as VRMSpringBoneLoaderPlugin,T as VRMSpringBoneManager};
{
"name": "@pixiv/three-vrm-springbone",
"version": "1.0.0-beta.15",
"version": "1.0.0-beta.16",
"description": "Spring bone module for @pixiv/three-vrm",

@@ -44,4 +44,4 @@ "license": "MIT",

"dependencies": {
"@pixiv/types-vrm-0.0": "1.0.0-beta.15",
"@pixiv/types-vrmc-springbone-1.0": "1.0.0-beta.15"
"@pixiv/types-vrm-0.0": "1.0.0-beta.16",
"@pixiv/types-vrmc-springbone-1.0": "1.0.0-beta.16"
},

@@ -55,3 +55,3 @@ "devDependencies": {

},
"gitHead": "3ff3b7ba6ee1c5357e50e361b7552d0e82160cfd"
"gitHead": "5c6c88c108dc8883e4c875dc5312a0d330099ace"
}

@@ -35,7 +35,2 @@ import * as THREE from 'three';

/**
* Next position of child tail, in center unit. Will be used for verlet integration.
* Actually used only in [[update]] and it's kind of temporary variable.
*/
private _nextTail;
/**
* Initial axis of the bone, in local unit.

@@ -45,11 +40,7 @@ */

/**
* Length of the bone in relative space unit. Will be used for normalization in update loop.
* It's same as local unit length unless there are scale transformations in the center space.
* Length of the bone in world unit. Will be used for normalization in update loop.
* It's same as local unit length unless there are scale transformations in the world space.
*/
private _centerSpaceBoneLength;
private _worldSpaceBoneLength;
/**
* Position of this bone in relative space, kind of a temporary variable.
*/
private _centerSpacePosition;
/**
* This springbone will be calculated based on the space relative from this object.

@@ -61,7 +52,2 @@ * If this is `null`, springbone will be calculated in world space.

/**
* Rotation of parent bone, in world unit.
* We should update this constantly in [[update]].
*/
private _parentWorldRotation;
/**
* Initial state of the local matrix of the bone.

@@ -68,0 +54,0 @@ */

@@ -35,7 +35,2 @@ import * as THREE from 'three';

/**
* Next position of child tail, in center unit. Will be used for verlet integration.
* Actually used only in [[update]] and it's kind of temporary variable.
*/
private _nextTail;
/**
* Initial axis of the bone, in local unit.

@@ -45,11 +40,7 @@ */

/**
* Length of the bone in relative space unit. Will be used for normalization in update loop.
* It's same as local unit length unless there are scale transformations in the center space.
* Length of the bone in world unit. Will be used for normalization in update loop.
* It's same as local unit length unless there are scale transformations in the world space.
*/
private _centerSpaceBoneLength;
private _worldSpaceBoneLength;
/**
* Position of this bone in relative space, kind of a temporary variable.
*/
private _centerSpacePosition;
/**
* This springbone will be calculated based on the space relative from this object.

@@ -62,7 +53,2 @@ * If this is `null`, springbone will be calculated in world space.

/**
* Rotation of parent bone, in world unit.
* We should update this constantly in [[update]].
*/
private _parentWorldRotation;
/**
* Initial state of the local matrix of the bone.

@@ -69,0 +55,0 @@ */

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc