@pixiv/three-vrm-springbone 1.0.0-beta.6 → 1.0.0-beta.7

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.
Files changed (30) hide show
  1. package/lib/three-vrm-springbone.js +1033 -1033
  2. package/lib/three-vrm-springbone.module.js +1033 -1033
  3. package/package.json +4 -4
  4. package/types/VRMSpringBoneCollider.d.ts +12 -12
  5. package/types/VRMSpringBoneColliderGroup.d.ts +14 -14
  6. package/types/VRMSpringBoneColliderShape.d.ts +20 -20
  7. package/types/VRMSpringBoneColliderShapeCapsule.d.ts +23 -23
  8. package/types/VRMSpringBoneColliderShapeSphere.d.ts +18 -18
  9. package/types/VRMSpringBoneJoint.d.ts +123 -123
  10. package/types/VRMSpringBoneJointSettings.d.ts +10 -10
  11. package/types/VRMSpringBoneLoaderPlugin.d.ts +34 -34
  12. package/types/VRMSpringBoneLoaderPluginOptions.d.ts +14 -14
  13. package/types/VRMSpringBoneManager.d.ts +33 -33
  14. package/types/helpers/VRMSpringBoneColliderHelper.d.ts +10 -10
  15. package/types/helpers/VRMSpringBoneJointHelper.d.ts +10 -10
  16. package/types/helpers/index.d.ts +2 -2
  17. package/types/helpers/utils/ColliderShapeBufferGeometry.d.ts +4 -4
  18. package/types/helpers/utils/ColliderShapeCapsuleBufferGeometry.d.ts +15 -15
  19. package/types/helpers/utils/ColliderShapeSphereBufferGeometry.d.ts +14 -14
  20. package/types/helpers/utils/SpringBoneBufferGeometry.d.ts +13 -13
  21. package/types/index.d.ts +10 -10
  22. package/types/tests/VRMSpringBoneColliderShapeCapsule.test.d.ts +1 -1
  23. package/types/tests/VRMSpringBoneColliderShapeSphere.test.d.ts +1 -1
  24. package/types/tests/matchers/toBeCloseToArray.d.ts +9 -9
  25. package/types/tests/matchers/toBeCloseToVector3.d.ts +10 -10
  26. package/types/utils/Matrix4InverseCache.d.ts +28 -28
  27. package/types/utils/getWorldQuaternionLite.d.ts +8 -8
  28. package/types/utils/mat4InvertCompat.d.ts +8 -8
  29. package/types/utils/traverseAncestorsFromRoot.d.ts +2 -2
  30. package/types/utils/traverseChildrenUntilConditionMet.d.ts +8 -8
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * @pixiv/three-vrm-springbone v1.0.0-beta.6
2
+ * @pixiv/three-vrm-springbone v1.0.0-beta.7
3
3
  * Spring bone module for @pixiv/three-vrm
4
4
  *
5
5
  * Copyright (c) 2020-2021 pixiv Inc.
@@ -34,675 +34,675 @@
34
34
 
35
35
  var THREE__namespace = /*#__PURE__*/_interopNamespace(THREE);
36
36
 
37
- /**
38
- * Represents a shape of a collider.
39
- */
40
- class VRMSpringBoneColliderShape {
37
+ /**
38
+ * Represents a shape of a collider.
39
+ */
40
+ class VRMSpringBoneColliderShape {
41
41
  }
42
42
 
43
- const _v3A$1 = new THREE__namespace.Vector3();
44
- const _v3B$1 = new THREE__namespace.Vector3();
45
- class VRMSpringBoneColliderShapeCapsule extends VRMSpringBoneColliderShape {
46
- constructor(params) {
47
- var _a, _b, _c;
48
- super();
49
- this.offset = (_a = params === null || params === void 0 ? void 0 : params.offset) !== null && _a !== void 0 ? _a : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
50
- this.tail = (_b = params === null || params === void 0 ? void 0 : params.tail) !== null && _b !== void 0 ? _b : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
51
- this.radius = (_c = params === null || params === void 0 ? void 0 : params.radius) !== null && _c !== void 0 ? _c : 1.0;
52
- }
53
- get type() {
54
- return 'capsule';
55
- }
56
- calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
57
- _v3A$1.copy(this.offset).applyMatrix4(colliderMatrix); // transformed head
58
- _v3B$1.copy(this.tail).applyMatrix4(colliderMatrix); // transformed tail
59
- _v3B$1.sub(_v3A$1); // from head to tail
60
- const lengthSqCapsule = _v3B$1.lengthSq();
61
- target.copy(objectPosition).sub(_v3A$1); // from head to object
62
- const dot = _v3B$1.dot(target); // dot product of offsetToTail and offsetToObject
63
- if (dot <= 0.0) ;
64
- else if (lengthSqCapsule <= dot) {
65
- // if object is near from the tail
66
- target.sub(_v3B$1); // from tail to object
67
- }
68
- else {
69
- // if object is between two ends
70
- _v3B$1.multiplyScalar(dot / lengthSqCapsule); // from head to the nearest point of the shaft
71
- target.sub(_v3B$1); // from the shaft point to object
72
- }
73
- const radius = objectRadius + this.radius;
74
- const distance = target.length() - radius;
75
- target.normalize();
76
- return distance;
77
- }
43
+ const _v3A$1 = new THREE__namespace.Vector3();
44
+ const _v3B$1 = new THREE__namespace.Vector3();
45
+ class VRMSpringBoneColliderShapeCapsule extends VRMSpringBoneColliderShape {
46
+ constructor(params) {
47
+ var _a, _b, _c;
48
+ super();
49
+ this.offset = (_a = params === null || params === void 0 ? void 0 : params.offset) !== null && _a !== void 0 ? _a : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
50
+ this.tail = (_b = params === null || params === void 0 ? void 0 : params.tail) !== null && _b !== void 0 ? _b : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
51
+ this.radius = (_c = params === null || params === void 0 ? void 0 : params.radius) !== null && _c !== void 0 ? _c : 1.0;
52
+ }
53
+ get type() {
54
+ return 'capsule';
55
+ }
56
+ calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
57
+ _v3A$1.copy(this.offset).applyMatrix4(colliderMatrix); // transformed head
58
+ _v3B$1.copy(this.tail).applyMatrix4(colliderMatrix); // transformed tail
59
+ _v3B$1.sub(_v3A$1); // from head to tail
60
+ const lengthSqCapsule = _v3B$1.lengthSq();
61
+ target.copy(objectPosition).sub(_v3A$1); // from head to object
62
+ const dot = _v3B$1.dot(target); // dot product of offsetToTail and offsetToObject
63
+ if (dot <= 0.0) ;
64
+ else if (lengthSqCapsule <= dot) {
65
+ // if object is near from the tail
66
+ target.sub(_v3B$1); // from tail to object
67
+ }
68
+ else {
69
+ // if object is between two ends
70
+ _v3B$1.multiplyScalar(dot / lengthSqCapsule); // from head to the nearest point of the shaft
71
+ target.sub(_v3B$1); // from the shaft point to object
72
+ }
73
+ const radius = objectRadius + this.radius;
74
+ const distance = target.length() - radius;
75
+ target.normalize();
76
+ return distance;
77
+ }
78
78
  }
79
79
 
80
- class VRMSpringBoneColliderShapeSphere extends VRMSpringBoneColliderShape {
81
- constructor(params) {
82
- var _a, _b;
83
- super();
84
- this.offset = (_a = params === null || params === void 0 ? void 0 : params.offset) !== null && _a !== void 0 ? _a : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
85
- this.radius = (_b = params === null || params === void 0 ? void 0 : params.radius) !== null && _b !== void 0 ? _b : 1.0;
86
- }
87
- get type() {
88
- return 'sphere';
89
- }
90
- calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
91
- target.copy(this.offset).applyMatrix4(colliderMatrix); // transformed offset
92
- target.negate().add(objectPosition); // a vector from collider center to object position
93
- const radius = objectRadius + this.radius;
94
- const distance = target.length() - radius;
95
- target.normalize();
96
- return distance;
97
- }
80
+ class VRMSpringBoneColliderShapeSphere extends VRMSpringBoneColliderShape {
81
+ constructor(params) {
82
+ var _a, _b;
83
+ super();
84
+ this.offset = (_a = params === null || params === void 0 ? void 0 : params.offset) !== null && _a !== void 0 ? _a : new THREE__namespace.Vector3(0.0, 0.0, 0.0);
85
+ this.radius = (_b = params === null || params === void 0 ? void 0 : params.radius) !== null && _b !== void 0 ? _b : 1.0;
86
+ }
87
+ get type() {
88
+ return 'sphere';
89
+ }
90
+ calculateCollision(colliderMatrix, objectPosition, objectRadius, target) {
91
+ target.copy(this.offset).applyMatrix4(colliderMatrix); // transformed offset
92
+ target.negate().add(objectPosition); // a vector from collider center to object position
93
+ const radius = objectRadius + this.radius;
94
+ const distance = target.length() - radius;
95
+ target.normalize();
96
+ return distance;
97
+ }
98
98
  }
99
99
 
100
- const _vecA = new THREE__namespace.Vector3();
101
- class ColliderShapeCapsuleBufferGeometry extends THREE__namespace.BufferGeometry {
102
- constructor(shape) {
103
- super();
104
- this._currentRadius = 0;
105
- this._currentOffset = new THREE__namespace.Vector3();
106
- this._currentTail = new THREE__namespace.Vector3();
107
- this._shape = shape;
108
- this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(396), 3);
109
- this.setAttribute('position', this._attrPos);
110
- this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(264), 1);
111
- this.setIndex(this._attrIndex);
112
- this._buildIndex();
113
- this.update();
114
- }
115
- update() {
116
- let shouldUpdateGeometry = false;
117
- if (this._currentRadius !== this._shape.radius) {
118
- this._currentRadius = this._shape.radius;
119
- shouldUpdateGeometry = true;
120
- }
121
- if (!this._currentOffset.equals(this._shape.offset)) {
122
- this._currentOffset.copy(this._shape.offset);
123
- shouldUpdateGeometry = true;
124
- }
125
- if (!this._currentTail.equals(this._shape.tail)) {
126
- this._currentTail.copy(this._shape.tail);
127
- shouldUpdateGeometry = true;
128
- }
129
- if (shouldUpdateGeometry) {
130
- this._buildPosition();
131
- }
132
- }
133
- _buildPosition() {
134
- _vecA.copy(this._currentTail).sub(this._currentOffset);
135
- const l = _vecA.length() / this._currentRadius;
136
- for (let i = 0; i <= 16; i++) {
137
- const t = (i / 16.0) * Math.PI;
138
- this._attrPos.setXYZ(i, -Math.sin(t), -Math.cos(t), 0.0);
139
- this._attrPos.setXYZ(17 + i, l + Math.sin(t), Math.cos(t), 0.0);
140
- this._attrPos.setXYZ(34 + i, -Math.sin(t), 0.0, -Math.cos(t));
141
- this._attrPos.setXYZ(51 + i, l + Math.sin(t), 0.0, Math.cos(t));
142
- }
143
- for (let i = 0; i < 32; i++) {
144
- const t = (i / 16.0) * Math.PI;
145
- this._attrPos.setXYZ(68 + i, 0.0, Math.sin(t), Math.cos(t));
146
- this._attrPos.setXYZ(100 + i, l, Math.sin(t), Math.cos(t));
147
- }
148
- const theta = Math.atan2(_vecA.y, Math.sqrt(_vecA.x * _vecA.x + _vecA.z * _vecA.z));
149
- const phi = -Math.atan2(_vecA.z, _vecA.x);
150
- this.rotateZ(theta);
151
- this.rotateY(phi);
152
- this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
153
- this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);
154
- this._attrPos.needsUpdate = true;
155
- }
156
- _buildIndex() {
157
- for (let i = 0; i < 34; i++) {
158
- const i1 = (i + 1) % 34;
159
- this._attrIndex.setXY(i * 2, i, i1);
160
- this._attrIndex.setXY(68 + i * 2, 34 + i, 34 + i1);
161
- }
162
- for (let i = 0; i < 32; i++) {
163
- const i1 = (i + 1) % 32;
164
- this._attrIndex.setXY(136 + i * 2, 68 + i, 68 + i1);
165
- this._attrIndex.setXY(200 + i * 2, 100 + i, 100 + i1);
166
- }
167
- this._attrIndex.needsUpdate = true;
168
- }
100
+ const _vecA = new THREE__namespace.Vector3();
101
+ class ColliderShapeCapsuleBufferGeometry extends THREE__namespace.BufferGeometry {
102
+ constructor(shape) {
103
+ super();
104
+ this._currentRadius = 0;
105
+ this._currentOffset = new THREE__namespace.Vector3();
106
+ this._currentTail = new THREE__namespace.Vector3();
107
+ this._shape = shape;
108
+ this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(396), 3);
109
+ this.setAttribute('position', this._attrPos);
110
+ this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(264), 1);
111
+ this.setIndex(this._attrIndex);
112
+ this._buildIndex();
113
+ this.update();
114
+ }
115
+ update() {
116
+ let shouldUpdateGeometry = false;
117
+ if (this._currentRadius !== this._shape.radius) {
118
+ this._currentRadius = this._shape.radius;
119
+ shouldUpdateGeometry = true;
120
+ }
121
+ if (!this._currentOffset.equals(this._shape.offset)) {
122
+ this._currentOffset.copy(this._shape.offset);
123
+ shouldUpdateGeometry = true;
124
+ }
125
+ if (!this._currentTail.equals(this._shape.tail)) {
126
+ this._currentTail.copy(this._shape.tail);
127
+ shouldUpdateGeometry = true;
128
+ }
129
+ if (shouldUpdateGeometry) {
130
+ this._buildPosition();
131
+ }
132
+ }
133
+ _buildPosition() {
134
+ _vecA.copy(this._currentTail).sub(this._currentOffset);
135
+ const l = _vecA.length() / this._currentRadius;
136
+ for (let i = 0; i <= 16; i++) {
137
+ const t = (i / 16.0) * Math.PI;
138
+ this._attrPos.setXYZ(i, -Math.sin(t), -Math.cos(t), 0.0);
139
+ this._attrPos.setXYZ(17 + i, l + Math.sin(t), Math.cos(t), 0.0);
140
+ this._attrPos.setXYZ(34 + i, -Math.sin(t), 0.0, -Math.cos(t));
141
+ this._attrPos.setXYZ(51 + i, l + Math.sin(t), 0.0, Math.cos(t));
142
+ }
143
+ for (let i = 0; i < 32; i++) {
144
+ const t = (i / 16.0) * Math.PI;
145
+ this._attrPos.setXYZ(68 + i, 0.0, Math.sin(t), Math.cos(t));
146
+ this._attrPos.setXYZ(100 + i, l, Math.sin(t), Math.cos(t));
147
+ }
148
+ const theta = Math.atan2(_vecA.y, Math.sqrt(_vecA.x * _vecA.x + _vecA.z * _vecA.z));
149
+ const phi = -Math.atan2(_vecA.z, _vecA.x);
150
+ this.rotateZ(theta);
151
+ this.rotateY(phi);
152
+ this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
153
+ this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);
154
+ this._attrPos.needsUpdate = true;
155
+ }
156
+ _buildIndex() {
157
+ for (let i = 0; i < 34; i++) {
158
+ const i1 = (i + 1) % 34;
159
+ this._attrIndex.setXY(i * 2, i, i1);
160
+ this._attrIndex.setXY(68 + i * 2, 34 + i, 34 + i1);
161
+ }
162
+ for (let i = 0; i < 32; i++) {
163
+ const i1 = (i + 1) % 32;
164
+ this._attrIndex.setXY(136 + i * 2, 68 + i, 68 + i1);
165
+ this._attrIndex.setXY(200 + i * 2, 100 + i, 100 + i1);
166
+ }
167
+ this._attrIndex.needsUpdate = true;
168
+ }
169
169
  }
170
170
 
171
- class ColliderShapeSphereBufferGeometry extends THREE__namespace.BufferGeometry {
172
- constructor(shape) {
173
- super();
174
- this._currentRadius = 0;
175
- this._currentOffset = new THREE__namespace.Vector3();
176
- this._shape = shape;
177
- this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(32 * 3 * 3), 3);
178
- this.setAttribute('position', this._attrPos);
179
- this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(64 * 3), 1);
180
- this.setIndex(this._attrIndex);
181
- this._buildIndex();
182
- this.update();
183
- }
184
- update() {
185
- let shouldUpdateGeometry = false;
186
- if (this._currentRadius !== this._shape.radius) {
187
- this._currentRadius = this._shape.radius;
188
- shouldUpdateGeometry = true;
189
- }
190
- if (!this._currentOffset.equals(this._shape.offset)) {
191
- this._currentOffset.copy(this._shape.offset);
192
- shouldUpdateGeometry = true;
193
- }
194
- if (shouldUpdateGeometry) {
195
- this._buildPosition();
196
- }
197
- }
198
- _buildPosition() {
199
- for (let i = 0; i < 32; i++) {
200
- const t = (i / 16.0) * Math.PI;
201
- this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);
202
- this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));
203
- this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));
204
- }
205
- this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
206
- this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);
207
- this._attrPos.needsUpdate = true;
208
- }
209
- _buildIndex() {
210
- for (let i = 0; i < 32; i++) {
211
- const i1 = (i + 1) % 32;
212
- this._attrIndex.setXY(i * 2, i, i1);
213
- this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);
214
- this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);
215
- }
216
- this._attrIndex.needsUpdate = true;
217
- }
171
+ class ColliderShapeSphereBufferGeometry extends THREE__namespace.BufferGeometry {
172
+ constructor(shape) {
173
+ super();
174
+ this._currentRadius = 0;
175
+ this._currentOffset = new THREE__namespace.Vector3();
176
+ this._shape = shape;
177
+ this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(32 * 3 * 3), 3);
178
+ this.setAttribute('position', this._attrPos);
179
+ this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(64 * 3), 1);
180
+ this.setIndex(this._attrIndex);
181
+ this._buildIndex();
182
+ this.update();
183
+ }
184
+ update() {
185
+ let shouldUpdateGeometry = false;
186
+ if (this._currentRadius !== this._shape.radius) {
187
+ this._currentRadius = this._shape.radius;
188
+ shouldUpdateGeometry = true;
189
+ }
190
+ if (!this._currentOffset.equals(this._shape.offset)) {
191
+ this._currentOffset.copy(this._shape.offset);
192
+ shouldUpdateGeometry = true;
193
+ }
194
+ if (shouldUpdateGeometry) {
195
+ this._buildPosition();
196
+ }
197
+ }
198
+ _buildPosition() {
199
+ for (let i = 0; i < 32; i++) {
200
+ const t = (i / 16.0) * Math.PI;
201
+ this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);
202
+ this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));
203
+ this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));
204
+ }
205
+ this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
206
+ this.translate(this._currentOffset.x, this._currentOffset.y, this._currentOffset.z);
207
+ this._attrPos.needsUpdate = true;
208
+ }
209
+ _buildIndex() {
210
+ for (let i = 0; i < 32; i++) {
211
+ const i1 = (i + 1) % 32;
212
+ this._attrIndex.setXY(i * 2, i, i1);
213
+ this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);
214
+ this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);
215
+ }
216
+ this._attrIndex.needsUpdate = true;
217
+ }
218
218
  }
219
219
 
220
- class VRMSpringBoneColliderHelper extends THREE__namespace.Group {
221
- constructor(collider) {
222
- super();
223
- this.matrixAutoUpdate = false;
224
- this.collider = collider;
225
- if (this.collider.shape instanceof VRMSpringBoneColliderShapeSphere) {
226
- this._geometry = new ColliderShapeSphereBufferGeometry(this.collider.shape);
227
- }
228
- else if (this.collider.shape instanceof VRMSpringBoneColliderShapeCapsule) {
229
- this._geometry = new ColliderShapeCapsuleBufferGeometry(this.collider.shape);
230
- }
231
- else {
232
- throw new Error('VRMSpringBoneColliderHelper: Unknown collider shape type detected');
233
- }
234
- const material = new THREE__namespace.LineBasicMaterial({
235
- color: 0xff00ff,
236
- depthTest: false,
237
- depthWrite: false,
238
- });
239
- this._line = new THREE__namespace.LineSegments(this._geometry, material);
240
- this.add(this._line);
241
- }
242
- dispose() {
243
- this._geometry.dispose();
244
- }
245
- updateMatrixWorld(force) {
246
- this.collider.updateWorldMatrix(true, false);
247
- this.matrix.copy(this.collider.matrixWorld);
248
- this._geometry.update();
249
- super.updateMatrixWorld(force);
250
- }
220
+ class VRMSpringBoneColliderHelper extends THREE__namespace.Group {
221
+ constructor(collider) {
222
+ super();
223
+ this.matrixAutoUpdate = false;
224
+ this.collider = collider;
225
+ if (this.collider.shape instanceof VRMSpringBoneColliderShapeSphere) {
226
+ this._geometry = new ColliderShapeSphereBufferGeometry(this.collider.shape);
227
+ }
228
+ else if (this.collider.shape instanceof VRMSpringBoneColliderShapeCapsule) {
229
+ this._geometry = new ColliderShapeCapsuleBufferGeometry(this.collider.shape);
230
+ }
231
+ else {
232
+ throw new Error('VRMSpringBoneColliderHelper: Unknown collider shape type detected');
233
+ }
234
+ const material = new THREE__namespace.LineBasicMaterial({
235
+ color: 0xff00ff,
236
+ depthTest: false,
237
+ depthWrite: false,
238
+ });
239
+ this._line = new THREE__namespace.LineSegments(this._geometry, material);
240
+ this.add(this._line);
241
+ }
242
+ dispose() {
243
+ this._geometry.dispose();
244
+ }
245
+ updateMatrixWorld(force) {
246
+ this.collider.updateWorldMatrix(true, false);
247
+ this.matrix.copy(this.collider.matrixWorld);
248
+ this._geometry.update();
249
+ super.updateMatrixWorld(force);
250
+ }
251
251
  }
252
252
 
253
- class SpringBoneBufferGeometry extends THREE__namespace.BufferGeometry {
254
- constructor(springBone) {
255
- super();
256
- this._currentRadius = 0;
257
- this._currentTail = new THREE__namespace.Vector3();
258
- this._springBone = springBone;
259
- this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(294), 3);
260
- this.setAttribute('position', this._attrPos);
261
- this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(194), 1);
262
- this.setIndex(this._attrIndex);
263
- this._buildIndex();
264
- this.update();
265
- }
266
- update() {
267
- let shouldUpdateGeometry = false;
268
- if (this._currentRadius !== this._springBone.settings.hitRadius) {
269
- this._currentRadius = this._springBone.settings.hitRadius;
270
- shouldUpdateGeometry = true;
271
- }
272
- if (!this._currentTail.equals(this._springBone.initialLocalChildPosition)) {
273
- this._currentTail.copy(this._springBone.initialLocalChildPosition);
274
- shouldUpdateGeometry = true;
275
- }
276
- if (shouldUpdateGeometry) {
277
- this._buildPosition();
278
- }
279
- }
280
- _buildPosition() {
281
- for (let i = 0; i < 32; i++) {
282
- const t = (i / 16.0) * Math.PI;
283
- this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);
284
- this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));
285
- this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));
286
- }
287
- this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
288
- this.translate(this._currentTail.x, this._currentTail.y, this._currentTail.z);
289
- this._attrPos.setXYZ(96, 0, 0, 0);
290
- this._attrPos.setXYZ(97, this._currentTail.x, this._currentTail.y, this._currentTail.z);
291
- this._attrPos.needsUpdate = true;
292
- }
293
- _buildIndex() {
294
- for (let i = 0; i < 32; i++) {
295
- const i1 = (i + 1) % 32;
296
- this._attrIndex.setXY(i * 2, i, i1);
297
- this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);
298
- this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);
299
- }
300
- this._attrIndex.setXY(192, 96, 97);
301
- this._attrIndex.needsUpdate = true;
302
- }
253
+ class SpringBoneBufferGeometry extends THREE__namespace.BufferGeometry {
254
+ constructor(springBone) {
255
+ super();
256
+ this._currentRadius = 0;
257
+ this._currentTail = new THREE__namespace.Vector3();
258
+ this._springBone = springBone;
259
+ this._attrPos = new THREE__namespace.BufferAttribute(new Float32Array(294), 3);
260
+ this.setAttribute('position', this._attrPos);
261
+ this._attrIndex = new THREE__namespace.BufferAttribute(new Uint16Array(194), 1);
262
+ this.setIndex(this._attrIndex);
263
+ this._buildIndex();
264
+ this.update();
265
+ }
266
+ update() {
267
+ let shouldUpdateGeometry = false;
268
+ if (this._currentRadius !== this._springBone.settings.hitRadius) {
269
+ this._currentRadius = this._springBone.settings.hitRadius;
270
+ shouldUpdateGeometry = true;
271
+ }
272
+ if (!this._currentTail.equals(this._springBone.initialLocalChildPosition)) {
273
+ this._currentTail.copy(this._springBone.initialLocalChildPosition);
274
+ shouldUpdateGeometry = true;
275
+ }
276
+ if (shouldUpdateGeometry) {
277
+ this._buildPosition();
278
+ }
279
+ }
280
+ _buildPosition() {
281
+ for (let i = 0; i < 32; i++) {
282
+ const t = (i / 16.0) * Math.PI;
283
+ this._attrPos.setXYZ(i, Math.cos(t), Math.sin(t), 0.0);
284
+ this._attrPos.setXYZ(32 + i, 0.0, Math.cos(t), Math.sin(t));
285
+ this._attrPos.setXYZ(64 + i, Math.sin(t), 0.0, Math.cos(t));
286
+ }
287
+ this.scale(this._currentRadius, this._currentRadius, this._currentRadius);
288
+ this.translate(this._currentTail.x, this._currentTail.y, this._currentTail.z);
289
+ this._attrPos.setXYZ(96, 0, 0, 0);
290
+ this._attrPos.setXYZ(97, this._currentTail.x, this._currentTail.y, this._currentTail.z);
291
+ this._attrPos.needsUpdate = true;
292
+ }
293
+ _buildIndex() {
294
+ for (let i = 0; i < 32; i++) {
295
+ const i1 = (i + 1) % 32;
296
+ this._attrIndex.setXY(i * 2, i, i1);
297
+ this._attrIndex.setXY(64 + i * 2, 32 + i, 32 + i1);
298
+ this._attrIndex.setXY(128 + i * 2, 64 + i, 64 + i1);
299
+ }
300
+ this._attrIndex.setXY(192, 96, 97);
301
+ this._attrIndex.needsUpdate = true;
302
+ }
303
303
  }
304
304
 
305
- class VRMSpringBoneJointHelper extends THREE__namespace.Group {
306
- constructor(springBone) {
307
- super();
308
- this.matrixAutoUpdate = false;
309
- this.springBone = springBone;
310
- this._geometry = new SpringBoneBufferGeometry(this.springBone);
311
- const material = new THREE__namespace.LineBasicMaterial({
312
- color: 0xffff00,
313
- depthTest: false,
314
- depthWrite: false,
315
- });
316
- this._line = new THREE__namespace.LineSegments(this._geometry, material);
317
- this.add(this._line);
318
- }
319
- dispose() {
320
- this._geometry.dispose();
321
- }
322
- updateMatrixWorld(force) {
323
- this.springBone.bone.updateWorldMatrix(true, false);
324
- this.matrix.copy(this.springBone.bone.matrixWorld);
325
- this._geometry.update();
326
- super.updateMatrixWorld(force);
327
- }
305
+ class VRMSpringBoneJointHelper extends THREE__namespace.Group {
306
+ constructor(springBone) {
307
+ super();
308
+ this.matrixAutoUpdate = false;
309
+ this.springBone = springBone;
310
+ this._geometry = new SpringBoneBufferGeometry(this.springBone);
311
+ const material = new THREE__namespace.LineBasicMaterial({
312
+ color: 0xffff00,
313
+ depthTest: false,
314
+ depthWrite: false,
315
+ });
316
+ this._line = new THREE__namespace.LineSegments(this._geometry, material);
317
+ this.add(this._line);
318
+ }
319
+ dispose() {
320
+ this._geometry.dispose();
321
+ }
322
+ updateMatrixWorld(force) {
323
+ this.springBone.bone.updateWorldMatrix(true, false);
324
+ this.matrix.copy(this.springBone.bone.matrixWorld);
325
+ this._geometry.update();
326
+ super.updateMatrixWorld(force);
327
+ }
328
328
  }
329
329
 
330
- /**
331
- * Represents a collider of a VRM.
332
- */
333
- class VRMSpringBoneCollider extends THREE__namespace.Object3D {
334
- constructor(shape) {
335
- super();
336
- this.shape = shape;
337
- }
330
+ /**
331
+ * Represents a collider of a VRM.
332
+ */
333
+ class VRMSpringBoneCollider extends THREE__namespace.Object3D {
334
+ constructor(shape) {
335
+ super();
336
+ this.shape = shape;
337
+ }
338
338
  }
339
339
 
340
- const _position = new THREE__namespace.Vector3();
341
- const _scale = new THREE__namespace.Vector3();
342
- /**
343
- * Extract world rotation of an object from its world space matrix, in cheaper way.
344
- *
345
- * @param object The object
346
- * @param out Target vector
347
- */
348
- function getWorldQuaternionLite(object, out) {
349
- object.matrixWorld.decompose(_position, out, _scale);
350
- return out;
340
+ const _position = new THREE__namespace.Vector3();
341
+ const _scale = new THREE__namespace.Vector3();
342
+ /**
343
+ * Extract world rotation of an object from its world space matrix, in cheaper way.
344
+ *
345
+ * @param object The object
346
+ * @param out Target vector
347
+ */
348
+ function getWorldQuaternionLite(object, out) {
349
+ object.matrixWorld.decompose(_position, out, _scale);
350
+ return out;
351
351
  }
352
352
 
353
- const _matA$1 = new THREE__namespace.Matrix4();
354
- /**
355
- * A compat function for `Matrix4.invert()` / `Matrix4.getInverse()`.
356
- * `Matrix4.invert()` is introduced in r123 and `Matrix4.getInverse()` emits a warning.
357
- * We are going to use this compat for a while.
358
- * @param target A target matrix
359
- */
360
- function mat4InvertCompat(target) {
361
- if (target.invert) {
362
- target.invert();
363
- }
364
- else {
365
- target.getInverse(_matA$1.copy(target));
366
- }
367
- return target;
353
+ const _matA$1 = new THREE__namespace.Matrix4();
354
+ /**
355
+ * A compat function for `Matrix4.invert()` / `Matrix4.getInverse()`.
356
+ * `Matrix4.invert()` is introduced in r123 and `Matrix4.getInverse()` emits a warning.
357
+ * We are going to use this compat for a while.
358
+ * @param target A target matrix
359
+ */
360
+ function mat4InvertCompat(target) {
361
+ if (target.invert) {
362
+ target.invert();
363
+ }
364
+ else {
365
+ target.getInverse(_matA$1.copy(target));
366
+ }
367
+ return target;
368
368
  }
369
369
 
370
- class Matrix4InverseCache {
371
- constructor(matrix) {
372
- /**
373
- * A cache of inverse of current matrix.
374
- */
375
- this._inverseCache = new THREE__namespace.Matrix4();
376
- /**
377
- * A flag that makes it want to recalculate its {@link _inverseCache}.
378
- * Will be set `true` when `elements` are mutated and be used in `getInverse`.
379
- */
380
- this._shouldUpdateInverse = true;
381
- this.matrix = matrix;
382
- const handler = {
383
- set: (obj, prop, newVal) => {
384
- this._shouldUpdateInverse = true;
385
- obj[prop] = newVal;
386
- return true;
387
- },
388
- };
389
- this._originalElements = matrix.elements;
390
- matrix.elements = new Proxy(matrix.elements, handler);
391
- }
392
- /**
393
- * Inverse of given matrix.
394
- * Note that it will return its internal private instance.
395
- * Make sure copying this before mutate this.
396
- */
397
- get inverse() {
398
- if (this._shouldUpdateInverse) {
399
- this._inverseCache.copy(this.matrix);
400
- mat4InvertCompat(this._inverseCache);
401
- this._shouldUpdateInverse = false;
402
- }
403
- return this._inverseCache;
404
- }
405
- revert() {
406
- this.matrix.elements = this._originalElements;
407
- }
370
+ class Matrix4InverseCache {
371
+ constructor(matrix) {
372
+ /**
373
+ * A cache of inverse of current matrix.
374
+ */
375
+ this._inverseCache = new THREE__namespace.Matrix4();
376
+ /**
377
+ * A flag that makes it want to recalculate its {@link _inverseCache}.
378
+ * Will be set `true` when `elements` are mutated and be used in `getInverse`.
379
+ */
380
+ this._shouldUpdateInverse = true;
381
+ this.matrix = matrix;
382
+ const handler = {
383
+ set: (obj, prop, newVal) => {
384
+ this._shouldUpdateInverse = true;
385
+ obj[prop] = newVal;
386
+ return true;
387
+ },
388
+ };
389
+ this._originalElements = matrix.elements;
390
+ matrix.elements = new Proxy(matrix.elements, handler);
391
+ }
392
+ /**
393
+ * Inverse of given matrix.
394
+ * Note that it will return its internal private instance.
395
+ * Make sure copying this before mutate this.
396
+ */
397
+ get inverse() {
398
+ if (this._shouldUpdateInverse) {
399
+ this._inverseCache.copy(this.matrix);
400
+ mat4InvertCompat(this._inverseCache);
401
+ this._shouldUpdateInverse = false;
402
+ }
403
+ return this._inverseCache;
404
+ }
405
+ revert() {
406
+ this.matrix.elements = this._originalElements;
407
+ }
408
408
  }
409
409
 
410
- // based on
411
- // http://rocketjump.skr.jp/unity3d/109/
412
- // https://github.com/dwango/UniVRM/blob/master/Scripts/SpringBone/VRMSpringBone.cs
413
- const IDENTITY_MATRIX4 = Object.freeze(new THREE__namespace.Matrix4());
414
- const IDENTITY_QUATERNION = Object.freeze(new THREE__namespace.Quaternion());
415
- // 計算中の一時保存用変数(一度インスタンスを作ったらあとは使い回す)
416
- const _v3A = new THREE__namespace.Vector3();
417
- const _v3B = new THREE__namespace.Vector3();
418
- // const _v3C = new THREE.Vector3();
419
- const _quatA = new THREE__namespace.Quaternion();
420
- const _matA = new THREE__namespace.Matrix4();
421
- const _matB = new THREE__namespace.Matrix4();
422
- /**
423
- * A class represents a single joint of a spring bone.
424
- * It should be managed by a [[VRMSpringBoneManager]].
425
- */
426
- class VRMSpringBoneJoint {
427
- /**
428
- * Create a new VRMSpringBone.
429
- *
430
- * @param bone An Object3D that will be attached to this bone
431
- * @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
432
- * @param settings Several parameters related to behavior of the spring bone
433
- * @param colliderGroups Collider groups that will be collided with this spring bone
434
- */
435
- constructor(bone, child, settings = {}, colliderGroups = []) {
436
- var _a, _b, _c, _d, _e, _f;
437
- /**
438
- * Current position of child tail, in world unit. Will be used for verlet integration.
439
- */
440
- this._currentTail = new THREE__namespace.Vector3();
441
- /**
442
- * Previous position of child tail, in world unit. Will be used for verlet integration.
443
- */
444
- this._prevTail = new THREE__namespace.Vector3();
445
- /**
446
- * Next position of child tail, in world unit. Will be used for verlet integration.
447
- * Actually used only in [[update]] and it's kind of temporary variable.
448
- */
449
- this._nextTail = new THREE__namespace.Vector3();
450
- /**
451
- * Initial axis of the bone, in local unit.
452
- */
453
- this._boneAxis = new THREE__namespace.Vector3();
454
- /**
455
- * Length of the bone in relative space unit. Will be used for normalization in update loop.
456
- * It's same as local unit length unless there are scale transformation in world matrix.
457
- */
458
- this._centerSpaceBoneLength = 0.0;
459
- /**
460
- * Position of this bone in relative space, kind of a temporary variable.
461
- */
462
- this._centerSpacePosition = new THREE__namespace.Vector3();
463
- /**
464
- * This springbone will be calculated based on the space relative from this object.
465
- * If this is `null`, springbone will be calculated in world space.
466
- */
467
- this._center = null;
468
- /**
469
- * Rotation of parent bone, in world unit.
470
- * We should update this constantly in [[update]].
471
- */
472
- this._parentWorldRotation = new THREE__namespace.Quaternion();
473
- /**
474
- * Initial state of the local matrix of the bone.
475
- */
476
- this._initialLocalMatrix = new THREE__namespace.Matrix4();
477
- /**
478
- * Initial state of the rotation of the bone.
479
- */
480
- this._initialLocalRotation = new THREE__namespace.Quaternion();
481
- /**
482
- * Initial state of the position of its child.
483
- */
484
- this._initialLocalChildPosition = new THREE__namespace.Vector3();
485
- this.bone = bone; // uniVRMでの parent
486
- this.bone.matrixAutoUpdate = false; // updateにより計算されるのでthree.js内での自動処理は不要
487
- this.child = child;
488
- this.settings = {
489
- hitRadius: (_a = settings.hitRadius) !== null && _a !== void 0 ? _a : 0.0,
490
- stiffness: (_b = settings.stiffness) !== null && _b !== void 0 ? _b : 1.0,
491
- gravityPower: (_c = settings.gravityPower) !== null && _c !== void 0 ? _c : 0.0,
492
- gravityDir: (_e = (_d = settings.gravityDir) === null || _d === void 0 ? void 0 : _d.clone()) !== null && _e !== void 0 ? _e : new THREE__namespace.Vector3(0.0, -1.0, 0.0),
493
- dragForce: (_f = settings.dragForce) !== null && _f !== void 0 ? _f : 0.4,
494
- };
495
- this.colliderGroups = colliderGroups;
496
- }
497
- get center() {
498
- return this._center;
499
- }
500
- set center(center) {
501
- var _a;
502
- // convert tails to world space
503
- this._getMatrixCenterToWorld(_matA);
504
- this._currentTail.applyMatrix4(_matA);
505
- this._prevTail.applyMatrix4(_matA);
506
- this._nextTail.applyMatrix4(_matA);
507
- // uninstall inverse cache
508
- if ((_a = this._center) === null || _a === void 0 ? void 0 : _a.userData.inverseCacheProxy) {
509
- this._center.userData.inverseCacheProxy.revert();
510
- delete this._center.userData.inverseCacheProxy;
511
- }
512
- // change the center
513
- this._center = center;
514
- // install inverse cache
515
- if (this._center) {
516
- if (!this._center.userData.inverseCacheProxy) {
517
- this._center.userData.inverseCacheProxy = new Matrix4InverseCache(this._center.matrixWorld);
518
- }
519
- }
520
- // convert tails to center space
521
- this._getMatrixWorldToCenter(_matA);
522
- this._currentTail.applyMatrix4(_matA);
523
- this._prevTail.applyMatrix4(_matA);
524
- this._nextTail.applyMatrix4(_matA);
525
- // convert center space dependant state
526
- _matA.multiply(this.bone.matrixWorld); // 🔥 ??
527
- this._centerSpacePosition.setFromMatrixPosition(_matA);
528
- this._centerSpaceBoneLength = _v3A
529
- .copy(this._initialLocalChildPosition)
530
- .applyMatrix4(_matA)
531
- .sub(this._centerSpacePosition)
532
- .length();
533
- }
534
- get initialLocalChildPosition() {
535
- return this._initialLocalChildPosition;
536
- }
537
- /**
538
- * Set the initial state of this spring bone.
539
- * You might want to call {@link VRMSpringBoneManager.setInitState} instead.
540
- */
541
- setInitState() {
542
- this.bone.updateMatrix();
543
- this.bone.updateWorldMatrix(false, false);
544
- // remember initial position of itself
545
- this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);
546
- this._initialLocalMatrix.copy(this.bone.matrix);
547
- this._initialLocalRotation.copy(this.bone.quaternion);
548
- // see initial position of its local child
549
- if (this.child) {
550
- this._initialLocalChildPosition.copy(this.child.position);
551
- }
552
- else {
553
- // 末端のボーン。子ボーンがいないため「自分の少し先」が子ボーンということにする
554
- // https://github.com/dwango/UniVRM/blob/master/Assets/VRM/UniVRM/Scripts/SpringBone/VRMSpringBone.cs#L246
555
- this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07); // magic number! derives from original UniVRM source
556
- }
557
- // copy the child position to tails
558
- this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));
559
- this._prevTail.copy(this._currentTail);
560
- this._nextTail.copy(this._currentTail);
561
- // set initial states that are related to local child position
562
- this._boneAxis.copy(this._initialLocalChildPosition).normalize();
563
- this._centerSpaceBoneLength = _v3A
564
- .copy(this._initialLocalChildPosition)
565
- .applyMatrix4(this.bone.matrixWorld)
566
- .sub(this._centerSpacePosition)
567
- .length();
568
- }
569
- /**
570
- * Reset the state of this bone.
571
- * You might want to call [[VRMSpringBoneManager.reset]] instead.
572
- */
573
- reset() {
574
- this.bone.quaternion.copy(this._initialLocalRotation);
575
- // We need to update its matrixWorld manually, since we tweaked the bone by our hand
576
- this.bone.updateMatrix();
577
- this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
578
- this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);
579
- // Apply updated position to tail states
580
- this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));
581
- this._prevTail.copy(this._currentTail);
582
- this._nextTail.copy(this._currentTail);
583
- }
584
- /**
585
- * Update the state of this bone.
586
- * You might want to call [[VRMSpringBoneManager.update]] instead.
587
- *
588
- * @param delta deltaTime
589
- */
590
- update(delta) {
591
- if (delta <= 0)
592
- return;
593
- // 親スプリングボーンの姿勢は常に変化している。
594
- // それに基づいて処理直前に自分のworldMatrixを更新しておく
595
- this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
596
- if (this.bone.parent) {
597
- // SpringBoneは親から順に処理されていくため、
598
- // 親のmatrixWorldは最新状態の前提でworldMatrixからquaternionを取り出す。
599
- // 制限はあるけれど、計算は少ないのでgetWorldQuaternionではなくこの方法を取る。
600
- getWorldQuaternionLite(this.bone.parent, this._parentWorldRotation);
601
- }
602
- else {
603
- this._parentWorldRotation.copy(IDENTITY_QUATERNION);
604
- }
605
- // Get bone position in center space
606
- this._getMatrixWorldToCenter(_matA);
607
- _matA.multiply(this.bone.matrixWorld); // 🔥 ??
608
- this._centerSpacePosition.setFromMatrixPosition(_matA);
609
- // Get parent position in center space
610
- this._getMatrixWorldToCenter(_matB);
611
- _matB.multiply(this._getParentMatrixWorld());
612
- // several parameters
613
- const stiffness = this.settings.stiffness * delta;
614
- const external = _v3B.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower * delta);
615
- // verlet積分で次の位置を計算
616
- this._nextTail
617
- .copy(this._currentTail)
618
- .add(_v3A
619
- .copy(this._currentTail)
620
- .sub(this._prevTail)
621
- .multiplyScalar(1 - this.settings.dragForce)) // 前フレームの移動を継続する(減衰もあるよ)
622
- .add(_v3A
623
- .copy(this._boneAxis)
624
- .applyMatrix4(this._initialLocalMatrix)
625
- .applyMatrix4(_matB)
626
- .sub(this._centerSpacePosition)
627
- .normalize()
628
- .multiplyScalar(stiffness)) // 親の回転による子ボーンの移動目標
629
- .add(external); // 外力による移動量
630
- // normalize bone length
631
- this._nextTail
632
- .sub(this._centerSpacePosition)
633
- .normalize()
634
- .multiplyScalar(this._centerSpaceBoneLength)
635
- .add(this._centerSpacePosition);
636
- // Collisionで移動
637
- this._collision(this._nextTail);
638
- this._prevTail.copy(this._currentTail);
639
- this._currentTail.copy(this._nextTail);
640
- // Apply rotation, convert vector3 thing into actual quaternion
641
- // Original UniVRM is doing world unit calculus at here but we're gonna do this on local unit
642
- // since Three.js is not good at world coordination stuff
643
- const initialCenterSpaceMatrixInv = mat4InvertCompat(_matA.copy(_matB.multiply(this._initialLocalMatrix)));
644
- const applyRotation = _quatA.setFromUnitVectors(this._boneAxis, _v3A.copy(this._nextTail).applyMatrix4(initialCenterSpaceMatrixInv).normalize());
645
- this.bone.quaternion.copy(this._initialLocalRotation).multiply(applyRotation);
646
- // We need to update its matrixWorld manually, since we tweaked the bone by our hand
647
- this.bone.updateMatrix();
648
- this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
649
- }
650
- /**
651
- * Do collision math against every colliders attached to this bone.
652
- *
653
- * @param tail The tail you want to process
654
- */
655
- _collision(tail) {
656
- this.colliderGroups.forEach((colliderGroup) => {
657
- colliderGroup.colliders.forEach((collider) => {
658
- this._getMatrixWorldToCenter(_matA);
659
- _matA.multiply(collider.matrixWorld);
660
- const dist = collider.shape.calculateCollision(_matA, tail, this.settings.hitRadius, _v3A);
661
- if (dist < 0.0) {
662
- // hit
663
- tail.add(_v3A.multiplyScalar(-dist));
664
- // normalize bone length
665
- tail
666
- .sub(this._centerSpacePosition)
667
- .normalize()
668
- .multiplyScalar(this._centerSpaceBoneLength)
669
- .add(this._centerSpacePosition);
670
- }
671
- });
672
- });
673
- }
674
- /**
675
- * Create a matrix that converts center space into world space.
676
- * @param target Target matrix
677
- */
678
- _getMatrixCenterToWorld(target) {
679
- if (this._center) {
680
- target.copy(this._center.matrixWorld);
681
- }
682
- else {
683
- target.identity();
684
- }
685
- return target;
686
- }
687
- /**
688
- * Create a matrix that converts world space into center space.
689
- * @param target Target matrix
690
- */
691
- _getMatrixWorldToCenter(target) {
692
- if (this._center) {
693
- target.copy(this._center.userData.inverseCacheProxy.inverse);
694
- }
695
- else {
696
- target.identity();
697
- }
698
- return target;
699
- }
700
- /**
701
- * Returns the world matrix of its parent object.
702
- */
703
- _getParentMatrixWorld() {
704
- return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;
705
- }
410
+ // based on
411
+ // http://rocketjump.skr.jp/unity3d/109/
412
+ // https://github.com/dwango/UniVRM/blob/master/Scripts/SpringBone/VRMSpringBone.cs
413
+ const IDENTITY_MATRIX4 = Object.freeze(new THREE__namespace.Matrix4());
414
+ const IDENTITY_QUATERNION = Object.freeze(new THREE__namespace.Quaternion());
415
+ // 計算中の一時保存用変数(一度インスタンスを作ったらあとは使い回す)
416
+ const _v3A = new THREE__namespace.Vector3();
417
+ const _v3B = new THREE__namespace.Vector3();
418
+ // const _v3C = new THREE.Vector3();
419
+ const _quatA = new THREE__namespace.Quaternion();
420
+ const _matA = new THREE__namespace.Matrix4();
421
+ const _matB = new THREE__namespace.Matrix4();
422
+ /**
423
+ * A class represents a single joint of a spring bone.
424
+ * It should be managed by a [[VRMSpringBoneManager]].
425
+ */
426
+ class VRMSpringBoneJoint {
427
+ /**
428
+ * Create a new VRMSpringBone.
429
+ *
430
+ * @param bone An Object3D that will be attached to this bone
431
+ * @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
432
+ * @param settings Several parameters related to behavior of the spring bone
433
+ * @param colliderGroups Collider groups that will be collided with this spring bone
434
+ */
435
+ constructor(bone, child, settings = {}, colliderGroups = []) {
436
+ var _a, _b, _c, _d, _e, _f;
437
+ /**
438
+ * Current position of child tail, in world unit. Will be used for verlet integration.
439
+ */
440
+ this._currentTail = new THREE__namespace.Vector3();
441
+ /**
442
+ * Previous position of child tail, in world unit. Will be used for verlet integration.
443
+ */
444
+ this._prevTail = new THREE__namespace.Vector3();
445
+ /**
446
+ * Next position of child tail, in world unit. Will be used for verlet integration.
447
+ * Actually used only in [[update]] and it's kind of temporary variable.
448
+ */
449
+ this._nextTail = new THREE__namespace.Vector3();
450
+ /**
451
+ * Initial axis of the bone, in local unit.
452
+ */
453
+ this._boneAxis = new THREE__namespace.Vector3();
454
+ /**
455
+ * Length of the bone in relative space unit. Will be used for normalization in update loop.
456
+ * It's same as local unit length unless there are scale transformation in world matrix.
457
+ */
458
+ this._centerSpaceBoneLength = 0.0;
459
+ /**
460
+ * Position of this bone in relative space, kind of a temporary variable.
461
+ */
462
+ this._centerSpacePosition = new THREE__namespace.Vector3();
463
+ /**
464
+ * This springbone will be calculated based on the space relative from this object.
465
+ * If this is `null`, springbone will be calculated in world space.
466
+ */
467
+ this._center = null;
468
+ /**
469
+ * Rotation of parent bone, in world unit.
470
+ * We should update this constantly in [[update]].
471
+ */
472
+ this._parentWorldRotation = new THREE__namespace.Quaternion();
473
+ /**
474
+ * Initial state of the local matrix of the bone.
475
+ */
476
+ this._initialLocalMatrix = new THREE__namespace.Matrix4();
477
+ /**
478
+ * Initial state of the rotation of the bone.
479
+ */
480
+ this._initialLocalRotation = new THREE__namespace.Quaternion();
481
+ /**
482
+ * Initial state of the position of its child.
483
+ */
484
+ this._initialLocalChildPosition = new THREE__namespace.Vector3();
485
+ this.bone = bone; // uniVRMでの parent
486
+ this.bone.matrixAutoUpdate = false; // updateにより計算されるのでthree.js内での自動処理は不要
487
+ this.child = child;
488
+ this.settings = {
489
+ hitRadius: (_a = settings.hitRadius) !== null && _a !== void 0 ? _a : 0.0,
490
+ stiffness: (_b = settings.stiffness) !== null && _b !== void 0 ? _b : 1.0,
491
+ gravityPower: (_c = settings.gravityPower) !== null && _c !== void 0 ? _c : 0.0,
492
+ gravityDir: (_e = (_d = settings.gravityDir) === null || _d === void 0 ? void 0 : _d.clone()) !== null && _e !== void 0 ? _e : new THREE__namespace.Vector3(0.0, -1.0, 0.0),
493
+ dragForce: (_f = settings.dragForce) !== null && _f !== void 0 ? _f : 0.4,
494
+ };
495
+ this.colliderGroups = colliderGroups;
496
+ }
497
+ get center() {
498
+ return this._center;
499
+ }
500
+ set center(center) {
501
+ var _a;
502
+ // convert tails to world space
503
+ this._getMatrixCenterToWorld(_matA);
504
+ this._currentTail.applyMatrix4(_matA);
505
+ this._prevTail.applyMatrix4(_matA);
506
+ this._nextTail.applyMatrix4(_matA);
507
+ // uninstall inverse cache
508
+ if ((_a = this._center) === null || _a === void 0 ? void 0 : _a.userData.inverseCacheProxy) {
509
+ this._center.userData.inverseCacheProxy.revert();
510
+ delete this._center.userData.inverseCacheProxy;
511
+ }
512
+ // change the center
513
+ this._center = center;
514
+ // install inverse cache
515
+ if (this._center) {
516
+ if (!this._center.userData.inverseCacheProxy) {
517
+ this._center.userData.inverseCacheProxy = new Matrix4InverseCache(this._center.matrixWorld);
518
+ }
519
+ }
520
+ // convert tails to center space
521
+ this._getMatrixWorldToCenter(_matA);
522
+ this._currentTail.applyMatrix4(_matA);
523
+ this._prevTail.applyMatrix4(_matA);
524
+ this._nextTail.applyMatrix4(_matA);
525
+ // convert center space dependant state
526
+ _matA.multiply(this.bone.matrixWorld); // 🔥 ??
527
+ this._centerSpacePosition.setFromMatrixPosition(_matA);
528
+ this._centerSpaceBoneLength = _v3A
529
+ .copy(this._initialLocalChildPosition)
530
+ .applyMatrix4(_matA)
531
+ .sub(this._centerSpacePosition)
532
+ .length();
533
+ }
534
+ get initialLocalChildPosition() {
535
+ return this._initialLocalChildPosition;
536
+ }
537
+ /**
538
+ * Set the initial state of this spring bone.
539
+ * You might want to call {@link VRMSpringBoneManager.setInitState} instead.
540
+ */
541
+ setInitState() {
542
+ this.bone.updateMatrix();
543
+ this.bone.updateWorldMatrix(false, false);
544
+ // remember initial position of itself
545
+ this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);
546
+ this._initialLocalMatrix.copy(this.bone.matrix);
547
+ this._initialLocalRotation.copy(this.bone.quaternion);
548
+ // see initial position of its local child
549
+ if (this.child) {
550
+ this._initialLocalChildPosition.copy(this.child.position);
551
+ }
552
+ else {
553
+ // vrm0 requires a 7cm fixed bone length for the final node in a chain
554
+ // See: https://github.com/vrm-c/vrm-specification/tree/master/specification/VRMC_springBone-1.0-beta#about-spring-configuration
555
+ this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07);
556
+ }
557
+ // copy the child position to tails
558
+ this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));
559
+ this._prevTail.copy(this._currentTail);
560
+ this._nextTail.copy(this._currentTail);
561
+ // set initial states that are related to local child position
562
+ this._boneAxis.copy(this._initialLocalChildPosition).normalize();
563
+ this._centerSpaceBoneLength = _v3A
564
+ .copy(this._initialLocalChildPosition)
565
+ .applyMatrix4(this.bone.matrixWorld)
566
+ .sub(this._centerSpacePosition)
567
+ .length();
568
+ }
569
+ /**
570
+ * Reset the state of this bone.
571
+ * You might want to call [[VRMSpringBoneManager.reset]] instead.
572
+ */
573
+ reset() {
574
+ this.bone.quaternion.copy(this._initialLocalRotation);
575
+ // We need to update its matrixWorld manually, since we tweaked the bone by our hand
576
+ this.bone.updateMatrix();
577
+ this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
578
+ this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);
579
+ // Apply updated position to tail states
580
+ this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));
581
+ this._prevTail.copy(this._currentTail);
582
+ this._nextTail.copy(this._currentTail);
583
+ }
584
+ /**
585
+ * Update the state of this bone.
586
+ * You might want to call [[VRMSpringBoneManager.update]] instead.
587
+ *
588
+ * @param delta deltaTime
589
+ */
590
+ update(delta) {
591
+ if (delta <= 0)
592
+ return;
593
+ // 親スプリングボーンの姿勢は常に変化している。
594
+ // それに基づいて処理直前に自分のworldMatrixを更新しておく
595
+ this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
596
+ if (this.bone.parent) {
597
+ // SpringBoneは親から順に処理されていくため、
598
+ // 親のmatrixWorldは最新状態の前提でworldMatrixからquaternionを取り出す。
599
+ // 制限はあるけれど、計算は少ないのでgetWorldQuaternionではなくこの方法を取る。
600
+ getWorldQuaternionLite(this.bone.parent, this._parentWorldRotation);
601
+ }
602
+ else {
603
+ this._parentWorldRotation.copy(IDENTITY_QUATERNION);
604
+ }
605
+ // Get bone position in center space
606
+ this._getMatrixWorldToCenter(_matA);
607
+ _matA.multiply(this.bone.matrixWorld); // 🔥 ??
608
+ this._centerSpacePosition.setFromMatrixPosition(_matA);
609
+ // Get parent position in center space
610
+ this._getMatrixWorldToCenter(_matB);
611
+ _matB.multiply(this._getParentMatrixWorld());
612
+ // several parameters
613
+ const stiffness = this.settings.stiffness * delta;
614
+ const external = _v3B.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower * delta);
615
+ // verlet積分で次の位置を計算
616
+ this._nextTail
617
+ .copy(this._currentTail)
618
+ .add(_v3A
619
+ .copy(this._currentTail)
620
+ .sub(this._prevTail)
621
+ .multiplyScalar(1 - this.settings.dragForce)) // 前フレームの移動を継続する(減衰もあるよ)
622
+ .add(_v3A
623
+ .copy(this._boneAxis)
624
+ .applyMatrix4(this._initialLocalMatrix)
625
+ .applyMatrix4(_matB)
626
+ .sub(this._centerSpacePosition)
627
+ .normalize()
628
+ .multiplyScalar(stiffness)) // 親の回転による子ボーンの移動目標
629
+ .add(external); // 外力による移動量
630
+ // normalize bone length
631
+ this._nextTail
632
+ .sub(this._centerSpacePosition)
633
+ .normalize()
634
+ .multiplyScalar(this._centerSpaceBoneLength)
635
+ .add(this._centerSpacePosition);
636
+ // Collisionで移動
637
+ this._collision(this._nextTail);
638
+ this._prevTail.copy(this._currentTail);
639
+ this._currentTail.copy(this._nextTail);
640
+ // Apply rotation, convert vector3 thing into actual quaternion
641
+ // Original UniVRM is doing world unit calculus at here but we're gonna do this on local unit
642
+ // since Three.js is not good at world coordination stuff
643
+ const initialCenterSpaceMatrixInv = mat4InvertCompat(_matA.copy(_matB.multiply(this._initialLocalMatrix)));
644
+ const applyRotation = _quatA.setFromUnitVectors(this._boneAxis, _v3A.copy(this._nextTail).applyMatrix4(initialCenterSpaceMatrixInv).normalize());
645
+ this.bone.quaternion.copy(this._initialLocalRotation).multiply(applyRotation);
646
+ // We need to update its matrixWorld manually, since we tweaked the bone by our hand
647
+ this.bone.updateMatrix();
648
+ this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);
649
+ }
650
+ /**
651
+ * Do collision math against every colliders attached to this bone.
652
+ *
653
+ * @param tail The tail you want to process
654
+ */
655
+ _collision(tail) {
656
+ this.colliderGroups.forEach((colliderGroup) => {
657
+ colliderGroup.colliders.forEach((collider) => {
658
+ this._getMatrixWorldToCenter(_matA);
659
+ _matA.multiply(collider.matrixWorld);
660
+ const dist = collider.shape.calculateCollision(_matA, tail, this.settings.hitRadius, _v3A);
661
+ if (dist < 0.0) {
662
+ // hit
663
+ tail.add(_v3A.multiplyScalar(-dist));
664
+ // normalize bone length
665
+ tail
666
+ .sub(this._centerSpacePosition)
667
+ .normalize()
668
+ .multiplyScalar(this._centerSpaceBoneLength)
669
+ .add(this._centerSpacePosition);
670
+ }
671
+ });
672
+ });
673
+ }
674
+ /**
675
+ * Create a matrix that converts center space into world space.
676
+ * @param target Target matrix
677
+ */
678
+ _getMatrixCenterToWorld(target) {
679
+ if (this._center) {
680
+ target.copy(this._center.matrixWorld);
681
+ }
682
+ else {
683
+ target.identity();
684
+ }
685
+ return target;
686
+ }
687
+ /**
688
+ * Create a matrix that converts world space into center space.
689
+ * @param target Target matrix
690
+ */
691
+ _getMatrixWorldToCenter(target) {
692
+ if (this._center) {
693
+ target.copy(this._center.userData.inverseCacheProxy.inverse);
694
+ }
695
+ else {
696
+ target.identity();
697
+ }
698
+ return target;
699
+ }
700
+ /**
701
+ * Returns the world matrix of its parent object.
702
+ */
703
+ _getParentMatrixWorld() {
704
+ return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;
705
+ }
706
706
  }
707
707
 
708
708
  /*! *****************************************************************************
@@ -730,398 +730,398 @@
730
730
  });
731
731
  }
732
732
 
733
- function traverseAncestorsFromRoot(object, callback) {
734
- const ancestors = [];
735
- let head = object;
736
- while (head !== null) {
737
- ancestors.unshift(head);
738
- head = head.parent;
739
- }
740
- ancestors.forEach((ancestor) => {
741
- callback(ancestor);
742
- });
733
+ function traverseAncestorsFromRoot(object, callback) {
734
+ const ancestors = [];
735
+ let head = object;
736
+ while (head !== null) {
737
+ ancestors.unshift(head);
738
+ head = head.parent;
739
+ }
740
+ ancestors.forEach((ancestor) => {
741
+ callback(ancestor);
742
+ });
743
743
  }
744
744
 
745
- /**
746
- * Traverse children of given object and execute given callback.
747
- * The given object itself wont be given to the callback.
748
- * If the return value of the callback is `true`, it will halt the traversal of its children.
749
- * @param object A root object
750
- * @param callback A callback function called for each children
751
- */
752
- function traverseChildrenUntilConditionMet(object, callback) {
753
- object.children.forEach((child) => {
754
- const result = callback(child);
755
- if (!result) {
756
- traverseChildrenUntilConditionMet(child, callback);
757
- }
758
- });
745
+ /**
746
+ * Traverse children of given object and execute given callback.
747
+ * The given object itself wont be given to the callback.
748
+ * If the return value of the callback is `true`, it will halt the traversal of its children.
749
+ * @param object A root object
750
+ * @param callback A callback function called for each children
751
+ */
752
+ function traverseChildrenUntilConditionMet(object, callback) {
753
+ object.children.forEach((child) => {
754
+ const result = callback(child);
755
+ if (!result) {
756
+ traverseChildrenUntilConditionMet(child, callback);
757
+ }
758
+ });
759
759
  }
760
760
 
761
- class VRMSpringBoneManager {
762
- constructor() {
763
- this._springBones = new Set();
764
- this._objectSpringBonesMap = new Map();
765
- }
766
- get springBones() {
767
- return this._springBones;
768
- }
769
- get colliderGroups() {
770
- const set = new Set();
771
- this._springBones.forEach((springBone) => {
772
- springBone.colliderGroups.forEach((colliderGroup) => {
773
- set.add(colliderGroup);
774
- });
775
- });
776
- return Array.from(set);
777
- }
778
- get colliders() {
779
- const set = new Set();
780
- this.colliderGroups.forEach((colliderGroup) => {
781
- colliderGroup.colliders.forEach((collider) => {
782
- set.add(collider);
783
- });
784
- });
785
- return Array.from(set);
786
- }
787
- addSpringBone(springBone) {
788
- this._springBones.add(springBone);
789
- let objectSet = this._objectSpringBonesMap.get(springBone.bone);
790
- if (objectSet == null) {
791
- objectSet = new Set();
792
- this._objectSpringBonesMap.set(springBone.bone, objectSet);
793
- }
794
- objectSet.add(springBone);
795
- }
796
- deleteSpringBone(springBone) {
797
- this._springBones.delete(springBone);
798
- const objectSet = this._objectSpringBonesMap.get(springBone.bone);
799
- objectSet.delete(springBone);
800
- }
801
- setInitState() {
802
- const springBonesTried = new Set();
803
- const springBonesDone = new Set();
804
- for (const springBone of this._springBones) {
805
- this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.setInitState());
806
- }
807
- }
808
- reset() {
809
- const springBonesTried = new Set();
810
- const springBonesDone = new Set();
811
- for (const springBone of this._springBones) {
812
- this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.reset());
813
- }
814
- }
815
- update(delta) {
816
- const constraintsTried = new Set();
817
- const constraintsDone = new Set();
818
- for (const springBone of this._springBones) {
819
- // update the springbone
820
- this._processSpringBone(springBone, constraintsTried, constraintsDone, (springBone) => springBone.update(delta));
821
- // update children world matrices
822
- // it is required when the spring bone chain is sparse
823
- traverseChildrenUntilConditionMet(springBone.bone, (object) => {
824
- var _a, _b;
825
- // if the object has attached springbone, halt the traversal
826
- if (((_b = (_a = this._objectSpringBonesMap.get(object)) === null || _a === void 0 ? void 0 : _a.size) !== null && _b !== void 0 ? _b : 0) > 0) {
827
- return true;
828
- }
829
- // otherwise update its world matrix
830
- object.updateWorldMatrix(false, false);
831
- return false;
832
- });
833
- }
834
- }
835
- /**
836
- * Update a spring bone.
837
- * If there are other spring bone that are dependant, it will try to update them recursively.
838
- * It might throw an error if there are circular dependencies.
839
- *
840
- * Intended to be used in {@link update} and {@link _processSpringBone} itself recursively.
841
- *
842
- * @param springBone A springBone you want to update
843
- * @param springBonesTried Set of springBones that are already tried to be updated
844
- * @param springBonesDone Set of springBones that are already up to date
845
- */
846
- _processSpringBone(springBone, springBonesTried, springBonesDone, callback) {
847
- if (springBonesDone.has(springBone)) {
848
- return;
849
- }
850
- if (springBonesTried.has(springBone)) {
851
- throw new Error('VRMSpringBoneManager: Circular dependency detected while updating constraints');
852
- }
853
- springBonesTried.add(springBone);
854
- const depObjects = this._getDependencies(springBone);
855
- for (const depObject of depObjects) {
856
- traverseAncestorsFromRoot(depObject, (depObjectAncestor) => {
857
- const objectSet = this._objectSpringBonesMap.get(depObjectAncestor);
858
- if (objectSet) {
859
- for (const depConstraint of objectSet) {
860
- this._processSpringBone(depConstraint, springBonesTried, springBonesDone, callback);
861
- }
862
- }
863
- });
864
- }
865
- callback(springBone);
866
- springBonesDone.add(springBone);
867
- }
868
- /**
869
- * Return a set of objects that are dependant of given spring bone.
870
- * @param springBone A spring bone
871
- * @return A set of objects that are dependant of given spring bone
872
- */
873
- _getDependencies(springBone) {
874
- const set = new Set();
875
- const parent = springBone.bone.parent;
876
- if (parent) {
877
- set.add(parent);
878
- }
879
- return set;
880
- }
761
+ class VRMSpringBoneManager {
762
+ constructor() {
763
+ this._springBones = new Set();
764
+ this._objectSpringBonesMap = new Map();
765
+ }
766
+ get springBones() {
767
+ return this._springBones;
768
+ }
769
+ get colliderGroups() {
770
+ const set = new Set();
771
+ this._springBones.forEach((springBone) => {
772
+ springBone.colliderGroups.forEach((colliderGroup) => {
773
+ set.add(colliderGroup);
774
+ });
775
+ });
776
+ return Array.from(set);
777
+ }
778
+ get colliders() {
779
+ const set = new Set();
780
+ this.colliderGroups.forEach((colliderGroup) => {
781
+ colliderGroup.colliders.forEach((collider) => {
782
+ set.add(collider);
783
+ });
784
+ });
785
+ return Array.from(set);
786
+ }
787
+ addSpringBone(springBone) {
788
+ this._springBones.add(springBone);
789
+ let objectSet = this._objectSpringBonesMap.get(springBone.bone);
790
+ if (objectSet == null) {
791
+ objectSet = new Set();
792
+ this._objectSpringBonesMap.set(springBone.bone, objectSet);
793
+ }
794
+ objectSet.add(springBone);
795
+ }
796
+ deleteSpringBone(springBone) {
797
+ this._springBones.delete(springBone);
798
+ const objectSet = this._objectSpringBonesMap.get(springBone.bone);
799
+ objectSet.delete(springBone);
800
+ }
801
+ setInitState() {
802
+ const springBonesTried = new Set();
803
+ const springBonesDone = new Set();
804
+ for (const springBone of this._springBones) {
805
+ this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.setInitState());
806
+ }
807
+ }
808
+ reset() {
809
+ const springBonesTried = new Set();
810
+ const springBonesDone = new Set();
811
+ for (const springBone of this._springBones) {
812
+ this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.reset());
813
+ }
814
+ }
815
+ update(delta) {
816
+ const constraintsTried = new Set();
817
+ const constraintsDone = new Set();
818
+ for (const springBone of this._springBones) {
819
+ // update the springbone
820
+ this._processSpringBone(springBone, constraintsTried, constraintsDone, (springBone) => springBone.update(delta));
821
+ // update children world matrices
822
+ // it is required when the spring bone chain is sparse
823
+ traverseChildrenUntilConditionMet(springBone.bone, (object) => {
824
+ var _a, _b;
825
+ // if the object has attached springbone, halt the traversal
826
+ if (((_b = (_a = this._objectSpringBonesMap.get(object)) === null || _a === void 0 ? void 0 : _a.size) !== null && _b !== void 0 ? _b : 0) > 0) {
827
+ return true;
828
+ }
829
+ // otherwise update its world matrix
830
+ object.updateWorldMatrix(false, false);
831
+ return false;
832
+ });
833
+ }
834
+ }
835
+ /**
836
+ * Update a spring bone.
837
+ * If there are other spring bone that are dependant, it will try to update them recursively.
838
+ * It might throw an error if there are circular dependencies.
839
+ *
840
+ * Intended to be used in {@link update} and {@link _processSpringBone} itself recursively.
841
+ *
842
+ * @param springBone A springBone you want to update
843
+ * @param springBonesTried Set of springBones that are already tried to be updated
844
+ * @param springBonesDone Set of springBones that are already up to date
845
+ */
846
+ _processSpringBone(springBone, springBonesTried, springBonesDone, callback) {
847
+ if (springBonesDone.has(springBone)) {
848
+ return;
849
+ }
850
+ if (springBonesTried.has(springBone)) {
851
+ throw new Error('VRMSpringBoneManager: Circular dependency detected while updating constraints');
852
+ }
853
+ springBonesTried.add(springBone);
854
+ const depObjects = this._getDependencies(springBone);
855
+ for (const depObject of depObjects) {
856
+ traverseAncestorsFromRoot(depObject, (depObjectAncestor) => {
857
+ const objectSet = this._objectSpringBonesMap.get(depObjectAncestor);
858
+ if (objectSet) {
859
+ for (const depConstraint of objectSet) {
860
+ this._processSpringBone(depConstraint, springBonesTried, springBonesDone, callback);
861
+ }
862
+ }
863
+ });
864
+ }
865
+ callback(springBone);
866
+ springBonesDone.add(springBone);
867
+ }
868
+ /**
869
+ * Return a set of objects that are dependant of given spring bone.
870
+ * @param springBone A spring bone
871
+ * @return A set of objects that are dependant of given spring bone
872
+ */
873
+ _getDependencies(springBone) {
874
+ const set = new Set();
875
+ const parent = springBone.bone.parent;
876
+ if (parent) {
877
+ set.add(parent);
878
+ }
879
+ return set;
880
+ }
881
881
  }
882
882
 
883
- class VRMSpringBoneLoaderPlugin {
884
- constructor(parser, options) {
885
- this.parser = parser;
886
- this.jointHelperRoot = options === null || options === void 0 ? void 0 : options.jointHelperRoot;
887
- this.colliderHelperRoot = options === null || options === void 0 ? void 0 : options.colliderHelperRoot;
888
- }
889
- get name() {
890
- return VRMSpringBoneLoaderPlugin.EXTENSION_NAME;
891
- }
892
- afterRoot(gltf) {
893
- return __awaiter(this, void 0, void 0, function* () {
894
- gltf.userData.vrmSpringBoneManager = yield this._import(gltf);
895
- });
896
- }
897
- /**
898
- * Import spring bones from a GLTF and return a {@link VRMSpringBoneManager}.
899
- * It might return `null` instead when it does not need to be created or something go wrong.
900
- *
901
- * @param gltf A parsed result of GLTF taken from GLTFLoader
902
- */
903
- _import(gltf) {
904
- return __awaiter(this, void 0, void 0, function* () {
905
- const v1Result = yield this._v1Import(gltf);
906
- if (v1Result != null) {
907
- return v1Result;
908
- }
909
- const v0Result = yield this._v0Import(gltf);
910
- if (v0Result != null) {
911
- return v0Result;
912
- }
913
- return null;
914
- });
915
- }
916
- _v1Import(gltf) {
917
- var _a, _b, _c, _d, _e;
918
- return __awaiter(this, void 0, void 0, function* () {
919
- // early abort if it doesn't use spring bones
920
- const isSpringBoneUsed = ((_a = gltf.parser.json.extensionsUsed) === null || _a === void 0 ? void 0 : _a.indexOf(VRMSpringBoneLoaderPlugin.EXTENSION_NAME)) !== -1;
921
- if (!isSpringBoneUsed) {
922
- return null;
923
- }
924
- const manager = new VRMSpringBoneManager();
925
- const threeNodes = yield gltf.parser.getDependencies('node');
926
- const extension = (_b = gltf.parser.json.extensions) === null || _b === void 0 ? void 0 : _b[VRMSpringBoneLoaderPlugin.EXTENSION_NAME];
927
- if (!extension) {
928
- return null;
929
- }
930
- const specVersion = extension.specVersion;
931
- if (specVersion !== '1.0-beta') {
932
- return null;
933
- }
934
- const colliders = (_c = extension.colliders) === null || _c === void 0 ? void 0 : _c.map((schemaCollider, iCollider) => {
935
- var _a, _b, _c, _d, _e;
936
- const node = threeNodes[schemaCollider.node];
937
- const schemaShape = schemaCollider.shape;
938
- if (schemaShape.sphere) {
939
- return this._importSphereCollider(node, {
940
- offset: new THREE__namespace.Vector3().fromArray((_a = schemaShape.sphere.offset) !== null && _a !== void 0 ? _a : [0.0, 0.0, 0.0]),
941
- radius: (_b = schemaShape.sphere.radius) !== null && _b !== void 0 ? _b : 0.0,
942
- });
943
- }
944
- else if (schemaShape.capsule) {
945
- return this._importCapsuleCollider(node, {
946
- offset: new THREE__namespace.Vector3().fromArray((_c = schemaShape.capsule.offset) !== null && _c !== void 0 ? _c : [0.0, 0.0, 0.0]),
947
- radius: (_d = schemaShape.capsule.radius) !== null && _d !== void 0 ? _d : 0.0,
948
- tail: new THREE__namespace.Vector3().fromArray((_e = schemaShape.capsule.tail) !== null && _e !== void 0 ? _e : [0.0, 0.0, 0.0]),
949
- });
950
- }
951
- throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${iCollider} has no valid shape`);
952
- });
953
- const colliderGroups = (_d = extension.colliderGroups) === null || _d === void 0 ? void 0 : _d.map((schemaColliderGroup, iColliderGroup) => {
954
- var _a;
955
- const cols = ((_a = schemaColliderGroup.colliders) !== null && _a !== void 0 ? _a : []).map((iCollider) => {
956
- const col = colliders === null || colliders === void 0 ? void 0 : colliders[iCollider];
957
- if (col == null) {
958
- throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${iColliderGroup} attempted to use a collider #${iCollider} but not found`);
959
- }
960
- return col;
961
- });
962
- return {
963
- colliders: cols,
964
- name: schemaColliderGroup.name,
965
- };
966
- });
967
- (_e = extension.springs) === null || _e === void 0 ? void 0 : _e.forEach((schemaSpring, iSpring) => {
968
- var _a;
969
- const schemaJoints = schemaSpring.joints;
970
- // prepare colliders
971
- const colliderGroupsForSpring = (_a = schemaSpring.colliderGroups) === null || _a === void 0 ? void 0 : _a.map((iColliderGroup) => {
972
- const group = colliderGroups === null || colliderGroups === void 0 ? void 0 : colliderGroups[iColliderGroup];
973
- if (group == null) {
974
- throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${iSpring} attempted to use a colliderGroup ${iColliderGroup} but not found`);
975
- }
976
- return group;
977
- });
978
- let prevJoint;
979
- schemaJoints.forEach((joint) => {
980
- var _a;
981
- if (prevJoint) {
982
- // prepare node
983
- const nodeIndex = prevJoint.node;
984
- const node = threeNodes[nodeIndex];
985
- const childIndex = joint.node;
986
- const child = threeNodes[childIndex];
987
- // prepare setting
988
- const setting = {
989
- hitRadius: prevJoint.hitRadius,
990
- dragForce: prevJoint.dragForce,
991
- gravityPower: prevJoint.gravityPower,
992
- stiffness: prevJoint.stiffness,
993
- gravityDir: new THREE__namespace.Vector3().fromArray((_a = prevJoint.gravityDir) !== null && _a !== void 0 ? _a : [0.0, 1.0, 0.0]),
994
- };
995
- // create spring bones
996
- const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);
997
- manager.addSpringBone(spring);
998
- }
999
- prevJoint = joint;
1000
- });
1001
- });
1002
- // init spring bones
1003
- gltf.scene.updateMatrixWorld();
1004
- manager.setInitState();
1005
- return manager;
1006
- });
1007
- }
1008
- _v0Import(gltf) {
1009
- var _a, _b, _c;
1010
- return __awaiter(this, void 0, void 0, function* () {
1011
- // early abort if it doesn't use vrm
1012
- const isVRMUsed = ((_a = gltf.parser.json.extensionsUsed) === null || _a === void 0 ? void 0 : _a.indexOf('VRM')) !== -1;
1013
- if (!isVRMUsed) {
1014
- return null;
1015
- }
1016
- // early abort if it doesn't have bone groups
1017
- const extension = (_b = gltf.parser.json.extensions) === null || _b === void 0 ? void 0 : _b['VRM'];
1018
- const schemaSecondaryAnimation = extension === null || extension === void 0 ? void 0 : extension.secondaryAnimation;
1019
- if (!schemaSecondaryAnimation) {
1020
- return null;
1021
- }
1022
- const schemaBoneGroups = schemaSecondaryAnimation === null || schemaSecondaryAnimation === void 0 ? void 0 : schemaSecondaryAnimation.boneGroups;
1023
- if (!schemaBoneGroups) {
1024
- return null;
1025
- }
1026
- const manager = new VRMSpringBoneManager();
1027
- const threeNodes = yield gltf.parser.getDependencies('node');
1028
- const colliderGroups = (_c = schemaSecondaryAnimation.colliderGroups) === null || _c === void 0 ? void 0 : _c.map((schemaColliderGroup) => {
1029
- var _a;
1030
- const node = threeNodes[schemaColliderGroup.node];
1031
- const colliders = ((_a = schemaColliderGroup.colliders) !== null && _a !== void 0 ? _a : []).map((schemaCollider, iCollider) => {
1032
- var _a, _b, _c;
1033
- const offset = new THREE__namespace.Vector3(0.0, 0.0, 0.0);
1034
- if (schemaCollider.offset) {
1035
- offset.set((_a = schemaCollider.offset.x) !== null && _a !== void 0 ? _a : 0.0, (_b = schemaCollider.offset.y) !== null && _b !== void 0 ? _b : 0.0, schemaCollider.offset.z ? -schemaCollider.offset.z : 0.0);
1036
- }
1037
- return this._importSphereCollider(node, {
1038
- offset,
1039
- radius: (_c = schemaCollider.radius) !== null && _c !== void 0 ? _c : 0.0,
1040
- });
1041
- });
1042
- return { colliders };
1043
- });
1044
- // import spring bones for each spring bone groups
1045
- schemaBoneGroups === null || schemaBoneGroups === void 0 ? void 0 : schemaBoneGroups.forEach((schemaBoneGroup, iBoneGroup) => {
1046
- const rootIndices = schemaBoneGroup.bones;
1047
- if (!rootIndices) {
1048
- return;
1049
- }
1050
- rootIndices.forEach((rootIndex) => {
1051
- var _a, _b, _c, _d;
1052
- const root = threeNodes[rootIndex];
1053
- // prepare setting
1054
- const gravityDir = new THREE__namespace.Vector3();
1055
- if (schemaBoneGroup.gravityDir) {
1056
- gravityDir.set((_a = schemaBoneGroup.gravityDir.x) !== null && _a !== void 0 ? _a : 0.0, (_b = schemaBoneGroup.gravityDir.y) !== null && _b !== void 0 ? _b : 0.0, (_c = schemaBoneGroup.gravityDir.z) !== null && _c !== void 0 ? _c : 0.0);
1057
- }
1058
- else {
1059
- gravityDir.set(0.0, -1.0, 0.0);
1060
- }
1061
- const setting = {
1062
- hitRadius: schemaBoneGroup.hitRadius,
1063
- dragForce: schemaBoneGroup.dragForce,
1064
- gravityPower: schemaBoneGroup.gravityPower,
1065
- stiffness: schemaBoneGroup.stiffiness,
1066
- gravityDir,
1067
- };
1068
- // prepare colliders
1069
- const colliderGroupsForSpring = (_d = schemaBoneGroup.colliderGroups) === null || _d === void 0 ? void 0 : _d.map((iColliderGroup) => {
1070
- const group = colliderGroups === null || colliderGroups === void 0 ? void 0 : colliderGroups[iColliderGroup];
1071
- if (group == null) {
1072
- throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${iBoneGroup} attempted to use a colliderGroup ${iColliderGroup} but not found`);
1073
- }
1074
- return group;
1075
- });
1076
- // create spring bones
1077
- root.traverse((node) => {
1078
- var _a;
1079
- const child = (_a = node.children[0]) !== null && _a !== void 0 ? _a : null;
1080
- const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);
1081
- manager.addSpringBone(spring);
1082
- });
1083
- });
1084
- });
1085
- // init spring bones
1086
- gltf.scene.updateMatrixWorld();
1087
- manager.setInitState();
1088
- return manager;
1089
- });
1090
- }
1091
- _importJoint(node, child, setting, colliderGroupsForSpring) {
1092
- const springBone = new VRMSpringBoneJoint(node, child, setting, colliderGroupsForSpring);
1093
- if (this.jointHelperRoot) {
1094
- const helper = new VRMSpringBoneJointHelper(springBone);
1095
- this.jointHelperRoot.add(helper);
1096
- helper.renderOrder = this.jointHelperRoot.renderOrder;
1097
- }
1098
- return springBone;
1099
- }
1100
- _importSphereCollider(destination, params) {
1101
- const { offset, radius } = params;
1102
- const shape = new VRMSpringBoneColliderShapeSphere({ offset, radius });
1103
- const collider = new VRMSpringBoneCollider(shape);
1104
- destination.add(collider);
1105
- if (this.colliderHelperRoot) {
1106
- const helper = new VRMSpringBoneColliderHelper(collider);
1107
- this.colliderHelperRoot.add(helper);
1108
- helper.renderOrder = this.colliderHelperRoot.renderOrder;
1109
- }
1110
- return collider;
1111
- }
1112
- _importCapsuleCollider(destination, params) {
1113
- const { offset, radius, tail } = params;
1114
- const shape = new VRMSpringBoneColliderShapeCapsule({ offset, radius, tail });
1115
- const collider = new VRMSpringBoneCollider(shape);
1116
- destination.add(collider);
1117
- if (this.colliderHelperRoot) {
1118
- const helper = new VRMSpringBoneColliderHelper(collider);
1119
- this.colliderHelperRoot.add(helper);
1120
- helper.renderOrder = this.colliderHelperRoot.renderOrder;
1121
- }
1122
- return collider;
1123
- }
1124
- }
883
+ class VRMSpringBoneLoaderPlugin {
884
+ constructor(parser, options) {
885
+ this.parser = parser;
886
+ this.jointHelperRoot = options === null || options === void 0 ? void 0 : options.jointHelperRoot;
887
+ this.colliderHelperRoot = options === null || options === void 0 ? void 0 : options.colliderHelperRoot;
888
+ }
889
+ get name() {
890
+ return VRMSpringBoneLoaderPlugin.EXTENSION_NAME;
891
+ }
892
+ afterRoot(gltf) {
893
+ return __awaiter(this, void 0, void 0, function* () {
894
+ gltf.userData.vrmSpringBoneManager = yield this._import(gltf);
895
+ });
896
+ }
897
+ /**
898
+ * Import spring bones from a GLTF and return a {@link VRMSpringBoneManager}.
899
+ * It might return `null` instead when it does not need to be created or something go wrong.
900
+ *
901
+ * @param gltf A parsed result of GLTF taken from GLTFLoader
902
+ */
903
+ _import(gltf) {
904
+ return __awaiter(this, void 0, void 0, function* () {
905
+ const v1Result = yield this._v1Import(gltf);
906
+ if (v1Result != null) {
907
+ return v1Result;
908
+ }
909
+ const v0Result = yield this._v0Import(gltf);
910
+ if (v0Result != null) {
911
+ return v0Result;
912
+ }
913
+ return null;
914
+ });
915
+ }
916
+ _v1Import(gltf) {
917
+ var _a, _b, _c, _d, _e;
918
+ return __awaiter(this, void 0, void 0, function* () {
919
+ // early abort if it doesn't use spring bones
920
+ const isSpringBoneUsed = ((_a = gltf.parser.json.extensionsUsed) === null || _a === void 0 ? void 0 : _a.indexOf(VRMSpringBoneLoaderPlugin.EXTENSION_NAME)) !== -1;
921
+ if (!isSpringBoneUsed) {
922
+ return null;
923
+ }
924
+ const manager = new VRMSpringBoneManager();
925
+ const threeNodes = yield gltf.parser.getDependencies('node');
926
+ const extension = (_b = gltf.parser.json.extensions) === null || _b === void 0 ? void 0 : _b[VRMSpringBoneLoaderPlugin.EXTENSION_NAME];
927
+ if (!extension) {
928
+ return null;
929
+ }
930
+ const specVersion = extension.specVersion;
931
+ if (specVersion !== '1.0-beta') {
932
+ return null;
933
+ }
934
+ const colliders = (_c = extension.colliders) === null || _c === void 0 ? void 0 : _c.map((schemaCollider, iCollider) => {
935
+ var _a, _b, _c, _d, _e;
936
+ const node = threeNodes[schemaCollider.node];
937
+ const schemaShape = schemaCollider.shape;
938
+ if (schemaShape.sphere) {
939
+ return this._importSphereCollider(node, {
940
+ offset: new THREE__namespace.Vector3().fromArray((_a = schemaShape.sphere.offset) !== null && _a !== void 0 ? _a : [0.0, 0.0, 0.0]),
941
+ radius: (_b = schemaShape.sphere.radius) !== null && _b !== void 0 ? _b : 0.0,
942
+ });
943
+ }
944
+ else if (schemaShape.capsule) {
945
+ return this._importCapsuleCollider(node, {
946
+ offset: new THREE__namespace.Vector3().fromArray((_c = schemaShape.capsule.offset) !== null && _c !== void 0 ? _c : [0.0, 0.0, 0.0]),
947
+ radius: (_d = schemaShape.capsule.radius) !== null && _d !== void 0 ? _d : 0.0,
948
+ tail: new THREE__namespace.Vector3().fromArray((_e = schemaShape.capsule.tail) !== null && _e !== void 0 ? _e : [0.0, 0.0, 0.0]),
949
+ });
950
+ }
951
+ throw new Error(`VRMSpringBoneLoaderPlugin: The collider #${iCollider} has no valid shape`);
952
+ });
953
+ const colliderGroups = (_d = extension.colliderGroups) === null || _d === void 0 ? void 0 : _d.map((schemaColliderGroup, iColliderGroup) => {
954
+ var _a;
955
+ const cols = ((_a = schemaColliderGroup.colliders) !== null && _a !== void 0 ? _a : []).map((iCollider) => {
956
+ const col = colliders === null || colliders === void 0 ? void 0 : colliders[iCollider];
957
+ if (col == null) {
958
+ throw new Error(`VRMSpringBoneLoaderPlugin: The colliderGroup #${iColliderGroup} attempted to use a collider #${iCollider} but not found`);
959
+ }
960
+ return col;
961
+ });
962
+ return {
963
+ colliders: cols,
964
+ name: schemaColliderGroup.name,
965
+ };
966
+ });
967
+ (_e = extension.springs) === null || _e === void 0 ? void 0 : _e.forEach((schemaSpring, iSpring) => {
968
+ var _a;
969
+ const schemaJoints = schemaSpring.joints;
970
+ // prepare colliders
971
+ const colliderGroupsForSpring = (_a = schemaSpring.colliderGroups) === null || _a === void 0 ? void 0 : _a.map((iColliderGroup) => {
972
+ const group = colliderGroups === null || colliderGroups === void 0 ? void 0 : colliderGroups[iColliderGroup];
973
+ if (group == null) {
974
+ throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${iSpring} attempted to use a colliderGroup ${iColliderGroup} but not found`);
975
+ }
976
+ return group;
977
+ });
978
+ let prevJoint;
979
+ schemaJoints.forEach((joint) => {
980
+ var _a;
981
+ if (prevJoint) {
982
+ // prepare node
983
+ const nodeIndex = prevJoint.node;
984
+ const node = threeNodes[nodeIndex];
985
+ const childIndex = joint.node;
986
+ const child = threeNodes[childIndex];
987
+ // prepare setting
988
+ const setting = {
989
+ hitRadius: prevJoint.hitRadius,
990
+ dragForce: prevJoint.dragForce,
991
+ gravityPower: prevJoint.gravityPower,
992
+ stiffness: prevJoint.stiffness,
993
+ gravityDir: new THREE__namespace.Vector3().fromArray((_a = prevJoint.gravityDir) !== null && _a !== void 0 ? _a : [0.0, 1.0, 0.0]),
994
+ };
995
+ // create spring bones
996
+ const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);
997
+ manager.addSpringBone(spring);
998
+ }
999
+ prevJoint = joint;
1000
+ });
1001
+ });
1002
+ // init spring bones
1003
+ gltf.scene.updateMatrixWorld();
1004
+ manager.setInitState();
1005
+ return manager;
1006
+ });
1007
+ }
1008
+ _v0Import(gltf) {
1009
+ var _a, _b, _c;
1010
+ return __awaiter(this, void 0, void 0, function* () {
1011
+ // early abort if it doesn't use vrm
1012
+ const isVRMUsed = ((_a = gltf.parser.json.extensionsUsed) === null || _a === void 0 ? void 0 : _a.indexOf('VRM')) !== -1;
1013
+ if (!isVRMUsed) {
1014
+ return null;
1015
+ }
1016
+ // early abort if it doesn't have bone groups
1017
+ const extension = (_b = gltf.parser.json.extensions) === null || _b === void 0 ? void 0 : _b['VRM'];
1018
+ const schemaSecondaryAnimation = extension === null || extension === void 0 ? void 0 : extension.secondaryAnimation;
1019
+ if (!schemaSecondaryAnimation) {
1020
+ return null;
1021
+ }
1022
+ const schemaBoneGroups = schemaSecondaryAnimation === null || schemaSecondaryAnimation === void 0 ? void 0 : schemaSecondaryAnimation.boneGroups;
1023
+ if (!schemaBoneGroups) {
1024
+ return null;
1025
+ }
1026
+ const manager = new VRMSpringBoneManager();
1027
+ const threeNodes = yield gltf.parser.getDependencies('node');
1028
+ const colliderGroups = (_c = schemaSecondaryAnimation.colliderGroups) === null || _c === void 0 ? void 0 : _c.map((schemaColliderGroup) => {
1029
+ var _a;
1030
+ const node = threeNodes[schemaColliderGroup.node];
1031
+ const colliders = ((_a = schemaColliderGroup.colliders) !== null && _a !== void 0 ? _a : []).map((schemaCollider, iCollider) => {
1032
+ var _a, _b, _c;
1033
+ const offset = new THREE__namespace.Vector3(0.0, 0.0, 0.0);
1034
+ if (schemaCollider.offset) {
1035
+ offset.set((_a = schemaCollider.offset.x) !== null && _a !== void 0 ? _a : 0.0, (_b = schemaCollider.offset.y) !== null && _b !== void 0 ? _b : 0.0, schemaCollider.offset.z ? -schemaCollider.offset.z : 0.0);
1036
+ }
1037
+ return this._importSphereCollider(node, {
1038
+ offset,
1039
+ radius: (_c = schemaCollider.radius) !== null && _c !== void 0 ? _c : 0.0,
1040
+ });
1041
+ });
1042
+ return { colliders };
1043
+ });
1044
+ // import spring bones for each spring bone groups
1045
+ schemaBoneGroups === null || schemaBoneGroups === void 0 ? void 0 : schemaBoneGroups.forEach((schemaBoneGroup, iBoneGroup) => {
1046
+ const rootIndices = schemaBoneGroup.bones;
1047
+ if (!rootIndices) {
1048
+ return;
1049
+ }
1050
+ rootIndices.forEach((rootIndex) => {
1051
+ var _a, _b, _c, _d;
1052
+ const root = threeNodes[rootIndex];
1053
+ // prepare setting
1054
+ const gravityDir = new THREE__namespace.Vector3();
1055
+ if (schemaBoneGroup.gravityDir) {
1056
+ gravityDir.set((_a = schemaBoneGroup.gravityDir.x) !== null && _a !== void 0 ? _a : 0.0, (_b = schemaBoneGroup.gravityDir.y) !== null && _b !== void 0 ? _b : 0.0, (_c = schemaBoneGroup.gravityDir.z) !== null && _c !== void 0 ? _c : 0.0);
1057
+ }
1058
+ else {
1059
+ gravityDir.set(0.0, -1.0, 0.0);
1060
+ }
1061
+ const setting = {
1062
+ hitRadius: schemaBoneGroup.hitRadius,
1063
+ dragForce: schemaBoneGroup.dragForce,
1064
+ gravityPower: schemaBoneGroup.gravityPower,
1065
+ stiffness: schemaBoneGroup.stiffiness,
1066
+ gravityDir,
1067
+ };
1068
+ // prepare colliders
1069
+ const colliderGroupsForSpring = (_d = schemaBoneGroup.colliderGroups) === null || _d === void 0 ? void 0 : _d.map((iColliderGroup) => {
1070
+ const group = colliderGroups === null || colliderGroups === void 0 ? void 0 : colliderGroups[iColliderGroup];
1071
+ if (group == null) {
1072
+ throw new Error(`VRMSpringBoneLoaderPlugin: The spring #${iBoneGroup} attempted to use a colliderGroup ${iColliderGroup} but not found`);
1073
+ }
1074
+ return group;
1075
+ });
1076
+ // create spring bones
1077
+ root.traverse((node) => {
1078
+ var _a;
1079
+ const child = (_a = node.children[0]) !== null && _a !== void 0 ? _a : null;
1080
+ const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);
1081
+ manager.addSpringBone(spring);
1082
+ });
1083
+ });
1084
+ });
1085
+ // init spring bones
1086
+ gltf.scene.updateMatrixWorld();
1087
+ manager.setInitState();
1088
+ return manager;
1089
+ });
1090
+ }
1091
+ _importJoint(node, child, setting, colliderGroupsForSpring) {
1092
+ const springBone = new VRMSpringBoneJoint(node, child, setting, colliderGroupsForSpring);
1093
+ if (this.jointHelperRoot) {
1094
+ const helper = new VRMSpringBoneJointHelper(springBone);
1095
+ this.jointHelperRoot.add(helper);
1096
+ helper.renderOrder = this.jointHelperRoot.renderOrder;
1097
+ }
1098
+ return springBone;
1099
+ }
1100
+ _importSphereCollider(destination, params) {
1101
+ const { offset, radius } = params;
1102
+ const shape = new VRMSpringBoneColliderShapeSphere({ offset, radius });
1103
+ const collider = new VRMSpringBoneCollider(shape);
1104
+ destination.add(collider);
1105
+ if (this.colliderHelperRoot) {
1106
+ const helper = new VRMSpringBoneColliderHelper(collider);
1107
+ this.colliderHelperRoot.add(helper);
1108
+ helper.renderOrder = this.colliderHelperRoot.renderOrder;
1109
+ }
1110
+ return collider;
1111
+ }
1112
+ _importCapsuleCollider(destination, params) {
1113
+ const { offset, radius, tail } = params;
1114
+ const shape = new VRMSpringBoneColliderShapeCapsule({ offset, radius, tail });
1115
+ const collider = new VRMSpringBoneCollider(shape);
1116
+ destination.add(collider);
1117
+ if (this.colliderHelperRoot) {
1118
+ const helper = new VRMSpringBoneColliderHelper(collider);
1119
+ this.colliderHelperRoot.add(helper);
1120
+ helper.renderOrder = this.colliderHelperRoot.renderOrder;
1121
+ }
1122
+ return collider;
1123
+ }
1124
+ }
1125
1125
  VRMSpringBoneLoaderPlugin.EXTENSION_NAME = 'VRMC_springBone';
1126
1126
 
1127
1127
  exports.VRMSpringBoneCollider = VRMSpringBoneCollider;
@@ -1139,4 +1139,4 @@
1139
1139
  Object.assign(THREE, exports);
1140
1140
 
1141
1141
  })));
1142
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"three-vrm-springbone.js","sources":["../src/VRMSpringBoneColliderShape.ts","../src/VRMSpringBoneColliderShapeCapsule.ts","../src/VRMSpringBoneColliderShapeSphere.ts","../src/helpers/utils/ColliderShapeCapsuleBufferGeometry.ts","../src/helpers/utils/ColliderShapeSphereBufferGeometry.ts","../src/helpers/VRMSpringBoneColliderHelper.ts","../src/helpers/utils/SpringBoneBufferGeometry.ts","../src/helpers/VRMSpringBoneJointHelper.ts","../src/VRMSpringBoneCollider.ts","../src/utils/getWorldQuaternionLite.ts","../src/utils/mat4InvertCompat.ts","../src/utils/Matrix4InverseCache.ts","../src/VRMSpringBoneJoint.ts","../../../node_modules/tslib/tslib.es6.js","../src/utils/traverseAncestorsFromRoot.ts","../src/utils/traverseChildrenUntilConditionMet.ts","../src/VRMSpringBoneManager.ts","../src/VRMSpringBoneLoaderPlugin.ts"],"sourcesContent":["/**\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 _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 ?? 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    _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 * 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 ?? 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    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 _vecA = new THREE.Vector3();\n\nexport class ColliderShapeCapsuleBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\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    if (this._currentRadius !== this._shape.radius) {\n      this._currentRadius = this._shape.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 (!this._currentTail.equals(this._shape.tail)) {\n      this._currentTail.copy(this._shape.tail);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    _vecA.copy(this._currentTail).sub(this._currentOffset);\n    const l = _vecA.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(_vecA.y, Math.sqrt(_vecA.x * _vecA.x + _vecA.z * _vecA.z));\n    const phi = -Math.atan2(_vecA.z, _vecA.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  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    if (this._currentRadius !== this._shape.radius) {\n      this._currentRadius = this._shape.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 { 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\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    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  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    if (this._currentRadius !== this._springBone.settings.hitRadius) {\n      this._currentRadius = this._springBone.settings.hitRadius;\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 { VRMSpringBoneJoint } from '../VRMSpringBoneJoint';\nimport { SpringBoneBufferGeometry } from './utils/SpringBoneBufferGeometry';\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    this._geometry.update();\n\n    super.updateMatrixWorld(force);\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';\n\nconst _position = new THREE.Vector3();\nconst _scale = new THREE.Vector3();\n\n/**\n * Extract world rotation of an object from its world space matrix, in cheaper way.\n *\n * @param object The object\n * @param out Target vector\n */\nexport function getWorldQuaternionLite(object: THREE.Object3D, out: THREE.Quaternion): THREE.Quaternion {\n  object.matrixWorld.decompose(_position, out, _scale);\n  return out;\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: number[];\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      this._inverseCache.copy(this.matrix);\n      mat4InvertCompat(this._inverseCache);\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: number, 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(matrix.elements, handler);\n  }\n\n  public revert(): void {\n    this.matrix.elements = this._originalElements;\n  }\n}\n","import * as THREE from 'three';\nimport { getWorldQuaternionLite } from './utils/getWorldQuaternionLite';\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 = Object.freeze(new THREE.Matrix4());\nconst IDENTITY_QUATERNION = Object.freeze(new THREE.Quaternion());\n\n// 計算中の一時保存用変数（一度インスタンスを作ったらあとは使い回す）\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\n// const _v3C = new THREE.Vector3();\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 world unit. Will be used for verlet integration.\n   */\n  private _currentTail = new THREE.Vector3();\n\n  /**\n   * Previous position of child tail, in world unit. Will be used for verlet integration.\n   */\n  private _prevTail = new THREE.Vector3();\n\n  /**\n   * Next position of child tail, in world unit. Will be used for verlet integration.\n   * Actually used only in [[update]] and it's kind of temporary variable.\n   */\n  private _nextTail = 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 relative space unit. Will be used for normalization in update loop.\n   * It's same as local unit length unless there are scale transformation in world matrix.\n   */\n  private _centerSpaceBoneLength = 0.0;\n\n  /**\n   * Position of this bone in relative space, kind of a temporary variable.\n   */\n  private _centerSpacePosition = new THREE.Vector3();\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    // convert tails to world space\n    this._getMatrixCenterToWorld(_matA);\n\n    this._currentTail.applyMatrix4(_matA);\n    this._prevTail.applyMatrix4(_matA);\n    this._nextTail.applyMatrix4(_matA);\n\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    // convert tails to center space\n    this._getMatrixWorldToCenter(_matA);\n\n    this._currentTail.applyMatrix4(_matA);\n    this._prevTail.applyMatrix4(_matA);\n    this._nextTail.applyMatrix4(_matA);\n\n    // convert center space dependant state\n    _matA.multiply(this.bone.matrixWorld); // 🔥 ??\n\n    this._centerSpacePosition.setFromMatrixPosition(_matA);\n\n    this._centerSpaceBoneLength = _v3A\n      .copy(this._initialLocalChildPosition)\n      .applyMatrix4(_matA)\n      .sub(this._centerSpacePosition)\n      .length();\n  }\n\n  /**\n   * Rotation of parent bone, in world unit.\n   * We should update this constantly in [[update]].\n   */\n  private _parentWorldRotation = new THREE.Quaternion();\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   * 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での parent\n    this.bone.matrixAutoUpdate = false; // updateにより計算されるのでthree.js内での自動処理は不要\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    this.bone.updateMatrix();\n    this.bone.updateWorldMatrix(false, false);\n\n    // remember initial position of itself\n    this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n\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      // 末端のボーン。子ボーンがいないため「自分の少し先」が子ボーンということにする\n      // https://github.com/dwango/UniVRM/blob/master/Assets/VRM/UniVRM/Scripts/SpringBone/VRMSpringBone.cs#L246\n      this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07); // magic number! derives from original UniVRM source\n    }\n\n    // copy the child position to tails\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));\n    this._prevTail.copy(this._currentTail);\n    this._nextTail.copy(this._currentTail);\n\n    // set initial states that are related to local child position\n    this._boneAxis.copy(this._initialLocalChildPosition).normalize();\n    this._centerSpaceBoneLength = _v3A\n      .copy(this._initialLocalChildPosition)\n      .applyMatrix4(this.bone.matrixWorld)\n      .sub(this._centerSpacePosition)\n      .length();\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._getParentMatrixWorld(), this.bone.matrix);\n    this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n\n    // Apply updated position to tail states\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));\n    this._prevTail.copy(this._currentTail);\n    this._nextTail.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    // 親スプリングボーンの姿勢は常に変化している。\n    // それに基づいて処理直前に自分のworldMatrixを更新しておく\n    this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);\n\n    if (this.bone.parent) {\n      // SpringBoneは親から順に処理されていくため、\n      // 親のmatrixWorldは最新状態の前提でworldMatrixからquaternionを取り出す。\n      // 制限はあるけれど、計算は少ないのでgetWorldQuaternionではなくこの方法を取る。\n      getWorldQuaternionLite(this.bone.parent, this._parentWorldRotation);\n    } else {\n      this._parentWorldRotation.copy(IDENTITY_QUATERNION);\n    }\n\n    // Get bone position in center space\n    this._getMatrixWorldToCenter(_matA);\n    _matA.multiply(this.bone.matrixWorld); // 🔥 ??\n    this._centerSpacePosition.setFromMatrixPosition(_matA);\n\n    // Get parent position in center space\n    this._getMatrixWorldToCenter(_matB);\n    _matB.multiply(this._getParentMatrixWorld());\n\n    // several parameters\n    const stiffness = this.settings.stiffness * delta;\n    const external = _v3B.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower * delta);\n\n    // verlet積分で次の位置を計算\n    this._nextTail\n      .copy(this._currentTail)\n      .add(\n        _v3A\n          .copy(this._currentTail)\n          .sub(this._prevTail)\n          .multiplyScalar(1 - this.settings.dragForce),\n      ) // 前フレームの移動を継続する(減衰もあるよ)\n      .add(\n        _v3A\n          .copy(this._boneAxis)\n          .applyMatrix4(this._initialLocalMatrix)\n          .applyMatrix4(_matB)\n          .sub(this._centerSpacePosition)\n          .normalize()\n          .multiplyScalar(stiffness),\n      ) // 親の回転による子ボーンの移動目標\n      .add(external); // 外力による移動量\n\n    // normalize bone length\n    this._nextTail\n      .sub(this._centerSpacePosition)\n      .normalize()\n      .multiplyScalar(this._centerSpaceBoneLength)\n      .add(this._centerSpacePosition);\n\n    // Collisionで移動\n    this._collision(this._nextTail);\n\n    this._prevTail.copy(this._currentTail);\n    this._currentTail.copy(this._nextTail);\n\n    // Apply rotation, convert vector3 thing into actual quaternion\n    // Original UniVRM is doing world unit calculus at here but we're gonna do this on local unit\n    // since Three.js is not good at world coordination stuff\n    const initialCenterSpaceMatrixInv = mat4InvertCompat(_matA.copy(_matB.multiply(this._initialLocalMatrix)));\n    const applyRotation = _quatA.setFromUnitVectors(\n      this._boneAxis,\n      _v3A.copy(this._nextTail).applyMatrix4(initialCenterSpaceMatrixInv).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._getParentMatrixWorld(), 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        this._getMatrixWorldToCenter(_matA);\n        _matA.multiply(collider.matrixWorld);\n\n        const dist = collider.shape.calculateCollision(_matA, 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\n            .sub(this._centerSpacePosition)\n            .normalize()\n            .multiplyScalar(this._centerSpaceBoneLength)\n            .add(this._centerSpacePosition);\n        }\n      });\n    });\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  /**\n   * Returns the world matrix of its parent object.\n   */\n  private _getParentMatrixWorld(): THREE.Matrix4 {\n    return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;\n  }\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from) {\r\n    for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\r\n        to[j] = from[i];\r\n    return to;\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\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","/**\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 _springBones = new Set<VRMSpringBoneJoint>();\n  public get springBones(): Set<VRMSpringBoneJoint> {\n    return this._springBones;\n  }\n\n  public get colliderGroups(): VRMSpringBoneColliderGroup[] {\n    const set = new Set<VRMSpringBoneColliderGroup>();\n    this._springBones.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 addSpringBone(springBone: VRMSpringBoneJoint): void {\n    this._springBones.add(springBone);\n\n    let objectSet = this._objectSpringBonesMap.get(springBone.bone);\n    if (objectSet == null) {\n      objectSet = new Set<VRMSpringBoneJoint>();\n      this._objectSpringBonesMap.set(springBone.bone, objectSet);\n    }\n    objectSet.add(springBone);\n  }\n\n  public deleteSpringBone(springBone: VRMSpringBoneJoint): void {\n    this._springBones.delete(springBone);\n\n    const objectSet = this._objectSpringBonesMap.get(springBone.bone)!;\n    objectSet.delete(springBone);\n  }\n\n  public setInitState(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.setInitState());\n    }\n  }\n\n  public reset(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.reset());\n    }\n  }\n\n  public update(delta: number): void {\n    const constraintsTried = new Set<VRMSpringBoneJoint>();\n    const constraintsDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      // update the springbone\n      this._processSpringBone(springBone, constraintsTried, constraintsDone, (springBone) => springBone.update(delta));\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 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   */\n  private _processSpringBone(\n    springBone: VRMSpringBoneJoint,\n    springBonesTried: Set<VRMSpringBoneJoint>,\n    springBonesDone: Set<VRMSpringBoneJoint>,\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 constraints');\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 depConstraint of objectSet) {\n            this._processSpringBone(depConstraint, springBonesTried, springBonesDone, callback);\n          }\n        }\n      });\n    }\n\n    callback(springBone);\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    return set;\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';\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';\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    // early abort if it doesn't use spring bones\n    const isSpringBoneUsed = gltf.parser.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: V1SpringBoneSchema.VRMCSpringBone | undefined =\n      gltf.parser.json.extensions?.[VRMSpringBoneLoaderPlugin.EXTENSION_NAME];\n    if (!extension) {\n      return null;\n    }\n\n    const specVersion = extension.specVersion;\n    if (specVersion !== '1.0-beta') {\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      let prevJoint: V1SpringBoneSchema.SpringBoneJoint | undefined;\n      schemaJoints.forEach((joint) => {\n        if (prevJoint) {\n          // prepare node\n          const nodeIndex = prevJoint.node;\n          const node = threeNodes[nodeIndex];\n          const childIndex = joint.node;\n          const child = threeNodes[childIndex];\n\n          // prepare setting\n          const setting: Partial<VRMSpringBoneJointSettings> = {\n            hitRadius: prevJoint.hitRadius,\n            dragForce: prevJoint.dragForce,\n            gravityPower: prevJoint.gravityPower,\n            stiffness: prevJoint.stiffness,\n            gravityDir: new THREE.Vector3().fromArray(prevJoint.gravityDir ?? [0.0, 1.0, 0.0]),\n          };\n\n          // create spring bones\n          const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          manager.addSpringBone(spring);\n        }\n\n        prevJoint = joint;\n      });\n    });\n\n    // init spring bones\n    gltf.scene.updateMatrixWorld();\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private async _v0Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    // early abort if it doesn't use vrm\n    const isVRMUsed = gltf.parser.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: V0VRM.VRM | undefined = gltf.parser.json.extensions?.['VRM'];\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        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          const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          manager.addSpringBone(spring);\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"],"names":["_v3A","THREE","_v3B","_matA"],"mappings":"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"}
1142
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"three-vrm-springbone.js","sources":["../src/VRMSpringBoneColliderShape.ts","../src/VRMSpringBoneColliderShapeCapsule.ts","../src/VRMSpringBoneColliderShapeSphere.ts","../src/helpers/utils/ColliderShapeCapsuleBufferGeometry.ts","../src/helpers/utils/ColliderShapeSphereBufferGeometry.ts","../src/helpers/VRMSpringBoneColliderHelper.ts","../src/helpers/utils/SpringBoneBufferGeometry.ts","../src/helpers/VRMSpringBoneJointHelper.ts","../src/VRMSpringBoneCollider.ts","../src/utils/getWorldQuaternionLite.ts","../src/utils/mat4InvertCompat.ts","../src/utils/Matrix4InverseCache.ts","../src/VRMSpringBoneJoint.ts","../../../node_modules/tslib/tslib.es6.js","../src/utils/traverseAncestorsFromRoot.ts","../src/utils/traverseChildrenUntilConditionMet.ts","../src/VRMSpringBoneManager.ts","../src/VRMSpringBoneLoaderPlugin.ts"],"sourcesContent":["/**\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 _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 ?? 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    _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 * 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 ?? 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    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 _vecA = new THREE.Vector3();\n\nexport class ColliderShapeCapsuleBufferGeometry extends THREE.BufferGeometry implements ColliderShapeBufferGeometry {\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    if (this._currentRadius !== this._shape.radius) {\n      this._currentRadius = this._shape.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 (!this._currentTail.equals(this._shape.tail)) {\n      this._currentTail.copy(this._shape.tail);\n      shouldUpdateGeometry = true;\n    }\n\n    if (shouldUpdateGeometry) {\n      this._buildPosition();\n    }\n  }\n\n  private _buildPosition(): void {\n    _vecA.copy(this._currentTail).sub(this._currentOffset);\n    const l = _vecA.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(_vecA.y, Math.sqrt(_vecA.x * _vecA.x + _vecA.z * _vecA.z));\n    const phi = -Math.atan2(_vecA.z, _vecA.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  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    if (this._currentRadius !== this._shape.radius) {\n      this._currentRadius = this._shape.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 { 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\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    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  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    if (this._currentRadius !== this._springBone.settings.hitRadius) {\n      this._currentRadius = this._springBone.settings.hitRadius;\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 { VRMSpringBoneJoint } from '../VRMSpringBoneJoint';\nimport { SpringBoneBufferGeometry } from './utils/SpringBoneBufferGeometry';\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    this._geometry.update();\n\n    super.updateMatrixWorld(force);\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';\n\nconst _position = new THREE.Vector3();\nconst _scale = new THREE.Vector3();\n\n/**\n * Extract world rotation of an object from its world space matrix, in cheaper way.\n *\n * @param object The object\n * @param out Target vector\n */\nexport function getWorldQuaternionLite(object: THREE.Object3D, out: THREE.Quaternion): THREE.Quaternion {\n  object.matrixWorld.decompose(_position, out, _scale);\n  return out;\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: number[];\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      this._inverseCache.copy(this.matrix);\n      mat4InvertCompat(this._inverseCache);\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: number, 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(matrix.elements, handler);\n  }\n\n  public revert(): void {\n    this.matrix.elements = this._originalElements;\n  }\n}\n","import * as THREE from 'three';\nimport { getWorldQuaternionLite } from './utils/getWorldQuaternionLite';\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 = Object.freeze(new THREE.Matrix4());\nconst IDENTITY_QUATERNION = Object.freeze(new THREE.Quaternion());\n\n// 計算中の一時保存用変数（一度インスタンスを作ったらあとは使い回す）\nconst _v3A = new THREE.Vector3();\nconst _v3B = new THREE.Vector3();\n// const _v3C = new THREE.Vector3();\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 world unit. Will be used for verlet integration.\n   */\n  private _currentTail = new THREE.Vector3();\n\n  /**\n   * Previous position of child tail, in world unit. Will be used for verlet integration.\n   */\n  private _prevTail = new THREE.Vector3();\n\n  /**\n   * Next position of child tail, in world unit. Will be used for verlet integration.\n   * Actually used only in [[update]] and it's kind of temporary variable.\n   */\n  private _nextTail = 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 relative space unit. Will be used for normalization in update loop.\n   * It's same as local unit length unless there are scale transformation in world matrix.\n   */\n  private _centerSpaceBoneLength = 0.0;\n\n  /**\n   * Position of this bone in relative space, kind of a temporary variable.\n   */\n  private _centerSpacePosition = new THREE.Vector3();\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    // convert tails to world space\n    this._getMatrixCenterToWorld(_matA);\n\n    this._currentTail.applyMatrix4(_matA);\n    this._prevTail.applyMatrix4(_matA);\n    this._nextTail.applyMatrix4(_matA);\n\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    // convert tails to center space\n    this._getMatrixWorldToCenter(_matA);\n\n    this._currentTail.applyMatrix4(_matA);\n    this._prevTail.applyMatrix4(_matA);\n    this._nextTail.applyMatrix4(_matA);\n\n    // convert center space dependant state\n    _matA.multiply(this.bone.matrixWorld); // 🔥 ??\n\n    this._centerSpacePosition.setFromMatrixPosition(_matA);\n\n    this._centerSpaceBoneLength = _v3A\n      .copy(this._initialLocalChildPosition)\n      .applyMatrix4(_matA)\n      .sub(this._centerSpacePosition)\n      .length();\n  }\n\n  /**\n   * Rotation of parent bone, in world unit.\n   * We should update this constantly in [[update]].\n   */\n  private _parentWorldRotation = new THREE.Quaternion();\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   * 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での parent\n    this.bone.matrixAutoUpdate = false; // updateにより計算されるのでthree.js内での自動処理は不要\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    this.bone.updateMatrix();\n    this.bone.updateWorldMatrix(false, false);\n\n    // remember initial position of itself\n    this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n\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-beta#about-spring-configuration\n      this._initialLocalChildPosition.copy(this.bone.position).normalize().multiplyScalar(0.07);\n    }\n\n    // copy the child position to tails\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));\n    this._prevTail.copy(this._currentTail);\n    this._nextTail.copy(this._currentTail);\n\n    // set initial states that are related to local child position\n    this._boneAxis.copy(this._initialLocalChildPosition).normalize();\n    this._centerSpaceBoneLength = _v3A\n      .copy(this._initialLocalChildPosition)\n      .applyMatrix4(this.bone.matrixWorld)\n      .sub(this._centerSpacePosition)\n      .length();\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._getParentMatrixWorld(), this.bone.matrix);\n    this._centerSpacePosition.setFromMatrixPosition(this.bone.matrixWorld);\n\n    // Apply updated position to tail states\n    this.bone.localToWorld(this._currentTail.copy(this._initialLocalChildPosition));\n    this._prevTail.copy(this._currentTail);\n    this._nextTail.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    // 親スプリングボーンの姿勢は常に変化している。\n    // それに基づいて処理直前に自分のworldMatrixを更新しておく\n    this.bone.matrixWorld.multiplyMatrices(this._getParentMatrixWorld(), this.bone.matrix);\n\n    if (this.bone.parent) {\n      // SpringBoneは親から順に処理されていくため、\n      // 親のmatrixWorldは最新状態の前提でworldMatrixからquaternionを取り出す。\n      // 制限はあるけれど、計算は少ないのでgetWorldQuaternionではなくこの方法を取る。\n      getWorldQuaternionLite(this.bone.parent, this._parentWorldRotation);\n    } else {\n      this._parentWorldRotation.copy(IDENTITY_QUATERNION);\n    }\n\n    // Get bone position in center space\n    this._getMatrixWorldToCenter(_matA);\n    _matA.multiply(this.bone.matrixWorld); // 🔥 ??\n    this._centerSpacePosition.setFromMatrixPosition(_matA);\n\n    // Get parent position in center space\n    this._getMatrixWorldToCenter(_matB);\n    _matB.multiply(this._getParentMatrixWorld());\n\n    // several parameters\n    const stiffness = this.settings.stiffness * delta;\n    const external = _v3B.copy(this.settings.gravityDir).multiplyScalar(this.settings.gravityPower * delta);\n\n    // verlet積分で次の位置を計算\n    this._nextTail\n      .copy(this._currentTail)\n      .add(\n        _v3A\n          .copy(this._currentTail)\n          .sub(this._prevTail)\n          .multiplyScalar(1 - this.settings.dragForce),\n      ) // 前フレームの移動を継続する(減衰もあるよ)\n      .add(\n        _v3A\n          .copy(this._boneAxis)\n          .applyMatrix4(this._initialLocalMatrix)\n          .applyMatrix4(_matB)\n          .sub(this._centerSpacePosition)\n          .normalize()\n          .multiplyScalar(stiffness),\n      ) // 親の回転による子ボーンの移動目標\n      .add(external); // 外力による移動量\n\n    // normalize bone length\n    this._nextTail\n      .sub(this._centerSpacePosition)\n      .normalize()\n      .multiplyScalar(this._centerSpaceBoneLength)\n      .add(this._centerSpacePosition);\n\n    // Collisionで移動\n    this._collision(this._nextTail);\n\n    this._prevTail.copy(this._currentTail);\n    this._currentTail.copy(this._nextTail);\n\n    // Apply rotation, convert vector3 thing into actual quaternion\n    // Original UniVRM is doing world unit calculus at here but we're gonna do this on local unit\n    // since Three.js is not good at world coordination stuff\n    const initialCenterSpaceMatrixInv = mat4InvertCompat(_matA.copy(_matB.multiply(this._initialLocalMatrix)));\n    const applyRotation = _quatA.setFromUnitVectors(\n      this._boneAxis,\n      _v3A.copy(this._nextTail).applyMatrix4(initialCenterSpaceMatrixInv).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._getParentMatrixWorld(), 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        this._getMatrixWorldToCenter(_matA);\n        _matA.multiply(collider.matrixWorld);\n\n        const dist = collider.shape.calculateCollision(_matA, 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\n            .sub(this._centerSpacePosition)\n            .normalize()\n            .multiplyScalar(this._centerSpaceBoneLength)\n            .add(this._centerSpacePosition);\n        }\n      });\n    });\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  /**\n   * Returns the world matrix of its parent object.\n   */\n  private _getParentMatrixWorld(): THREE.Matrix4 {\n    return this.bone.parent ? this.bone.parent.matrixWorld : IDENTITY_MATRIX4;\n  }\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from) {\r\n    for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\r\n        to[j] = from[i];\r\n    return to;\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\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","/**\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 _springBones = new Set<VRMSpringBoneJoint>();\n  public get springBones(): Set<VRMSpringBoneJoint> {\n    return this._springBones;\n  }\n\n  public get colliderGroups(): VRMSpringBoneColliderGroup[] {\n    const set = new Set<VRMSpringBoneColliderGroup>();\n    this._springBones.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 addSpringBone(springBone: VRMSpringBoneJoint): void {\n    this._springBones.add(springBone);\n\n    let objectSet = this._objectSpringBonesMap.get(springBone.bone);\n    if (objectSet == null) {\n      objectSet = new Set<VRMSpringBoneJoint>();\n      this._objectSpringBonesMap.set(springBone.bone, objectSet);\n    }\n    objectSet.add(springBone);\n  }\n\n  public deleteSpringBone(springBone: VRMSpringBoneJoint): void {\n    this._springBones.delete(springBone);\n\n    const objectSet = this._objectSpringBonesMap.get(springBone.bone)!;\n    objectSet.delete(springBone);\n  }\n\n  public setInitState(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.setInitState());\n    }\n  }\n\n  public reset(): void {\n    const springBonesTried = new Set<VRMSpringBoneJoint>();\n    const springBonesDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      this._processSpringBone(springBone, springBonesTried, springBonesDone, (springBone) => springBone.reset());\n    }\n  }\n\n  public update(delta: number): void {\n    const constraintsTried = new Set<VRMSpringBoneJoint>();\n    const constraintsDone = new Set<VRMSpringBoneJoint>();\n\n    for (const springBone of this._springBones) {\n      // update the springbone\n      this._processSpringBone(springBone, constraintsTried, constraintsDone, (springBone) => springBone.update(delta));\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 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   */\n  private _processSpringBone(\n    springBone: VRMSpringBoneJoint,\n    springBonesTried: Set<VRMSpringBoneJoint>,\n    springBonesDone: Set<VRMSpringBoneJoint>,\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 constraints');\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 depConstraint of objectSet) {\n            this._processSpringBone(depConstraint, springBonesTried, springBonesDone, callback);\n          }\n        }\n      });\n    }\n\n    callback(springBone);\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    return set;\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';\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';\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    // early abort if it doesn't use spring bones\n    const isSpringBoneUsed = gltf.parser.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: V1SpringBoneSchema.VRMCSpringBone | undefined =\n      gltf.parser.json.extensions?.[VRMSpringBoneLoaderPlugin.EXTENSION_NAME];\n    if (!extension) {\n      return null;\n    }\n\n    const specVersion = extension.specVersion;\n    if (specVersion !== '1.0-beta') {\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      let prevJoint: V1SpringBoneSchema.SpringBoneJoint | undefined;\n      schemaJoints.forEach((joint) => {\n        if (prevJoint) {\n          // prepare node\n          const nodeIndex = prevJoint.node;\n          const node = threeNodes[nodeIndex];\n          const childIndex = joint.node;\n          const child = threeNodes[childIndex];\n\n          // prepare setting\n          const setting: Partial<VRMSpringBoneJointSettings> = {\n            hitRadius: prevJoint.hitRadius,\n            dragForce: prevJoint.dragForce,\n            gravityPower: prevJoint.gravityPower,\n            stiffness: prevJoint.stiffness,\n            gravityDir: new THREE.Vector3().fromArray(prevJoint.gravityDir ?? [0.0, 1.0, 0.0]),\n          };\n\n          // create spring bones\n          const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          manager.addSpringBone(spring);\n        }\n\n        prevJoint = joint;\n      });\n    });\n\n    // init spring bones\n    gltf.scene.updateMatrixWorld();\n    manager.setInitState();\n\n    return manager;\n  }\n\n  private async _v0Import(gltf: GLTF): Promise<VRMSpringBoneManager | null> {\n    // early abort if it doesn't use vrm\n    const isVRMUsed = gltf.parser.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: V0VRM.VRM | undefined = gltf.parser.json.extensions?.['VRM'];\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        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          const spring = this._importJoint(node, child, setting, colliderGroupsForSpring);\n          manager.addSpringBone(spring);\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"],"names":["_v3A","THREE","_v3B","_matA"],"mappings":"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"}