Socket
Socket
Sign inDemoInstall

@pixiv/three-vrm-springbone

Package Overview
Dependencies
Maintainers
3
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.0 to 1.0.0-beta.1

LICENSE

2

lib/three-vrm-springbone.min.js

@@ -16,2 +16,2 @@ /*! (c) 2020 pixiv Inc. - https://github.com/pixiv/three-vrm/blob/master/LICENSE */

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 I(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 C{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;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.reset()))}update(t){const e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,e,i,(e=>e.update(t))),V(r.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){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating constraints");e.add(t);const s=this._getDependencies(t);for(const t of s)I(t,(t=>{const s=this._objectSpringBonesMap.get(t);if(s)for(const t of s)this._processSpringBone(t,e,i,r)}));r(t),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class W{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 W.EXTENSION_NAME}afterRoot(t){return T(this,void 0,void 0,(function*(){null==t.userData.promiseVrmSpringBoneManager&&(t.userData.promiseVrmSpringBoneManager=(()=>T(this,void 0,void 0,(function*(){return yield this._import(t)})))(),t.userData.vrmSpringBoneManager=yield t.userData.promiseVrmSpringBoneManager),yield t.userData.promiseVrmSpringBoneManager}))}_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;return T(this,void 0,void 0,(function*(){if(!(-1!==t.parser.json.extensionsUsed.indexOf(W.EXTENSION_NAME)))return null;const o=new C,a=yield t.parser.getDependencies("node"),l=null===(e=t.parser.json.extensions)||void 0===e?void 0:e[W.EXTENSION_NAME];if(!l)return null;if("1.0-draft"!==l.specVersion)return null;const h=null===(i=l.colliders)||void 0===i?void 0:i.map(((t,e)=>{var i,s,n,o,l;const h=a[t.node],c=t.shape;if(c.sphere)return this._importSphereCollider(h,{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(h,{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!==(l=c.capsule.tail)&&void 0!==l?l:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${e} has no valid shape`)})),c=null===(s=l.colliderGroups)||void 0===s?void 0:s.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==h?void 0:h[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===(n=l.springs)||void 0===n||n.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==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}));let l;s.forEach((t=>{var e;if(l){const i=l.node,s=a[i],h=t.node,c=a[h],d={hitRadius:l.hitRadius,dragForce:l.dragForce,gravityPower:l.gravityPower,stiffness:l.stiffness,gravityDir:(new r.Vector3).fromArray(null!==(e=l.gravityDir)&&void 0!==e?e:[0,1,0])},u=this._importJoint(s,c,d,n);o.addSpringBone(u)}l=t}))})),t.scene.updateMatrixWorld(),o.setInitState(),o}))}_v0Import(t){var e,i;return T(this,void 0,void 0,(function*(){if(!(-1!==t.parser.json.extensionsUsed.indexOf("VRM")))return null;const s=null===(e=t.parser.json.extensions)||void 0===e?void 0:e.VRM,n=null==s?void 0:s.secondaryAnimation;if(!n)return null;const o=null==n?void 0:n.boneGroups;if(!o)return null;const a=new C,l=yield t.parser.getDependencies("node"),h=null===(i=n.colliderGroups)||void 0===i?void 0:i.map((t=>{var e;const i=l[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==o||o.forEach(((t,e)=>{const i=t.bones;i&&i.forEach((i=>{var s,n,o,c;const d=l[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===(c=t.colliderGroups)||void 0===c?void 0:c.map((t=>{const i=null==h?void 0:h[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i}));d.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);a.addSpringBone(r)}))}))})),t.scene.updateMatrixWorld(),a.setInitState(),a}))}_importJoint(t,e,i,r){const s=new R(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}}W.EXTENSION_NAME="VRMC_springBone",t.VRMSpringBoneCollider=f,t.VRMSpringBoneColliderHelper=u,t.VRMSpringBoneColliderShape=s,t.VRMSpringBoneColliderShapeCapsule=a,t.VRMSpringBoneColliderShapeSphere=l,t.VRMSpringBoneJoint=R,t.VRMSpringBoneJointHelper=_,t.VRMSpringBoneLoaderPlugin=W,t.VRMSpringBoneManager=C,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 I(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 C{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;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.reset()))}update(t){const e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,e,i,(e=>e.update(t))),V(r.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){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating constraints");e.add(t);const s=this._getDependencies(t);for(const t of s)I(t,(t=>{const s=this._objectSpringBonesMap.get(t);if(s)for(const t of s)this._processSpringBone(t,e,i,r)}));r(t),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class W{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 W.EXTENSION_NAME}afterRoot(t){return T(this,void 0,void 0,(function*(){null==t.userData.promiseVrmSpringBoneManager&&(t.userData.promiseVrmSpringBoneManager=(()=>T(this,void 0,void 0,(function*(){return yield this._import(t)})))(),t.userData.vrmSpringBoneManager=yield t.userData.promiseVrmSpringBoneManager),yield t.userData.promiseVrmSpringBoneManager}))}_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;return T(this,void 0,void 0,(function*(){if(!(-1!==t.parser.json.extensionsUsed.indexOf(W.EXTENSION_NAME)))return null;const o=new C,a=yield t.parser.getDependencies("node"),l=null===(e=t.parser.json.extensions)||void 0===e?void 0:e[W.EXTENSION_NAME];if(!l)return null;if("1.0-beta"!==l.specVersion)return null;const h=null===(i=l.colliders)||void 0===i?void 0:i.map(((t,e)=>{var i,s,n,o,l;const h=a[t.node],c=t.shape;if(c.sphere)return this._importSphereCollider(h,{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(h,{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!==(l=c.capsule.tail)&&void 0!==l?l:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${e} has no valid shape`)})),c=null===(s=l.colliderGroups)||void 0===s?void 0:s.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==h?void 0:h[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===(n=l.springs)||void 0===n||n.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==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}));let l;s.forEach((t=>{var e;if(l){const i=l.node,s=a[i],h=t.node,c=a[h],d={hitRadius:l.hitRadius,dragForce:l.dragForce,gravityPower:l.gravityPower,stiffness:l.stiffness,gravityDir:(new r.Vector3).fromArray(null!==(e=l.gravityDir)&&void 0!==e?e:[0,1,0])},u=this._importJoint(s,c,d,n);o.addSpringBone(u)}l=t}))})),t.scene.updateMatrixWorld(),o.setInitState(),o}))}_v0Import(t){var e,i;return T(this,void 0,void 0,(function*(){if(!(-1!==t.parser.json.extensionsUsed.indexOf("VRM")))return null;const s=null===(e=t.parser.json.extensions)||void 0===e?void 0:e.VRM,n=null==s?void 0:s.secondaryAnimation;if(!n)return null;const o=null==n?void 0:n.boneGroups;if(!o)return null;const a=new C,l=yield t.parser.getDependencies("node"),h=null===(i=n.colliderGroups)||void 0===i?void 0:i.map((t=>{var e;const i=l[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==o||o.forEach(((t,e)=>{const i=t.bones;i&&i.forEach((i=>{var s,n,o,c;const d=l[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===(c=t.colliderGroups)||void 0===c?void 0:c.map((t=>{const i=null==h?void 0:h[t];if(null==i)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${e} attempted to use a colliderGroup ${t} but not found`);return i}));d.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);a.addSpringBone(r)}))}))})),t.scene.updateMatrixWorld(),a.setInitState(),a}))}_importJoint(t,e,i,r){const s=new R(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}}W.EXTENSION_NAME="VRMC_springBone",t.VRMSpringBoneCollider=f,t.VRMSpringBoneColliderHelper=u,t.VRMSpringBoneColliderShape=s,t.VRMSpringBoneColliderShapeCapsule=a,t.VRMSpringBoneColliderShapeSphere=l,t.VRMSpringBoneJoint=R,t.VRMSpringBoneJointHelper=_,t.VRMSpringBoneLoaderPlugin=W,t.VRMSpringBoneManager=C,Object.defineProperty(t,"__esModule",{value:!0}),Object.assign(e,t)}));
/*! (c) 2020 pixiv Inc. - https://github.com/pixiv/three-vrm/blob/master/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:1}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:1}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;class x{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.getInverse(this.matrix),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const g=Object.freeze(new t.Matrix4),v=Object.freeze(new t.Quaternion),y=new t.Vector3,m=new t.Vector3,M=new t.Quaternion,w=new t.Matrix4,P=new t.Matrix4;class b{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(w),this._currentTail.applyMatrix4(w),this._prevTail.applyMatrix4(w),this._nextTail.applyMatrix4(w),(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 x(this._center.matrixWorld))),this._getMatrixWorldToCenter(w),this._currentTail.applyMatrix4(w),this._prevTail.applyMatrix4(w),this._nextTail.applyMatrix4(w),w.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(w),this._centerSpaceBoneLength=y.copy(this._initialLocalChildPosition).applyMatrix4(w).sub(this._centerSpacePosition).length()}get initialLocalChildPosition(){return this._initialLocalChildPosition}setInitState(){this.bone.updateMatrix(),this.bone.updateWorldMatrix(!1,!1),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=y.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._getParentMatrixWorld(),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.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(),this.bone.matrix),this.bone.parent?(e=this.bone.parent,i=this._parentWorldRotation,e.matrixWorld.decompose(p,i,_)):this._parentWorldRotation.copy(v),this._getMatrixWorldToCenter(w),w.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(w),this._getMatrixWorldToCenter(P),P.multiply(this._getParentMatrixWorld());const r=this.settings.stiffness*t,s=m.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t);this._nextTail.copy(this._currentTail).add(y.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(y.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(P).sub(this._centerSpacePosition).normalize().multiplyScalar(r)).add(s),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=((o=w.copy(P.multiply(this._initialLocalMatrix))).invert?o.invert():o.getInverse(f.copy(o)),o);var o;const a=M.setFromUnitVectors(this._boneAxis,y.copy(this._nextTail).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(a),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(),this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{this._getMatrixWorldToCenter(w),w.multiply(e.matrixWorld);const i=e.shape.calculateCollision(w,t,this.settings.hitRadius,y);i<0&&(t.add(y.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}_getParentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:g}}
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:1}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:1}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;class x{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.getInverse(this.matrix),this._shouldUpdateInverse=!1),this._inverseCache}revert(){this.matrix.elements=this._originalElements}}const g=Object.freeze(new t.Matrix4),v=Object.freeze(new t.Quaternion),y=new t.Vector3,m=new t.Vector3,M=new t.Quaternion,w=new t.Matrix4,b=new t.Matrix4;class P{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(w),this._currentTail.applyMatrix4(w),this._prevTail.applyMatrix4(w),this._nextTail.applyMatrix4(w),(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 x(this._center.matrixWorld))),this._getMatrixWorldToCenter(w),this._currentTail.applyMatrix4(w),this._prevTail.applyMatrix4(w),this._nextTail.applyMatrix4(w),w.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(w),this._centerSpaceBoneLength=y.copy(this._initialLocalChildPosition).applyMatrix4(w).sub(this._centerSpacePosition).length()}get initialLocalChildPosition(){return this._initialLocalChildPosition}setInitState(){this.bone.updateMatrix(),this.bone.updateWorldMatrix(!1,!1),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=y.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._getParentMatrixWorld(),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.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(),this.bone.matrix),this.bone.parent?(e=this.bone.parent,i=this._parentWorldRotation,e.matrixWorld.decompose(p,i,_)):this._parentWorldRotation.copy(v),this._getMatrixWorldToCenter(w),w.multiply(this.bone.matrixWorld),this._centerSpacePosition.setFromMatrixPosition(w),this._getMatrixWorldToCenter(b),b.multiply(this._getParentMatrixWorld());const r=this.settings.stiffness*t,s=m.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower*t);this._nextTail.copy(this._currentTail).add(y.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1-this.settings.dragForce)).add(y.copy(this._boneAxis).applyMatrix4(this._initialLocalMatrix).applyMatrix4(b).sub(this._centerSpacePosition).normalize().multiplyScalar(r)).add(s),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=((o=w.copy(b.multiply(this._initialLocalMatrix))).invert?o.invert():o.getInverse(f.copy(o)),o);var o;const a=M.setFromUnitVectors(this._boneAxis,y.copy(this._nextTail).applyMatrix4(n).normalize());this.bone.quaternion.copy(this._initialLocalRotation).multiply(a),this.bone.updateMatrix(),this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(),this.bone.matrix)}_collision(t){this.colliderGroups.forEach((e=>{e.colliders.forEach((e=>{this._getMatrixWorldToCenter(w),w.multiply(e.matrixWorld);const i=e.shape.calculateCollision(w,t,this.settings.hitRadius,y);i<0&&(t.add(y.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}_getParentMatrixWorld(){return this.bone.parent?this.bone.parent.matrixWorld:g}}
/*! *****************************************************************************

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

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */function S(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 T(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 R{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;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.reset()))}update(t){const e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,e,i,(e=>e.update(t))),B(r.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){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating constraints");e.add(t);const s=this._getDependencies(t);for(const t of s)T(t,(t=>{const s=this._objectSpringBonesMap.get(t);if(s)for(const t of s)this._processSpringBone(t,e,i,r)}));r(t),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class I{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 I.EXTENSION_NAME}afterRoot(t){return S(this,void 0,void 0,(function*(){null==t.userData.promiseVrmSpringBoneManager&&(t.userData.promiseVrmSpringBoneManager=(()=>S(this,void 0,void 0,(function*(){return yield this._import(t)})))(),t.userData.vrmSpringBoneManager=yield t.userData.promiseVrmSpringBoneManager),yield t.userData.promiseVrmSpringBoneManager}))}_import(t){return S(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;return S(this,void 0,void 0,(function*(){if(!(-1!==e.parser.json.extensionsUsed.indexOf(I.EXTENSION_NAME)))return null;const o=new R,a=yield e.parser.getDependencies("node"),l=null===(i=e.parser.json.extensions)||void 0===i?void 0:i[I.EXTENSION_NAME];if(!l)return null;if("1.0-draft"!==l.specVersion)return null;const h=null===(r=l.colliders)||void 0===r?void 0:r.map(((e,i)=>{var r,s,n,o,l;const h=a[e.node],c=e.shape;if(c.sphere)return this._importSphereCollider(h,{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(h,{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!==(l=c.capsule.tail)&&void 0!==l?l:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${i} has no valid shape`)})),c=null===(s=l.colliderGroups)||void 0===s?void 0:s.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==h?void 0:h[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===(n=l.springs)||void 0===n||n.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==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}));let l;s.forEach((e=>{var i;if(l){const r=l.node,s=a[r],h=e.node,c=a[h],d={hitRadius:l.hitRadius,dragForce:l.dragForce,gravityPower:l.gravityPower,stiffness:l.stiffness,gravityDir:(new t.Vector3).fromArray(null!==(i=l.gravityDir)&&void 0!==i?i:[0,1,0])},u=this._importJoint(s,c,d,n);o.addSpringBone(u)}l=e}))})),e.scene.updateMatrixWorld(),o.setInitState(),o}))}_v0Import(e){var i,r;return S(this,void 0,void 0,(function*(){if(!(-1!==e.parser.json.extensionsUsed.indexOf("VRM")))return null;const s=null===(i=e.parser.json.extensions)||void 0===i?void 0:i.VRM,n=null==s?void 0:s.secondaryAnimation;if(!n)return null;const o=null==n?void 0:n.boneGroups;if(!o)return null;const a=new R,l=yield e.parser.getDependencies("node"),h=null===(r=n.colliderGroups)||void 0===r?void 0:r.map((e=>{var i;const r=l[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==o||o.forEach(((e,i)=>{const r=e.bones;r&&r.forEach((r=>{var s,n,o,c;const d=l[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===(c=e.colliderGroups)||void 0===c?void 0:c.map((t=>{const e=null==h?void 0:h[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e}));d.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);a.addSpringBone(r)}))}))})),e.scene.updateMatrixWorld(),a.setInitState(),a}))}_importJoint(t,e,i,r){const s=new b(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}}I.EXTENSION_NAME="VRMC_springBone";export{u as VRMSpringBoneCollider,h as VRMSpringBoneColliderHelper,e as VRMSpringBoneColliderShape,s as VRMSpringBoneColliderShapeCapsule,n as VRMSpringBoneColliderShapeSphere,b as VRMSpringBoneJoint,d as VRMSpringBoneJointHelper,I as VRMSpringBoneLoaderPlugin,R as VRMSpringBoneManager};
***************************************************************************** */function S(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 T(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 R{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;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.setInitState()))}reset(){const t=new Set,e=new Set;for(const i of this._springBones)this._processSpringBone(i,t,e,(t=>t.reset()))}update(t){const e=new Set,i=new Set;for(const r of this._springBones)this._processSpringBone(r,e,i,(e=>e.update(t))),B(r.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){if(i.has(t))return;if(e.has(t))throw new Error("VRMSpringBoneManager: Circular dependency detected while updating constraints");e.add(t);const s=this._getDependencies(t);for(const t of s)T(t,(t=>{const s=this._objectSpringBonesMap.get(t);if(s)for(const t of s)this._processSpringBone(t,e,i,r)}));r(t),i.add(t)}_getDependencies(t){const e=new Set,i=t.bone.parent;return i&&e.add(i),e}}class I{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 I.EXTENSION_NAME}afterRoot(t){return S(this,void 0,void 0,(function*(){null==t.userData.promiseVrmSpringBoneManager&&(t.userData.promiseVrmSpringBoneManager=(()=>S(this,void 0,void 0,(function*(){return yield this._import(t)})))(),t.userData.vrmSpringBoneManager=yield t.userData.promiseVrmSpringBoneManager),yield t.userData.promiseVrmSpringBoneManager}))}_import(t){return S(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;return S(this,void 0,void 0,(function*(){if(!(-1!==e.parser.json.extensionsUsed.indexOf(I.EXTENSION_NAME)))return null;const o=new R,a=yield e.parser.getDependencies("node"),l=null===(i=e.parser.json.extensions)||void 0===i?void 0:i[I.EXTENSION_NAME];if(!l)return null;if("1.0-beta"!==l.specVersion)return null;const h=null===(r=l.colliders)||void 0===r?void 0:r.map(((e,i)=>{var r,s,n,o,l;const h=a[e.node],c=e.shape;if(c.sphere)return this._importSphereCollider(h,{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(h,{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!==(l=c.capsule.tail)&&void 0!==l?l:[0,0,0])});throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${i} has no valid shape`)})),c=null===(s=l.colliderGroups)||void 0===s?void 0:s.map(((t,e)=>{var i;return{colliders:(null!==(i=t.colliders)&&void 0!==i?i:[]).map((t=>{const i=null==h?void 0:h[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===(n=l.springs)||void 0===n||n.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==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}));let l;s.forEach((e=>{var i;if(l){const r=l.node,s=a[r],h=e.node,c=a[h],d={hitRadius:l.hitRadius,dragForce:l.dragForce,gravityPower:l.gravityPower,stiffness:l.stiffness,gravityDir:(new t.Vector3).fromArray(null!==(i=l.gravityDir)&&void 0!==i?i:[0,1,0])},u=this._importJoint(s,c,d,n);o.addSpringBone(u)}l=e}))})),e.scene.updateMatrixWorld(),o.setInitState(),o}))}_v0Import(e){var i,r;return S(this,void 0,void 0,(function*(){if(!(-1!==e.parser.json.extensionsUsed.indexOf("VRM")))return null;const s=null===(i=e.parser.json.extensions)||void 0===i?void 0:i.VRM,n=null==s?void 0:s.secondaryAnimation;if(!n)return null;const o=null==n?void 0:n.boneGroups;if(!o)return null;const a=new R,l=yield e.parser.getDependencies("node"),h=null===(r=n.colliderGroups)||void 0===r?void 0:r.map((e=>{var i;const r=l[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==o||o.forEach(((e,i)=>{const r=e.bones;r&&r.forEach((r=>{var s,n,o,c;const d=l[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===(c=e.colliderGroups)||void 0===c?void 0:c.map((t=>{const e=null==h?void 0:h[t];if(null==e)throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${i} attempted to use a colliderGroup ${t} but not found`);return e}));d.traverse((t=>{var e;const i=null!==(e=t.children[0])&&void 0!==e?e:null,r=this._importJoint(t,i,p,_);a.addSpringBone(r)}))}))})),e.scene.updateMatrixWorld(),a.setInitState(),a}))}_importJoint(t,e,i,r){const s=new P(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}}I.EXTENSION_NAME="VRMC_springBone";export{u as VRMSpringBoneCollider,h as VRMSpringBoneColliderHelper,e as VRMSpringBoneColliderShape,s as VRMSpringBoneColliderShapeCapsule,n as VRMSpringBoneColliderShapeSphere,P as VRMSpringBoneJoint,d as VRMSpringBoneJointHelper,I as VRMSpringBoneLoaderPlugin,R as VRMSpringBoneManager};
{
"name": "@pixiv/three-vrm-springbone",
"version": "1.0.0-beta.0",
"version": "1.0.0-beta.1",
"description": "Spring bone module for @pixiv/three-vrm",

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

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

@@ -56,3 +56,4 @@ "devDependencies": {

"three": "^0.126.1"
}
},
"gitHead": "5c8307e43c5dcc7fed2a41a2c8ae866685a071f4"
}

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