@esotericsoftware/spine-webgl 4.2.45 → 4.2.46

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.
@@ -158,7 +158,7 @@ export class SkeletonRenderer {
158
158
  batcher.setBlendMode(blendMode, premultipliedAlpha);
159
159
  }
160
160
  if (clipper.isClipping()) {
161
- clipper.clipTriangles(renderable.vertices, renderable.numFloats, triangles, triangles.length, uvs, finalColor, darkColor, twoColorTint);
161
+ clipper.clipTriangles(renderable.vertices, triangles, triangles.length, uvs, finalColor, darkColor, twoColorTint);
162
162
  let clippedVertices = new Float32Array(clipper.clippedVertices);
163
163
  let clippedTriangles = clipper.clippedTriangles;
164
164
  if (transformer)
@@ -206,4 +206,4 @@ export class SkeletonRenderer {
206
206
  return this.clipper;
207
207
  }
208
208
  }
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SkeletonRenderer.js","sourceRoot":"","sources":["../src/SkeletonRenderer.ts"],"names":[],"mappings":"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"}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SkeletonRenderer.js","sourceRoot":"","sources":["../src/SkeletonRenderer.ts"],"names":[],"mappings":"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"}
@@ -4505,6 +4505,11 @@ var spine = (() => {
4505
4505
  wasApplied() {
4506
4506
  return this.nextTrackLast != -1;
4507
4507
  }
4508
+ /** Returns true if there is a {@link #getNext()} track entry and it will become the current track entry during the next
4509
+ * {@link AnimationState#update(float)}. */
4510
+ isNextReady() {
4511
+ return this.next != null && this.nextTrackLast - this.next.delay >= 0;
4512
+ }
4508
4513
  };
4509
4514
  var EventQueue = class {
4510
4515
  objects = [];
@@ -8141,7 +8146,7 @@ var spine = (() => {
8141
8146
  }
8142
8147
  if (vertices && triangles) {
8143
8148
  if (clipper != null && clipper.isClipping()) {
8144
- clipper.clipTriangles(vertices, verticesLength, triangles, triangles.length);
8149
+ clipper.clipTriangles(vertices, triangles, triangles.length);
8145
8150
  vertices = clipper.clippedVertices;
8146
8151
  verticesLength = clipper.clippedVertices.length;
8147
8152
  }
@@ -10346,74 +10351,70 @@ var spine = (() => {
10346
10351
  isClipping() {
10347
10352
  return this.clipAttachment != null;
10348
10353
  }
10349
- clipTriangles(vertices, verticesLength, triangles, trianglesLength, uvs, light, dark, twoColor) {
10354
+ clipTriangles(vertices, triangles, trianglesLength, uvs, light, dark, twoColor) {
10350
10355
  if (uvs && light && dark && typeof twoColor === "boolean")
10351
- this.clipTrianglesRender(vertices, verticesLength, triangles, trianglesLength, uvs, light, dark, twoColor);
10356
+ this.clipTrianglesRender(vertices, triangles, trianglesLength, uvs, light, dark, twoColor);
10352
10357
  else
10353
- this.clipTrianglesNoRender(vertices, verticesLength, triangles, trianglesLength);
10358
+ this.clipTrianglesNoRender(vertices, triangles, trianglesLength);
10354
10359
  }
10355
- clipTrianglesNoRender(vertices, verticesLength, triangles, trianglesLength) {
10360
+ clipTrianglesNoRender(vertices, triangles, trianglesLength) {
10356
10361
  let clipOutput = this.clipOutput, clippedVertices = this.clippedVertices;
10357
10362
  let clippedTriangles = this.clippedTriangles;
10358
10363
  let polygons = this.clippingPolygons;
10359
10364
  let polygonsCount = polygons.length;
10360
- let vertexSize = 2;
10361
10365
  let index = 0;
10362
10366
  clippedVertices.length = 0;
10363
10367
  clippedTriangles.length = 0;
10364
- outer:
10365
- for (let i = 0; i < trianglesLength; i += 3) {
10366
- let vertexOffset = triangles[i] << 1;
10367
- let x1 = vertices[vertexOffset], y1 = vertices[vertexOffset + 1];
10368
- vertexOffset = triangles[i + 1] << 1;
10369
- let x2 = vertices[vertexOffset], y2 = vertices[vertexOffset + 1];
10370
- vertexOffset = triangles[i + 2] << 1;
10371
- let x3 = vertices[vertexOffset], y3 = vertices[vertexOffset + 1];
10372
- for (let p = 0; p < polygonsCount; p++) {
10373
- let s = clippedVertices.length;
10374
- if (this.clip(x1, y1, x2, y2, x3, y3, polygons[p], clipOutput)) {
10375
- let clipOutputLength = clipOutput.length;
10376
- if (clipOutputLength == 0)
10377
- continue;
10378
- let clipOutputCount = clipOutputLength >> 1;
10379
- let clipOutputItems = this.clipOutput;
10380
- let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + clipOutputCount * vertexSize);
10381
- for (let ii = 0; ii < clipOutputLength; ii += 2) {
10382
- let x = clipOutputItems[ii], y = clipOutputItems[ii + 1];
10383
- clippedVerticesItems[s] = x;
10384
- clippedVerticesItems[s + 1] = y;
10385
- s += 2;
10386
- }
10387
- s = clippedTriangles.length;
10388
- let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3 * (clipOutputCount - 2));
10389
- clipOutputCount--;
10390
- for (let ii = 1; ii < clipOutputCount; ii++) {
10391
- clippedTrianglesItems[s] = index;
10392
- clippedTrianglesItems[s + 1] = index + ii;
10393
- clippedTrianglesItems[s + 2] = index + ii + 1;
10394
- s += 3;
10395
- }
10396
- index += clipOutputCount + 1;
10397
- } else {
10398
- let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + 3 * vertexSize);
10399
- clippedVerticesItems[s] = x1;
10400
- clippedVerticesItems[s + 1] = y1;
10401
- clippedVerticesItems[s + 2] = x2;
10402
- clippedVerticesItems[s + 3] = y2;
10403
- clippedVerticesItems[s + 4] = x3;
10404
- clippedVerticesItems[s + 5] = y3;
10405
- s = clippedTriangles.length;
10406
- let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3);
10368
+ for (let i = 0; i < trianglesLength; i += 3) {
10369
+ let vertexOffset = triangles[i] << 1;
10370
+ let x1 = vertices[vertexOffset], y1 = vertices[vertexOffset + 1];
10371
+ vertexOffset = triangles[i + 1] << 1;
10372
+ let x2 = vertices[vertexOffset], y2 = vertices[vertexOffset + 1];
10373
+ vertexOffset = triangles[i + 2] << 1;
10374
+ let x3 = vertices[vertexOffset], y3 = vertices[vertexOffset + 1];
10375
+ for (let p = 0; p < polygonsCount; p++) {
10376
+ let s = clippedVertices.length;
10377
+ if (this.clip(x1, y1, x2, y2, x3, y3, polygons[p], clipOutput)) {
10378
+ let clipOutputLength = clipOutput.length;
10379
+ if (clipOutputLength == 0)
10380
+ continue;
10381
+ let clipOutputCount = clipOutputLength >> 1;
10382
+ let clipOutputItems = this.clipOutput;
10383
+ let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + clipOutputCount * 2);
10384
+ for (let ii = 0; ii < clipOutputLength; ii += 2, s += 2) {
10385
+ let x = clipOutputItems[ii], y = clipOutputItems[ii + 1];
10386
+ clippedVerticesItems[s] = x;
10387
+ clippedVerticesItems[s + 1] = y;
10388
+ }
10389
+ s = clippedTriangles.length;
10390
+ let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3 * (clipOutputCount - 2));
10391
+ clipOutputCount--;
10392
+ for (let ii = 1; ii < clipOutputCount; ii++, s += 3) {
10407
10393
  clippedTrianglesItems[s] = index;
10408
- clippedTrianglesItems[s + 1] = index + 1;
10409
- clippedTrianglesItems[s + 2] = index + 2;
10410
- index += 3;
10411
- continue outer;
10394
+ clippedTrianglesItems[s + 1] = index + ii;
10395
+ clippedTrianglesItems[s + 2] = index + ii + 1;
10412
10396
  }
10397
+ index += clipOutputCount + 1;
10398
+ } else {
10399
+ let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + 3 * 2);
10400
+ clippedVerticesItems[s] = x1;
10401
+ clippedVerticesItems[s + 1] = y1;
10402
+ clippedVerticesItems[s + 2] = x2;
10403
+ clippedVerticesItems[s + 3] = y2;
10404
+ clippedVerticesItems[s + 4] = x3;
10405
+ clippedVerticesItems[s + 5] = y3;
10406
+ s = clippedTriangles.length;
10407
+ let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3);
10408
+ clippedTrianglesItems[s] = index;
10409
+ clippedTrianglesItems[s + 1] = index + 1;
10410
+ clippedTrianglesItems[s + 2] = index + 2;
10411
+ index += 3;
10412
+ break;
10413
10413
  }
10414
10414
  }
10415
+ }
10415
10416
  }
10416
- clipTrianglesRender(vertices, verticesLength, triangles, trianglesLength, uvs, light, dark, twoColor) {
10417
+ clipTrianglesRender(vertices, triangles, trianglesLength, uvs, light, dark, twoColor) {
10417
10418
  let clipOutput = this.clipOutput, clippedVertices = this.clippedVertices;
10418
10419
  let clippedTriangles = this.clippedTriangles;
10419
10420
  let polygons = this.clippingPolygons;
@@ -10422,129 +10423,126 @@ var spine = (() => {
10422
10423
  let index = 0;
10423
10424
  clippedVertices.length = 0;
10424
10425
  clippedTriangles.length = 0;
10425
- outer:
10426
- for (let i = 0; i < trianglesLength; i += 3) {
10427
- let vertexOffset = triangles[i] << 1;
10428
- let x1 = vertices[vertexOffset], y1 = vertices[vertexOffset + 1];
10429
- let u1 = uvs[vertexOffset], v1 = uvs[vertexOffset + 1];
10430
- vertexOffset = triangles[i + 1] << 1;
10431
- let x2 = vertices[vertexOffset], y2 = vertices[vertexOffset + 1];
10432
- let u2 = uvs[vertexOffset], v2 = uvs[vertexOffset + 1];
10433
- vertexOffset = triangles[i + 2] << 1;
10434
- let x3 = vertices[vertexOffset], y3 = vertices[vertexOffset + 1];
10435
- let u3 = uvs[vertexOffset], v3 = uvs[vertexOffset + 1];
10436
- for (let p = 0; p < polygonsCount; p++) {
10437
- let s = clippedVertices.length;
10438
- if (this.clip(x1, y1, x2, y2, x3, y3, polygons[p], clipOutput)) {
10439
- let clipOutputLength = clipOutput.length;
10440
- if (clipOutputLength == 0)
10441
- continue;
10442
- let d0 = y2 - y3, d1 = x3 - x2, d2 = x1 - x3, d4 = y3 - y1;
10443
- let d = 1 / (d0 * d2 + d1 * (y1 - y3));
10444
- let clipOutputCount = clipOutputLength >> 1;
10445
- let clipOutputItems = this.clipOutput;
10446
- let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + clipOutputCount * vertexSize);
10447
- for (let ii = 0; ii < clipOutputLength; ii += 2) {
10448
- let x = clipOutputItems[ii], y = clipOutputItems[ii + 1];
10449
- clippedVerticesItems[s] = x;
10450
- clippedVerticesItems[s + 1] = y;
10451
- clippedVerticesItems[s + 2] = light.r;
10452
- clippedVerticesItems[s + 3] = light.g;
10453
- clippedVerticesItems[s + 4] = light.b;
10454
- clippedVerticesItems[s + 5] = light.a;
10455
- let c0 = x - x3, c1 = y - y3;
10456
- let a = (d0 * c0 + d1 * c1) * d;
10457
- let b = (d4 * c0 + d2 * c1) * d;
10458
- let c = 1 - a - b;
10459
- clippedVerticesItems[s + 6] = u1 * a + u2 * b + u3 * c;
10460
- clippedVerticesItems[s + 7] = v1 * a + v2 * b + v3 * c;
10461
- if (twoColor) {
10462
- clippedVerticesItems[s + 8] = dark.r;
10463
- clippedVerticesItems[s + 9] = dark.g;
10464
- clippedVerticesItems[s + 10] = dark.b;
10465
- clippedVerticesItems[s + 11] = dark.a;
10466
- }
10467
- s += vertexSize;
10468
- }
10469
- s = clippedTriangles.length;
10470
- let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3 * (clipOutputCount - 2));
10471
- clipOutputCount--;
10472
- for (let ii = 1; ii < clipOutputCount; ii++) {
10473
- clippedTrianglesItems[s] = index;
10474
- clippedTrianglesItems[s + 1] = index + ii;
10475
- clippedTrianglesItems[s + 2] = index + ii + 1;
10476
- s += 3;
10477
- }
10478
- index += clipOutputCount + 1;
10479
- } else {
10480
- let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + 3 * vertexSize);
10481
- clippedVerticesItems[s] = x1;
10482
- clippedVerticesItems[s + 1] = y1;
10426
+ for (let i = 0; i < trianglesLength; i += 3) {
10427
+ let vertexOffset = triangles[i] << 1;
10428
+ let x1 = vertices[vertexOffset], y1 = vertices[vertexOffset + 1];
10429
+ let u1 = uvs[vertexOffset], v1 = uvs[vertexOffset + 1];
10430
+ vertexOffset = triangles[i + 1] << 1;
10431
+ let x2 = vertices[vertexOffset], y2 = vertices[vertexOffset + 1];
10432
+ let u2 = uvs[vertexOffset], v2 = uvs[vertexOffset + 1];
10433
+ vertexOffset = triangles[i + 2] << 1;
10434
+ let x3 = vertices[vertexOffset], y3 = vertices[vertexOffset + 1];
10435
+ let u3 = uvs[vertexOffset], v3 = uvs[vertexOffset + 1];
10436
+ for (let p = 0; p < polygonsCount; p++) {
10437
+ let s = clippedVertices.length;
10438
+ if (this.clip(x1, y1, x2, y2, x3, y3, polygons[p], clipOutput)) {
10439
+ let clipOutputLength = clipOutput.length;
10440
+ if (clipOutputLength == 0)
10441
+ continue;
10442
+ let d0 = y2 - y3, d1 = x3 - x2, d2 = x1 - x3, d4 = y3 - y1;
10443
+ let d = 1 / (d0 * d2 + d1 * (y1 - y3));
10444
+ let clipOutputCount = clipOutputLength >> 1;
10445
+ let clipOutputItems = this.clipOutput;
10446
+ let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + clipOutputCount * vertexSize);
10447
+ for (let ii = 0; ii < clipOutputLength; ii += 2, s += vertexSize) {
10448
+ let x = clipOutputItems[ii], y = clipOutputItems[ii + 1];
10449
+ clippedVerticesItems[s] = x;
10450
+ clippedVerticesItems[s + 1] = y;
10483
10451
  clippedVerticesItems[s + 2] = light.r;
10484
10452
  clippedVerticesItems[s + 3] = light.g;
10485
10453
  clippedVerticesItems[s + 4] = light.b;
10486
10454
  clippedVerticesItems[s + 5] = light.a;
10487
- if (!twoColor) {
10488
- clippedVerticesItems[s + 6] = u1;
10489
- clippedVerticesItems[s + 7] = v1;
10490
- clippedVerticesItems[s + 8] = x2;
10491
- clippedVerticesItems[s + 9] = y2;
10492
- clippedVerticesItems[s + 10] = light.r;
10493
- clippedVerticesItems[s + 11] = light.g;
10494
- clippedVerticesItems[s + 12] = light.b;
10495
- clippedVerticesItems[s + 13] = light.a;
10496
- clippedVerticesItems[s + 14] = u2;
10497
- clippedVerticesItems[s + 15] = v2;
10498
- clippedVerticesItems[s + 16] = x3;
10499
- clippedVerticesItems[s + 17] = y3;
10500
- clippedVerticesItems[s + 18] = light.r;
10501
- clippedVerticesItems[s + 19] = light.g;
10502
- clippedVerticesItems[s + 20] = light.b;
10503
- clippedVerticesItems[s + 21] = light.a;
10504
- clippedVerticesItems[s + 22] = u3;
10505
- clippedVerticesItems[s + 23] = v3;
10506
- } else {
10507
- clippedVerticesItems[s + 6] = u1;
10508
- clippedVerticesItems[s + 7] = v1;
10455
+ let c0 = x - x3, c1 = y - y3;
10456
+ let a = (d0 * c0 + d1 * c1) * d;
10457
+ let b = (d4 * c0 + d2 * c1) * d;
10458
+ let c = 1 - a - b;
10459
+ clippedVerticesItems[s + 6] = u1 * a + u2 * b + u3 * c;
10460
+ clippedVerticesItems[s + 7] = v1 * a + v2 * b + v3 * c;
10461
+ if (twoColor) {
10509
10462
  clippedVerticesItems[s + 8] = dark.r;
10510
10463
  clippedVerticesItems[s + 9] = dark.g;
10511
10464
  clippedVerticesItems[s + 10] = dark.b;
10512
10465
  clippedVerticesItems[s + 11] = dark.a;
10513
- clippedVerticesItems[s + 12] = x2;
10514
- clippedVerticesItems[s + 13] = y2;
10515
- clippedVerticesItems[s + 14] = light.r;
10516
- clippedVerticesItems[s + 15] = light.g;
10517
- clippedVerticesItems[s + 16] = light.b;
10518
- clippedVerticesItems[s + 17] = light.a;
10519
- clippedVerticesItems[s + 18] = u2;
10520
- clippedVerticesItems[s + 19] = v2;
10521
- clippedVerticesItems[s + 20] = dark.r;
10522
- clippedVerticesItems[s + 21] = dark.g;
10523
- clippedVerticesItems[s + 22] = dark.b;
10524
- clippedVerticesItems[s + 23] = dark.a;
10525
- clippedVerticesItems[s + 24] = x3;
10526
- clippedVerticesItems[s + 25] = y3;
10527
- clippedVerticesItems[s + 26] = light.r;
10528
- clippedVerticesItems[s + 27] = light.g;
10529
- clippedVerticesItems[s + 28] = light.b;
10530
- clippedVerticesItems[s + 29] = light.a;
10531
- clippedVerticesItems[s + 30] = u3;
10532
- clippedVerticesItems[s + 31] = v3;
10533
- clippedVerticesItems[s + 32] = dark.r;
10534
- clippedVerticesItems[s + 33] = dark.g;
10535
- clippedVerticesItems[s + 34] = dark.b;
10536
- clippedVerticesItems[s + 35] = dark.a;
10537
10466
  }
10538
- s = clippedTriangles.length;
10539
- let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3);
10467
+ }
10468
+ s = clippedTriangles.length;
10469
+ let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3 * (clipOutputCount - 2));
10470
+ clipOutputCount--;
10471
+ for (let ii = 1; ii < clipOutputCount; ii++, s += 3) {
10540
10472
  clippedTrianglesItems[s] = index;
10541
- clippedTrianglesItems[s + 1] = index + 1;
10542
- clippedTrianglesItems[s + 2] = index + 2;
10543
- index += 3;
10544
- continue outer;
10473
+ clippedTrianglesItems[s + 1] = index + ii;
10474
+ clippedTrianglesItems[s + 2] = index + ii + 1;
10545
10475
  }
10476
+ index += clipOutputCount + 1;
10477
+ } else {
10478
+ let clippedVerticesItems = Utils.setArraySize(clippedVertices, s + 3 * vertexSize);
10479
+ clippedVerticesItems[s] = x1;
10480
+ clippedVerticesItems[s + 1] = y1;
10481
+ clippedVerticesItems[s + 2] = light.r;
10482
+ clippedVerticesItems[s + 3] = light.g;
10483
+ clippedVerticesItems[s + 4] = light.b;
10484
+ clippedVerticesItems[s + 5] = light.a;
10485
+ if (!twoColor) {
10486
+ clippedVerticesItems[s + 6] = u1;
10487
+ clippedVerticesItems[s + 7] = v1;
10488
+ clippedVerticesItems[s + 8] = x2;
10489
+ clippedVerticesItems[s + 9] = y2;
10490
+ clippedVerticesItems[s + 10] = light.r;
10491
+ clippedVerticesItems[s + 11] = light.g;
10492
+ clippedVerticesItems[s + 12] = light.b;
10493
+ clippedVerticesItems[s + 13] = light.a;
10494
+ clippedVerticesItems[s + 14] = u2;
10495
+ clippedVerticesItems[s + 15] = v2;
10496
+ clippedVerticesItems[s + 16] = x3;
10497
+ clippedVerticesItems[s + 17] = y3;
10498
+ clippedVerticesItems[s + 18] = light.r;
10499
+ clippedVerticesItems[s + 19] = light.g;
10500
+ clippedVerticesItems[s + 20] = light.b;
10501
+ clippedVerticesItems[s + 21] = light.a;
10502
+ clippedVerticesItems[s + 22] = u3;
10503
+ clippedVerticesItems[s + 23] = v3;
10504
+ } else {
10505
+ clippedVerticesItems[s + 6] = u1;
10506
+ clippedVerticesItems[s + 7] = v1;
10507
+ clippedVerticesItems[s + 8] = dark.r;
10508
+ clippedVerticesItems[s + 9] = dark.g;
10509
+ clippedVerticesItems[s + 10] = dark.b;
10510
+ clippedVerticesItems[s + 11] = dark.a;
10511
+ clippedVerticesItems[s + 12] = x2;
10512
+ clippedVerticesItems[s + 13] = y2;
10513
+ clippedVerticesItems[s + 14] = light.r;
10514
+ clippedVerticesItems[s + 15] = light.g;
10515
+ clippedVerticesItems[s + 16] = light.b;
10516
+ clippedVerticesItems[s + 17] = light.a;
10517
+ clippedVerticesItems[s + 18] = u2;
10518
+ clippedVerticesItems[s + 19] = v2;
10519
+ clippedVerticesItems[s + 20] = dark.r;
10520
+ clippedVerticesItems[s + 21] = dark.g;
10521
+ clippedVerticesItems[s + 22] = dark.b;
10522
+ clippedVerticesItems[s + 23] = dark.a;
10523
+ clippedVerticesItems[s + 24] = x3;
10524
+ clippedVerticesItems[s + 25] = y3;
10525
+ clippedVerticesItems[s + 26] = light.r;
10526
+ clippedVerticesItems[s + 27] = light.g;
10527
+ clippedVerticesItems[s + 28] = light.b;
10528
+ clippedVerticesItems[s + 29] = light.a;
10529
+ clippedVerticesItems[s + 30] = u3;
10530
+ clippedVerticesItems[s + 31] = v3;
10531
+ clippedVerticesItems[s + 32] = dark.r;
10532
+ clippedVerticesItems[s + 33] = dark.g;
10533
+ clippedVerticesItems[s + 34] = dark.b;
10534
+ clippedVerticesItems[s + 35] = dark.a;
10535
+ }
10536
+ s = clippedTriangles.length;
10537
+ let clippedTrianglesItems = Utils.setArraySize(clippedTriangles, s + 3);
10538
+ clippedTrianglesItems[s] = index;
10539
+ clippedTrianglesItems[s + 1] = index + 1;
10540
+ clippedTrianglesItems[s + 2] = index + 2;
10541
+ index += 3;
10542
+ break;
10546
10543
  }
10547
10544
  }
10545
+ }
10548
10546
  }
10549
10547
  /** Clips the input triangle against the convex, clockwise clipping area. If the triangle lies entirely within the clipping
10550
10548
  * area, false is returned. The clipping area must duplicate the first vertex at the end of the vertices list. */
@@ -10567,47 +10565,46 @@ var spine = (() => {
10567
10565
  input.push(x1);
10568
10566
  input.push(y1);
10569
10567
  output.length = 0;
10570
- let clippingVertices = clippingArea;
10571
10568
  let clippingVerticesLast = clippingArea.length - 4;
10569
+ let clippingVertices = clippingArea;
10572
10570
  for (let i = 0; ; i += 2) {
10573
10571
  let edgeX = clippingVertices[i], edgeY = clippingVertices[i + 1];
10574
- let edgeX2 = clippingVertices[i + 2], edgeY2 = clippingVertices[i + 3];
10575
- let deltaX = edgeX - edgeX2, deltaY = edgeY - edgeY2;
10572
+ let ex = edgeX - clippingVertices[i + 2], ey = edgeY - clippingVertices[i + 3];
10573
+ let outputStart = output.length;
10576
10574
  let inputVertices = input;
10577
- let inputVerticesLength = input.length - 2, outputStart = output.length;
10578
- for (let ii = 0; ii < inputVerticesLength; ii += 2) {
10575
+ for (let ii = 0, nn = input.length - 2; ii < nn; ) {
10579
10576
  let inputX = inputVertices[ii], inputY = inputVertices[ii + 1];
10580
- let inputX2 = inputVertices[ii + 2], inputY2 = inputVertices[ii + 3];
10581
- let side2 = deltaX * (inputY2 - edgeY2) - deltaY * (inputX2 - edgeX2) > 0;
10582
- if (deltaX * (inputY - edgeY2) - deltaY * (inputX - edgeX2) > 0) {
10583
- if (side2) {
10577
+ ii += 2;
10578
+ let inputX2 = inputVertices[ii], inputY2 = inputVertices[ii + 1];
10579
+ let s2 = ey * (edgeX - inputX2) > ex * (edgeY - inputY2);
10580
+ let s1 = ey * (edgeX - inputX) - ex * (edgeY - inputY);
10581
+ if (s1 > 0) {
10582
+ if (s2) {
10584
10583
  output.push(inputX2);
10585
10584
  output.push(inputY2);
10586
10585
  continue;
10587
10586
  }
10588
- let c0 = inputY2 - inputY, c2 = inputX2 - inputX;
10589
- let s = c0 * (edgeX2 - edgeX) - c2 * (edgeY2 - edgeY);
10590
- if (Math.abs(s) > 1e-6) {
10591
- let ua = (c2 * (edgeY - inputY) - c0 * (edgeX - inputX)) / s;
10592
- output.push(edgeX + (edgeX2 - edgeX) * ua);
10593
- output.push(edgeY + (edgeY2 - edgeY) * ua);
10587
+ let ix = inputX2 - inputX, iy = inputY2 - inputY, t = s1 / (ix * ey - iy * ex);
10588
+ if (t >= 0 && t <= 1) {
10589
+ output.push(inputX + ix * t);
10590
+ output.push(inputY + iy * t);
10594
10591
  } else {
10595
- output.push(edgeX);
10596
- output.push(edgeY);
10592
+ output.push(inputX2);
10593
+ output.push(inputY2);
10594
+ continue;
10597
10595
  }
10598
- } else if (side2) {
10599
- let c0 = inputY2 - inputY, c2 = inputX2 - inputX;
10600
- let s = c0 * (edgeX2 - edgeX) - c2 * (edgeY2 - edgeY);
10601
- if (Math.abs(s) > 1e-6) {
10602
- let ua = (c2 * (edgeY - inputY) - c0 * (edgeX - inputX)) / s;
10603
- output.push(edgeX + (edgeX2 - edgeX) * ua);
10604
- output.push(edgeY + (edgeY2 - edgeY) * ua);
10596
+ } else if (s2) {
10597
+ let ix = inputX2 - inputX, iy = inputY2 - inputY, t = s1 / (ix * ey - iy * ex);
10598
+ if (t >= 0 && t <= 1) {
10599
+ output.push(inputX + ix * t);
10600
+ output.push(inputY + iy * t);
10601
+ output.push(inputX2);
10602
+ output.push(inputY2);
10605
10603
  } else {
10606
- output.push(edgeX);
10607
- output.push(edgeY);
10604
+ output.push(inputX2);
10605
+ output.push(inputY2);
10606
+ continue;
10608
10607
  }
10609
- output.push(inputX2);
10610
- output.push(inputY2);
10611
10608
  }
10612
10609
  clipped = true;
10613
10610
  }
@@ -13724,7 +13721,7 @@ void main () {
13724
13721
  batcher.setBlendMode(blendMode, premultipliedAlpha);
13725
13722
  }
13726
13723
  if (clipper.isClipping()) {
13727
- clipper.clipTriangles(renderable.vertices, renderable.numFloats, triangles, triangles.length, uvs, finalColor, darkColor, twoColorTint);
13724
+ clipper.clipTriangles(renderable.vertices, triangles, triangles.length, uvs, finalColor, darkColor, twoColorTint);
13728
13725
  let clippedVertices = new Float32Array(clipper.clippedVertices);
13729
13726
  let clippedTriangles = clipper.clippedTriangles;
13730
13727
  if (transformer)