2017-04-07 01:49:15 +00:00
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var GameObject = require('../GameObject');
|
2017-07-04 00:59:31 +00:00
|
|
|
var Components = require('../components');
|
2017-04-07 01:49:15 +00:00
|
|
|
var Render = require('./EffectLayerRender');
|
|
|
|
var TexturedAndNormalizedTintedShader = require('../../renderer/webgl/shaders/TexturedAndNormalizedTintedShader');
|
|
|
|
|
2017-05-09 23:43:12 +00:00
|
|
|
// EffectLayer renders all elements on the layer to an offscreen render target
|
|
|
|
// and then when rendering the color buffer of that render target to the main screen
|
|
|
|
// it applies the effect layer shader.
|
|
|
|
|
2017-04-07 01:49:15 +00:00
|
|
|
var EffectLayer = new Class({
|
|
|
|
|
|
|
|
Extends: GameObject,
|
|
|
|
|
|
|
|
Mixins: [
|
|
|
|
Components.Alpha,
|
2017-04-10 16:12:54 +00:00
|
|
|
Components.BlendMode,
|
|
|
|
Components.Flip,
|
|
|
|
Components.GetBounds,
|
2017-04-07 01:49:15 +00:00
|
|
|
Components.Origin,
|
|
|
|
Components.RenderTarget,
|
2017-04-10 16:12:54 +00:00
|
|
|
Components.ScaleMode,
|
|
|
|
Components.Size,
|
|
|
|
Components.Transform,
|
|
|
|
Components.Visible,
|
2017-06-22 02:19:03 +00:00
|
|
|
Components.ScrollFactor,
|
2017-04-07 01:49:15 +00:00
|
|
|
Render
|
|
|
|
],
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2017-07-14 13:30:20 +00:00
|
|
|
function EffectLayer (scene, x, y, width, height, effectName, fragmentShader)
|
2017-04-07 01:49:15 +00:00
|
|
|
{
|
2017-07-14 13:30:20 +00:00
|
|
|
GameObject.call(this, scene, 'EffectLayer');
|
2017-04-10 16:12:54 +00:00
|
|
|
|
2017-05-20 01:16:45 +00:00
|
|
|
var pot = ((width & (width - 1)) == 0 && (height & (height - 1)) == 0);
|
2017-07-14 13:30:20 +00:00
|
|
|
var resourceManager = scene.game.renderer.resourceManager;
|
2017-06-02 16:27:51 +00:00
|
|
|
var wrap;
|
2017-04-07 01:49:15 +00:00
|
|
|
var gl;
|
|
|
|
|
2017-04-12 23:05:12 +00:00
|
|
|
this.dstRenderTarget = null;
|
2017-04-20 23:50:47 +00:00
|
|
|
this.renderTexture = null;
|
2017-04-07 01:49:15 +00:00
|
|
|
this.dstShader = null;
|
2017-04-07 18:50:44 +00:00
|
|
|
this.uniforms = {};
|
2017-04-07 01:49:15 +00:00
|
|
|
|
|
|
|
if (resourceManager !== undefined)
|
|
|
|
{
|
2017-07-14 13:30:20 +00:00
|
|
|
gl = scene.game.renderer.gl;
|
2017-06-02 16:27:51 +00:00
|
|
|
wrap = pot ? gl.REPEAT : gl.CLAMP_TO_EDGE;
|
2017-04-07 01:49:15 +00:00
|
|
|
this.dstShader = resourceManager.createShader(effectName, {
|
|
|
|
vert: TexturedAndNormalizedTintedShader.vert,
|
|
|
|
frag: fragmentShader
|
|
|
|
});
|
2017-04-12 23:05:12 +00:00
|
|
|
|
2017-04-20 23:50:47 +00:00
|
|
|
this.renderTexture = resourceManager.createTexture(
|
2017-04-12 23:05:12 +00:00
|
|
|
0,
|
|
|
|
gl.LINEAR, gl.LINEAR,
|
2017-05-20 01:16:45 +00:00
|
|
|
wrap, wrap,
|
2017-04-12 23:05:12 +00:00
|
|
|
gl.RGBA,
|
2017-04-07 01:49:15 +00:00
|
|
|
null, width, height
|
|
|
|
);
|
2017-04-12 23:05:12 +00:00
|
|
|
|
2017-04-20 23:50:47 +00:00
|
|
|
this.dstRenderTarget = resourceManager.createRenderTarget(width, height, this.renderTexture, null);
|
2017-08-03 20:02:57 +00:00
|
|
|
scene.game.renderer.currentTexture[0] = null; // force rebinding of prev texture
|
2017-04-07 01:49:15 +00:00
|
|
|
}
|
2017-04-12 23:05:12 +00:00
|
|
|
|
2017-04-07 01:49:15 +00:00
|
|
|
this.flipY = true;
|
|
|
|
this.setPosition(x, y);
|
|
|
|
this.setSize(width, height);
|
|
|
|
this.setOrigin(0, 0);
|
|
|
|
},
|
|
|
|
|
2017-06-28 09:22:48 +00:00
|
|
|
setClearAlpha: function (alpha)
|
|
|
|
{
|
|
|
|
if (this.dstRenderTarget)
|
|
|
|
{
|
2017-07-04 15:10:51 +00:00
|
|
|
this.dstRenderTarget.clearAlpha = alpha;
|
2017-06-28 09:22:48 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2017-05-09 23:43:12 +00:00
|
|
|
renderOffScreen: function ()
|
2017-04-21 00:30:19 +00:00
|
|
|
{
|
|
|
|
this.renderTarget = this.dstRenderTarget;
|
|
|
|
},
|
|
|
|
|
|
|
|
renderOnScreen: function ()
|
|
|
|
{
|
|
|
|
this.renderTarget = null;
|
|
|
|
},
|
|
|
|
|
2017-04-07 01:49:15 +00:00
|
|
|
add: function (gameObject)
|
|
|
|
{
|
|
|
|
if (gameObject.renderTarget !== undefined)
|
|
|
|
{
|
|
|
|
gameObject.renderTarget = this.dstRenderTarget;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
remove: function (gameObject)
|
|
|
|
{
|
|
|
|
if (gameObject.renderTarget !== undefined)
|
|
|
|
{
|
|
|
|
gameObject.renderTarget = null;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-07 18:50:44 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
getUniformLocation: function (uniformName)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
var uniforms = this.uniforms;
|
|
|
|
var location;
|
|
|
|
|
|
|
|
if (uniformName in uniforms)
|
|
|
|
{
|
|
|
|
location = uniforms[uniformName];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
location = dstShader.getUniformLocation(uniformName);
|
|
|
|
uniforms[uniformName] = location;
|
|
|
|
}
|
|
|
|
|
|
|
|
return location;
|
|
|
|
},
|
|
|
|
|
|
|
|
setFloat: function (uniformName, x)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-07 18:50:44 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-07 18:50:44 +00:00
|
|
|
|
|
|
|
dstShader.setConstantFloat1(this.getUniformLocation(uniformName), x);
|
|
|
|
},
|
|
|
|
|
|
|
|
setFloat2: function (uniformName, x, y)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-07 18:50:44 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-07 18:50:44 +00:00
|
|
|
|
|
|
|
dstShader.setConstantFloat2(this.getUniformLocation(uniformName), x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
setFloat3: function (uniformName, x, y, z)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-07 18:50:44 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-07 18:50:44 +00:00
|
|
|
|
|
|
|
dstShader.setConstantFloat3(this.getUniformLocation(uniformName), x, y, z);
|
|
|
|
},
|
|
|
|
|
|
|
|
setFloat4: function (uniformName, x, y, z, w)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-07 18:50:44 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-07 18:50:44 +00:00
|
|
|
|
|
|
|
dstShader.setConstantFloat4(this.getUniformLocation(uniformName), x, y, z, w);
|
2017-04-10 15:05:56 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
setInt: function (uniformName, x)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantInt1(this.getUniformLocation(uniformName), x);
|
|
|
|
},
|
|
|
|
|
|
|
|
setInt2: function (uniformName, x, y)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantInt2(this.getUniformLocation(uniformName), x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
setInt3: function (uniformName, x, y, z)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantInt3(this.getUniformLocation(uniformName), x, y, z);
|
|
|
|
},
|
|
|
|
|
|
|
|
setInt4: function (uniformName, x, y, z, w)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantInt4(this.getUniformLocation(uniformName), x, y, z, w);
|
|
|
|
},
|
|
|
|
|
|
|
|
setMatrix2x2: function (uniformName, matrix)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantMatrix2x2(this.getUniformLocation(uniformName), matrix);
|
|
|
|
},
|
|
|
|
|
|
|
|
setMatrix3x3: function (uniformName, matrix)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantMatrix3x3(this.getUniformLocation(uniformName), matrix);
|
|
|
|
},
|
|
|
|
|
|
|
|
setMatrix4x4: function (uniformName, matrix)
|
|
|
|
{
|
|
|
|
var dstShader = this.dstShader;
|
|
|
|
|
|
|
|
if (dstShader === null)
|
2017-04-12 23:05:12 +00:00
|
|
|
{
|
2017-04-10 15:05:56 +00:00
|
|
|
return;
|
2017-04-12 23:05:12 +00:00
|
|
|
}
|
2017-04-10 15:05:56 +00:00
|
|
|
|
|
|
|
dstShader.setConstantMatrix4x4(this.getUniformLocation(uniformName), matrix);
|
2017-04-07 01:49:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = EffectLayer;
|