mirror of
https://github.com/smallmain/cocos-enhance-kit.git
synced 2025-01-15 07:21:07 +00:00
384 lines
14 KiB
JavaScript
384 lines
14 KiB
JavaScript
|
/****************************************************************************
|
||
|
Copyright (c) 2016 Chukong Technologies Inc.
|
||
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
||
|
|
||
|
http://www.cocos2d-x.org
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||
|
of this software and associated documentation files (the "Software"), to deal
|
||
|
in the Software without restriction, including without limitation the rights
|
||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
|
copies of the Software, and to permit persons to whom the Software is
|
||
|
furnished to do so, subject to the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be included in
|
||
|
all copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||
|
THE SOFTWARE.
|
||
|
****************************************************************************/
|
||
|
|
||
|
import Mat4 from '../../cocos2d/core/value-types/mat4';
|
||
|
|
||
|
const BinaryOffset = dragonBones.BinaryOffset;
|
||
|
const BoneType = dragonBones.BoneType;
|
||
|
|
||
|
dragonBones.CCSlot = cc.Class({
|
||
|
name: 'dragonBones.CCSlot',
|
||
|
extends: dragonBones.Slot,
|
||
|
|
||
|
ctor () {
|
||
|
this._localVertices = [];
|
||
|
this._indices = [];
|
||
|
this._matrix = cc.mat4();
|
||
|
this._worldMatrix = cc.mat4();
|
||
|
this._worldMatrixDirty = true;
|
||
|
this._visible = false;
|
||
|
this._color = cc.color();
|
||
|
},
|
||
|
|
||
|
_onClear () {
|
||
|
this._super();
|
||
|
this._localVertices.length = 0;
|
||
|
this._indices.length = 0;
|
||
|
Mat4.identity(this._matrix);
|
||
|
Mat4.identity(this._worldMatrix);
|
||
|
this._worldMatrixDirty = true;
|
||
|
this._color = cc.color();
|
||
|
this._visible = false;
|
||
|
},
|
||
|
|
||
|
statics : {
|
||
|
toString: function () {
|
||
|
return "[class dragonBones.CCSlot]";
|
||
|
}
|
||
|
},
|
||
|
|
||
|
// just for adapt to dragonbones api,no need to do any thing
|
||
|
_onUpdateDisplay () {
|
||
|
},
|
||
|
|
||
|
// just for adapt to dragonbones api,no need to do any thing
|
||
|
_initDisplay (value) {
|
||
|
},
|
||
|
|
||
|
_addDisplay () {
|
||
|
this._visible = true;
|
||
|
},
|
||
|
|
||
|
// just for adapt to dragonbones api,no need to do any thing
|
||
|
_replaceDisplay (value) {
|
||
|
},
|
||
|
|
||
|
_removeDisplay () {
|
||
|
this._visible = false;
|
||
|
},
|
||
|
|
||
|
// just for adapt to dragonbones api,no need to do any thing
|
||
|
_disposeDisplay (object) {
|
||
|
},
|
||
|
|
||
|
_updateVisible () {
|
||
|
this._visible = this.parent._visible;
|
||
|
},
|
||
|
|
||
|
// just for adapt to dragonbones api,no need to do any thing
|
||
|
_updateZOrder () {
|
||
|
},
|
||
|
|
||
|
_updateBlendMode () {
|
||
|
if (this._childArmature) {
|
||
|
let childSlots = this._childArmature.getSlots();
|
||
|
for (let i = 0, l = childSlots.length; i < l; i++) {
|
||
|
let slot = childSlots[i];
|
||
|
slot._blendMode = this._blendMode;
|
||
|
slot._updateBlendMode();
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
_updateColor () {
|
||
|
let c = this._color;
|
||
|
c.r = this._colorTransform.redMultiplier * 255;
|
||
|
c.g = this._colorTransform.greenMultiplier * 255;
|
||
|
c.b = this._colorTransform.blueMultiplier * 255;
|
||
|
c.a = this._colorTransform.alphaMultiplier * 255;
|
||
|
},
|
||
|
|
||
|
//return dragonBones.CCTexture2D
|
||
|
getTexture () {
|
||
|
return this._textureData && this._textureData.spriteFrame && this._textureData.spriteFrame.getTexture();
|
||
|
},
|
||
|
|
||
|
_updateFrame () {
|
||
|
this._indices.length = 0;
|
||
|
let indices = this._indices,
|
||
|
localVertices = this._localVertices;
|
||
|
let indexOffset = 0, vfOffset = 0;
|
||
|
|
||
|
let currentTextureData = this._textureData;
|
||
|
if (!this._display || this._displayIndex < 0 || !currentTextureData || !currentTextureData.spriteFrame) return;
|
||
|
|
||
|
let texture = currentTextureData.spriteFrame.getTexture();
|
||
|
let textureAtlasWidth = texture.width;
|
||
|
let textureAtlasHeight = texture.height;
|
||
|
let region = currentTextureData.region;
|
||
|
|
||
|
const currentVerticesData = (this._deformVertices !== null && this._display === this._meshDisplay) ? this._deformVertices.verticesData : null;
|
||
|
|
||
|
if (currentVerticesData) {
|
||
|
const data = currentVerticesData.data;
|
||
|
const intArray = data.intArray;
|
||
|
const floatArray = data.floatArray;
|
||
|
const vertexCount = intArray[currentVerticesData.offset + BinaryOffset.MeshVertexCount];
|
||
|
const triangleCount = intArray[currentVerticesData.offset + BinaryOffset.MeshTriangleCount];
|
||
|
let vertexOffset = intArray[currentVerticesData.offset + BinaryOffset.MeshFloatOffset];
|
||
|
|
||
|
if (vertexOffset < 0) {
|
||
|
vertexOffset += 65536; // Fixed out of bouds bug.
|
||
|
}
|
||
|
|
||
|
const uvOffset = vertexOffset + vertexCount * 2;
|
||
|
const scale = this._armature._armatureData.scale;
|
||
|
|
||
|
for (let i = 0, l = vertexCount * 2; i < l; i += 2) {
|
||
|
localVertices[vfOffset++] = floatArray[vertexOffset + i] * scale;
|
||
|
localVertices[vfOffset++] = -floatArray[vertexOffset + i + 1] * scale;
|
||
|
|
||
|
if (currentVerticesData.rotated) {
|
||
|
localVertices[vfOffset++] = (region.x + (1.0 - floatArray[uvOffset + i]) * region.width) / textureAtlasWidth;
|
||
|
localVertices[vfOffset++] = (region.y + floatArray[uvOffset + i + 1] * region.height) / textureAtlasHeight;
|
||
|
} else {
|
||
|
localVertices[vfOffset++] = (region.x + floatArray[uvOffset + i] * region.width) / textureAtlasWidth;
|
||
|
localVertices[vfOffset++] = (region.y + floatArray[uvOffset + i + 1] * region.height) / textureAtlasHeight;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for (let i = 0; i < triangleCount * 3; ++i) {
|
||
|
indices[indexOffset++] = intArray[currentVerticesData.offset + BinaryOffset.MeshVertexIndices + i];
|
||
|
}
|
||
|
|
||
|
localVertices.length = vfOffset;
|
||
|
indices.length = indexOffset;
|
||
|
|
||
|
let isSkinned = !!currentVerticesData.weight;
|
||
|
if (isSkinned) {
|
||
|
this._identityTransform();
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
let l = region.x / textureAtlasWidth;
|
||
|
let b = (region.y + region.height) / textureAtlasHeight;
|
||
|
let r = (region.x + region.width) / textureAtlasWidth;
|
||
|
let t = region.y / textureAtlasHeight;
|
||
|
|
||
|
localVertices[vfOffset++] = 0; // 0x
|
||
|
localVertices[vfOffset++] = 0; // 0y
|
||
|
localVertices[vfOffset++] = l; // 0u
|
||
|
localVertices[vfOffset++] = b; // 0v
|
||
|
|
||
|
localVertices[vfOffset++] = region.width; // 1x
|
||
|
localVertices[vfOffset++] = 0; // 1y
|
||
|
localVertices[vfOffset++] = r; // 1u
|
||
|
localVertices[vfOffset++] = b; // 1v
|
||
|
|
||
|
localVertices[vfOffset++] = 0; // 2x
|
||
|
localVertices[vfOffset++] = region.height;; // 2y
|
||
|
localVertices[vfOffset++] = l; // 2u
|
||
|
localVertices[vfOffset++] = t; // 2v
|
||
|
|
||
|
localVertices[vfOffset++] = region.width; // 3x
|
||
|
localVertices[vfOffset++] = region.height;; // 3y
|
||
|
localVertices[vfOffset++] = r; // 3u
|
||
|
localVertices[vfOffset++] = t; // 3v
|
||
|
|
||
|
indices[0] = 0;
|
||
|
indices[1] = 1;
|
||
|
indices[2] = 2;
|
||
|
indices[3] = 1;
|
||
|
indices[4] = 3;
|
||
|
indices[5] = 2;
|
||
|
|
||
|
localVertices.length = vfOffset;
|
||
|
indices.length = 6;
|
||
|
}
|
||
|
|
||
|
this._visibleDirty = true;
|
||
|
this._blendModeDirty = true;
|
||
|
this._colorDirty = true;
|
||
|
},
|
||
|
|
||
|
_updateMesh () {
|
||
|
const scale = this._armature._armatureData.scale;
|
||
|
const deformVertices = this._deformVertices.vertices;
|
||
|
const bones = this._deformVertices.bones;
|
||
|
const verticesData = this._deformVertices.verticesData;
|
||
|
const weightData = verticesData.weight;
|
||
|
const hasDeform = deformVertices.length > 0 && verticesData.inheritDeform;
|
||
|
|
||
|
let localVertices = this._localVertices;
|
||
|
if (weightData) {
|
||
|
const data = verticesData.data;
|
||
|
const intArray = data.intArray;
|
||
|
const floatArray = data.floatArray;
|
||
|
const vertexCount = intArray[verticesData.offset + BinaryOffset.MeshVertexCount];
|
||
|
let weightFloatOffset = intArray[weightData.offset + BinaryOffset.WeigthFloatOffset];
|
||
|
|
||
|
if (weightFloatOffset < 0) {
|
||
|
weightFloatOffset += 65536; // Fixed out of bouds bug.
|
||
|
}
|
||
|
|
||
|
for (
|
||
|
let i = 0, iB = weightData.offset + BinaryOffset.WeigthBoneIndices + bones.length, iV = weightFloatOffset, iF = 0, lvi = 0;
|
||
|
i < vertexCount;
|
||
|
i++, lvi+=4
|
||
|
) {
|
||
|
const boneCount = intArray[iB++];
|
||
|
let xG = 0.0, yG = 0.0;
|
||
|
|
||
|
for (let j = 0; j < boneCount; ++j) {
|
||
|
const boneIndex = intArray[iB++];
|
||
|
const bone = bones[boneIndex];
|
||
|
|
||
|
if (bone !== null) {
|
||
|
const matrix = bone.globalTransformMatrix;
|
||
|
const weight = floatArray[iV++];
|
||
|
let xL = floatArray[iV++] * scale;
|
||
|
let yL = floatArray[iV++] * scale;
|
||
|
|
||
|
if (hasDeform) {
|
||
|
xL += deformVertices[iF++];
|
||
|
yL += deformVertices[iF++];
|
||
|
}
|
||
|
|
||
|
xG += (matrix.a * xL + matrix.c * yL + matrix.tx) * weight;
|
||
|
yG += (matrix.b * xL + matrix.d * yL + matrix.ty) * weight;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
localVertices[lvi] = xG;
|
||
|
localVertices[lvi + 1] = -yG;
|
||
|
}
|
||
|
}
|
||
|
else if (hasDeform) {
|
||
|
const isSurface = this._parent._boneData.type !== BoneType.Bone;
|
||
|
const data = verticesData.data;
|
||
|
const intArray = data.intArray;
|
||
|
const floatArray = data.floatArray;
|
||
|
const vertexCount = intArray[verticesData.offset + BinaryOffset.MeshVertexCount];
|
||
|
let vertexOffset = intArray[verticesData.offset + BinaryOffset.MeshFloatOffset];
|
||
|
|
||
|
if (vertexOffset < 0) {
|
||
|
vertexOffset += 65536; // Fixed out of bouds bug.
|
||
|
}
|
||
|
|
||
|
for (let i = 0, l = vertexCount, lvi = 0; i < l; i ++, lvi += 4) {
|
||
|
const x = floatArray[vertexOffset + i*2] * scale + deformVertices[i*2];
|
||
|
const y = floatArray[vertexOffset + i*2 + 1] * scale + deformVertices[i*2 + 1];
|
||
|
|
||
|
if (isSurface) {
|
||
|
const matrix = this._parent._getGlobalTransformMatrix(x, y);
|
||
|
localVertices[lvi] = matrix.a * x + matrix.c * y + matrix.tx;
|
||
|
localVertices[lvi + 1] = -matrix.b * x + matrix.d * y + matrix.ty;
|
||
|
}
|
||
|
else {
|
||
|
localVertices[lvi] = x;
|
||
|
localVertices[lvi + 1] = -y;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (weightData) {
|
||
|
this._identityTransform();
|
||
|
}
|
||
|
},
|
||
|
|
||
|
_identityTransform() {
|
||
|
let m = this._matrix.m;
|
||
|
m[0] = 1.0;
|
||
|
m[1] = 0.0;
|
||
|
m[4] = -0.0;
|
||
|
m[5] = -1.0;
|
||
|
m[12] = 0.0;
|
||
|
m[13] = 0.0;
|
||
|
this._worldMatrixDirty = true;
|
||
|
},
|
||
|
|
||
|
_updateTransform () {
|
||
|
let t = this._matrix;
|
||
|
let tm = t.m;
|
||
|
tm[0] = this.globalTransformMatrix.a;
|
||
|
tm[1] = this.globalTransformMatrix.b;
|
||
|
tm[4] = -this.globalTransformMatrix.c;
|
||
|
tm[5] = -this.globalTransformMatrix.d;
|
||
|
|
||
|
if (this._childArmature) {
|
||
|
tm[12] = this.globalTransformMatrix.tx;
|
||
|
tm[13] = this.globalTransformMatrix.ty;
|
||
|
} else {
|
||
|
tm[12] = this.globalTransformMatrix.tx - (this.globalTransformMatrix.a * this._pivotX - this.globalTransformMatrix.c * this._pivotY);
|
||
|
tm[13] = this.globalTransformMatrix.ty - (this.globalTransformMatrix.b * this._pivotX - this.globalTransformMatrix.d * this._pivotY);
|
||
|
}
|
||
|
this._worldMatrixDirty = true;
|
||
|
},
|
||
|
|
||
|
updateWorldMatrix () {
|
||
|
if (!this._armature) return;
|
||
|
|
||
|
var parentSlot = this._armature._parent;
|
||
|
if (parentSlot) {
|
||
|
parentSlot.updateWorldMatrix();
|
||
|
}
|
||
|
|
||
|
if (this._worldMatrixDirty) {
|
||
|
this.calculWorldMatrix();
|
||
|
var childArmature = this.childArmature;
|
||
|
if (!childArmature) return;
|
||
|
var slots = childArmature.getSlots();
|
||
|
for (var i = 0,n = slots.length; i < n; i++) {
|
||
|
var slot = slots[i];
|
||
|
if (slot) {
|
||
|
slot._worldMatrixDirty = true;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
_mulMat (out, a, b) {
|
||
|
let am = a.m, bm = b.m, outm = out.m;
|
||
|
let aa=am[0], ab=am[1], ac=am[4], ad=am[5], atx=am[12], aty=am[13];
|
||
|
let ba=bm[0], bb=bm[1], bc=bm[4], bd=bm[5], btx=bm[12], bty=bm[13];
|
||
|
if (ab !== 0 || ac !== 0) {
|
||
|
outm[0] = ba * aa + bb * ac;
|
||
|
outm[1] = ba * ab + bb * ad;
|
||
|
outm[4] = bc * aa + bd * ac;
|
||
|
outm[5] = bc * ab + bd * ad;
|
||
|
outm[12] = aa * btx + ac * bty + atx;
|
||
|
outm[13] = ab * btx + ad * bty + aty;
|
||
|
}
|
||
|
else {
|
||
|
outm[0] = ba * aa;
|
||
|
outm[1] = bb * ad;
|
||
|
outm[4] = bc * aa;
|
||
|
outm[5] = bd * ad;
|
||
|
outm[12] = aa * btx + atx;
|
||
|
outm[13] = ad * bty + aty;
|
||
|
}
|
||
|
},
|
||
|
|
||
|
calculWorldMatrix () {
|
||
|
var parent = this._armature._parent;
|
||
|
if (parent) {
|
||
|
this._mulMat(this._worldMatrix ,parent._worldMatrix, this._matrix);
|
||
|
} else {
|
||
|
Mat4.copy(this._worldMatrix, this._matrix);
|
||
|
}
|
||
|
this._worldMatrixDirty = false;
|
||
|
}
|
||
|
});
|