@pixiv/three-vrm-springbone 3.0.0 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * @pixiv/three-vrm-springbone v3.0.0
2
+ * @pixiv/three-vrm-springbone v3.1.0
3
3
  * Spring bone module for @pixiv/three-vrm
4
4
  *
5
5
  * Copyright (c) 2019-2024 pixiv Inc.
@@ -28,7 +28,7 @@ var __async = (__this, __arguments, generator) => {
28
28
  };
29
29
 
30
30
  // src/helpers/VRMSpringBoneColliderHelper.ts
31
- import * as THREE5 from "three";
31
+ import * as THREE7 from "three";
32
32
 
33
33
  // src/VRMSpringBoneColliderShapeCapsule.ts
34
34
  import * as THREE from "three";
@@ -45,11 +45,12 @@ var VRMSpringBoneColliderShapeCapsule = class extends VRMSpringBoneColliderShape
45
45
  return "capsule";
46
46
  }
47
47
  constructor(params) {
48
- var _a, _b, _c;
48
+ var _a, _b, _c, _d;
49
49
  super();
50
50
  this.offset = (_a = params == null ? void 0 : params.offset) != null ? _a : new THREE.Vector3(0, 0, 0);
51
51
  this.tail = (_b = params == null ? void 0 : params.tail) != null ? _b : new THREE.Vector3(0, 0, 0);
52
52
  this.radius = (_c = params == null ? void 0 : params.radius) != null ? _c : 0;
53
+ this.inside = (_d = params == null ? void 0 : params.inside) != null ? _d : false;
53
54
  }
54
55
  calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
55
56
  _v3A.copy(this.offset).applyMatrix4(colliderMatrix);
@@ -65,49 +66,79 @@ var VRMSpringBoneColliderShapeCapsule = class extends VRMSpringBoneColliderShape
65
66
  _v3B.multiplyScalar(dot / lengthSqCapsule);
66
67
  target.sub(_v3B);
67
68
  }
68
- const radius = objectRadius + this.radius;
69
- const distance = target.length() - radius;
69
+ const distance = this.inside ? this.radius - objectRadius - target.length() : target.length() - objectRadius - this.radius;
70
70
  target.normalize();
71
+ if (this.inside) {
72
+ target.negate();
73
+ }
71
74
  return distance;
72
75
  }
73
76
  };
74
77
 
75
- // src/VRMSpringBoneColliderShapeSphere.ts
78
+ // src/VRMSpringBoneColliderShapePlane.ts
76
79
  import * as THREE2 from "three";
77
- var VRMSpringBoneColliderShapeSphere = class extends VRMSpringBoneColliderShape {
80
+ var _v3A2 = new THREE2.Vector3();
81
+ var _mat3A = new THREE2.Matrix3();
82
+ var VRMSpringBoneColliderShapePlane = class extends VRMSpringBoneColliderShape {
78
83
  get type() {
79
- return "sphere";
84
+ return "plane";
80
85
  }
81
86
  constructor(params) {
82
87
  var _a, _b;
83
88
  super();
84
89
  this.offset = (_a = params == null ? void 0 : params.offset) != null ? _a : new THREE2.Vector3(0, 0, 0);
90
+ this.normal = (_b = params == null ? void 0 : params.normal) != null ? _b : new THREE2.Vector3(0, 0, 1);
91
+ }
92
+ calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
93
+ target.copy(this.offset).applyMatrix4(colliderMatrix);
94
+ target.negate().add(objectPosition);
95
+ _mat3A.getNormalMatrix(colliderMatrix);
96
+ _v3A2.copy(this.normal).applyNormalMatrix(_mat3A).normalize();
97
+ const distance = target.dot(_v3A2) - objectRadius;
98
+ target.copy(_v3A2);
99
+ return distance;
100
+ }
101
+ };
102
+
103
+ // src/VRMSpringBoneColliderShapeSphere.ts
104
+ import * as THREE3 from "three";
105
+ var VRMSpringBoneColliderShapeSphere = class extends VRMSpringBoneColliderShape {
106
+ get type() {
107
+ return "sphere";
108
+ }
109
+ constructor(params) {
110
+ var _a, _b, _c;
111
+ super();
112
+ this.offset = (_a = params == null ? void 0 : params.offset) != null ? _a : new THREE3.Vector3(0, 0, 0);
85
113
  this.radius = (_b = params == null ? void 0 : params.radius) != null ? _b : 0;
114
+ this.inside = (_c = params == null ? void 0 : params.inside) != null ? _c : false;
86
115
  }
87
116
  calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
88
117
  target.copy(this.offset).applyMatrix4(colliderMatrix);
89
118
  target.negate().add(objectPosition);
90
- const radius = objectRadius + this.radius;
91
- const distance = target.length() - radius;
119
+ const distance = this.inside ? this.radius - objectRadius - target.length() : target.length() - objectRadius - this.radius;
92
120
  target.normalize();
121
+ if (this.inside) {
122
+ target.negate();
123
+ }
93
124
  return distance;
94
125
  }
95
126
  };
96
127
 
97
128
  // src/helpers/utils/ColliderShapeCapsuleBufferGeometry.ts
98
- import * as THREE3 from "three";
99
- var _v3A2 = new THREE3.Vector3();
100
- var ColliderShapeCapsuleBufferGeometry = class extends THREE3.BufferGeometry {
129
+ import * as THREE4 from "three";
130
+ var _v3A3 = new THREE4.Vector3();
131
+ var ColliderShapeCapsuleBufferGeometry = class extends THREE4.BufferGeometry {
101
132
  constructor(shape) {
102
133
  super();
103
134
  this.worldScale = 1;
104
135
  this._currentRadius = 0;
105
- this._currentOffset = new THREE3.Vector3();
106
- this._currentTail = new THREE3.Vector3();
136
+ this._currentOffset = new THREE4.Vector3();
137
+ this._currentTail = new THREE4.Vector3();
107
138
  this._shape = shape;
108
- this._attrPos = new THREE3.BufferAttribute(new Float32Array(396), 3);
139
+ this._attrPos = new THREE4.BufferAttribute(new Float32Array(396), 3);
109
140
  this.setAttribute("position", this._attrPos);
110
- this._attrIndex = new THREE3.BufferAttribute(new Uint16Array(264), 1);
141
+ this._attrIndex = new THREE4.BufferAttribute(new Uint16Array(264), 1);
111
142
  this.setIndex(this._attrIndex);
112
143
  this._buildIndex();
113
144
  this.update();
@@ -123,7 +154,7 @@ var ColliderShapeCapsuleBufferGeometry = class extends THREE3.BufferGeometry {
123
154
  this._currentOffset.copy(this._shape.offset);
124
155
  shouldUpdateGeometry = true;
125
156
  }
126
- const tail = _v3A2.copy(this._shape.tail).divideScalar(this.worldScale);
157
+ const tail = _v3A3.copy(this._shape.tail).divideScalar(this.worldScale);
127
158
  if (this._currentTail.distanceToSquared(tail) > 1e-10) {
128
159
  this._currentTail.copy(tail);
129
160
  shouldUpdateGeometry = true;
@@ -133,8 +164,8 @@ var ColliderShapeCapsuleBufferGeometry = class extends THREE3.BufferGeometry {
133
164
  }
134
165
  }
135
166
  _buildPosition() {
136
- _v3A2.copy(this._currentTail).sub(this._currentOffset);
137
- const l = _v3A2.length() / this._currentRadius;
167
+ _v3A3.copy(this._currentTail).sub(this._currentOffset);
168
+ const l = _v3A3.length() / this._currentRadius;
138
169
  for (let i = 0; i <= 16; i++) {
139
170
  const t = i / 16 * Math.PI;
140
171
  this._attrPos.setXYZ(i, -Math.sin(t), -Math.cos(t), 0);
@@ -147,8 +178,8 @@ var ColliderShapeCapsuleBufferGeometry = class extends THREE3.BufferGeometry {
147
178
  this._attrPos.setXYZ(68 + i, 0, Math.sin(t), Math.cos(t));
148
179
  this._attrPos.setXYZ(100 + i, l, Math.sin(t), Math.cos(t));
149
180
  }
150
- const theta = Math.atan2(_v3A2.y, Math.sqrt(_v3A2.x * _v3A2.x + _v3A2.z * _v3A2.z));
151
- const phi = -Math.atan2(_v3A2.z, _v3A2.x);
181
+ const theta = Math.atan2(_v3A3.y, Math.sqrt(_v3A3.x * _v3A3.x + _v3A3.z * _v3A3.z));
182
+ const phi = -Math.atan2(_v3A3.z, _v3A3.x);
152
183
  this.rotateZ(theta);
153
184
  this.rotateY(phi);
154
185
  this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
@@ -170,18 +201,69 @@ var ColliderShapeCapsuleBufferGeometry = class extends THREE3.BufferGeometry {
170
201
  }
171
202
  };
172
203
 
204
+ // src/helpers/utils/ColliderShapePlaneBufferGeometry.ts
205
+ import * as THREE5 from "three";
206
+ var ColliderShapePlaneBufferGeometry = class extends THREE5.BufferGeometry {
207
+ constructor(shape) {
208
+ super();
209
+ this.worldScale = 1;
210
+ this._currentOffset = new THREE5.Vector3();
211
+ this._currentNormal = new THREE5.Vector3();
212
+ this._shape = shape;
213
+ this._attrPos = new THREE5.BufferAttribute(new Float32Array(6 * 3), 3);
214
+ this.setAttribute("position", this._attrPos);
215
+ this._attrIndex = new THREE5.BufferAttribute(new Uint16Array(10), 1);
216
+ this.setIndex(this._attrIndex);
217
+ this._buildIndex();
218
+ this.update();
219
+ }
220
+ update() {
221
+ let shouldUpdateGeometry = false;
222
+ if (!this._currentOffset.equals(this._shape.offset)) {
223
+ this._currentOffset.copy(this._shape.offset);
224
+ shouldUpdateGeometry = true;
225
+ }
226
+ if (!this._currentNormal.equals(this._shape.normal)) {
227
+ this._currentNormal.copy(this._shape.normal);
228
+ shouldUpdateGeometry = true;
229
+ }
230
+ if (shouldUpdateGeometry) {
231
+ this._buildPosition();
232
+ }
233
+ }
234
+ _buildPosition() {
235
+ this._attrPos.setXYZ(0, -0.5, -0.5, 0);
236
+ this._attrPos.setXYZ(1, 0.5, -0.5, 0);
237
+ this._attrPos.setXYZ(2, 0.5, 0.5, 0);
238
+ this._attrPos.setXYZ(3, -0.5, 0.5, 0);
239
+ this._attrPos.setXYZ(4, 0, 0, 0);
240
+ this._attrPos.setXYZ(5, 0, 0, 0.25);
241
+ this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);
242
+ this.lookAt(this._currentNormal);
243
+ this._attrPos.needsUpdate = true;
244
+ }
245
+ _buildIndex() {
246
+ this._attrIndex.setXY(0, 0, 1);
247
+ this._attrIndex.setXY(2, 1, 2);
248
+ this._attrIndex.setXY(4, 2, 3);
249
+ this._attrIndex.setXY(6, 3, 0);
250
+ this._attrIndex.setXY(8, 4, 5);
251
+ this._attrIndex.needsUpdate = true;
252
+ }
253
+ };
254
+
173
255
  // src/helpers/utils/ColliderShapeSphereBufferGeometry.ts
174
- import * as THREE4 from "three";
175
- var ColliderShapeSphereBufferGeometry = class extends THREE4.BufferGeometry {
256
+ import * as THREE6 from "three";
257
+ var ColliderShapeSphereBufferGeometry = class extends THREE6.BufferGeometry {
176
258
  constructor(shape) {
177
259
  super();
178
260
  this.worldScale = 1;
179
261
  this._currentRadius = 0;
180
- this._currentOffset = new THREE4.Vector3();
262
+ this._currentOffset = new THREE6.Vector3();
181
263
  this._shape = shape;
182
- this._attrPos = new THREE4.BufferAttribute(new Float32Array(32 * 3 * 3), 3);
264
+ this._attrPos = new THREE6.BufferAttribute(new Float32Array(32 * 3 * 3), 3);
183
265
  this.setAttribute("position", this._attrPos);
184
- this._attrIndex = new THREE4.BufferAttribute(new Uint16Array(64 * 3), 1);
266
+ this._attrIndex = new THREE6.BufferAttribute(new Uint16Array(64 * 3), 1);
185
267
  this.setIndex(this._attrIndex);
186
268
  this._buildIndex();
187
269
  this.update();
@@ -224,8 +306,8 @@ var ColliderShapeSphereBufferGeometry = class extends THREE4.BufferGeometry {
224
306
  };
225
307
 
226
308
  // src/helpers/VRMSpringBoneColliderHelper.ts
227
- var _v3A3 = new THREE5.Vector3();
228
- var VRMSpringBoneColliderHelper = class extends THREE5.Group {
309
+ var _v3A4 = new THREE7.Vector3();
310
+ var VRMSpringBoneColliderHelper = class extends THREE7.Group {
229
311
  constructor(collider) {
230
312
  super();
231
313
  this.matrixAutoUpdate = false;
@@ -234,15 +316,17 @@ var VRMSpringBoneColliderHelper = class extends THREE5.Group {
234
316
  this._geometry = new ColliderShapeSphereBufferGeometry(this.collider.shape);
235
317
  } else if (this.collider.shape instanceof VRMSpringBoneColliderShapeCapsule) {
236
318
  this._geometry = new ColliderShapeCapsuleBufferGeometry(this.collider.shape);
319
+ } else if (this.collider.shape instanceof VRMSpringBoneColliderShapePlane) {
320
+ this._geometry = new ColliderShapePlaneBufferGeometry(this.collider.shape);
237
321
  } else {
238
322
  throw new Error("VRMSpringBoneColliderHelper: Unknown collider shape type detected");
239
323
  }
240
- const material = new THREE5.LineBasicMaterial({
324
+ const material = new THREE7.LineBasicMaterial({
241
325
  color: 16711935,
242
326
  depthTest: false,
243
327
  depthWrite: false
244
328
  });
245
- this._line = new THREE5.LineSegments(this._geometry, material);
329
+ this._line = new THREE7.LineSegments(this._geometry, material);
246
330
  this.add(this._line);
247
331
  }
248
332
  dispose() {
@@ -252,27 +336,27 @@ var VRMSpringBoneColliderHelper = class extends THREE5.Group {
252
336
  this.collider.updateWorldMatrix(true, false);
253
337
  this.matrix.copy(this.collider.matrixWorld);
254
338
  const matrixWorldElements = this.matrix.elements;
255
- this._geometry.worldScale = _v3A3.set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2]).length();
339
+ this._geometry.worldScale = _v3A4.set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2]).length();
256
340
  this._geometry.update();
257
341
  super.updateMatrixWorld(force);
258
342
  }
259
343
  };
260
344
 
261
345
  // src/helpers/VRMSpringBoneJointHelper.ts
262
- import * as THREE7 from "three";
346
+ import * as THREE9 from "three";
263
347
 
264
348
  // src/helpers/utils/SpringBoneBufferGeometry.ts
265
- import * as THREE6 from "three";
266
- var SpringBoneBufferGeometry = class extends THREE6.BufferGeometry {
349
+ import * as THREE8 from "three";
350
+ var SpringBoneBufferGeometry = class extends THREE8.BufferGeometry {
267
351
  constructor(springBone) {
268
352
  super();
269
353
  this.worldScale = 1;
270
354
  this._currentRadius = 0;
271
- this._currentTail = new THREE6.Vector3();
355
+ this._currentTail = new THREE8.Vector3();
272
356
  this._springBone = springBone;
273
- this._attrPos = new THREE6.BufferAttribute(new Float32Array(294), 3);
357
+ this._attrPos = new THREE8.BufferAttribute(new Float32Array(294), 3);
274
358
  this.setAttribute("position", this._attrPos);
275
- this._attrIndex = new THREE6.BufferAttribute(new Uint16Array(194), 1);
359
+ this._attrIndex = new THREE8.BufferAttribute(new Uint16Array(194), 1);
276
360
  this.setIndex(this._attrIndex);
277
361
  this._buildIndex();
278
362
  this.update();
@@ -318,19 +402,19 @@ var SpringBoneBufferGeometry = class extends THREE6.BufferGeometry {
318
402
  };
319
403
 
320
404
  // src/helpers/VRMSpringBoneJointHelper.ts
321
- var _v3A4 = new THREE7.Vector3();
322
- var VRMSpringBoneJointHelper = class extends THREE7.Group {
405
+ var _v3A5 = new THREE9.Vector3();
406
+ var VRMSpringBoneJointHelper = class extends THREE9.Group {
323
407
  constructor(springBone) {
324
408
  super();
325
409
  this.matrixAutoUpdate = false;
326
410
  this.springBone = springBone;
327
411
  this._geometry = new SpringBoneBufferGeometry(this.springBone);
328
- const material = new THREE7.LineBasicMaterial({
412
+ const material = new THREE9.LineBasicMaterial({
329
413
  color: 16776960,
330
414
  depthTest: false,
331
415
  depthWrite: false
332
416
  });
333
- this._line = new THREE7.LineSegments(this._geometry, material);
417
+ this._line = new THREE9.LineSegments(this._geometry, material);
334
418
  this.add(this._line);
335
419
  }
336
420
  dispose() {
@@ -340,15 +424,15 @@ var VRMSpringBoneJointHelper = class extends THREE7.Group {
340
424
  this.springBone.bone.updateWorldMatrix(true, false);
341
425
  this.matrix.copy(this.springBone.bone.matrixWorld);
342
426
  const matrixWorldElements = this.matrix.elements;
343
- this._geometry.worldScale = _v3A4.set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2]).length();
427
+ this._geometry.worldScale = _v3A5.set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2]).length();
344
428
  this._geometry.update();
345
429
  super.updateMatrixWorld(force);
346
430
  }
347
431
  };
348
432
 
349
433
  // src/VRMSpringBoneCollider.ts
350
- import * as THREE8 from "three";
351
- var VRMSpringBoneCollider = class extends THREE8.Object3D {
434
+ import * as THREE10 from "three";
435
+ var VRMSpringBoneCollider = class extends THREE10.Object3D {
352
436
  constructor(shape) {
353
437
  super();
354
438
  this.shape = shape;
@@ -356,11 +440,11 @@ var VRMSpringBoneCollider = class extends THREE8.Object3D {
356
440
  };
357
441
 
358
442
  // src/VRMSpringBoneJoint.ts
359
- import * as THREE11 from "three";
443
+ import * as THREE13 from "three";
360
444
 
361
445
  // src/utils/mat4InvertCompat.ts
362
- import * as THREE9 from "three";
363
- var _matA = new THREE9.Matrix4();
446
+ import * as THREE11 from "three";
447
+ var _matA = new THREE11.Matrix4();
364
448
  function mat4InvertCompat(target) {
365
449
  if (target.invert) {
366
450
  target.invert();
@@ -371,13 +455,13 @@ function mat4InvertCompat(target) {
371
455
  }
372
456
 
373
457
  // src/utils/Matrix4InverseCache.ts
374
- import * as THREE10 from "three";
458
+ import * as THREE12 from "three";
375
459
  var Matrix4InverseCache = class {
376
460
  constructor(matrix) {
377
461
  /**
378
462
  * A cache of inverse of current matrix.
379
463
  */
380
- this._inverseCache = new THREE10.Matrix4();
464
+ this._inverseCache = new THREE12.Matrix4();
381
465
  /**
382
466
  * A flag that makes it want to recalculate its {@link _inverseCache}.
383
467
  * Will be set `true` when `elements` are mutated and be used in `getInverse`.
@@ -412,16 +496,16 @@ var Matrix4InverseCache = class {
412
496
  };
413
497
 
414
498
  // src/VRMSpringBoneJoint.ts
415
- var IDENTITY_MATRIX4 = new THREE11.Matrix4();
416
- var _v3A5 = new THREE11.Vector3();
417
- var _v3B2 = new THREE11.Vector3();
418
- var _v3C = new THREE11.Vector3();
419
- var _worldSpacePosition = new THREE11.Vector3();
420
- var _centerSpacePosition = new THREE11.Vector3();
421
- var _nextTail = new THREE11.Vector3();
422
- var _quatA = new THREE11.Quaternion();
423
- var _matA2 = new THREE11.Matrix4();
424
- var _matB = new THREE11.Matrix4();
499
+ var IDENTITY_MATRIX4 = new THREE13.Matrix4();
500
+ var _v3A6 = new THREE13.Vector3();
501
+ var _v3B2 = new THREE13.Vector3();
502
+ var _v3C = new THREE13.Vector3();
503
+ var _worldSpacePosition = new THREE13.Vector3();
504
+ var _centerSpacePosition = new THREE13.Vector3();
505
+ var _nextTail = new THREE13.Vector3();
506
+ var _quatA = new THREE13.Quaternion();
507
+ var _matA2 = new THREE13.Matrix4();
508
+ var _matB = new THREE13.Matrix4();
425
509
  var VRMSpringBoneJoint = class {
426
510
  /**
427
511
  * Create a new VRMSpringBone.
@@ -435,15 +519,15 @@ var VRMSpringBoneJoint = class {
435
519
  /**
436
520
  * Current position of child tail, in center unit. Will be used for verlet integration.
437
521
  */
438
- this._currentTail = new THREE11.Vector3();
522
+ this._currentTail = new THREE13.Vector3();
439
523
  /**
440
524
  * Previous position of child tail, in center unit. Will be used for verlet integration.
441
525
  */
442
- this._prevTail = new THREE11.Vector3();
526
+ this._prevTail = new THREE13.Vector3();
443
527
  /**
444
528
  * Initial axis of the bone, in local unit.
445
529
  */
446
- this._boneAxis = new THREE11.Vector3();
530
+ this._boneAxis = new THREE13.Vector3();
447
531
  /**
448
532
  * Length of the bone in world unit.
449
533
  * Will be used for normalization in update loop, will be updated by {@link _calcWorldSpaceBoneLength}.
@@ -459,15 +543,15 @@ var VRMSpringBoneJoint = class {
459
543
  /**
460
544
  * Initial state of the local matrix of the bone.
461
545
  */
462
- this._initialLocalMatrix = new THREE11.Matrix4();
546
+ this._initialLocalMatrix = new THREE13.Matrix4();
463
547
  /**
464
548
  * Initial state of the rotation of the bone.
465
549
  */
466
- this._initialLocalRotation = new THREE11.Quaternion();
550
+ this._initialLocalRotation = new THREE13.Quaternion();
467
551
  /**
468
552
  * Initial state of the position of its child.
469
553
  */
470
- this._initialLocalChildPosition = new THREE11.Vector3();
554
+ this._initialLocalChildPosition = new THREE13.Vector3();
471
555
  var _a, _b, _c, _d, _e, _f;
472
556
  this.bone = bone;
473
557
  this.bone.matrixAutoUpdate = false;
@@ -476,7 +560,7 @@ var VRMSpringBoneJoint = class {
476
560
  hitRadius: (_a = settings.hitRadius) != null ? _a : 0,
477
561
  stiffness: (_b = settings.stiffness) != null ? _b : 1,
478
562
  gravityPower: (_c = settings.gravityPower) != null ? _c : 0,
479
- gravityDir: (_e = (_d = settings.gravityDir) == null ? void 0 : _d.clone()) != null ? _e : new THREE11.Vector3(0, -1, 0),
563
+ gravityDir: (_e = (_d = settings.gravityDir) == null ? void 0 : _d.clone()) != null ? _e : new THREE13.Vector3(0, -1, 0),
480
564
  dragForce: (_f = settings.dragForce) != null ? _f : 0.4
481
565
  };
482
566
  this.colliderGroups = colliderGroups;
@@ -554,19 +638,19 @@ var VRMSpringBoneJoint = class {
554
638
  const centerSpaceGravity = _v3C.copy(this.settings.gravityDir).applyQuaternion(quatWorldToCenter).normalize();
555
639
  const matrixCenterToWorld = this._getMatrixCenterToWorld(_matA2);
556
640
  _nextTail.copy(this._currentTail).add(
557
- _v3A5.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1 - this.settings.dragForce)
558
- ).add(_v3A5.copy(centerSpaceBoneAxis).multiplyScalar(this.settings.stiffness * delta)).add(_v3A5.copy(centerSpaceGravity).multiplyScalar(this.settings.gravityPower * delta)).applyMatrix4(matrixCenterToWorld);
641
+ _v3A6.copy(this._currentTail).sub(this._prevTail).multiplyScalar(1 - this.settings.dragForce)
642
+ ).add(_v3A6.copy(centerSpaceBoneAxis).multiplyScalar(this.settings.stiffness * delta)).add(_v3A6.copy(centerSpaceGravity).multiplyScalar(this.settings.gravityPower * delta)).applyMatrix4(matrixCenterToWorld);
559
643
  _nextTail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);
560
644
  this._collision(_nextTail);
561
645
  matrixWorldToCenter = this._getMatrixWorldToCenter(_matA2);
562
646
  this._prevTail.copy(this._currentTail);
563
- this._currentTail.copy(_v3A5.copy(_nextTail).applyMatrix4(matrixWorldToCenter));
647
+ this._currentTail.copy(_v3A6.copy(_nextTail).applyMatrix4(matrixWorldToCenter));
564
648
  const worldSpaceInitialMatrixInv = mat4InvertCompat(
565
649
  _matA2.copy(this._parentMatrixWorld).multiply(this._initialLocalMatrix)
566
650
  );
567
651
  const applyRotation = _quatA.setFromUnitVectors(
568
652
  this._boneAxis,
569
- _v3A5.copy(_nextTail).applyMatrix4(worldSpaceInitialMatrixInv).normalize()
653
+ _v3A6.copy(_nextTail).applyMatrix4(worldSpaceInitialMatrixInv).normalize()
570
654
  );
571
655
  this.bone.quaternion.copy(this._initialLocalRotation).multiply(applyRotation);
572
656
  this.bone.updateMatrix();
@@ -580,9 +664,9 @@ var VRMSpringBoneJoint = class {
580
664
  _collision(tail) {
581
665
  this.colliderGroups.forEach((colliderGroup) => {
582
666
  colliderGroup.colliders.forEach((collider) => {
583
- const dist = collider.shape.calculateCollision(collider.matrixWorld, tail, this.settings.hitRadius, _v3A5);
667
+ const dist = collider.shape.calculateCollision(collider.matrixWorld, tail, this.settings.hitRadius, _v3A6);
584
668
  if (dist < 0) {
585
- tail.add(_v3A5.multiplyScalar(-dist));
669
+ tail.add(_v3A6.multiplyScalar(-dist));
586
670
  tail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);
587
671
  }
588
672
  });
@@ -593,14 +677,14 @@ var VRMSpringBoneJoint = class {
593
677
  * Intended to be used in {@link update}.
594
678
  */
595
679
  _calcWorldSpaceBoneLength() {
596
- _v3A5.setFromMatrixPosition(this.bone.matrixWorld);
680
+ _v3A6.setFromMatrixPosition(this.bone.matrixWorld);
597
681
  if (this.child) {
598
682
  _v3B2.setFromMatrixPosition(this.child.matrixWorld);
599
683
  } else {
600
684
  _v3B2.copy(this._initialLocalChildPosition);
601
685
  _v3B2.applyMatrix4(this.bone.matrixWorld);
602
686
  }
603
- this._worldSpaceBoneLength = _v3A5.sub(_v3B2).length();
687
+ this._worldSpaceBoneLength = _v3A6.sub(_v3B2).length();
604
688
  }
605
689
  /**
606
690
  * Create a matrix that converts center space into world space.
@@ -629,7 +713,7 @@ var VRMSpringBoneJoint = class {
629
713
  };
630
714
 
631
715
  // src/VRMSpringBoneLoaderPlugin.ts
632
- import * as THREE12 from "three";
716
+ import * as THREE14 from "three";
633
717
 
634
718
  // src/utils/traverseAncestorsFromRoot.ts
635
719
  function traverseAncestorsFromRoot(object, callback) {
@@ -828,15 +912,19 @@ var VRMSpringBoneManager = class {
828
912
  };
829
913
 
830
914
  // src/VRMSpringBoneLoaderPlugin.ts
915
+ var EXTENSION_NAME_EXTENDED_COLLIDER = "VRMC_springBone_extended_collider";
831
916
  var POSSIBLE_SPEC_VERSIONS = /* @__PURE__ */ new Set(["1.0", "1.0-beta"]);
917
+ var POSSIBLE_SPEC_VERSIONS_EXTENDED_COLLIDERS = /* @__PURE__ */ new Set(["1.0"]);
832
918
  var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
833
919
  get name() {
834
920
  return _VRMSpringBoneLoaderPlugin.EXTENSION_NAME;
835
921
  }
836
922
  constructor(parser, options) {
923
+ var _a;
837
924
  this.parser = parser;
838
925
  this.jointHelperRoot = options == null ? void 0 : options.jointHelperRoot;
839
926
  this.colliderHelperRoot = options == null ? void 0 : options.colliderHelperRoot;
927
+ this.useExtendedColliders = (_a = options == null ? void 0 : options.useExtendedColliders) != null ? _a : true;
840
928
  }
841
929
  afterRoot(gltf) {
842
930
  return __async(this, null, function* () {
@@ -884,19 +972,51 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
884
972
  return null;
885
973
  }
886
974
  const colliders = (_c = extension.colliders) == null ? void 0 : _c.map((schemaCollider, iCollider) => {
887
- var _a2, _b2, _c2, _d2, _e2;
975
+ var _a2, _b2, _c2, _d2, _e2, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
888
976
  const node = threeNodes[schemaCollider.node];
889
977
  const schemaShape = schemaCollider.shape;
978
+ const schemaExCollider = (_a2 = schemaCollider.extensions) == null ? void 0 : _a2[EXTENSION_NAME_EXTENDED_COLLIDER];
979
+ if (this.useExtendedColliders && schemaExCollider != null) {
980
+ const specVersionExCollider = schemaExCollider.specVersion;
981
+ if (!POSSIBLE_SPEC_VERSIONS_EXTENDED_COLLIDERS.has(specVersionExCollider)) {
982
+ console.warn(
983
+ `VRMSpringBoneLoaderPlugin: Unknown ${EXTENSION_NAME_EXTENDED_COLLIDER} specVersion "${specVersionExCollider}". Fallbacking to the ${_VRMSpringBoneLoaderPlugin.EXTENSION_NAME} definition`
984
+ );
985
+ } else {
986
+ const schemaExShape = schemaExCollider.shape;
987
+ if (schemaExShape.sphere) {
988
+ return this._importSphereCollider(node, {
989
+ offset: new THREE14.Vector3().fromArray((_b2 = schemaExShape.sphere.offset) != null ? _b2 : [0, 0, 0]),
990
+ radius: (_c2 = schemaExShape.sphere.radius) != null ? _c2 : 0,
991
+ inside: (_d2 = schemaExShape.sphere.inside) != null ? _d2 : false
992
+ });
993
+ } else if (schemaExShape.capsule) {
994
+ return this._importCapsuleCollider(node, {
995
+ offset: new THREE14.Vector3().fromArray((_e2 = schemaExShape.capsule.offset) != null ? _e2 : [0, 0, 0]),
996
+ radius: (_f = schemaExShape.capsule.radius) != null ? _f : 0,
997
+ tail: new THREE14.Vector3().fromArray((_g = schemaExShape.capsule.tail) != null ? _g : [0, 0, 0]),
998
+ inside: (_h = schemaExShape.capsule.inside) != null ? _h : false
999
+ });
1000
+ } else if (schemaExShape.plane) {
1001
+ return this._importPlaneCollider(node, {
1002
+ offset: new THREE14.Vector3().fromArray((_i = schemaExShape.plane.offset) != null ? _i : [0, 0, 0]),
1003
+ normal: new THREE14.Vector3().fromArray((_j = schemaExShape.plane.normal) != null ? _j : [0, 0, 1])
1004
+ });
1005
+ }
1006
+ }
1007
+ }
890
1008
  if (schemaShape.sphere) {
891
1009
  return this._importSphereCollider(node, {
892
- offset: new THREE12.Vector3().fromArray((_a2 = schemaShape.sphere.offset) != null ? _a2 : [0, 0, 0]),
893
- radius: (_b2 = schemaShape.sphere.radius) != null ? _b2 : 0
1010
+ offset: new THREE14.Vector3().fromArray((_k = schemaShape.sphere.offset) != null ? _k : [0, 0, 0]),
1011
+ radius: (_l = schemaShape.sphere.radius) != null ? _l : 0,
1012
+ inside: false
894
1013
  });
895
1014
  } else if (schemaShape.capsule) {
896
1015
  return this._importCapsuleCollider(node, {
897
- offset: new THREE12.Vector3().fromArray((_c2 = schemaShape.capsule.offset) != null ? _c2 : [0, 0, 0]),
898
- radius: (_d2 = schemaShape.capsule.radius) != null ? _d2 : 0,
899
- tail: new THREE12.Vector3().fromArray((_e2 = schemaShape.capsule.tail) != null ? _e2 : [0, 0, 0])
1016
+ offset: new THREE14.Vector3().fromArray((_m = schemaShape.capsule.offset) != null ? _m : [0, 0, 0]),
1017
+ radius: (_n = schemaShape.capsule.radius) != null ? _n : 0,
1018
+ tail: new THREE14.Vector3().fromArray((_o = schemaShape.capsule.tail) != null ? _o : [0, 0, 0]),
1019
+ inside: false
900
1020
  });
901
1021
  }
902
1022
  throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${iCollider} has no valid shape`);
@@ -944,7 +1064,7 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
944
1064
  dragForce: prevSchemaJoint.dragForce,
945
1065
  gravityPower: prevSchemaJoint.gravityPower,
946
1066
  stiffness: prevSchemaJoint.stiffness,
947
- gravityDir: prevSchemaJoint.gravityDir != null ? new THREE12.Vector3().fromArray(prevSchemaJoint.gravityDir) : void 0
1067
+ gravityDir: prevSchemaJoint.gravityDir != null ? new THREE14.Vector3().fromArray(prevSchemaJoint.gravityDir) : void 0
948
1068
  };
949
1069
  const joint = this._importJoint(node, child, setting, colliderGroupsForSpring);
950
1070
  if (center) {
@@ -984,7 +1104,7 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
984
1104
  const node = threeNodes[schemaColliderGroup.node];
985
1105
  const colliders = ((_a2 = schemaColliderGroup.colliders) != null ? _a2 : []).map((schemaCollider, iCollider) => {
986
1106
  var _a3, _b2, _c2;
987
- const offset = new THREE12.Vector3(0, 0, 0);
1107
+ const offset = new THREE14.Vector3(0, 0, 0);
988
1108
  if (schemaCollider.offset) {
989
1109
  offset.set(
990
1110
  (_a3 = schemaCollider.offset.x) != null ? _a3 : 0,
@@ -995,7 +1115,8 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
995
1115
  }
996
1116
  return this._importSphereCollider(node, {
997
1117
  offset,
998
- radius: (_c2 = schemaCollider.radius) != null ? _c2 : 0
1118
+ radius: (_c2 = schemaCollider.radius) != null ? _c2 : 0,
1119
+ inside: false
999
1120
  });
1000
1121
  });
1001
1122
  return { colliders };
@@ -1009,7 +1130,7 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
1009
1130
  rootIndices.forEach((rootIndex) => {
1010
1131
  var _a2, _b2, _c2, _d;
1011
1132
  const root = threeNodes[rootIndex];
1012
- const gravityDir = new THREE12.Vector3();
1133
+ const gravityDir = new THREE14.Vector3();
1013
1134
  if (schemaBoneGroup.gravityDir) {
1014
1135
  gravityDir.set(
1015
1136
  (_a2 = schemaBoneGroup.gravityDir.x) != null ? _a2 : 0,
@@ -1062,8 +1183,7 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
1062
1183
  return springBone;
1063
1184
  }
1064
1185
  _importSphereCollider(destination, params) {
1065
- const { offset, radius } = params;
1066
- const shape = new VRMSpringBoneColliderShapeSphere({ offset, radius });
1186
+ const shape = new VRMSpringBoneColliderShapeSphere(params);
1067
1187
  const collider = new VRMSpringBoneCollider(shape);
1068
1188
  destination.add(collider);
1069
1189
  if (this.colliderHelperRoot) {
@@ -1074,8 +1194,18 @@ var _VRMSpringBoneLoaderPlugin = class _VRMSpringBoneLoaderPlugin {
1074
1194
  return collider;
1075
1195
  }
1076
1196
  _importCapsuleCollider(destination, params) {
1077
- const { offset, radius, tail } = params;
1078
- const shape = new VRMSpringBoneColliderShapeCapsule({ offset, radius, tail });
1197
+ const shape = new VRMSpringBoneColliderShapeCapsule(params);
1198
+ const collider = new VRMSpringBoneCollider(shape);
1199
+ destination.add(collider);
1200
+ if (this.colliderHelperRoot) {
1201
+ const helper = new VRMSpringBoneColliderHelper(collider);
1202
+ this.colliderHelperRoot.add(helper);
1203
+ helper.renderOrder = this.colliderHelperRoot.renderOrder;
1204
+ }
1205
+ return collider;
1206
+ }
1207
+ _importPlaneCollider(destination, params) {
1208
+ const shape = new VRMSpringBoneColliderShapePlane(params);
1079
1209
  const collider = new VRMSpringBoneCollider(shape);
1080
1210
  destination.add(collider);
1081
1211
  if (this.colliderHelperRoot) {
@@ -1093,10 +1223,11 @@ export {
1093
1223
  VRMSpringBoneColliderHelper,
1094
1224
  VRMSpringBoneColliderShape,
1095
1225
  VRMSpringBoneColliderShapeCapsule,
1226
+ VRMSpringBoneColliderShapePlane,
1096
1227
  VRMSpringBoneColliderShapeSphere,
1097
1228
  VRMSpringBoneJoint,
1098
1229
  VRMSpringBoneJointHelper,
1099
1230
  VRMSpringBoneLoaderPlugin,
1100
1231
  VRMSpringBoneManager
1101
1232
  };
1102
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/helpers/VRMSpringBoneColliderHelper.ts", "../src/VRMSpringBoneColliderShapeCapsule.ts", "../src/VRMSpringBoneColliderShape.ts", "../src/VRMSpringBoneColliderShapeSphere.ts", "../src/helpers/utils/ColliderShapeCapsuleBufferGeometry.ts", "../src/helpers/utils/ColliderShapeSphereBufferGeometry.ts", "../src/helpers/VRMSpringBoneJointHelper.ts", "../src/helpers/utils/SpringBoneBufferGeometry.ts", "../src/VRMSpringBoneCollider.ts", "../src/VRMSpringBoneJoint.ts", "../src/utils/mat4InvertCompat.ts", "../src/utils/Matrix4InverseCache.ts", "../src/VRMSpringBoneLoaderPlugin.ts", "../src/utils/traverseAncestorsFromRoot.ts", "../src/utils/traverseChildrenUntilConditionMet.ts", "../src/VRMSpringBoneManager.ts"],
  "sourcesContent": ["import * as THREE from 'three';\nimport { VRMSpringBoneCollider } from '../VRMSpringBoneCollider';\nimport { VRMSpringBoneColliderShapeCapsule } from '../VRMSpringBoneColliderShapeCapsule';\nimport { VRMSpringBoneColliderShapeSphere } from '../VRMSpringBoneColliderShapeSphere';\nimport { ColliderShapeBufferGeometry } from './utils/ColliderShapeBufferGeometry';\nimport { ColliderShapeCapsuleBufferGeometry } from './utils/ColliderShapeCapsuleBufferGeometry';\nimport { ColliderShapeSphereBufferGeometry } from './utils/ColliderShapeSphereBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class VRMSpringBoneColliderHelper extends THREE.Group {\n  public readonly collider: VRMSpringBoneCollider;\n  private readonly _geometry: ColliderShapeBufferGeometry;\n  private readonly _line: THREE.LineSegments;\n\n  public constructor(collider: VRMSpringBoneCollider) {\n    super();\n    this.matrixAutoUpdate = false;\n\n    this.collider = collider;\n\n    if (this.collider.shape instanceof VRMSpringBoneColliderShapeSphere) {\n      this._geometry = new ColliderShapeSphereBufferGeometry(this.collider.shape);\n    } else if (this.collider.shape instanceof VRMSpringBoneColliderShapeCapsule) {\n      this._geometry = new ColliderShapeCapsuleBufferGeometry(this.collider.shape);\n    } else {\n      throw new Error('VRMSpringBoneColliderHelper: Unknown collider shape type detected');\n    }\n\n    const material = new THREE.LineBasicMaterial({\n      color: 0xff00ff,\n      depthTest: false,\n      depthWrite: false,\n    });\n\n    this._line = new THREE.LineSegments(this._geometry, material);\n    this.add(this._line);\n  }\n\n  public dispose(): void {\n    this._geometry.dispose();\n  }\n\n  public updateMatrixWorld(force: boolean): void {\n    this.collider.updateWorldMatrix(true, false);\n\n    this.matrix.copy(this.collider.matrixWorld);\n\n    const matrixWorldElements = this.matrix.elements;\n    this._geometry.worldScale = _v3A\n      .set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2])\n      .length(); // calculate scale of x component\n\n    this._geometry.update();\n\n    super.updateMatrixWorld(force);\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\n\nexport class VRMSpringBoneColliderShapeCapsule extends VRMSpringBoneColliderShape {\n  public get type(): 'capsule' {\n    return 'capsule';\n  }\n\n  /**\n   * The offset of the head from the origin.\n   */\n  public offset: THREE.Vector3;\n\n  /**\n   * The offset of the tail from the origin.\n   */\n  public tail: THREE.Vector3;\n\n  /**\n   * The radius.\n   */\n  public radius: number;\n\n  public constructor(params?: { radius?: number; offset?: THREE.Vector3; tail?: THREE.Vector3 }) {\n    super();\n\n    this.offset = params?.offset ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.tail = params?.tail ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.radius = params?.radius ?? 0.0;\n  }\n\n  public calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number {\n    _v3A.copy(this.offset).applyMatrix4(colliderMatrix); // transformed head\n    _v3B.copy(this.tail).applyMatrix4(colliderMatrix); // transformed tail\n    _v3B.sub(_v3A); // from head to tail\n    const lengthSqCapsule = _v3B.lengthSq();\n\n    target.copy(objectPosition).sub(_v3A); // from head to object\n    const dot = _v3B.dot(target); // dot product of offsetToTail and offsetToObject\n\n    if (dot <= 0.0) {\n      // if object is near from the head\n      // do nothing, use the current value directly\n    } else if (lengthSqCapsule <= dot) {\n      // if object is near from the tail\n      target.sub(_v3B); // from tail to object\n    } else {\n      // if object is between two ends\n      _v3B.multiplyScalar(dot / lengthSqCapsule); // from head to the nearest point of the shaft\n      target.sub(_v3B); // from the shaft point to object\n    }\n\n    const radius = objectRadius + this.radius;\n    const distance = target.length() - radius;\n    target.normalize();\n    return distance;\n  }\n}\n", "import type * as THREE from 'three';\n\n/**\n * Represents a shape of a collider.\n */\nexport abstract class VRMSpringBoneColliderShape {\n  /**\n   * The type of the shape.\n   */\n  public abstract get type(): string;\n\n  /**\n   * Calculate a distance and a direction from the collider to a target object.\n   * It's hit if the distance is negative.\n   * The direction will be contained in the given target vector.\n   *\n   * @param colliderMatrix A matrix represents the transform of the collider\n   * @param objectPosition A vector represents the position of the target object\n   * @param objectRadius The radius of the object\n   * @param target The result direction will be contained in this vector\n   */\n  public abstract calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number;\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\nexport class VRMSpringBoneColliderShapeSphere extends VRMSpringBoneColliderShape {\n  public get type(): 'sphere' {\n    return 'sphere';\n  }\n\n  /**\n   * The offset from the origin.\n   */\n  public offset: THREE.Vector3;\n\n  /**\n   * The radius.\n   */\n  public radius: number;\n\n  public constructor(params?: { radius?: number; offset?: THREE.Vector3 }) {\n    super();\n\n    this.offset = params?.offset ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.radius = params?.radius ?? 0.0;\n  }\n\n  public calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number {\n    target.copy(this.offset).applyMatrix4(colliderMatrix); // transformed offset\n    target.negate().add(objectPosition); // a vector from collider center to object position\n    const radius = objectRadius + this.radius;\n    const distance = target.length() - radius;\n    target.normalize();\n    return distance;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShapeCapsule } from '../../VRMSpringBoneColliderShapeCapsule';\nimport { ColliderShapeBufferGeometry } from './ColliderShapeBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class ColliderShapeCapsuleBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _shape: VRMSpringBoneColliderShapeCapsule;\n  private _currentRadius = 0;\n  private readonly _currentOffset = new THREE.Vector3();\n  private readonly _currentTail = new THREE.Vector3();\n\n  public constructor(shape: VRMSpringBoneColliderShapeCapsule) {\n    super();\n\n    this._shape = shape;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(396), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(264), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._shape.radius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentOffset.equals(this._shape.offset)) {\n      this._currentOffset.copy(this._shape.offset);\n      shouldUpdateGeometry = true;\n    }\n\n    const tail = _v3A.copy(this._shape.tail).divideScalar(this.worldScale);\n    if (this._currentTail.distanceToSquared(tail) > 1e-10) {\n      this._currentTail.copy(tail);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    _v3A.copy(this._currentTail).sub(this._currentOffset);\n    const l = _v3A.length() / this._currentRadius;\n\n    for (let i = 0; i <= 16; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, -Math.sin(t), -Math.cos(t), 0.0);\n      this._attrPos.setXYZ(17 + i, l + Math.sin(t), Math.cos(t), 0.0);\n      this._attrPos.setXYZ(34 + i, -Math.sin(t), 0.0, -Math.cos(t));\n      this._attrPos.setXYZ(51 + i, l + Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n      this._attrPos.setXYZ(68 + i, 0.0, Math.sin(t), Math.cos(t));\n      this._attrPos.setXYZ(100 + i, l, Math.sin(t), Math.cos(t));\n    }\n\n    const theta = Math.atan2(_v3A.y, Math.sqrt(_v3A.x * _v3A.x + _v3A.z * _v3A.z));\n    const phi = -Math.atan2(_v3A.z, _v3A.x);\n\n    this.rotateZ(theta);\n    this.rotateY(phi);\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 34; i++) {\n      const i1 = (i + 1) % 34;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(68 + i * 2, 34 + i, 34 + i1);\n    }\n\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(136 + i * 2, 68 + i, 68 + i1);\n      this._attrIndex.setXY(200 + i * 2, 100 + i, 100 + i1);\n    }\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShapeSphere } from '../../VRMSpringBoneColliderShapeSphere';\nimport { ColliderShapeBufferGeometry } from './ColliderShapeBufferGeometry';\n\nexport class ColliderShapeSphereBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _shape: VRMSpringBoneColliderShapeSphere;\n  private _currentRadius = 0;\n  private readonly _currentOffset = new THREE.Vector3();\n\n  public constructor(shape: VRMSpringBoneColliderShapeSphere) {\n    super();\n\n    this._shape = shape;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(32 * 3 * 3), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(64 * 3), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._shape.radius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentOffset.equals(this._shape.offset)) {\n      this._currentOffset.copy(this._shape.offset);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);\n      this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));\n      this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);\n      this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);\n    }\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneJoint } from '../VRMSpringBoneJoint';\nimport { SpringBoneBufferGeometry } from './utils/SpringBoneBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class VRMSpringBoneJointHelper extends THREE.Group {\n  public readonly springBone: VRMSpringBoneJoint;\n  private readonly _geometry: SpringBoneBufferGeometry;\n  private readonly _line: THREE.LineSegments;\n\n  public constructor(springBone: VRMSpringBoneJoint) {\n    super();\n    this.matrixAutoUpdate = false;\n\n    this.springBone = springBone;\n\n    this._geometry = new SpringBoneBufferGeometry(this.springBone);\n\n    const material = new THREE.LineBasicMaterial({\n      color: 0xffff00,\n      depthTest: false,\n      depthWrite: false,\n    });\n\n    this._line = new THREE.LineSegments(this._geometry, material);\n    this.add(this._line);\n  }\n\n  public dispose(): void {\n    this._geometry.dispose();\n  }\n\n  public updateMatrixWorld(force: boolean): void {\n    this.springBone.bone.updateWorldMatrix(true, false);\n\n    this.matrix.copy(this.springBone.bone.matrixWorld);\n\n    const matrixWorldElements = this.matrix.elements;\n    this._geometry.worldScale = _v3A\n      .set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2])\n      .length(); // calculate scale of x component\n\n    this._geometry.update();\n\n    super.updateMatrixWorld(force);\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneJoint } from '../../VRMSpringBoneJoint';\n\nexport class SpringBoneBufferGeometry extends THREE.BufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _springBone: VRMSpringBoneJoint;\n  private _currentRadius = 0;\n  private readonly _currentTail = new THREE.Vector3();\n\n  public constructor(springBone: VRMSpringBoneJoint) {\n    super();\n\n    this._springBone = springBone;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(294), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(194), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._springBone.settings.hitRadius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentTail.equals(this._springBone.initialLocalChildPosition)) {\n      this._currentTail.copy(this._springBone.initialLocalChildPosition);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);\n      this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));\n      this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentTail.x, this._currentTail.y, this._currentTail.z);\n\n    this._attrPos.setXYZ(96, 0, 0, 0);\n    this._attrPos.setXYZ(97, this._currentTail.x, this._currentTail.y, this._currentTail.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);\n      this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);\n    }\n    this._attrIndex.setXY(192, 96, 97);\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport type { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\n/**\n * Represents a collider of a VRM.\n */\nexport class VRMSpringBoneCollider extends THREE.Object3D {\n  /**\n   * The shape of the collider.\n   */\n  public readonly shape: VRMSpringBoneColliderShape;\n\n  public constructor(shape: VRMSpringBoneColliderShape) {\n    super();\n\n    this.shape = shape;\n  }\n}\n", "import * as THREE from 'three';\nimport { mat4InvertCompat } from './utils/mat4InvertCompat';\nimport { Matrix4InverseCache } from './utils/Matrix4InverseCache';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport type { VRMSpringBoneJointSettings } from './VRMSpringBoneJointSettings';\n\n// based on\n// http://rocketjump.skr.jp/unity3d/109/\n// https://github.com/dwango/UniVRM/blob/master/Scripts/SpringBone/VRMSpringBone.cs\n\nconst IDENTITY_MATRIX4 = new THREE.Matrix4();\n\n// \u8A08\u7B97\u4E2D\u306E\u4E00\u6642\u4FDD\u5B58\u7528\u5909\u6570\uFF08\u4E00\u5EA6\u30A4\u30F3\u30B9\u30BF\u30F3\u30B9\u3092\u4F5C\u3063\u305F\u3089\u3042\u3068\u306F\u4F7F\u3044\u56DE\u3059\uFF09\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\nconst _v3C = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _worldSpacePosition = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _centerSpacePosition = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _nextTail = new THREE.Vector3();\n\nconst _quatA = new THREE.Quaternion();\nconst _matA = new THREE.Matrix4();\nconst _matB = new THREE.Matrix4();\n\n/**\n * A class represents a single joint of a spring bone.\n * It should be managed by a [[VRMSpringBoneManager]].\n */\nexport class VRMSpringBoneJoint {\n  /**\n   * Settings of the bone.\n   */\n  public settings: VRMSpringBoneJointSettings;\n\n  /**\n   * Collider groups attached to this bone.\n   */\n  public colliderGroups: VRMSpringBoneColliderGroup[];\n\n  /**\n   * An Object3D attached to this bone.\n   */\n  public readonly bone: THREE.Object3D;\n\n  /**\n   * An Object3D that will be used as a tail of this spring bone.\n   * It can be null when the spring bone is imported from VRM 0.0.\n   */\n  public readonly child: THREE.Object3D | null;\n\n  /**\n   * Current position of child tail, in center unit. Will be used for verlet integration.\n   */\n  private _currentTail = new THREE.Vector3();\n\n  /**\n   * Previous position of child tail, in center unit. Will be used for verlet integration.\n   */\n  private _prevTail = new THREE.Vector3();\n\n  /**\n   * Initial axis of the bone, in local unit.\n   */\n  private _boneAxis = new THREE.Vector3();\n\n  /**\n   * Length of the bone in world unit.\n   * Will be used for normalization in update loop, will be updated by {@link _calcWorldSpaceBoneLength}.\n   *\n   * It's same as local unit length unless there are scale transformations in the world space.\n   */\n  private _worldSpaceBoneLength = 0.0;\n\n  /**\n   * This springbone will be calculated based on the space relative from this object.\n   * If this is `null`, springbone will be calculated in world space.\n   */\n  private _center: THREE.Object3D | null = null;\n  public get center(): THREE.Object3D | null {\n    return this._center;\n  }\n  public set center(center: THREE.Object3D | null) {\n    // uninstall inverse cache\n    if (this._center?.userData.inverseCacheProxy) {\n      (this._center.userData.inverseCacheProxy as Matrix4InverseCache).revert();\n      delete this._center.userData.inverseCacheProxy;\n    }\n\n    // change the center\n    this._center = center;\n\n    // install inverse cache\n    if (this._center) {\n      if (!this._center.userData.inverseCacheProxy) {\n        this._center.userData.inverseCacheProxy = new Matrix4InverseCache(this._center.matrixWorld);\n      }\n    }\n  }\n\n  /**\n   * Initial state of the local matrix of the bone.\n   */\n  private _initialLocalMatrix = new THREE.Matrix4();\n\n  /**\n   * Initial state of the rotation of the bone.\n   */\n  private _initialLocalRotation = new THREE.Quaternion();\n\n  /**\n   * Initial state of the position of its child.\n   */\n  private _initialLocalChildPosition = new THREE.Vector3();\n  public get initialLocalChildPosition(): THREE.Vector3 {\n    return this._initialLocalChildPosition;\n  }\n\n  /**\n   * Returns the world matrix of its parent object.\n   * Note that it returns a reference to the matrix. Don't mutate this directly!\n   */\n  private get _parentMatrixWorld(): THREE.Matrix4 {\n    return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;\n  }\n\n  /**\n   * Create a new VRMSpringBone.\n   *\n   * @param bone An Object3D that will be attached to this bone\n   * @param child An Object3D that will be used as a tail of this spring bone. It can be null when the spring bone is imported from VRM 0.0\n   * @param settings Several parameters related to behavior of the spring bone\n   * @param colliderGroups Collider groups that will be collided with this spring bone\n   */\n  constructor(\n    bone: THREE.Object3D,\n    child: THREE.Object3D | null,\n    settings: Partial<VRMSpringBoneJointSettings> = {},\n    colliderGroups: VRMSpringBoneColliderGroup[] = [],\n  ) {\n    this.bone = bone; // uniVRM\u3067\u306E parent\n    this.bone.matrixAutoUpdate = false; // update\u306B\u3088\u308A\u8A08\u7B97\u3055\u308C\u308B\u306E\u3067three.js\u5185\u3067\u306E\u81EA\u52D5\u51E6\u7406\u306F\u4E0D\u8981\n\n    this.child = child;\n\n    this.settings = {\n      hitRadius: settings.hitRadius ?? 0.0,\n      stiffness: settings.stiffness ?? 1.0,\n      gravityPower: settings.gravityPower ?? 0.0,\n      gravityDir: settings.gravityDir?.clone() ?? new THREE.Vector3(0.0, -1.0, 0.0),\n      dragForce: settings.dragForce ?? 0.4,\n    };\n\n    this.colliderGroups = colliderGroups;\n  }\n\n  /**\n   * Set the initial state of this spring bone.\n   * You might want to call {@link VRMSpringBoneManager.setInitState} instead.\n   */\n  public setInitState(): void {\n    // remember initial position of itself\n    this._initialLocalMatrix.copy(this.bone.matrix);\n    this._initialLocalRotation.copy(this.bone.quaternion);\n\n    // see initial position of its local child\n    if (this.child) {\n      this._initialLocalChildPosition.copy(this.child.position);\n    } else {\n      // vrm0 requires a 7cm fixed bone length for the final node in a chain\n      // See: https://github.com/vrm-c/vrm-specification/tree/master/specification/VRMC_springBone-1.0#about-spring-configuration\n      this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07);\n    }\n\n    // copy the child position to tails\n    const matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)).applyMatrix4(matrixWorldToCenter);\n    this._prevTail.copy(this._currentTail);\n\n    // set initial states that are related to local child position\n    this._boneAxis.copy(this._initialLocalChildPosition).normalize();\n  }\n\n  /**\n   * Reset the state of this bone.\n   * You might want to call [[VRMSpringBoneManager.reset]] instead.\n   */\n  public reset(): void {\n    this.bone.quaternion.copy(this._initialLocalRotation);\n\n    // We need to update its matrixWorld manually, since we tweaked the bone by our hand\n    this.bone.updateMatrix();\n    this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld, this.bone.matrix);\n\n    // Apply updated position to tail states\n    const matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)).applyMatrix4(matrixWorldToCenter);\n    this._prevTail.copy(this._currentTail);\n  }\n\n  /**\n   * Update the state of this bone.\n   * You might want to call [[VRMSpringBoneManager.update]] instead.\n   *\n   * @param delta deltaTime\n   */\n  public update(delta: number): void {\n    if (delta <= 0) return;\n\n    // Update the _worldSpaceBoneLength\n    this._calcWorldSpaceBoneLength();\n\n    // Get bone position in center space\n    _worldSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n    let matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    _centerSpacePosition.copy(_worldSpacePosition).applyMatrix4(matrixWorldToCenter);\n    const quatWorldToCenter = _quatA.setFromRotationMatrix(matrixWorldToCenter);\n\n    // Get parent matrix in center space\n    const centerSpaceParentMatrix = _matB.copy(matrixWorldToCenter).multiply(this._parentMatrixWorld);\n\n    // Get boneAxis in center space\n    const centerSpaceBoneAxis = _v3B\n      .copy(this._boneAxis)\n      .applyMatrix4(this._initialLocalMatrix)\n      .applyMatrix4(centerSpaceParentMatrix)\n      .sub(_centerSpacePosition)\n      .normalize();\n\n    // gravity in center space\n    const centerSpaceGravity = _v3C.copy(this.settings.gravityDir).applyQuaternion(quatWorldToCenter).normalize();\n\n    const matrixCenterToWorld = this._getMatrixCenterToWorld(_matA);\n\n    // verlet\u7A4D\u5206\u3067\u6B21\u306E\u4F4D\u7F6E\u3092\u8A08\u7B97\n    _nextTail\n      .copy(this._currentTail)\n      .add(\n        _v3A\n          .copy(this._currentTail)\n          .sub(this._prevTail)\n          .multiplyScalar(1 - this.settings.dragForce),\n      ) // \u524D\u30D5\u30EC\u30FC\u30E0\u306E\u79FB\u52D5\u3092\u7D99\u7D9A\u3059\u308B(\u6E1B\u8870\u3082\u3042\u308B\u3088)\n      .add(_v3A.copy(centerSpaceBoneAxis).multiplyScalar(this.settings.stiffness * delta)) // \u89AA\u306E\u56DE\u8EE2\u306B\u3088\u308B\u5B50\u30DC\u30FC\u30F3\u306E\u79FB\u52D5\u76EE\u6A19\n      .add(_v3A.copy(centerSpaceGravity).multiplyScalar(this.settings.gravityPower * delta)) // \u5916\u529B\u306B\u3088\u308B\u79FB\u52D5\u91CF\n      .applyMatrix4(matrixCenterToWorld); // tail\u3092world space\u306B\u623B\u3059\n\n    // normalize bone length\n    _nextTail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);\n\n    // Collision\u3067\u79FB\u52D5\n    this._collision(_nextTail);\n\n    // update prevTail and currentTail\n    matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n\n    this._prevTail.copy(this._currentTail);\n    this._currentTail.copy(_v3A.copy(_nextTail).applyMatrix4(matrixWorldToCenter));\n\n    // Apply rotation, convert vector3 thing into actual quaternion\n    // Original UniVRM is doing center unit calculus at here but we're gonna do this on local unit\n    const worldSpaceInitialMatrixInv = mat4InvertCompat(\n      _matA.copy(this._parentMatrixWorld).multiply(this._initialLocalMatrix),\n    );\n    const applyRotation = _quatA.setFromUnitVectors(\n      this._boneAxis,\n      _v3A.copy(_nextTail).applyMatrix4(worldSpaceInitialMatrixInv).normalize(),\n    );\n\n    this.bone.quaternion.copy(this._initialLocalRotation).multiply(applyRotation);\n\n    // We need to update its matrixWorld manually, since we tweaked the bone by our hand\n    this.bone.updateMatrix();\n    this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld, this.bone.matrix);\n  }\n\n  /**\n   * Do collision math against every colliders attached to this bone.\n   *\n   * @param tail The tail you want to process\n   */\n  private _collision(tail: THREE.Vector3): void {\n    this.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        const dist = collider.shape.calculateCollision(collider.matrixWorld, tail, this.settings.hitRadius, _v3A);\n\n        if (dist < 0.0) {\n          // hit\n          tail.add(_v3A.multiplyScalar(-dist));\n\n          // normalize bone length\n          tail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);\n        }\n      });\n    });\n  }\n\n  /**\n   * Calculate the {@link _worldSpaceBoneLength}.\n   * Intended to be used in {@link update}.\n   */\n  private _calcWorldSpaceBoneLength(): void {\n    _v3A.setFromMatrixPosition(this.bone.matrixWorld); // get world position of this.bone\n\n    if (this.child) {\n      _v3B.setFromMatrixPosition(this.child.matrixWorld); // get world position of this.child\n    } else {\n      _v3B.copy(this._initialLocalChildPosition);\n      _v3B.applyMatrix4(this.bone.matrixWorld);\n    }\n\n    this._worldSpaceBoneLength = _v3A.sub(_v3B).length();\n  }\n\n  /**\n   * Create a matrix that converts center space into world space.\n   * @param target Target matrix\n   */\n  private _getMatrixCenterToWorld(target: THREE.Matrix4): THREE.Matrix4 {\n    if (this._center) {\n      target.copy(this._center.matrixWorld);\n    } else {\n      target.identity();\n    }\n\n    return target;\n  }\n\n  /**\n   * Create a matrix that converts world space into center space.\n   * @param target Target matrix\n   */\n  private _getMatrixWorldToCenter(target: THREE.Matrix4): THREE.Matrix4 {\n    if (this._center) {\n      target.copy((this._center.userData.inverseCacheProxy as Matrix4InverseCache).inverse);\n    } else {\n      target.identity();\n    }\n\n    return target;\n  }\n}\n", "import * as THREE from 'three';\n\nconst _matA = new THREE.Matrix4();\n\n/**\n * A compat function for `Matrix4.invert()` / `Matrix4.getInverse()`.\n * `Matrix4.invert()` is introduced in r123 and `Matrix4.getInverse()` emits a warning.\n * We are going to use this compat for a while.\n * @param target A target matrix\n */\nexport function mat4InvertCompat<T extends THREE.Matrix4>(target: T): T {\n  if ((target as any).invert) {\n    target.invert();\n  } else {\n    (target as any).getInverse(_matA.copy(target));\n  }\n\n  return target;\n}\n", "import * as THREE from 'three';\nimport { mat4InvertCompat } from './mat4InvertCompat';\n\nexport class Matrix4InverseCache {\n  /**\n   * The target matrix.\n   */\n  public readonly matrix: THREE.Matrix4;\n\n  /**\n   * A cache of inverse of current matrix.\n   */\n  private readonly _inverseCache = new THREE.Matrix4();\n\n  /**\n   * A flag that makes it want to recalculate its {@link _inverseCache}.\n   * Will be set `true` when `elements` are mutated and be used in `getInverse`.\n   */\n  private _shouldUpdateInverse = true;\n\n  /**\n   * The original of `matrix.elements`\n   */\n  private readonly _originalElements: THREE.Matrix4Tuple;\n\n  /**\n   * Inverse of given matrix.\n   * Note that it will return its internal private instance.\n   * Make sure copying this before mutate this.\n   */\n  public get inverse(): THREE.Matrix4 {\n    if (this._shouldUpdateInverse) {\n      mat4InvertCompat(this._inverseCache.copy(this.matrix));\n      this._shouldUpdateInverse = false;\n    }\n\n    return this._inverseCache;\n  }\n\n  public constructor(matrix: THREE.Matrix4) {\n    this.matrix = matrix;\n\n    const handler: ProxyHandler<number[]> = {\n      set: (obj, prop: any, newVal) => {\n        this._shouldUpdateInverse = true;\n        obj[prop] = newVal;\n\n        return true;\n      },\n    };\n\n    this._originalElements = matrix.elements;\n    matrix.elements = new Proxy<THREE.Matrix4Tuple>(matrix.elements, handler);\n  }\n\n  public revert(): void {\n    this.matrix.elements = this._originalElements;\n  }\n}\n", "import type * as V0VRM from '@pixiv/types-vrm-0.0';\nimport type * as V1SpringBoneSchema from '@pixiv/types-vrmc-springbone-1.0';\nimport * as THREE from 'three';\nimport type { GLTF, GLTFLoaderPlugin, GLTFParser } from 'three/examples/jsm/loaders/GLTFLoader.js';\nimport { VRMSpringBoneColliderHelper, VRMSpringBoneJointHelper } from './helpers';\nimport { VRMSpringBoneCollider } from './VRMSpringBoneCollider';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport { VRMSpringBoneColliderShapeCapsule } from './VRMSpringBoneColliderShapeCapsule';\nimport { VRMSpringBoneColliderShapeSphere } from './VRMSpringBoneColliderShapeSphere';\nimport { VRMSpringBoneJoint } from './VRMSpringBoneJoint';\nimport type { VRMSpringBoneLoaderPluginOptions } from './VRMSpringBoneLoaderPluginOptions';\nimport { VRMSpringBoneManager } from './VRMSpringBoneManager';\nimport type { VRMSpringBoneJointSettings } from './VRMSpringBoneJointSettings';\nimport { GLTF as GLTFSchema } from '@gltf-transform/core';\n\n/**\n * Possible spec versions it recognizes.\n */\nconst POSSIBLE_SPEC_VERSIONS = new Set(['1.0', '1.0-beta']);\n\nexport class VRMSpringBoneLoaderPlugin implements GLTFLoaderPlugin {\n  public static readonly EXTENSION_NAME = 'VRMC_springBone';\n\n  /**\n   * Specify an Object3D to add {@link VRMSpringBoneJointHelper} s.\n   * If not specified, helper will not be created.\n   * If `renderOrder` is set to the root, helpers will copy the same `renderOrder` .\n   */\n  public jointHelperRoot?: THREE.Object3D;\n\n  /**\n   * Specify an Object3D to add {@link VRMSpringBoneJointHelper} s.\n   * If not specified, helper will not be created.\n   * If `renderOrder` is set to the root, helpers will copy the same `renderOrder` .\n   */\n  public colliderHelperRoot?: THREE.Object3D;\n\n  public readonly parser: GLTFParser;\n\n  public get name(): string {\n    return VRMSpringBoneLoaderPlugin.EXTENSION_NAME;\n  }\n\n  public constructor(parser: GLTFParser, options?: VRMSpringBoneLoaderPluginOptions) {\n    this.parser = parser;\n\n    this.jointHelperRoot = options?.jointHelperRoot;\n    this.colliderHelperRoot = options?.colliderHelperRoot;\n  }\n\n  public async afterRoot(gltf: GLTF): Promise<void> {\n    gltf.userData.vrmSpringBoneManager = await this._import(gltf);\n  }\n\n  /**\n   * Import spring bones from a GLTF and return a {@link VRMSpringBoneManager}.\n   * It might return `null` instead when it does not need to be created or something go wrong.\n   *\n   * @param gltf A parsed result of GLTF taken from GLTFLoader\n   */\n  private async _import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const v1Result = await this._v1Import(gltf);\n    if (v1Result != null) {\n      return v1Result;\n    }\n\n    const v0Result = await this._v0Import(gltf);\n    if (v0Result != null) {\n      return v0Result;\n    }\n\n    return null;\n  }\n\n  private async _v1Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const json = gltf.parser.json as GLTFSchema.IGLTF;\n\n    // early abort if it doesn't use spring bones\n    const isSpringBoneUsed = json.extensionsUsed?.indexOf(VRMSpringBoneLoaderPlugin.EXTENSION_NAME) !== -1;\n    if (!isSpringBoneUsed) {\n      return null;\n    }\n\n    const manager = new VRMSpringBoneManager();\n\n    const threeNodes: THREE.Object3D[] = await gltf.parser.getDependencies('node');\n\n    const extension = json.extensions?.[VRMSpringBoneLoaderPlugin.EXTENSION_NAME] as\n      | V1SpringBoneSchema.VRMCSpringBone\n      | undefined;\n    if (!extension) {\n      return null;\n    }\n\n    const specVersion = extension.specVersion;\n    if (!POSSIBLE_SPEC_VERSIONS.has(specVersion)) {\n      console.warn(\n        `VRMSpringBoneLoaderPlugin: Unknown ${VRMSpringBoneLoaderPlugin.EXTENSION_NAME} specVersion \"${specVersion}\"`,\n      );\n      return null;\n    }\n\n    const colliders = extension.colliders?.map((schemaCollider, iCollider) => {\n      const node = threeNodes[schemaCollider.node!];\n      const schemaShape = schemaCollider.shape!;\n\n      if (schemaShape.sphere) {\n        return this._importSphereCollider(node, {\n          offset: new THREE.Vector3().fromArray(schemaShape.sphere.offset ?? [0.0, 0.0, 0.0]),\n          radius: schemaShape.sphere.radius ?? 0.0,\n        });\n      } else if (schemaShape.capsule) {\n        return this._importCapsuleCollider(node, {\n          offset: new THREE.Vector3().fromArray(schemaShape.capsule.offset ?? [0.0, 0.0, 0.0]),\n          radius: schemaShape.capsule.radius ?? 0.0,\n          tail: new THREE.Vector3().fromArray(schemaShape.capsule.tail ?? [0.0, 0.0, 0.0]),\n        });\n      }\n\n      throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${iCollider} has no valid shape`);\n    });\n\n    const colliderGroups = extension.colliderGroups?.map(\n      (schemaColliderGroup, iColliderGroup): VRMSpringBoneColliderGroup => {\n        const cols = (schemaColliderGroup.colliders ?? []).map((iCollider) => {\n          const col = colliders?.[iCollider];\n\n          if (col == null) {\n            throw new Error(\n              `VRMSpringBoneLoaderPlugin: The colliderGroup #${iColliderGroup} attempted to use a collider #${iCollider} but not found`,\n            );\n          }\n\n          return col;\n        });\n\n        return {\n          colliders: cols,\n          name: schemaColliderGroup.name,\n        };\n      },\n    );\n\n    extension.springs?.forEach((schemaSpring, iSpring) => {\n      const schemaJoints = schemaSpring.joints;\n\n      // prepare colliders\n      const colliderGroupsForSpring = schemaSpring.colliderGroups?.map((iColliderGroup) => {\n        const group = colliderGroups?.[iColliderGroup];\n\n        if (group == null) {\n          throw new Error(\n            `VRMSpringBoneLoaderPlugin: The spring #${iSpring} attempted to use a colliderGroup ${iColliderGroup} but not found`,\n          );\n        }\n\n        return group;\n      });\n\n      const center = schemaSpring.center != null ? threeNodes[schemaSpring.center] : undefined;\n\n      let prevSchemaJoint: V1SpringBoneSchema.SpringBoneJoint | undefined;\n      schemaJoints.forEach((schemaJoint) => {\n        if (prevSchemaJoint) {\n          // prepare node\n          const nodeIndex = prevSchemaJoint.node;\n          const node = threeNodes[nodeIndex];\n          const childIndex = schemaJoint.node;\n          const child = threeNodes[childIndex];\n\n          // prepare setting\n          const setting: Partial<VRMSpringBoneJointSettings> = {\n            hitRadius: prevSchemaJoint.hitRadius,\n            dragForce: prevSchemaJoint.dragForce,\n            gravityPower: prevSchemaJoint.gravityPower,\n            stiffness: prevSchemaJoint.stiffness,\n            gravityDir:\n              prevSchemaJoint.gravityDir != null\n                ? new THREE.Vector3().fromArray(prevSchemaJoint.gravityDir)\n                : undefined,\n          };\n\n          // create spring bones\n          const joint = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          if (center) {\n            joint.center = center;\n          }\n\n          manager.addJoint(joint);\n        }\n\n        prevSchemaJoint = schemaJoint;\n      });\n    });\n\n    // init spring bones\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private async _v0Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const json = gltf.parser.json as GLTFSchema.IGLTF;\n\n    // early abort if it doesn't use vrm\n    const isVRMUsed = json.extensionsUsed?.indexOf('VRM') !== -1;\n    if (!isVRMUsed) {\n      return null;\n    }\n\n    // early abort if it doesn't have bone groups\n    const extension = json.extensions?.['VRM'] as V0VRM.VRM | undefined;\n    const schemaSecondaryAnimation = extension?.secondaryAnimation;\n    if (!schemaSecondaryAnimation) {\n      return null;\n    }\n\n    const schemaBoneGroups = schemaSecondaryAnimation?.boneGroups;\n    if (!schemaBoneGroups) {\n      return null;\n    }\n\n    const manager = new VRMSpringBoneManager();\n\n    const threeNodes: THREE.Object3D[] = await gltf.parser.getDependencies('node');\n\n    const colliderGroups = schemaSecondaryAnimation.colliderGroups?.map(\n      (schemaColliderGroup): VRMSpringBoneColliderGroup => {\n        const node = threeNodes[schemaColliderGroup.node!];\n        const colliders = (schemaColliderGroup.colliders ?? []).map((schemaCollider, iCollider) => {\n          const offset = new THREE.Vector3(0.0, 0.0, 0.0);\n          if (schemaCollider.offset) {\n            offset.set(\n              schemaCollider.offset.x ?? 0.0,\n              schemaCollider.offset.y ?? 0.0,\n              schemaCollider.offset.z ? -schemaCollider.offset.z : 0.0, // z is opposite in VRM0.0\n            );\n          }\n\n          return this._importSphereCollider(node, {\n            offset,\n            radius: schemaCollider.radius ?? 0.0,\n          });\n        });\n\n        return { colliders };\n      },\n    );\n\n    // import spring bones for each spring bone groups\n    schemaBoneGroups?.forEach((schemaBoneGroup, iBoneGroup) => {\n      const rootIndices = schemaBoneGroup.bones;\n      if (!rootIndices) {\n        return;\n      }\n\n      rootIndices.forEach((rootIndex) => {\n        const root = threeNodes[rootIndex];\n\n        // prepare setting\n        const gravityDir = new THREE.Vector3();\n        if (schemaBoneGroup.gravityDir) {\n          gravityDir.set(\n            schemaBoneGroup.gravityDir.x ?? 0.0,\n            schemaBoneGroup.gravityDir.y ?? 0.0,\n            schemaBoneGroup.gravityDir.z ?? 0.0,\n          );\n        } else {\n          gravityDir.set(0.0, -1.0, 0.0);\n        }\n\n        const center = schemaBoneGroup.center != null ? threeNodes[schemaBoneGroup.center] : undefined;\n\n        const setting: Partial<VRMSpringBoneJointSettings> = {\n          hitRadius: schemaBoneGroup.hitRadius,\n          dragForce: schemaBoneGroup.dragForce,\n          gravityPower: schemaBoneGroup.gravityPower,\n          stiffness: schemaBoneGroup.stiffiness,\n          gravityDir,\n        };\n\n        // prepare colliders\n        const colliderGroupsForSpring = schemaBoneGroup.colliderGroups?.map((iColliderGroup) => {\n          const group = colliderGroups?.[iColliderGroup];\n\n          if (group == null) {\n            throw new Error(\n              `VRMSpringBoneLoaderPlugin: The spring #${iBoneGroup} attempted to use a colliderGroup ${iColliderGroup} but not found`,\n            );\n          }\n\n          return group;\n        });\n\n        // create spring bones\n        root.traverse((node) => {\n          const child: THREE.Object3D | null = node.children[0] ?? null;\n\n          const joint = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          if (center) {\n            joint.center = center;\n          }\n\n          manager.addJoint(joint);\n        });\n      });\n    });\n\n    // init spring bones\n    gltf.scene.updateMatrixWorld();\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private _importJoint(\n    node: THREE.Object3D,\n    child: THREE.Object3D,\n    setting?: Partial<VRMSpringBoneJointSettings>,\n    colliderGroupsForSpring?: VRMSpringBoneColliderGroup[],\n  ): VRMSpringBoneJoint {\n    const springBone = new VRMSpringBoneJoint(node, child, setting, colliderGroupsForSpring);\n\n    if (this.jointHelperRoot) {\n      const helper = new VRMSpringBoneJointHelper(springBone);\n      this.jointHelperRoot.add(helper);\n      helper.renderOrder = this.jointHelperRoot.renderOrder;\n    }\n\n    return springBone;\n  }\n\n  private _importSphereCollider(\n    destination: THREE.Object3D,\n    params: {\n      offset: THREE.Vector3;\n      radius: number;\n    },\n  ): VRMSpringBoneCollider {\n    const { offset, radius } = params;\n\n    const shape = new VRMSpringBoneColliderShapeSphere({ offset, radius });\n\n    const collider = new VRMSpringBoneCollider(shape);\n\n    destination.add(collider);\n\n    if (this.colliderHelperRoot) {\n      const helper = new VRMSpringBoneColliderHelper(collider);\n      this.colliderHelperRoot.add(helper);\n      helper.renderOrder = this.colliderHelperRoot.renderOrder;\n    }\n\n    return collider;\n  }\n\n  private _importCapsuleCollider(\n    destination: THREE.Object3D,\n    params: {\n      offset: THREE.Vector3;\n      radius: number;\n      tail: THREE.Vector3;\n    },\n  ): VRMSpringBoneCollider {\n    const { offset, radius, tail } = params;\n\n    const shape = new VRMSpringBoneColliderShapeCapsule({ offset, radius, tail });\n\n    const collider = new VRMSpringBoneCollider(shape);\n\n    destination.add(collider);\n\n    if (this.colliderHelperRoot) {\n      const helper = new VRMSpringBoneColliderHelper(collider);\n      this.colliderHelperRoot.add(helper);\n      helper.renderOrder = this.colliderHelperRoot.renderOrder;\n    }\n\n    return collider;\n  }\n}\n", "import type * as THREE from 'three';\n\nexport function traverseAncestorsFromRoot(object: THREE.Object3D, callback: (object: THREE.Object3D) => void): void {\n  const ancestors: THREE.Object3D[] = [];\n\n  let head: THREE.Object3D | null = object;\n  while (head !== null) {\n    ancestors.unshift(head);\n    head = head.parent;\n  }\n\n  ancestors.forEach((ancestor) => {\n    callback(ancestor);\n  });\n}\n", "import type * as THREE from 'three';\n\n/**\n * Traverse children of given object and execute given callback.\n * The given object itself wont be given to the callback.\n * If the return value of the callback is `true`, it will halt the traversal of its children.\n * @param object A root object\n * @param callback A callback function called for each children\n */\nexport function traverseChildrenUntilConditionMet(\n  object: THREE.Object3D,\n  callback: (object: THREE.Object3D) => boolean,\n): void {\n  object.children.forEach((child) => {\n    const result = callback(child);\n    if (!result) {\n      traverseChildrenUntilConditionMet(child, callback);\n    }\n  });\n}\n", "import type * as THREE from 'three';\nimport type { VRMSpringBoneJoint } from './VRMSpringBoneJoint';\nimport { traverseAncestorsFromRoot } from './utils/traverseAncestorsFromRoot';\nimport type { VRMSpringBoneCollider } from './VRMSpringBoneCollider';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport { traverseChildrenUntilConditionMet } from './utils/traverseChildrenUntilConditionMet';\n\nexport class VRMSpringBoneManager {\n  private _joints = new Set<VRMSpringBoneJoint>();\n  public get joints(): Set<VRMSpringBoneJoint> {\n    return this._joints;\n  }\n\n  /**\n   * @deprecated Use {@link joints} instead.\n   */\n  public get springBones(): Set<VRMSpringBoneJoint> {\n    console.warn('VRMSpringBoneManager: springBones is deprecated. use joints instead.');\n\n    return this._joints;\n  }\n\n  public get colliderGroups(): VRMSpringBoneColliderGroup[] {\n    const set = new Set<VRMSpringBoneColliderGroup>();\n    this._joints.forEach((springBone) => {\n      springBone.colliderGroups.forEach((colliderGroup) => {\n        set.add(colliderGroup);\n      });\n    });\n    return Array.from(set);\n  }\n\n  public get colliders(): VRMSpringBoneCollider[] {\n    const set = new Set<VRMSpringBoneCollider>();\n    this.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        set.add(collider);\n      });\n    });\n    return Array.from(set);\n  }\n\n  private _objectSpringBonesMap = new Map<THREE.Object3D, Set<VRMSpringBoneJoint>>();\n\n  public addJoint(joint: VRMSpringBoneJoint): void {\n    this._joints.add(joint);\n\n    let objectSet = this._objectSpringBonesMap.get(joint.bone);\n    if (objectSet == null) {\n      objectSet = new Set<VRMSpringBoneJoint>();\n      this._objectSpringBonesMap.set(joint.bone, objectSet);\n    }\n    objectSet.add(joint);\n  }\n\n  /**\n   * @deprecated Use {@link addJoint} instead.\n   */\n  public addSpringBone(joint: VRMSpringBoneJoint): void {\n    console.warn('VRMSpringBoneManager: addSpringBone() is deprecated. use addJoint() instead.');\n\n    this.addJoint(joint);\n  }\n\n  public deleteJoint(joint: VRMSpringBoneJoint): void {\n    this._joints.delete(joint);\n\n    const objectSet = this._objectSpringBonesMap.get(joint.bone)!;\n    objectSet.delete(joint);\n  }\n\n  /**\n   * @deprecated Use {@link deleteJoint} instead.\n   */\n  public deleteSpringBone(joint: VRMSpringBoneJoint): void {\n    console.warn('VRMSpringBoneManager: deleteSpringBone() is deprecated. use deleteJoint() instead.');\n\n    this.deleteJoint(joint);\n  }\n\n  public setInitState(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.setInitState(),\n      );\n    }\n  }\n\n  public reset(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.reset(),\n      );\n    }\n  }\n\n  public update(delta: number): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      // update the springbone\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.update(delta),\n      );\n\n      // update children world matrices\n      // it is required when the spring bone chain is sparse\n      traverseChildrenUntilConditionMet(springBone.bone, (object) => {\n        // if the object has attached springbone, halt the traversal\n        if ((this._objectSpringBonesMap.get(object)?.size ?? 0) > 0) {\n          return true;\n        }\n\n        // otherwise update its world matrix\n        object.updateWorldMatrix(false, false);\n        return false;\n      });\n    }\n  }\n\n  /**\n   * Update a spring bone.\n   * If there are other spring bone that are dependant, it will try to update them recursively.\n   * It updates matrixWorld of all ancestors and myself.\n   * It might throw an error if there are circular dependencies.\n   *\n   * Intended to be used in {@link update} and {@link _processSpringBone} itself recursively.\n   *\n   * @param springBone A springBone you want to update\n   * @param springBonesTried Set of springBones that are already tried to be updated\n   * @param springBonesDone Set of springBones that are already up to date\n   * @param objectUpdated Set of object3D whose matrixWorld is updated\n   */\n  private _processSpringBone(\n    springBone: VRMSpringBoneJoint,\n    springBonesTried: Set<VRMSpringBoneJoint>,\n    springBonesDone: Set<VRMSpringBoneJoint>,\n    objectUpdated: Set<THREE.Object3D>,\n    callback: (springBone: VRMSpringBoneJoint) => void,\n  ): void {\n    if (springBonesDone.has(springBone)) {\n      return;\n    }\n\n    if (springBonesTried.has(springBone)) {\n      throw new Error('VRMSpringBoneManager: Circular dependency detected while updating springbones');\n    }\n    springBonesTried.add(springBone);\n\n    const depObjects = this._getDependencies(springBone);\n    for (const depObject of depObjects) {\n      traverseAncestorsFromRoot(depObject, (depObjectAncestor) => {\n        const objectSet = this._objectSpringBonesMap.get(depObjectAncestor);\n        if (objectSet) {\n          for (const depSpringBone of objectSet) {\n            this._processSpringBone(depSpringBone, springBonesTried, springBonesDone, objectUpdated, callback);\n          }\n        } else if (!objectUpdated.has(depObjectAncestor)) {\n          // update matrix of non-springbone\n          depObjectAncestor.updateWorldMatrix(false, false);\n          objectUpdated.add(depObjectAncestor);\n        }\n      });\n    }\n\n    // update my matrix\n    springBone.bone.updateMatrix();\n    springBone.bone.updateWorldMatrix(false, false);\n\n    callback(springBone);\n\n    objectUpdated.add(springBone.bone);\n\n    springBonesDone.add(springBone);\n  }\n\n  /**\n   * Return a set of objects that are dependant of given spring bone.\n   * @param springBone A spring bone\n   * @return A set of objects that are dependant of given spring bone\n   */\n  private _getDependencies(springBone: VRMSpringBoneJoint): Set<THREE.Object3D> {\n    const set = new Set<THREE.Object3D>();\n\n    const parent = springBone.bone.parent;\n    if (parent) {\n      set.add(parent);\n    }\n\n    springBone.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        set.add(collider);\n      });\n    });\n\n    return set;\n  }\n}\n"],
  "mappings": "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",
  "names": ["THREE", "THREE", "THREE", "_v3A", "THREE", "_v3A", "THREE", "THREE", "_v3A", "THREE", "THREE", "THREE", "THREE", "_v3A", "_v3B", "_matA", "THREE", "springBone", "_a", "_b", "_c", "_d", "_e"]
}

1233
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/helpers/VRMSpringBoneColliderHelper.ts", "../src/VRMSpringBoneColliderShapeCapsule.ts", "../src/VRMSpringBoneColliderShape.ts", "../src/VRMSpringBoneColliderShapePlane.ts", "../src/VRMSpringBoneColliderShapeSphere.ts", "../src/helpers/utils/ColliderShapeCapsuleBufferGeometry.ts", "../src/helpers/utils/ColliderShapePlaneBufferGeometry.ts", "../src/helpers/utils/ColliderShapeSphereBufferGeometry.ts", "../src/helpers/VRMSpringBoneJointHelper.ts", "../src/helpers/utils/SpringBoneBufferGeometry.ts", "../src/VRMSpringBoneCollider.ts", "../src/VRMSpringBoneJoint.ts", "../src/utils/mat4InvertCompat.ts", "../src/utils/Matrix4InverseCache.ts", "../src/VRMSpringBoneLoaderPlugin.ts", "../src/utils/traverseAncestorsFromRoot.ts", "../src/utils/traverseChildrenUntilConditionMet.ts", "../src/VRMSpringBoneManager.ts"],
  "sourcesContent": ["import * as THREE from 'three';\nimport { VRMSpringBoneCollider } from '../VRMSpringBoneCollider';\nimport { VRMSpringBoneColliderShapeCapsule } from '../VRMSpringBoneColliderShapeCapsule';\nimport { VRMSpringBoneColliderShapePlane } from '../VRMSpringBoneColliderShapePlane';\nimport { VRMSpringBoneColliderShapeSphere } from '../VRMSpringBoneColliderShapeSphere';\nimport { ColliderShapeBufferGeometry } from './utils/ColliderShapeBufferGeometry';\nimport { ColliderShapeCapsuleBufferGeometry } from './utils/ColliderShapeCapsuleBufferGeometry';\nimport { ColliderShapePlaneBufferGeometry } from './utils/ColliderShapePlaneBufferGeometry';\nimport { ColliderShapeSphereBufferGeometry } from './utils/ColliderShapeSphereBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class VRMSpringBoneColliderHelper extends THREE.Group {\n  public readonly collider: VRMSpringBoneCollider;\n  private readonly _geometry: ColliderShapeBufferGeometry;\n  private readonly _line: THREE.LineSegments;\n\n  public constructor(collider: VRMSpringBoneCollider) {\n    super();\n    this.matrixAutoUpdate = false;\n\n    this.collider = collider;\n\n    if (this.collider.shape instanceof VRMSpringBoneColliderShapeSphere) {\n      this._geometry = new ColliderShapeSphereBufferGeometry(this.collider.shape);\n    } else if (this.collider.shape instanceof VRMSpringBoneColliderShapeCapsule) {\n      this._geometry = new ColliderShapeCapsuleBufferGeometry(this.collider.shape);\n    } else if (this.collider.shape instanceof VRMSpringBoneColliderShapePlane) {\n      this._geometry = new ColliderShapePlaneBufferGeometry(this.collider.shape);\n    } else {\n      throw new Error('VRMSpringBoneColliderHelper: Unknown collider shape type detected');\n    }\n\n    const material = new THREE.LineBasicMaterial({\n      color: 0xff00ff,\n      depthTest: false,\n      depthWrite: false,\n    });\n\n    this._line = new THREE.LineSegments(this._geometry, material);\n    this.add(this._line);\n  }\n\n  public dispose(): void {\n    this._geometry.dispose();\n  }\n\n  public updateMatrixWorld(force: boolean): void {\n    this.collider.updateWorldMatrix(true, false);\n\n    this.matrix.copy(this.collider.matrixWorld);\n\n    const matrixWorldElements = this.matrix.elements;\n    this._geometry.worldScale = _v3A\n      .set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2])\n      .length(); // calculate scale of x component\n\n    this._geometry.update();\n\n    super.updateMatrixWorld(force);\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\n\nexport class VRMSpringBoneColliderShapeCapsule extends VRMSpringBoneColliderShape {\n  public get type(): 'capsule' {\n    return 'capsule';\n  }\n\n  /**\n   * The offset of the capsule head from the origin in local space.\n   */\n  public offset: THREE.Vector3;\n\n  /**\n   * The offset of the capsule tail from the origin in local space.\n   */\n  public tail: THREE.Vector3;\n\n  /**\n   * The radius of the capsule.\n   */\n  public radius: number;\n\n  /**\n   * If true, the collider prevents spring bones from going outside of the capsule instead.\n   */\n  public inside: boolean;\n\n  public constructor(params?: { radius?: number; offset?: THREE.Vector3; tail?: THREE.Vector3; inside?: boolean }) {\n    super();\n\n    this.offset = params?.offset ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.tail = params?.tail ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.radius = params?.radius ?? 0.0;\n    this.inside = params?.inside ?? false;\n  }\n\n  public calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number {\n    _v3A.copy(this.offset).applyMatrix4(colliderMatrix); // transformed head\n    _v3B.copy(this.tail).applyMatrix4(colliderMatrix); // transformed tail\n    _v3B.sub(_v3A); // from head to tail\n    const lengthSqCapsule = _v3B.lengthSq();\n\n    target.copy(objectPosition).sub(_v3A); // from head to object\n    const dot = _v3B.dot(target); // dot product of offsetToTail and offsetToObject\n\n    if (dot <= 0.0) {\n      // if object is near from the head\n      // do nothing, use the current value directly\n    } else if (lengthSqCapsule <= dot) {\n      // if object is near from the tail\n      target.sub(_v3B); // from tail to object\n    } else {\n      // if object is between two ends\n      _v3B.multiplyScalar(dot / lengthSqCapsule); // from head to the nearest point of the shaft\n      target.sub(_v3B); // from the shaft point to object\n    }\n\n    const distance = this.inside\n      ? this.radius - objectRadius - target.length()\n      : target.length() - objectRadius - this.radius;\n\n    target.normalize(); // convert the delta to the direction\n    if (this.inside) {\n      target.negate(); // if inside, reverse the direction\n    }\n\n    return distance;\n  }\n}\n", "import type * as THREE from 'three';\n\n/**\n * Represents a shape of a collider.\n */\nexport abstract class VRMSpringBoneColliderShape {\n  /**\n   * The type of the shape.\n   */\n  public abstract get type(): string;\n\n  /**\n   * Calculate a distance and a direction from the collider to a target object.\n   * It's hit if the distance is negative.\n   * The direction will be contained in the given target vector.\n   *\n   * @param colliderMatrix A matrix represents the transform of the collider\n   * @param objectPosition A vector represents the position of the target object\n   * @param objectRadius The radius of the object\n   * @param target The result direction will be contained in this vector\n   */\n  public abstract calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number;\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\nconst _v3A = new THREE.Vector3();\nconst _mat3A = new THREE.Matrix3();\n\nexport class VRMSpringBoneColliderShapePlane extends VRMSpringBoneColliderShape {\n  public get type(): 'plane' {\n    return 'plane';\n  }\n\n  /**\n   * The offset of the plane from the origin in local space.\n   */\n  public offset: THREE.Vector3;\n\n  /**\n   * The normal of the plane in local space. Must be normalized.\n   */\n  public normal: THREE.Vector3;\n\n  public constructor(params?: { offset?: THREE.Vector3; normal?: THREE.Vector3 }) {\n    super();\n\n    this.offset = params?.offset ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.normal = params?.normal ?? new THREE.Vector3(0.0, 0.0, 1.0);\n  }\n\n  public calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number {\n    target.copy(this.offset).applyMatrix4(colliderMatrix); // transformed offset\n    target.negate().add(objectPosition); // a vector from collider center to object position\n\n    _mat3A.getNormalMatrix(colliderMatrix); // convert the collider matrix to the normal matrix\n    _v3A.copy(this.normal).applyNormalMatrix(_mat3A).normalize(); // transformed normal\n    const distance = target.dot(_v3A) - objectRadius;\n\n    target.copy(_v3A); // convert the delta to the direction\n\n    return distance;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\nexport class VRMSpringBoneColliderShapeSphere extends VRMSpringBoneColliderShape {\n  public get type(): 'sphere' {\n    return 'sphere';\n  }\n\n  /**\n   * The offset of the sphere from the origin in local space.\n   */\n  public offset: THREE.Vector3;\n\n  /**\n   * The radius.\n   */\n  public radius: number;\n\n  /**\n   * If true, the collider prevents spring bones from going outside of the sphere instead.\n   */\n  public inside: boolean;\n\n  public constructor(params?: { radius?: number; offset?: THREE.Vector3; inside?: boolean }) {\n    super();\n\n    this.offset = params?.offset ?? new THREE.Vector3(0.0, 0.0, 0.0);\n    this.radius = params?.radius ?? 0.0;\n    this.inside = params?.inside ?? false;\n  }\n\n  public calculateCollision(\n    colliderMatrix: THREE.Matrix4,\n    objectPosition: THREE.Vector3,\n    objectRadius: number,\n    target: THREE.Vector3,\n  ): number {\n    target.copy(this.offset).applyMatrix4(colliderMatrix); // transformed offset\n    target.negate().add(objectPosition); // a vector from collider center to object position\n\n    const distance = this.inside\n      ? this.radius - objectRadius - target.length()\n      : target.length() - objectRadius - this.radius;\n\n    target.normalize(); // convert the delta to the direction\n    if (this.inside) {\n      target.negate(); // if inside, reverse the direction\n    }\n\n    return distance;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShapeCapsule } from '../../VRMSpringBoneColliderShapeCapsule';\nimport { ColliderShapeBufferGeometry } from './ColliderShapeBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class ColliderShapeCapsuleBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _shape: VRMSpringBoneColliderShapeCapsule;\n  private _currentRadius = 0;\n  private readonly _currentOffset = new THREE.Vector3();\n  private readonly _currentTail = new THREE.Vector3();\n\n  public constructor(shape: VRMSpringBoneColliderShapeCapsule) {\n    super();\n\n    this._shape = shape;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(396), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(264), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._shape.radius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentOffset.equals(this._shape.offset)) {\n      this._currentOffset.copy(this._shape.offset);\n      shouldUpdateGeometry = true;\n    }\n\n    const tail = _v3A.copy(this._shape.tail).divideScalar(this.worldScale);\n    if (this._currentTail.distanceToSquared(tail) > 1e-10) {\n      this._currentTail.copy(tail);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    _v3A.copy(this._currentTail).sub(this._currentOffset);\n    const l = _v3A.length() / this._currentRadius;\n\n    for (let i = 0; i <= 16; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, -Math.sin(t), -Math.cos(t), 0.0);\n      this._attrPos.setXYZ(17 + i, l + Math.sin(t), Math.cos(t), 0.0);\n      this._attrPos.setXYZ(34 + i, -Math.sin(t), 0.0, -Math.cos(t));\n      this._attrPos.setXYZ(51 + i, l + Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n      this._attrPos.setXYZ(68 + i, 0.0, Math.sin(t), Math.cos(t));\n      this._attrPos.setXYZ(100 + i, l, Math.sin(t), Math.cos(t));\n    }\n\n    const theta = Math.atan2(_v3A.y, Math.sqrt(_v3A.x * _v3A.x + _v3A.z * _v3A.z));\n    const phi = -Math.atan2(_v3A.z, _v3A.x);\n\n    this.rotateZ(theta);\n    this.rotateY(phi);\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 34; i++) {\n      const i1 = (i + 1) % 34;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(68 + i * 2, 34 + i, 34 + i1);\n    }\n\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(136 + i * 2, 68 + i, 68 + i1);\n      this._attrIndex.setXY(200 + i * 2, 100 + i, 100 + i1);\n    }\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShapePlane } from '../../VRMSpringBoneColliderShapePlane';\nimport { ColliderShapeBufferGeometry } from './ColliderShapeBufferGeometry';\n\nexport class ColliderShapePlaneBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _shape: VRMSpringBoneColliderShapePlane;\n  private readonly _currentOffset = new THREE.Vector3();\n  private readonly _currentNormal = new THREE.Vector3();\n\n  public constructor(shape: VRMSpringBoneColliderShapePlane) {\n    super();\n\n    this._shape = shape;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(6 * 3), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(10), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    if (!this._currentOffset.equals(this._shape.offset)) {\n      this._currentOffset.copy(this._shape.offset);\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentNormal.equals(this._shape.normal)) {\n      this._currentNormal.copy(this._shape.normal);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    this._attrPos.setXYZ(0, -0.5, -0.5, 0);\n    this._attrPos.setXYZ(1, 0.5, -0.5, 0);\n    this._attrPos.setXYZ(2, 0.5, 0.5, 0);\n    this._attrPos.setXYZ(3, -0.5, 0.5, 0);\n    this._attrPos.setXYZ(4, 0, 0, 0);\n    this._attrPos.setXYZ(5, 0, 0, 0.25);\n\n    this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);\n    this.lookAt(this._currentNormal);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    this._attrIndex.setXY(0, 0, 1);\n    this._attrIndex.setXY(2, 1, 2);\n    this._attrIndex.setXY(4, 2, 3);\n    this._attrIndex.setXY(6, 3, 0);\n    this._attrIndex.setXY(8, 4, 5);\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneColliderShapeSphere } from '../../VRMSpringBoneColliderShapeSphere';\nimport { ColliderShapeBufferGeometry } from './ColliderShapeBufferGeometry';\n\nexport class ColliderShapeSphereBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _shape: VRMSpringBoneColliderShapeSphere;\n  private _currentRadius = 0;\n  private readonly _currentOffset = new THREE.Vector3();\n\n  public constructor(shape: VRMSpringBoneColliderShapeSphere) {\n    super();\n\n    this._shape = shape;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(32 * 3 * 3), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(64 * 3), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._shape.radius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentOffset.equals(this._shape.offset)) {\n      this._currentOffset.copy(this._shape.offset);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);\n      this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));\n      this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);\n      this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);\n    }\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneJoint } from '../VRMSpringBoneJoint';\nimport { SpringBoneBufferGeometry } from './utils/SpringBoneBufferGeometry';\n\nconst _v3A = new THREE.Vector3();\n\nexport class VRMSpringBoneJointHelper extends THREE.Group {\n  public readonly springBone: VRMSpringBoneJoint;\n  private readonly _geometry: SpringBoneBufferGeometry;\n  private readonly _line: THREE.LineSegments;\n\n  public constructor(springBone: VRMSpringBoneJoint) {\n    super();\n    this.matrixAutoUpdate = false;\n\n    this.springBone = springBone;\n\n    this._geometry = new SpringBoneBufferGeometry(this.springBone);\n\n    const material = new THREE.LineBasicMaterial({\n      color: 0xffff00,\n      depthTest: false,\n      depthWrite: false,\n    });\n\n    this._line = new THREE.LineSegments(this._geometry, material);\n    this.add(this._line);\n  }\n\n  public dispose(): void {\n    this._geometry.dispose();\n  }\n\n  public updateMatrixWorld(force: boolean): void {\n    this.springBone.bone.updateWorldMatrix(true, false);\n\n    this.matrix.copy(this.springBone.bone.matrixWorld);\n\n    const matrixWorldElements = this.matrix.elements;\n    this._geometry.worldScale = _v3A\n      .set(matrixWorldElements[0], matrixWorldElements[1], matrixWorldElements[2])\n      .length(); // calculate scale of x component\n\n    this._geometry.update();\n\n    super.updateMatrixWorld(force);\n  }\n}\n", "import * as THREE from 'three';\nimport { VRMSpringBoneJoint } from '../../VRMSpringBoneJoint';\n\nexport class SpringBoneBufferGeometry extends THREE.BufferGeometry {\n  public worldScale = 1.0;\n\n  private readonly _attrPos: THREE.BufferAttribute;\n  private readonly _attrIndex: THREE.BufferAttribute;\n  private readonly _springBone: VRMSpringBoneJoint;\n  private _currentRadius = 0;\n  private readonly _currentTail = new THREE.Vector3();\n\n  public constructor(springBone: VRMSpringBoneJoint) {\n    super();\n\n    this._springBone = springBone;\n\n    this._attrPos = new THREE.BufferAttribute(new Float32Array(294), 3);\n    this.setAttribute('position', this._attrPos);\n\n    this._attrIndex = new THREE.BufferAttribute(new Uint16Array(194), 1);\n    this.setIndex(this._attrIndex);\n\n    this._buildIndex();\n    this.update();\n  }\n\n  public update(): void {\n    let shouldUpdateGeometry = false;\n\n    const radius = this._springBone.settings.hitRadius / this.worldScale;\n    if (this._currentRadius !== radius) {\n      this._currentRadius = radius;\n      shouldUpdateGeometry = true;\n    }\n\n    if (!this._currentTail.equals(this._springBone.initialLocalChildPosition)) {\n      this._currentTail.copy(this._springBone.initialLocalChildPosition);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    for (let i = 0; i < 32; i++) {\n      const t = (i / 16.0) * Math.PI;\n\n      this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);\n      this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));\n      this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));\n    }\n\n    this.scale(this._currentRadius, this._currentRadius, this._currentRadius);\n    this.translate(this._currentTail.x, this._currentTail.y, this._currentTail.z);\n\n    this._attrPos.setXYZ(96, 0, 0, 0);\n    this._attrPos.setXYZ(97, this._currentTail.x, this._currentTail.y, this._currentTail.z);\n\n    this._attrPos.needsUpdate = true;\n  }\n\n  private _buildIndex(): void {\n    for (let i = 0; i < 32; i++) {\n      const i1 = (i + 1) % 32;\n\n      this._attrIndex.setXY(i * 2, i, i1);\n      this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);\n      this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);\n    }\n    this._attrIndex.setXY(192, 96, 97);\n\n    this._attrIndex.needsUpdate = true;\n  }\n}\n", "import * as THREE from 'three';\nimport type { VRMSpringBoneColliderShape } from './VRMSpringBoneColliderShape';\n\n/**\n * Represents a collider of a VRM.\n */\nexport class VRMSpringBoneCollider extends THREE.Object3D {\n  /**\n   * The shape of the collider.\n   */\n  public readonly shape: VRMSpringBoneColliderShape;\n\n  public constructor(shape: VRMSpringBoneColliderShape) {\n    super();\n\n    this.shape = shape;\n  }\n}\n", "import * as THREE from 'three';\nimport { mat4InvertCompat } from './utils/mat4InvertCompat';\nimport { Matrix4InverseCache } from './utils/Matrix4InverseCache';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport type { VRMSpringBoneJointSettings } from './VRMSpringBoneJointSettings';\n\n// based on\n// http://rocketjump.skr.jp/unity3d/109/\n// https://github.com/dwango/UniVRM/blob/master/Scripts/SpringBone/VRMSpringBone.cs\n\nconst IDENTITY_MATRIX4 = new THREE.Matrix4();\n\n// \u8A08\u7B97\u4E2D\u306E\u4E00\u6642\u4FDD\u5B58\u7528\u5909\u6570\uFF08\u4E00\u5EA6\u30A4\u30F3\u30B9\u30BF\u30F3\u30B9\u3092\u4F5C\u3063\u305F\u3089\u3042\u3068\u306F\u4F7F\u3044\u56DE\u3059\uFF09\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\nconst _v3C = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _worldSpacePosition = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _centerSpacePosition = new THREE.Vector3();\n\n/**\n * A temporary variable which is used in `update`\n */\nconst _nextTail = new THREE.Vector3();\n\nconst _quatA = new THREE.Quaternion();\nconst _matA = new THREE.Matrix4();\nconst _matB = new THREE.Matrix4();\n\n/**\n * A class represents a single joint of a spring bone.\n * It should be managed by a [[VRMSpringBoneManager]].\n */\nexport class VRMSpringBoneJoint {\n  /**\n   * Settings of the bone.\n   */\n  public settings: VRMSpringBoneJointSettings;\n\n  /**\n   * Collider groups attached to this bone.\n   */\n  public colliderGroups: VRMSpringBoneColliderGroup[];\n\n  /**\n   * An Object3D attached to this bone.\n   */\n  public readonly bone: THREE.Object3D;\n\n  /**\n   * An Object3D that will be used as a tail of this spring bone.\n   * It can be null when the spring bone is imported from VRM 0.0.\n   */\n  public readonly child: THREE.Object3D | null;\n\n  /**\n   * Current position of child tail, in center unit. Will be used for verlet integration.\n   */\n  private _currentTail = new THREE.Vector3();\n\n  /**\n   * Previous position of child tail, in center unit. Will be used for verlet integration.\n   */\n  private _prevTail = new THREE.Vector3();\n\n  /**\n   * Initial axis of the bone, in local unit.\n   */\n  private _boneAxis = new THREE.Vector3();\n\n  /**\n   * Length of the bone in world unit.\n   * Will be used for normalization in update loop, will be updated by {@link _calcWorldSpaceBoneLength}.\n   *\n   * It's same as local unit length unless there are scale transformations in the world space.\n   */\n  private _worldSpaceBoneLength = 0.0;\n\n  /**\n   * This springbone will be calculated based on the space relative from this object.\n   * If this is `null`, springbone will be calculated in world space.\n   */\n  private _center: THREE.Object3D | null = null;\n  public get center(): THREE.Object3D | null {\n    return this._center;\n  }\n  public set center(center: THREE.Object3D | null) {\n    // uninstall inverse cache\n    if (this._center?.userData.inverseCacheProxy) {\n      (this._center.userData.inverseCacheProxy as Matrix4InverseCache).revert();\n      delete this._center.userData.inverseCacheProxy;\n    }\n\n    // change the center\n    this._center = center;\n\n    // install inverse cache\n    if (this._center) {\n      if (!this._center.userData.inverseCacheProxy) {\n        this._center.userData.inverseCacheProxy = new Matrix4InverseCache(this._center.matrixWorld);\n      }\n    }\n  }\n\n  /**\n   * Initial state of the local matrix of the bone.\n   */\n  private _initialLocalMatrix = new THREE.Matrix4();\n\n  /**\n   * Initial state of the rotation of the bone.\n   */\n  private _initialLocalRotation = new THREE.Quaternion();\n\n  /**\n   * Initial state of the position of its child.\n   */\n  private _initialLocalChildPosition = new THREE.Vector3();\n  public get initialLocalChildPosition(): THREE.Vector3 {\n    return this._initialLocalChildPosition;\n  }\n\n  /**\n   * Returns the world matrix of its parent object.\n   * Note that it returns a reference to the matrix. Don't mutate this directly!\n   */\n  private get _parentMatrixWorld(): THREE.Matrix4 {\n    return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;\n  }\n\n  /**\n   * Create a new VRMSpringBone.\n   *\n   * @param bone An Object3D that will be attached to this bone\n   * @param child An Object3D that will be used as a tail of this spring bone. It can be null when the spring bone is imported from VRM 0.0\n   * @param settings Several parameters related to behavior of the spring bone\n   * @param colliderGroups Collider groups that will be collided with this spring bone\n   */\n  constructor(\n    bone: THREE.Object3D,\n    child: THREE.Object3D | null,\n    settings: Partial<VRMSpringBoneJointSettings> = {},\n    colliderGroups: VRMSpringBoneColliderGroup[] = [],\n  ) {\n    this.bone = bone; // uniVRM\u3067\u306E parent\n    this.bone.matrixAutoUpdate = false; // update\u306B\u3088\u308A\u8A08\u7B97\u3055\u308C\u308B\u306E\u3067three.js\u5185\u3067\u306E\u81EA\u52D5\u51E6\u7406\u306F\u4E0D\u8981\n\n    this.child = child;\n\n    this.settings = {\n      hitRadius: settings.hitRadius ?? 0.0,\n      stiffness: settings.stiffness ?? 1.0,\n      gravityPower: settings.gravityPower ?? 0.0,\n      gravityDir: settings.gravityDir?.clone() ?? new THREE.Vector3(0.0, -1.0, 0.0),\n      dragForce: settings.dragForce ?? 0.4,\n    };\n\n    this.colliderGroups = colliderGroups;\n  }\n\n  /**\n   * Set the initial state of this spring bone.\n   * You might want to call {@link VRMSpringBoneManager.setInitState} instead.\n   */\n  public setInitState(): void {\n    // remember initial position of itself\n    this._initialLocalMatrix.copy(this.bone.matrix);\n    this._initialLocalRotation.copy(this.bone.quaternion);\n\n    // see initial position of its local child\n    if (this.child) {\n      this._initialLocalChildPosition.copy(this.child.position);\n    } else {\n      // vrm0 requires a 7cm fixed bone length for the final node in a chain\n      // See: https://github.com/vrm-c/vrm-specification/tree/master/specification/VRMC_springBone-1.0#about-spring-configuration\n      this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07);\n    }\n\n    // copy the child position to tails\n    const matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)).applyMatrix4(matrixWorldToCenter);\n    this._prevTail.copy(this._currentTail);\n\n    // set initial states that are related to local child position\n    this._boneAxis.copy(this._initialLocalChildPosition).normalize();\n  }\n\n  /**\n   * Reset the state of this bone.\n   * You might want to call [[VRMSpringBoneManager.reset]] instead.\n   */\n  public reset(): void {\n    this.bone.quaternion.copy(this._initialLocalRotation);\n\n    // We need to update its matrixWorld manually, since we tweaked the bone by our hand\n    this.bone.updateMatrix();\n    this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld, this.bone.matrix);\n\n    // Apply updated position to tail states\n    const matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition)).applyMatrix4(matrixWorldToCenter);\n    this._prevTail.copy(this._currentTail);\n  }\n\n  /**\n   * Update the state of this bone.\n   * You might want to call [[VRMSpringBoneManager.update]] instead.\n   *\n   * @param delta deltaTime\n   */\n  public update(delta: number): void {\n    if (delta <= 0) return;\n\n    // Update the _worldSpaceBoneLength\n    this._calcWorldSpaceBoneLength();\n\n    // Get bone position in center space\n    _worldSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n    let matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n    _centerSpacePosition.copy(_worldSpacePosition).applyMatrix4(matrixWorldToCenter);\n    const quatWorldToCenter = _quatA.setFromRotationMatrix(matrixWorldToCenter);\n\n    // Get parent matrix in center space\n    const centerSpaceParentMatrix = _matB.copy(matrixWorldToCenter).multiply(this._parentMatrixWorld);\n\n    // Get boneAxis in center space\n    const centerSpaceBoneAxis = _v3B\n      .copy(this._boneAxis)\n      .applyMatrix4(this._initialLocalMatrix)\n      .applyMatrix4(centerSpaceParentMatrix)\n      .sub(_centerSpacePosition)\n      .normalize();\n\n    // gravity in center space\n    const centerSpaceGravity = _v3C.copy(this.settings.gravityDir).applyQuaternion(quatWorldToCenter).normalize();\n\n    const matrixCenterToWorld = this._getMatrixCenterToWorld(_matA);\n\n    // verlet\u7A4D\u5206\u3067\u6B21\u306E\u4F4D\u7F6E\u3092\u8A08\u7B97\n    _nextTail\n      .copy(this._currentTail)\n      .add(\n        _v3A\n          .copy(this._currentTail)\n          .sub(this._prevTail)\n          .multiplyScalar(1 - this.settings.dragForce),\n      ) // \u524D\u30D5\u30EC\u30FC\u30E0\u306E\u79FB\u52D5\u3092\u7D99\u7D9A\u3059\u308B(\u6E1B\u8870\u3082\u3042\u308B\u3088)\n      .add(_v3A.copy(centerSpaceBoneAxis).multiplyScalar(this.settings.stiffness * delta)) // \u89AA\u306E\u56DE\u8EE2\u306B\u3088\u308B\u5B50\u30DC\u30FC\u30F3\u306E\u79FB\u52D5\u76EE\u6A19\n      .add(_v3A.copy(centerSpaceGravity).multiplyScalar(this.settings.gravityPower * delta)) // \u5916\u529B\u306B\u3088\u308B\u79FB\u52D5\u91CF\n      .applyMatrix4(matrixCenterToWorld); // tail\u3092world space\u306B\u623B\u3059\n\n    // normalize bone length\n    _nextTail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);\n\n    // Collision\u3067\u79FB\u52D5\n    this._collision(_nextTail);\n\n    // update prevTail and currentTail\n    matrixWorldToCenter = this._getMatrixWorldToCenter(_matA);\n\n    this._prevTail.copy(this._currentTail);\n    this._currentTail.copy(_v3A.copy(_nextTail).applyMatrix4(matrixWorldToCenter));\n\n    // Apply rotation, convert vector3 thing into actual quaternion\n    // Original UniVRM is doing center unit calculus at here but we're gonna do this on local unit\n    const worldSpaceInitialMatrixInv = mat4InvertCompat(\n      _matA.copy(this._parentMatrixWorld).multiply(this._initialLocalMatrix),\n    );\n    const applyRotation = _quatA.setFromUnitVectors(\n      this._boneAxis,\n      _v3A.copy(_nextTail).applyMatrix4(worldSpaceInitialMatrixInv).normalize(),\n    );\n\n    this.bone.quaternion.copy(this._initialLocalRotation).multiply(applyRotation);\n\n    // We need to update its matrixWorld manually, since we tweaked the bone by our hand\n    this.bone.updateMatrix();\n    this.bone.matrixWorld.multiplyMatrices(this._parentMatrixWorld, this.bone.matrix);\n  }\n\n  /**\n   * Do collision math against every colliders attached to this bone.\n   *\n   * @param tail The tail you want to process\n   */\n  private _collision(tail: THREE.Vector3): void {\n    this.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        const dist = collider.shape.calculateCollision(collider.matrixWorld, tail, this.settings.hitRadius, _v3A);\n\n        if (dist < 0.0) {\n          // hit\n          tail.add(_v3A.multiplyScalar(-dist));\n\n          // normalize bone length\n          tail.sub(_worldSpacePosition).normalize().multiplyScalar(this._worldSpaceBoneLength).add(_worldSpacePosition);\n        }\n      });\n    });\n  }\n\n  /**\n   * Calculate the {@link _worldSpaceBoneLength}.\n   * Intended to be used in {@link update}.\n   */\n  private _calcWorldSpaceBoneLength(): void {\n    _v3A.setFromMatrixPosition(this.bone.matrixWorld); // get world position of this.bone\n\n    if (this.child) {\n      _v3B.setFromMatrixPosition(this.child.matrixWorld); // get world position of this.child\n    } else {\n      _v3B.copy(this._initialLocalChildPosition);\n      _v3B.applyMatrix4(this.bone.matrixWorld);\n    }\n\n    this._worldSpaceBoneLength = _v3A.sub(_v3B).length();\n  }\n\n  /**\n   * Create a matrix that converts center space into world space.\n   * @param target Target matrix\n   */\n  private _getMatrixCenterToWorld(target: THREE.Matrix4): THREE.Matrix4 {\n    if (this._center) {\n      target.copy(this._center.matrixWorld);\n    } else {\n      target.identity();\n    }\n\n    return target;\n  }\n\n  /**\n   * Create a matrix that converts world space into center space.\n   * @param target Target matrix\n   */\n  private _getMatrixWorldToCenter(target: THREE.Matrix4): THREE.Matrix4 {\n    if (this._center) {\n      target.copy((this._center.userData.inverseCacheProxy as Matrix4InverseCache).inverse);\n    } else {\n      target.identity();\n    }\n\n    return target;\n  }\n}\n", "import * as THREE from 'three';\n\nconst _matA = new THREE.Matrix4();\n\n/**\n * A compat function for `Matrix4.invert()` / `Matrix4.getInverse()`.\n * `Matrix4.invert()` is introduced in r123 and `Matrix4.getInverse()` emits a warning.\n * We are going to use this compat for a while.\n * @param target A target matrix\n */\nexport function mat4InvertCompat<T extends THREE.Matrix4>(target: T): T {\n  if ((target as any).invert) {\n    target.invert();\n  } else {\n    (target as any).getInverse(_matA.copy(target));\n  }\n\n  return target;\n}\n", "import * as THREE from 'three';\nimport { mat4InvertCompat } from './mat4InvertCompat';\n\nexport class Matrix4InverseCache {\n  /**\n   * The target matrix.\n   */\n  public readonly matrix: THREE.Matrix4;\n\n  /**\n   * A cache of inverse of current matrix.\n   */\n  private readonly _inverseCache = new THREE.Matrix4();\n\n  /**\n   * A flag that makes it want to recalculate its {@link _inverseCache}.\n   * Will be set `true` when `elements` are mutated and be used in `getInverse`.\n   */\n  private _shouldUpdateInverse = true;\n\n  /**\n   * The original of `matrix.elements`\n   */\n  private readonly _originalElements: THREE.Matrix4Tuple;\n\n  /**\n   * Inverse of given matrix.\n   * Note that it will return its internal private instance.\n   * Make sure copying this before mutate this.\n   */\n  public get inverse(): THREE.Matrix4 {\n    if (this._shouldUpdateInverse) {\n      mat4InvertCompat(this._inverseCache.copy(this.matrix));\n      this._shouldUpdateInverse = false;\n    }\n\n    return this._inverseCache;\n  }\n\n  public constructor(matrix: THREE.Matrix4) {\n    this.matrix = matrix;\n\n    const handler: ProxyHandler<number[]> = {\n      set: (obj, prop: any, newVal) => {\n        this._shouldUpdateInverse = true;\n        obj[prop] = newVal;\n\n        return true;\n      },\n    };\n\n    this._originalElements = matrix.elements;\n    matrix.elements = new Proxy<THREE.Matrix4Tuple>(matrix.elements, handler);\n  }\n\n  public revert(): void {\n    this.matrix.elements = this._originalElements;\n  }\n}\n", "import type * as V0VRM from '@pixiv/types-vrm-0.0';\nimport type * as V1SpringBoneSchema from '@pixiv/types-vrmc-springbone-1.0';\nimport type * as SpringBoneExtendedColliderSchema from '@pixiv/types-vrmc-springbone-extended-collider-1.0';\nimport * as THREE from 'three';\nimport type { GLTF, GLTFLoaderPlugin, GLTFParser } from 'three/examples/jsm/loaders/GLTFLoader.js';\nimport { VRMSpringBoneColliderHelper, VRMSpringBoneJointHelper } from './helpers';\nimport { VRMSpringBoneCollider } from './VRMSpringBoneCollider';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport { VRMSpringBoneColliderShapeCapsule } from './VRMSpringBoneColliderShapeCapsule';\nimport { VRMSpringBoneColliderShapeSphere } from './VRMSpringBoneColliderShapeSphere';\nimport { VRMSpringBoneJoint } from './VRMSpringBoneJoint';\nimport type { VRMSpringBoneLoaderPluginOptions } from './VRMSpringBoneLoaderPluginOptions';\nimport { VRMSpringBoneManager } from './VRMSpringBoneManager';\nimport type { VRMSpringBoneJointSettings } from './VRMSpringBoneJointSettings';\nimport { GLTF as GLTFSchema } from '@gltf-transform/core';\nimport { VRMSpringBoneColliderShapePlane } from './VRMSpringBoneColliderShapePlane';\n\nconst EXTENSION_NAME_EXTENDED_COLLIDER = 'VRMC_springBone_extended_collider';\n\n/**\n * Possible spec versions it recognizes.\n */\nconst POSSIBLE_SPEC_VERSIONS = new Set(['1.0', '1.0-beta']);\n\n/**\n * Possible spec versions of `VRMC_springBone_extended_collider` it recognizes.\n */\nconst POSSIBLE_SPEC_VERSIONS_EXTENDED_COLLIDERS = new Set(['1.0']);\n\nexport class VRMSpringBoneLoaderPlugin implements GLTFLoaderPlugin {\n  public static readonly EXTENSION_NAME = 'VRMC_springBone';\n\n  /**\n   * Specify an Object3D to add {@link VRMSpringBoneJointHelper} s.\n   * If not specified, helper will not be created.\n   * If `renderOrder` is set to the root, helpers will copy the same `renderOrder` .\n   */\n  public jointHelperRoot?: THREE.Object3D;\n\n  /**\n   * Specify an Object3D to add {@link VRMSpringBoneJointHelper} s.\n   * If not specified, helper will not be created.\n   * If `renderOrder` is set to the root, helpers will copy the same `renderOrder` .\n   */\n  public colliderHelperRoot?: THREE.Object3D;\n\n  /**\n   * If true, load colliders defined in `VRMC_springBone_extended_collider`.\n   * Set to `false` to disable loading extended colliders and use the fallback behavior.\n   * `true` by default.\n   */\n  public useExtendedColliders: boolean;\n\n  public readonly parser: GLTFParser;\n\n  public get name(): string {\n    return VRMSpringBoneLoaderPlugin.EXTENSION_NAME;\n  }\n\n  public constructor(parser: GLTFParser, options?: VRMSpringBoneLoaderPluginOptions) {\n    this.parser = parser;\n\n    this.jointHelperRoot = options?.jointHelperRoot;\n    this.colliderHelperRoot = options?.colliderHelperRoot;\n    this.useExtendedColliders = options?.useExtendedColliders ?? true;\n  }\n\n  public async afterRoot(gltf: GLTF): Promise<void> {\n    gltf.userData.vrmSpringBoneManager = await this._import(gltf);\n  }\n\n  /**\n   * Import spring bones from a GLTF and return a {@link VRMSpringBoneManager}.\n   * It might return `null` instead when it does not need to be created or something go wrong.\n   *\n   * @param gltf A parsed result of GLTF taken from GLTFLoader\n   */\n  private async _import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const v1Result = await this._v1Import(gltf);\n    if (v1Result != null) {\n      return v1Result;\n    }\n\n    const v0Result = await this._v0Import(gltf);\n    if (v0Result != null) {\n      return v0Result;\n    }\n\n    return null;\n  }\n\n  private async _v1Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const json = gltf.parser.json as GLTFSchema.IGLTF;\n\n    // early abort if it doesn't use spring bones\n    const isSpringBoneUsed = json.extensionsUsed?.indexOf(VRMSpringBoneLoaderPlugin.EXTENSION_NAME) !== -1;\n    if (!isSpringBoneUsed) {\n      return null;\n    }\n\n    const manager = new VRMSpringBoneManager();\n\n    const threeNodes: THREE.Object3D[] = await gltf.parser.getDependencies('node');\n\n    const extension = json.extensions?.[VRMSpringBoneLoaderPlugin.EXTENSION_NAME] as\n      | V1SpringBoneSchema.VRMCSpringBone\n      | undefined;\n    if (!extension) {\n      return null;\n    }\n\n    const specVersion = extension.specVersion;\n    if (!POSSIBLE_SPEC_VERSIONS.has(specVersion)) {\n      console.warn(\n        `VRMSpringBoneLoaderPlugin: Unknown ${VRMSpringBoneLoaderPlugin.EXTENSION_NAME} specVersion \"${specVersion}\"`,\n      );\n      return null;\n    }\n\n    const colliders = extension.colliders?.map((schemaCollider, iCollider) => {\n      const node = threeNodes[schemaCollider.node!];\n      const schemaShape = schemaCollider.shape!;\n\n      // TODO: separate into several functions\n\n      const schemaExCollider: SpringBoneExtendedColliderSchema.VRMCSpringBoneExtendedCollider | undefined =\n        schemaCollider.extensions?.[EXTENSION_NAME_EXTENDED_COLLIDER];\n\n      if (this.useExtendedColliders && schemaExCollider != null) {\n        const specVersionExCollider = schemaExCollider.specVersion;\n        if (!POSSIBLE_SPEC_VERSIONS_EXTENDED_COLLIDERS.has(specVersionExCollider)) {\n          console.warn(\n            `VRMSpringBoneLoaderPlugin: Unknown ${EXTENSION_NAME_EXTENDED_COLLIDER} specVersion \"${specVersionExCollider}\". Fallbacking to the ${VRMSpringBoneLoaderPlugin.EXTENSION_NAME} definition`,\n          );\n        } else {\n          const schemaExShape = schemaExCollider.shape!;\n          if (schemaExShape.sphere) {\n            return this._importSphereCollider(node, {\n              offset: new THREE.Vector3().fromArray(schemaExShape.sphere.offset ?? [0.0, 0.0, 0.0]),\n              radius: schemaExShape.sphere.radius ?? 0.0,\n              inside: schemaExShape.sphere.inside ?? false,\n            });\n          } else if (schemaExShape.capsule) {\n            return this._importCapsuleCollider(node, {\n              offset: new THREE.Vector3().fromArray(schemaExShape.capsule.offset ?? [0.0, 0.0, 0.0]),\n              radius: schemaExShape.capsule.radius ?? 0.0,\n              tail: new THREE.Vector3().fromArray(schemaExShape.capsule.tail ?? [0.0, 0.0, 0.0]),\n              inside: schemaExShape.capsule.inside ?? false,\n            });\n          } else if (schemaExShape.plane) {\n            return this._importPlaneCollider(node, {\n              offset: new THREE.Vector3().fromArray(schemaExShape.plane.offset ?? [0.0, 0.0, 0.0]),\n              normal: new THREE.Vector3().fromArray(schemaExShape.plane.normal ?? [0.0, 0.0, 1.0]),\n            });\n          }\n        }\n      }\n\n      if (schemaShape.sphere) {\n        return this._importSphereCollider(node, {\n          offset: new THREE.Vector3().fromArray(schemaShape.sphere.offset ?? [0.0, 0.0, 0.0]),\n          radius: schemaShape.sphere.radius ?? 0.0,\n          inside: false,\n        });\n      } else if (schemaShape.capsule) {\n        return this._importCapsuleCollider(node, {\n          offset: new THREE.Vector3().fromArray(schemaShape.capsule.offset ?? [0.0, 0.0, 0.0]),\n          radius: schemaShape.capsule.radius ?? 0.0,\n          tail: new THREE.Vector3().fromArray(schemaShape.capsule.tail ?? [0.0, 0.0, 0.0]),\n          inside: false,\n        });\n      }\n\n      throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${iCollider} has no valid shape`);\n    });\n\n    const colliderGroups = extension.colliderGroups?.map(\n      (schemaColliderGroup, iColliderGroup): VRMSpringBoneColliderGroup => {\n        const cols = (schemaColliderGroup.colliders ?? []).map((iCollider) => {\n          const col = colliders?.[iCollider];\n\n          if (col == null) {\n            throw new Error(\n              `VRMSpringBoneLoaderPlugin: The colliderGroup #${iColliderGroup} attempted to use a collider #${iCollider} but not found`,\n            );\n          }\n\n          return col;\n        });\n\n        return {\n          colliders: cols,\n          name: schemaColliderGroup.name,\n        };\n      },\n    );\n\n    extension.springs?.forEach((schemaSpring, iSpring) => {\n      const schemaJoints = schemaSpring.joints;\n\n      // prepare colliders\n      const colliderGroupsForSpring = schemaSpring.colliderGroups?.map((iColliderGroup) => {\n        const group = colliderGroups?.[iColliderGroup];\n\n        if (group == null) {\n          throw new Error(\n            `VRMSpringBoneLoaderPlugin: The spring #${iSpring} attempted to use a colliderGroup ${iColliderGroup} but not found`,\n          );\n        }\n\n        return group;\n      });\n\n      const center = schemaSpring.center != null ? threeNodes[schemaSpring.center] : undefined;\n\n      let prevSchemaJoint: V1SpringBoneSchema.SpringBoneJoint | undefined;\n      schemaJoints.forEach((schemaJoint) => {\n        if (prevSchemaJoint) {\n          // prepare node\n          const nodeIndex = prevSchemaJoint.node;\n          const node = threeNodes[nodeIndex];\n          const childIndex = schemaJoint.node;\n          const child = threeNodes[childIndex];\n\n          // prepare setting\n          const setting: Partial<VRMSpringBoneJointSettings> = {\n            hitRadius: prevSchemaJoint.hitRadius,\n            dragForce: prevSchemaJoint.dragForce,\n            gravityPower: prevSchemaJoint.gravityPower,\n            stiffness: prevSchemaJoint.stiffness,\n            gravityDir:\n              prevSchemaJoint.gravityDir != null\n                ? new THREE.Vector3().fromArray(prevSchemaJoint.gravityDir)\n                : undefined,\n          };\n\n          // create spring bones\n          const joint = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          if (center) {\n            joint.center = center;\n          }\n\n          manager.addJoint(joint);\n        }\n\n        prevSchemaJoint = schemaJoint;\n      });\n    });\n\n    // init spring bones\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private async _v0Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    const json = gltf.parser.json as GLTFSchema.IGLTF;\n\n    // early abort if it doesn't use vrm\n    const isVRMUsed = json.extensionsUsed?.indexOf('VRM') !== -1;\n    if (!isVRMUsed) {\n      return null;\n    }\n\n    // early abort if it doesn't have bone groups\n    const extension = json.extensions?.['VRM'] as V0VRM.VRM | undefined;\n    const schemaSecondaryAnimation = extension?.secondaryAnimation;\n    if (!schemaSecondaryAnimation) {\n      return null;\n    }\n\n    const schemaBoneGroups = schemaSecondaryAnimation?.boneGroups;\n    if (!schemaBoneGroups) {\n      return null;\n    }\n\n    const manager = new VRMSpringBoneManager();\n\n    const threeNodes: THREE.Object3D[] = await gltf.parser.getDependencies('node');\n\n    const colliderGroups = schemaSecondaryAnimation.colliderGroups?.map(\n      (schemaColliderGroup): VRMSpringBoneColliderGroup => {\n        const node = threeNodes[schemaColliderGroup.node!];\n        const colliders = (schemaColliderGroup.colliders ?? []).map((schemaCollider, iCollider) => {\n          const offset = new THREE.Vector3(0.0, 0.0, 0.0);\n          if (schemaCollider.offset) {\n            offset.set(\n              schemaCollider.offset.x ?? 0.0,\n              schemaCollider.offset.y ?? 0.0,\n              schemaCollider.offset.z ? -schemaCollider.offset.z : 0.0, // z is opposite in VRM0.0\n            );\n          }\n\n          return this._importSphereCollider(node, {\n            offset,\n            radius: schemaCollider.radius ?? 0.0,\n            inside: false,\n          });\n        });\n\n        return { colliders };\n      },\n    );\n\n    // import spring bones for each spring bone groups\n    schemaBoneGroups?.forEach((schemaBoneGroup, iBoneGroup) => {\n      const rootIndices = schemaBoneGroup.bones;\n      if (!rootIndices) {\n        return;\n      }\n\n      rootIndices.forEach((rootIndex) => {\n        const root = threeNodes[rootIndex];\n\n        // prepare setting\n        const gravityDir = new THREE.Vector3();\n        if (schemaBoneGroup.gravityDir) {\n          gravityDir.set(\n            schemaBoneGroup.gravityDir.x ?? 0.0,\n            schemaBoneGroup.gravityDir.y ?? 0.0,\n            schemaBoneGroup.gravityDir.z ?? 0.0,\n          );\n        } else {\n          gravityDir.set(0.0, -1.0, 0.0);\n        }\n\n        const center = schemaBoneGroup.center != null ? threeNodes[schemaBoneGroup.center] : undefined;\n\n        const setting: Partial<VRMSpringBoneJointSettings> = {\n          hitRadius: schemaBoneGroup.hitRadius,\n          dragForce: schemaBoneGroup.dragForce,\n          gravityPower: schemaBoneGroup.gravityPower,\n          stiffness: schemaBoneGroup.stiffiness,\n          gravityDir,\n        };\n\n        // prepare colliders\n        const colliderGroupsForSpring = schemaBoneGroup.colliderGroups?.map((iColliderGroup) => {\n          const group = colliderGroups?.[iColliderGroup];\n\n          if (group == null) {\n            throw new Error(\n              `VRMSpringBoneLoaderPlugin: The spring #${iBoneGroup} attempted to use a colliderGroup ${iColliderGroup} but not found`,\n            );\n          }\n\n          return group;\n        });\n\n        // create spring bones\n        root.traverse((node) => {\n          const child: THREE.Object3D | null = node.children[0] ?? null;\n\n          const joint = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          if (center) {\n            joint.center = center;\n          }\n\n          manager.addJoint(joint);\n        });\n      });\n    });\n\n    // init spring bones\n    gltf.scene.updateMatrixWorld();\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private _importJoint(\n    node: THREE.Object3D,\n    child: THREE.Object3D,\n    setting?: Partial<VRMSpringBoneJointSettings>,\n    colliderGroupsForSpring?: VRMSpringBoneColliderGroup[],\n  ): VRMSpringBoneJoint {\n    const springBone = new VRMSpringBoneJoint(node, child, setting, colliderGroupsForSpring);\n\n    if (this.jointHelperRoot) {\n      const helper = new VRMSpringBoneJointHelper(springBone);\n      this.jointHelperRoot.add(helper);\n      helper.renderOrder = this.jointHelperRoot.renderOrder;\n    }\n\n    return springBone;\n  }\n\n  private _importSphereCollider(\n    destination: THREE.Object3D,\n    params: {\n      offset: THREE.Vector3;\n      radius: number;\n      inside: boolean;\n    },\n  ): VRMSpringBoneCollider {\n    const shape = new VRMSpringBoneColliderShapeSphere(params);\n\n    const collider = new VRMSpringBoneCollider(shape);\n\n    destination.add(collider);\n\n    if (this.colliderHelperRoot) {\n      const helper = new VRMSpringBoneColliderHelper(collider);\n      this.colliderHelperRoot.add(helper);\n      helper.renderOrder = this.colliderHelperRoot.renderOrder;\n    }\n\n    return collider;\n  }\n\n  private _importCapsuleCollider(\n    destination: THREE.Object3D,\n    params: {\n      offset: THREE.Vector3;\n      radius: number;\n      tail: THREE.Vector3;\n      inside: boolean;\n    },\n  ): VRMSpringBoneCollider {\n    const shape = new VRMSpringBoneColliderShapeCapsule(params);\n\n    const collider = new VRMSpringBoneCollider(shape);\n\n    destination.add(collider);\n\n    if (this.colliderHelperRoot) {\n      const helper = new VRMSpringBoneColliderHelper(collider);\n      this.colliderHelperRoot.add(helper);\n      helper.renderOrder = this.colliderHelperRoot.renderOrder;\n    }\n\n    return collider;\n  }\n\n  private _importPlaneCollider(\n    destination: THREE.Object3D,\n    params: {\n      offset: THREE.Vector3;\n      normal: THREE.Vector3;\n    },\n  ): VRMSpringBoneCollider {\n    const shape = new VRMSpringBoneColliderShapePlane(params);\n\n    const collider = new VRMSpringBoneCollider(shape);\n\n    destination.add(collider);\n\n    if (this.colliderHelperRoot) {\n      const helper = new VRMSpringBoneColliderHelper(collider);\n      this.colliderHelperRoot.add(helper);\n      helper.renderOrder = this.colliderHelperRoot.renderOrder;\n    }\n\n    return collider;\n  }\n}\n", "import type * as THREE from 'three';\n\nexport function traverseAncestorsFromRoot(object: THREE.Object3D, callback: (object: THREE.Object3D) => void): void {\n  const ancestors: THREE.Object3D[] = [];\n\n  let head: THREE.Object3D | null = object;\n  while (head !== null) {\n    ancestors.unshift(head);\n    head = head.parent;\n  }\n\n  ancestors.forEach((ancestor) => {\n    callback(ancestor);\n  });\n}\n", "import type * as THREE from 'three';\n\n/**\n * Traverse children of given object and execute given callback.\n * The given object itself wont be given to the callback.\n * If the return value of the callback is `true`, it will halt the traversal of its children.\n * @param object A root object\n * @param callback A callback function called for each children\n */\nexport function traverseChildrenUntilConditionMet(\n  object: THREE.Object3D,\n  callback: (object: THREE.Object3D) => boolean,\n): void {\n  object.children.forEach((child) => {\n    const result = callback(child);\n    if (!result) {\n      traverseChildrenUntilConditionMet(child, callback);\n    }\n  });\n}\n", "import type * as THREE from 'three';\nimport type { VRMSpringBoneJoint } from './VRMSpringBoneJoint';\nimport { traverseAncestorsFromRoot } from './utils/traverseAncestorsFromRoot';\nimport type { VRMSpringBoneCollider } from './VRMSpringBoneCollider';\nimport type { VRMSpringBoneColliderGroup } from './VRMSpringBoneColliderGroup';\nimport { traverseChildrenUntilConditionMet } from './utils/traverseChildrenUntilConditionMet';\n\nexport class VRMSpringBoneManager {\n  private _joints = new Set<VRMSpringBoneJoint>();\n  public get joints(): Set<VRMSpringBoneJoint> {\n    return this._joints;\n  }\n\n  /**\n   * @deprecated Use {@link joints} instead.\n   */\n  public get springBones(): Set<VRMSpringBoneJoint> {\n    console.warn('VRMSpringBoneManager: springBones is deprecated. use joints instead.');\n\n    return this._joints;\n  }\n\n  public get colliderGroups(): VRMSpringBoneColliderGroup[] {\n    const set = new Set<VRMSpringBoneColliderGroup>();\n    this._joints.forEach((springBone) => {\n      springBone.colliderGroups.forEach((colliderGroup) => {\n        set.add(colliderGroup);\n      });\n    });\n    return Array.from(set);\n  }\n\n  public get colliders(): VRMSpringBoneCollider[] {\n    const set = new Set<VRMSpringBoneCollider>();\n    this.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        set.add(collider);\n      });\n    });\n    return Array.from(set);\n  }\n\n  private _objectSpringBonesMap = new Map<THREE.Object3D, Set<VRMSpringBoneJoint>>();\n\n  public addJoint(joint: VRMSpringBoneJoint): void {\n    this._joints.add(joint);\n\n    let objectSet = this._objectSpringBonesMap.get(joint.bone);\n    if (objectSet == null) {\n      objectSet = new Set<VRMSpringBoneJoint>();\n      this._objectSpringBonesMap.set(joint.bone, objectSet);\n    }\n    objectSet.add(joint);\n  }\n\n  /**\n   * @deprecated Use {@link addJoint} instead.\n   */\n  public addSpringBone(joint: VRMSpringBoneJoint): void {\n    console.warn('VRMSpringBoneManager: addSpringBone() is deprecated. use addJoint() instead.');\n\n    this.addJoint(joint);\n  }\n\n  public deleteJoint(joint: VRMSpringBoneJoint): void {\n    this._joints.delete(joint);\n\n    const objectSet = this._objectSpringBonesMap.get(joint.bone)!;\n    objectSet.delete(joint);\n  }\n\n  /**\n   * @deprecated Use {@link deleteJoint} instead.\n   */\n  public deleteSpringBone(joint: VRMSpringBoneJoint): void {\n    console.warn('VRMSpringBoneManager: deleteSpringBone() is deprecated. use deleteJoint() instead.');\n\n    this.deleteJoint(joint);\n  }\n\n  public setInitState(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.setInitState(),\n      );\n    }\n  }\n\n  public reset(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.reset(),\n      );\n    }\n  }\n\n  public update(delta: number): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n    const objectUpdated = new Set<THREE.Object3D>();\n\n    for (const springBone of this._joints) {\n      // update the springbone\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, objectUpdated, (springBone) =>\n        springBone.update(delta),\n      );\n\n      // update children world matrices\n      // it is required when the spring bone chain is sparse\n      traverseChildrenUntilConditionMet(springBone.bone, (object) => {\n        // if the object has attached springbone, halt the traversal\n        if ((this._objectSpringBonesMap.get(object)?.size ?? 0) > 0) {\n          return true;\n        }\n\n        // otherwise update its world matrix\n        object.updateWorldMatrix(false, false);\n        return false;\n      });\n    }\n  }\n\n  /**\n   * Update a spring bone.\n   * If there are other spring bone that are dependant, it will try to update them recursively.\n   * It updates matrixWorld of all ancestors and myself.\n   * It might throw an error if there are circular dependencies.\n   *\n   * Intended to be used in {@link update} and {@link _processSpringBone} itself recursively.\n   *\n   * @param springBone A springBone you want to update\n   * @param springBonesTried Set of springBones that are already tried to be updated\n   * @param springBonesDone Set of springBones that are already up to date\n   * @param objectUpdated Set of object3D whose matrixWorld is updated\n   */\n  private _processSpringBone(\n    springBone: VRMSpringBoneJoint,\n    springBonesTried: Set<VRMSpringBoneJoint>,\n    springBonesDone: Set<VRMSpringBoneJoint>,\n    objectUpdated: Set<THREE.Object3D>,\n    callback: (springBone: VRMSpringBoneJoint) => void,\n  ): void {\n    if (springBonesDone.has(springBone)) {\n      return;\n    }\n\n    if (springBonesTried.has(springBone)) {\n      throw new Error('VRMSpringBoneManager: Circular dependency detected while updating springbones');\n    }\n    springBonesTried.add(springBone);\n\n    const depObjects = this._getDependencies(springBone);\n    for (const depObject of depObjects) {\n      traverseAncestorsFromRoot(depObject, (depObjectAncestor) => {\n        const objectSet = this._objectSpringBonesMap.get(depObjectAncestor);\n        if (objectSet) {\n          for (const depSpringBone of objectSet) {\n            this._processSpringBone(depSpringBone, springBonesTried, springBonesDone, objectUpdated, callback);\n          }\n        } else if (!objectUpdated.has(depObjectAncestor)) {\n          // update matrix of non-springbone\n          depObjectAncestor.updateWorldMatrix(false, false);\n          objectUpdated.add(depObjectAncestor);\n        }\n      });\n    }\n\n    // update my matrix\n    springBone.bone.updateMatrix();\n    springBone.bone.updateWorldMatrix(false, false);\n\n    callback(springBone);\n\n    objectUpdated.add(springBone.bone);\n\n    springBonesDone.add(springBone);\n  }\n\n  /**\n   * Return a set of objects that are dependant of given spring bone.\n   * @param springBone A spring bone\n   * @return A set of objects that are dependant of given spring bone\n   */\n  private _getDependencies(springBone: VRMSpringBoneJoint): Set<THREE.Object3D> {\n    const set = new Set<THREE.Object3D>();\n\n    const parent = springBone.bone.parent;\n    if (parent) {\n      set.add(parent);\n    }\n\n    springBone.colliderGroups.forEach((colliderGroup) => {\n      colliderGroup.colliders.forEach((collider) => {\n        set.add(collider);\n      });\n    });\n\n    return set;\n  }\n}\n"],
  "mappings": "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",
  "names": ["THREE", "THREE", "_v3A", "THREE", "THREE", "_v3A", "THREE", "THREE", "_v3A", "THREE", "THREE", "_v3A", "THREE", "THREE", "THREE", "THREE", "_v3A", "_v3B", "_matA", "THREE", "springBone", "_a", "_b", "_c", "_d", "_e"]
}
