@esotericsoftware/spine-webgl 4.2.45 → 4.2.47
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.
- package/dist/SkeletonRenderer.js +2 -2
- package/dist/iife/spine-webgl.js +190 -193
- package/dist/iife/spine-webgl.js.map +2 -2
- package/dist/iife/spine-webgl.min.js +26 -26
- package/package.json +2 -2
package/dist/SkeletonRenderer.js
CHANGED
|
@@ -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,
|
|
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,
|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SkeletonRenderer.js","sourceRoot":"","sources":["../src/SkeletonRenderer.ts"],"names":[],"mappings":"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"}
|
package/dist/iife/spine-webgl.js
CHANGED
|
@@ -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,
|
|
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,
|
|
10354
|
+
clipTriangles(vertices, triangles, trianglesLength, uvs, light, dark, twoColor) {
|
|
10350
10355
|
if (uvs && light && dark && typeof twoColor === "boolean")
|
|
10351
|
-
this.clipTrianglesRender(vertices,
|
|
10356
|
+
this.clipTrianglesRender(vertices, triangles, trianglesLength, uvs, light, dark, twoColor);
|
|
10352
10357
|
else
|
|
10353
|
-
this.clipTrianglesNoRender(vertices,
|
|
10358
|
+
this.clipTrianglesNoRender(vertices, triangles, trianglesLength);
|
|
10354
10359
|
}
|
|
10355
|
-
clipTrianglesNoRender(vertices,
|
|
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
|
-
|
|
10365
|
-
|
|
10366
|
-
|
|
10367
|
-
|
|
10368
|
-
|
|
10369
|
-
|
|
10370
|
-
|
|
10371
|
-
|
|
10372
|
-
|
|
10373
|
-
|
|
10374
|
-
|
|
10375
|
-
|
|
10376
|
-
|
|
10377
|
-
|
|
10378
|
-
|
|
10379
|
-
|
|
10380
|
-
|
|
10381
|
-
|
|
10382
|
-
|
|
10383
|
-
|
|
10384
|
-
|
|
10385
|
-
|
|
10386
|
-
|
|
10387
|
-
|
|
10388
|
-
|
|
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 +
|
|
10409
|
-
clippedTrianglesItems[s + 2] = index +
|
|
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,
|
|
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
|
-
|
|
10426
|
-
|
|
10427
|
-
|
|
10428
|
-
|
|
10429
|
-
|
|
10430
|
-
|
|
10431
|
-
|
|
10432
|
-
|
|
10433
|
-
|
|
10434
|
-
|
|
10435
|
-
|
|
10436
|
-
|
|
10437
|
-
|
|
10438
|
-
|
|
10439
|
-
|
|
10440
|
-
|
|
10441
|
-
|
|
10442
|
-
|
|
10443
|
-
|
|
10444
|
-
|
|
10445
|
-
|
|
10446
|
-
|
|
10447
|
-
|
|
10448
|
-
|
|
10449
|
-
|
|
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
|
-
|
|
10488
|
-
|
|
10489
|
-
|
|
10490
|
-
|
|
10491
|
-
|
|
10492
|
-
|
|
10493
|
-
|
|
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
|
-
|
|
10539
|
-
|
|
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 +
|
|
10542
|
-
clippedTrianglesItems[s + 2] = index +
|
|
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
|
|
10575
|
-
let
|
|
10572
|
+
let ex = edgeX - clippingVertices[i + 2], ey = edgeY - clippingVertices[i + 3];
|
|
10573
|
+
let outputStart = output.length;
|
|
10576
10574
|
let inputVertices = input;
|
|
10577
|
-
let
|
|
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
|
-
|
|
10581
|
-
let
|
|
10582
|
-
|
|
10583
|
-
|
|
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
|
|
10589
|
-
|
|
10590
|
-
|
|
10591
|
-
|
|
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(
|
|
10596
|
-
output.push(
|
|
10592
|
+
output.push(inputX2);
|
|
10593
|
+
output.push(inputY2);
|
|
10594
|
+
continue;
|
|
10597
10595
|
}
|
|
10598
|
-
} else if (
|
|
10599
|
-
let
|
|
10600
|
-
|
|
10601
|
-
|
|
10602
|
-
|
|
10603
|
-
output.push(
|
|
10604
|
-
output.push(
|
|
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(
|
|
10607
|
-
output.push(
|
|
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,
|
|
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)
|