2018-01-22 21:21:47 +00:00
|
|
|
var Class = require('../../../utils/Class');
|
|
|
|
var WebGLPipeline = require('../WebGLPipeline');
|
|
|
|
var Utils = require('../Utils');
|
2018-01-22 23:01:00 +00:00
|
|
|
var ShaderSourceVS = require('../shaders/TextureTint.vert');
|
2018-01-25 05:26:14 +00:00
|
|
|
var ShaderSourceFS = require('../shaders/TextureTint.frag');
|
|
|
|
var ModelViewProjection = require('./components/ModelViewProjection');
|
2018-01-22 21:21:47 +00:00
|
|
|
|
2018-01-22 22:51:15 +00:00
|
|
|
var TextureTintPipeline = new Class({
|
2018-01-22 21:21:47 +00:00
|
|
|
|
|
|
|
Extends: WebGLPipeline,
|
|
|
|
|
2018-01-25 05:26:14 +00:00
|
|
|
Mixins: [
|
|
|
|
ModelViewProjection
|
|
|
|
],
|
|
|
|
|
2018-01-22 21:21:47 +00:00
|
|
|
initialize:
|
|
|
|
|
2018-01-26 23:17:11 +00:00
|
|
|
function TextureTintPipeline(game, gl, renderer, overrideFragmentShader)
|
2018-01-22 21:21:47 +00:00
|
|
|
{
|
|
|
|
WebGLPipeline.call(this, {
|
2018-01-22 22:51:15 +00:00
|
|
|
name: 'TextureTintPipeline',
|
2018-01-22 21:21:47 +00:00
|
|
|
game: game,
|
|
|
|
gl: gl,
|
|
|
|
renderer: renderer,
|
|
|
|
topology: gl.TRIANGLES,
|
2018-01-22 23:01:00 +00:00
|
|
|
vertShader: ShaderSourceVS,
|
2018-01-26 23:17:11 +00:00
|
|
|
fragShader: (overrideFragmentShader ? overrideFragmentShader : ShaderSourceFS),
|
2018-01-26 00:34:35 +00:00
|
|
|
vertexCapacity: 6 * 2000,
|
2018-01-22 21:21:47 +00:00
|
|
|
|
|
|
|
vertexSize:
|
|
|
|
Float32Array.BYTES_PER_ELEMENT * 2 +
|
|
|
|
Float32Array.BYTES_PER_ELEMENT * 2 +
|
|
|
|
Uint8Array.BYTES_PER_ELEMENT * 4,
|
|
|
|
|
|
|
|
attributes: [
|
|
|
|
{
|
|
|
|
name: 'inPosition',
|
|
|
|
size: 2,
|
|
|
|
type: gl.FLOAT,
|
|
|
|
normalized: false,
|
|
|
|
offset: 0
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'inTexCoord',
|
|
|
|
size: 2,
|
|
|
|
type: gl.FLOAT,
|
|
|
|
normalized: false,
|
|
|
|
offset: Float32Array.BYTES_PER_ELEMENT * 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'inTint',
|
|
|
|
size: 4,
|
|
|
|
type: gl.UNSIGNED_BYTE,
|
|
|
|
normalized: true,
|
|
|
|
offset: Float32Array.BYTES_PER_ELEMENT * 4
|
|
|
|
}
|
|
|
|
]
|
|
|
|
});
|
|
|
|
|
|
|
|
this.vertexViewF32 = new Float32Array(this.vertexData);
|
|
|
|
this.vertexViewU32 = new Uint32Array(this.vertexData);
|
2018-01-26 00:34:35 +00:00
|
|
|
this.maxQuads = 2000;
|
2018-01-25 05:26:14 +00:00
|
|
|
this.mvpInit();
|
|
|
|
},
|
|
|
|
|
|
|
|
onBind: function ()
|
|
|
|
{
|
|
|
|
WebGLPipeline.prototype.onBind.call(this);
|
|
|
|
this.mvpUpdate();
|
|
|
|
|
|
|
|
return this;
|
2018-01-22 21:21:47 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
resize: function (width, height, resolution)
|
|
|
|
{
|
|
|
|
WebGLPipeline.prototype.resize.call(this, width, height, resolution);
|
2018-01-25 05:26:14 +00:00
|
|
|
this.projOrtho(0, this.width, this.height, 0, -1000.0, 1000.0);
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
drawStaticTilemapLayer: function (tilemap, camera)
|
|
|
|
{
|
|
|
|
if (tilemap.vertexCount > 0)
|
|
|
|
{
|
|
|
|
var pipelineVertexBuffer = this.vertexBuffer;
|
|
|
|
var gl = this.gl;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var frame = tilemap.tileset.image.get();
|
|
|
|
|
|
|
|
if (renderer.currentPipeline &&
|
|
|
|
renderer.currentPipeline.vertexCount > 0)
|
|
|
|
{
|
|
|
|
renderer.flush();
|
|
|
|
}
|
2018-01-22 21:21:47 +00:00
|
|
|
|
2018-01-25 05:26:14 +00:00
|
|
|
this.vertexBuffer = tilemap.vertexBuffer;
|
|
|
|
|
|
|
|
renderer.setTexture2D(frame.source.glTexture, 0);
|
|
|
|
renderer.setPipeline(this);
|
2018-01-22 21:21:47 +00:00
|
|
|
|
2018-01-25 05:26:14 +00:00
|
|
|
gl.drawArrays(this.topology, 0, tilemap.vertexCount);
|
|
|
|
|
|
|
|
this.vertexBuffer = pipelineVertexBuffer;
|
|
|
|
}
|
2018-01-22 21:21:47 +00:00
|
|
|
|
2018-01-26 03:47:41 +00:00
|
|
|
this.viewIdentity();
|
|
|
|
this.modelIdentity();
|
2018-01-22 21:21:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 01:10:30 +00:00
|
|
|
drawEmitterManager: function (emitterManager, camera)
|
|
|
|
{
|
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
|
|
|
var emitters = emitterManager.emitters.list;
|
|
|
|
var emitterCount = emitters.length;
|
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var maxQuads = this.maxQuads;
|
|
|
|
var cameraScrollX = camera.scrollX;
|
|
|
|
var cameraScrollY = camera.scrollY;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var sin = Math.sin;
|
|
|
|
var cos = Math.cos;
|
|
|
|
var vertexComponentCount = this.vertexComponentCount;
|
|
|
|
var vertexCapacity = this.vertexCapacity;
|
|
|
|
|
|
|
|
renderer.setTexture2D(emitterManager.defaultFrame.source.glTexture, 0);
|
|
|
|
|
|
|
|
for (var emitterIndex = 0; emitterIndex < emitterCount; ++emitterIndex)
|
|
|
|
{
|
|
|
|
var emitter = emitters[emitterIndex];
|
|
|
|
var particles = emitter.alive;
|
|
|
|
var aliveLength = particles.length;
|
|
|
|
var batchCount = Math.ceil(aliveLength / maxQuads);
|
|
|
|
var particleOffset = 0;
|
|
|
|
var scrollX = cameraScrollX * emitter.scrollFactorX;
|
|
|
|
var scrollY = cameraScrollY * emitter.scrollFactorY;
|
|
|
|
|
|
|
|
if (!emitter.visible || aliveLength === 0)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
renderer.setBlendMode(emitter.blendMode);
|
|
|
|
|
|
|
|
if (this.vertexCount > 0)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var batchIndex = 0; batchIndex < batchCount; ++batchIndex)
|
|
|
|
{
|
|
|
|
var batchSize = Math.min(aliveLength, maxQuads);
|
|
|
|
var vertexCount = 0;
|
|
|
|
|
|
|
|
for (var index = 0; index < batchSize; ++index)
|
|
|
|
{
|
|
|
|
var particle = particles[particleOffset + index];
|
|
|
|
|
|
|
|
if (particle.alpha <= 0)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
var frame = particle.frame;
|
|
|
|
var uvs = frame.uvs;
|
|
|
|
var x = -(frame.halfWidth);
|
|
|
|
var y = -(frame.halfHeight);
|
|
|
|
var color = particle.color;
|
|
|
|
var xw = x + frame.width;
|
|
|
|
var yh = y + frame.height;
|
|
|
|
var sr = sin(particle.rotation);
|
|
|
|
var cr = cos(particle.rotation);
|
|
|
|
var sra = cr * particle.scaleX;
|
|
|
|
var srb = -sr * particle.scaleX;
|
|
|
|
var src = sr * particle.scaleY;
|
|
|
|
var srd = cr * particle.scaleY;
|
|
|
|
var sre = particle.x - scrollX * particle.scrollFactorX;
|
|
|
|
var srf = particle.y - scrollY * particle.scrollFactorY;
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
|
|
|
var tx0 = x * mva + y * mvc + mve;
|
|
|
|
var ty0 = x * mvb + y * mvd + mvf;
|
|
|
|
var tx1 = x * mva + yh * mvc + mve;
|
|
|
|
var ty1 = x * mvb + yh * mvd + mvf;
|
|
|
|
var tx2 = xw * mva + yh * mvc + mve;
|
|
|
|
var ty2 = xw * mvb + yh * mvd + mvf;
|
|
|
|
var tx3 = xw * mva + y * mvc + mve;
|
|
|
|
var ty3 = xw * mvb + y * mvd + mvf;
|
|
|
|
var vertexOffset = vertexCount * vertexComponentCount;
|
|
|
|
|
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 2] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 3] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 4] = color;
|
|
|
|
vertexViewF32[vertexOffset + 5] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
|
|
|
vertexViewF32[vertexOffset + 7] = uvs.x1;
|
|
|
|
vertexViewF32[vertexOffset + 8] = uvs.y1;
|
|
|
|
vertexViewU32[vertexOffset + 9] = color;
|
|
|
|
vertexViewF32[vertexOffset + 10] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 12] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 13] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 14] = color;
|
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 17] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 18] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 19] = color;
|
|
|
|
vertexViewF32[vertexOffset + 20] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 22] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 23] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 24] = color;
|
|
|
|
vertexViewF32[vertexOffset + 25] = tx3;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty3;
|
|
|
|
vertexViewF32[vertexOffset + 27] = uvs.x3;
|
|
|
|
vertexViewF32[vertexOffset + 28] = uvs.y3;
|
|
|
|
vertexViewU32[vertexOffset + 29] = color;
|
|
|
|
|
|
|
|
vertexCount += 6;
|
|
|
|
}
|
|
|
|
|
|
|
|
particleOffset += batchSize;
|
|
|
|
aliveLength -= batchSize;
|
|
|
|
|
|
|
|
this.vertexCount = vertexCount;
|
|
|
|
|
|
|
|
if (vertexCount >= vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-01-22 21:21:47 +00:00
|
|
|
drawBlitter: function (blitter, camera)
|
|
|
|
{
|
2018-01-23 16:38:58 +00:00
|
|
|
this.renderer.setPipeline(this);
|
2018-01-22 21:21:47 +00:00
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
2018-01-22 21:21:47 +00:00
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var list = blitter.getRenderList();
|
|
|
|
var length = list.length;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
|
|
|
var a = cameraMatrix[0];
|
|
|
|
var b = cameraMatrix[1];
|
|
|
|
var c = cameraMatrix[2];
|
|
|
|
var d = cameraMatrix[3];
|
|
|
|
var e = cameraMatrix[4];
|
|
|
|
var f = cameraMatrix[5];
|
|
|
|
var cameraScrollX = camera.scrollX * blitter.scrollFactorX;
|
|
|
|
var cameraScrollY = camera.scrollY * blitter.scrollFactorY;
|
2018-01-25 01:10:30 +00:00
|
|
|
var batchCount = Math.ceil(length / this.maxQuads);
|
2018-01-22 21:21:47 +00:00
|
|
|
var batchOffset = 0;
|
|
|
|
var blitterX = blitter.x;
|
|
|
|
var blitterY = blitter.y;
|
|
|
|
|
|
|
|
for (var batchIndex = 0; batchIndex < batchCount; ++batchIndex)
|
|
|
|
{
|
2018-01-25 01:10:30 +00:00
|
|
|
var batchSize = Math.min(length, this.maxQuads);
|
2018-01-22 21:21:47 +00:00
|
|
|
var vertexOffset = 0;
|
2018-01-23 23:36:49 +00:00
|
|
|
var vertexCount = 0;
|
2018-01-22 21:21:47 +00:00
|
|
|
|
|
|
|
for (var index = 0; index < batchSize; ++index)
|
|
|
|
{
|
|
|
|
var bob = list[batchOffset + index];
|
|
|
|
var frame = bob.frame;
|
|
|
|
var alpha = bob.alpha;
|
2018-01-23 19:29:47 +00:00
|
|
|
var tint = getTint(0xffffff, bob.alpha);
|
2018-01-22 21:21:47 +00:00
|
|
|
var uvs = frame.uvs;
|
|
|
|
var flipX = bob.flipX;
|
|
|
|
var flipY = bob.flipY;
|
|
|
|
var width = frame.width * (flipX ? -1.0 : 1.0);
|
|
|
|
var height = frame.height * (flipY ? -1.0 : 1.0);
|
|
|
|
var x = blitterX + bob.x + frame.x - cameraScrollX + (width * ((flipX) ? 1.0 : 0.0));
|
|
|
|
var y = blitterY + bob.y + frame.y - cameraScrollY + (height * ((flipY) ? 1.0 : 0.0));
|
|
|
|
var xw = x + width;
|
|
|
|
var yh = y + height;
|
2018-01-23 23:36:49 +00:00
|
|
|
var tx0 = x * a + y * c + e;
|
|
|
|
var ty0 = x * b + y * d + f;
|
|
|
|
var tx1 = xw * a + yh * c + e;
|
|
|
|
var ty1 = xw * b + yh * d + f;
|
2018-01-24 03:57:33 +00:00
|
|
|
|
2018-01-22 21:21:47 +00:00
|
|
|
// Bind Texture if texture wasn't bound.
|
|
|
|
// This needs to be here because of multiple
|
|
|
|
// texture atlas.
|
|
|
|
renderer.setTexture2D(frame.texture.source[frame.sourceIndex].glTexture, 0);
|
|
|
|
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 2] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 3] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 4] = tint;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 5] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 7] = uvs.x1;
|
|
|
|
vertexViewF32[vertexOffset + 8] = uvs.y1;
|
|
|
|
vertexViewU32[vertexOffset + 9] = tint;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 10] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty1;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 12] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 13] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 14] = tint;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 17] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 18] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 19] = tint;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 20] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty1;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 22] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 23] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 24] = tint;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexViewF32[vertexOffset + 25] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty0;
|
2018-01-22 21:21:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 27] = uvs.x3;
|
|
|
|
vertexViewF32[vertexOffset + 28] = uvs.y3;
|
|
|
|
vertexViewU32[vertexOffset + 29] = tint;
|
|
|
|
|
|
|
|
vertexOffset += 30;
|
2018-01-23 23:36:49 +00:00
|
|
|
vertexCount += 6;
|
2018-01-22 21:21:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
batchOffset += batchSize;
|
|
|
|
length -= batchSize;
|
|
|
|
|
2018-01-23 23:36:49 +00:00
|
|
|
if (vertexCount <= this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.vertexCount = vertexCount;
|
|
|
|
this.flush();
|
|
|
|
}
|
2018-01-22 21:21:47 +00:00
|
|
|
}
|
2018-01-23 16:38:58 +00:00
|
|
|
},
|
|
|
|
|
2018-01-24 00:40:20 +00:00
|
|
|
batchTexture: function (
|
|
|
|
texture,
|
2018-01-25 00:15:51 +00:00
|
|
|
textureWidth, textureHeight,
|
2018-01-24 22:29:57 +00:00
|
|
|
srcX, srcY,
|
|
|
|
srcWidth, srcHeight,
|
2018-01-24 00:40:20 +00:00
|
|
|
scaleX, scaleY,
|
|
|
|
rotation,
|
|
|
|
flipX, flipY,
|
|
|
|
scrollFactorX, scrollFactorY,
|
|
|
|
displayOriginX, displayOriginY,
|
|
|
|
frameX, frameY, frameWidth, frameHeight,
|
|
|
|
tintTL, tintTR, tintBL, tintBR,
|
2018-01-25 00:15:51 +00:00
|
|
|
uOffset, vOffset,
|
2018-01-24 00:40:20 +00:00
|
|
|
camera)
|
|
|
|
{
|
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
flipY = flipY ^ (texture.isRenderTexture ? 1 : 0);
|
|
|
|
rotation = -rotation;
|
|
|
|
|
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
2018-01-24 22:29:57 +00:00
|
|
|
var width = srcWidth * (flipX ? -1.0 : 1.0);
|
|
|
|
var height = srcHeight * (flipY ? -1.0 : 1.0);
|
|
|
|
var x = -displayOriginX + ((srcWidth) * (flipX ? 1.0 : 0.0));
|
|
|
|
var y = -displayOriginY + ((srcHeight) * (flipY ? 1.0 : 0.0));
|
2018-01-24 00:40:20 +00:00
|
|
|
var xw = x + width;
|
|
|
|
var yh = y + height;
|
2018-01-24 22:29:57 +00:00
|
|
|
var translateX = srcX - camera.scrollX * scrollFactorX;
|
|
|
|
var translateY = srcY - camera.scrollY * scrollFactorY;
|
2018-01-24 00:40:20 +00:00
|
|
|
var sr = Math.sin(rotation);
|
|
|
|
var cr = Math.cos(rotation);
|
|
|
|
var sra = cr * scaleX;
|
|
|
|
var srb = -sr * scaleX;
|
|
|
|
var src = sr * scaleY;
|
|
|
|
var srd = cr * scaleY;
|
|
|
|
var sre = translateX;
|
|
|
|
var srf = translateY;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
|
|
|
var tx0 = x * mva + y * mvc + mve;
|
|
|
|
var ty0 = x * mvb + y * mvd + mvf;
|
|
|
|
var tx1 = x * mva + yh * mvc + mve;
|
|
|
|
var ty1 = x * mvb + yh * mvd + mvf;
|
|
|
|
var tx2 = xw * mva + yh * mvc + mve;
|
|
|
|
var ty2 = xw * mvb + yh * mvd + mvf;
|
|
|
|
var tx3 = xw * mva + y * mvc + mve;
|
|
|
|
var ty3 = xw * mvb + y * mvd + mvf;
|
|
|
|
var vertexOffset = 0;
|
2018-01-25 05:26:14 +00:00
|
|
|
var u0 = ((frameX + 0.5) / textureWidth) + uOffset;
|
|
|
|
var v0 = ((frameY + 0.5) / textureHeight) + vOffset;
|
|
|
|
var u1 = ((frameX - 0.5 + frameWidth) / textureWidth) + uOffset;
|
|
|
|
var v1 = ((frameY - 0.5 + frameHeight) / textureHeight) + vOffset;
|
2018-01-24 00:40:20 +00:00
|
|
|
|
|
|
|
renderer.setTexture2D(texture, 0);
|
|
|
|
|
|
|
|
vertexOffset = this.vertexCount * this.vertexComponentCount;
|
|
|
|
|
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 2] = u0;
|
|
|
|
vertexViewF32[vertexOffset + 3] = v0;
|
|
|
|
vertexViewU32[vertexOffset + 4] = tintTL;
|
|
|
|
vertexViewF32[vertexOffset + 5] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
2018-01-25 05:26:14 +00:00
|
|
|
vertexViewF32[vertexOffset + 7] = u0;
|
2018-01-24 00:40:20 +00:00
|
|
|
vertexViewF32[vertexOffset + 8] = v1;
|
|
|
|
vertexViewU32[vertexOffset + 9] = tintTR;
|
|
|
|
vertexViewF32[vertexOffset + 10] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty2;
|
2018-01-25 05:26:14 +00:00
|
|
|
vertexViewF32[vertexOffset + 12] = u1;
|
|
|
|
vertexViewF32[vertexOffset + 13] = v1;
|
2018-01-24 00:40:20 +00:00
|
|
|
vertexViewU32[vertexOffset + 14] = tintBL;
|
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 17] = u0;
|
|
|
|
vertexViewF32[vertexOffset + 18] = v0;
|
|
|
|
vertexViewU32[vertexOffset + 19] = tintTL;
|
|
|
|
vertexViewF32[vertexOffset + 20] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty2;
|
2018-01-25 05:26:14 +00:00
|
|
|
vertexViewF32[vertexOffset + 22] = u1;
|
|
|
|
vertexViewF32[vertexOffset + 23] = v1;
|
2018-01-24 00:40:20 +00:00
|
|
|
vertexViewU32[vertexOffset + 24] = tintBL;
|
|
|
|
vertexViewF32[vertexOffset + 25] = tx3;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty3;
|
2018-01-25 05:26:14 +00:00
|
|
|
vertexViewF32[vertexOffset + 27] = u1;
|
|
|
|
vertexViewF32[vertexOffset + 28] = v0;
|
2018-01-24 00:40:20 +00:00
|
|
|
vertexViewU32[vertexOffset + 29] = tintBR;
|
|
|
|
|
|
|
|
this.vertexCount += 6;
|
|
|
|
},
|
|
|
|
|
2018-01-23 16:38:58 +00:00
|
|
|
batchSprite: function (sprite, camera)
|
|
|
|
{
|
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
2018-01-23 16:38:58 +00:00
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
2018-01-23 19:29:47 +00:00
|
|
|
var renderer = this.renderer;
|
2018-01-23 16:38:58 +00:00
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
|
|
|
var frame = sprite.frame;
|
|
|
|
var texture = frame.texture.source[frame.sourceIndex].glTexture;
|
|
|
|
var forceFlipY = (texture.isRenderTexture ? true : false);
|
|
|
|
var flipX = sprite.flipX;
|
|
|
|
var flipY = sprite.flipY ^ forceFlipY;
|
|
|
|
var uvs = frame.uvs;
|
|
|
|
var width = frame.width * (flipX ? -1.0 : 1.0);
|
|
|
|
var height = frame.height * (flipY ? -1.0 : 1.0);
|
|
|
|
var x = -sprite.displayOriginX + frame.x + ((frame.width) * (flipX ? 1.0 : 0.0));
|
|
|
|
var y = -sprite.displayOriginY + frame.y + ((frame.height) * (flipY ? 1.0 : 0.0));
|
|
|
|
var xw = x + width;
|
|
|
|
var yh = y + height;
|
|
|
|
var translateX = sprite.x - camera.scrollX * sprite.scrollFactorX;
|
|
|
|
var translateY = sprite.y - camera.scrollY * sprite.scrollFactorY;
|
|
|
|
var scaleX = sprite.scaleX;
|
|
|
|
var scaleY = sprite.scaleY;
|
|
|
|
var rotation = -sprite.rotation;
|
|
|
|
var alphaTL = sprite._alphaTL;
|
|
|
|
var alphaTR = sprite._alphaTR;
|
|
|
|
var alphaBL = sprite._alphaBL;
|
|
|
|
var alphaBR = sprite._alphaBR;
|
|
|
|
var tintTL = sprite._tintTL;
|
|
|
|
var tintTR = sprite._tintTR;
|
|
|
|
var tintBL = sprite._tintBL;
|
|
|
|
var tintBR = sprite._tintBR;
|
|
|
|
var sr = Math.sin(rotation);
|
|
|
|
var cr = Math.cos(rotation);
|
|
|
|
var sra = cr * scaleX;
|
|
|
|
var srb = -sr * scaleX;
|
|
|
|
var src = sr * scaleY;
|
|
|
|
var srd = cr * scaleY;
|
|
|
|
var sre = translateX;
|
|
|
|
var srf = translateY;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
|
|
|
var tx0 = x * mva + y * mvc + mve;
|
|
|
|
var ty0 = x * mvb + y * mvd + mvf;
|
|
|
|
var tx1 = x * mva + yh * mvc + mve;
|
|
|
|
var ty1 = x * mvb + yh * mvd + mvf;
|
|
|
|
var tx2 = xw * mva + yh * mvc + mve;
|
|
|
|
var ty2 = xw * mvb + yh * mvd + mvf;
|
|
|
|
var tx3 = xw * mva + y * mvc + mve;
|
|
|
|
var ty3 = xw * mvb + y * mvd + mvf;
|
|
|
|
var tint0 = getTint(tintTL, alphaTL);
|
|
|
|
var tint1 = getTint(tintTR, alphaTR);
|
|
|
|
var tint2 = getTint(tintBL, alphaBL);
|
|
|
|
var tint3 = getTint(tintBR, alphaBR);
|
2018-01-23 20:32:20 +00:00
|
|
|
var vertexOffset = 0;
|
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
renderer.setTexture2D(texture, 0);
|
|
|
|
|
2018-01-23 20:32:20 +00:00
|
|
|
vertexOffset = this.vertexCount * this.vertexComponentCount;
|
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 2] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 3] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 4] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 5] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
|
|
|
vertexViewF32[vertexOffset + 7] = uvs.x1;
|
|
|
|
vertexViewF32[vertexOffset + 8] = uvs.y1;
|
|
|
|
vertexViewU32[vertexOffset + 9] = tint1;
|
|
|
|
vertexViewF32[vertexOffset + 10] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 12] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 13] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 14] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 17] = uvs.x0;
|
|
|
|
vertexViewF32[vertexOffset + 18] = uvs.y0;
|
|
|
|
vertexViewU32[vertexOffset + 19] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 20] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 22] = uvs.x2;
|
|
|
|
vertexViewF32[vertexOffset + 23] = uvs.y2;
|
|
|
|
vertexViewU32[vertexOffset + 24] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 25] = tx3;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty3;
|
|
|
|
vertexViewF32[vertexOffset + 27] = uvs.x3;
|
|
|
|
vertexViewF32[vertexOffset + 28] = uvs.y3;
|
|
|
|
vertexViewU32[vertexOffset + 29] = tint3;
|
2018-01-23 16:38:58 +00:00
|
|
|
|
|
|
|
this.vertexCount += 6;
|
2018-01-23 19:29:47 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
batchMesh: function (mesh, camera)
|
|
|
|
{
|
|
|
|
var vertices = mesh.vertices;
|
|
|
|
var length = vertices.length;
|
|
|
|
var vertexCount = (length / 2)|0;
|
|
|
|
|
2018-01-23 20:32:20 +00:00
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
if (this.vertexCount + vertexCount > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
|
|
|
var uvs = mesh.uv;
|
|
|
|
var colors = mesh.colors;
|
|
|
|
var alphas = mesh.alphas;
|
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
|
|
|
var a = cameraMatrix[0];
|
|
|
|
var b = cameraMatrix[1];
|
|
|
|
var c = cameraMatrix[2];
|
|
|
|
var d = cameraMatrix[3];
|
|
|
|
var e = cameraMatrix[4];
|
|
|
|
var f = cameraMatrix[5];
|
|
|
|
var frame = mesh.frame;
|
|
|
|
var texture = mesh.texture.source[frame.sourceIndex].glTexture;
|
|
|
|
var translateX = mesh.x - camera.scrollX * mesh.scrollFactorX;
|
|
|
|
var translateY = mesh.y - camera.scrollY * mesh.scrollFactorY;
|
|
|
|
var scaleX = mesh.scaleX;
|
|
|
|
var scaleY = mesh.scaleY;
|
|
|
|
var rotation = -mesh.rotation;
|
|
|
|
var sr = Math.sin(rotation);
|
|
|
|
var cr = Math.cos(rotation);
|
|
|
|
var sra = cr * scaleX;
|
|
|
|
var srb = -sr * scaleX;
|
|
|
|
var src = sr * scaleY;
|
|
|
|
var srd = cr * scaleY;
|
|
|
|
var sre = translateX;
|
|
|
|
var srf = translateY;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
2018-01-23 20:32:20 +00:00
|
|
|
var vertexOffset = 0;
|
2018-01-23 23:36:49 +00:00
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
renderer.setTexture2D(texture, 0);
|
2018-01-23 20:32:20 +00:00
|
|
|
vertexOffset = this.vertexCount * this.vertexComponentCount;
|
2018-01-23 19:29:47 +00:00
|
|
|
|
|
|
|
for (var index = 0, index0 = 0; index < length; index += 2)
|
|
|
|
{
|
|
|
|
var x = vertices[index + 0];
|
|
|
|
var y = vertices[index + 1];
|
|
|
|
var tx = x * mva + y * mvc + mve;
|
|
|
|
var ty = x * mvb + y * mvd + mvf;
|
|
|
|
|
|
|
|
vertexViewF32[vertexOffset + 0] = tx;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty;
|
|
|
|
vertexViewF32[vertexOffset + 2] = uvs[index + 0];
|
|
|
|
vertexViewF32[vertexOffset + 3] = uvs[index + 1];
|
|
|
|
vertexViewU32[vertexOffset + 4] = getTint(colors[index0], alphas[index0]);
|
|
|
|
|
|
|
|
vertexOffset += 5;
|
|
|
|
index0 += 1;
|
|
|
|
}
|
2018-01-23 16:38:58 +00:00
|
|
|
|
2018-01-23 19:29:47 +00:00
|
|
|
this.vertexCount += vertexCount;
|
2018-01-23 23:36:49 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
batchBitmapText: function (bitmapText, camera)
|
|
|
|
{
|
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
var text = bitmapText.text;
|
|
|
|
var textLength = text.length;
|
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
2018-01-26 00:05:38 +00:00
|
|
|
var cameraWidth = camera.width + 50;
|
|
|
|
var cameraHeight = camera.height + 50;
|
|
|
|
var cameraX = -50;
|
|
|
|
var cameraY = -50;
|
2018-01-23 23:36:49 +00:00
|
|
|
var frame = bitmapText.frame;
|
|
|
|
var textureSource = bitmapText.texture.source[frame.sourceIndex];
|
|
|
|
var cameraScrollX = camera.scrollX * bitmapText.scrollFactorX;
|
|
|
|
var cameraScrollY = camera.scrollY * bitmapText.scrollFactorY;
|
|
|
|
var fontData = bitmapText.fontData;
|
|
|
|
var lineHeight = fontData.lineHeight;
|
2018-01-26 00:34:35 +00:00
|
|
|
var scale = (bitmapText.fontSize / fontData.size);
|
2018-01-23 23:36:49 +00:00
|
|
|
var chars = fontData.chars;
|
|
|
|
var alpha = bitmapText.alpha;
|
|
|
|
var tint0 = getTint(bitmapText._tintTL, alpha);
|
|
|
|
var tint1 = getTint(bitmapText._tintTR, alpha);
|
|
|
|
var tint2 = getTint(bitmapText._tintBL, alpha);
|
|
|
|
var tint3 = getTint(bitmapText._tintBR, alpha);
|
|
|
|
var srcX = bitmapText.x;
|
|
|
|
var srcY = bitmapText.y;
|
|
|
|
var textureX = frame.cutX;
|
|
|
|
var textureY = frame.cutY;
|
|
|
|
var textureWidth = textureSource.width;
|
|
|
|
var textureHeight = textureSource.height;
|
|
|
|
var texture = textureSource.glTexture;
|
|
|
|
var xAdvance = 0;
|
|
|
|
var yAdvance = 0;
|
|
|
|
var indexCount = 0;
|
|
|
|
var charCode = 0;
|
|
|
|
var glyph = null;
|
|
|
|
var glyphX = 0;
|
|
|
|
var glyphY = 0;
|
|
|
|
var glyphW = 0;
|
|
|
|
var glyphH = 0;
|
|
|
|
var x = 0;
|
|
|
|
var y = 0;
|
|
|
|
var xw = 0;
|
|
|
|
var yh = 0;
|
|
|
|
var umin = 0;
|
|
|
|
var umax = 0;
|
|
|
|
var vmin = 0;
|
|
|
|
var vmax = 0;
|
|
|
|
var lastGlyph = null;
|
|
|
|
var lastCharCode = 0;
|
|
|
|
var translateX = (srcX - cameraScrollX) + frame.x;
|
|
|
|
var translateY = (srcY - cameraScrollY) + frame.y;
|
|
|
|
var rotation = -bitmapText.rotation;
|
|
|
|
var scaleX = bitmapText.scaleX;
|
|
|
|
var scaleY = bitmapText.scaleY;
|
|
|
|
var sr = Math.sin(rotation);
|
|
|
|
var cr = Math.cos(rotation);
|
|
|
|
var sra = cr * scaleX;
|
|
|
|
var srb = -sr * scaleX;
|
|
|
|
var src = sr * scaleY;
|
|
|
|
var srd = cr * scaleY;
|
|
|
|
var sre = translateX;
|
|
|
|
var srf = translateY;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
|
|
|
var vertexOffset = 0;
|
|
|
|
|
|
|
|
renderer.setTexture2D(texture, 0);
|
|
|
|
|
|
|
|
for (var index = 0; index < textLength; ++index)
|
|
|
|
{
|
|
|
|
charCode = text.charCodeAt(index);
|
|
|
|
|
|
|
|
if (charCode === 10)
|
|
|
|
{
|
|
|
|
xAdvance = 0;
|
|
|
|
indexCount = 0;
|
|
|
|
yAdvance += lineHeight;
|
|
|
|
lastGlyph = null;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
glyph = chars[charCode];
|
|
|
|
|
|
|
|
if (!glyph)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
glyphX = textureX + glyph.x;
|
|
|
|
glyphY = textureY + glyph.y;
|
2018-01-24 18:55:23 +00:00
|
|
|
|
2018-01-23 23:36:49 +00:00
|
|
|
glyphW = glyph.width;
|
|
|
|
glyphH = glyph.height;
|
2018-01-24 18:55:23 +00:00
|
|
|
|
2018-01-26 00:34:35 +00:00
|
|
|
x = (indexCount + glyph.xOffset + xAdvance) * scale;
|
|
|
|
y = (glyph.yOffset + yAdvance) * scale;
|
2018-01-23 23:36:49 +00:00
|
|
|
|
|
|
|
if (lastGlyph !== null)
|
|
|
|
{
|
|
|
|
var kerningOffset = glyph.kerning[lastCharCode];
|
|
|
|
x += (kerningOffset !== undefined) ? kerningOffset : 0;
|
2018-01-24 18:55:23 +00:00
|
|
|
}
|
|
|
|
|
2018-01-26 00:05:38 +00:00
|
|
|
xAdvance += glyph.xAdvance;
|
|
|
|
indexCount += 1;
|
|
|
|
lastGlyph = glyph;
|
|
|
|
lastCharCode = charCode;
|
|
|
|
|
2018-01-26 00:34:35 +00:00
|
|
|
// Nothing to render or a space? Then skip to the next glyph
|
|
|
|
if (glyphW === 0 || glyphH === 0 || charCode === 32)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
xw = x + glyphW * scale;
|
|
|
|
yh = y + glyphH * scale;
|
|
|
|
tx0 = x * mva + y * mvc + mve;
|
|
|
|
ty0 = x * mvb + y * mvd + mvf;
|
|
|
|
tx1 = x * mva + yh * mvc + mve;
|
|
|
|
ty1 = x * mvb + yh * mvd + mvf;
|
|
|
|
tx2 = xw * mva + yh * mvc + mve;
|
|
|
|
ty2 = xw * mvb + yh * mvd + mvf;
|
|
|
|
tx3 = xw * mva + y * mvc + mve;
|
|
|
|
ty3 = xw * mvb + y * mvd + mvf;
|
2018-01-24 18:55:23 +00:00
|
|
|
|
|
|
|
umin = glyphX / textureWidth;
|
|
|
|
umax = (glyphX + glyphW) / textureWidth;
|
|
|
|
vmin = glyphY / textureHeight;
|
|
|
|
vmax = (glyphY + glyphH) / textureHeight;
|
|
|
|
|
2018-01-26 00:05:38 +00:00
|
|
|
if ((tx0 < cameraX || tx0 > cameraWidth || ty0 < cameraY || ty0 > cameraHeight) &&
|
|
|
|
(tx1 < cameraX || tx1 > cameraWidth || ty1 < cameraY || ty1 > cameraHeight) &&
|
|
|
|
(tx2 < cameraX || tx2 > cameraWidth || ty2 < cameraY || ty2 > cameraHeight) &&
|
2018-01-26 00:34:35 +00:00
|
|
|
(tx3 < cameraX || tx3 > cameraWidth || ty3 < cameraY || ty3 > cameraHeight))
|
2018-01-26 00:05:38 +00:00
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-01-24 18:55:23 +00:00
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
2018-01-23 23:36:49 +00:00
|
|
|
}
|
2018-01-24 18:55:23 +00:00
|
|
|
|
|
|
|
vertexOffset = this.vertexCount * this.vertexComponentCount;
|
|
|
|
|
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 2] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 3] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 4] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 5] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
|
|
|
vertexViewF32[vertexOffset + 7] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 8] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 9] = tint1;
|
|
|
|
vertexViewF32[vertexOffset + 10] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 12] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 13] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 14] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 17] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 18] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 19] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 20] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 22] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 23] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 24] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 25] = tx3;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty3;
|
|
|
|
vertexViewF32[vertexOffset + 27] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 28] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 29] = tint3;
|
|
|
|
|
|
|
|
this.vertexCount += 6;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
batchDynamicBitmapText: function (bitmapText, camera)
|
|
|
|
{
|
|
|
|
this.renderer.setPipeline(this);
|
|
|
|
|
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
var displayCallback = bitmapText.displayCallback;
|
|
|
|
var text = bitmapText.text;
|
|
|
|
var textLength = text.length;
|
|
|
|
var getTint = Utils.getTintAppendFloatAlpha;
|
|
|
|
var vertexViewF32 = this.vertexViewF32;
|
|
|
|
var vertexViewU32 = this.vertexViewU32;
|
|
|
|
var renderer = this.renderer;
|
|
|
|
var cameraMatrix = camera.matrix.matrix;
|
|
|
|
var frame = bitmapText.frame;
|
|
|
|
var textureSource = bitmapText.texture.source[frame.sourceIndex];
|
|
|
|
var cameraScrollX = camera.scrollX * bitmapText.scrollFactorX;
|
|
|
|
var cameraScrollY = camera.scrollY * bitmapText.scrollFactorY;
|
|
|
|
var scrollX = bitmapText.scrollX;
|
|
|
|
var scrollY = bitmapText.scrollY;
|
|
|
|
var fontData = bitmapText.fontData;
|
|
|
|
var lineHeight = fontData.lineHeight;
|
|
|
|
var scale = (bitmapText.fontSize / fontData.size);
|
|
|
|
var chars = fontData.chars;
|
|
|
|
var alpha = bitmapText.alpha;
|
|
|
|
var tint0 = getTint(bitmapText._tintTL, alpha);
|
|
|
|
var tint1 = getTint(bitmapText._tintTR, alpha);
|
|
|
|
var tint2 = getTint(bitmapText._tintBL, alpha);
|
|
|
|
var tint3 = getTint(bitmapText._tintBR, alpha);
|
|
|
|
var srcX = bitmapText.x;
|
|
|
|
var srcY = bitmapText.y;
|
|
|
|
var textureX = frame.cutX;
|
|
|
|
var textureY = frame.cutY;
|
|
|
|
var textureWidth = textureSource.width;
|
|
|
|
var textureHeight = textureSource.height;
|
|
|
|
var texture = textureSource.glTexture;
|
|
|
|
var xAdvance = 0;
|
|
|
|
var yAdvance = 0;
|
|
|
|
var indexCount = 0;
|
|
|
|
var charCode = 0;
|
|
|
|
var glyph = null;
|
|
|
|
var glyphX = 0;
|
|
|
|
var glyphY = 0;
|
|
|
|
var glyphW = 0;
|
|
|
|
var glyphH = 0;
|
|
|
|
var x = 0;
|
|
|
|
var y = 0;
|
|
|
|
var xw = 0;
|
|
|
|
var yh = 0;
|
|
|
|
var umin = 0;
|
|
|
|
var umax = 0;
|
|
|
|
var vmin = 0;
|
|
|
|
var vmax = 0;
|
|
|
|
var lastGlyph = null;
|
|
|
|
var lastCharCode = 0;
|
|
|
|
var translateX = srcX + frame.x;
|
|
|
|
var translateY = srcY + frame.y;
|
|
|
|
var rotation = -bitmapText.rotation;
|
|
|
|
var scaleX = bitmapText.scaleX;
|
|
|
|
var scaleY = bitmapText.scaleY;
|
|
|
|
var sr = Math.sin(rotation);
|
|
|
|
var cr = Math.cos(rotation);
|
|
|
|
var sra = cr * scaleX;
|
|
|
|
var srb = -sr * scaleX;
|
|
|
|
var src = sr * scaleY;
|
|
|
|
var srd = cr * scaleY;
|
|
|
|
var sre = translateX;
|
|
|
|
var srf = translateY;
|
|
|
|
var cma = cameraMatrix[0];
|
|
|
|
var cmb = cameraMatrix[1];
|
|
|
|
var cmc = cameraMatrix[2];
|
|
|
|
var cmd = cameraMatrix[3];
|
|
|
|
var cme = cameraMatrix[4];
|
|
|
|
var cmf = cameraMatrix[5];
|
|
|
|
var mva = sra * cma + srb * cmc;
|
|
|
|
var mvb = sra * cmb + srb * cmd;
|
|
|
|
var mvc = src * cma + srd * cmc;
|
|
|
|
var mvd = src * cmb + srd * cmd;
|
|
|
|
var mve = sre * cma + srf * cmc + cme;
|
|
|
|
var mvf = sre * cmb + srf * cmd + cmf;
|
|
|
|
var crop = (bitmapText.cropWidth > 0 || bitmapText.cropHeight > 0);
|
|
|
|
var uta, utb, utc, utd, ute, utf;
|
|
|
|
var vertexOffset = 0;
|
2018-01-23 23:36:49 +00:00
|
|
|
|
2018-01-24 18:55:23 +00:00
|
|
|
renderer.setTexture2D(texture, 0);
|
|
|
|
|
|
|
|
if (crop)
|
|
|
|
{
|
|
|
|
renderer.pushScissor(
|
|
|
|
bitmapText.x,
|
|
|
|
bitmapText.y,
|
|
|
|
bitmapText.cropWidth * bitmapText.scaleX,
|
|
|
|
bitmapText.cropHeight * bitmapText.scaleY
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var index = 0; index < textLength; ++index)
|
|
|
|
{
|
|
|
|
scale = (bitmapText.fontSize / bitmapText.fontData.size);
|
|
|
|
rotation = 0;
|
|
|
|
|
|
|
|
charCode = text.charCodeAt(index);
|
|
|
|
|
|
|
|
if (charCode === 10)
|
2018-01-23 23:36:49 +00:00
|
|
|
{
|
2018-01-24 18:55:23 +00:00
|
|
|
xAdvance = 0;
|
|
|
|
indexCount = 0;
|
|
|
|
yAdvance += lineHeight;
|
|
|
|
lastGlyph = null;
|
2018-01-23 23:36:49 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-01-24 18:55:23 +00:00
|
|
|
glyph = chars[charCode];
|
|
|
|
|
|
|
|
if (!glyph)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
glyphX = textureX + glyph.x;
|
|
|
|
glyphY = textureY + glyph.y;
|
|
|
|
|
|
|
|
glyphW = glyph.width;
|
|
|
|
glyphH = glyph.height;
|
|
|
|
|
|
|
|
x = (indexCount + glyph.xOffset + xAdvance) - scrollX;
|
|
|
|
y = (glyph.yOffset + yAdvance) - scrollY;
|
|
|
|
|
|
|
|
if (lastGlyph !== null)
|
|
|
|
{
|
|
|
|
var kerningOffset = glyph.kerning[lastCharCode];
|
|
|
|
x += (kerningOffset !== undefined) ? kerningOffset : 0;
|
|
|
|
}
|
|
|
|
|
2018-01-26 00:34:35 +00:00
|
|
|
xAdvance += glyph.xAdvance;
|
|
|
|
indexCount += 1;
|
|
|
|
lastGlyph = glyph;
|
|
|
|
lastCharCode = charCode;
|
|
|
|
|
|
|
|
// Nothing to render or a space? Then skip to the next glyph
|
|
|
|
if (glyphW === 0 || glyphH === 0 || charCode === 32)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-01-24 18:55:23 +00:00
|
|
|
if (displayCallback)
|
|
|
|
{
|
|
|
|
var output = displayCallback({
|
|
|
|
color: 0,
|
|
|
|
tint: {
|
|
|
|
topLeft: tint0,
|
|
|
|
topRight: tint1,
|
|
|
|
bottomLeft: tint2,
|
|
|
|
bottomRight: tint3
|
|
|
|
},
|
|
|
|
index: index,
|
|
|
|
charCode: charCode,
|
|
|
|
x: x,
|
|
|
|
y: y,
|
|
|
|
scale: scale,
|
|
|
|
rotation: 0,
|
|
|
|
data: glyph.data
|
|
|
|
});
|
|
|
|
|
|
|
|
x = output.x;
|
|
|
|
y = output.y;
|
|
|
|
scale = output.scale;
|
|
|
|
rotation = output.rotation;
|
|
|
|
|
|
|
|
if (output.color)
|
|
|
|
{
|
|
|
|
tint0 = output.color;
|
|
|
|
tint1 = output.color;
|
|
|
|
tint2 = output.color;
|
|
|
|
tint3 = output.color;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tint0 = output.tint.topLeft;
|
|
|
|
tint1 = output.tint.topRight;
|
|
|
|
tint2 = output.tint.bottomLeft;
|
|
|
|
tint3 = output.tint.bottomRight;
|
|
|
|
}
|
|
|
|
|
|
|
|
tint0 = getTint(tint0, alpha);
|
|
|
|
tint1 = getTint(tint1, alpha);
|
|
|
|
tint2 = getTint(tint2, alpha);
|
|
|
|
tint3 = getTint(tint3, alpha);
|
|
|
|
}
|
|
|
|
|
|
|
|
x *= scale;
|
|
|
|
y *= scale;
|
|
|
|
x -= cameraScrollX;
|
|
|
|
y -= cameraScrollY;
|
|
|
|
|
|
|
|
sr = Math.sin(-rotation);
|
|
|
|
cr = Math.cos(-rotation);
|
|
|
|
uta = cr * scale;
|
|
|
|
utb = -sr * scale;
|
|
|
|
utc = sr * scale;
|
|
|
|
utd = cr * scale;
|
|
|
|
ute = x;
|
|
|
|
utf = y;
|
|
|
|
|
|
|
|
sra = uta * mva + utb * mvc;
|
|
|
|
srb = uta * mvb + utb * mvd;
|
|
|
|
src = utc * mva + utd * mvc;
|
|
|
|
srd = utc * mvb + utd * mvd;
|
|
|
|
sre = ute * mva + utf * mvc + mve;
|
|
|
|
srf = ute * mvb + utf * mvd + mvf;
|
|
|
|
|
|
|
|
xw = glyphW;
|
|
|
|
yh = glyphH;
|
|
|
|
tx0 = sre;
|
|
|
|
ty0 = srf;
|
|
|
|
tx1 = yh * src + sre;
|
|
|
|
ty1 = yh * srd + srf;
|
|
|
|
tx2 = xw * sra + yh * src + sre;
|
|
|
|
ty2 = xw * srb + yh * srd + srf;
|
|
|
|
tx3 = xw * sra + sre;
|
|
|
|
ty3 = xw * srb + srf;
|
|
|
|
|
2018-01-23 23:36:49 +00:00
|
|
|
umin = glyphX / textureWidth;
|
|
|
|
umax = (glyphX + glyphW) / textureWidth;
|
|
|
|
vmin = glyphY / textureHeight;
|
|
|
|
vmax = (glyphY + glyphH) / textureHeight;
|
|
|
|
|
|
|
|
if (this.vertexCount + 6 > this.vertexCapacity)
|
|
|
|
{
|
|
|
|
this.flush();
|
|
|
|
}
|
|
|
|
|
|
|
|
vertexOffset = this.vertexCount * this.vertexComponentCount;
|
|
|
|
|
|
|
|
vertexViewF32[vertexOffset + 0] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 1] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 2] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 3] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 4] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 5] = tx1;
|
|
|
|
vertexViewF32[vertexOffset + 6] = ty1;
|
|
|
|
vertexViewF32[vertexOffset + 7] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 8] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 9] = tint1;
|
|
|
|
vertexViewF32[vertexOffset + 10] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 11] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 12] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 13] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 14] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 15] = tx0;
|
|
|
|
vertexViewF32[vertexOffset + 16] = ty0;
|
|
|
|
vertexViewF32[vertexOffset + 17] = umin;
|
|
|
|
vertexViewF32[vertexOffset + 18] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 19] = tint0;
|
|
|
|
vertexViewF32[vertexOffset + 20] = tx2;
|
|
|
|
vertexViewF32[vertexOffset + 21] = ty2;
|
|
|
|
vertexViewF32[vertexOffset + 22] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 23] = vmax;
|
|
|
|
vertexViewU32[vertexOffset + 24] = tint2;
|
|
|
|
vertexViewF32[vertexOffset + 25] = tx3;
|
|
|
|
vertexViewF32[vertexOffset + 26] = ty3;
|
|
|
|
vertexViewF32[vertexOffset + 27] = umax;
|
|
|
|
vertexViewF32[vertexOffset + 28] = vmin;
|
|
|
|
vertexViewU32[vertexOffset + 29] = tint3;
|
|
|
|
|
|
|
|
this.vertexCount += 6;
|
|
|
|
}
|
2018-01-24 18:55:23 +00:00
|
|
|
|
|
|
|
if (crop)
|
|
|
|
{
|
|
|
|
renderer.popScissor();
|
|
|
|
}
|
2018-01-22 21:21:47 +00:00
|
|
|
}
|
2018-01-24 22:29:57 +00:00
|
|
|
|
2018-01-22 21:21:47 +00:00
|
|
|
});
|
|
|
|
|
2018-01-22 22:51:15 +00:00
|
|
|
module.exports = TextureTintPipeline;
|