diff --git a/README.md b/README.md index 11a3493ea..975a82a02 100644 --- a/README.md +++ b/README.md @@ -12,9 +12,9 @@ It's easy to use, configurable for high-quality graphics. Benefit from the modul #### [Download](https://github.com/pissang/claygl/releases) -#### [API](http://docs.claygl.com/api) +#### [API](http://docs.claygl.xyz/api) -#### [Examples](http://examples.claygl.com) +#### [Examples](http://examples.claygl.xyz) ## Projects diff --git a/dist/claygl.es.js b/dist/claygl.es.js index 4d154ea91..798bed959 100644 --- a/dist/claygl.es.js +++ b/dist/claygl.es.js @@ -593,9 +593,6 @@ Clip.prototype = { }; Clip.prototype.constructor = Clip; -/** - * @module echarts/animation/Animator - */ var arraySlice = Array.prototype.slice; function defaultGetter(target, key) { @@ -615,7 +612,8 @@ function interpolateArray(p0, p1, percent, out, arrDim) { for (var i = 0; i < len; i++) { out[i] = interpolateNumber(p0[i], p1[i], percent); } - } else { + } + else { var len2 = p0[0].length; for (var i = 0; i < len; i++) { for (var j = 0; j < len2; j++) { @@ -752,10 +750,10 @@ function isArraySame(arr0, arr1, arrDim) { return true; } -function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, interpolater) { +function createTrackClip(animator, globalEasing, oneTrackDone, keyframes, propName, interpolater, maxTime) { var getter = animator._getter; var setter = animator._setter; - var useSpline = easing === 'spline'; + var useSpline = globalEasing === 'spline'; var trackLen = keyframes.length; if (!trackLen) { @@ -776,16 +774,17 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in return a.time - b.time; }); - var trackMaxTime = keyframes[trackLen - 1].time; // Percents of each keyframe var kfPercents = []; // Value of each keyframe var kfValues = []; + // Easing funcs of each keyframe. + var kfEasings = []; var prevValue = keyframes[0].value; var isAllValueEqual = true; for (var i = 0; i < trackLen; i++) { - kfPercents.push(keyframes[i].time / trackMaxTime); + kfPercents.push(keyframes[i].time / maxTime); // Assume value is a color when it is a string var value = keyframes[i].value; @@ -798,6 +797,7 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in prevValue = value; kfValues.push(value); + kfEasings.push(keyframes[i].easing); } if (isAllValueEqual) { return; @@ -828,7 +828,7 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in var onframe = function(target, percent) { // Find the range keyframes // kf1-----kf2---------current--------kf3 - // find kf2(i) and kf3(i+1) and do interpolation + // find kf2(i) and kf3(i + 1) and do interpolation if (percent < cachePercent) { // Start from next key start = Math.min(cacheKey + 1, trackLen - 1); @@ -837,24 +837,30 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in break; } } - i = Math.min(i, trackLen-2); - } else { + i = Math.min(i, trackLen - 2); + } + else { for (i = cacheKey; i < trackLen; i++) { if (kfPercents[i] > percent) { break; } } - i = Math.min(i-1, trackLen-2); + i = Math.min(i - 1, trackLen - 2); } cacheKey = i; cachePercent = percent; - var range = (kfPercents[i+1] - kfPercents[i]); + var range = (kfPercents[i + 1] - kfPercents[i]); if (range === 0) { return; - } else { + } + else { w = (percent - kfPercents[i]) / range; + // Clamp 0 - 1 + w = Math.max(Math.min(1, w), 0); } + w = kfEasings[i + 1](w); + if (useSpline) { p1 = kfValues[i]; p0 = kfValues[i === 0 ? i : i - 1]; @@ -869,20 +875,23 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in p0, p1, p2, p3, w ) ); - } else if (isValueArray) { + } + else if (isValueArray) { catmullRomInterpolateArray( p0, p1, p2, p3, w, w*w, w*w*w, getter(target, propName), arrDim ); - } else { + } + else { setter( target, propName, catmullRomInterpolate(p0, p1, p2, p3, w, w*w, w*w*w) ); } - } else { + } + else { if (interpolater) { setter( target, @@ -895,13 +904,15 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in ) ); } + else if (isValueArray) { interpolateArray( kfValues[i], kfValues[i+1], w, getter(target, propName), arrDim ); - } else { + } + else { setter( target, propName, @@ -913,15 +924,15 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in var clip = new Clip({ target: animator._target, - life: trackMaxTime, + life: maxTime, loop: animator._loop, delay: animator._delay, onframe: onframe, onfinish: oneTrackDone }); - if (easing && easing !== 'spline') { - clip.setEasing(easing); + if (globalEasing && globalEasing !== 'spline') { + clip.setEasing(globalEasing); } return clip; @@ -958,6 +969,14 @@ function Animator(target, loop, getter, setter, interpolater) { this._onframeList = []; this._clipList = []; + + this._maxTime = 0; + + this._lastKFTime = 0; +} + +function noopEasing(w) { + return w; } Animator.prototype = { @@ -965,12 +984,17 @@ Animator.prototype = { constructor: Animator, /** - * @param {number} time Keyframe time using millisecond - * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {number} time Keyframe time using millisecond + * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {string|Function} [easing] * @return {clay.animation.Animator} * @memberOf clay.animation.Animator.prototype */ - when: function (time, props) { + when: function (time, props, easing$$1) { + + this._maxTime = Math.max(time, this._maxTime); + + easing$$1 = (typeof easing$$1 === 'function' ? easing$$1 : easing[easing$$1]) || noopEasing; for (var propName in props) { if (!this._tracks[propName]) { this._tracks[propName] = []; @@ -983,17 +1007,31 @@ Animator.prototype = { time: 0, value: cloneValue( this._getter(this._target, propName) - ) + ), + easing: easing$$1 }); } } this._tracks[propName].push({ time: parseInt(time), - value: props[propName] + value: props[propName], + easing: easing$$1 }); } return this; }, + /** + * @param {number} time Keyframe elapsed time since last keyframe + * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {string|Function} [easing] + * @return {clay.animation.Animator} + * @memberOf clay.animation.Animator.prototype + */ + then: function (duringTime, props, easing$$1) { + this.when(duringTime + this._lastKFTime, props, easing$$1); + this._lastKFTime += duringTime; + return this; + }, /** * callback when running animation * @param {Function} callback callback have two args, animating target and current percent @@ -1023,7 +1061,7 @@ Animator.prototype = { * @return {clay.animation.Animator} * @memberOf clay.animation.Animator.prototype */ - start: function (easing) { + start: function (globalEasing) { var self = this; var clipCount = 0; @@ -1038,8 +1076,8 @@ Animator.prototype = { var lastClip; for (var propName in this._tracks) { var clip = createTrackClip( - this, easing, oneTrackDone, - this._tracks[propName], propName, self._interpolater + this, globalEasing, oneTrackDone, + this._tracks[propName], propName, self._interpolater, self._maxTime ); if (clip) { this._clipList.push(clip); @@ -11008,6 +11046,11 @@ var Texture = Base.extend( * @default true */ flipY: true, + + /** + * A flag to indicate if texture source is sRGB + */ + sRGB: true, /** * @type {number} * @default 4 @@ -11646,6 +11689,9 @@ LRU$1.prototype.clear = function() { this._map = {}; }; +/** + * @namespace clay.core.color + */ var colorUtil = {}; var kCSSColorTable = { @@ -11798,10 +11844,10 @@ function putToCache(colorStr, rgbaArr) { } /** + * @name clay.core.color.parse * @param {string} colorStr * @param {Array.} out * @return {Array.} - * @memberOf module:zrender/util/color */ colorUtil.parse = function (colorStr, rgbaArr) { if (!colorStr) { @@ -11925,6 +11971,7 @@ colorUtil.parseToFloat = function (colorStr, rgbaArr) { }; /** + * @name clay.core.color.hsla2rgba * @param {Array.} hsla * @param {Array.} rgba * @return {Array.} rgba @@ -11954,6 +12001,7 @@ function hsla2rgba(hsla, rgba) { } /** + * @name clay.core.color.rgba2hsla * @param {Array.} rgba * @return {Array.} hsla */ @@ -12020,10 +12068,10 @@ function rgba2hsla(rgba) { } /** + * @name clay.core.color.lift * @param {string} color * @param {number} level * @return {string} - * @memberOf module:zrender/util/color */ colorUtil.lift = function (color, level) { var colorArr = colorUtil.parse(color); @@ -12041,9 +12089,9 @@ colorUtil.lift = function (color, level) { }; /** + * @name clay.core.color.toHex * @param {string} color * @return {string} - * @memberOf module:zrender/util/color */ colorUtil.toHex = function (color) { var colorArr = colorUtil.parse(color); @@ -12054,6 +12102,7 @@ colorUtil.toHex = function (color) { /** * Map value to color. Faster than lerp methods because color is represented by rgba array. + * @name clay.core.color * @param {number} normalizedValue A float between 0 and 1. * @param {Array.>} colors List of rgba color array * @param {Array.} [out] Mapped gba color array @@ -12082,9 +12131,6 @@ colorUtil.fastLerp = function (normalizedValue, colors, out) { return out; }; -/** - * @deprecated - */ colorUtil.fastMapToColor = colorUtil.fastLerp; /** @@ -12093,7 +12139,6 @@ colorUtil.fastMapToColor = colorUtil.fastLerp; * @param {boolean=} fullOutput Default false. * @return {(string|Object)} Result color. If fullOutput, * return {color: ..., leftIndex: ..., rightIndex: ..., value: ...}, - * @memberOf module:zrender/util/color */ colorUtil.lerp = function (normalizedValue, colors, fullOutput) { if (!(colors && colors.length) @@ -12135,12 +12180,12 @@ colorUtil.lerp = function (normalizedValue, colors, fullOutput) { colorUtil.mapToColor = colorUtil.lerp; /** + * @name clay.core.color * @param {string} color * @param {number=} h 0 ~ 360, ignore when null. * @param {number=} s 0 ~ 1, ignore when null. * @param {number=} l 0 ~ 1, ignore when null. * @return {string} Color string in rgba format. - * @memberOf module:zrender/util/color */ colorUtil.modifyHSL = function (color, h, s, l) { color = colorUtil.parse(color); @@ -12159,7 +12204,6 @@ colorUtil.modifyHSL = function (color, h, s, l) { * @param {string} color * @param {number=} alpha 0 ~ 1 * @return {string} Color string in rgba format. - * @memberOf module:zrender/util/color */ colorUtil.modifyAlpha = function (color, alpha) { color = colorUtil.parse(color); @@ -14296,7 +14340,6 @@ var Renderer = Base.extend(function () { } // Render opaque list - scene.trigger('beforerender:opaque', this, opaqueList); var opaqueRenderInfo = this.renderPass(opaqueList, camera, { getMaterial: function (renderable) { return sceneMaterial || renderable.material; @@ -14304,9 +14347,6 @@ var Renderer = Base.extend(function () { sortCompare: this.opaqueSortCompare }); - scene.trigger('afterrender:opaque', this, opaqueList, opaqueRenderInfo); - scene.trigger('beforerender:transparent', this, transparentList); - var transparentRenderInfo = this.renderPass(transparentList, camera, { getMaterial: function (renderable) { return sceneMaterial || renderable.material; @@ -14314,7 +14354,6 @@ var Renderer = Base.extend(function () { sortCompare: this.transparentSortCompare }); - scene.trigger('afterrender:transparent', this, transparentList, transparentRenderInfo); var renderInfo = {}; for (var name in opaqueRenderInfo) { renderInfo[name] = opaqueRenderInfo[name] + transparentRenderInfo[name]; @@ -14417,6 +14456,8 @@ var Renderer = Base.extend(function () { * @return {IRenderInfo} */ renderPass: function(list, camera, passConfig) { + this.trigger('beforerenderpass', this, list, camera, passConfig); + var renderInfo = { triangleCount: 0, vertexCount: 0, @@ -14607,6 +14648,8 @@ var Renderer = Base.extend(function () { list[i].__program = null; } + this.trigger('afterrenderpass', this, list, camera, passConfig); + return renderInfo; }, @@ -19013,6 +19056,104 @@ var Sphere$1 = Geometry.extend( } }); +/** + * @constructor clay.geometry.ParametricSurface + * @extends clay.Geometry + * @param {Object} [opt] + * @param {Object} [generator] + * @param {Function} generator.x + * @param {Function} generator.y + * @param {Function} generator.z + * @param {Array} [generator.u=[0, 1, 0.05]] + * @param {Array} [generator.v=[0, 1, 0.05]] + */ +var ParametricSurface$1 = Geometry.extend( +/** @lends clay.geometry.ParametricSurface# */ +{ + dynamic: false, + /** + * @type {Object} + */ + generator: null + +}, function() { + this.build(); +}, +/** @lends clay.geometry.ParametricSurface.prototype */ +{ + /** + * Build parametric surface geometry + */ + build: function () { + var generator = this.generator; + + if (!generator || !generator.x || !generator.y || !generator.z) { + throw new Error('Invalid generator'); + } + var xFunc = generator.x; + var yFunc = generator.y; + var zFunc = generator.z; + var uRange = generator.u || [0, 1, 0.05]; + var vRange = generator.v || [0, 1, 0.05]; + + var uNum = Math.floor((uRange[1] - uRange[0] + uRange[2]) / uRange[2]); + var vNum = Math.floor((vRange[1] - vRange[0] + vRange[2]) / vRange[2]); + + if (!isFinite(uNum) || !isFinite(vNum)) { + throw new Error('Infinite generator'); + } + + var vertexNum = uNum * vNum; + this.attributes.position.init(vertexNum); + this.attributes.texcoord0.init(vertexNum); + + var pos = []; + var texcoord = []; + var nVertex = 0; + for (var j = 0; j < vNum; j++) { + for (var i = 0; i < uNum; i++) { + var u = i * uRange[2] + uRange[0]; + var v = j * vRange[2] + vRange[0]; + pos[0] = xFunc(u, v); + pos[1] = yFunc(u, v); + pos[2] = zFunc(u, v); + + texcoord[0] = i / (uNum - 1); + texcoord[1] = j / (vNum - 1); + + this.attributes.position.set(nVertex, pos); + this.attributes.texcoord0.set(nVertex, texcoord); + nVertex++; + } + } + + var IndicesCtor = vertexNum > 0xffff ? Uint32Array : Uint16Array; + var nIndices = (uNum - 1) * (vNum - 1) * 6; + var indices = this.indices = new IndicesCtor(nIndices); + + var n = 0; + for (var j = 0; j < vNum - 1; j++) { + for (var i = 0; i < uNum - 1; i++) { + var i2 = j * uNum + i; + var i1 = (j * uNum + i + 1); + var i4 = (j + 1) * uNum + i + 1; + var i3 = (j + 1) * uNum + i; + + indices[n++] = i1; + indices[n++] = i2; + indices[n++] = i4; + + indices[n++] = i2; + indices[n++] = i3; + indices[n++] = i4; + } + } + + this.generateVertexNormals(); + this.updateBoundingBox(); + } +}); + var mathUtil = {}; mathUtil.isPowerOfTwo = function (value) { @@ -19258,6 +19399,271 @@ Object.defineProperty(Texture2D.prototype, 'height', { } }); +var isPowerOfTwo$1 = mathUtil.isPowerOfTwo; + +var targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; + +/** + * @constructor clay.TextureCube + * @extends clay.Texture + * + * @example + * ... + * var mat = new clay.Material({ + * shader: clay.shader.library.get('clay.phong', 'environmentMap') + * }); + * var envMap = new clay.TextureCube(); + * envMap.load({ + * 'px': 'assets/textures/sky/px.jpg', + * 'nx': 'assets/textures/sky/nx.jpg' + * 'py': 'assets/textures/sky/py.jpg' + * 'ny': 'assets/textures/sky/ny.jpg' + * 'pz': 'assets/textures/sky/pz.jpg' + * 'nz': 'assets/textures/sky/nz.jpg' + * }); + * mat.set('environmentMap', envMap); + * ... + * envMap.success(function () { + * // Wait for the sky texture loaded + * animation.on('frame', function (frameTime) { + * renderer.render(scene, camera); + * }); + * }); + */ +var TextureCube = Texture.extend(function () { + return /** @lends clay.TextureCube# */{ + + /** + * @type {boolean} + * @default false + */ + // PENDING cubemap should not flipY in default. + // flipY: false, + + /** + * @type {Object} + * @property {?HTMLImageElement|HTMLCanvasElemnet} px + * @property {?HTMLImageElement|HTMLCanvasElemnet} nx + * @property {?HTMLImageElement|HTMLCanvasElemnet} py + * @property {?HTMLImageElement|HTMLCanvasElemnet} ny + * @property {?HTMLImageElement|HTMLCanvasElemnet} pz + * @property {?HTMLImageElement|HTMLCanvasElemnet} nz + */ + image: { + px: null, + nx: null, + py: null, + ny: null, + pz: null, + nz: null + }, + /** + * Pixels data of each side. Will be ignored if images are set. + * @type {Object} + * @property {?Uint8Array} px + * @property {?Uint8Array} nx + * @property {?Uint8Array} py + * @property {?Uint8Array} ny + * @property {?Uint8Array} pz + * @property {?Uint8Array} nz + */ + pixels: { + px: null, + nx: null, + py: null, + ny: null, + pz: null, + nz: null + }, + + /** + * @type {Array.} + */ + mipmaps: [] + }; +}, { + update: function (renderer) { + var _gl = renderer.gl; + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); + + this.updateCommon(renderer); + + var glFormat = this.format; + var glType = this.type; + + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS()); + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT()); + + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter()); + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter()); + + var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic'); + if (anisotropicExt && this.anisotropic > 1) { + _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic); + } + + // Fallback to float type if browser don't have half float extension + if (glType === 36193) { + var halfFloatExt = renderer.getGLExtension('OES_texture_half_float'); + if (!halfFloatExt) { + glType = glenum.FLOAT; + } + } + + if (this.mipmaps.length) { + var width = this.width; + var height = this.height; + for (var i = 0; i < this.mipmaps.length; i++) { + var mipmap = this.mipmaps[i]; + this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType); + width /= 2; + height /= 2; + } + } + else { + this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType); + + if (!this.NPOT && this.useMipmap) { + _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); + } + } + + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null); + }, + + _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) { + for (var i = 0; i < 6; i++) { + var target = targetList[i]; + var img = data.image && data.image[target]; + if (img) { + _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img); + } + else { + _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]); + } + } + }, + + /** + * @param {clay.Renderer} renderer + * @memberOf clay.TextureCube.prototype + */ + generateMipmap: function (renderer) { + var _gl = renderer.gl; + if (this.useMipmap && !this.NPOT) { + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); + _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); + } + }, + + bind: function (renderer) { + renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer)); + }, + + unbind: function (renderer) { + renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null); + }, + + // Overwrite the isPowerOfTwo method + isPowerOfTwo: function () { + if (this.image.px) { + return isPowerOfTwo$1(this.image.px.width) + && isPowerOfTwo$1(this.image.px.height); + } + else { + return isPowerOfTwo$1(this.width) + && isPowerOfTwo$1(this.height); + } + }, + + isRenderable: function () { + if (this.image.px) { + return isImageRenderable(this.image.px) + && isImageRenderable(this.image.nx) + && isImageRenderable(this.image.py) + && isImageRenderable(this.image.ny) + && isImageRenderable(this.image.pz) + && isImageRenderable(this.image.nz); + } + else { + return !!(this.width && this.height); + } + }, + + load: function (imageList, crossOrigin) { + var loading = 0; + var self = this; + util$1.each(imageList, function (src, target){ + var image = new Image(); + if (crossOrigin) { + image.crossOrigin = crossOrigin; + } + image.onload = function () { + loading --; + if (loading === 0){ + self.dirty(); + self.trigger('success', self); + } + image.onload = null; + }; + image.onerror = function () { + loading --; + image.onerror = null; + }; + + loading++; + image.src = src; + self.image[target] = image; + }); + + return this; + } +}); + +Object.defineProperty(TextureCube.prototype, 'width', { + get: function () { + if (this.image && this.image.px) { + return this.image.px.width; + } + return this._width; + }, + set: function (value) { + if (this.image && this.image.px) { + console.warn('Texture from image can\'t set width'); + } + else { + if (this._width !== value) { + this.dirty(); + } + this._width = value; + } + } +}); +Object.defineProperty(TextureCube.prototype, 'height', { + get: function () { + if (this.image && this.image.px) { + return this.image.px.height; + } + return this._height; + }, + set: function (value) { + if (this.image && this.image.px) { + console.warn('Texture from image can\'t set height'); + } + else { + if (this._height !== value) { + this.dirty(); + } + this._height = value; + } + } +}); +function isImageRenderable(image) { + return image.nodeName === 'CANVAS' || + image.nodeName === 'VIDEO' || + image.complete; +} + var _library = {}; function ShaderLibrary () { @@ -20044,7 +20450,7 @@ var request = { get : get }; -var standardEssl = "\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n#ifdef GAMMA_ENCODE\n outColor.rgb = pow(outColor.rgb, vec3(1 / 2.2));\n#endif\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end"; +var standardEssl = "\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end"; // Import standard shader Shader['import'](standardEssl); @@ -20662,13 +21068,13 @@ var Skeleton = Base.extend(function () { var utilGlsl = "\n@export clay.util.rand\nhighp float rand(vec2 uv) {\n const highp float a = 12.9898, b = 78.233, c = 43758.5453;\n highp float dt = dot(uv.xy, vec2(a,b)), sn = mod(dt, 3.141592653589793);\n return fract(sin(sn) * c);\n}\n@end\n@export clay.util.calculate_attenuation\nuniform float attenuationFactor : 5.0;\nfloat lightAttenuation(float dist, float range)\n{\n float attenuation = 1.0;\n attenuation = dist*dist/(range*range+1.0);\n float att_s = attenuationFactor;\n attenuation = 1.0/(attenuation*att_s+1.0);\n att_s = 1.0/(att_s+1.0);\n attenuation = attenuation - att_s;\n attenuation /= 1.0 - att_s;\n return clamp(attenuation, 0.0, 1.0);\n}\n@end\n@export clay.util.edge_factor\nfloat edgeFactor(float width)\n{\n vec3 d = fwidth(v_Barycentric);\n vec3 a3 = smoothstep(vec3(0.0), d * width, v_Barycentric);\n return min(min(a3.x, a3.y), a3.z);\n}\n@end\n@export clay.util.encode_float\nvec4 encodeFloat(const in float depth)\n{\n const vec4 bitShifts = vec4(256.0*256.0*256.0, 256.0*256.0, 256.0, 1.0);\n const vec4 bit_mask = vec4(0.0, 1.0/256.0, 1.0/256.0, 1.0/256.0);\n vec4 res = fract(depth * bitShifts);\n res -= res.xxyz * bit_mask;\n return res;\n}\n@end\n@export clay.util.decode_float\nfloat decodeFloat(const in vec4 color)\n{\n const vec4 bitShifts = vec4(1.0/(256.0*256.0*256.0), 1.0/(256.0*256.0), 1.0/256.0, 1.0);\n return dot(color, bitShifts);\n}\n@end\n@export clay.util.float\n@import clay.util.encode_float\n@import clay.util.decode_float\n@end\n@export clay.util.rgbm_decode\nvec3 RGBMDecode(vec4 rgbm, float range) {\n return range * rgbm.rgb * rgbm.a;\n}\n@end\n@export clay.util.rgbm_encode\nvec4 RGBMEncode(vec3 color, float range) {\n if (dot(color, color) == 0.0) {\n return vec4(0.0);\n }\n vec4 rgbm;\n color /= range;\n rgbm.a = clamp(max(max(color.r, color.g), max(color.b, 1e-6)), 0.0, 1.0);\n rgbm.a = ceil(rgbm.a * 255.0) / 255.0;\n rgbm.rgb = color / rgbm.a;\n return rgbm;\n}\n@end\n@export clay.util.rgbm\n@import clay.util.rgbm_decode\n@import clay.util.rgbm_encode\nvec4 decodeHDR(vec4 color)\n{\n#if defined(RGBM_DECODE) || defined(RGBM)\n return vec4(RGBMDecode(color, 51.5), 1.0);\n#else\n return color;\n#endif\n}\nvec4 encodeHDR(vec4 color)\n{\n#if defined(RGBM_ENCODE) || defined(RGBM)\n return RGBMEncode(color.xyz, 51.5);\n#else\n return color;\n#endif\n}\n@end\n@export clay.util.srgb\nvec4 sRGBToLinear(in vec4 value) {\n return vec4(mix(pow(value.rgb * 0.9478672986 + vec3(0.0521327014), vec3(2.4)), value.rgb * 0.0773993808, vec3(lessThanEqual(value.rgb, vec3(0.04045)))), value.w);\n}\nvec4 linearTosRGB(in vec4 value) {\n return vec4(mix(pow(value.rgb, vec3(0.41666)) * 1.055 - vec3(0.055), value.rgb * 12.92, vec3(lessThanEqual(value.rgb, vec3(0.0031308)))), value.w);\n}\n@end\n@export clay.chunk.skinning_header\n#ifdef SKINNING\nattribute vec3 weight : WEIGHT;\nattribute vec4 joint : JOINT;\nuniform mat4 skinMatrix[JOINT_COUNT] : SKIN_MATRIX;\nmat4 getSkinMatrix(float idx) {\n return skinMatrix[int(idx)];\n}\n#endif\n@end\n@export clay.chunk.skin_matrix\nmat4 skinMatrixWS = getSkinMatrix(joint.x) * weight.x;\nif (weight.y > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.y) * weight.y;\n}\nif (weight.z > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.z) * weight.z;\n}\nfloat weightW = 1.0-weight.x-weight.y-weight.z;\nif (weightW > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.w) * weightW;\n}\n@end\n@export clay.util.parallax_correct\nvec3 parallaxCorrect(in vec3 dir, in vec3 pos, in vec3 boxMin, in vec3 boxMax) {\n vec3 first = (boxMax - pos) / dir;\n vec3 second = (boxMin - pos) / dir;\n vec3 further = max(first, second);\n float dist = min(further.x, min(further.y, further.z));\n vec3 fixedPos = pos + dir * dist;\n vec3 boxCenter = (boxMax + boxMin) * 0.5;\n return normalize(fixedPos - boxCenter);\n}\n@end\n@export clay.util.clamp_sample\nvec4 clampSample(const in sampler2D texture, const in vec2 coord)\n{\n#ifdef STEREO\n float eye = step(0.5, coord.x) * 0.5;\n vec2 coordClamped = clamp(coord, vec2(eye, 0.0), vec2(0.5 + eye, 1.0));\n#else\n vec2 coordClamped = clamp(coord, vec2(0.0), vec2(1.0));\n#endif\n return texture2D(texture, coordClamped);\n}\n@end\n@export clay.util.ACES\nvec3 ACESToneMapping(vec3 color)\n{\n const float A = 2.51;\n const float B = 0.03;\n const float C = 2.43;\n const float D = 0.59;\n const float E = 0.14;\n return (color * (A * color + B)) / (color * (C * color + D) + E);\n}\n@end"; -var basicEssl = "@export clay.basic.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Barycentric = barycentric;\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.basic.fragment\nvarying vec2 v_Texcoord;\nuniform sampler2D diffuseMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\n#ifdef SRGB_DECODE\n tex = sRGBToLinear(tex);\n#endif\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\n gl_FragColor.a = tex.a;\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#endif\n gl_FragColor.rgb += emission;\n if( lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef GAMMA_ENCODE\n gl_FragColor.rgb = pow(gl_FragColor.rgb, vec3(1 / 2.2));\n#endif\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; +var basicEssl = "@export clay.basic.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Barycentric = barycentric;\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.basic.fragment\nvarying vec2 v_Texcoord;\nuniform sampler2D diffuseMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\n#ifdef SRGB_DECODE\n tex = sRGBToLinear(tex);\n#endif\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\n gl_FragColor.a = tex.a;\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#endif\n gl_FragColor.rgb += emission;\n if( lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; var lambertEssl = "\n@export clay.lambert.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 normal : NORMAL;\nattribute vec3 barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4( skinnedPosition, 1.0 );\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Normal = normalize( ( worldInverseTranspose * vec4(skinnedNormal, 0.0) ).xyz );\n v_WorldPosition = ( world * vec4( skinnedPosition, 1.0) ).xyz;\n v_Barycentric = barycentric;\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.lambert.fragment\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D diffuseMap;\nuniform sampler2D alphaMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.plugin.compute_shadow_map\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_NORMAL\n gl_FragColor = vec4(v_Normal * 0.5 + 0.5, 1.0);\n return;\n#endif\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = texture2D( diffuseMap, v_Texcoord );\n#ifdef SRGB_DECODE\n tex.rgb = pow(tex.rgb, vec3(2.2));\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#ifdef DIFFUSEMAP_ALPHA_ALPHA\n gl_FragColor.a *= tex.a;\n#endif\n#endif\n vec3 diffuseColor = vec3(0.0, 0.0, 0.0);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {\n diffuseColor += ambientLightColor[_idx_];\n }\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseColor += calcAmbientSHLight(_idx_, v_Normal) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if( shadowEnabled )\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int i = 0; i < POINT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = pointLightPosition[i];\n vec3 lightColor = pointLightColor[i];\n float range = pointLightRange[i];\n vec3 lightDirection = lightPosition - v_WorldPosition;\n float dist = length(lightDirection);\n float attenuation = lightAttenuation(dist, range);\n lightDirection /= dist;\n float ndl = dot( v_Normal, lightDirection );\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsPoint[i];\n }\n#endif\n diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * attenuation * shadowContrib;\n }\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int i = 0; i < DIRECTIONAL_LIGHT_COUNT; i++)\n {\n vec3 lightDirection = -directionalLightDirection[i];\n vec3 lightColor = directionalLightColor[i];\n float ndl = dot(v_Normal, normalize(lightDirection));\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsDir[i];\n }\n#endif\n diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * shadowContrib;\n }\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = -spotLightPosition[i];\n vec3 spotLightDirection = -normalize( spotLightDirection[i] );\n vec3 lightColor = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 lightDirection = lightPosition - v_WorldPosition;\n float dist = length(lightDirection);\n float attenuation = lightAttenuation(dist, range);\n lightDirection /= dist;\n float c = dot(spotLightDirection, lightDirection);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n float ndl = dot(v_Normal, lightDirection);\n ndl = clamp(ndl, 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n diffuseColor += lightColor * ndl * attenuation * (1.0-falloff) * shadowContrib;\n }\n#endif\n gl_FragColor.rgb *= diffuseColor;\n gl_FragColor.rgb += emission;\n if(lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; var wireframeEssl = "@export clay.wireframe.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 world : WORLD;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\n v_Barycentric = barycentric;\n}\n@end\n@export clay.wireframe.fragment\nuniform vec3 color : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\nuniform float lineWidth : 1.0;\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\nvoid main()\n{\n gl_FragColor.rgb = color;\n gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\n}\n@end"; -var skyboxEssl = "@export clay.skybox.vertex\nuniform mat4 world : WORLD;\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_WorldPosition;\nvoid main()\n{\n v_WorldPosition = (world * vec4(position, 1.0)).xyz;\n gl_Position = worldViewProjection * vec4(position, 1.0);\n}\n@end\n@export clay.skybox.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform samplerCube environmentMap;\nuniform float lod: 0.0;\nvarying vec3 v_WorldPosition;\n@import clay.util.rgbm\nvoid main()\n{\n vec3 eyePos = viewInverse[3].xyz;\n vec3 viewDirection = normalize(v_WorldPosition - eyePos);\n vec3 tex = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod)).rgb;\n#ifdef SRGB_DECODE\n tex.rgb = pow(tex.rgb, vec3(2.2));\n#endif\n gl_FragColor = encodeHDR(vec4(tex, 1.0));\n}\n@end"; +var skyboxEssl = "@export clay.skybox.vertex\nuniform mat4 world : WORLD;\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_WorldPosition;\nvoid main()\n{\n v_WorldPosition = (world * vec4(position, 1.0)).xyz;\n gl_Position = worldViewProjection * vec4(position, 1.0);\n}\n@end\n@export clay.skybox.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform samplerCube environmentMap;\nuniform float lod: 0.0;\nvarying vec3 v_WorldPosition;\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n vec3 eyePos = viewInverse[3].xyz;\n vec3 viewDirection = normalize(v_WorldPosition - eyePos);\n#ifdef LOD\n vec4 texel = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod));\n#else\n vec4 texel = decodeHDR(textureCube(environmentMap, viewDirection));\n#endif\n#ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n#endif\n#ifdef TONEMAPPING\n texel.rgb = ACESToneMapping(texel.rgb);\n#endif\n#ifdef SRGB_ENCODE\n texel = linearTosRGB(texel);\n#endif\n gl_FragColor = encodeHDR(vec4(texel.rgb, 1.0));\n}\n@end"; var coloradjustEssl = "@export clay.compositor.coloradjust\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float exposure : 0.0;\nuniform float gamma : 1.0;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\n color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\n color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\n float luminance = dot( color, w );\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.brightness\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = tex.rgb + vec3(brightness);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.contrast\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float contrast : 1.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.exposure\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float exposure : 0.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb * pow(2.0, exposure);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.gamma\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float gamma : 1.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = pow(tex.rgb, vec3(gamma));\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.saturation\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb;\n float luminance = dot(color, w);\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end"; @@ -21050,7 +21456,7 @@ function () { textures: lib.textures, materials: lib.materials, skeletons: lib.skeletons, - meshes: lib.meshes, + meshes: lib.instancedMeshes, clips: lib.clips, nodes: lib.nodes }; @@ -21419,6 +21825,7 @@ function () { metalness: metallicRoughnessMatInfo.metallicFactor || 0, roughness: metallicRoughnessMatInfo.roughnessFactor || 0, emission: materialInfo.emissiveFactor || [0, 0, 0], + emissionIntensity: 1, alphaCutoff: materialInfo.alphaCutoff || 0 }; if (commonProperties.roughnessMap) { @@ -21509,6 +21916,7 @@ function () { specularColor: specularGlossinessMatInfo.specularFactor || [1, 1, 1], glossiness: specularGlossinessMatInfo.glossinessFactor || 0, emission: materialInfo.emissiveFactor || [0, 0, 0], + emissionIntensity: 1, alphaCutoff: materialInfo.alphaCutoff == null ? 0.9 : materialInfo.alphaCutoff }; if (commonProperties.glossinessMap) { @@ -21719,6 +22127,8 @@ function () { }); } + lib.instancedMeshes = []; + util$1.each(json.nodes, function (nodeInfo, idx) { var node; if (nodeInfo.camera != null && this.includeCamera) { @@ -21732,12 +22142,15 @@ function () { // Replace the node with mesh directly node = instanceMesh(primitives[0]); node.setName(nodeInfo.name); + lib.instancedMeshes.push(node); } else { node = new Node(); node.setName(nodeInfo.name); for (var j = 0; j < primitives.length; j++) { - node.add(instanceMesh(primitives[j])); + var newMesh = instanceMesh(primitives[j]); + node.add(newMesh); + lib.instancedMeshes.push(newMesh); } } } @@ -22118,263 +22531,6 @@ var AmbientLight = Light.extend({ */ }); -var isPowerOfTwo$1 = mathUtil.isPowerOfTwo; - -var targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; - -/** - * @constructor clay.TextureCube - * @extends clay.Texture - * - * @example - * ... - * var mat = new clay.Material({ - * shader: clay.shader.library.get('clay.phong', 'environmentMap') - * }); - * var envMap = new clay.TextureCube(); - * envMap.load({ - * 'px': 'assets/textures/sky/px.jpg', - * 'nx': 'assets/textures/sky/nx.jpg' - * 'py': 'assets/textures/sky/py.jpg' - * 'ny': 'assets/textures/sky/ny.jpg' - * 'pz': 'assets/textures/sky/pz.jpg' - * 'nz': 'assets/textures/sky/nz.jpg' - * }); - * mat.set('environmentMap', envMap); - * ... - * envMap.success(function () { - * // Wait for the sky texture loaded - * animation.on('frame', function (frameTime) { - * renderer.render(scene, camera); - * }); - * }); - */ -var TextureCube = Texture.extend(function () { - return /** @lends clay.TextureCube# */{ - /** - * @type {Object} - * @property {?HTMLImageElement|HTMLCanvasElemnet} px - * @property {?HTMLImageElement|HTMLCanvasElemnet} nx - * @property {?HTMLImageElement|HTMLCanvasElemnet} py - * @property {?HTMLImageElement|HTMLCanvasElemnet} ny - * @property {?HTMLImageElement|HTMLCanvasElemnet} pz - * @property {?HTMLImageElement|HTMLCanvasElemnet} nz - */ - image: { - px: null, - nx: null, - py: null, - ny: null, - pz: null, - nz: null - }, - /** - * Pixels data of each side. Will be ignored if images are set. - * @type {Object} - * @property {?Uint8Array} px - * @property {?Uint8Array} nx - * @property {?Uint8Array} py - * @property {?Uint8Array} ny - * @property {?Uint8Array} pz - * @property {?Uint8Array} nz - */ - pixels: { - px: null, - nx: null, - py: null, - ny: null, - pz: null, - nz: null - }, - - /** - * @type {Array.} - */ - mipmaps: [] - }; -}, { - update: function (renderer) { - var _gl = renderer.gl; - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); - - this.updateCommon(renderer); - - var glFormat = this.format; - var glType = this.type; - - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS()); - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT()); - - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter()); - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter()); - - var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic'); - if (anisotropicExt && this.anisotropic > 1) { - _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic); - } - - // Fallback to float type if browser don't have half float extension - if (glType === 36193) { - var halfFloatExt = renderer.getGLExtension('OES_texture_half_float'); - if (!halfFloatExt) { - glType = glenum.FLOAT; - } - } - - if (this.mipmaps.length) { - var width = this.width; - var height = this.height; - for (var i = 0; i < this.mipmaps.length; i++) { - var mipmap = this.mipmaps[i]; - this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType); - width /= 2; - height /= 2; - } - } - else { - this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType); - - if (!this.NPOT && this.useMipmap) { - _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); - } - } - - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null); - }, - - _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) { - for (var i = 0; i < 6; i++) { - var target = targetList[i]; - var img = data.image && data.image[target]; - if (img) { - _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img); - } - else { - _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]); - } - } - }, - - /** - * @param {clay.Renderer} renderer - * @memberOf clay.TextureCube.prototype - */ - generateMipmap: function (renderer) { - var _gl = renderer.gl; - if (this.useMipmap && !this.NPOT) { - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); - _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); - } - }, - - bind: function (renderer) { - renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer)); - }, - - unbind: function (renderer) { - renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null); - }, - - // Overwrite the isPowerOfTwo method - isPowerOfTwo: function () { - if (this.image.px) { - return isPowerOfTwo$1(this.image.px.width) - && isPowerOfTwo$1(this.image.px.height); - } - else { - return isPowerOfTwo$1(this.width) - && isPowerOfTwo$1(this.height); - } - }, - - isRenderable: function () { - if (this.image.px) { - return isImageRenderable(this.image.px) - && isImageRenderable(this.image.nx) - && isImageRenderable(this.image.py) - && isImageRenderable(this.image.ny) - && isImageRenderable(this.image.pz) - && isImageRenderable(this.image.nz); - } - else { - return !!(this.width && this.height); - } - }, - - load: function (imageList, crossOrigin) { - var loading = 0; - var self = this; - util$1.each(imageList, function (src, target){ - var image = new Image(); - if (crossOrigin) { - image.crossOrigin = crossOrigin; - } - image.onload = function () { - loading --; - if (loading === 0){ - self.dirty(); - self.trigger('success', self); - } - image.onload = null; - }; - image.onerror = function () { - loading --; - image.onerror = null; - }; - - loading++; - image.src = src; - self.image[target] = image; - }); - - return this; - } -}); - -Object.defineProperty(TextureCube.prototype, 'width', { - get: function () { - if (this.image && this.image.px) { - return this.image.px.width; - } - return this._width; - }, - set: function (value) { - if (this.image && this.image.px) { - console.warn('Texture from image can\'t set width'); - } - else { - if (this._width !== value) { - this.dirty(); - } - this._width = value; - } - } -}); -Object.defineProperty(TextureCube.prototype, 'height', { - get: function () { - if (this.image && this.image.px) { - return this.image.px.height; - } - return this._height; - }, - set: function (value) { - if (this.image && this.image.px) { - console.warn('Texture from image can\'t set height'); - } - else { - if (this._height !== value) { - this.dirty(); - } - this._height = value; - } - } -}); -function isImageRenderable(image) { - return image.nodeName === 'CANVAS' || - image.nodeName === 'VIDEO' || - image.complete; -} - var KEY_FRAMEBUFFER = 'framebuffer'; var KEY_RENDERBUFFER = 'renderbuffer'; var KEY_RENDERBUFFER_WIDTH = KEY_RENDERBUFFER + '_width'; @@ -23019,6 +23175,8 @@ var Skybox = Mesh.extend(function () { if (this.scene) { this.detachScene(); } + scene.skybox = this; + this.scene = scene; scene.on('beforerender', this._beforeRenderScene, this); }, @@ -23028,6 +23186,7 @@ var Skybox = Mesh.extend(function () { detachScene: function () { if (this.scene) { this.scene.off('beforerender', this._beforeRenderScene); + this.scene.skybox = null; } this.scene = null; }, @@ -23064,6 +23223,12 @@ var Skybox = Mesh.extend(function () { this.update(); // Don't remember to disable blend renderer.gl.disable(renderer.gl.BLEND); + if (this.material.get('lod') > 0) { + this.material.define('fragment', 'LOD'); + } + else { + this.material.undefine('fragment', 'LOD'); + } renderer.renderPass([this], camera); } }); @@ -23265,6 +23430,8 @@ var Skydome = Mesh.extend(function () { if (this.scene) { this.detachScene(); } + scene.skydome = this; + this.scene = scene; scene.on('beforerender', this._beforeRenderScene, this); }, @@ -23275,6 +23442,7 @@ var Skydome = Mesh.extend(function () { detachScene: function () { if (this.scene) { this.scene.off('beforerender', this._beforeRenderScene); + this.scene.skydome = null; } this.scene = null; }, @@ -23610,7 +23778,8 @@ var textureUtil = { if (path.match(/.hdr$/) || option.fileType === 'hdr') { texture = new Texture2D({ width: 0, - height: 0 + height: 0, + sRGB: false }); textureUtil._fetchTexture( path, @@ -23706,6 +23875,9 @@ var textureUtil = { skydome.material.define('fragment', 'RGBM_ENCODE'); } + // Share sRGB + cubeMap.sRGB = panoramaMap.sRGB; + environmentMapPass.texture = cubeMap; environmentMapPass.render(renderer, skydome.scene); environmentMapPass.texture = null; @@ -25424,4499 +25596,4694 @@ RayPicking.Intersection = function (point, pointWorld, target, triangle, triangl this.distance = distance; }; -// Spherical Harmonic Helpers var vec3$15 = glmatrix.vec3; -var sh = {}; - -var targets$3 = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; +var vec2$1 = glmatrix.vec2; -function harmonics(normal, index){ - var x = normal[0]; - var y = normal[1]; - var z = normal[2]; +/** + * @constructor clay.geometry.Cone + * @extends clay.Geometry + * @param {Object} [opt] + * @param {number} [opt.topRadius] + * @param {number} [opt.bottomRadius] + * @param {number} [opt.height] + * @param {number} [opt.capSegments] + * @param {number} [opt.heightSegments] + */ +var Cone$1 = Geometry.extend( +/** @lends clay.geometry.Cone# */ +{ + dynamic: false, + /** + * @type {number} + */ + topRadius: 0, - if (index === 0) { - return 1.0; - } - else if (index === 1) { - return x; - } - else if (index === 2) { - return y; - } - else if (index === 3) { - return z; - } - else if (index === 4) { - return x * z; - } - else if (index === 5) { - return y * z; - } - else if (index === 6) { - return x * y; - } - else if (index === 7) { - return 3.0 * z * z - 1.0; - } - else { - return x * x - y * y; - } -} + /** + * @type {number} + */ + bottomRadius: 1, -var normalTransform = { - px: [2, 1, 0, -1, -1, 1], - nx: [2, 1, 0, 1, -1, -1], - py: [0, 2, 1, 1, -1, -1], - ny: [0, 2, 1, 1, 1, 1], - pz: [0, 1, 2, -1, -1, -1], - nz: [0, 1, 2, 1, -1, 1] -}; + /** + * @type {number} + */ + height: 2, -// Project on cpu. -function projectEnvironmentMapCPU(renderer, cubePixels, width, height) { - var coeff = new vendor.Float32Array(9 * 3); - var normal = vec3$15.create(); - var texel = vec3$15.create(); - var fetchNormal = vec3$15.create(); - for (var m = 0; m < 9; m++) { - var result = vec3$15.create(); - for (var k = 0; k < targets$3.length; k++) { - var pixels = cubePixels[targets$3[k]]; + /** + * @type {number} + */ + capSegments: 20, - var sideResult = vec3$15.create(); - var divider = 0; - var i = 0; - var transform = normalTransform[targets$3[k]]; - for (var y = 0; y < height; y++) { - for (var x = 0; x < width; x++) { + /** + * @type {number} + */ + heightSegments: 1 +}, function() { + this.build(); +}, +/** @lends clay.geometry.Cone.prototype */ +{ + /** + * Build cone geometry + */ + build: function() { + var positions = []; + var texcoords = []; + var faces = []; + positions.length = 0; + texcoords.length = 0; + faces.length = 0; + // Top cap + var capSegRadial = Math.PI * 2 / this.capSegments; - normal[0] = x / (width - 1.0) * 2.0 - 1.0; - // TODO Flip y? - normal[1] = y / (height - 1.0) * 2.0 - 1.0; - normal[2] = -1.0; - vec3$15.normalize(normal, normal); + var topCap = []; + var bottomCap = []; - fetchNormal[0] = normal[transform[0]] * transform[3]; - fetchNormal[1] = normal[transform[1]] * transform[4]; - fetchNormal[2] = normal[transform[2]] * transform[5]; + var r1 = this.topRadius; + var r2 = this.bottomRadius; + var y = this.height / 2; - texel[0] = pixels[i++] / 255; - texel[1] = pixels[i++] / 255; - texel[2] = pixels[i++] / 255; - // RGBM Decode - var scale = pixels[i++] / 255 * 51.5; - texel[0] *= scale; - texel[1] *= scale; - texel[2] *= scale; + var c1 = vec3$15.fromValues(0, y, 0); + var c2 = vec3$15.fromValues(0, -y, 0); + for (var i = 0; i < this.capSegments; i++) { + var theta = i * capSegRadial; + var x = r1 * Math.sin(theta); + var z = r1 * Math.cos(theta); + topCap.push(vec3$15.fromValues(x, y, z)); - vec3$15.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]); - // -normal.z equals cos(theta) of Lambertian - divider += -normal[2]; - } - } - vec3$15.scaleAndAdd(result, result, sideResult, 1 / divider); + x = r2 * Math.sin(theta); + z = r2 * Math.cos(theta); + bottomCap.push(vec3$15.fromValues(x, -y, z)); } - coeff[m * 3] = result[0] / 6.0; - coeff[m * 3 + 1] = result[1] / 6.0; - coeff[m * 3 + 2] = result[2] / 6.0; - } - return coeff; -} + // Build top cap + positions.push(c1); + // FIXME + texcoords.push(vec2$1.fromValues(0, 1)); + var n = this.capSegments; + for (var i = 0; i < n; i++) { + positions.push(topCap[i]); + // FIXME + texcoords.push(vec2$1.fromValues(i / n, 0)); + faces.push([0, i+1, (i+1) % n + 1]); + } -/** - * @param {clay.Renderer} renderer - * @param {clay.Texture} envMap - * @param {Object} [textureOpts] - * @param {Object} [textureOpts.lod] - * @param {boolean} [textureOpts.decodeRGBM] - */ -sh.projectEnvironmentMap = function (renderer, envMap, opts) { + // Build bottom cap + var offset = positions.length; + positions.push(c2); + texcoords.push(vec2$1.fromValues(0, 1)); + for (var i = 0; i < n; i++) { + positions.push(bottomCap[i]); + // FIXME + texcoords.push(vec2$1.fromValues(i / n, 0)); + faces.push([offset, offset+((i+1) % n + 1), offset+i+1]); + } - // TODO sRGB + // Build side + offset = positions.length; + var n2 = this.heightSegments; + for (var i = 0; i < n; i++) { + for (var j = 0; j < n2+1; j++) { + var v = j / n2; + positions.push(vec3$15.lerp(vec3$15.create(), topCap[i], bottomCap[i], v)); + texcoords.push(vec2$1.fromValues(i / n, v)); + } + } + for (var i = 0; i < n; i++) { + for (var j = 0; j < n2; j++) { + var i1 = i * (n2 + 1) + j; + var i2 = ((i + 1) % n) * (n2 + 1) + j; + var i3 = ((i + 1) % n) * (n2 + 1) + j + 1; + var i4 = i * (n2 + 1) + j + 1; + faces.push([offset+i2, offset+i1, offset+i4]); + faces.push([offset+i4, offset+i3, offset+i2]); + } + } - opts = opts || {}; - opts.lod = opts.lod || 0; + this.attributes.position.fromArray(positions); + this.attributes.texcoord0.fromArray(texcoords); - var skybox; - var dummyScene = new Scene(); - var size = 64; - if (envMap instanceof Texture2D) { - skybox = new Skydome({ - scene: dummyScene, - environmentMap: envMap - }); - } - else { - size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width; - skybox = new Skybox({ - scene: dummyScene, - environmentMap: envMap - }); - } - // Convert to rgbm - var width = Math.ceil(size / Math.pow(2, opts.lod)); - var height = Math.ceil(size / Math.pow(2, opts.lod)); - var rgbmTexture = new Texture2D({ - width: width, - height: height - }); - var framebuffer = new FrameBuffer(); - skybox.material.define('fragment', 'RGBM_ENCODE'); - if (opts.decodeRGBM) { - skybox.material.define('fragment', 'RGBM_DECODE'); - } - skybox.material.set('lod', opts.lod); - var envMapPass = new EnvironmentMapPass({ - texture: rgbmTexture - }); - var cubePixels = {}; - for (var i = 0; i < targets$3.length; i++) { - cubePixels[targets$3[i]] = new Uint8Array(width * height * 4); - var camera = envMapPass.getCamera(targets$3[i]); - camera.fov = 90; - framebuffer.attach(rgbmTexture); - framebuffer.bind(renderer); - renderer.render(dummyScene, camera); - renderer.gl.readPixels( - 0, 0, width, height, - Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets$3[i]] - ); - framebuffer.unbind(renderer); - } + this.initIndicesFromArray(faces); - skybox.dispose(renderer); - framebuffer.dispose(renderer); - rgbmTexture.dispose(renderer); + this.generateVertexNormals(); - return projectEnvironmentMapCPU(renderer, cubePixels, width, height); -}; + this.boundingBox = new BoundingBox(); + var r = Math.max(this.topRadius, this.bottomRadius); + this.boundingBox.min.set(-r, -this.height/2, -r); + this.boundingBox.max.set(r, this.height/2, r); + } +}); /** - * Helpers for creating a common 3d application. - * @namespace clay.application + * @constructor clay.geometry.Cylinder + * @extends clay.Geometry + * @param {Object} [opt] + * @param {number} [opt.radius] + * @param {number} [opt.height] + * @param {number} [opt.capSegments] + * @param {number} [opt.heightSegments] */ +var Cylinder$1 = Geometry.extend( +/** @lends clay.geometry.Cylinder# */ +{ + dynamic: false, + /** + * @type {number} + */ + radius: 1, - // TODO createCompositor - // TODO mobile. scroll events. - // TODO Dispose test. geoCache test. - // TODO fitModel, normal generation. - // TODO Skybox, Skydome. - // TODO Particle ? -var parseColor = colorUtil.parseToFloat; + /** + * @type {number} + */ + height: 2, -/** - * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike - */ -/** - * @typedef {string|Array.} Color - */ -/** - * @typedef {HTMLDomElement|string} DomQuery - */ + /** + * @type {number} + */ + capSegments: 50, -/** - * @constructor - * @alias clay.application.App3D - * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector` - * @param {Object} appNS - * @param {Function} appNS.init Initialization callback that will be called when initing app. - * You can return a promise in init to start the loop asynchronously when the promise is resolved. - * @param {Function} appNS.loop Loop callback that will be called each frame. - * @param {Function} appNS.beforeRender - * @param {Function} appNS.afterRender - * @param {number} [appNS.width] Container width. - * @param {number} [appNS.height] Container height. - * @param {number} [appNS.devicePixelRatio] - * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect - * @param {boolean} [appNS.graphic.shadow=false] If enable shadow - * @param {boolean} [appNS.graphic.linear=false] If use linear space - * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping. - * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex. - */ -function App3D(dom, appNS) { + /** + * @type {number} + */ + heightSegments: 1 +}, function() { + this.build(); +}, +/** @lends clay.geometry.Cylinder.prototype */ +{ + /** + * Build cylinder geometry + */ + build: function() { + var cone = new Cone$1({ + topRadius: this.radius, + bottomRadius: this.radius, + capSegments: this.capSegments, + heightSegments: this.heightSegments, + height: this.height + }); - appNS = appNS || {}; - appNS.graphic = appNS.graphic || {}; + this.attributes.position.value = cone.attributes.position.value; + this.attributes.normal.value = cone.attributes.normal.value; + this.attributes.texcoord0.value = cone.attributes.texcoord0.value; + this.indices = cone.indices; - if (typeof dom === 'string') { - dom = document.querySelector(dom); + this.boundingBox = cone.boundingBox; } +}); - if (!dom) { throw new Error('Invalid dom'); } +var gbufferEssl = "@export clay.deferred.gbuffer.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat;\nuniform vec2 uvOffset;\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#ifdef FIRST_PASS\nattribute vec3 normal : NORMAL;\n#endif\n@import clay.chunk.skinning_header\n#ifdef FIRST_PASS\nvarying vec3 v_Normal;\nattribute vec4 tangent : TANGENT;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nvarying vec3 v_WorldPosition;\n#endif\nvarying vec2 v_Texcoord;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef FIRST_PASS\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n bool hasTangent = dot(tangent, tangent) > 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"; - var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS'; - var rendererOpts = {}; - isDomCanvas && (rendererOpts.canvas = dom); - appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio); +var chunkEssl = "@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end"; - var gRenderer = new Renderer(rendererOpts); - var gWidth = appNS.width || dom.clientWidth; - var gHeight = appNS.height || dom.clientHeight; +Shader.import(gbufferEssl); +Shader.import(chunkEssl); - var gScene = new Scene(); - var gTimeline = new Timeline(); - var gShadowPass = appNS.graphic.shadow && new ShadowMapPass(); - var gRayPicking = appNS.event && new RayPicking({ - scene: gScene, - renderer: gRenderer - }); +function createFillCanvas(color) { + var canvas = document.createElement('canvas'); + canvas.width = canvas.height = 1; + var ctx = canvas.getContext('2d'); + ctx.fillStyle = color || '#000'; + ctx.fillRect(0, 0, 1, 1); - !isDomCanvas && dom.appendChild(gRenderer.canvas); + return canvas; +} - gRenderer.resize(gWidth, gHeight); +function attachTextureToSlot(renderer, program, symbol, texture, slot) { + var gl = renderer.gl; + program.setUniform(gl, '1i', symbol, slot); - var gFrameTime = 0; - var gElapsedTime = 0; + gl.activeTexture(gl.TEXTURE0 + slot); + // Maybe texture is not loaded yet; + if (texture.isRenderable()) { + texture.bind(renderer); + } + else { + // Bind texture to null + texture.unbind(renderer); + } +} - gTimeline.start(); +// TODO Use globalShader insteadof globalMaterial? +function getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) { - Object.defineProperties(this, { - /** - * Container dom element - * @name clay.application.App3D#container - * @type {HTMLDomElement} - */ - container: { get: function () { return dom; } }, - /** - * @name clay.application.App3D#renderer - * @type {clay.Renderer} - */ - renderer: { get: function () { return gRenderer; }}, - /** - * @name clay.application.App3D#scene - * @type {clay.Renderer} - */ - scene: { get: function () { return gScene; }}, - /** - * @name clay.application.App3D#timeline - * @type {clay.Renderer} - */ - timeline: { get: function () { return gTimeline; }}, - /** - * Time elapsed since last frame. Can be used in loop to calculate the movement. - * @name clay.application.App3D#frameTime - * @type {number} - */ - frameTime: { get: function () { return gFrameTime; }}, - /** - * Time elapsed since application created. - * @name clay.application.App3D#elapsedTime - * @type {number} - */ - elapsedTime: { get: function () { return gElapsedTime; }} - }); + var previousNormalMap; + var previousRougGlossMap; + var previousRenderable; - /** - * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given. - * @function - * @memberOf {clay.application.App3D} - * @param {number} [width] - * @param {number} [height] - */ - this.resize = function (width, height) { - gWidth = width || appNS.width || dom.clientWidth; - gHeight = height || dom.height || dom.clientHeight; - gRenderer.resize(gWidth, gHeight); - }; + return function (renderable, gBufferMat, prevMaterial) { + // Material not change + if (previousRenderable && previousRenderable.material === renderable.material) { + return; + } - /** - * Dispose the application - * @function - */ - this.dispose = function () { - this._disposed = true; + var standardMaterial = renderable.material; + var program = renderable.__program; - if (appNS.dispose) { - appNS.dispose(this); + var glossiness; + var roughGlossMap; + var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS'); + var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED'); + var roughGlossChannel; + if (useRoughnessWorkflow) { + glossiness = 1.0 - standardMaterial.get('roughness'); + roughGlossMap = standardMaterial.get('roughnessMap'); + roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL'); } - gTimeline.stop(); - gRenderer.disposeScene(gScene); - gShadowPass && gShadowPass.dispose(gRenderer); - - dom.innerHTML = ''; - ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) { - this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType)); - }); - }; + else { + glossiness = standardMaterial.get('glossiness'); + roughGlossMap = standardMaterial.get('glossinessMap'); + roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL'); + } + var useRoughGlossMap = !!roughGlossMap; - gRayPicking && this._initMouseEvents(gRayPicking); + var normalMap = standardMaterial.get('normalMap') || defaultNormalMap; + var uvRepeat = standardMaterial.get('uvRepeat'); + var uvOffset = standardMaterial.get('uvOffset'); - this._geoCache = new LRU$1(20); - this._texCache = new LRU$1(20); + roughGlossMap = roughGlossMap || defaultRoughnessMap; - // Do init the application. - var initPromise = Promise.resolve(appNS.init && appNS.init(this)); - // Use the inited camera. - gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); + if (prevMaterial !== gBufferMat) { + gBufferMat.set('glossiness', glossiness); + gBufferMat.set('normalMap', normalMap); + gBufferMat.set('roughGlossMap', roughGlossMap); + gBufferMat.set('useRoughGlossMap', +useRoughGlossMap); + gBufferMat.set('useRoughness', +useRoughnessWorkflow); + gBufferMat.set('doubleSided', +doubleSided); + gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0); + gBufferMat.set('uvRepeat', uvRepeat); + gBufferMat.set('uvOffset', uvOffset); + } + else { + program.setUniform( + gl, '1f', 'glossiness', glossiness + ); - var gTexturesList = {}; - var gGeometriesList = {}; + if (previousNormalMap !== normalMap) { + attachTextureToSlot(this, program, 'normalMap', normalMap, 0); + } + if (previousRougGlossMap !== roughGlossMap) { + attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1); + } + program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap); + program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow); + program.setUniform(gl, '1i', 'doubleSided', +doubleSided); + program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0); + if (uvRepeat != null) { + program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + } + if (uvOffset != null) { + program.setUniform(gl, '2f', 'uvOffset', uvOffset); + } + } - if (!appNS.loop) { - console.warn('Miss loop method.'); - } + previousNormalMap = normalMap; + previousRougGlossMap = roughGlossMap; - var self = this; - initPromise.then(function () { - appNS.loop && gTimeline.on('frame', function (frameTime) { - gFrameTime = frameTime; - gElapsedTime += frameTime; - appNS.loop(self); + previousRenderable = renderable; + }; +} - gScene.update(); - self._updateGraphicOptions(appNS.graphic, gScene.opaqueList); - self._updateGraphicOptions(appNS.graphic, gScene.transparentList); +function getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) { + var previousDiffuseMap; + var previousRenderable; + var previousMetalnessMap; - gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); - // Render shadow pass - gShadowPass && gShadowPass.render(gRenderer, gScene, null, true); + return function (renderable, gBufferMat, prevMaterial) { + // Material not change + if (previousRenderable && previousRenderable.material === renderable.material) { + return; + } - appNS.beforeRender && appNS.beforeRender(self); - self._doRender(gRenderer, gScene, true); - appNS.afterRender && appNS.afterRender(self); + var program = renderable.__program; + var standardMaterial = renderable.material; - // Mark all resources unused; - markUnused(gTexturesList); - markUnused(gGeometriesList); + var color = standardMaterial.get('color'); + var metalness = standardMaterial.get('metalness'); - // Collect resources used in this frame. - var newTexturesList = []; - var newGeometriesList = []; - collectResources(gScene, newTexturesList, newGeometriesList); + var diffuseMap = standardMaterial.get('diffuseMap'); + var metalnessMap = standardMaterial.get('metalnessMap'); - // Dispose those unsed resources. - checkAndDispose(gRenderer, gTexturesList); - checkAndDispose(gRenderer, gGeometriesList); + var uvRepeat = standardMaterial.get('uvRepeat'); + var uvOffset = standardMaterial.get('uvOffset'); - gTexturesList = newTexturesList; - gGeometriesList = newGeometriesList; - }); - }); -} + var useMetalnessMap = !!metalnessMap; -function isImageLikeElement(val) { - return val instanceof Image - || val instanceof HTMLCanvasElement - || val instanceof HTMLVideoElement; -} + diffuseMap = diffuseMap || defaultDiffuseMap; + metalnessMap = metalnessMap || defaultMetalnessMap; -function getKeyFromImageLike(val) { - typeof val === 'string' - ? val : (val.__key__ || (val.__key__ = util$1.genGUID())); -} + if (prevMaterial !== gBufferMat) { + gBufferMat.set('color', color); + gBufferMat.set('metalness', metalness); + gBufferMat.set('diffuseMap', diffuseMap); + gBufferMat.set('metalnessMap', metalnessMap); + gBufferMat.set('useMetalnessMap', +useMetalnessMap); + gBufferMat.set('uvRepeat', uvRepeat); + gBufferMat.set('uvOffset', uvOffset); -function makeHandlerName(eveType) { - return '_' + eveType + 'Handler'; -} + gBufferMat.set('linear', +standardMaterial.linear); + } + else { + program.setUniform(gl, '1f', 'metalness', metalness); -function packageEvent(eventType, pickResult, offsetX, offsetY) { - var event = util$1.clone(pickResult); - event.type = eventType; - event.offsetX = offsetX; - event.offsetY = offsetY; - return event; -} + program.setUniform(gl, '3f', 'color', color); + if (previousDiffuseMap !== diffuseMap) { + attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0); + } + if (previousMetalnessMap !== metalnessMap) { + attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1); + } + program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap); + program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + program.setUniform(gl, '2f', 'uvOffset', uvOffset); -function bubblingEvent(target, event) { - while (target && !event.cancelBubble) { - target.trigger(event.type, event); - target = target.getParent(); - } + program.setUniform(gl, '1i', 'linear', +standardMaterial.linear); + } + + previousDiffuseMap = diffuseMap; + previousMetalnessMap = metalnessMap; + + previousRenderable = renderable; + }; } -App3D.prototype._initMouseEvents = function (rayPicking) { - var dom = this.container; +/** + * GBuffer is provided for deferred rendering and SSAO, SSR pass. + * It will do two passes rendering to three target textures. See + * + {@link clay.deferred.GBuffer#getTargetTexture1} + * + {@link clay.deferred.GBuffer#getTargetTexture2} + * + {@link clay.deferred.GBuffer#getTargetTexture3} + * @constructor + * @alias clay.deferred.GBuffer + * @extends clay.core.Base + */ +var GBuffer = Base.extend(function () { - var oldTarget = null; - ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) { - dom.addEventListener(eveType, this[makeHandlerName(eveType)] = function (e) { - if (!rayPicking.camera) { // Not have camera yet. - return; - } + return { - var box = dom.getBoundingClientRect(); - var offsetX = e.clientX - box.left; - var offsetY = e.clientY - box.top; + enableTargetTexture1: true, - var pickResult = rayPicking.pick(offsetX, offsetY); + enableTargetTexture2: true, - if (pickResult) { - // Just ignore silent element. - if (pickResult.target.silent) { - return; - } + enableTargetTexture3: true, - if (eveType === 'mousemove') { - var targetChanged = pickResult.target !== oldTarget; - if (targetChanged) { - oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', { - target: oldTarget - }, offsetX, offsetY)); - } - bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY)); - if (targetChanged) { - bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY)); - } - } - else { - bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY)); - } - oldTarget = pickResult.target; - } - else if (oldTarget) { - bubblingEvent(oldTarget, packageEvent('mouseout', { - target: oldTarget - }, offsetX, offsetY)); - oldTarget = null; + renderTransparent: false, + + _renderList: [], + // - R: normal.x + // - G: normal.y + // - B: normal.z + // - A: glossiness + _gBufferTex1: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST, + // PENDING + type: Texture.HALF_FLOAT + }), + + // - R: depth + _gBufferTex2: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST, + // format: Texture.DEPTH_COMPONENT, + // type: Texture.UNSIGNED_INT + + format: Texture.DEPTH_STENCIL, + type: Texture.UNSIGNED_INT_24_8_WEBGL + }), + + // - R: albedo.r + // - G: albedo.g + // - B: albedo.b + // - A: metalness + _gBufferTex3: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST + }), + + _defaultNormalMap: new Texture2D({ + image: createFillCanvas('#000') + }), + _defaultRoughnessMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + _defaultMetalnessMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + _defaultDiffuseMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + + _frameBuffer: new FrameBuffer(), + + _gBufferMaterial1: new Material({ + shader: new Shader( + Shader.source('clay.deferred.gbuffer.vertex'), + Shader.source('clay.deferred.gbuffer1.fragment') + ), + vertexDefines: { + FIRST_PASS: null + }, + fragmentDefines: { + FIRST_PASS: null } - }); - }, this); -}; + }), + _gBufferMaterial2: new Material({ + shader: new Shader( + Shader.source('clay.deferred.gbuffer.vertex'), + Shader.source('clay.deferred.gbuffer2.fragment') + ) + }), -App3D.prototype._updateGraphicOptions = function (graphicOpts, list) { - var enableTonemapping = !!graphicOpts.tonemapping; - var isLinearSpace = !!graphicOpts.linear; + _debugPass: new Pass({ + fragment: Shader.source('clay.deferred.gbuffer.debug') + }) + }; +}, /** @lends clay.deferred.GBuffer# */{ - var prevMaterial; + /** + * Set G Buffer size. + * @param {number} width + * @param {number} height + */ + resize: function (width, height) { + if (this._gBufferTex1.width === width + && this._gBufferTex1.height === height + ) { + return; + } + this._gBufferTex1.width = width; + this._gBufferTex1.height = height; - for (var i = 0; i < list.length; i++) { - var mat = list[i].material; - if (mat === prevMaterial) { - continue; + this._gBufferTex2.width = width; + this._gBufferTex2.height = height; + + this._gBufferTex3.width = width; + this._gBufferTex3.height = height; + }, + + // TODO is dpr needed? + setViewport: function (x, y, width, height, dpr) { + var viewport; + if (typeof x === 'object') { + viewport = x; + } + else { + viewport = { + x: x, y: y, + width: width, height: height, + devicePixelRatio: dpr || 1 + }; } + this._frameBuffer.viewport = viewport; + }, - enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING'); - if (isLinearSpace) { - mat.define('fragment', 'SRGB_ENCODE'); - mat.define('fragment', 'SRGB_DECODE'); + getViewport: function () { + if (this._frameBuffer.viewport) { + return this._frameBuffer.viewport; } else { - mat.undefine('fragment', 'SRGB_ENCODE'); - mat.undefine('fragment', 'SRGB_DECODE'); + return { + x: 0, y: 0, + width: this._gBufferTex1.width, + height: this._gBufferTex1.height, + devicePixelRatio: 1 + }; } + }, - prevMaterial = mat; - } -}; + /** + * Update G Buffer + * @param {clay.Renderer} renderer + * @param {clay.Scene} scene + * @param {clay.camera.Perspective} camera + */ + update: function (renderer, scene, camera) { -App3D.prototype._doRender = function (renderer, scene) { - var camera = scene.getMainCamera(); - camera.aspect = renderer.getViewportAspect(); - renderer.render(scene); -}; + var gl = renderer.gl; + var frameBuffer = this._frameBuffer; + var viewport = frameBuffer.viewport; + var opaqueList = scene.opaqueList; + var transparentList = scene.transparentList; -function markUnused(resourceList) { - for (var i = 0; i < resourceList.length; i++) { - resourceList[i].__used__ = 0; - } -} + var offset = 0; + var renderList = this._renderList; + for (var i = 0; i < opaqueList.length; i++) { + if (!opaqueList[i].ignoreGBuffer) { + renderList[offset++] = opaqueList[i]; + } + } + if (this.renderTransparent) { + for (var i = 0; i < transparentList.length; i++) { + if (!transparentList[i].ignoreGBuffer) { + renderList[offset++] = transparentList[i]; + } + } + } + renderList.length = offset; -function checkAndDispose(renderer, resourceList) { - for (var i = 0; i < resourceList.length; i++) { - if (!resourceList[i].__used__) { - resourceList[i].dispose(renderer); + gl.clearColor(0, 0, 0, 0); + gl.depthMask(true); + gl.colorMask(true, true, true, true); + gl.disable(gl.BLEND); + + var enableTargetTexture1 = this.enableTargetTexture1; + var enableTargetTexture2 = this.enableTargetTexture2; + var enableTargetTexture3 = this.enableTargetTexture3; + if (!enableTargetTexture1 && !enableTargetTexture3) { + console.warn('Can\'t disable targetTexture1 targetTexture3 both'); + enableTargetTexture1 = true; } - } -} -function updateUsed(resource, list) { - resource.__used__ = resource.__used__ || 0; - resource.__used__++; - if (resource.__used__ === 1) { - // Don't push to the list twice. - list.push(resource); - } -} -function collectResources(scene, textureResourceList, geometryResourceList) { - function trackQueue(queue) { - var prevMaterial; - var prevGeometry; - for (var i = 0; i < queue.length; i++) { - var renderable = queue[i]; - var geometry = renderable.geometry; - var material = renderable.material; + if (enableTargetTexture2) { + frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT); + } - // TODO optimize!! - if (material !== prevMaterial) { - var textureUniforms = material.getTextureUniforms(); - for (var u = 0; u < textureUniforms.length; u++) { - var uniformName = textureUniforms[u]; - var val = material.uniforms[uniformName].value; - if (!val) { - continue; - } - if (val instanceof Texture) { - updateUsed(val, textureResourceList); - } - else if (val instanceof Array) { - for (var k = 0; k < val.length; k++) { - if (val[k] instanceof Texture) { - updateUsed(val[k], textureResourceList); - } - } - } - } + // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow + renderer.bindSceneRendering(scene); + if (enableTargetTexture1) { + // Pass 1 + frameBuffer.attach(this._gBufferTex1); + frameBuffer.bind(renderer); + + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); } - if (geometry !== prevGeometry) { - updateUsed(geometry, geometryResourceList); + gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); } + var gBufferMaterial1 = this._gBufferMaterial1; + var passConfig = { + getMaterial: function () { + return gBufferMaterial1; + }, + beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap), + sortCompare: renderer.opaqueSortCompare + }; + // FIXME Use MRT if possible + renderer.renderPass(renderList, camera, passConfig); - prevMaterial = material; - prevGeometry = geometry; } - } + if (enableTargetTexture3) { - trackQueue(scene.opaqueList); - trackQueue(scene.transparentList); + // Pass 2 + frameBuffer.attach(this._gBufferTex3); + frameBuffer.bind(renderer); - for (var k = 0; k < scene.lights.length; k++) { - // Track AmbientCubemap - if (scene.lights[k].cubemap) { - updateUsed(scene.lights[k].cubemap, textureResourceList); + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + } + gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); + } + + var gBufferMaterial2 = this._gBufferMaterial2; + var passConfig = { + getMaterial: function () { + return gBufferMaterial2; + }, + beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap), + sortCompare: renderer.opaqueSortCompare + }; + renderer.renderPass(renderList, camera, passConfig); } - } -} -/** - * Load a texture from image or string. - * @param {ImageLike} img - * @param {Object} [opts] Texture options. - * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} - * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} - * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} - * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} - * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} - * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} - * @param {number} [opts.exposure] Only be used when source is a HDR image. - * @param {boolean} [useCache] If use cache. - * @return {Promise} - * @example - * app.loadTexture('diffuseMap.jpg') - * .then(function (texture) { - * material.set('diffuseMap', texture); - * }); - */ -App3D.prototype.loadTexture = function (urlOrImg, opts, useCache) { - var self = this; - var key = getKeyFromImageLike(urlOrImg); - if (useCache) { - if (this._texCache.get(key)) { - return this._texCache.get(key); + + renderer.bindSceneRendering(null); + frameBuffer.unbind(renderer); + }, + + renderDebug: function (renderer, camera, type, viewport) { + var debugTypes = { + normal: 0, + depth: 1, + position: 2, + glossiness: 3, + metalness: 4, + albedo: 5 + }; + if (debugTypes[type] == null) { + console.warn('Unkown type "' + type + '"'); + // Default use normal + type = 'normal'; } - } - // TODO Promise ? - var promise = new Promise(function (resolve, reject) { - var texture = self.loadTextureSync(urlOrImg, opts); - if (!texture.isRenderable()) { - texture.success(function () { - if (self._disposed) { - return; - } - resolve(texture); - }); - texture.error(function () { - if (self._disposed) { - return; - } - reject(); - }); - } - else { - resolve(texture); - } - }); - if (useCache) { - this._texCache.put(key, promise); - } - return promise; -}; -/** - * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. - * @param {ImageLike} img - * @param {Object} [opts] Texture options. - * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} - * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} - * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} - * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} - * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} - * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} - * @param {number} [opts.exposure] Only be used when source is a HDR image. - * @return {Promise} - * @example - * var texture = app.loadTexture('diffuseMap.jpg', { - * anisotropic: 8, - * flipY: false - * }); - * material.set('diffuseMap', texture); - */ -App3D.prototype.loadTextureSync = function (urlOrImg, opts) { - var texture = new Texture2D(opts); - if (typeof urlOrImg === 'string') { - if (urlOrImg.match(/.hdr$|^data:application\/octet-stream/)) { - texture = textureUtil.loadTexture(urlOrImg, { - exposure: opts && opts.exposure, - fileType: 'hdr' - }, function () { - texture.dirty(); - texture.trigger('success'); - }); - } - else { - texture.load(urlOrImg); - } - } - else if (isImageLikeElement(urlOrImg)) { - texture.image = urlOrImg; - texture.dynamic = urlOrImg instanceof HTMLVideoElement; - } - return texture; -}; + renderer.saveClear(); + renderer.saveViewport(); + renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT; -/** - * Create a material. - * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms. - * Uniforms can be `color`, `alpha` `diffuseMap` etc. - * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow. - * @param {boolean} [transparent=false] If material is transparent. - * @return {clay.Material} - */ -App3D.prototype.createMaterial = function (matConfig) { - matConfig = matConfig || {}; - matConfig.shader = matConfig.shader || 'clay.standardMR'; - var shader = matConfig.shader instanceof Shader ? matConfig.shader : library.get(matConfig.shader); - var material = new Material({ - shader: shader - }); - function makeTextureSetter(key) { - return function (texture) { - material.setUniform(key, texture); - }; - } - for (var key in matConfig) { - if (material.uniforms[key]) { - var val = matConfig[key]; - if (material.uniforms[key].type === 't' || isImageLikeElement(val)) { - // Try to load a texture. - this.loadTexture(val).then(makeTextureSetter(key)); - } - else { - material.setUniform(key, val); - } + if (viewport) { + renderer.setViewport(viewport); } - } + var viewProjectionInv = new Matrix4(); + Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - if (matConfig.transparent) { - matConfig.depthMask = false; - matConfig.transparent = true; - } - return material; -}; + var debugPass = this._debugPass; + debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]); + debugPass.setUniform('gBufferTexture1', this._gBufferTex1); + debugPass.setUniform('gBufferTexture2', this._gBufferTex2); + debugPass.setUniform('gBufferTexture3', this._gBufferTex3); + debugPass.setUniform('debug', debugTypes[type]); + debugPass.setUniform('viewProjectionInv', viewProjectionInv.array); + debugPass.render(renderer); -/** - * Create a cube mesh and add it to the scene or the given parent node. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of cube. - * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a white cube. - * app.createCube() - */ -App3D.prototype.createCube = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv, subdiv]; - } + renderer.restoreViewport(); + renderer.restoreClear(); + }, - var geoKey = 'cube-' + subdiv.join('-'); - var cube = this._geoCache.get(geoKey); - if (!cube) { - cube = new Cube$1({ - widthSegments: subdiv[0], - heightSegments: subdiv[1], - depthSegments: subdiv[2] - }); - this._geoCache.put(geoKey, cube); - } - return this.createMesh(cube, material, parentNode); -}; + /** + * Get first target texture. + * Channel storage: + * + R: normal.x * 0.5 + 0.5 + * + G: normal.y * 0.5 + 0.5 + * + B: normal.z * 0.5 + 0.5 + * + A: glossiness + * @return {clay.Texture2D} + */ + getTargetTexture1: function () { + return this._gBufferTex1; + }, -/** - * Create a cube mesh that camera is inside the cube. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of cube. - * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a white cube inside. - * app.createCubeInside() - */ -App3D.prototype.createCubeInside = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv, subdiv]; - } - var geoKey = 'cubeInside-' + subdiv.join('-'); - var cube = this._geoCache.get(geoKey); - if (!cube) { - cube = new Cube$1({ - inside: true, - widthSegments: subdiv[0], - heightSegments: subdiv[1], - depthSegments: subdiv[2] - }); - this._geoCache.put(geoKey, cube); - } + /** + * Get second target texture. + * Channel storage: + * + R: depth + * @return {clay.Texture2D} + */ + getTargetTexture2: function () { + return this._gBufferTex2; + }, - return this.createMesh(cube, material, parentNode); -}; + /** + * Get third target texture. + * Channel storage: + * + R: albedo.r + * + G: albedo.g + * + B: albedo.b + * + A: metalness + * @return {clay.Texture2D} + */ + getTargetTexture3: function () { + return this._gBufferTex3; + }, -/** - * Create a sphere mesh and add it to the scene or the given parent node. - * @function - * @param {number} [subdivision=20] Subdivision of sphere. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a semi-transparent sphere. - * app.createSphere(20, { - * color: [0, 0, 1], - * transparent: true, - * alpha: 0.5 - * }) - */ -App3D.prototype.createSphere = function (subdivision, material, parentNode) { - if (subdivision == null) { - subdivision = 20; - } - var geoKey = 'sphere-' + subdivision; - var sphere = this._geoCache.get(geoKey); - if (!sphere) { - sphere = new Sphere$1({ - widthSegments: subdivision * 2, - heightSegments: subdivision - }); - this._geoCache.put(geoKey, sphere); - } - return this.createMesh(sphere, material, parentNode); -}; -/** - * Create a plane mesh and add it to the scene or the given parent node. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of plane. - * Can be a number to represent both width and height dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a red color plane. - * app.createPlane(1, { - * color: [1, 0, 0] - * }) - */ -App3D.prototype.createPlane = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv]; - } - var geoKey = 'plane-' + subdiv.join('-'); - var planeGeo = this._geoCache.get(geoKey); - if (!planeGeo) { - planeGeo = new Plane$3({ - widthSegments: subdiv[0], - heightSegments: subdiv[1] - }); - this._geoCache.put(geoKey, planeGeo); + /** + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { } - return this.createMesh(planeGeo, material, parentNode); -}; - -/** - * Create a general mesh with given geometry instance and material config. - * @param {*} geometry - */ -App3D.prototype.createMesh = function (geometry, mat, parentNode) { - var mesh = new Mesh({ - geometry: geometry, - material: mat instanceof Material ? mat : this.createMaterial(mat) - }); - parentNode = parentNode || this.scene; - parentNode.add(mesh); - return mesh; -}; +}); -/** - * Create a perspective or orthographic camera and add it to the scene. - * @param {Array.|clay.math.Vector3} position - * @param {Array.|clay.math.Vector3} target - * @param {string} [type="perspective"] Can be 'perspective' or 'orthographic'(in short 'ortho') - * @return {clay.camera.Perspective} - */ -App3D.prototype.createCamera = function (position, target, type) { - var CameraCtor; - if (type === 'ortho' || type === 'orthographic') { - CameraCtor = Orthographic$1; - } - else { - if (type && type !== 'perspective') { - console.error('Unkown camera type ' + type + '. Use default perspective camera'); - } - CameraCtor = Perspective$1; - } +var lightvolumeGlsl = "@export clay.deferred.light_volume.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_Position;\nvoid main()\n{\n gl_Position = worldViewProjection * vec4(position, 1.0);\n v_Position = position;\n}\n@end"; - var camera = new CameraCtor(); - if (position instanceof Vector3) { - camera.position.copy(position); - } - else if (position instanceof Array) { - camera.position.setArray(position); - } +var spotGlsl = "@export clay.deferred.spot_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\n@import clay.util.calculate_attenuation\nuniform vec3 lightPosition;\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform float umbraAngleCosine;\nuniform float penumbraAngleCosine;\nuniform float lightRange;\nuniform float falloffFactor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform mat4 lightMatrix;\nuniform float lightShadowMapSize;\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n float attenuation = lightAttenuation(dist, lightRange);\n float c = dot(-normalize(lightDirection), L);\n float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrix, position, lightShadowMapSize\n );\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; - if (target instanceof Array) { - target = new Vector3(target[0], target[1], target[2]); - } - if (target instanceof Vector3) { - camera.lookAt(target); - } +var directionalGlsl = "@export clay.deferred.directional_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform float lightShadowMapSize;\nuniform mat4 lightMatrices[SHADOW_CASCADE];\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = -normalize(lightDirection);\n vec3 V = normalize(eyePosition - position);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = 1.0;\n for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\n if (\n z >= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; - this.scene.add(camera); +var ambientGlsl = "@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"; - return camera; -}; +var ambientshGlsl = "@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"; -/** - * Create a directional light and add it to the scene. - * @param {Array.|clay.math.Vector3} dir A Vector3 or array to represent the direction. - * @param {Color} [color='#fff'] Color of directional light, default to be white. - * @param {number} [intensity] Intensity of directional light, default to be 1. - * - * @example - * app.createDirectionalLight([-1, -1, -1], '#fff', 2); - */ -App3D.prototype.createDirectionalLight = function (dir, color, intensity) { - var light = new DirectionalLight(); - if (dir instanceof Vector3) { - dir = dir.array; - } - light.position.setArray(dir).negate(); - light.lookAt(Vector3.ZERO); - if (typeof color === 'string') { - color = parseColor(color); - } - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); +var ambientcubemapGlsl = "@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"; - this.scene.add(light); - return light; -}; +var pointGlsl = "@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"; -/** - * Create a spot light and add it to the scene. - * @param {Array.|clay.math.Vector3} position Position of the spot light. - * @param {Array.|clay.math.Vector3} [target] Target position where spot light points to. - * @param {number} [range=20] Falloff range of spot light. Default to be 20. - * @param {Color} [color='#fff'] Color of spot light, default to be white. - * @param {number} [intensity=1] Intensity of spot light, default to be 1. - * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line. - * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line. - * - * @example - * app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900); - */ -App3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) { - var light = new SpotLight(); - light.position.setArray(position instanceof Vector3 ? position.array : position); +var sphereGlsl = "@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"; - if (target instanceof Array) { - target = new Vector3(target[0], target[1], target[2]); - } - if (target instanceof Vector3) { - light.lookAt(target); - } +var tubeGlsl = "@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"; - if (typeof color === 'string') { - color = parseColor(color); - } - range != null && (light.range = range); - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); - umbraAngle != null && (light.umbraAngle = umbraAngle); - penumbraAngle != null && (light.penumbraAngle = penumbraAngle); +// Light-pre pass deferred rendering +// http://www.realtimerendering.com/blog/deferred-lighting-approaches/ +// Light shaders +Shader.import(prezGlsl); +Shader.import(utilGlsl); +Shader.import(lightvolumeGlsl); - this.scene.add(light); +// Light shaders +Shader.import(spotGlsl); +Shader.import(directionalGlsl); +Shader.import(ambientGlsl); +Shader.import(ambientshGlsl); +Shader.import(ambientcubemapGlsl); +Shader.import(pointGlsl); +Shader.import(sphereGlsl); +Shader.import(tubeGlsl); - return light; -}; +Shader.import(prezGlsl); /** - * Create a point light. - * @param {Array.|clay.math.Vector3} position Position of point light.. - * @param {number} [range=100] Falloff range of point light. - * @param {Color} [color='#fff'] Color of point light. - * @param {number} [intensity=1] Intensity of point light. + * Deferred renderer + * @constructor + * @alias clay.deferred.Renderer + * @extends clay.core.Base */ -App3D.prototype.createPointLight = function (position, range, color, intensity) { - var light = new PointLight(); - light.position.setArray(position instanceof Vector3 ? position.array : position); +var DeferredRenderer = Base.extend(function () { - if (typeof color === 'string') { - color = parseColor(color); - } - range != null && (light.range = range); - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); + var fullQuadVertex = Shader.source('clay.compositor.vertex'); + var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex'); - this.scene.add(light); + var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light')); - return light; -}; + var lightAccumulateBlendFunc = function (gl) { + gl.blendEquation(gl.FUNC_ADD); + gl.blendFunc(gl.ONE, gl.ONE); + }; -/** - * Create a ambient light. - * @param {Color} [color='#fff'] Color of ambient light. - * @param {number} [intensity=1] Intensity of ambient light. - */ -App3D.prototype.createAmbientLight = function (color, intensity) { - var light = new AmbientLight(); + var createLightPassMat = function (shader) { + return new Material({ + shader: shader, + blend: lightAccumulateBlendFunc, + transparent: true, + depthMask: false + }); + }; - if (typeof color === 'string') { - color = parseColor(color); - } - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); + var createVolumeShader = function (name) { + return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name)); + }; - this.scene.add(light); + // Rotate and positioning to fit the spot light + // Which the cusp of cone pointing to the positive z + // and positioned on the origin + var coneGeo = new Cone$1({ + capSegments: 10 + }); + var mat = new Matrix4(); + mat.rotateX(Math.PI / 2) + .translate(new Vector3(0, -1, 0)); - return light; -}; + coneGeo.applyTransform(mat); -/** - * Create an cubemap ambient light and an spherical harmonic ambient light - * for specular and diffuse lighting in PBR rendering - * @param {ImageLike} [envImage] Panorama environment image, HDR format is better. - * @param {number} [specularIntenstity=0.7] Intensity of specular light. - * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light. - * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR. - * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering. - */ -App3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) { - var self = this; - if (exposure == null) { - exposure = 1; - } - if (prefilteredCubemapSize == null) { - prefilteredCubemapSize = 32; - } + var cylinderGeo = new Cylinder$1({ + capSegments: 10 + }); + // Align with x axis + mat.identity().rotateZ(Math.PI / 2); + cylinderGeo.applyTransform(mat); - var scene = this.scene; + return /** @lends clay.deferred.Renderer# */ { - return this.loadTexture(envImage, { - exposure: exposure - }).then(function (envTexture) { - var specLight = new AmbientCubemapLight({ - intensity: specIntensity != null ? specIntensity : 0.7 - }); - specLight.cubemap = envTexture; - envTexture.flipY = false; - // TODO Cache prefilter ? - specLight.prefilter(self.renderer, 32); + /** + * Provide ShadowMapPass for shadow rendering. + * @type {clay.prePass.ShadowMap} + */ + shadowMapPass: null, + /** + * If enable auto resizing from given defualt renderer size. + * @type {boolean} + */ + autoResize: true, - var diffLight = new AmbientSHLight({ - intensity: diffIntensity != null ? diffIntensity : 0.7, - coefficients: sh.projectEnvironmentMap( - self.renderer, specLight.cubemap, { - lod: 1 - } - ) - }); - scene.add(specLight); - scene.add(diffLight); + _createLightPassMat: createLightPassMat, - return { - specular: specLight, - diffuse: diffLight, - // Original environment map - environmentMap: envTexture - }; - }); -}; + _gBuffer: new GBuffer(), -/** - * Load a [glTF](https://github.com/KhronosGroup/glTF) format model. - * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script, - * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application. - * @param {string} url - * @param {Object} opts - * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'. - * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded. - * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model. - * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z' - * @param {boolean} [opts.textureFlipY=false] - * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file. - * @return {Promise} - */ -App3D.prototype.loadModel = function (url, opts) { - if (typeof url !== 'string') { - throw new Error('Invalid URL.'); - } + _lightAccumFrameBuffer: new FrameBuffer({ + depthBuffer: false + }), - opts = opts || {}; - if (opts.autoPlayAnimation == null) { - opts.autoPlayAnimation = true; - } - var shader = opts.shader || 'clay.standard'; + _lightAccumTex: new Texture2D({ + // FIXME Device not support float texture + type: Texture.HALF_FLOAT, + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST + }), - var loaderOpts = { - rootNode: new Node(), - shader: shader, - textureRootPath: opts.textureRootPath, - crossOrigin: 'Anonymous', - textureFlipY: opts.textureFlipY - }; - if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') { - loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2); - } + _fullQuadPass: new Pass({ + blendWithPrevious: true + }), - var loader = new GLTFLoader(loaderOpts); + _directionalLightMat: createLightPassMat(directionalLightShader), - var scene = this.scene; - var timeline = this.timeline; - var self = this; + _ambientMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_light') + )), + _ambientSHMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light') + )), + _ambientCubemapMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light') + )), - return new Promise(function (resolve, reject) { - function afterLoad(result) { - if (self._disposed) { - return; - } + _spotLightShader: createVolumeShader('spot_light'), + _pointLightShader: createVolumeShader('point_light'), - scene.add(result.rootNode); - if (opts.autoPlayAnimation) { - result.clips.forEach(function (clip) { - timeline.addClip(clip); - }); - } - resolve(result); - } - loader.success(function (result) { - if (self._disposed) { - return; - } + _sphereLightShader: createVolumeShader('sphere_light'), + _tubeLightShader: createVolumeShader('tube_light'), - if (!opts.waitTextureLoaded) { - afterLoad(result); - } - else { - Promise.all(result.textures.map(function (texture) { - if (texture.isRenderable()) { - return Promise.resolve(texture); - } - return new Promise(function (resolve) { - texture.success(resolve); - texture.error(resolve); - }); - })).then(function () { - afterLoad(result); - }).catch(function () { - afterLoad(result); - }); - } - }); - loader.error(function () { - reject(); - }); - loader.load(url); - }); -}; + _lightSphereGeo: new Sphere$1({ + widthSegments: 10, + heightSegements: 10 + }), + _lightConeGeo: coneGeo, -var application = { - App3D: App3D, + _lightCylinderGeo: cylinderGeo, + + _outputPass: new Pass({ + fragment: Shader.source('clay.compositor.output') + }) + }; +}, /** @lends clay.deferred.Renderer# */ { /** - * Create a 3D application that will manage the app initialization and loop. - * @name clay.application.create - * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector` - * @param {Object} appNS - * @param {Function} init Initialization callback that will be called when initing app. - * @param {Function} loop Loop callback that will be called each frame. - * @param {number} [width] Container width. - * @param {number} [height] Container height. - * @param {number} [devicePixelRatio] - * @return {clay.application.App3D} - * - * @example - * clay.application.create('#app', { - * init: function (app) { - * app.createCube(); - * var camera = app.createCamera(); - * camera.position.set(0, 0, 2); - * }, - * loop: function () { // noop } - * }) + * Do render + * @param {clay.Renderer} renderer + * @param {clay.Scene} scene + * @param {clay.Camera} camera + * @param {Object} [opts] + * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture + * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow. + * @param {boolean} [opts.notUpdateScene = true] If not update the scene. */ - create: function (dom, appNS) { - return new App3D(dom, appNS); - } -}; - -/** - * @constructor - * @alias clay.async.Task - * @mixes clay.core.mixin.notifier - */ -var Task = function() { - this._fullfilled = false; - this._rejected = false; -}; -/** - * Task successed - * @param {} data - */ -Task.prototype.resolve = function(data) { - this._fullfilled = true; - this._rejected = false; - this.trigger('success', data); -}; -/** - * Task failed - * @param {} err - */ -Task.prototype.reject = function(err) { - this._rejected = true; - this._fullfilled = false; - this.trigger('error', err); -}; -/** - * If task successed - * @return {boolean} - */ -Task.prototype.isFullfilled = function() { - return this._fullfilled; -}; -/** - * If task failed - * @return {boolean} - */ -Task.prototype.isRejected = function() { - return this._rejected; -}; -/** - * If task finished, either successed or failed - * @return {boolean} - */ -Task.prototype.isSettled = function() { - return this._fullfilled || this._rejected; -}; + render: function (renderer, scene, camera, opts) { -util$1.extend(Task.prototype, notifier); + opts = opts || {}; + opts.renderToTarget = opts.renderToTarget || false; + opts.notUpdateShadow = opts.notUpdateShadow || false; + opts.notUpdateScene = opts.notUpdateScene || false; -function makeRequestTask(url, responseType) { - var task = new Task(); - request.get({ - url: url, - responseType: responseType, - onload: function(res) { - task.resolve(res); - }, - onerror: function(error) { - task.reject(error); + if (!opts.notUpdateScene) { + scene.update(false, true); } - }); - return task; -} -/** - * Make a request task - * @param {string|object|object[]|string[]} url - * @param {string} [responseType] - * @example - * var task = Task.makeRequestTask('./a.json'); - * var task = Task.makeRequestTask({ - * url: 'b.bin', - * responseType: 'arraybuffer' - * }); - * var tasks = Task.makeRequestTask(['./a.json', './b.json']); - * var tasks = Task.makeRequestTask([ - * {url: 'a.json'}, - * {url: 'b.bin', responseType: 'arraybuffer'} - * ]); - * @return {clay.async.Task|clay.async.Task[]} - */ -Task.makeRequestTask = function(url, responseType) { - if (typeof url === 'string') { - return makeRequestTask(url, responseType); - } else if (url.url) { // Configure object - var obj = url; - return makeRequestTask(obj.url, obj.responseType); - } else if (Array.isArray(url)) { // Url list - var urlList = url; - var tasks = []; - urlList.forEach(function(obj) { - var url, responseType; - if (typeof obj === 'string') { - url = obj; - } else if (Object(obj) === obj) { - url = obj.url; - responseType = obj.responseType; - } - tasks.push(makeRequestTask(url, responseType)); - }); - return tasks; - } -}; -/** - * @return {clay.async.Task} - */ -Task.makeTask = function() { - return new Task(); -}; -util$1.extend(Task.prototype, notifier); + camera.update(true); -/** - * @constructor - * @alias clay.async.TaskGroup - * @extends clay.async.Task - */ -var TaskGroup = function () { + // PENDING For stereo rendering + var dpr = renderer.getDevicePixelRatio(); + if (this.autoResize + && (renderer.getWidth() * dpr !== this._lightAccumTex.width + || renderer.getHeight() * dpr !== this._lightAccumTex.height) + ) { + this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr); + } - Task.apply(this, arguments); + this._gBuffer.update(renderer, scene, camera); - this._tasks = []; + // Accumulate light buffer + this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow); - this._fulfilledNumber = 0; + if (!opts.renderToTarget) { + this._outputPass.setUniform('texture', this._lightAccumTex); - this._rejectedNumber = 0; -}; + this._outputPass.render(renderer); + // this._gBuffer.renderDebug(renderer, camera, 'normal'); + } + }, -var Ctor = function (){}; -Ctor.prototype = Task.prototype; -TaskGroup.prototype = new Ctor(); + /** + * @return {clay.Texture2D} + */ + getTargetTexture: function () { + return this._lightAccumTex; + }, -TaskGroup.prototype.constructor = TaskGroup; + /** + * @return {clay.FrameBuffer} + */ + getTargetFrameBuffer: function () { + return this._lightAccumFrameBuffer; + }, -/** - * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}. - * @param {Array.} tasks - * @chainable - * @example - * // Load texture list - * var list = ['a.jpg', 'b.jpg', 'c.jpg'] - * var textures = list.map(function (src) { - * var texture = new clay.Texture2D(); - * texture.load(src); - * return texture; - * }); - * var taskGroup = new clay.async.TaskGroup(); - * taskGroup.all(textures).success(function () { - * // Do some thing after all textures loaded - * }); - */ -TaskGroup.prototype.all = function (tasks) { - var count = 0; - var self = this; - var data = []; - this._tasks = tasks; - this._fulfilledNumber = 0; - this._rejectedNumber = 0; + /** + * @return {clay.deferred.GBuffer} + */ + getGBuffer: function () { + return this._gBuffer; + }, - util$1.each(tasks, function (task, idx) { - if (!task || !task.once) { - return; - } - count++; - task.once('success', function (res) { - count--; + // TODO is dpr needed? + setViewport: function (x, y, width, height, dpr) { + this._gBuffer.setViewport(x, y, width, height, dpr); + this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport(); + }, - self._fulfilledNumber++; - // TODO - // Some tasks like texture, loader are not inherited from task - // We need to set the states here - task._fulfilled = true; - task._rejected = false; + // getFullQuadLightPass: function () { + // return this._fullQuadPass; + // }, - data[idx] = res; - if (count === 0) { - self.resolve(data); - } - }); - task.once('error', function () { + /** + * Set renderer size. + * @param {number} width + * @param {number} height + */ + resize: function (width, height) { + this._lightAccumTex.width = width; + this._lightAccumTex.height = height; - self._rejectedNumber ++; + // PENDING viewport ? + this._gBuffer.resize(width, height); + }, - task._fulfilled = false; - task._rejected = true; + _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) { + var gl = renderer.gl; + var lightAccumTex = this._lightAccumTex; + var lightAccumFrameBuffer = this._lightAccumFrameBuffer; - self.reject(task); - }); - }); - if (count === 0) { - setTimeout(function () { - self.resolve(data); - }); - return this; - } - return this; -}; -/** - * Wait for all given tasks finished, either successed or failed - * @param {Array.} tasks - * @return {clay.async.TaskGroup} - */ -TaskGroup.prototype.allSettled = function (tasks) { - var count = 0; - var self = this; - var data = []; - if (tasks.length === 0) { - setTimeout(function () { - self.trigger('success', data); - }); - return this; - } - this._tasks = tasks; + var eyePosition = camera.getWorldPosition().array; - util$1.each(tasks, function (task, idx) { - if (!task || !task.once) { - return; + // Update volume meshes + for (var i = 0; i < scene.lights.length; i++) { + this._updateLightProxy(scene.lights[i]); } - count++; - task.once('success', function (res) { - count--; - self._fulfilledNumber++; + var shadowMapPass = this.shadowMapPass; + if (shadowMapPass && updateShadow) { + gl.clearColor(1, 1, 1, 1); + this._prepareLightShadow(renderer, scene, camera); + } - task._fulfilled = true; - task._rejected = false; + this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow); - data[idx] = res; - if (count === 0) { - self.resolve(data); - } - }); - task.once('error', function (err) { - count--; + lightAccumFrameBuffer.attach(lightAccumTex); + lightAccumFrameBuffer.bind(renderer); + var clearColor = renderer.clearColor; - self._rejectedNumber++; + var viewport = lightAccumFrameBuffer.viewport; + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + } + gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]); + gl.clear(gl.COLOR_BUFFER_BIT); + gl.enable(gl.BLEND); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); + } - task._fulfilled = false; - task._rejected = true; + this.trigger('startlightaccumulate', renderer, scene, camera); - // TODO - data[idx] = null; - if (count === 0) { - self.resolve(data); - } - }); - }); - return this; -}; -/** - * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getFulfilledNumber = function (recursive) { - if (recursive) { - var nFulfilled = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nFulfilled += task.getFulfilledNumber(recursive); - } else if(task._fulfilled) { - nFulfilled += 1; - } - } - return nFulfilled; - } else { - return this._fulfilledNumber; - } -}; + var viewProjectionInv = new Matrix4(); + Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); -/** - * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getRejectedNumber = function (recursive) { - if (recursive) { - var nRejected = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nRejected += task.getRejectedNumber(recursive); - } else if(task._rejected) { - nRejected += 1; - } - } - return nRejected; - } else { - return this._rejectedNumber; - } -}; + var volumeMeshList = []; -/** - * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getSettledNumber = function (recursive) { + for (var i = 0; i < scene.lights.length; i++) { + var light = scene.lights[i]; + var uTpl = light.uniformTemplates; - if (recursive) { - var nSettled = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nSettled += task.getSettledNumber(recursive); - } else if(task._rejected || task._fulfilled) { - nSettled += 1; - } - } - return nSettled; - } else { - return this._fulfilledNumber + this._rejectedNumber; - } -}; + var volumeMesh = light.volumeMesh || light.__volumeMesh; -/** - * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getTaskNumber = function (recursive) { - if (recursive) { - var nTask = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nTask += task.getTaskNumber(recursive); - } else { - nTask += 1; - } - } - return nTask; - } else { - return this._tasks.length; - } -}; + if (volumeMesh) { + var material = volumeMesh.material; + // Volume mesh will affect the scene bounding box when rendering + // if castShadow is true + volumeMesh.castShadow = false; -var CanvasMaterial = Base.extend({ + var unknownLightType = false; + switch (light.type) { + case 'POINT_LIGHT': + material.setUniform('lightColor', uTpl.pointLightColor.value(light)); + material.setUniform('lightRange', uTpl.pointLightRange.value(light)); + material.setUniform('lightPosition', uTpl.pointLightPosition.value(light)); + break; + case 'SPOT_LIGHT': + material.setUniform('lightPosition', uTpl.spotLightPosition.value(light)); + material.setUniform('lightColor', uTpl.spotLightColor.value(light)); + material.setUniform('lightRange', uTpl.spotLightRange.value(light)); + material.setUniform('lightDirection', uTpl.spotLightDirection.value(light)); + material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light)); + material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light)); + material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light)); + break; + case 'SPHERE_LIGHT': + material.setUniform('lightColor', uTpl.sphereLightColor.value(light)); + material.setUniform('lightRange', uTpl.sphereLightRange.value(light)); + material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light)); + material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light)); + break; + case 'TUBE_LIGHT': + material.setUniform('lightColor', uTpl.tubeLightColor.value(light)); + material.setUniform('lightRange', uTpl.tubeLightRange.value(light)); + material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light)); + material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light)); + break; + default: + unknownLightType = true; + } - color: [1, 1, 1, 1], + if (unknownLightType) { + continue; + } - opacity: 1, + material.setUniform('eyePosition', eyePosition); + material.setUniform('viewProjectionInv', viewProjectionInv.array); + material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); + material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); + material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - pointSize: 0, + volumeMeshList.push(volumeMesh); - pointShape: 'rectangle' -}); + } + else { + var pass = this._fullQuadPass; + var unknownLightType = false; + // Full quad light + switch (light.type) { + case 'AMBIENT_LIGHT': + pass.material = this._ambientMat; + pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light)); + break; + case 'AMBIENT_SH_LIGHT': + pass.material = this._ambientSHMat; + pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light)); + pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light)); + break; + case 'AMBIENT_CUBEMAP_LIGHT': + pass.material = this._ambientCubemapMat; + pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light)); + pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light)); + pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light)); + break; + case 'DIRECTIONAL_LIGHT': + var hasShadow = shadowMapPass && light.castShadow; + pass.material = this._directionalLightMat; + pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + if (hasShadow) { + pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade); + } + pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light)); + pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light)); + break; + default: + // Unkonw light type + unknownLightType = true; + } + if (unknownLightType) { + continue; + } -var mat4$8 = glmatrix.mat4; -var vec3$16 = glmatrix.vec3; -var vec4$2 = glmatrix.vec4; + var passMaterial = pass.material; + passMaterial.setUniform('eyePosition', eyePosition); + passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array); + passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); + passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); + passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); -var vec4Create = vec4$2.create; + // TODO + if (shadowMapPass && light.castShadow) { + passMaterial.setUniform('lightShadowMap', light.__shadowMap); + passMaterial.setUniform('lightMatrices', light.__lightMatrices); + passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear); + passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar); -var round = Math.round; + passMaterial.setUniform('lightShadowMapSize', light.shadowResolution); + } -var PRIMITIVE_TRIANGLE = 1; -var PRIMITIVE_LINE = 2; -var PRIMITIVE_POINT = 3; + pass.renderQuad(renderer); + } + } -function PrimitivePool(constructor) { - this.ctor = constructor; + this._renderVolumeMeshList(renderer, camera, volumeMeshList); - this._data = []; + this.trigger('lightaccumulate', renderer, scene, camera); - this._size = 0; -} + lightAccumFrameBuffer.unbind(renderer); -PrimitivePool.prototype = { - pick: function () { - var data = this._data; - var size = this._size; - var obj = data[size]; - if (! obj) { - // Constructor must have no parameters - obj = new this.ctor(); - data[size] = obj; - } - this._size++; - return obj; - }, + this.trigger('afterlightaccumulate', renderer, scene, camera); - reset: function () { - this._size = 0; }, - shrink: function () { - this._data.length = this._size; - }, + _prepareLightShadow: (function () { + var worldView = new Matrix4(); + return function (renderer, scene, camera) { + var shadowCasters; - clear: function () { - this._data = []; - this._size = 0; - } -}; + shadowCasters = this._shadowCasters || (this._shadowCasters = []); + var count = 0; + var list = scene.opaqueList; + for (var i = 0; i < list.length; i++) { + if (list[i].castShadow) { + shadowCasters[count++] = list[i]; + } + } + shadowCasters.length = count; -function Triangle() { - this.vertices = [vec4Create(), vec4Create(), vec4Create()]; - this.color = vec4Create(); + for (var i = 0; i < scene.lights.length; i++) { + var light = scene.lights[i]; + var volumeMesh = light.volumeMesh || light.__volumeMesh; + if (!light.castShadow) { + continue; + } - this.depth = 0; -} + switch (light.type) { + case 'POINT_LIGHT': + case 'SPOT_LIGHT': + // Frustum culling + Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); + if (renderer.isFrustumCulled( + volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array + )) { + continue; + } -Triangle.prototype.type = PRIMITIVE_TRIANGLE; + this._prepareSingleLightShadow( + renderer, scene, camera, light, shadowCasters, volumeMesh.material + ); + break; + case 'DIRECTIONAL_LIGHT': + this._prepareSingleLightShadow( + renderer, scene, camera, light, shadowCasters, null + ); + } + } + }; + })(), -function Point() { - // Here use an array to make it more convinient to proccessing in _setPrimitive method - this.vertices = [vec4Create()]; + _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) { + switch (light.type) { + case 'POINT_LIGHT': + var shadowMaps = []; + this.shadowMapPass.renderPointLightShadow( + renderer, scene, light, casters, shadowMaps + ); + material.setUniform('lightShadowMap', shadowMaps[0]); + material.setUniform('lightShadowMapSize', light.shadowResolution); + break; + case 'SPOT_LIGHT': + var shadowMaps = []; + var lightMatrices = []; + this.shadowMapPass.renderSpotLightShadow( + renderer, scene, light, casters, lightMatrices, shadowMaps + ); + material.setUniform('lightShadowMap', shadowMaps[0]); + material.setUniform('lightMatrix', lightMatrices[0]); + material.setUniform('lightShadowMapSize', light.shadowResolution); + break; + case 'DIRECTIONAL_LIGHT': + var shadowMaps = []; + var lightMatrices = []; + var cascadeClips = []; + this.shadowMapPass.renderDirectionalLightShadow( + renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps + ); + var cascadeClipsNear = cascadeClips.slice(); + var cascadeClipsFar = cascadeClips.slice(); + cascadeClipsNear.pop(); + cascadeClipsFar.shift(); - this.color = vec4Create(); + // Iterate from far to near + cascadeClipsNear.reverse(); + cascadeClipsFar.reverse(); + lightMatrices.reverse(); - this.depth = 0; -} + light.__cascadeClipsNear = cascadeClipsNear; + light.__cascadeClipsFar = cascadeClipsFar; + light.__shadowMap = shadowMaps[0]; + light.__lightMatrices = lightMatrices; + break; + } + }, -Point.prototype.type = PRIMITIVE_POINT; + // Update light volume mesh + // Light volume mesh is rendered in light accumulate pass instead of full quad. + // It will reduce pixels significantly when local light is relatively small. + // And we can use custom volume mesh to shape the light. + // + // See "Deferred Shading Optimizations" in GDC2011 + _updateLightProxy: function (light) { + var volumeMesh; + if (light.volumeMesh) { + volumeMesh = light.volumeMesh; + } + else { + switch (light.type) { + // Only local light (point and spot) needs volume mesh. + // Directional and ambient light renders in full quad + case 'POINT_LIGHT': + case 'SPHERE_LIGHT': + var shader = light.type === 'SPHERE_LIGHT' + ? this._sphereLightShader : this._pointLightShader; + // Volume mesh created automatically + if (!light.__volumeMesh) { + light.__volumeMesh = new Mesh({ + material: this._createLightPassMat(shader), + geometry: this._lightSphereGeo, + // Disable culling + // if light volume mesh intersect camera near plane + // We need mesh inside can still be rendered + culling: false + }); + } + volumeMesh = light.__volumeMesh; + var r = light.range + (light.radius || 0); + volumeMesh.scale.set(r, r, r); + break; + case 'SPOT_LIGHT': + light.__volumeMesh = light.__volumeMesh || new Mesh({ + material: this._createLightPassMat(this._spotLightShader), + geometry: this._lightConeGeo, + culling: false + }); + volumeMesh = light.__volumeMesh; + var aspect = Math.tan(light.penumbraAngle * Math.PI / 180); + var range = light.range; + volumeMesh.scale.set(aspect * range, aspect * range, range / 2); + break; + case 'TUBE_LIGHT': + light.__volumeMesh = light.__volumeMesh || new Mesh({ + material: this._createLightPassMat(this._tubeLightShader), + geometry: this._lightCylinderGeo, + culling: false + }); + volumeMesh = light.__volumeMesh; + var range = light.range; + volumeMesh.scale.set(light.length / 2 + range, range, range); + break; + } + } + if (volumeMesh) { + volumeMesh.update(); + // Apply light transform + Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform); + var hasShadow = this.shadowMapPass && light.castShadow; + volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + } + }, -function Line() { - this.vertices = [vec4Create(), vec4Create()]; - this.color = vec4Create(); + _renderVolumeMeshList: (function () { + var worldViewProjection = new Matrix4(); + var worldView = new Matrix4(); + var preZMaterial = new Material({ + shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment')) + }); + return function (renderer, camera, volumeMeshList) { + var gl = renderer.gl; - this.depth = 0; + gl.enable(gl.DEPTH_TEST); + gl.disable(gl.CULL_FACE); + gl.blendEquation(gl.FUNC_ADD); + gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE); + gl.depthFunc(gl.LEQUAL); - this.lineWidth = 1; -} + gl.clear(gl.DEPTH_BUFFER_BIT); -Line.prototype.type = PRIMITIVE_LINE; + var viewport = renderer.viewport; + var dpr = viewport.devicePixelRatio; + var viewportUniform = [ + viewport.x * dpr, viewport.y * dpr, + viewport.width * dpr, viewport.height * dpr + ]; -function depthSortFunc(x, y) { - // Sort from far to near, which in depth of projection space is from larger to smaller - return y.depth - x.depth; -} + var windowSizeUniform = [ + this._lightAccumTex.width, + this._lightAccumTex.height + ]; -function vec3ToColorStr(v3) { - return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')'; -} + for (var i = 0; i < volumeMeshList.length; i++) { + var volumeMesh = volumeMeshList[i]; -function vec4ToColorStr(v4) { - return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')'; -} + // Frustum culling + Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); + if (renderer.isFrustumCulled( + volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array + )) { + continue; + } -var CanvasRenderer = Base.extend({ + // Use prez to avoid one pixel rendered twice + gl.colorMask(false, false, false, false); + gl.depthMask(true); + // depthMask must be enabled before clear DEPTH_BUFFER + gl.clear(gl.DEPTH_BUFFER_BIT); - canvas: null, + Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView); - _width: 100, + var preZProgram = renderer.getProgram(volumeMesh, preZMaterial); + volumeMesh.__program = preZProgram; + renderer.validateProgram(preZProgram); + preZProgram.bind(renderer); - _height: 100, + var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION; + preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); + volumeMesh.render(renderer, preZMaterial, preZProgram); - devicePixelRatio: window.devicePixelRatio || 1.0, + // Render light + gl.colorMask(true, true, true, true); + gl.depthMask(false); + var program = renderer.getProgram(volumeMesh, volumeMesh.material); + volumeMesh.__program = program; + renderer.validateProgram(program); + program.bind(renderer); - color: [0.0, 0.0, 0.0, 0.0], + var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION; + // Set some common uniforms + program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); + program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform); + program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform); - clear: true, + volumeMesh.material.bind(renderer, program); + volumeMesh.render(renderer, volumeMesh.material, program); + } - ctx: null, + gl.depthFunc(gl.LESS); + }; + })(), - // Cached primitive list, including triangle, line, point - _primitives: [], + /** + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { + this._gBuffer.dispose(renderer); - // Triangle pool - _triangles: new PrimitivePool(Triangle), + this._lightAccumFrameBuffer.dispose(renderer); + this._lightAccumTex.dispose(renderer); - // Line pool - _lines: new PrimitivePool(Line), + this._lightConeGeo.dispose(renderer); + this._lightCylinderGeo.dispose(renderer); + this._lightSphereGeo.dispose(renderer); - // Point pool - _points: new PrimitivePool(Point) -}, function () { - if (! this.canvas) { - this.canvas = document.createElement('canvas'); - } - var canvas = this.canvas; + this._fullQuadPass.dispose(renderer); + this._outputPass.dispose(renderer); - try { - this.ctx = canvas.getContext('2d'); - var ctx = this.ctx; - if (!ctx) { - throw new Error(); - } - } - catch (e) { - throw 'Error creating WebGL Context ' + e; + this._directionalLightMat.dispose(renderer); + + this.shadowMapPass.dispose(renderer); } +}); - this.resize(); -}, { +// Spherical Harmonic Helpers +var vec3$16 = glmatrix.vec3; +var sh = {}; - resize: function (width, height) { - var dpr = this.devicePixelRatio; - var canvas = this.canvas; - if (width != null) { - canvas.style.width = width + 'px'; - canvas.style.height = height + 'px'; - canvas.width = width * dpr; - canvas.height = height * dpr; +var targets$3 = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; - this._width = width; - this._height = height; - } - else { - this._width = canvas.width / dpr; - this._height = canvas.height / dpr; - } - }, +function harmonics(normal, index){ + var x = normal[0]; + var y = normal[1]; + var z = normal[2]; - getWidth: function () { - return this._width; - }, + if (index === 0) { + return 1.0; + } + else if (index === 1) { + return x; + } + else if (index === 2) { + return y; + } + else if (index === 3) { + return z; + } + else if (index === 4) { + return x * z; + } + else if (index === 5) { + return y * z; + } + else if (index === 6) { + return x * y; + } + else if (index === 7) { + return 3.0 * z * z - 1.0; + } + else { + return x * x - y * y; + } +} - getHeight: function () { - return this._height; - }, +var normalTransform = { + px: [2, 1, 0, -1, -1, 1], + nx: [2, 1, 0, 1, -1, -1], + py: [0, 2, 1, 1, -1, -1], + ny: [0, 2, 1, 1, 1, 1], + pz: [0, 1, 2, -1, -1, -1], + nz: [0, 1, 2, 1, -1, 1] +}; - getViewportAspect: function () { - return this._width / this._height; - }, +// Project on cpu. +function projectEnvironmentMapCPU(renderer, cubePixels, width, height) { + var coeff = new vendor.Float32Array(9 * 3); + var normal = vec3$16.create(); + var texel = vec3$16.create(); + var fetchNormal = vec3$16.create(); + for (var m = 0; m < 9; m++) { + var result = vec3$16.create(); + for (var k = 0; k < targets$3.length; k++) { + var pixels = cubePixels[targets$3[k]]; - render: function (scene, camera) { + var sideResult = vec3$16.create(); + var divider = 0; + var i = 0; + var transform = normalTransform[targets$3[k]]; + for (var y = 0; y < height; y++) { + for (var x = 0; x < width; x++) { - if (this.clear) { - var color = this.color; - var ctx = this.ctx; - var dpr = this.devicePixelRatio; - var w = this._width * dpr; - var h = this._height * dpr; - if (color && color[3] === 0) { - ctx.clearRect(0, 0, w, h); - } - else { - // Has transparency - if (color[3] < 1) { - ctx.clearRect(0, 0, w, h); + normal[0] = x / (width - 1.0) * 2.0 - 1.0; + // TODO Flip y? + normal[1] = y / (height - 1.0) * 2.0 - 1.0; + normal[2] = -1.0; + vec3$16.normalize(normal, normal); + + fetchNormal[0] = normal[transform[0]] * transform[3]; + fetchNormal[1] = normal[transform[1]] * transform[4]; + fetchNormal[2] = normal[transform[2]] * transform[5]; + + texel[0] = pixels[i++] / 255; + texel[1] = pixels[i++] / 255; + texel[2] = pixels[i++] / 255; + // RGBM Decode + var scale = pixels[i++] / 255 * 51.5; + texel[0] *= scale; + texel[1] *= scale; + texel[2] *= scale; + + vec3$16.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]); + // -normal.z equals cos(theta) of Lambertian + divider += -normal[2]; } - ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color); - ctx.fillRect(0, 0, w, h); } + vec3$16.scaleAndAdd(result, result, sideResult, 1 / divider); } - scene.update(); - camera.update(); + coeff[m * 3] = result[0] / 6.0; + coeff[m * 3 + 1] = result[1] / 6.0; + coeff[m * 3 + 2] = result[2] / 6.0; + } + return coeff; +} - var opaqueList = scene.opaqueList; - var transparentList = scene.transparentList; - var list = opaqueList.concat(transparentList); +/** + * @param {clay.Renderer} renderer + * @param {clay.Texture} envMap + * @param {Object} [textureOpts] + * @param {Object} [textureOpts.lod] + * @param {boolean} [textureOpts.decodeRGBM] + */ +sh.projectEnvironmentMap = function (renderer, envMap, opts) { - this.renderPass(list, camera); - }, + // TODO sRGB - renderPass: function (list, camera) { - var viewProj = mat4$8.create(); - mat4$8.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array); - var worldViewProjMat = mat4$8.create(); - var posViewSpace = vec3$16.create(); + opts = opts || {}; + opts.lod = opts.lod || 0; - var primitives = this._primitives; - var trianglesPool = this._triangles; - var linesPool = this._lines; - var pointsPool = this._points; + var skybox; + var dummyScene = new Scene(); + var size = 64; + if (envMap instanceof Texture2D) { + skybox = new Skydome({ + scene: dummyScene, + environmentMap: envMap + }); + } + else { + size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width; + skybox = new Skybox({ + scene: dummyScene, + environmentMap: envMap + }); + } + // Convert to rgbm + var width = Math.ceil(size / Math.pow(2, opts.lod)); + var height = Math.ceil(size / Math.pow(2, opts.lod)); + var rgbmTexture = new Texture2D({ + width: width, + height: height + }); + var framebuffer = new FrameBuffer(); + skybox.material.define('fragment', 'RGBM_ENCODE'); + if (opts.decodeRGBM) { + skybox.material.define('fragment', 'RGBM_DECODE'); + } + skybox.material.set('lod', opts.lod); + var envMapPass = new EnvironmentMapPass({ + texture: rgbmTexture + }); + var cubePixels = {}; + for (var i = 0; i < targets$3.length; i++) { + cubePixels[targets$3[i]] = new Uint8Array(width * height * 4); + var camera = envMapPass.getCamera(targets$3[i]); + camera.fov = 90; + framebuffer.attach(rgbmTexture); + framebuffer.bind(renderer); + renderer.render(dummyScene, camera); + renderer.gl.readPixels( + 0, 0, width, height, + Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets$3[i]] + ); + framebuffer.unbind(renderer); + } - trianglesPool.reset(); - linesPool.reset(); - pointsPool.reset(); + skybox.dispose(renderer); + framebuffer.dispose(renderer); + rgbmTexture.dispose(renderer); - var nPrimitive = 0; + return projectEnvironmentMapCPU(renderer, cubePixels, width, height); +}; - var indices = [0, 0, 0]; - var matColor = []; - for (var i = 0; i < list.length; i++) { - var renderable = list[i]; +/** + * Helpers for creating a common 3d application. + * @namespace clay.application + */ - mat4$8.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array); + // TODO createCompositor + // TODO Dispose test. geoCache test. + // TODO Tonemapping exposure + // TODO fitModel. + // TODO Particle ? +var parseColor = colorUtil.parseToFloat; - var geometry = renderable.geometry; - var material = renderable.material; - var attributes = geometry.attributes; +var EVE_NAMES = ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove', + 'touchstart', 'touchend', 'touchmove', + 'mousewheel', 'DOMMouseScroll' +]; - // alpha is default 1 - if (material.color.length == 3) { - vec3$16.copy(matColor, material.color); - matColor[3] = 1; - } - else { - vec4$2.copy(matColor, material.color); - } +/** + * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike + */ +/** + * @typedef {string|Array.} Color + */ +/** + * @typedef {HTMLDomElement|string} DomQuery + */ - var nVertex = geometry.vertexCount; - // Only support TRIANGLES, LINES, POINTS draw modes - switch (renderable.mode) { - case glenum.TRIANGLES: - if (geometry.isUseIndices()) { - var nFace = geometry.triangleCount; - for (var j = 0; j < nFace; j++) { - geometry.getFace(j, indices); +/** + * @constructor + * @alias clay.application.App3D + * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector` + * @param {Object} appNS + * @param {Function} appNS.init Initialization callback that will be called when initing app. + * You can return a promise in init to start the loop asynchronously when the promise is resolved. + * @param {Function} appNS.loop Loop callback that will be called each frame. + * @param {Function} appNS.beforeRender + * @param {Function} appNS.afterRender + * @param {number} [appNS.width] Container width. + * @param {number} [appNS.height] Container height. + * @param {number} [appNS.devicePixelRatio] + * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect + * @param {boolean} [appNS.graphic.shadow=false] If enable shadow + * @param {boolean} [appNS.graphic.linear=false] If use linear space + * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping. + * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex. + */ +function App3D(dom, appNS) { - var triangle = trianglesPool.pick(); - triangle.material = material; + appNS = appNS || {}; + appNS.graphic = appNS.graphic || {}; - var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + if (typeof dom === 'string') { + dom = document.querySelector(dom); + } - if (! clipped) { - primitives[nPrimitive++] = triangle; - } - } - } - else { - for (var j = 0; j < nVertex;) { - indices[0] = j++; - indices[1] = j++; - indices[2] = j++; + if (!dom) { throw new Error('Invalid dom'); } - var triangle = trianglesPool.pick(); - triangle.material = material; + var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS'; + var rendererOpts = {}; + isDomCanvas && (rendererOpts.canvas = dom); + appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio); - var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + var gRenderer = new Renderer(rendererOpts); + var gWidth = appNS.width || dom.clientWidth; + var gHeight = appNS.height || dom.clientHeight; - if (! clipped) { - primitives[nPrimitive++] = triangle; - } - } - } - break; - case glenum.LINES: - // LINES mode can't use face - for (var j = 0; j < nVertex;) { - indices[0] = j++; - indices[1] = j++; - var line = linesPool.pick(); - line.material = material; - line.lineWidth = renderable.lineWidth; + var gScene = new Scene(); + var gTimeline = new Timeline(); + var gShadowPass = appNS.graphic.shadow && new ShadowMapPass(); + var gRayPicking = appNS.event && new RayPicking({ + scene: gScene, + renderer: gRenderer + }); - var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor); + !isDomCanvas && dom.appendChild(gRenderer.canvas); - if (! clipped) { - primitives[nPrimitive++] = line; - } - } - break; - case glenum.POINTS: - for (var j = 0; j < nVertex; j++) { - indices[0] = j; - var point = pointsPool.pick(); - point.material = material; + gRenderer.resize(gWidth, gHeight); - var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor); + var gFrameTime = 0; + var gElapsedTime = 0; - if (! clipped) { - primitives[nPrimitive++] = point; - } - } - // POINTS mode can't use face - break; - } - } + gTimeline.start(); - trianglesPool.shrink(); - linesPool.shrink(); - pointsPool.shrink(); + Object.defineProperties(this, { + /** + * Container dom element + * @name clay.application.App3D#container + * @type {HTMLDomElement} + */ + container: { get: function () { return dom; } }, + /** + * @name clay.application.App3D#renderer + * @type {clay.Renderer} + */ + renderer: { get: function () { return gRenderer; }}, + /** + * @name clay.application.App3D#scene + * @type {clay.Renderer} + */ + scene: { get: function () { return gScene; }}, + /** + * @name clay.application.App3D#timeline + * @type {clay.Renderer} + */ + timeline: { get: function () { return gTimeline; }}, + /** + * Time elapsed since last frame. Can be used in loop to calculate the movement. + * @name clay.application.App3D#frameTime + * @type {number} + */ + frameTime: { get: function () { return gFrameTime; }}, + /** + * Time elapsed since application created. + * @name clay.application.App3D#elapsedTime + * @type {number} + */ + elapsedTime: { get: function () { return gElapsedTime; }} + }); - primitives.length = nPrimitive; + /** + * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given. + * @function + * @memberOf {clay.application.App3D} + * @param {number} [width] + * @param {number} [height] + */ + this.resize = function (width, height) { + gWidth = width || appNS.width || dom.clientWidth; + gHeight = height || dom.height || dom.clientHeight; + gRenderer.resize(gWidth, gHeight); + }; - primitives.sort(depthSortFunc); - this._drawPrimitives(primitives); - }, + /** + * Dispose the application + * @function + */ + this.dispose = function () { + this._disposed = true; - _setPrimitive: (function () { - var vertexColor = vec4Create(); - return function (primitive, indices, size, attributes, worldViewProjMat, matColor) { - var colorAttrib = attributes.color; - var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0; - var priColor = primitive.color; + if (appNS.dispose) { + appNS.dispose(this); + } + gTimeline.stop(); + gRenderer.disposeScene(gScene); + gShadowPass && gShadowPass.dispose(gRenderer); - primitive.depth = 0; - if (useVertexColor) { - vec4$2.set(priColor, 0, 0, 0, 0); - } + dom.innerHTML = ''; + EVE_NAMES.forEach(function (eveType) { + this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType)); + }); + }; - var clipped = true; + gRayPicking && this._initMouseEvents(gRayPicking); - var percent = 1 / size; - for (var i = 0; i < size; i++) { - var coord = primitive.vertices[i]; - attributes.position.get(indices[i], coord); - coord[3] = 1; - vec4$2.transformMat4(coord, coord, worldViewProjMat); - if (useVertexColor) { - colorAttrib.get(indices[i], vertexColor); - // Average vertex color - // Each primitive only call fill or stroke once - // So color must be the same - vec4$2.scaleAndAdd(priColor, priColor, vertexColor, percent); - } + this._geoCache = new LRU$1(20); + this._texCache = new LRU$1(20); - // Clipping - var x = coord[0]; - var y = coord[1]; - var z = coord[2]; - var w = coord[3]; + // Do init the application. + var initPromise = Promise.resolve(appNS.init && appNS.init(this)); + // Use the inited camera. + gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); - // TODO Point clipping - if (x > -w && x < w && y > -w && y < w && z > -w && z < w) { - clipped = false; - } + var gTexturesList = {}; + var gGeometriesList = {}; - var invW = 1 / w; - coord[0] = x * invW; - coord[1] = y * invW; - coord[2] = z * invW; - // Use primitive average depth; - primitive.depth += coord[2]; - } + if (!appNS.loop) { + console.warn('Miss loop method.'); + } - if (! clipped) { - primitive.depth /= size; + var self = this; + initPromise.then(function () { + appNS.loop && gTimeline.on('frame', function (frameTime) { + gFrameTime = frameTime; + gElapsedTime += frameTime; + appNS.loop(self); - if (useVertexColor) { - vec4$2.mul(priColor, priColor, matColor); - } - else { - vec4$2.copy(priColor, matColor); - } - } + gScene.update(); - return clipped; - } - })(), + self._updateGraphicOptions(appNS.graphic, gScene.opaqueList, false); + self._updateGraphicOptions(appNS.graphic, gScene.transparentList, false); + var skyboxList = []; + gScene.skybox && skyboxList.push(gScene.skybox); + gScene.skydome && skyboxList.push(gScene.skydome); + self._updateGraphicOptions(appNS.graphic, skyboxList, true); - _drawPrimitives: function (primitives) { - var ctx = this.ctx; - ctx.save(); + gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); + // Render shadow pass + gShadowPass && gShadowPass.render(gRenderer, gScene, null, true); - var prevMaterial; + appNS.beforeRender && appNS.beforeRender(self); + self._doRender(gRenderer, gScene, true); + appNS.afterRender && appNS.afterRender(self); - var dpr = this.devicePixelRatio; - var width = this._width * dpr; - var height = this._height * dpr; - var halfWidth = width / 2; - var halfHeight = height / 2; + // Mark all resources unused; + markUnused(gTexturesList); + markUnused(gGeometriesList); - var prevLineWidth; - var prevStrokeColor; + // Collect resources used in this frame. + var newTexturesList = []; + var newGeometriesList = []; + collectResources(gScene, newTexturesList, newGeometriesList); - for (var i = 0; i < primitives.length; i++) { - var primitive = primitives[i]; - var vertices = primitive.vertices; + // Dispose those unsed resources. + checkAndDispose(gRenderer, gTexturesList); + checkAndDispose(gRenderer, gGeometriesList); - var primitiveType = primitive.type; - var material = primitive.material; - if (material !== prevMaterial) { - // Set material - ctx.globalAlpha = material.opacity; - prevMaterial = material; - } + gTexturesList = newTexturesList; + gGeometriesList = newGeometriesList; + }); + }); +} - var colorStr = vec4ToColorStr(primitive.color); - switch (primitiveType) { - case PRIMITIVE_TRIANGLE: - var v0 = vertices[0]; - var v1 = vertices[1]; - var v2 = vertices[2]; - ctx.fillStyle = colorStr; - ctx.beginPath(); - ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); - ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); - ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight); - ctx.closePath(); - ctx.fill(); - break; - case PRIMITIVE_LINE: - var v0 = vertices[0]; - var v1 = vertices[1]; - var lineWidth = primitive.lineWidth; - if (prevStrokeColor !== colorStr) { - prevStrokeColor = ctx.strokeStyle = colorStr; - } - if (lineWidth !== prevLineWidth) { - ctx.lineWidth = prevLineWidth = lineWidth; - } - ctx.beginPath(); - ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); - ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); - ctx.stroke(); - break; - case PRIMITIVE_POINT: - var pointSize = material.pointSize; - var pointShape = material.pointShape; - var halfSize = pointSize / 2; - if (pointSize > 0) { - var v0 = vertices[0]; - var cx = (v0[0] + 1) * halfWidth; - var cy = (-v0[1] + 1) * halfHeight; +function isImageLikeElement(val) { + return val instanceof Image + || val instanceof HTMLCanvasElement + || val instanceof HTMLVideoElement; +} - ctx.fillStyle = colorStr; - if (pointShape === 'rectangle') { - ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize); - } - else if (pointShape === 'circle') { - ctx.beginPath(); - ctx.arc(cx, cy, halfSize, 0, Math.PI * 2); - ctx.fill(); - } - } - break; - } - } +function getKeyFromImageLike(val) { + typeof val === 'string' + ? val : (val.__key__ || (val.__key__ = util$1.genGUID())); +} - ctx.restore(); - }, +function makeHandlerName(eveType) { + return '_' + eveType + 'Handler'; +} - dispose: function () { - this._triangles.clear(); - this._lines.clear(); - this._points.clear(); - this._primitives = []; +function packageEvent(eventType, pickResult, offsetX, offsetY, wheelDelta) { + var event = util$1.clone(pickResult); + event.type = eventType; + event.offsetX = offsetX; + event.offsetY = offsetY; + if (wheelDelta !== null) { + event.wheelDelta = wheelDelta; + } + return event; +} - this.ctx = null; - this.canvas = null; +function bubblingEvent(target, event) { + while (target && !event.cancelBubble) { + target.trigger(event.type, event); + target = target.getParent(); } -}); +} -// PENDING -// Use topological sort ? +App3D.prototype._initMouseEvents = function (rayPicking) { + var dom = this.container; -/** - * Node of graph based post processing. - * - * @constructor clay.compositor.Node - * @extends clay.core.Base - * - */ -var Node$1 = Base.extend(function () { - return /** @lends clay.compositor.Node# */ { - /** - * @type {string} - */ - name: '', + var oldTarget = null; + EVE_NAMES.forEach(function (_eveType) { + dom.addEventListener(_eveType, this[makeHandlerName(_eveType)] = function (e) { + if (!rayPicking.camera) { // Not have camera yet. + return; + } + e.preventDefault(); - /** - * Input links, will be updated by the graph - * @example: - * inputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - inputLinks: {}, + var box = dom.getBoundingClientRect(); + var offsetX, offsetY; + var eveType = _eveType; + + if (eveType.indexOf('touch') >= 0) { + var touch = eveType != 'touchend' + ? e.targetTouches[0] + : e.changedTouches[0]; + if (eveType === 'touchstart') { + eveType = 'mousedown'; + } + else if (eveType === 'touchend') { + eveType = 'mouseup'; + } + else if (eveType === 'touchmove') { + eveType = 'mousemove'; + } + offsetX = touch.clientX - box.left; + offsetY = touch.clientY - box.top; + } + else { + offsetX = e.clientX - box.left; + offsetY = e.clientY - box.top; + } - /** - * Output links, will be updated by the graph - * @example: - * outputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - outputLinks: {}, + var pickResult = rayPicking.pick(offsetX, offsetY); - // Save the output texture of previous frame - // Will be used when there exist a circular reference - _prevOutputTextures: {}, - _outputTextures: {}, + var delta; + if (eveType === 'DOMMouseScroll' || eveType === 'mousewheel') { + delta = (e.wheelDelta) ? e.wheelDelta / 120 : -(e.detail || 0) / 3; + } - // Example: { name: 2 } - _outputReferences: {}, + if (pickResult) { + // Just ignore silent element. + if (pickResult.target.silent) { + return; + } - _rendering: false, - // If rendered in this frame - _rendered: false, + if (eveType === 'mousemove') { + // PENDING touchdown should trigger mouseover event ? + var targetChanged = pickResult.target !== oldTarget; + if (targetChanged) { + oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', { + target: oldTarget + }, offsetX, offsetY)); + } + bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY)); + if (targetChanged) { + bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY)); + } + } + else { + bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY, delta)); + } + oldTarget = pickResult.target; + } + else if (oldTarget) { + bubblingEvent(oldTarget, packageEvent('mouseout', { + target: oldTarget + }, offsetX, offsetY)); + oldTarget = null; + } + }); + }, this); +}; - _compositor: null - }; -}, -/** @lends clay.compositor.Node.prototype */ -{ +App3D.prototype._updateGraphicOptions = function (graphicOpts, list, isSkybox) { + var enableTonemapping = !!graphicOpts.tonemapping; + var isLinearSpace = !!graphicOpts.linear; - // TODO Remove parameter function callback - updateParameter: function (outputName, renderer) { - var outputInfo = this.outputs[outputName]; - var parameters = outputInfo.parameters; - var parametersCopy = outputInfo._parametersCopy; - if (!parametersCopy) { - parametersCopy = outputInfo._parametersCopy = {}; + var prevMaterial; + + for (var i = 0; i < list.length; i++) { + var mat = list[i].material; + if (mat === prevMaterial) { + continue; } - if (parameters) { - for (var key in parameters) { - if (key !== 'width' && key !== 'height') { - parametersCopy[key] = parameters[key]; - } + + enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING'); + if (isLinearSpace) { + var decodeSRGB = true; + if (isSkybox && mat.get('environmentMap') && !mat.get('environmentMap').sRGB) { + decodeSRGB = false; } - } - var width, height; - if (parameters.width instanceof Function) { - width = parameters.width.call(this, renderer); - } - else { - width = parameters.width; - } - if (parameters.height instanceof Function) { - height = parameters.height.call(this, renderer); + decodeSRGB && mat.define('fragment', 'SRGB_DECODE'); + mat.define('fragment', 'SRGB_ENCODE'); } else { - height = parameters.height; - } - if ( - parametersCopy.width !== width - || parametersCopy.height !== height - ) { - if (this._outputTextures[outputName]) { - this._outputTextures[outputName].dispose(renderer.gl); - } + mat.undefine('fragment', 'SRGB_DECODE'); + mat.undefine('fragment', 'SRGB_ENCODE'); } - parametersCopy.width = width; - parametersCopy.height = height; - return parametersCopy; - }, + prevMaterial = mat; + } +}; - /** - * Set parameter - * @param {string} name - * @param {} value - */ - setParameter: function (name, value) {}, - /** - * Get parameter value - * @param {string} name - * @return {} - */ - getParameter: function (name) {}, - /** - * Set parameters - * @param {Object} obj - */ - setParameters: function (obj) { - for (var name in obj) { - this.setParameter(name, obj[name]); - } - }, +App3D.prototype._doRender = function (renderer, scene) { + var camera = scene.getMainCamera(); + camera.aspect = renderer.getViewportAspect(); + renderer.render(scene); +}; - render: function () {}, - getOutput: function (renderer /*optional*/, name) { - if (name == null) { - // Return the output texture without rendering - name = renderer; - return this._outputTextures[name]; - } - var outputInfo = this.outputs[name]; - if (!outputInfo) { - return ; - } +function markUnused(resourceList) { + for (var i = 0; i < resourceList.length; i++) { + resourceList[i].__used__ = 0; + } +} - // Already been rendered in this frame - if (this._rendered) { - // Force return texture in last frame - if (outputInfo.outputLastFrame) { - return this._prevOutputTextures[name]; - } - else { - return this._outputTextures[name]; - } - } - else if ( - // TODO - this._rendering // Solve Circular Reference - ) { - if (!this._prevOutputTextures[name]) { - // Create a blank texture at first pass - this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {}); - } - return this._prevOutputTextures[name]; +function checkAndDispose(renderer, resourceList) { + for (var i = 0; i < resourceList.length; i++) { + if (!resourceList[i].__used__) { + resourceList[i].dispose(renderer); } + } +} - this.render(renderer); - - return this._outputTextures[name]; - }, +function updateUsed(resource, list) { + resource.__used__ = resource.__used__ || 0; + resource.__used__++; + if (resource.__used__ === 1) { + // Don't push to the list twice. + list.push(resource); + } +} +function collectResources(scene, textureResourceList, geometryResourceList) { + function trackQueue(queue) { + var prevMaterial; + var prevGeometry; + for (var i = 0; i < queue.length; i++) { + var renderable = queue[i]; + var geometry = renderable.geometry; + var material = renderable.material; - removeReference: function (outputName) { - this._outputReferences[outputName]--; - if (this._outputReferences[outputName] === 0) { - var outputInfo = this.outputs[outputName]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[outputName]) { - this._compositor.releaseTexture(this._prevOutputTextures[outputName]); + // TODO optimize!! + if (material !== prevMaterial) { + var textureUniforms = material.getTextureUniforms(); + for (var u = 0; u < textureUniforms.length; u++) { + var uniformName = textureUniforms[u]; + var val = material.uniforms[uniformName].value; + if (!val) { + continue; + } + if (val instanceof Texture) { + updateUsed(val, textureResourceList); + } + else if (val instanceof Array) { + for (var k = 0; k < val.length; k++) { + if (val[k] instanceof Texture) { + updateUsed(val[k], textureResourceList); + } + } + } } - this._prevOutputTextures[outputName] = this._outputTextures[outputName]; } - else { - // Output of this node have alreay been used by all other nodes - // Put the texture back to the pool. - this._compositor.releaseTexture(this._outputTextures[outputName]); + if (geometry !== prevGeometry) { + updateUsed(geometry, geometryResourceList); } - } - }, - - link: function (inputPinName, fromNode, fromPinName) { - // The relationship from output pin to input pin is one-on-multiple - this.inputLinks[inputPinName] = { - node: fromNode, - pin: fromPinName - }; - if (!fromNode.outputLinks[fromPinName]) { - fromNode.outputLinks[fromPinName] = []; + prevMaterial = material; + prevGeometry = geometry; } - fromNode.outputLinks[fromPinName].push({ - node: this, - pin: inputPinName - }); - - // Enabled the pin texture in shader - this.pass.material.enableTexture(inputPinName); - }, + } - clear: function () { - this.inputLinks = {}; - this.outputLinks = {}; - }, + trackQueue(scene.opaqueList); + trackQueue(scene.transparentList); - updateReference: function (outputName) { - if (!this._rendering) { - this._rendering = true; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - link.node.updateReference(link.pin); - } - this._rendering = false; + for (var k = 0; k < scene.lights.length; k++) { + // Track AmbientCubemap + if (scene.lights[k].cubemap) { + updateUsed(scene.lights[k].cubemap, textureResourceList); } - if (outputName) { - this._outputReferences[outputName] ++; + } +} +/** + * Load a texture from image or string. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} + * @param {boolean} [opts.convertToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} + * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} + * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} + * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} + * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} + * @param {number} [opts.exposure] Only be used when source is a HDR image. + * @param {boolean} [useCache] If use cache. + * @return {Promise} + * @example + * app.loadTexture('diffuseMap.jpg') + * .then(function (texture) { + * material.set('diffuseMap', texture); + * }); + */ +App3D.prototype.loadTexture = function (urlOrImg, opts, useCache) { + var self = this; + var key = getKeyFromImageLike(urlOrImg); + if (useCache) { + if (this._texCache.get(key)) { + return this._texCache.get(key); } - }, - - beforeFrame: function () { - this._rendered = false; + } + // TODO Promise ? + var promise = new Promise(function (resolve, reject) { + var texture = self.loadTextureSync(urlOrImg, opts); + if (!texture.isRenderable()) { + texture.success(function () { + if (self._disposed) { + return; + } + resolve(texture); + }); + texture.error(function () { + if (self._disposed) { + return; + } + reject(); + }); + } + else { + resolve(texture); + } + }); + if (useCache) { + this._texCache.put(key, promise); + } + return promise; +}; - for (var name in this.outputLinks) { - this._outputReferences[name] = 0; +function nearestPowerOfTwo(val) { + return Math.pow(2, Math.round(Math.log(val) / Math.LN2)); +} +function convertTextureToPowerOfTwo(texture) { + if ((texture.wrapS === Texture.REPEAT || texture.wrapT === Texture.REPEAT) + && texture.image + ) { + // var canvas = document.createElement('canvas'); + var width = nearestPowerOfTwo(texture.width); + var height = nearestPowerOfTwo(texture.height); + if (width !== texture.width || height !== texture.height) { + var canvas = document.createElement('canvas'); + canvas.width = width; + canvas.height = height; + var ctx = canvas.getContext('2d'); + ctx.drawImage(texture.image, 0, 0, width, height); + canvas.srcImage = texture.image; + texture.image = canvas; + texture.dirty(); } - }, + } +} - afterFrame: function () { - // Put back all the textures to pool - for (var name in this.outputLinks) { - if (this._outputReferences[name] > 0) { - var outputInfo = this.outputs[name]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[name]) { - this._compositor.releaseTexture(this._prevOutputTextures[name]); - } - this._prevOutputTextures[name] = this._outputTextures[name]; - } - else { - this._compositor.releaseTexture(this._outputTextures[name]); - } +/** + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} + * @param {boolean} [opts.convertToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} + * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} + * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} + * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} + * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} + * @param {number} [opts.exposure] Only be used when source is a HDR image. + * @return {clay.Texture2D} + * @example + * var texture = app.loadTexture('diffuseMap.jpg', { + * anisotropic: 8, + * flipY: false + * }); + * material.set('diffuseMap', texture); + */ +App3D.prototype.loadTextureSync = function (urlOrImg, opts) { + var texture = new Texture2D(opts); + if (typeof urlOrImg === 'string') { + if (urlOrImg.match(/.hdr$|^data:application\/octet-stream/)) { + texture = textureUtil.loadTexture(urlOrImg, { + exposure: opts && opts.exposure, + fileType: 'hdr' + }, function () { + texture.dirty(); + texture.trigger('success'); + }); + for (var key in opts) { + texture[key] = opts[key]; + } + } + else { + texture.load(urlOrImg); + if (opts && opts.convertToPOT) { + texture.success(function () { + convertTextureToPowerOfTwo(texture); + }); } } } -}); + else if (isImageLikeElement(urlOrImg)) { + texture.image = urlOrImg; + texture.dynamic = urlOrImg instanceof HTMLVideoElement; + } + return texture; +}; /** - * @constructor clay.compositor.Graph - * @extends clay.core.Base - */ -var Graph = Base.extend(function () { - return /** @lends clay.compositor.Graph# */ { - /** - * @type {Array.} - */ - nodes: [] - }; -}, -/** @lends clay.compositor.Graph.prototype */ -{ - - /** - * Mark to update - */ - dirty: function () { - this._dirty = true; - }, - /** - * @param {clay.compositor.Node} node - */ - addNode: function (node) { - - if (this.nodes.indexOf(node) >= 0) { - return; + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=false] If flipY. See {@link clay.Texture.flipY} + * @return {Promise} + * @example + * app.loadTextureCube({ + * px: 'skybox/px.jpg', py: 'skybox/py.jpg', pz: 'skybox/pz.jpg', + * nx: 'skybox/nx.jpg', ny: 'skybox/ny.jpg', nz: 'skybox/nz.jpg' + * }).then(function (texture) { + * skybox.setEnvironmentMap(texture); + * }) + */ +App3D.prototype.loadTextureCube = function (imgList, opts) { + var textureCube = this.loadTextureCubeSync(imgList, opts); + return new Promise(function (resolve, reject) { + if (textureCube.isRenderable()) { + resolve(textureCube); } + else { + textureCube.success(function () { + resolve(textureCube); + }).error(function () { + reject(); + }); + } + }); +}; - this.nodes.push(node); +/** + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=false] If flipY. See {@link clay.Texture.flipY} + * @return {clay.TextureCube} + * @example + * var texture = app.loadTextureCubeSync({ + * px: 'skybox/px.jpg', py: 'skybox/py.jpg', pz: 'skybox/pz.jpg', + * nx: 'skybox/nx.jpg', ny: 'skybox/ny.jpg', nz: 'skybox/nz.jpg' + * }); + * skybox.setEnvironmentMap(texture); + */ +App3D.prototype.loadTextureCubeSync = function (imgList, opts) { + opts = opts || {}; + opts.flipY = opts.flipY || false; + var textureCube = new TextureCube(opts); + if (!imgList || !imgList.px || !imgList.nx || !imgList.py || !imgList.ny || !imgList.pz || !imgList.nz) { + throw new Error('Invalid cubemap format. Should be an object including px,nx,py,ny,pz,nz'); + } + if (typeof imgList.px === 'string') { + textureCube.load(imgList); + } + else { + textureCube.image = util$1.clone(imgList); + } + return textureCube; +}; - this._dirty = true; - }, - /** - * @param {clay.compositor.Node|string} node - */ - removeNode: function (node) { - if (typeof node === 'string') { - node = this.getNodeByName(node); - } - var idx = this.nodes.indexOf(node); - if (idx >= 0) { - this.nodes.splice(idx, 1); - this._dirty = true; - } - }, - /** - * @param {string} name - * @return {clay.compositor.Node} - */ - getNodeByName: function (name) { - for (var i = 0; i < this.nodes.length; i++) { - if (this.nodes[i].name === name) { - return this.nodes[i]; +/** + * Create a material. + * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms. + * Uniforms can be `color`, `alpha` `diffuseMap` etc. + * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow. + * @param {boolean} [transparent=false] If material is transparent. + * @param {boolean} [convertTextureToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @return {clay.Material} + */ +App3D.prototype.createMaterial = function (matConfig) { + matConfig = matConfig || {}; + matConfig.shader = matConfig.shader || 'clay.standardMR'; + var shader = matConfig.shader instanceof Shader ? matConfig.shader : library.get(matConfig.shader); + var material = new Material({ + shader: shader + }); + function makeTextureSetter(key) { + return function (texture) { + material.setUniform(key, texture); + }; + } + for (var key in matConfig) { + if (material.uniforms[key]) { + var val = matConfig[key]; + if ((material.uniforms[key].type === 't' || isImageLikeElement(val)) + && !(val instanceof Texture) + ) { + // Try to load a texture. + this.loadTexture(val, { + convertToPOT: matConfig.convertTextureToPOT + }).then(makeTextureSetter(key)); + } + else { + material.setUniform(key, val); } } - }, - /** - * Update links of graph - */ - update: function () { - for (var i = 0; i < this.nodes.length; i++) { - this.nodes[i].clear(); - } - // Traverse all the nodes and build the graph - for (var i = 0; i < this.nodes.length; i++) { - var node = this.nodes[i]; + } - if (!node.inputs) { - continue; - } - for (var inputName in node.inputs) { - if (!node.inputs[inputName]) { - continue; - } - if (node.pass && !node.pass.material.isUniformEnabled(inputName)) { - console.warn('Pin ' + node.name + '.' + inputName + ' not used.'); - continue; - } - var fromPinInfo = node.inputs[inputName]; + if (matConfig.transparent) { + matConfig.depthMask = false; + matConfig.transparent = true; + } + return material; +}; - var fromPin = this.findPin(fromPinInfo); - if (fromPin) { - node.link(inputName, fromPin.node, fromPin.pin); - } - else { - if (typeof fromPinInfo === 'string') { - console.warn('Node ' + fromPinInfo + ' not exist'); - } - else { - console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist'); - } - } - } - } - }, +/** + * Create a cube mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of cube. + * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a white cube. + * app.createCube() + */ +App3D.prototype.createCube = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; + } + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv, subdiv]; + } - findPin: function (input) { - var node; - // Try to take input as a directly a node - if (typeof input === 'string' || input instanceof Node$1) { - input = { - node: input - }; - } + var geoKey = 'cube-' + subdiv.join('-'); + var cube = this._geoCache.get(geoKey); + if (!cube) { + cube = new Cube$1({ + widthSegments: subdiv[0], + heightSegments: subdiv[1], + depthSegments: subdiv[2] + }); + cube.generateTangents(); + this._geoCache.put(geoKey, cube); + } + return this.createMesh(cube, material, parentNode); +}; - if (typeof input.node === 'string') { - for (var i = 0; i < this.nodes.length; i++) { - var tmp = this.nodes[i]; - if (tmp.name === input.node) { - node = tmp; - } - } - } - else { - node = input.node; - } - if (node) { - var inputPin = input.pin; - if (!inputPin) { - // Use first pin defaultly - if (node.outputs) { - inputPin = Object.keys(node.outputs)[0]; - } - } - if (node.outputs[inputPin]) { - return { - node: node, - pin: inputPin - }; - } - } +/** + * Create a cube mesh that camera is inside the cube. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of cube. + * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a white cube inside. + * app.createCubeInside() + */ +App3D.prototype.createCubeInside = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; } -}); + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv, subdiv]; + } + var geoKey = 'cubeInside-' + subdiv.join('-'); + var cube = this._geoCache.get(geoKey); + if (!cube) { + cube = new Cube$1({ + inside: true, + widthSegments: subdiv[0], + heightSegments: subdiv[1], + depthSegments: subdiv[2] + }); + cube.generateTangents(); + this._geoCache.put(geoKey, cube); + } + + return this.createMesh(cube, material, parentNode); +}; /** - * Compositor provide graph based post processing - * - * @constructor clay.compositor.Compositor - * @extends clay.compositor.Graph - * + * Create a sphere mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {number} [subdivision=20] Subdivision of sphere. + * @return {clay.Mesh} + * @example + * // Create a semi-transparent sphere. + * app.createSphere({ + * color: [0, 0, 1], + * transparent: true, + * alpha: 0.5 + * }) */ -var Compositor = Graph.extend(function() { - return { - // Output node - _outputs: [], +App3D.prototype.createSphere = function (material, parentNode, subdivision) { + if (subdivision == null) { + subdivision = 20; + } + var geoKey = 'sphere-' + subdivision; + var sphere = this._geoCache.get(geoKey); + if (!sphere) { + sphere = new Sphere$1({ + widthSegments: subdivision * 2, + heightSegments: subdivision + }); + sphere.generateTangents(); + this._geoCache.put(geoKey, sphere); + } + return this.createMesh(sphere, material, parentNode); +}; - _texturePool: new TexturePool(), +/** + * Create a plane mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of plane. + * Can be a number to represent both width and height dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a red color plane. + * app.createPlane({ + * color: [1, 0, 0] + * }) + */ +App3D.prototype.createPlane = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; + } + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv]; + } + var geoKey = 'plane-' + subdiv.join('-'); + var planeGeo = this._geoCache.get(geoKey); + if (!planeGeo) { + planeGeo = new Plane$3({ + widthSegments: subdiv[0], + heightSegments: subdiv[1] + }); + planeGeo.generateTangents(); + this._geoCache.put(geoKey, planeGeo); + } + return this.createMesh(planeGeo, material, parentNode); +}; - _frameBuffer: new FrameBuffer({ - depthBuffer: false - }) - }; -}, -/** @lends clay.compositor.Compositor.prototype */ -{ - addNode: function(node) { - Graph.prototype.addNode.call(this, node); - node._compositor = this; - }, - /** - * @param {clay.Renderer} renderer - */ - render: function(renderer, frameBuffer) { - if (this._dirty) { - this.update(); - this._dirty = false; +/** + * Create mesh with parametric surface function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Object} generator + * @param {Function} generator.x + * @param {Function} generator.y + * @param {Function} generator.z + * @param {Array} [generator.u=[0, 1, 0.05]] + * @param {Array} [generator.v=[0, 1, 0.05]] + * @return {clay.Mesh} + */ +App3D.prototype.createParametricSurface = function (material, parentNode, generator) { + var geo = new ParametricSurface$1({ + generator: generator + }); + geo.generateTangents(); + return this.createMesh(geo, material, parentNode); +}; - this._outputs.length = 0; - for (var i = 0; i < this.nodes.length; i++) { - if (!this.nodes[i].outputs) { - this._outputs.push(this.nodes[i]); - } - } - } - for (var i = 0; i < this.nodes.length; i++) { - // Update the reference number of each output texture - this.nodes[i].beforeFrame(); - } +/** + * Create a general mesh with given geometry instance and material config. + * @param {clay.Geometry} geometry + * @return {clay.Mesh} + */ +App3D.prototype.createMesh = function (geometry, mat, parentNode) { + var mesh = new Mesh({ + geometry: geometry, + material: mat instanceof Material ? mat : this.createMaterial(mat) + }); + parentNode = parentNode || this.scene; + parentNode.add(mesh); + return mesh; +}; - for (var i = 0; i < this._outputs.length; i++) { - this._outputs[i].updateReference(); - } +/** + * Create an empty node + * @param {clay.Node} parentNode + * @return {clay.Node} + */ +App3D.prototype.createNode = function (parentNode) { + var node = new Node(); + parentNode = parentNode || this.scene; + parentNode.add(node); + return node; +}; - for (var i = 0; i < this._outputs.length; i++) { - this._outputs[i].render(renderer, frameBuffer); +/** + * Create a perspective or orthographic camera and add it to the scene. + * @param {Array.|clay.math.Vector3} position + * @param {Array.|clay.math.Vector3} target + * @param {string} [type="perspective"] Can be 'perspective' or 'orthographic'(in short 'ortho') + * @return {clay.camera.Perspective} + */ +App3D.prototype.createCamera = function (position, target, type) { + var CameraCtor; + if (type === 'ortho' || type === 'orthographic') { + CameraCtor = Orthographic$1; + } + else { + if (type && type !== 'perspective') { + console.error('Unkown camera type ' + type + '. Use default perspective camera'); } + CameraCtor = Perspective$1; + } - for (var i = 0; i < this.nodes.length; i++) { - // Clear up - this.nodes[i].afterFrame(); - } - }, + var camera = new CameraCtor(); + if (position instanceof Vector3) { + camera.position.copy(position); + } + else if (position instanceof Array) { + camera.position.setArray(position); + } - allocateTexture: function (parameters) { - return this._texturePool.get(parameters); - }, + if (target instanceof Array) { + target = new Vector3(target[0], target[1], target[2]); + } + if (target instanceof Vector3) { + camera.lookAt(target); + } - releaseTexture: function (parameters) { - this._texturePool.put(parameters); - }, + this.scene.add(camera); - getFrameBuffer: function () { - return this._frameBuffer; - }, + return camera; +}; - /** - * Dispose compositor - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { - this._texturePool.clear(renderer); +/** + * Create a directional light and add it to the scene. + * @param {Array.|clay.math.Vector3} dir A Vector3 or array to represent the direction. + * @param {Color} [color='#fff'] Color of directional light, default to be white. + * @param {number} [intensity] Intensity of directional light, default to be 1. + * + * @example + * app.createDirectionalLight([-1, -1, -1], '#fff', 2); + */ +App3D.prototype.createDirectionalLight = function (dir, color, intensity) { + var light = new DirectionalLight(); + if (dir instanceof Vector3) { + dir = dir.array; } -}); + light.position.setArray(dir).negate(); + light.lookAt(Vector3.ZERO); + if (typeof color === 'string') { + color = parseColor(color); + } + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); + + this.scene.add(light); + return light; +}; /** - * @constructor clay.compositor.SceneNode - * @extends clay.compositor.Node + * Create a spot light and add it to the scene. + * @param {Array.|clay.math.Vector3} position Position of the spot light. + * @param {Array.|clay.math.Vector3} [target] Target position where spot light points to. + * @param {number} [range=20] Falloff range of spot light. Default to be 20. + * @param {Color} [color='#fff'] Color of spot light, default to be white. + * @param {number} [intensity=1] Intensity of spot light, default to be 1. + * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line. + * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line. + * + * @example + * app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900); */ -var SceneNode$1 = Node$1.extend( -/** @lends clay.compositor.SceneNode# */ -{ - name: 'scene', - /** - * @type {clay.Scene} - */ - scene: null, - /** - * @type {clay.Camera} - */ - camera: null, - /** - * @type {boolean} - */ - autoUpdateScene: true, - /** - * @type {boolean} - */ - preZ: false +App3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) { + var light = new SpotLight(); + light.position.setArray(position instanceof Vector3 ? position.array : position); -}, function() { - this.frameBuffer = new FrameBuffer(); -}, { - render: function(renderer) { + if (target instanceof Array) { + target = new Vector3(target[0], target[1], target[2]); + } + if (target instanceof Vector3) { + light.lookAt(target); + } - this._rendering = true; - var _gl = renderer.gl; + if (typeof color === 'string') { + color = parseColor(color); + } + range != null && (light.range = range); + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); + umbraAngle != null && (light.umbraAngle = umbraAngle); + penumbraAngle != null && (light.penumbraAngle = penumbraAngle); - this.trigger('beforerender'); + this.scene.add(light); - var renderInfo; + return light; +}; - if (!this.outputs) { +/** + * Create a point light. + * @param {Array.|clay.math.Vector3} position Position of point light.. + * @param {number} [range=100] Falloff range of point light. + * @param {Color} [color='#fff'] Color of point light. + * @param {number} [intensity=1] Intensity of point light. + */ +App3D.prototype.createPointLight = function (position, range, color, intensity) { + var light = new PointLight(); + light.position.setArray(position instanceof Vector3 ? position.array : position); - renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); + if (typeof color === 'string') { + color = parseColor(color); + } + range != null && (light.range = range); + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); - } - else { + this.scene.add(light); - var frameBuffer = this.frameBuffer; - for (var name in this.outputs) { - var parameters = this.updateParameter(name, renderer); - var outputInfo = this.outputs[name]; - var texture = this._compositor.allocateTexture(parameters); - this._outputTextures[name] = texture; + return light; +}; - var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; - if (typeof(attachment) == 'string') { - attachment = _gl[attachment]; - } - frameBuffer.attach(texture, attachment); - } - frameBuffer.bind(renderer); +/** + * Create a ambient light. + * @param {Color} [color='#fff'] Color of ambient light. + * @param {number} [intensity=1] Intensity of ambient light. + */ +App3D.prototype.createAmbientLight = function (color, intensity) { + var light = new AmbientLight(); - // MRT Support in chrome - // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html - var ext = renderer.getGLExtension('EXT_draw_buffers'); - if (ext) { - var bufs = []; - for (var attachment in this.outputs) { - attachment = parseInt(attachment); - if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) { - bufs.push(attachment); - } - } - ext.drawBuffersEXT(bufs); - } + if (typeof color === 'string') { + color = parseColor(color); + } + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); - // Always clear - // PENDING - renderer.saveClear(); - renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT; - renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); - renderer.restoreClear(); + this.scene.add(light); - frameBuffer.unbind(renderer); - } + return light; +}; - this.trigger('afterrender', renderInfo); +/** + * Create an cubemap ambient light and an spherical harmonic ambient light + * for specular and diffuse lighting in PBR rendering + * @param {ImageLike|TextureCube} [envImage] Panorama environment image, HDR format is better. Or a pre loaded texture cube + * @param {number} [specularIntenstity=0.7] Intensity of specular light. + * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light. + * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR. + * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering. + */ +App3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) { + var self = this; + if (exposure == null) { + exposure = 1; + } + if (prefilteredCubemapSize == null) { + prefilteredCubemapSize = 32; + } - this._rendering = false; - this._rendered = true; + var scene = this.scene; + + var loadPromise; + if (envImage instanceof TextureCube) { + loadPromise = envImage.isRenderable() + ? Promise.resolve(envImage) + : new Promise(function (resolve, reject) { + envImage.success(function () { + resolve(envImage); + }); + }); } -}); + else { + loadPromise = this.loadTexture(envImage, { + exposure: exposure + }); + } + + return loadPromise.then(function (envTexture) { + var specLight = new AmbientCubemapLight({ + intensity: specIntensity != null ? specIntensity : 0.7 + }); + specLight.cubemap = envTexture; + envTexture.flipY = false; + // TODO Cache prefilter ? + specLight.prefilter(self.renderer, 32); + + var diffLight = new AmbientSHLight({ + intensity: diffIntensity != null ? diffIntensity : 0.7, + coefficients: sh.projectEnvironmentMap( + self.renderer, specLight.cubemap, { + lod: 1 + } + ) + }); + scene.add(specLight); + scene.add(diffLight); + + return { + specular: specLight, + diffuse: diffLight, + // Original environment map + environmentMap: envTexture + }; + }); +}; /** - * @constructor clay.compositor.TextureNode - * @extends clay.compositor.Node + * Load a [glTF](https://github.com/KhronosGroup/glTF) format model. + * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script, + * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application. + * @param {string} url + * @param {Object} opts + * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'. + * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded. + * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model. + * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z' + * @param {boolean} [opts.textureFlipY=false] + * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file. + * @return {Promise} */ -var TextureNode$1 = Node$1.extend(function() { - return /** @lends clay.compositor.TextureNode# */ { - /** - * @type {clay.Texture2D} - */ - texture: null, +App3D.prototype.loadModel = function (url, opts) { + if (typeof url !== 'string') { + throw new Error('Invalid URL.'); + } - // Texture node must have output without parameters - outputs: { - color: {} - } + opts = opts || {}; + if (opts.autoPlayAnimation == null) { + opts.autoPlayAnimation = true; + } + var shader = opts.shader || 'clay.standard'; + + var loaderOpts = { + rootNode: new Node(), + shader: shader, + textureRootPath: opts.textureRootPath, + crossOrigin: 'Anonymous', + textureFlipY: opts.textureFlipY }; -}, function () { -}, { + if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') { + loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2); + } - getOutput: function (renderer, name) { - return this.texture; - }, + var loader = new GLTFLoader(loaderOpts); - // Do nothing - beforeFrame: function () {}, - afterFrame: function () {} -}); + var scene = this.scene; + var timeline = this.timeline; + var self = this; -// TODO Shader library -// TODO curlnoise demo wrong + return new Promise(function (resolve, reject) { + function afterLoad(result) { + if (self._disposed) { + return; + } -// PENDING -// Use topological sort ? + scene.add(result.rootNode); + if (opts.autoPlayAnimation) { + result.clips.forEach(function (clip) { + timeline.addClip(clip); + }); + } + resolve(result); + } + loader.success(function (result) { + if (self._disposed) { + return; + } -/** - * Filter node - * - * @constructor clay.compositor.FilterNode - * @extends clay.compositor.Node - * - * @example - var node = new clay.compositor.Node({ - name: 'fxaa', - shader: clay.Shader.source('clay.compositor.fxaa'), - inputs: { - texture: { - node: 'scene', - pin: 'color' + if (!opts.waitTextureLoaded) { + afterLoad(result); } - }, - // Multiple outputs is preserved for MRT support in WebGL2.0 - outputs: { - color: { - attachment: clay.FrameBuffer.COLOR_ATTACHMENT0 - parameters: { - format: clay.Texture.RGBA, - width: 512, - height: 512 - }, - // Node will keep the RTT rendered in last frame - keepLastFrame: true, - // Force the node output the RTT rendered in last frame - outputLastFrame: true + else { + Promise.all(result.textures.map(function (texture) { + if (texture.isRenderable()) { + return Promise.resolve(texture); + } + return new Promise(function (resolve) { + texture.success(resolve); + texture.error(resolve); + }); + })).then(function () { + afterLoad(result); + }).catch(function () { + afterLoad(result); + }); } - } + }); + loader.error(function () { + reject(); + }); + loader.load(url); }); - * - */ -var FilterNode$1 = Node$1.extend(function () { - return /** @lends clay.compositor.Node# */ { - /** - * @type {string} - */ - name: '', - - /** - * @type {Object} - */ - inputs: {}, - - /** - * @type {Object} - */ - outputs: null, +}; - /** - * @type {string} - */ - shader: '', - /** - * Input links, will be updated by the graph - * @example: - * inputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - inputLinks: {}, +var application = { + App3D: App3D, + /** + * Create a 3D application that will manage the app initialization and loop. + * @name clay.application.create + * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector` + * @param {Object} appNS + * @param {Function} init Initialization callback that will be called when initing app. + * @param {Function} loop Loop callback that will be called each frame. + * @param {number} [width] Container width. + * @param {number} [height] Container height. + * @param {number} [devicePixelRatio] + * @return {clay.application.App3D} + * + * @example + * clay.application.create('#app', { + * init: function (app) { + * app.createCube(); + * var camera = app.createCamera(); + * camera.position.set(0, 0, 2); + * }, + * loop: function () { // noop } + * }) + */ + create: function (dom, appNS) { + return new App3D(dom, appNS); + } +}; - /** - * Output links, will be updated by the graph - * @example: - * outputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - outputLinks: {}, +/** + * @constructor + * @alias clay.async.Task + * @mixes clay.core.mixin.notifier + */ +var Task = function() { + this._fullfilled = false; + this._rejected = false; +}; +/** + * Task successed + * @param {} data + */ +Task.prototype.resolve = function(data) { + this._fullfilled = true; + this._rejected = false; + this.trigger('success', data); +}; +/** + * Task failed + * @param {} err + */ +Task.prototype.reject = function(err) { + this._rejected = true; + this._fullfilled = false; + this.trigger('error', err); +}; +/** + * If task successed + * @return {boolean} + */ +Task.prototype.isFullfilled = function() { + return this._fullfilled; +}; +/** + * If task failed + * @return {boolean} + */ +Task.prototype.isRejected = function() { + return this._rejected; +}; +/** + * If task finished, either successed or failed + * @return {boolean} + */ +Task.prototype.isSettled = function() { + return this._fullfilled || this._rejected; +}; - /** - * @type {clay.compositor.Pass} - */ - pass: null, +util$1.extend(Task.prototype, notifier); - // Save the output texture of previous frame - // Will be used when there exist a circular reference - _prevOutputTextures: {}, - _outputTextures: {}, +function makeRequestTask(url, responseType) { + var task = new Task(); + request.get({ + url: url, + responseType: responseType, + onload: function(res) { + task.resolve(res); + }, + onerror: function(error) { + task.reject(error); + } + }); + return task; +} +/** + * Make a request task + * @param {string|object|object[]|string[]} url + * @param {string} [responseType] + * @example + * var task = Task.makeRequestTask('./a.json'); + * var task = Task.makeRequestTask({ + * url: 'b.bin', + * responseType: 'arraybuffer' + * }); + * var tasks = Task.makeRequestTask(['./a.json', './b.json']); + * var tasks = Task.makeRequestTask([ + * {url: 'a.json'}, + * {url: 'b.bin', responseType: 'arraybuffer'} + * ]); + * @return {clay.async.Task|clay.async.Task[]} + */ +Task.makeRequestTask = function(url, responseType) { + if (typeof url === 'string') { + return makeRequestTask(url, responseType); + } else if (url.url) { // Configure object + var obj = url; + return makeRequestTask(obj.url, obj.responseType); + } else if (Array.isArray(url)) { // Url list + var urlList = url; + var tasks = []; + urlList.forEach(function(obj) { + var url, responseType; + if (typeof obj === 'string') { + url = obj; + } else if (Object(obj) === obj) { + url = obj.url; + responseType = obj.responseType; + } + tasks.push(makeRequestTask(url, responseType)); + }); + return tasks; + } +}; +/** + * @return {clay.async.Task} + */ +Task.makeTask = function() { + return new Task(); +}; - // Example: { name: 2 } - _outputReferences: {}, +util$1.extend(Task.prototype, notifier); - _rendering: false, - // If rendered in this frame - _rendered: false, +/** + * @constructor + * @alias clay.async.TaskGroup + * @extends clay.async.Task + */ +var TaskGroup = function () { - _compositor: null - }; -}, function () { + Task.apply(this, arguments); - var pass = new Pass({ - fragment: this.shader - }); - this.pass = pass; -}, -/** @lends clay.compositor.Node.prototype */ -{ - /** - * @param {clay.Renderer} renderer - */ - render: function (renderer, frameBuffer) { - this.trigger('beforerender', renderer); + this._tasks = []; - this._rendering = true; + this._fulfilledNumber = 0; - var _gl = renderer.gl; + this._rejectedNumber = 0; +}; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - var inputTexture = link.node.getOutput(renderer, link.pin); - this.pass.setUniform(inputName, inputTexture); - } - // Output - if (!this.outputs) { - this.pass.outputs = null; +var Ctor = function (){}; +Ctor.prototype = Task.prototype; +TaskGroup.prototype = new Ctor(); - this._compositor.getFrameBuffer().unbind(renderer); +TaskGroup.prototype.constructor = TaskGroup; - this.pass.render(renderer, frameBuffer); +/** + * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}. + * @param {Array.} tasks + * @chainable + * @example + * // Load texture list + * var list = ['a.jpg', 'b.jpg', 'c.jpg'] + * var textures = list.map(function (src) { + * var texture = new clay.Texture2D(); + * texture.load(src); + * return texture; + * }); + * var taskGroup = new clay.async.TaskGroup(); + * taskGroup.all(textures).success(function () { + * // Do some thing after all textures loaded + * }); + */ +TaskGroup.prototype.all = function (tasks) { + var count = 0; + var self = this; + var data = []; + this._tasks = tasks; + this._fulfilledNumber = 0; + this._rejectedNumber = 0; + + util$1.each(tasks, function (task, idx) { + if (!task || !task.once) { + return; } - else { - this.pass.outputs = {}; + count++; + task.once('success', function (res) { + count--; - var attachedTextures = {}; - for (var name in this.outputs) { - var parameters = this.updateParameter(name, renderer); - if (isNaN(parameters.width)) { - this.updateParameter(name, renderer); - } - var outputInfo = this.outputs[name]; - var texture = this._compositor.allocateTexture(parameters); - this._outputTextures[name] = texture; - var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; - if (typeof(attachment) == 'string') { - attachment = _gl[attachment]; - } - attachedTextures[attachment] = texture; - } - this._compositor.getFrameBuffer().bind(renderer); + self._fulfilledNumber++; + // TODO + // Some tasks like texture, loader are not inherited from task + // We need to set the states here + task._fulfilled = true; + task._rejected = false; - for (var attachment in attachedTextures) { - // FIXME attachment changes in different nodes - this._compositor.getFrameBuffer().attach( - attachedTextures[attachment], attachment - ); + data[idx] = res; + if (count === 0) { + self.resolve(data); } + }); + task.once('error', function () { - this.pass.render(renderer); + self._rejectedNumber ++; - // Because the data of texture is changed over time, - // Here update the mipmaps of texture each time after rendered; - this._compositor.getFrameBuffer().updateMipmap(renderer.gl); - } + task._fulfilled = false; + task._rejected = true; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - link.node.removeReference(link.pin); + self.reject(task); + }); + }); + if (count === 0) { + setTimeout(function () { + self.resolve(data); + }); + return this; + } + return this; +}; +/** + * Wait for all given tasks finished, either successed or failed + * @param {Array.} tasks + * @return {clay.async.TaskGroup} + */ +TaskGroup.prototype.allSettled = function (tasks) { + var count = 0; + var self = this; + var data = []; + if (tasks.length === 0) { + setTimeout(function () { + self.trigger('success', data); + }); + return this; + } + this._tasks = tasks; + + util$1.each(tasks, function (task, idx) { + if (!task || !task.once) { + return; } + count++; + task.once('success', function (res) { + count--; - this._rendering = false; - this._rendered = true; + self._fulfilledNumber++; - this.trigger('afterrender', renderer); - }, + task._fulfilled = true; + task._rejected = false; - // TODO Remove parameter function callback - updateParameter: function (outputName, renderer) { - var outputInfo = this.outputs[outputName]; - var parameters = outputInfo.parameters; - var parametersCopy = outputInfo._parametersCopy; - if (!parametersCopy) { - parametersCopy = outputInfo._parametersCopy = {}; - } - if (parameters) { - for (var key in parameters) { - if (key !== 'width' && key !== 'height') { - parametersCopy[key] = parameters[key]; - } - } - } - var width, height; - if (parameters.width instanceof Function) { - width = parameters.width.call(this, renderer); - } - else { - width = parameters.width; - } - if (parameters.height instanceof Function) { - height = parameters.height.call(this, renderer); - } - else { - height = parameters.height; - } - if ( - parametersCopy.width !== width - || parametersCopy.height !== height - ) { - if (this._outputTextures[outputName]) { - this._outputTextures[outputName].dispose(renderer); + data[idx] = res; + if (count === 0) { + self.resolve(data); } - } - parametersCopy.width = width; - parametersCopy.height = height; - - return parametersCopy; - }, + }); + task.once('error', function (err) { + count--; - /** - * Set parameter - * @param {string} name - * @param {} value - */ - setParameter: function (name, value) { - this.pass.setUniform(name, value); - }, - /** - * Get parameter value - * @param {string} name - * @return {} - */ - getParameter: function (name) { - return this.pass.getUniform(name); - }, - /** - * Set parameters - * @param {Object} obj - */ - setParameters: function (obj) { - for (var name in obj) { - this.setParameter(name, obj[name]); - } - }, - // /** - // * Set shader code - // * @param {string} shaderStr - // */ - // setShader: function (shaderStr) { - // var material = this.pass.material; - // material.shader.setFragment(shaderStr); - // material.attachShader(material.shader, true); - // }, - /** - * Proxy of pass.material.define('fragment', xxx); - * @param {string} symbol - * @param {number} [val] - */ - define: function (symbol, val) { - this.pass.material.define('fragment', symbol, val); - }, + self._rejectedNumber++; - /** - * Proxy of pass.material.undefine('fragment', xxx) - * @param {string} symbol - */ - undefine: function (symbol) { - this.pass.material.undefine('fragment', symbol); - }, + task._fulfilled = false; + task._rejected = true; - removeReference: function (outputName) { - this._outputReferences[outputName]--; - if (this._outputReferences[outputName] === 0) { - var outputInfo = this.outputs[outputName]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[outputName]) { - this._compositor.releaseTexture(this._prevOutputTextures[outputName]); - } - this._prevOutputTextures[outputName] = this._outputTextures[outputName]; + // TODO + data[idx] = null; + if (count === 0) { + self.resolve(data); } - else { - // Output of this node have alreay been used by all other nodes - // Put the texture back to the pool. - this._compositor.releaseTexture(this._outputTextures[outputName]); + }); + }); + return this; +}; +/** + * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getFulfilledNumber = function (recursive) { + if (recursive) { + var nFulfilled = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nFulfilled += task.getFulfilledNumber(recursive); + } else if(task._fulfilled) { + nFulfilled += 1; } } - }, - - clear: function () { - Node$1.prototype.clear.call(this); - - // Default disable all texture - this.pass.material.disableTexturesAll(); + return nFulfilled; + } else { + return this._fulfilledNumber; } -}); - -var shaderSourceReg = /^#source\((.*?)\)/; +}; /** - * @param {Object} json - * @param {Object} [opts] - * @return {clay.compositor.Compositor} + * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} */ -function createCompositor(json, opts) { - var compositor = new Compositor(); - opts = opts || {}; - - var lib = { - textures: {}, - parameters: {} - }; - var afterLoad = function(shaderLib, textureLib) { - for (var i = 0; i < json.nodes.length; i++) { - var nodeInfo = json.nodes[i]; - var node = createNode(nodeInfo, lib, opts); - if (node) { - compositor.addNode(node); +TaskGroup.prototype.getRejectedNumber = function (recursive) { + if (recursive) { + var nRejected = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nRejected += task.getRejectedNumber(recursive); + } else if(task._rejected) { + nRejected += 1; } } - }; - - for (var name in json.parameters) { - var paramInfo = json.parameters[name]; - lib.parameters[name] = convertParameter(paramInfo); + return nRejected; + } else { + return this._rejectedNumber; } - // TODO load texture asynchronous - loadTextures(json, lib, opts, function(textureLib) { - lib.textures = textureLib; - afterLoad(); - }); - - return compositor; -} - -function createNode(nodeInfo, lib, opts) { - var type = nodeInfo.type || 'filter'; - var shaderSource; - var inputs; - var outputs; +}; - if (type === 'filter') { - var shaderExp = nodeInfo.shader.trim(); - var res = shaderSourceReg.exec(shaderExp); - if (res) { - shaderSource = Shader.source(res[1].trim()); - } - else if (shaderExp.charAt(0) === '#') { - shaderSource = lib.shaders[shaderExp.substr(1)]; - } - if (!shaderSource) { - shaderSource = shaderExp; - } - if (!shaderSource) { - return; - } - } +/** + * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getSettledNumber = function (recursive) { - if (nodeInfo.inputs) { - inputs = {}; - for (var name in nodeInfo.inputs) { - if (typeof nodeInfo.inputs[name] === 'string') { - inputs[name] = nodeInfo.inputs[name]; - } - else { - inputs[name] = { - node: nodeInfo.inputs[name].node, - pin: nodeInfo.inputs[name].pin - }; + if (recursive) { + var nSettled = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nSettled += task.getSettledNumber(recursive); + } else if(task._rejected || task._fulfilled) { + nSettled += 1; } } + return nSettled; + } else { + return this._fulfilledNumber + this._rejectedNumber; } - if (nodeInfo.outputs) { - outputs = {}; - for (var name in nodeInfo.outputs) { - var outputInfo = nodeInfo.outputs[name]; - outputs[name] = {}; - if (outputInfo.attachment != null) { - outputs[name].attachment = outputInfo.attachment; - } - if (outputInfo.keepLastFrame != null) { - outputs[name].keepLastFrame = outputInfo.keepLastFrame; - } - if (outputInfo.outputLastFrame != null) { - outputs[name].outputLastFrame = outputInfo.outputLastFrame; - } - if (outputInfo.parameters) { - outputs[name].parameters = convertParameter(outputInfo.parameters); +}; + +/** + * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getTaskNumber = function (recursive) { + if (recursive) { + var nTask = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nTask += task.getTaskNumber(recursive); + } else { + nTask += 1; } } + return nTask; + } else { + return this._tasks.length; } - var node; - if (type === 'scene') { - node = new SceneNode$1({ - name: nodeInfo.name, - scene: opts.scene, - camera: opts.camera, - outputs: outputs - }); - } - else if (type === 'texture') { - node = new TextureNode$1({ - name: nodeInfo.name, - outputs: outputs - }); - } - // Default is filter - else { - node = new FilterNode$1({ - name: nodeInfo.name, - shader: shaderSource, - inputs: inputs, - outputs: outputs - }); - } - if (node) { - if (nodeInfo.parameters) { - for (var name in nodeInfo.parameters) { - var val = nodeInfo.parameters[name]; - if (typeof(val) === 'string') { - val = val.trim(); - if (val.charAt(0) === '#') { - val = lib.textures[val.substr(1)]; - } - else { - node.on( - 'beforerender', createSizeSetHandler( - name, tryConvertExpr(val) - ) - ); - } - } - node.setParameter(name, val); - } - } - if (nodeInfo.defines && node.pass) { - for (var name in nodeInfo.defines) { - var val = nodeInfo.defines[name]; - node.pass.material.define('fragment', name, val); - } +}; + +var CanvasMaterial = Base.extend({ + + color: [1, 1, 1, 1], + + opacity: 1, + + pointSize: 0, + + pointShape: 'rectangle' +}); + +var mat4$8 = glmatrix.mat4; +var vec3$17 = glmatrix.vec3; +var vec4$2 = glmatrix.vec4; + +var vec4Create = vec4$2.create; + +var round = Math.round; + +var PRIMITIVE_TRIANGLE = 1; +var PRIMITIVE_LINE = 2; +var PRIMITIVE_POINT = 3; + +function PrimitivePool(constructor) { + this.ctor = constructor; + + this._data = []; + + this._size = 0; +} + +PrimitivePool.prototype = { + pick: function () { + var data = this._data; + var size = this._size; + var obj = data[size]; + if (! obj) { + // Constructor must have no parameters + obj = new this.ctor(); + data[size] = obj; } - } - return node; -} + this._size++; + return obj; + }, -function convertParameter(paramInfo) { - var param = {}; - if (!paramInfo) { - return param; - } - ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap'] - .forEach(function(name) { - var val = paramInfo[name]; - if (val != null) { - // Convert string to enum - if (typeof val === 'string') { - val = Texture[val]; - } - param[name] = val; - } - }); - ['width', 'height'] - .forEach(function(name) { - if (paramInfo[name] != null) { - var val = paramInfo[name]; - if (typeof val === 'string') { - val = val.trim(); - param[name] = createSizeParser( - name, tryConvertExpr(val) - ); - } - else { - param[name] = val; - } - } - }); - if (paramInfo.useMipmap != null) { - param.useMipmap = paramInfo.useMipmap; + reset: function () { + this._size = 0; + }, + + shrink: function () { + this._data.length = this._size; + }, + + clear: function () { + this._data = []; + this._size = 0; } - return param; +}; + +function Triangle() { + this.vertices = [vec4Create(), vec4Create(), vec4Create()]; + this.color = vec4Create(); + + this.depth = 0; } -function loadTextures(json, lib, opts, callback) { - if (!json.textures) { - callback({}); - return; - } - var textures = {}; - var loading = 0; +Triangle.prototype.type = PRIMITIVE_TRIANGLE; - var cbd = false; - var textureRootPath = opts.textureRootPath; - util$1.each(json.textures, function(textureInfo, name) { - var texture; - var path = textureInfo.path; - var parameters = convertParameter(textureInfo.parameters); - if (Array.isArray(path) && path.length === 6) { - if (textureRootPath) { - path = path.map(function(item) { - return util$1.relative2absolute(item, textureRootPath); - }); - } - texture = new TextureCube(parameters); - } - else if(typeof path === 'string') { - if (textureRootPath) { - path = util$1.relative2absolute(path, textureRootPath); - } - texture = new Texture2D(parameters); - } - else { - return; - } +function Point() { + // Here use an array to make it more convinient to proccessing in _setPrimitive method + this.vertices = [vec4Create()]; - texture.load(path); - loading++; - texture.once('success', function() { - textures[name] = texture; - loading--; - if (loading === 0) { - callback(textures); - cbd = true; - } - }); - }); + this.color = vec4Create(); - if (loading === 0 && !cbd) { - callback(textures); - } + this.depth = 0; } -function createSizeSetHandler(name, exprFunc) { - return function (renderer) { - // PENDING viewport size or window size - var dpr = renderer.getDevicePixelRatio(); - // PENDING If multiply dpr ? - var width = renderer.getWidth(); - var height = renderer.getHeight(); - var result = exprFunc(width, height, dpr); - this.setParameter(name, result); - }; +Point.prototype.type = PRIMITIVE_POINT; + +function Line() { + this.vertices = [vec4Create(), vec4Create()]; + this.color = vec4Create(); + + this.depth = 0; + + this.lineWidth = 1; } -function createSizeParser(name, exprFunc) { - return function (renderer) { - var dpr = renderer.getDevicePixelRatio(); - var width = renderer.getWidth(); - var height = renderer.getHeight(); - return exprFunc(width, height, dpr); - }; +Line.prototype.type = PRIMITIVE_LINE; + +function depthSortFunc(x, y) { + // Sort from far to near, which in depth of projection space is from larger to smaller + return y.depth - x.depth; } -function tryConvertExpr(string) { - // PENDING - var exprRes = /^expr\((.*)\)$/.exec(string); - if (exprRes) { - try { - var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]); - // Try run t - func(1, 1); +function vec3ToColorStr(v3) { + return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')'; +} - return func; - } - catch (e) { - throw new Error('Invalid expression.'); - } - } +function vec4ToColorStr(v4) { + return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')'; } -var gbufferEssl = "@export clay.deferred.gbuffer.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat;\nuniform vec2 uvOffset;\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#ifdef FIRST_PASS\nattribute vec3 normal : NORMAL;\n#endif\n@import clay.chunk.skinning_header\n#ifdef FIRST_PASS\nvarying vec3 v_Normal;\nattribute vec4 tangent : TANGENT;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nvarying vec3 v_WorldPosition;\n#endif\nvarying vec2 v_Texcoord;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef FIRST_PASS\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n bool hasTangent = dot(tangent, tangent) > 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"; +var CanvasRenderer = Base.extend({ -var chunkEssl = "@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end"; + canvas: null, -Shader.import(gbufferEssl); -Shader.import(chunkEssl); + _width: 100, -function createFillCanvas(color) { - var canvas = document.createElement('canvas'); - canvas.width = canvas.height = 1; - var ctx = canvas.getContext('2d'); - ctx.fillStyle = color || '#000'; - ctx.fillRect(0, 0, 1, 1); + _height: 100, - return canvas; -} + devicePixelRatio: window.devicePixelRatio || 1.0, -function attachTextureToSlot(renderer, program, symbol, texture, slot) { - var gl = renderer.gl; - program.setUniform(gl, '1i', symbol, slot); + color: [0.0, 0.0, 0.0, 0.0], - gl.activeTexture(gl.TEXTURE0 + slot); - // Maybe texture is not loaded yet; - if (texture.isRenderable()) { - texture.bind(renderer); - } - else { - // Bind texture to null - texture.unbind(renderer); - } -} + clear: true, -// TODO Use globalShader insteadof globalMaterial? -function getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) { + ctx: null, - var previousNormalMap; - var previousRougGlossMap; - var previousRenderable; + // Cached primitive list, including triangle, line, point + _primitives: [], - return function (renderable, gBufferMat, prevMaterial) { - // Material not change - if (previousRenderable && previousRenderable.material === renderable.material) { - return; + // Triangle pool + _triangles: new PrimitivePool(Triangle), + + // Line pool + _lines: new PrimitivePool(Line), + + // Point pool + _points: new PrimitivePool(Point) +}, function () { + if (! this.canvas) { + this.canvas = document.createElement('canvas'); + } + var canvas = this.canvas; + + try { + this.ctx = canvas.getContext('2d'); + var ctx = this.ctx; + if (!ctx) { + throw new Error(); } + } + catch (e) { + throw 'Error creating WebGL Context ' + e; + } - var standardMaterial = renderable.material; - var program = renderable.__program; + this.resize(); +}, { - var glossiness; - var roughGlossMap; - var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS'); - var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED'); - var roughGlossChannel; - if (useRoughnessWorkflow) { - glossiness = 1.0 - standardMaterial.get('roughness'); - roughGlossMap = standardMaterial.get('roughnessMap'); - roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL'); + resize: function (width, height) { + var dpr = this.devicePixelRatio; + var canvas = this.canvas; + if (width != null) { + canvas.style.width = width + 'px'; + canvas.style.height = height + 'px'; + canvas.width = width * dpr; + canvas.height = height * dpr; + + this._width = width; + this._height = height; } else { - glossiness = standardMaterial.get('glossiness'); - roughGlossMap = standardMaterial.get('glossinessMap'); - roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL'); + this._width = canvas.width / dpr; + this._height = canvas.height / dpr; } - var useRoughGlossMap = !!roughGlossMap; + }, - var normalMap = standardMaterial.get('normalMap') || defaultNormalMap; - var uvRepeat = standardMaterial.get('uvRepeat'); - var uvOffset = standardMaterial.get('uvOffset'); + getWidth: function () { + return this._width; + }, - roughGlossMap = roughGlossMap || defaultRoughnessMap; + getHeight: function () { + return this._height; + }, - if (prevMaterial !== gBufferMat) { - gBufferMat.set('glossiness', glossiness); - gBufferMat.set('normalMap', normalMap); - gBufferMat.set('roughGlossMap', roughGlossMap); - gBufferMat.set('useRoughGlossMap', +useRoughGlossMap); - gBufferMat.set('useRoughness', +useRoughnessWorkflow); - gBufferMat.set('doubleSided', +doubleSided); - gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0); - gBufferMat.set('uvRepeat', uvRepeat); - gBufferMat.set('uvOffset', uvOffset); - } - else { - program.setUniform( - gl, '1f', 'glossiness', glossiness - ); + getViewportAspect: function () { + return this._width / this._height; + }, - if (previousNormalMap !== normalMap) { - attachTextureToSlot(this, program, 'normalMap', normalMap, 0); + render: function (scene, camera) { + + if (this.clear) { + var color = this.color; + var ctx = this.ctx; + var dpr = this.devicePixelRatio; + var w = this._width * dpr; + var h = this._height * dpr; + if (color && color[3] === 0) { + ctx.clearRect(0, 0, w, h); } - if (previousRougGlossMap !== roughGlossMap) { - attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1); + else { + // Has transparency + if (color[3] < 1) { + ctx.clearRect(0, 0, w, h); + } + ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color); + ctx.fillRect(0, 0, w, h); } - program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap); - program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow); - program.setUniform(gl, '1i', 'doubleSided', +doubleSided); - program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0); - if (uvRepeat != null) { - program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + } + + scene.update(); + camera.update(); + + var opaqueList = scene.opaqueList; + var transparentList = scene.transparentList; + var list = opaqueList.concat(transparentList); + + this.renderPass(list, camera); + }, + + renderPass: function (list, camera) { + var viewProj = mat4$8.create(); + mat4$8.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array); + var worldViewProjMat = mat4$8.create(); + var posViewSpace = vec3$17.create(); + + var primitives = this._primitives; + var trianglesPool = this._triangles; + var linesPool = this._lines; + var pointsPool = this._points; + + trianglesPool.reset(); + linesPool.reset(); + pointsPool.reset(); + + var nPrimitive = 0; + + var indices = [0, 0, 0]; + var matColor = []; + for (var i = 0; i < list.length; i++) { + var renderable = list[i]; + + mat4$8.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array); + + var geometry = renderable.geometry; + var material = renderable.material; + var attributes = geometry.attributes; + + // alpha is default 1 + if (material.color.length == 3) { + vec3$17.copy(matColor, material.color); + matColor[3] = 1; } - if (uvOffset != null) { - program.setUniform(gl, '2f', 'uvOffset', uvOffset); + else { + vec4$2.copy(matColor, material.color); } - } - previousNormalMap = normalMap; - previousRougGlossMap = roughGlossMap; + var nVertex = geometry.vertexCount; + // Only support TRIANGLES, LINES, POINTS draw modes + switch (renderable.mode) { + case glenum.TRIANGLES: + if (geometry.isUseIndices()) { + var nFace = geometry.triangleCount; + for (var j = 0; j < nFace; j++) { + geometry.getFace(j, indices); - previousRenderable = renderable; - }; -} + var triangle = trianglesPool.pick(); + triangle.material = material; -function getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) { - var previousDiffuseMap; - var previousRenderable; - var previousMetalnessMap; + var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); - return function (renderable, gBufferMat, prevMaterial) { - // Material not change - if (previousRenderable && previousRenderable.material === renderable.material) { - return; + if (! clipped) { + primitives[nPrimitive++] = triangle; + } + } + } + else { + for (var j = 0; j < nVertex;) { + indices[0] = j++; + indices[1] = j++; + indices[2] = j++; + + var triangle = trianglesPool.pick(); + triangle.material = material; + + var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = triangle; + } + } + } + break; + case glenum.LINES: + // LINES mode can't use face + for (var j = 0; j < nVertex;) { + indices[0] = j++; + indices[1] = j++; + var line = linesPool.pick(); + line.material = material; + line.lineWidth = renderable.lineWidth; + + var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = line; + } + } + break; + case glenum.POINTS: + for (var j = 0; j < nVertex; j++) { + indices[0] = j; + var point = pointsPool.pick(); + point.material = material; + + var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = point; + } + } + // POINTS mode can't use face + break; + } } - var program = renderable.__program; - var standardMaterial = renderable.material; + trianglesPool.shrink(); + linesPool.shrink(); + pointsPool.shrink(); - var color = standardMaterial.get('color'); - var metalness = standardMaterial.get('metalness'); + primitives.length = nPrimitive; - var diffuseMap = standardMaterial.get('diffuseMap'); - var metalnessMap = standardMaterial.get('metalnessMap'); + primitives.sort(depthSortFunc); + this._drawPrimitives(primitives); + }, - var uvRepeat = standardMaterial.get('uvRepeat'); - var uvOffset = standardMaterial.get('uvOffset'); + _setPrimitive: (function () { + var vertexColor = vec4Create(); + return function (primitive, indices, size, attributes, worldViewProjMat, matColor) { + var colorAttrib = attributes.color; + var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0; + var priColor = primitive.color; - var useMetalnessMap = !!metalnessMap; + primitive.depth = 0; + if (useVertexColor) { + vec4$2.set(priColor, 0, 0, 0, 0); + } - diffuseMap = diffuseMap || defaultDiffuseMap; - metalnessMap = metalnessMap || defaultMetalnessMap; + var clipped = true; - if (prevMaterial !== gBufferMat) { - gBufferMat.set('color', color); - gBufferMat.set('metalness', metalness); - gBufferMat.set('diffuseMap', diffuseMap); - gBufferMat.set('metalnessMap', metalnessMap); - gBufferMat.set('useMetalnessMap', +useMetalnessMap); - gBufferMat.set('uvRepeat', uvRepeat); - gBufferMat.set('uvOffset', uvOffset); + var percent = 1 / size; + for (var i = 0; i < size; i++) { + var coord = primitive.vertices[i]; + attributes.position.get(indices[i], coord); + coord[3] = 1; + vec4$2.transformMat4(coord, coord, worldViewProjMat); + if (useVertexColor) { + colorAttrib.get(indices[i], vertexColor); + // Average vertex color + // Each primitive only call fill or stroke once + // So color must be the same + vec4$2.scaleAndAdd(priColor, priColor, vertexColor, percent); + } - gBufferMat.set('linear', +standardMaterial.linear); - } - else { - program.setUniform(gl, '1f', 'metalness', metalness); + // Clipping + var x = coord[0]; + var y = coord[1]; + var z = coord[2]; + var w = coord[3]; - program.setUniform(gl, '3f', 'color', color); - if (previousDiffuseMap !== diffuseMap) { - attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0); + // TODO Point clipping + if (x > -w && x < w && y > -w && y < w && z > -w && z < w) { + clipped = false; + } + + var invW = 1 / w; + coord[0] = x * invW; + coord[1] = y * invW; + coord[2] = z * invW; + // Use primitive average depth; + primitive.depth += coord[2]; } - if (previousMetalnessMap !== metalnessMap) { - attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1); + + if (! clipped) { + primitive.depth /= size; + + if (useVertexColor) { + vec4$2.mul(priColor, priColor, matColor); + } + else { + vec4$2.copy(priColor, matColor); + } } - program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap); - program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); - program.setUniform(gl, '2f', 'uvOffset', uvOffset); - program.setUniform(gl, '1i', 'linear', +standardMaterial.linear); + return clipped; } + })(), - previousDiffuseMap = diffuseMap; - previousMetalnessMap = metalnessMap; + _drawPrimitives: function (primitives) { + var ctx = this.ctx; + ctx.save(); - previousRenderable = renderable; - }; -} + var prevMaterial; -/** - * GBuffer is provided for deferred rendering and SSAO, SSR pass. - * It will do two passes rendering to three target textures. See - * + {@link clay.deferred.GBuffer#getTargetTexture1} - * + {@link clay.deferred.GBuffer#getTargetTexture2} - * + {@link clay.deferred.GBuffer#getTargetTexture3} - * @constructor - * @alias clay.deferred.GBuffer - * @extends clay.core.Base - */ -var GBuffer = Base.extend(function () { + var dpr = this.devicePixelRatio; + var width = this._width * dpr; + var height = this._height * dpr; + var halfWidth = width / 2; + var halfHeight = height / 2; - return { + var prevLineWidth; + var prevStrokeColor; - enableTargetTexture1: true, + for (var i = 0; i < primitives.length; i++) { + var primitive = primitives[i]; + var vertices = primitive.vertices; - enableTargetTexture2: true, + var primitiveType = primitive.type; + var material = primitive.material; + if (material !== prevMaterial) { + // Set material + ctx.globalAlpha = material.opacity; + prevMaterial = material; + } - enableTargetTexture3: true, + var colorStr = vec4ToColorStr(primitive.color); + switch (primitiveType) { + case PRIMITIVE_TRIANGLE: + var v0 = vertices[0]; + var v1 = vertices[1]; + var v2 = vertices[2]; + ctx.fillStyle = colorStr; + ctx.beginPath(); + ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); + ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); + ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight); + ctx.closePath(); + ctx.fill(); + break; + case PRIMITIVE_LINE: + var v0 = vertices[0]; + var v1 = vertices[1]; + var lineWidth = primitive.lineWidth; + if (prevStrokeColor !== colorStr) { + prevStrokeColor = ctx.strokeStyle = colorStr; + } + if (lineWidth !== prevLineWidth) { + ctx.lineWidth = prevLineWidth = lineWidth; + } + ctx.beginPath(); + ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); + ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); + ctx.stroke(); + break; + case PRIMITIVE_POINT: + var pointSize = material.pointSize; + var pointShape = material.pointShape; + var halfSize = pointSize / 2; + if (pointSize > 0) { + var v0 = vertices[0]; + var cx = (v0[0] + 1) * halfWidth; + var cy = (-v0[1] + 1) * halfHeight; - renderTransparent: false, + ctx.fillStyle = colorStr; + if (pointShape === 'rectangle') { + ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize); + } + else if (pointShape === 'circle') { + ctx.beginPath(); + ctx.arc(cx, cy, halfSize, 0, Math.PI * 2); + ctx.fill(); + } + } + break; + } + } - _renderList: [], - // - R: normal.x - // - G: normal.y - // - B: normal.z - // - A: glossiness - _gBufferTex1: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST, - // PENDING - type: Texture.HALF_FLOAT - }), + ctx.restore(); + }, - // - R: depth - _gBufferTex2: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST, - // format: Texture.DEPTH_COMPONENT, - // type: Texture.UNSIGNED_INT + dispose: function () { + this._triangles.clear(); + this._lines.clear(); + this._points.clear(); + this._primitives = []; - format: Texture.DEPTH_STENCIL, - type: Texture.UNSIGNED_INT_24_8_WEBGL - }), + this.ctx = null; + this.canvas = null; + } +}); - // - R: albedo.r - // - G: albedo.g - // - B: albedo.b - // - A: metalness - _gBufferTex3: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST - }), +// PENDING +// Use topological sort ? - _defaultNormalMap: new Texture2D({ - image: createFillCanvas('#000') - }), - _defaultRoughnessMap: new Texture2D({ - image: createFillCanvas('#fff') - }), - _defaultMetalnessMap: new Texture2D({ - image: createFillCanvas('#fff') - }), - _defaultDiffuseMap: new Texture2D({ - image: createFillCanvas('#fff') - }), +/** + * Node of graph based post processing. + * + * @constructor clay.compositor.Node + * @extends clay.core.Base + * + */ +var Node$1 = Base.extend(function () { + return /** @lends clay.compositor.Node# */ { + /** + * @type {string} + */ + name: '', - _frameBuffer: new FrameBuffer(), + /** + * Input links, will be updated by the graph + * @example: + * inputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + inputLinks: {}, - _gBufferMaterial1: new Material({ - shader: new Shader( - Shader.source('clay.deferred.gbuffer.vertex'), - Shader.source('clay.deferred.gbuffer1.fragment') - ), - vertexDefines: { - FIRST_PASS: null - }, - fragmentDefines: { - FIRST_PASS: null - } - }), - _gBufferMaterial2: new Material({ - shader: new Shader( - Shader.source('clay.deferred.gbuffer.vertex'), - Shader.source('clay.deferred.gbuffer2.fragment') - ) - }), + /** + * Output links, will be updated by the graph + * @example: + * outputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + outputLinks: {}, - _debugPass: new Pass({ - fragment: Shader.source('clay.deferred.gbuffer.debug') - }) - }; -}, /** @lends clay.deferred.GBuffer# */{ + // Save the output texture of previous frame + // Will be used when there exist a circular reference + _prevOutputTextures: {}, + _outputTextures: {}, - /** - * Set G Buffer size. - * @param {number} width - * @param {number} height - */ - resize: function (width, height) { - if (this._gBufferTex1.width === width - && this._gBufferTex1.height === height - ) { - return; - } - this._gBufferTex1.width = width; - this._gBufferTex1.height = height; + // Example: { name: 2 } + _outputReferences: {}, - this._gBufferTex2.width = width; - this._gBufferTex2.height = height; + _rendering: false, + // If rendered in this frame + _rendered: false, - this._gBufferTex3.width = width; - this._gBufferTex3.height = height; - }, + _compositor: null + }; +}, +/** @lends clay.compositor.Node.prototype */ +{ - // TODO is dpr needed? - setViewport: function (x, y, width, height, dpr) { - var viewport; - if (typeof x === 'object') { - viewport = x; + // TODO Remove parameter function callback + updateParameter: function (outputName, renderer) { + var outputInfo = this.outputs[outputName]; + var parameters = outputInfo.parameters; + var parametersCopy = outputInfo._parametersCopy; + if (!parametersCopy) { + parametersCopy = outputInfo._parametersCopy = {}; + } + if (parameters) { + for (var key in parameters) { + if (key !== 'width' && key !== 'height') { + parametersCopy[key] = parameters[key]; + } + } + } + var width, height; + if (parameters.width instanceof Function) { + width = parameters.width.call(this, renderer); } else { - viewport = { - x: x, y: y, - width: width, height: height, - devicePixelRatio: dpr || 1 - }; + width = parameters.width; } - this._frameBuffer.viewport = viewport; - }, - - getViewport: function () { - if (this._frameBuffer.viewport) { - return this._frameBuffer.viewport; + if (parameters.height instanceof Function) { + height = parameters.height.call(this, renderer); } else { - return { - x: 0, y: 0, - width: this._gBufferTex1.width, - height: this._gBufferTex1.height, - devicePixelRatio: 1 - }; + height = parameters.height; + } + if ( + parametersCopy.width !== width + || parametersCopy.height !== height + ) { + if (this._outputTextures[outputName]) { + this._outputTextures[outputName].dispose(renderer.gl); + } } + parametersCopy.width = width; + parametersCopy.height = height; + + return parametersCopy; }, /** - * Update G Buffer - * @param {clay.Renderer} renderer - * @param {clay.Scene} scene - * @param {clay.camera.Perspective} camera + * Set parameter + * @param {string} name + * @param {} value */ - update: function (renderer, scene, camera) { + setParameter: function (name, value) {}, + /** + * Get parameter value + * @param {string} name + * @return {} + */ + getParameter: function (name) {}, + /** + * Set parameters + * @param {Object} obj + */ + setParameters: function (obj) { + for (var name in obj) { + this.setParameter(name, obj[name]); + } + }, - var gl = renderer.gl; + render: function () {}, - var frameBuffer = this._frameBuffer; - var viewport = frameBuffer.viewport; - var opaqueList = scene.opaqueList; - var transparentList = scene.transparentList; + getOutput: function (renderer /*optional*/, name) { + if (name == null) { + // Return the output texture without rendering + name = renderer; + return this._outputTextures[name]; + } + var outputInfo = this.outputs[name]; + if (!outputInfo) { + return ; + } - var offset = 0; - var renderList = this._renderList; - for (var i = 0; i < opaqueList.length; i++) { - if (!opaqueList[i].ignoreGBuffer) { - renderList[offset++] = opaqueList[i]; + // Already been rendered in this frame + if (this._rendered) { + // Force return texture in last frame + if (outputInfo.outputLastFrame) { + return this._prevOutputTextures[name]; } - } - if (this.renderTransparent) { - for (var i = 0; i < transparentList.length; i++) { - if (!transparentList[i].ignoreGBuffer) { - renderList[offset++] = transparentList[i]; - } + else { + return this._outputTextures[name]; } } - renderList.length = offset; - - gl.clearColor(0, 0, 0, 0); - gl.depthMask(true); - gl.colorMask(true, true, true, true); - gl.disable(gl.BLEND); - - var enableTargetTexture1 = this.enableTargetTexture1; - var enableTargetTexture2 = this.enableTargetTexture2; - var enableTargetTexture3 = this.enableTargetTexture3; - if (!enableTargetTexture1 && !enableTargetTexture3) { - console.warn('Can\'t disable targetTexture1 targetTexture3 both'); - enableTargetTexture1 = true; + else if ( + // TODO + this._rendering // Solve Circular Reference + ) { + if (!this._prevOutputTextures[name]) { + // Create a blank texture at first pass + this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {}); + } + return this._prevOutputTextures[name]; } - if (enableTargetTexture2) { - frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT); - } + this.render(renderer); - // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow - renderer.bindSceneRendering(scene); - if (enableTargetTexture1) { - // Pass 1 - frameBuffer.attach(this._gBufferTex1); - frameBuffer.bind(renderer); + return this._outputTextures[name]; + }, - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + removeReference: function (outputName) { + this._outputReferences[outputName]--; + if (this._outputReferences[outputName] === 0) { + var outputInfo = this.outputs[outputName]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[outputName]) { + this._compositor.releaseTexture(this._prevOutputTextures[outputName]); + } + this._prevOutputTextures[outputName] = this._outputTextures[outputName]; } - gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); + else { + // Output of this node have alreay been used by all other nodes + // Put the texture back to the pool. + this._compositor.releaseTexture(this._outputTextures[outputName]); } - var gBufferMaterial1 = this._gBufferMaterial1; - var passConfig = { - getMaterial: function () { - return gBufferMaterial1; - }, - beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap), - sortCompare: renderer.opaqueSortCompare - }; - // FIXME Use MRT if possible - renderer.renderPass(renderList, camera, passConfig); + } + }, + link: function (inputPinName, fromNode, fromPinName) { + + // The relationship from output pin to input pin is one-on-multiple + this.inputLinks[inputPinName] = { + node: fromNode, + pin: fromPinName + }; + if (!fromNode.outputLinks[fromPinName]) { + fromNode.outputLinks[fromPinName] = []; } - if (enableTargetTexture3) { + fromNode.outputLinks[fromPinName].push({ + node: this, + pin: inputPinName + }); - // Pass 2 - frameBuffer.attach(this._gBufferTex3); - frameBuffer.bind(renderer); + // Enabled the pin texture in shader + this.pass.material.enableTexture(inputPinName); + }, - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); - } - gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); - } + clear: function () { + this.inputLinks = {}; + this.outputLinks = {}; + }, - var gBufferMaterial2 = this._gBufferMaterial2; - var passConfig = { - getMaterial: function () { - return gBufferMaterial2; - }, - beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap), - sortCompare: renderer.opaqueSortCompare - }; - renderer.renderPass(renderList, camera, passConfig); + updateReference: function (outputName) { + if (!this._rendering) { + this._rendering = true; + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + link.node.updateReference(link.pin); + } + this._rendering = false; + } + if (outputName) { + this._outputReferences[outputName] ++; } + }, - renderer.bindSceneRendering(null); - frameBuffer.unbind(renderer); + beforeFrame: function () { + this._rendered = false; + + for (var name in this.outputLinks) { + this._outputReferences[name] = 0; + } }, - renderDebug: function (renderer, camera, type, viewport) { - var debugTypes = { - normal: 0, - depth: 1, - position: 2, - glossiness: 3, - metalness: 4, - albedo: 5 - }; - if (debugTypes[type] == null) { - console.warn('Unkown type "' + type + '"'); - // Default use normal - type = 'normal'; + afterFrame: function () { + // Put back all the textures to pool + for (var name in this.outputLinks) { + if (this._outputReferences[name] > 0) { + var outputInfo = this.outputs[name]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[name]) { + this._compositor.releaseTexture(this._prevOutputTextures[name]); + } + this._prevOutputTextures[name] = this._outputTextures[name]; + } + else { + this._compositor.releaseTexture(this._outputTextures[name]); + } + } } + } +}); - renderer.saveClear(); - renderer.saveViewport(); - renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT; +/** + * @constructor clay.compositor.Graph + * @extends clay.core.Base + */ +var Graph = Base.extend(function () { + return /** @lends clay.compositor.Graph# */ { + /** + * @type {Array.} + */ + nodes: [] + }; +}, +/** @lends clay.compositor.Graph.prototype */ +{ - if (viewport) { - renderer.setViewport(viewport); + /** + * Mark to update + */ + dirty: function () { + this._dirty = true; + }, + /** + * @param {clay.compositor.Node} node + */ + addNode: function (node) { + + if (this.nodes.indexOf(node) >= 0) { + return; } - var viewProjectionInv = new Matrix4(); - Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - var debugPass = this._debugPass; - debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]); - debugPass.setUniform('gBufferTexture1', this._gBufferTex1); - debugPass.setUniform('gBufferTexture2', this._gBufferTex2); - debugPass.setUniform('gBufferTexture3', this._gBufferTex3); - debugPass.setUniform('debug', debugTypes[type]); - debugPass.setUniform('viewProjectionInv', viewProjectionInv.array); - debugPass.render(renderer); + this.nodes.push(node); - renderer.restoreViewport(); - renderer.restoreClear(); + this._dirty = true; }, - /** - * Get first target texture. - * Channel storage: - * + R: normal.x * 0.5 + 0.5 - * + G: normal.y * 0.5 + 0.5 - * + B: normal.z * 0.5 + 0.5 - * + A: glossiness - * @return {clay.Texture2D} + * @param {clay.compositor.Node|string} node */ - getTargetTexture1: function () { - return this._gBufferTex1; + removeNode: function (node) { + if (typeof node === 'string') { + node = this.getNodeByName(node); + } + var idx = this.nodes.indexOf(node); + if (idx >= 0) { + this.nodes.splice(idx, 1); + this._dirty = true; + } }, - /** - * Get second target texture. - * Channel storage: - * + R: depth - * @return {clay.Texture2D} + * @param {string} name + * @return {clay.compositor.Node} */ - getTargetTexture2: function () { - return this._gBufferTex2; + getNodeByName: function (name) { + for (var i = 0; i < this.nodes.length; i++) { + if (this.nodes[i].name === name) { + return this.nodes[i]; + } + } }, - /** - * Get third target texture. - * Channel storage: - * + R: albedo.r - * + G: albedo.g - * + B: albedo.b - * + A: metalness - * @return {clay.Texture2D} + * Update links of graph */ - getTargetTexture3: function () { - return this._gBufferTex3; + update: function () { + for (var i = 0; i < this.nodes.length; i++) { + this.nodes[i].clear(); + } + // Traverse all the nodes and build the graph + for (var i = 0; i < this.nodes.length; i++) { + var node = this.nodes[i]; + + if (!node.inputs) { + continue; + } + for (var inputName in node.inputs) { + if (!node.inputs[inputName]) { + continue; + } + if (node.pass && !node.pass.material.isUniformEnabled(inputName)) { + console.warn('Pin ' + node.name + '.' + inputName + ' not used.'); + continue; + } + var fromPinInfo = node.inputs[inputName]; + + var fromPin = this.findPin(fromPinInfo); + if (fromPin) { + node.link(inputName, fromPin.node, fromPin.pin); + } + else { + if (typeof fromPinInfo === 'string') { + console.warn('Node ' + fromPinInfo + ' not exist'); + } + else { + console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist'); + } + } + } + } }, + findPin: function (input) { + var node; + // Try to take input as a directly a node + if (typeof input === 'string' || input instanceof Node$1) { + input = { + node: input + }; + } - /** - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { + if (typeof input.node === 'string') { + for (var i = 0; i < this.nodes.length; i++) { + var tmp = this.nodes[i]; + if (tmp.name === input.node) { + node = tmp; + } + } + } + else { + node = input.node; + } + if (node) { + var inputPin = input.pin; + if (!inputPin) { + // Use first pin defaultly + if (node.outputs) { + inputPin = Object.keys(node.outputs)[0]; + } + } + if (node.outputs[inputPin]) { + return { + node: node, + pin: inputPin + }; + } + } } }); -var vec3$17 = glmatrix.vec3; -var vec2$1 = glmatrix.vec2; - /** - * @constructor clay.geometry.Cone - * @extends clay.Geometry - * @param {Object} [opt] - * @param {number} [opt.topRadius] - * @param {number} [opt.bottomRadius] - * @param {number} [opt.height] - * @param {number} [opt.capSegments] - * @param {number} [opt.heightSegments] + * Compositor provide graph based post processing + * + * @constructor clay.compositor.Compositor + * @extends clay.compositor.Graph + * */ -var Cone$1 = Geometry.extend( -/** @lends clay.geometry.Cone# */ -{ - dynamic: false, - /** - * @type {number} - */ - topRadius: 0, - - /** - * @type {number} - */ - bottomRadius: 1, - - /** - * @type {number} - */ - height: 2, +var Compositor = Graph.extend(function() { + return { + // Output node + _outputs: [], - /** - * @type {number} - */ - capSegments: 20, + _texturePool: new TexturePool(), - /** - * @type {number} - */ - heightSegments: 1 -}, function() { - this.build(); + _frameBuffer: new FrameBuffer({ + depthBuffer: false + }) + }; }, -/** @lends clay.geometry.Cone.prototype */ +/** @lends clay.compositor.Compositor.prototype */ { + addNode: function(node) { + Graph.prototype.addNode.call(this, node); + node._compositor = this; + }, /** - * Build cone geometry + * @param {clay.Renderer} renderer */ - build: function() { - var positions = []; - var texcoords = []; - var faces = []; - positions.length = 0; - texcoords.length = 0; - faces.length = 0; - // Top cap - var capSegRadial = Math.PI * 2 / this.capSegments; - - var topCap = []; - var bottomCap = []; - - var r1 = this.topRadius; - var r2 = this.bottomRadius; - var y = this.height / 2; - - var c1 = vec3$17.fromValues(0, y, 0); - var c2 = vec3$17.fromValues(0, -y, 0); - for (var i = 0; i < this.capSegments; i++) { - var theta = i * capSegRadial; - var x = r1 * Math.sin(theta); - var z = r1 * Math.cos(theta); - topCap.push(vec3$17.fromValues(x, y, z)); + render: function(renderer, frameBuffer) { + if (this._dirty) { + this.update(); + this._dirty = false; - x = r2 * Math.sin(theta); - z = r2 * Math.cos(theta); - bottomCap.push(vec3$17.fromValues(x, -y, z)); + this._outputs.length = 0; + for (var i = 0; i < this.nodes.length; i++) { + if (!this.nodes[i].outputs) { + this._outputs.push(this.nodes[i]); + } + } } - // Build top cap - positions.push(c1); - // FIXME - texcoords.push(vec2$1.fromValues(0, 1)); - var n = this.capSegments; - for (var i = 0; i < n; i++) { - positions.push(topCap[i]); - // FIXME - texcoords.push(vec2$1.fromValues(i / n, 0)); - faces.push([0, i+1, (i+1) % n + 1]); + for (var i = 0; i < this.nodes.length; i++) { + // Update the reference number of each output texture + this.nodes[i].beforeFrame(); } - // Build bottom cap - var offset = positions.length; - positions.push(c2); - texcoords.push(vec2$1.fromValues(0, 1)); - for (var i = 0; i < n; i++) { - positions.push(bottomCap[i]); - // FIXME - texcoords.push(vec2$1.fromValues(i / n, 0)); - faces.push([offset, offset+((i+1) % n + 1), offset+i+1]); + for (var i = 0; i < this._outputs.length; i++) { + this._outputs[i].updateReference(); } - // Build side - offset = positions.length; - var n2 = this.heightSegments; - for (var i = 0; i < n; i++) { - for (var j = 0; j < n2+1; j++) { - var v = j / n2; - positions.push(vec3$17.lerp(vec3$17.create(), topCap[i], bottomCap[i], v)); - texcoords.push(vec2$1.fromValues(i / n, v)); - } + for (var i = 0; i < this._outputs.length; i++) { + this._outputs[i].render(renderer, frameBuffer); } - for (var i = 0; i < n; i++) { - for (var j = 0; j < n2; j++) { - var i1 = i * (n2 + 1) + j; - var i2 = ((i + 1) % n) * (n2 + 1) + j; - var i3 = ((i + 1) % n) * (n2 + 1) + j + 1; - var i4 = i * (n2 + 1) + j + 1; - faces.push([offset+i2, offset+i1, offset+i4]); - faces.push([offset+i4, offset+i3, offset+i2]); - } + + for (var i = 0; i < this.nodes.length; i++) { + // Clear up + this.nodes[i].afterFrame(); } + }, - this.attributes.position.fromArray(positions); - this.attributes.texcoord0.fromArray(texcoords); + allocateTexture: function (parameters) { + return this._texturePool.get(parameters); + }, - this.initIndicesFromArray(faces); + releaseTexture: function (parameters) { + this._texturePool.put(parameters); + }, - this.generateVertexNormals(); + getFrameBuffer: function () { + return this._frameBuffer; + }, - this.boundingBox = new BoundingBox(); - var r = Math.max(this.topRadius, this.bottomRadius); - this.boundingBox.min.set(-r, -this.height/2, -r); - this.boundingBox.max.set(r, this.height/2, r); + /** + * Dispose compositor + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { + this._texturePool.clear(renderer); } }); /** - * @constructor clay.geometry.Cylinder - * @extends clay.Geometry - * @param {Object} [opt] - * @param {number} [opt.radius] - * @param {number} [opt.height] - * @param {number} [opt.capSegments] - * @param {number} [opt.heightSegments] + * @constructor clay.compositor.SceneNode + * @extends clay.compositor.Node */ -var Cylinder$1 = Geometry.extend( -/** @lends clay.geometry.Cylinder# */ +var SceneNode$1 = Node$1.extend( +/** @lends clay.compositor.SceneNode# */ { - dynamic: false, - /** - * @type {number} - */ - radius: 1, - + name: 'scene', /** - * @type {number} + * @type {clay.Scene} */ - height: 2, - + scene: null, /** - * @type {number} + * @type {clay.Camera} */ - capSegments: 50, - + camera: null, /** - * @type {number} + * @type {boolean} */ - heightSegments: 1 -}, function() { - this.build(); -}, -/** @lends clay.geometry.Cylinder.prototype */ -{ + autoUpdateScene: true, /** - * Build cylinder geometry + * @type {boolean} */ - build: function() { - var cone = new Cone$1({ - topRadius: this.radius, - bottomRadius: this.radius, - capSegments: this.capSegments, - heightSegments: this.heightSegments, - height: this.height - }); + preZ: false - this.attributes.position.value = cone.attributes.position.value; - this.attributes.normal.value = cone.attributes.normal.value; - this.attributes.texcoord0.value = cone.attributes.texcoord0.value; - this.indices = cone.indices; +}, function() { + this.frameBuffer = new FrameBuffer(); +}, { + render: function(renderer) { - this.boundingBox = cone.boundingBox; - } -}); + this._rendering = true; + var _gl = renderer.gl; -var lightvolumeGlsl = "@export clay.deferred.light_volume.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_Position;\nvoid main()\n{\n gl_Position = worldViewProjection * vec4(position, 1.0);\n v_Position = position;\n}\n@end"; + this.trigger('beforerender'); -var spotGlsl = "@export clay.deferred.spot_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\n@import clay.util.calculate_attenuation\nuniform vec3 lightPosition;\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform float umbraAngleCosine;\nuniform float penumbraAngleCosine;\nuniform float lightRange;\nuniform float falloffFactor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform mat4 lightMatrix;\nuniform float lightShadowMapSize;\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n float attenuation = lightAttenuation(dist, lightRange);\n float c = dot(-normalize(lightDirection), L);\n float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrix, position, lightShadowMapSize\n );\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; + var renderInfo; -var directionalGlsl = "@export clay.deferred.directional_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform float lightShadowMapSize;\nuniform mat4 lightMatrices[SHADOW_CASCADE];\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = -normalize(lightDirection);\n vec3 V = normalize(eyePosition - position);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = 1.0;\n for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\n if (\n z >= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; + if (!this.outputs) { -var ambientGlsl = "@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"; + renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); -var ambientshGlsl = "@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"; + } + else { -var ambientcubemapGlsl = "@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"; + var frameBuffer = this.frameBuffer; + for (var name in this.outputs) { + var parameters = this.updateParameter(name, renderer); + var outputInfo = this.outputs[name]; + var texture = this._compositor.allocateTexture(parameters); + this._outputTextures[name] = texture; -var pointGlsl = "@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"; + var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; + if (typeof(attachment) == 'string') { + attachment = _gl[attachment]; + } + frameBuffer.attach(texture, attachment); + } + frameBuffer.bind(renderer); -var sphereGlsl = "@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"; + // MRT Support in chrome + // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html + var ext = renderer.getGLExtension('EXT_draw_buffers'); + if (ext) { + var bufs = []; + for (var attachment in this.outputs) { + attachment = parseInt(attachment); + if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) { + bufs.push(attachment); + } + } + ext.drawBuffersEXT(bufs); + } -var tubeGlsl = "@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"; + // Always clear + // PENDING + renderer.saveClear(); + renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT; + renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); + renderer.restoreClear(); -// Light-pre pass deferred rendering -// http://www.realtimerendering.com/blog/deferred-lighting-approaches/ -// Light shaders -Shader.import(prezGlsl); -Shader.import(utilGlsl); -Shader.import(lightvolumeGlsl); + frameBuffer.unbind(renderer); + } -// Light shaders -Shader.import(spotGlsl); -Shader.import(directionalGlsl); -Shader.import(ambientGlsl); -Shader.import(ambientshGlsl); -Shader.import(ambientcubemapGlsl); -Shader.import(pointGlsl); -Shader.import(sphereGlsl); -Shader.import(tubeGlsl); + this.trigger('afterrender', renderInfo); -Shader.import(prezGlsl); + this._rendering = false; + this._rendered = true; + } +}); /** - * Deferred renderer - * @constructor - * @alias clay.deferred.Renderer - * @extends clay.core.Base + * @constructor clay.compositor.TextureNode + * @extends clay.compositor.Node */ -var DeferredRenderer = Base.extend(function () { - - var fullQuadVertex = Shader.source('clay.compositor.vertex'); - var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex'); - - var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light')); - - var lightAccumulateBlendFunc = function (gl) { - gl.blendEquation(gl.FUNC_ADD); - gl.blendFunc(gl.ONE, gl.ONE); - }; - - var createLightPassMat = function (shader) { - return new Material({ - shader: shader, - blend: lightAccumulateBlendFunc, - transparent: true, - depthMask: false - }); - }; +var TextureNode$1 = Node$1.extend(function() { + return /** @lends clay.compositor.TextureNode# */ { + /** + * @type {clay.Texture2D} + */ + texture: null, - var createVolumeShader = function (name) { - return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name)); + // Texture node must have output without parameters + outputs: { + color: {} + } }; +}, function () { +}, { - // Rotate and positioning to fit the spot light - // Which the cusp of cone pointing to the positive z - // and positioned on the origin - var coneGeo = new Cone$1({ - capSegments: 10 - }); - var mat = new Matrix4(); - mat.rotateX(Math.PI / 2) - .translate(new Vector3(0, -1, 0)); + getOutput: function (renderer, name) { + return this.texture; + }, - coneGeo.applyTransform(mat); + // Do nothing + beforeFrame: function () {}, + afterFrame: function () {} +}); - var cylinderGeo = new Cylinder$1({ - capSegments: 10 - }); - // Align with x axis - mat.identity().rotateZ(Math.PI / 2); - cylinderGeo.applyTransform(mat); +// TODO Shader library +// TODO curlnoise demo wrong - return /** @lends clay.deferred.Renderer# */ { +// PENDING +// Use topological sort ? +/** + * Filter node + * + * @constructor clay.compositor.FilterNode + * @extends clay.compositor.Node + * + * @example + var node = new clay.compositor.Node({ + name: 'fxaa', + shader: clay.Shader.source('clay.compositor.fxaa'), + inputs: { + texture: { + node: 'scene', + pin: 'color' + } + }, + // Multiple outputs is preserved for MRT support in WebGL2.0 + outputs: { + color: { + attachment: clay.FrameBuffer.COLOR_ATTACHMENT0 + parameters: { + format: clay.Texture.RGBA, + width: 512, + height: 512 + }, + // Node will keep the RTT rendered in last frame + keepLastFrame: true, + // Force the node output the RTT rendered in last frame + outputLastFrame: true + } + } + }); + * + */ +var FilterNode$1 = Node$1.extend(function () { + return /** @lends clay.compositor.Node# */ { /** - * Provide ShadowMapPass for shadow rendering. - * @type {clay.prePass.ShadowMap} + * @type {string} */ - shadowMapPass: null, + name: '', + /** - * If enable auto resizing from given defualt renderer size. - * @type {boolean} + * @type {Object} */ - autoResize: true, + inputs: {}, - _createLightPassMat: createLightPassMat, + /** + * @type {Object} + */ + outputs: null, - _gBuffer: new GBuffer(), + /** + * @type {string} + */ + shader: '', - _lightAccumFrameBuffer: new FrameBuffer({ - depthBuffer: false - }), + /** + * Input links, will be updated by the graph + * @example: + * inputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + inputLinks: {}, - _lightAccumTex: new Texture2D({ - // FIXME Device not support float texture - type: Texture.HALF_FLOAT, - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST - }), + /** + * Output links, will be updated by the graph + * @example: + * outputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + outputLinks: {}, - _fullQuadPass: new Pass({ - blendWithPrevious: true - }), + /** + * @type {clay.compositor.Pass} + */ + pass: null, - _directionalLightMat: createLightPassMat(directionalLightShader), + // Save the output texture of previous frame + // Will be used when there exist a circular reference + _prevOutputTextures: {}, + _outputTextures: {}, - _ambientMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_light') - )), - _ambientSHMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light') - )), - _ambientCubemapMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light') - )), + // Example: { name: 2 } + _outputReferences: {}, - _spotLightShader: createVolumeShader('spot_light'), - _pointLightShader: createVolumeShader('point_light'), + _rendering: false, + // If rendered in this frame + _rendered: false, - _sphereLightShader: createVolumeShader('sphere_light'), - _tubeLightShader: createVolumeShader('tube_light'), + _compositor: null + }; +}, function () { - _lightSphereGeo: new Sphere$1({ - widthSegments: 10, - heightSegements: 10 - }), + var pass = new Pass({ + fragment: this.shader + }); + this.pass = pass; +}, +/** @lends clay.compositor.Node.prototype */ +{ + /** + * @param {clay.Renderer} renderer + */ + render: function (renderer, frameBuffer) { + this.trigger('beforerender', renderer); - _lightConeGeo: coneGeo, + this._rendering = true; - _lightCylinderGeo: cylinderGeo, + var _gl = renderer.gl; - _outputPass: new Pass({ - fragment: Shader.source('clay.compositor.output') - }) - }; -}, /** @lends clay.deferred.Renderer# */ { - /** - * Do render - * @param {clay.Renderer} renderer - * @param {clay.Scene} scene - * @param {clay.Camera} camera - * @param {Object} [opts] - * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture - * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow. - * @param {boolean} [opts.notUpdateScene = true] If not update the scene. - */ - render: function (renderer, scene, camera, opts) { + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + var inputTexture = link.node.getOutput(renderer, link.pin); + this.pass.setUniform(inputName, inputTexture); + } + // Output + if (!this.outputs) { + this.pass.outputs = null; - opts = opts || {}; - opts.renderToTarget = opts.renderToTarget || false; - opts.notUpdateShadow = opts.notUpdateShadow || false; - opts.notUpdateScene = opts.notUpdateScene || false; + this._compositor.getFrameBuffer().unbind(renderer); - if (!opts.notUpdateScene) { - scene.update(false, true); + this.pass.render(renderer, frameBuffer); } + else { + this.pass.outputs = {}; - camera.update(true); + var attachedTextures = {}; + for (var name in this.outputs) { + var parameters = this.updateParameter(name, renderer); + if (isNaN(parameters.width)) { + this.updateParameter(name, renderer); + } + var outputInfo = this.outputs[name]; + var texture = this._compositor.allocateTexture(parameters); + this._outputTextures[name] = texture; + var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; + if (typeof(attachment) == 'string') { + attachment = _gl[attachment]; + } + attachedTextures[attachment] = texture; + } + this._compositor.getFrameBuffer().bind(renderer); - // PENDING For stereo rendering - var dpr = renderer.getDevicePixelRatio(); - if (this.autoResize - && (renderer.getWidth() * dpr !== this._lightAccumTex.width - || renderer.getHeight() * dpr !== this._lightAccumTex.height) - ) { - this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr); + for (var attachment in attachedTextures) { + // FIXME attachment changes in different nodes + this._compositor.getFrameBuffer().attach( + attachedTextures[attachment], attachment + ); + } + + this.pass.render(renderer); + + // Because the data of texture is changed over time, + // Here update the mipmaps of texture each time after rendered; + this._compositor.getFrameBuffer().updateMipmap(renderer.gl); } - this._gBuffer.update(renderer, scene, camera); + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + link.node.removeReference(link.pin); + } - // Accumulate light buffer - this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow); + this._rendering = false; + this._rendered = true; - if (!opts.renderToTarget) { - this._outputPass.setUniform('texture', this._lightAccumTex); + this.trigger('afterrender', renderer); + }, - this._outputPass.render(renderer); - // this._gBuffer.renderDebug(renderer, camera, 'normal'); + // TODO Remove parameter function callback + updateParameter: function (outputName, renderer) { + var outputInfo = this.outputs[outputName]; + var parameters = outputInfo.parameters; + var parametersCopy = outputInfo._parametersCopy; + if (!parametersCopy) { + parametersCopy = outputInfo._parametersCopy = {}; + } + if (parameters) { + for (var key in parameters) { + if (key !== 'width' && key !== 'height') { + parametersCopy[key] = parameters[key]; + } + } + } + var width, height; + if (parameters.width instanceof Function) { + width = parameters.width.call(this, renderer); + } + else { + width = parameters.width; + } + if (parameters.height instanceof Function) { + height = parameters.height.call(this, renderer); + } + else { + height = parameters.height; + } + if ( + parametersCopy.width !== width + || parametersCopy.height !== height + ) { + if (this._outputTextures[outputName]) { + this._outputTextures[outputName].dispose(renderer); + } } + parametersCopy.width = width; + parametersCopy.height = height; + + return parametersCopy; }, /** - * @return {clay.Texture2D} + * Set parameter + * @param {string} name + * @param {} value */ - getTargetTexture: function () { - return this._lightAccumTex; + setParameter: function (name, value) { + this.pass.setUniform(name, value); }, - /** - * @return {clay.FrameBuffer} + * Get parameter value + * @param {string} name + * @return {} */ - getTargetFrameBuffer: function () { - return this._lightAccumFrameBuffer; + getParameter: function (name) { + return this.pass.getUniform(name); }, - /** - * @return {clay.deferred.GBuffer} + * Set parameters + * @param {Object} obj */ - getGBuffer: function () { - return this._gBuffer; - }, - - // TODO is dpr needed? - setViewport: function (x, y, width, height, dpr) { - this._gBuffer.setViewport(x, y, width, height, dpr); - this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport(); + setParameters: function (obj) { + for (var name in obj) { + this.setParameter(name, obj[name]); + } }, - - // getFullQuadLightPass: function () { - // return this._fullQuadPass; + // /** + // * Set shader code + // * @param {string} shaderStr + // */ + // setShader: function (shaderStr) { + // var material = this.pass.material; + // material.shader.setFragment(shaderStr); + // material.attachShader(material.shader, true); // }, - /** - * Set renderer size. - * @param {number} width - * @param {number} height + * Proxy of pass.material.define('fragment', xxx); + * @param {string} symbol + * @param {number} [val] */ - resize: function (width, height) { - this._lightAccumTex.width = width; - this._lightAccumTex.height = height; - - // PENDING viewport ? - this._gBuffer.resize(width, height); + define: function (symbol, val) { + this.pass.material.define('fragment', symbol, val); }, - _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) { - var gl = renderer.gl; - var lightAccumTex = this._lightAccumTex; - var lightAccumFrameBuffer = this._lightAccumFrameBuffer; - - var eyePosition = camera.getWorldPosition().array; - - // Update volume meshes - for (var i = 0; i < scene.lights.length; i++) { - this._updateLightProxy(scene.lights[i]); - } - - var shadowMapPass = this.shadowMapPass; - if (shadowMapPass && updateShadow) { - gl.clearColor(1, 1, 1, 1); - this._prepareLightShadow(renderer, scene, camera); - } - - this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow); - - lightAccumFrameBuffer.attach(lightAccumTex); - lightAccumFrameBuffer.bind(renderer); - var clearColor = renderer.clearColor; - - var viewport = lightAccumFrameBuffer.viewport; - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); - } - gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]); - gl.clear(gl.COLOR_BUFFER_BIT); - gl.enable(gl.BLEND); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); - } - - this.trigger('startlightaccumulate', renderer, scene, camera); - - var viewProjectionInv = new Matrix4(); - Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - - var volumeMeshList = []; - - for (var i = 0; i < scene.lights.length; i++) { - var light = scene.lights[i]; - var uTpl = light.uniformTemplates; - - var volumeMesh = light.volumeMesh || light.__volumeMesh; - - if (volumeMesh) { - var material = volumeMesh.material; - // Volume mesh will affect the scene bounding box when rendering - // if castShadow is true - volumeMesh.castShadow = false; - - var unknownLightType = false; - switch (light.type) { - case 'POINT_LIGHT': - material.setUniform('lightColor', uTpl.pointLightColor.value(light)); - material.setUniform('lightRange', uTpl.pointLightRange.value(light)); - material.setUniform('lightPosition', uTpl.pointLightPosition.value(light)); - break; - case 'SPOT_LIGHT': - material.setUniform('lightPosition', uTpl.spotLightPosition.value(light)); - material.setUniform('lightColor', uTpl.spotLightColor.value(light)); - material.setUniform('lightRange', uTpl.spotLightRange.value(light)); - material.setUniform('lightDirection', uTpl.spotLightDirection.value(light)); - material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light)); - material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light)); - material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light)); - break; - case 'SPHERE_LIGHT': - material.setUniform('lightColor', uTpl.sphereLightColor.value(light)); - material.setUniform('lightRange', uTpl.sphereLightRange.value(light)); - material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light)); - material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light)); - break; - case 'TUBE_LIGHT': - material.setUniform('lightColor', uTpl.tubeLightColor.value(light)); - material.setUniform('lightRange', uTpl.tubeLightRange.value(light)); - material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light)); - material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light)); - break; - default: - unknownLightType = true; - } - - if (unknownLightType) { - continue; - } - - material.setUniform('eyePosition', eyePosition); - material.setUniform('viewProjectionInv', viewProjectionInv.array); - material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); - material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); - material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - - volumeMeshList.push(volumeMesh); - - } - else { - var pass = this._fullQuadPass; - var unknownLightType = false; - // Full quad light - switch (light.type) { - case 'AMBIENT_LIGHT': - pass.material = this._ambientMat; - pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light)); - break; - case 'AMBIENT_SH_LIGHT': - pass.material = this._ambientSHMat; - pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light)); - pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light)); - break; - case 'AMBIENT_CUBEMAP_LIGHT': - pass.material = this._ambientCubemapMat; - pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light)); - pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light)); - pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light)); - break; - case 'DIRECTIONAL_LIGHT': - var hasShadow = shadowMapPass && light.castShadow; - pass.material = this._directionalLightMat; - pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); - if (hasShadow) { - pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade); - } - pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light)); - pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light)); - break; - default: - // Unkonw light type - unknownLightType = true; - } - if (unknownLightType) { - continue; - } - - var passMaterial = pass.material; - passMaterial.setUniform('eyePosition', eyePosition); - passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array); - passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); - passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); - passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - - // TODO - if (shadowMapPass && light.castShadow) { - passMaterial.setUniform('lightShadowMap', light.__shadowMap); - passMaterial.setUniform('lightMatrices', light.__lightMatrices); - passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear); - passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar); + /** + * Proxy of pass.material.undefine('fragment', xxx) + * @param {string} symbol + */ + undefine: function (symbol) { + this.pass.material.undefine('fragment', symbol); + }, - passMaterial.setUniform('lightShadowMapSize', light.shadowResolution); + removeReference: function (outputName) { + this._outputReferences[outputName]--; + if (this._outputReferences[outputName] === 0) { + var outputInfo = this.outputs[outputName]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[outputName]) { + this._compositor.releaseTexture(this._prevOutputTextures[outputName]); } - - pass.renderQuad(renderer); + this._prevOutputTextures[outputName] = this._outputTextures[outputName]; + } + else { + // Output of this node have alreay been used by all other nodes + // Put the texture back to the pool. + this._compositor.releaseTexture(this._outputTextures[outputName]); } } - - this._renderVolumeMeshList(renderer, camera, volumeMeshList); - - this.trigger('lightaccumulate', renderer, scene, camera); - - lightAccumFrameBuffer.unbind(renderer); - - this.trigger('afterlightaccumulate', renderer, scene, camera); - }, - _prepareLightShadow: (function () { - var worldView = new Matrix4(); - return function (renderer, scene, camera) { - var shadowCasters; + clear: function () { + Node$1.prototype.clear.call(this); - shadowCasters = this._shadowCasters || (this._shadowCasters = []); - var count = 0; - var list = scene.opaqueList; - for (var i = 0; i < list.length; i++) { - if (list[i].castShadow) { - shadowCasters[count++] = list[i]; - } - } - shadowCasters.length = count; + // Default disable all texture + this.pass.material.disableTexturesAll(); + } +}); - for (var i = 0; i < scene.lights.length; i++) { - var light = scene.lights[i]; - var volumeMesh = light.volumeMesh || light.__volumeMesh; - if (!light.castShadow) { - continue; - } +var shaderSourceReg = /^#source\((.*?)\)/; - switch (light.type) { - case 'POINT_LIGHT': - case 'SPOT_LIGHT': - // Frustum culling - Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); - if (renderer.isFrustumCulled( - volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array - )) { - continue; - } +/** + * @name clay.compositor.createCompositor + * @function + * @param {Object} json + * @param {Object} [opts] + * @return {clay.compositor.Compositor} + */ +function createCompositor(json, opts) { + var compositor = new Compositor(); + opts = opts || {}; - this._prepareSingleLightShadow( - renderer, scene, camera, light, shadowCasters, volumeMesh.material - ); - break; - case 'DIRECTIONAL_LIGHT': - this._prepareSingleLightShadow( - renderer, scene, camera, light, shadowCasters, null - ); - } + var lib = { + textures: {}, + parameters: {} + }; + var afterLoad = function(shaderLib, textureLib) { + for (var i = 0; i < json.nodes.length; i++) { + var nodeInfo = json.nodes[i]; + var node = createNode(nodeInfo, lib, opts); + if (node) { + compositor.addNode(node); } - }; - })(), + } + }; - _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) { - switch (light.type) { - case 'POINT_LIGHT': - var shadowMaps = []; - this.shadowMapPass.renderPointLightShadow( - renderer, scene, light, casters, shadowMaps - ); - material.setUniform('lightShadowMap', shadowMaps[0]); - material.setUniform('lightShadowMapSize', light.shadowResolution); - break; - case 'SPOT_LIGHT': - var shadowMaps = []; - var lightMatrices = []; - this.shadowMapPass.renderSpotLightShadow( - renderer, scene, light, casters, lightMatrices, shadowMaps - ); - material.setUniform('lightShadowMap', shadowMaps[0]); - material.setUniform('lightMatrix', lightMatrices[0]); - material.setUniform('lightShadowMapSize', light.shadowResolution); - break; - case 'DIRECTIONAL_LIGHT': - var shadowMaps = []; - var lightMatrices = []; - var cascadeClips = []; - this.shadowMapPass.renderDirectionalLightShadow( - renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps - ); - var cascadeClipsNear = cascadeClips.slice(); - var cascadeClipsFar = cascadeClips.slice(); - cascadeClipsNear.pop(); - cascadeClipsFar.shift(); + for (var name in json.parameters) { + var paramInfo = json.parameters[name]; + lib.parameters[name] = convertParameter(paramInfo); + } + // TODO load texture asynchronous + loadTextures(json, lib, opts, function(textureLib) { + lib.textures = textureLib; + afterLoad(); + }); - // Iterate from far to near - cascadeClipsNear.reverse(); - cascadeClipsFar.reverse(); - lightMatrices.reverse(); + return compositor; +} - light.__cascadeClipsNear = cascadeClipsNear; - light.__cascadeClipsFar = cascadeClipsFar; - light.__shadowMap = shadowMaps[0]; - light.__lightMatrices = lightMatrices; - break; +function createNode(nodeInfo, lib, opts) { + var type = nodeInfo.type || 'filter'; + var shaderSource; + var inputs; + var outputs; + + if (type === 'filter') { + var shaderExp = nodeInfo.shader.trim(); + var res = shaderSourceReg.exec(shaderExp); + if (res) { + shaderSource = Shader.source(res[1].trim()); } - }, + else if (shaderExp.charAt(0) === '#') { + shaderSource = lib.shaders[shaderExp.substr(1)]; + } + if (!shaderSource) { + shaderSource = shaderExp; + } + if (!shaderSource) { + return; + } + } - // Update light volume mesh - // Light volume mesh is rendered in light accumulate pass instead of full quad. - // It will reduce pixels significantly when local light is relatively small. - // And we can use custom volume mesh to shape the light. - // - // See "Deferred Shading Optimizations" in GDC2011 - _updateLightProxy: function (light) { - var volumeMesh; - if (light.volumeMesh) { - volumeMesh = light.volumeMesh; + if (nodeInfo.inputs) { + inputs = {}; + for (var name in nodeInfo.inputs) { + if (typeof nodeInfo.inputs[name] === 'string') { + inputs[name] = nodeInfo.inputs[name]; + } + else { + inputs[name] = { + node: nodeInfo.inputs[name].node, + pin: nodeInfo.inputs[name].pin + }; + } } - else { - switch (light.type) { - // Only local light (point and spot) needs volume mesh. - // Directional and ambient light renders in full quad - case 'POINT_LIGHT': - case 'SPHERE_LIGHT': - var shader = light.type === 'SPHERE_LIGHT' - ? this._sphereLightShader : this._pointLightShader; - // Volume mesh created automatically - if (!light.__volumeMesh) { - light.__volumeMesh = new Mesh({ - material: this._createLightPassMat(shader), - geometry: this._lightSphereGeo, - // Disable culling - // if light volume mesh intersect camera near plane - // We need mesh inside can still be rendered - culling: false - }); + } + if (nodeInfo.outputs) { + outputs = {}; + for (var name in nodeInfo.outputs) { + var outputInfo = nodeInfo.outputs[name]; + outputs[name] = {}; + if (outputInfo.attachment != null) { + outputs[name].attachment = outputInfo.attachment; + } + if (outputInfo.keepLastFrame != null) { + outputs[name].keepLastFrame = outputInfo.keepLastFrame; + } + if (outputInfo.outputLastFrame != null) { + outputs[name].outputLastFrame = outputInfo.outputLastFrame; + } + if (outputInfo.parameters) { + outputs[name].parameters = convertParameter(outputInfo.parameters); + } + } + } + var node; + if (type === 'scene') { + node = new SceneNode$1({ + name: nodeInfo.name, + scene: opts.scene, + camera: opts.camera, + outputs: outputs + }); + } + else if (type === 'texture') { + node = new TextureNode$1({ + name: nodeInfo.name, + outputs: outputs + }); + } + // Default is filter + else { + node = new FilterNode$1({ + name: nodeInfo.name, + shader: shaderSource, + inputs: inputs, + outputs: outputs + }); + } + if (node) { + if (nodeInfo.parameters) { + for (var name in nodeInfo.parameters) { + var val = nodeInfo.parameters[name]; + if (typeof(val) === 'string') { + val = val.trim(); + if (val.charAt(0) === '#') { + val = lib.textures[val.substr(1)]; } - volumeMesh = light.__volumeMesh; - var r = light.range + (light.radius || 0); - volumeMesh.scale.set(r, r, r); - break; - case 'SPOT_LIGHT': - light.__volumeMesh = light.__volumeMesh || new Mesh({ - material: this._createLightPassMat(this._spotLightShader), - geometry: this._lightConeGeo, - culling: false - }); - volumeMesh = light.__volumeMesh; - var aspect = Math.tan(light.penumbraAngle * Math.PI / 180); - var range = light.range; - volumeMesh.scale.set(aspect * range, aspect * range, range / 2); - break; - case 'TUBE_LIGHT': - light.__volumeMesh = light.__volumeMesh || new Mesh({ - material: this._createLightPassMat(this._tubeLightShader), - geometry: this._lightCylinderGeo, - culling: false - }); - volumeMesh = light.__volumeMesh; - var range = light.range; - volumeMesh.scale.set(light.length / 2 + range, range, range); - break; + else { + node.on( + 'beforerender', createSizeSetHandler( + name, tryConvertExpr(val) + ) + ); + } + } + node.setParameter(name, val); } } - if (volumeMesh) { - volumeMesh.update(); - // Apply light transform - Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform); - var hasShadow = this.shadowMapPass && light.castShadow; - volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + if (nodeInfo.defines && node.pass) { + for (var name in nodeInfo.defines) { + var val = nodeInfo.defines[name]; + node.pass.material.define('fragment', name, val); + } } - }, + } + return node; +} - _renderVolumeMeshList: (function () { - var worldViewProjection = new Matrix4(); - var worldView = new Matrix4(); - var preZMaterial = new Material({ - shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment')) +function convertParameter(paramInfo) { + var param = {}; + if (!paramInfo) { + return param; + } + ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap'] + .forEach(function(name) { + var val = paramInfo[name]; + if (val != null) { + // Convert string to enum + if (typeof val === 'string') { + val = Texture[val]; + } + param[name] = val; + } }); - return function (renderer, camera, volumeMeshList) { - var gl = renderer.gl; - - gl.enable(gl.DEPTH_TEST); - gl.disable(gl.CULL_FACE); - gl.blendEquation(gl.FUNC_ADD); - gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE); - gl.depthFunc(gl.LEQUAL); - - gl.clear(gl.DEPTH_BUFFER_BIT); - - var viewport = renderer.viewport; - var dpr = viewport.devicePixelRatio; - var viewportUniform = [ - viewport.x * dpr, viewport.y * dpr, - viewport.width * dpr, viewport.height * dpr - ]; - - var windowSizeUniform = [ - this._lightAccumTex.width, - this._lightAccumTex.height - ]; - - for (var i = 0; i < volumeMeshList.length; i++) { - var volumeMesh = volumeMeshList[i]; - - // Frustum culling - Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); - if (renderer.isFrustumCulled( - volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array - )) { - continue; + ['width', 'height'] + .forEach(function(name) { + if (paramInfo[name] != null) { + var val = paramInfo[name]; + if (typeof val === 'string') { + val = val.trim(); + param[name] = createSizeParser( + name, tryConvertExpr(val) + ); } + else { + param[name] = val; + } + } + }); + if (paramInfo.useMipmap != null) { + param.useMipmap = paramInfo.useMipmap; + } + return param; +} - // Use prez to avoid one pixel rendered twice - gl.colorMask(false, false, false, false); - gl.depthMask(true); - // depthMask must be enabled before clear DEPTH_BUFFER - gl.clear(gl.DEPTH_BUFFER_BIT); - - Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView); - - var preZProgram = renderer.getProgram(volumeMesh, preZMaterial); - volumeMesh.__program = preZProgram; - renderer.validateProgram(preZProgram); - preZProgram.bind(renderer); - - var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION; - preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); - volumeMesh.render(renderer, preZMaterial, preZProgram); - - // Render light - gl.colorMask(true, true, true, true); - gl.depthMask(false); - var program = renderer.getProgram(volumeMesh, volumeMesh.material); - volumeMesh.__program = program; - renderer.validateProgram(program); - program.bind(renderer); - - var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION; - // Set some common uniforms - program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); - program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform); - program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform); +function loadTextures(json, lib, opts, callback) { + if (!json.textures) { + callback({}); + return; + } + var textures = {}; + var loading = 0; - volumeMesh.material.bind(renderer, program); - volumeMesh.render(renderer, volumeMesh.material, program); + var cbd = false; + var textureRootPath = opts.textureRootPath; + util$1.each(json.textures, function(textureInfo, name) { + var texture; + var path = textureInfo.path; + var parameters = convertParameter(textureInfo.parameters); + if (Array.isArray(path) && path.length === 6) { + if (textureRootPath) { + path = path.map(function(item) { + return util$1.relative2absolute(item, textureRootPath); + }); } + texture = new TextureCube(parameters); + } + else if(typeof path === 'string') { + if (textureRootPath) { + path = util$1.relative2absolute(path, textureRootPath); + } + texture = new Texture2D(parameters); + } + else { + return; + } - gl.depthFunc(gl.LESS); - }; - })(), - - /** - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { - this._gBuffer.dispose(renderer); + texture.load(path); + loading++; + texture.once('success', function() { + textures[name] = texture; + loading--; + if (loading === 0) { + callback(textures); + cbd = true; + } + }); + }); - this._lightAccumFrameBuffer.dispose(renderer); - this._lightAccumTex.dispose(renderer); + if (loading === 0 && !cbd) { + callback(textures); + } +} - this._lightConeGeo.dispose(renderer); - this._lightCylinderGeo.dispose(renderer); - this._lightSphereGeo.dispose(renderer); +function createSizeSetHandler(name, exprFunc) { + return function (renderer) { + // PENDING viewport size or window size + var dpr = renderer.getDevicePixelRatio(); + // PENDING If multiply dpr ? + var width = renderer.getWidth(); + var height = renderer.getHeight(); + var result = exprFunc(width, height, dpr); + this.setParameter(name, result); + }; +} - this._fullQuadPass.dispose(renderer); - this._outputPass.dispose(renderer); +function createSizeParser(name, exprFunc) { + return function (renderer) { + var dpr = renderer.getDevicePixelRatio(); + var width = renderer.getWidth(); + var height = renderer.getHeight(); + return exprFunc(width, height, dpr); + }; +} - this._directionalLightMat.dispose(renderer); +function tryConvertExpr(string) { + // PENDING + var exprRes = /^expr\((.*)\)$/.exec(string); + if (exprRes) { + try { + var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]); + // Try run t + func(1, 1); - this.shadowMapPass.dispose(renderer); + return func; + } + catch (e) { + throw new Error('Invalid expression.'); + } } -}); +} /** * @constructor clay.light.Sphere @@ -34275,7 +34642,7 @@ function copyIfNecessary(arr, shallow) { /** * @name clay.version */ -var version = '1.0.0-rc.1'; +var version = '1.0.0'; var outputEssl$1 = "@export clay.vr.disorter.output.vertex\nattribute vec2 texcoord: TEXCOORD_0;\nattribute vec3 position: POSITION;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n v_Texcoord = texcoord;\n gl_Position = vec4(position.xy, 0.5, 1.0);\n}\n@end\n@export clay.vr.disorter.output.fragment\nuniform sampler2D texture;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n gl_FragColor = texture2D(texture, v_Texcoord);\n}\n@end"; @@ -34649,6 +35016,7 @@ var geometry = { Cone : Cone$1, Cube : Cube$1, Cylinder : Cylinder$1, + ParametricSurface : ParametricSurface$1, Plane : Plane$3, Sphere : Sphere$1 }; @@ -34733,4 +35101,3 @@ var vr = { }; export { animation, application, async, Camera, camera, canvas, compositor, core, deferred, dep, FrameBuffer, Geometry, geometry, gpu, Joint, Light, light, loader, Material, math, Mesh, Node, particle, picking, plugin, prePass, Renderable, Renderer, Scene, Shader, shader, Skeleton, StandardMaterial, StaticGeometry, Texture, Texture2D, TextureCube, util, version, vr }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"claygl.es.js","sources":["../src/animation/easing.js","../src/animation/Clip.js","../src/animation/Animator.js","../src/animation/Blend1DClip.js","../src/util/delaunay.js","../src/dep/glmatrix.js","../src/math/Vector2.js","../src/animation/Blend2DClip.js","../src/animation/TransformTrack.js","../src/animation/SamplerTrack.js","../src/core/mixin/extend.js","../src/core/mixin/notifier.js","../src/core/util.js","../src/core/Base.js","../src/animation/Timeline.js","../src/animation/TrackClip.js","../src/core/GLInfo.js","../src/core/glenum.js","../src/core/vendor.js","../src/math/Vector3.js","../src/math/BoundingBox.js","../src/math/Matrix4.js","../src/core/Cache.js","../src/Texture.js","../src/core/LinkedList.js","../src/core/LRU.js","../src/core/color.js","../src/Material.js","../src/gpu/GLProgram.js","../src/gpu/ProgramManager.js","../src/Shader.js","../src/shader/source/header/calcAmbientSHLight.glsl.js","../src/shader/source/header/light.js","../src/shader/source/prez.glsl.js","../src/Renderer.js","../src/math/Quaternion.js","../src/Node.js","../src/Light.js","../src/math/Plane.js","../src/math/Frustum.js","../src/math/Ray.js","../src/Camera.js","../src/Scene.js","../src/Geometry.js","../src/geometry/Plane.js","../src/geometry/Cube.js","../src/geometry/Sphere.js","../src/math/util.js","../src/Texture2D.js","../src/shader/library.js","../src/Renderable.js","../src/Mesh.js","../src/camera/Perspective.js","../src/camera/Orthographic.js","../src/core/request.js","../src/shader/source/standard.glsl.js","../src/StandardMaterial.js","../src/Joint.js","../src/Skeleton.js","../src/shader/source/util.glsl.js","../src/shader/source/basic.glsl.js","../src/shader/source/lambert.glsl.js","../src/shader/source/wireframe.glsl.js","../src/shader/source/skybox.glsl.js","../src/shader/source/compositor/coloradjust.glsl.js","../src/shader/source/compositor/blur.glsl.js","../src/shader/source/compositor/lum.glsl.js","../src/shader/source/compositor/lut.glsl.js","../src/shader/source/compositor/vignette.glsl.js","../src/shader/source/compositor/output.glsl.js","../src/shader/source/compositor/bright.glsl.js","../src/shader/source/compositor/downsample.glsl.js","../src/shader/source/compositor/upsample.glsl.js","../src/shader/source/compositor/hdr.glsl.js","../src/shader/source/compositor/dof.glsl.js","../src/shader/source/compositor/lensflare.glsl.js","../src/shader/source/compositor/blend.glsl.js","../src/shader/source/compositor/fxaa.glsl.js","../src/shader/source/compositor/fxaa3.glsl.js","../src/shader/builtin.js","../src/loader/GLTF.js","../src/light/Directional.js","../src/light/Point.js","../src/light/Spot.js","../src/light/Ambient.js","../src/TextureCube.js","../src/FrameBuffer.js","../src/shader/source/compositor/vertex.glsl.js","../src/compositor/Pass.js","../src/plugin/Skybox.js","../src/prePass/EnvironmentMap.js","../src/plugin/Skydome.js","../src/util/dds.js","../src/util/hdr.js","../src/util/texture.js","../src/util/shader/integrateBRDF.glsl.js","../src/util/shader/prefilter.glsl.js","../src/util/cubemap.js","../src/light/AmbientCubemap.js","../src/light/AmbientSH.js","../src/compositor/TexturePool.js","../src/shader/source/shadowmap.glsl.js","../src/prePass/ShadowMap.js","../src/picking/RayPicking.js","../src/util/sh.js","../src/application.js","../src/async/Task.js","../src/async/TaskGroup.js","../src/canvas/Material.js","../src/canvas/Renderer.js","../src/compositor/Node.js","../src/compositor/Graph.js","../src/compositor/Compositor.js","../src/compositor/SceneNode.js","../src/compositor/TextureNode.js","../src/compositor/FilterNode.js","../src/compositor/createCompositor.js","../src/shader/source/deferred/gbuffer.glsl.js","../src/shader/source/deferred/chunk.glsl.js","../src/deferred/GBuffer.js","../src/geometry/Cone.js","../src/geometry/Cylinder.js","../src/shader/source/deferred/lightvolume.glsl.js","../src/shader/source/deferred/spot.glsl.js","../src/shader/source/deferred/directional.glsl.js","../src/shader/source/deferred/ambient.glsl.js","../src/shader/source/deferred/ambientsh.glsl.js","../src/shader/source/deferred/ambientcubemap.glsl.js","../src/shader/source/deferred/point.glsl.js","../src/shader/source/deferred/sphere.glsl.js","../src/shader/source/deferred/tube.glsl.js","../src/deferred/Renderer.js","../src/light/Sphere.js","../src/light/Tube.js","../src/loader/FX.js","../src/math/Matrix2.js","../src/math/Matrix2d.js","../src/math/Matrix3.js","../src/math/Value.js","../src/math/Vector4.js","../src/particle/Particle.js","../src/particle/Emitter.js","../src/particle/Field.js","../src/particle/ForceField.js","../src/particle/particle.glsl.js","../src/particle/ParticleRenderable.js","../src/picking/color.glsl.js","../src/picking/PixelPicking.js","../src/plugin/FreeControl.js","../src/plugin/GestureMgr.js","../src/plugin/InfinitePlane.js","../src/plugin/OrbitControl.js","../src/StaticGeometry.js","../src/util/mesh.js","../src/util/transferable.js","../src/version.js","../src/vr/output.glsl.js","../src/vr/CardboardDistorter.js","../src/vr/StereoCamera.js","../src/claygl.js"],"sourcesContent":["// 缓动函数来自 https://github.com/sole/tween.js/blob/master/src/Tween.js\n\n/**\n * @namespace clay.animation.easing\n */\nvar easing = {\n    /**\n     * @alias clay.animation.easing.linear\n     * @param {number} k\n     * @return {number}\n     */\n    linear: function(k) {\n        return k;\n    },\n    /**\n     * @alias clay.animation.easing.quadraticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticIn: function(k) {\n        return k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quadraticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticOut: function(k) {\n        return k * (2 - k);\n    },\n    /**\n     * @alias clay.animation.easing.quadraticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k;\n        }\n        return - 0.5 * (--k * (k - 2) - 1);\n    },\n    /**\n     * @alias clay.animation.easing.cubicIn\n     * @param {number} k\n     * @return {number}\n     */\n    cubicIn: function(k) {\n        return k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.cubicOut\n     * @param {number} k\n     * @return {number}\n     */\n    cubicOut: function(k) {\n        return --k * k * k + 1;\n    },\n    /**\n     * @alias clay.animation.easing.cubicInOut\n     * @param {number} k\n     * @return {number}\n     */\n    cubicInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k;\n        }\n        return 0.5 * ((k -= 2) * k * k + 2);\n    },\n    /**\n     * @alias clay.animation.easing.quarticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quarticIn: function(k) {\n        return k * k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quarticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quarticOut: function(k) {\n        return 1 - (--k * k * k * k);\n    },\n    /**\n     * @alias clay.animation.easing.quarticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quarticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k * k;\n        }\n        return - 0.5 * ((k -= 2) * k * k * k - 2);\n    },\n    /**\n     * @alias clay.animation.easing.quinticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quinticIn: function(k) {\n        return k * k * k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quinticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quinticOut: function(k) {\n        return --k * k * k * k * k + 1;\n    },\n    /**\n     * @alias clay.animation.easing.quinticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quinticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k * k * k;\n        }\n        return 0.5 * ((k -= 2) * k * k * k * k + 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalIn\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalIn: function(k) {\n        return 1 - Math.cos(k * Math.PI / 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalOut\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalOut: function(k) {\n        return Math.sin(k * Math.PI / 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalInOut\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalInOut: function(k) {\n        return 0.5 * (1 - Math.cos(Math.PI * k));\n    },\n    /**\n     * @alias clay.animation.easing.exponentialIn\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialIn: function(k) {\n        return k === 0 ? 0 : Math.pow(1024, k - 1);\n    },\n    /**\n     * @alias clay.animation.easing.exponentialOut\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialOut: function(k) {\n        return k === 1 ? 1 : 1 - Math.pow(2, - 10 * k);\n    },\n    /**\n     * @alias clay.animation.easing.exponentialInOut\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialInOut: function(k) {\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if ((k *= 2) < 1) {\n            return 0.5 * Math.pow(1024, k - 1);\n        }\n        return 0.5 * (- Math.pow(2, - 10 * (k - 1)) + 2);\n    },\n    /**\n     * @alias clay.animation.easing.circularIn\n     * @param {number} k\n     * @return {number}\n     */\n    circularIn: function(k) {\n        return 1 - Math.sqrt(1 - k * k);\n    },\n    /**\n     * @alias clay.animation.easing.circularOut\n     * @param {number} k\n     * @return {number}\n     */\n    circularOut: function(k) {\n        return Math.sqrt(1 - (--k * k));\n    },\n    /**\n     * @alias clay.animation.easing.circularInOut\n     * @param {number} k\n     * @return {number}\n     */\n    circularInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return - 0.5 * (Math.sqrt(1 - k * k) - 1);\n        }\n        return 0.5 * (Math.sqrt(1 - (k -= 2) * k) + 1);\n    },\n    /**\n     * @alias clay.animation.easing.elasticIn\n     * @param {number} k\n     * @return {number}\n     */\n    elasticIn: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        return - (a * Math.pow(2, 10 * (k -= 1)) *\n                    Math.sin((k - s) * (2 * Math.PI) / p));\n    },\n    /**\n     * @alias clay.animation.easing.elasticOut\n     * @param {number} k\n     * @return {number}\n     */\n    elasticOut: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }\n        else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        return (a * Math.pow(2, - 10 * k) *\n                Math.sin((k - s) * (2 * Math.PI) / p) + 1);\n    },\n    /**\n     * @alias clay.animation.easing.elasticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    elasticInOut: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }\n        else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        if ((k *= 2) < 1) {\n            return - 0.5 * (a * Math.pow(2, 10 * (k -= 1))\n                * Math.sin((k - s) * (2 * Math.PI) / p));\n        }\n        return a * Math.pow(2, -10 * (k -= 1))\n                * Math.sin((k - s) * (2 * Math.PI) / p) * 0.5 + 1;\n\n    },\n    /**\n     * @alias clay.animation.easing.backIn\n     * @param {number} k\n     * @return {number}\n     */\n    backIn: function(k) {\n        var s = 1.70158;\n        return k * k * ((s + 1) * k - s);\n    },\n    /**\n     * @alias clay.animation.easing.backOut\n     * @param {number} k\n     * @return {number}\n     */\n    backOut: function(k) {\n        var s = 1.70158;\n        return --k * k * ((s + 1) * k + s) + 1;\n    },\n    /**\n     * @alias clay.animation.easing.backInOut\n     * @param {number} k\n     * @return {number}\n     */\n    backInOut: function(k) {\n        var s = 1.70158 * 1.525;\n        if ((k *= 2) < 1) {\n            return 0.5 * (k * k * ((s + 1) * k - s));\n        }\n        return 0.5 * ((k -= 2) * k * ((s + 1) * k + s) + 2);\n    },\n    /**\n     * @alias clay.animation.easing.bounceIn\n     * @param {number} k\n     * @return {number}\n     */\n    bounceIn: function(k) {\n        return 1 - easing.bounceOut(1 - k);\n    },\n    /**\n     * @alias clay.animation.easing.bounceOut\n     * @param {number} k\n     * @return {number}\n     */\n    bounceOut: function(k) {\n        if (k < (1 / 2.75)) {\n            return 7.5625 * k * k;\n        }\n        else if (k < (2 / 2.75)) {\n            return 7.5625 * (k -= (1.5 / 2.75)) * k + 0.75;\n        } else if (k < (2.5 / 2.75)) {\n            return 7.5625 * (k -= (2.25 / 2.75)) * k + 0.9375;\n        } else {\n            return 7.5625 * (k -= (2.625 / 2.75)) * k + 0.984375;\n        }\n    },\n    /**\n     * @alias clay.animation.easing.bounceInOut\n     * @param {number} k\n     * @return {number}\n     */\n    bounceInOut: function(k) {\n        if (k < 0.5) {\n            return easing.bounceIn(k * 2) * 0.5;\n        }\n        return easing.bounceOut(k * 2 - 1) * 0.5 + 0.5;\n    }\n};\n\nexport default easing;\n","import Easing from './easing';\n\nfunction noop () {}\n/**\n * @constructor\n * @alias clay.animation.Clip\n * @param {Object} [opts]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRate]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n */\nvar Clip = function (opts) {\n\n    opts = opts || {};\n\n    /**\n     * @type {string}\n     */\n    this.name = opts.name || '';\n\n    /**\n     * @type {Object}\n     */\n    this.target = opts.target;\n\n    /**\n     * @type {number}\n     */\n    this.life = opts.life || 1000;\n\n    /**\n     * @type {number}\n     */\n    this.delay = opts.delay || 0;\n\n    /**\n     * @type {number}\n     */\n    this.gap = opts.gap || 0;\n\n    /**\n     * @type {number}\n     */\n    this.playbackRate = opts.playbackRate || 1;\n\n\n    this._initialized = false;\n\n    this._elapsedTime = 0;\n\n    this._loop = opts.loop == null ? false : opts.loop;\n    this.setLoop(this._loop);\n\n    if (opts.easing != null) {\n        this.setEasing(opts.easing);\n    }\n\n    /**\n     * @type {Function}\n     */\n    this.onframe = opts.onframe || noop;\n\n    /**\n     * @type {Function}\n     */\n    this.onfinish = opts.onfinish || noop;\n\n    /**\n     * @type {Function}\n     */\n    this.onrestart = opts.onrestart || noop;\n\n    this._paused = false;\n};\n\nClip.prototype = {\n\n    gap: 0,\n\n    life: 0,\n\n    delay: 0,\n\n    /**\n     * @param {number|boolean} loop\n     */\n    setLoop: function (loop) {\n        this._loop = loop;\n        if (loop) {\n            if (typeof(loop) == 'number') {\n                this._loopRemained = loop;\n            }\n            else {\n                this._loopRemained = 1e8;\n            }\n        }\n    },\n\n    /**\n     * @param {string|Function} easing\n     */\n    setEasing: function (easing) {\n        if (typeof(easing) === 'string') {\n            easing = Easing[easing];\n        }\n        this.easing = easing;\n    },\n\n    /**\n     * @param  {number} time\n     * @return {string}\n     */\n    step: function (time, deltaTime, silent) {\n        if (!this._initialized) {\n            this._startTime = time + this.delay;\n            this._initialized = true;\n        }\n        if (this._currentTime != null) {\n            deltaTime = time - this._currentTime;\n        }\n        this._currentTime = time;\n\n        if (this._paused) {\n            return 'paused';\n        }\n\n        if (time < this._startTime) {\n            return;\n        }\n\n        // PENDIGN Sync ?\n        this._elapse(time, deltaTime);\n\n        var percent = Math.min(this._elapsedTime / this.life, 1);\n\n        if (percent < 0) {\n            return;\n        }\n\n        var schedule;\n        if (this.easing) {\n            schedule = this.easing(percent);\n        }\n        else {\n            schedule = percent;\n        }\n\n        if (!silent) {\n            this.fire('frame', schedule);\n        }\n\n        if (percent === 1) {\n            if (this._loop && this._loopRemained > 0) {\n                this._restartInLoop(time);\n                this._loopRemained--;\n                return 'restart';\n            }\n            else {\n                // Mark this clip to be deleted\n                // In the animation.update\n                this._needsRemove = true;\n\n                return 'finish';\n            }\n        }\n        else {\n            return null;\n        }\n    },\n\n    /**\n     * @param  {number} time\n     * @return {string}\n     */\n    setTime: function (time) {\n        return this.step(time + this._startTime);\n    },\n\n    restart: function (time) {\n        // If user leave the page for a while, when he gets back\n        // All clips may be expired and all start from the beginning value(position)\n        // It is clearly wrong, so we use remainder to add a offset\n\n        var remainder = 0;\n        // Remainder ignored if restart is invoked manually\n        if (time) {\n            this._elapse(time);\n            remainder = this._elapsedTime % this.life;\n        }\n        time = time || Date.now();\n\n        this._startTime = time - remainder + this.delay;\n        this._elapsedTime = 0;\n\n        this._needsRemove = false;\n        this._paused = false;\n    },\n\n    getElapsedTime: function () {\n        return this._elapsedTime;\n    },\n\n    _restartInLoop: function (time) {\n        this._startTime = time + this.gap;\n        this._elapsedTime = 0;\n    },\n\n    _elapse: function (time, deltaTime) {\n        this._elapsedTime += deltaTime * this.playbackRate;\n    },\n\n    fire: function (eventType, arg) {\n        var eventName = 'on' + eventType;\n        if (this[eventName]) {\n            this[eventName](this.target, arg);\n        }\n    },\n\n    clone: function () {\n        var clip = new this.constructor();\n        clip.name = this.name;\n        clip._loop = this._loop;\n        clip._loopRemained = this._loopRemained;\n\n        clip.life = this.life;\n        clip.gap = this.gap;\n        clip.delay = this.delay;\n\n        return clip;\n    },\n    /**\n     * Pause the clip.\n     */\n    pause: function () {\n        this._paused = true;\n    },\n\n    /**\n     * Resume the clip.\n     */\n    resume: function () {\n        this._paused = false;\n    }\n};\nClip.prototype.constructor = Clip;\n\nexport default Clip;\n","/**\n * @module echarts/animation/Animator\n */\nimport Clip from './Clip';\n\nvar arraySlice = Array.prototype.slice;\n\nfunction defaultGetter(target, key) {\n    return target[key];\n}\nfunction defaultSetter(target, key, value) {\n    target[key] = value;\n}\n\nfunction interpolateNumber(p0, p1, percent) {\n    return (p1 - p0) * percent + p0;\n}\n\nfunction interpolateArray(p0, p1, percent, out, arrDim) {\n    var len = p0.length;\n    if (arrDim == 1) {\n        for (var i = 0; i < len; i++) {\n            out[i] = interpolateNumber(p0[i], p1[i], percent);\n        }\n    } else {\n        var len2 = p0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                out[i][j] = interpolateNumber(\n                    p0[i][j], p1[i][j], percent\n                );\n            }\n        }\n    }\n}\n\nfunction isArrayLike(data) {\n    if (typeof(data) == 'undefined') {\n        return false;\n    } else if (typeof(data) == 'string') {\n        return false;\n    } else {\n        return typeof(data.length) == 'number';\n    }\n}\n\nfunction cloneValue(value) {\n    if (isArrayLike(value)) {\n        var len = value.length;\n        if (isArrayLike(value[0])) {\n            var ret = [];\n            for (var i = 0; i < len; i++) {\n                ret.push(arraySlice.call(value[i]));\n            }\n            return ret;\n        } else {\n            return arraySlice.call(value);\n        }\n    } else {\n        return value;\n    }\n}\n\nfunction catmullRomInterpolateArray(\n    p0, p1, p2, p3, t, t2, t3, out, arrDim\n) {\n    var len = p0.length;\n    if (arrDim == 1) {\n        for (var i = 0; i < len; i++) {\n            out[i] = catmullRomInterpolate(\n                p0[i], p1[i], p2[i], p3[i], t, t2, t3\n            );\n        }\n    } else {\n        var len2 = p0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                out[i][j] = catmullRomInterpolate(\n                    p0[i][j], p1[i][j], p2[i][j], p3[i][j],\n                    t, t2, t3\n                );\n            }\n        }\n    }\n}\n\nfunction catmullRomInterpolate(p0, p1, p2, p3, t, t2, t3) {\n    var v0 = (p2 - p0) * 0.5;\n    var v1 = (p3 - p1) * 0.5;\n    return (2 * (p1 - p2) + v0 + v1) * t3\n            + (- 3 * (p1 - p2) - 2 * v0 - v1) * t2\n            + v0 * t + p1;\n}\n\n// arr0 is source array, arr1 is target array.\n// Do some preprocess to avoid error happened when interpolating from arr0 to arr1\nfunction fillArr(arr0, arr1, arrDim) {\n    var arr0Len = arr0.length;\n    var arr1Len = arr1.length;\n    if (arr0Len !== arr1Len) {\n        // FIXME Not work for TypedArray\n        var isPreviousLarger = arr0Len > arr1Len;\n        if (isPreviousLarger) {\n            // Cut the previous\n            arr0.length = arr1Len;\n        }\n        else {\n            // Fill the previous\n            for (var i = arr0Len; i < arr1Len; i++) {\n                arr0.push(\n                    arrDim === 1 ? arr1[i] : arraySlice.call(arr1[i])\n                );\n            }\n        }\n    }\n    // Handling NaN value\n    var len2 = arr0[0] && arr0[0].length;\n    for (var i = 0; i < arr0.length; i++) {\n        if (arrDim === 1) {\n            if (isNaN(arr0[i])) {\n                arr0[i] = arr1[i];\n            }\n        }\n        else {\n            for (var j = 0; j < len2; j++) {\n                if (isNaN(arr0[i][j])) {\n                    arr0[i][j] = arr1[i][j];\n                }\n            }\n        }\n    }\n}\n\nfunction isArraySame(arr0, arr1, arrDim) {\n    if (arr0 === arr1) {\n        return true;\n    }\n    var len = arr0.length;\n    if (len !== arr1.length) {\n        return false;\n    }\n    if (arrDim === 1) {\n        for (var i = 0; i < len; i++) {\n            if (arr0[i] !== arr1[i]) {\n                return false;\n            }\n        }\n    }\n    else {\n        var len2 = arr0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                if (arr0[i][j] !== arr1[i][j]) {\n                    return false;\n                }\n            }\n        }\n    }\n    return true;\n}\n\nfunction createTrackClip(animator, easing, oneTrackDone, keyframes, propName, interpolater) {\n    var getter = animator._getter;\n    var setter = animator._setter;\n    var useSpline = easing === 'spline';\n\n    var trackLen = keyframes.length;\n    if (!trackLen) {\n        return;\n    }\n    // Guess data type\n    var firstVal = keyframes[0].value;\n    var isValueArray = isArrayLike(firstVal);\n\n    // For vertices morphing\n    var arrDim = (\n            isValueArray\n            && isArrayLike(firstVal[0])\n        )\n        ? 2 : 1;\n    // Sort keyframe as ascending\n    keyframes.sort(function(a, b) {\n        return a.time - b.time;\n    });\n\n    var trackMaxTime = keyframes[trackLen - 1].time;\n    // Percents of each keyframe\n    var kfPercents = [];\n    // Value of each keyframe\n    var kfValues = [];\n\n    var prevValue = keyframes[0].value;\n    var isAllValueEqual = true;\n    for (var i = 0; i < trackLen; i++) {\n        kfPercents.push(keyframes[i].time / trackMaxTime);\n\n        // Assume value is a color when it is a string\n        var value = keyframes[i].value;\n\n        // Check if value is equal, deep check if value is array\n        if (!((isValueArray && isArraySame(value, prevValue, arrDim))\n            || (!isValueArray && value === prevValue))) {\n            isAllValueEqual = false;\n        }\n        prevValue = value;\n\n        kfValues.push(value);\n    }\n    if (isAllValueEqual) {\n        return;\n    }\n\n    var lastValue = kfValues[trackLen - 1];\n    // Polyfill array and NaN value\n    for (var i = 0; i < trackLen - 1; i++) {\n        if (isValueArray) {\n            fillArr(kfValues[i], lastValue, arrDim);\n        }\n        else {\n            if (isNaN(kfValues[i]) && !isNaN(lastValue)) {\n                kfValues[i] = lastValue;\n            }\n        }\n    }\n    isValueArray && fillArr(getter(animator._target, propName), lastValue, arrDim);\n\n    // Cache the key of last frame to speed up when\n    // animation playback is sequency\n    var cacheKey = 0;\n    var cachePercent = 0;\n    var start;\n    var i, w;\n    var p0, p1, p2, p3;\n\n    var onframe = function(target, percent) {\n        // Find the range keyframes\n        // kf1-----kf2---------current--------kf3\n        // find kf2(i) and kf3(i+1) and do interpolation\n        if (percent < cachePercent) {\n            // Start from next key\n            start = Math.min(cacheKey + 1, trackLen - 1);\n            for (i = start; i >= 0; i--) {\n                if (kfPercents[i] <= percent) {\n                    break;\n                }\n            }\n            i = Math.min(i, trackLen-2);\n        } else {\n            for (i = cacheKey; i < trackLen; i++) {\n                if (kfPercents[i] > percent) {\n                    break;\n                }\n            }\n            i = Math.min(i-1, trackLen-2);\n        }\n        cacheKey = i;\n        cachePercent = percent;\n\n        var range = (kfPercents[i+1] - kfPercents[i]);\n        if (range === 0) {\n            return;\n        } else {\n            w = (percent - kfPercents[i]) / range;\n        }\n        if (useSpline) {\n            p1 = kfValues[i];\n            p0 = kfValues[i === 0 ? i : i - 1];\n            p2 = kfValues[i > trackLen - 2 ? trackLen - 1 : i + 1];\n            p3 = kfValues[i > trackLen - 3 ? trackLen - 1 : i + 2];\n            if (interpolater) {\n                setter(\n                    target,\n                    propName,\n                    interpolater(\n                        getter(target, propName),\n                        p0, p1, p2, p3, w\n                    )\n                );\n            } else if (isValueArray) {\n                catmullRomInterpolateArray(\n                    p0, p1, p2, p3, w, w*w, w*w*w,\n                    getter(target, propName),\n                    arrDim\n                );\n            } else {\n                setter(\n                    target,\n                    propName,\n                    catmullRomInterpolate(p0, p1, p2, p3, w, w*w, w*w*w)\n                );\n            }\n        } else {\n            if (interpolater) {\n                setter(\n                    target,\n                    propName,\n                    interpolater(\n                        getter(target, propName),\n                        kfValues[i],\n                        kfValues[i + 1],\n                        w\n                    )\n                );\n            }\n            else if (isValueArray) {\n                interpolateArray(\n                    kfValues[i], kfValues[i+1], w,\n                    getter(target, propName),\n                    arrDim\n                );\n            } else {\n                setter(\n                    target,\n                    propName,\n                    interpolateNumber(kfValues[i], kfValues[i+1], w)\n                );\n            }\n        }\n    };\n\n    var clip = new Clip({\n        target: animator._target,\n        life: trackMaxTime,\n        loop: animator._loop,\n        delay: animator._delay,\n        onframe: onframe,\n        onfinish: oneTrackDone\n    });\n\n    if (easing && easing !== 'spline') {\n        clip.setEasing(easing);\n    }\n\n    return clip;\n}\n\n/**\n * @description Animator object can only be created by Animation.prototype.animate method.\n * After created, we can use {@link clay.animation.Animator#when} to add all keyframes and {@link clay.animation.Animator#start} it.\n * Clips will be automatically created and added to the animation instance which created this deferred object.\n *\n * @constructor clay.animation.Animator\n *\n * @param {Object} target\n * @param {boolean} loop\n * @param {Function} getter\n * @param {Function} setter\n * @param {Function} interpolater\n */\nfunction Animator(target, loop, getter, setter, interpolater) {\n    this._tracks = {};\n    this._target = target;\n\n    this._loop = loop || false;\n\n    this._getter = getter || defaultGetter;\n    this._setter = setter || defaultSetter;\n\n    this._interpolater = interpolater || null;\n\n    this._delay = 0;\n\n    this._doneList = [];\n\n    this._onframeList = [];\n\n    this._clipList = [];\n}\n\nAnimator.prototype = {\n\n    constructor: Animator,\n\n    /**\n     * @param  {number} time Keyframe time using millisecond\n     * @param  {Object} props A key-value object. Value can be number, 1d and 2d array\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    when: function (time, props) {\n        for (var propName in props) {\n            if (!this._tracks[propName]) {\n                this._tracks[propName] = [];\n                // If time is 0\n                //  Then props is given initialize value\n                // Else\n                //  Initialize value from current prop value\n                if (time !== 0) {\n                    this._tracks[propName].push({\n                        time: 0,\n                        value: cloneValue(\n                            this._getter(this._target, propName)\n                        )\n                    });\n                }\n            }\n            this._tracks[propName].push({\n                time: parseInt(time),\n                value: props[propName]\n            });\n        }\n        return this;\n    },\n    /**\n     * callback when running animation\n     * @param  {Function} callback callback have two args, animating target and current percent\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    during: function (callback) {\n        this._onframeList.push(callback);\n        return this;\n    },\n\n    _doneCallback: function () {\n        // Clear all tracks\n        this._tracks = {};\n        // Clear all clips\n        this._clipList.length = 0;\n\n        var doneList = this._doneList;\n        var len = doneList.length;\n        for (var i = 0; i < len; i++) {\n            doneList[i].call(this);\n        }\n    },\n    /**\n     * Start the animation\n     * @param  {string|Function} easing\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    start: function (easing) {\n\n        var self = this;\n        var clipCount = 0;\n\n        var oneTrackDone = function() {\n            clipCount--;\n            if (clipCount === 0) {\n                self._doneCallback();\n            }\n        };\n\n        var lastClip;\n        for (var propName in this._tracks) {\n            var clip = createTrackClip(\n                this, easing, oneTrackDone,\n                this._tracks[propName], propName, self._interpolater\n            );\n            if (clip) {\n                this._clipList.push(clip);\n                clipCount++;\n\n                // If start after added to animation\n                if (this.animation) {\n                    this.animation.addClip(clip);\n                }\n\n                lastClip = clip;\n            }\n        }\n\n        // Add during callback on the last clip\n        if (lastClip) {\n            var oldOnFrame = lastClip.onframe;\n            lastClip.onframe = function (target, percent) {\n                oldOnFrame(target, percent);\n\n                for (var i = 0; i < self._onframeList.length; i++) {\n                    self._onframeList[i](target, percent);\n                }\n            };\n        }\n\n        if (!clipCount) {\n            this._doneCallback();\n        }\n        return this;\n    },\n\n    /**\n     * Stop the animation\n     * @memberOf clay.animation.Animator.prototype\n     */\n    stop: function () {\n        for (var i = 0; i < this._clipList.length; i++) {\n            var clip = this._clipList[i];\n            this.animation.removeClip(clip);\n        }\n        this._clipList = [];\n    },\n    /**\n     * Delay given milliseconds\n     * @param  {number} time\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    delay: function (time){\n        this._delay = time;\n        return this;\n    },\n    /**\n     * Callback after animation finished\n     * @param {Function} func\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    done: function (func) {\n        if (func) {\n            this._doneList.push(func);\n        }\n        return this;\n    },\n    /**\n     * Get all clips created in start method.\n     * @return {clay.animation.Clip[]}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    getClips: function () {\n        return this._clipList;\n    }\n};\n\nexport default Animator;\n","// 1D Blend clip of blend tree\n// http://docs.unity3d.com/Documentation/Manual/1DBlending.html\n\nimport Clip from './Clip';\n\nvar clipSortFunc = function (a, b) {\n    return a.position < b.position;\n};\n\n/**\n * @typedef {Object} clay.animation.Blend1DClip.IClipInput\n * @property {number} position\n * @property {clay.animation.Clip} clip\n * @property {number} offset\n */\n\n/**\n * 1d blending node in animation blend tree.\n * output clip must have blend1D and copy method\n * @constructor\n * @alias clay.animation.Blend1DClip\n * @extends clay.animation.Clip\n *\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {object[]} [opts.inputs]\n * @param {number} [opts.position]\n * @param {clay.animation.Clip} [opts.output]\n */\nvar Blend1DClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n    /**\n     * Output clip must have blend1D and copy method\n     * @type {clay.animation.Clip}\n     */\n    this.output = opts.output || null;\n    /**\n     * @type {clay.animation.Blend1DClip.IClipInput[]}\n     */\n    this.inputs = opts.inputs || [];\n    /**\n     * @type {number}\n     */\n    this.position = 0;\n\n    this._cacheKey = 0;\n    this._cachePosition = -Infinity;\n\n    this.inputs.sort(clipSortFunc);\n};\n\nBlend1DClip.prototype = new Clip();\nBlend1DClip.prototype.constructor = Blend1DClip;\n\n/**\n * @param {number} position\n * @param {clay.animation.Clip} inputClip\n * @param {number} [offset]\n * @return {clay.animation.Blend1DClip.IClipInput}\n */\nBlend1DClip.prototype.addInput = function (position, inputClip, offset) {\n    var obj = {\n        position: position,\n        clip: inputClip,\n        offset: offset || 0\n    };\n    this.life = Math.max(inputClip.life, this.life);\n\n    if (!this.inputs.length) {\n        this.inputs.push(obj);\n        return obj;\n    }\n    var len = this.inputs.length;\n    if (this.inputs[0].position > position) {\n        this.inputs.unshift(obj);\n    } else if (this.inputs[len - 1].position <= position) {\n        this.inputs.push(obj);\n    } else {\n        var key = this._findKey(position);\n        this.inputs.splice(key, obj);\n    }\n\n    return obj;\n};\n\nBlend1DClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n    return ret;\n};\n\nBlend1DClip.prototype.setTime = function (time) {\n    var position = this.position;\n    var inputs = this.inputs;\n    var len = inputs.length;\n    var min = inputs[0].position;\n    var max = inputs[len-1].position;\n\n    if (position <= min || position >= max) {\n        var in0 = position <= min ? inputs[0] : inputs[len-1];\n        var clip = in0.clip;\n        var offset = in0.offset;\n        clip.setTime((time + offset) % clip.life);\n        // Input clip is a blend clip\n        // PENDING\n        if (clip.output instanceof Clip) {\n            this.output.copy(clip.output);\n        } else {\n            this.output.copy(clip);\n        }\n    } else {\n        var key = this._findKey(position);\n        var in1 = inputs[key];\n        var in2 = inputs[key + 1];\n        var clip1 = in1.clip;\n        var clip2 = in2.clip;\n        // Set time on input clips\n        clip1.setTime((time + in1.offset) % clip1.life);\n        clip2.setTime((time + in2.offset) % clip2.life);\n\n        var w = (this.position - in1.position) / (in2.position - in1.position);\n\n        var c1 = clip1.output instanceof Clip ? clip1.output : clip1;\n        var c2 = clip2.output instanceof Clip ? clip2.output : clip2;\n        this.output.blend1D(c1, c2, w);\n    }\n};\n\n/**\n * Clone a new Blend1D clip\n * @param {boolean} cloneInputs True if clone the input clips\n * @return {clay.animation.Blend1DClip}\n */\nBlend1DClip.prototype.clone = function (cloneInputs) {\n    var clip = Clip.prototype.clone.call(this);\n    clip.output = this.output.clone();\n    for (var i = 0; i < this.inputs.length; i++) {\n        var inputClip = cloneInputs ? this.inputs[i].clip.clone(true) : this.inputs[i].clip;\n        clip.addInput(this.inputs[i].position, inputClip, this.inputs[i].offset);\n    }\n    return clip;\n};\n\n// Find the key where position in range [inputs[key].position, inputs[key+1].position)\nBlend1DClip.prototype._findKey = function (position) {\n    var key = -1;\n    var inputs = this.inputs;\n    var len = inputs.length;\n    if (this._cachePosition < position) {\n        for (var i = this._cacheKey; i < len-1; i++) {\n            if (position >= inputs[i].position && position < inputs[i+1].position) {\n                key = i;\n            }\n        }\n    } else {\n        var s = Math.min(len-2, this._cacheKey);\n        for (var i = s; i >= 0; i--) {\n            if (position >= inputs[i].position && position < inputs[i+1].position) {\n                key = i;\n            }\n        }\n    }\n    if (key >= 0) {\n        this._cacheKey = key;\n        this._cachePosition = position;\n    }\n\n    return key;\n};\n\nexport default Blend1DClip;","// Delaunay Triangulation\n// Modified from https://github.com/ironwallaby/delaunay\nvar EPSILON = 1.0 / 1048576.0;\n\nfunction supertriangle(vertices) {\n    var xmin = Number.POSITIVE_INFINITY;\n    var ymin = Number.POSITIVE_INFINITY;\n    var xmax = Number.NEGATIVE_INFINITY;\n    var ymax = Number.NEGATIVE_INFINITY;\n    var i, dx, dy, dmax, xmid, ymid;\n\n    for (i = vertices.length; i--; ) {\n        if (vertices[i][0] < xmin) { xmin = vertices[i][0]; }\n        if (vertices[i][0] > xmax) { xmax = vertices[i][0]; }\n        if (vertices[i][1] < ymin) { ymin = vertices[i][1]; }\n        if (vertices[i][1] > ymax) { ymax = vertices[i][1]; }\n    }\n\n    dx = xmax - xmin;\n    dy = ymax - ymin;\n    dmax = Math.max(dx, dy);\n    xmid = xmin + dx * 0.5;\n    ymid = ymin + dy * 0.5;\n\n    return [\n        [xmid - 20 * dmax, ymid -      dmax],\n        [xmid            , ymid + 20 * dmax],\n        [xmid + 20 * dmax, ymid -      dmax]\n    ];\n}\n\nfunction circumcircle(vertices, i, j, k) {\n    var x1 = vertices[i][0],\n            y1 = vertices[i][1],\n            x2 = vertices[j][0],\n            y2 = vertices[j][1],\n            x3 = vertices[k][0],\n            y3 = vertices[k][1],\n            fabsy1y2 = Math.abs(y1 - y2),\n            fabsy2y3 = Math.abs(y2 - y3),\n            xc, yc, m1, m2, mx1, mx2, my1, my2, dx, dy;\n\n    /* Check for coincident points */\n    if (fabsy1y2 < EPSILON && fabsy2y3 < EPSILON) {\n        throw new Error('Eek! Coincident points!');\n    }\n\n    if (fabsy1y2 < EPSILON) {\n        m2  = -((x3 - x2) / (y3 - y2));\n        mx2 = (x2 + x3) / 2.0;\n        my2 = (y2 + y3) / 2.0;\n        xc  = (x2 + x1) / 2.0;\n        yc  = m2 * (xc - mx2) + my2;\n    }\n\n    else if (fabsy2y3 < EPSILON) {\n        m1  = -((x2 - x1) / (y2 - y1));\n        mx1 = (x1 + x2) / 2.0;\n        my1 = (y1 + y2) / 2.0;\n        xc  = (x3 + x2) / 2.0;\n        yc  = m1 * (xc - mx1) + my1;\n    }\n\n    else {\n        m1  = -((x2 - x1) / (y2 - y1));\n        m2  = -((x3 - x2) / (y3 - y2));\n        mx1 = (x1 + x2) / 2.0;\n        mx2 = (x2 + x3) / 2.0;\n        my1 = (y1 + y2) / 2.0;\n        my2 = (y2 + y3) / 2.0;\n        xc  = (m1 * mx1 - m2 * mx2 + my2 - my1) / (m1 - m2);\n        yc  = (fabsy1y2 > fabsy2y3) ?\n            m1 * (xc - mx1) + my1 :\n            m2 * (xc - mx2) + my2;\n    }\n\n    dx = x2 - xc;\n    dy = y2 - yc;\n    return {i: i, j: j, k: k, x: xc, y: yc, r: dx * dx + dy * dy};\n}\n\nfunction dedup(edges) {\n    var i, j, a, b, m, n;\n\n    for (j = edges.length; j; ) {\n        b = edges[--j];\n        a = edges[--j];\n\n        for (i = j; i; ) {\n            n = edges[--i];\n            m = edges[--i];\n\n            if ((a === m && b === n) || (a === n && b === m)) {\n                edges.splice(j, 2);\n                edges.splice(i, 2);\n                break;\n            }\n        }\n    }\n}\n\nvar delaunay = {\n    triangulate: function(vertices, key) {\n        var n = vertices.length;\n        var i, j, indices, st, open, closed, edges, dx, dy, a, b, c;\n\n        /* Bail if there aren't enough vertices to form any triangles. */\n        if (n < 3) {\n            return [];\n        }\n\n        /* Slice out the actual vertices from the passed objects. (Duplicate the\n            * array even if we don't, though, since we need to make a supertriangle\n            * later on!) */\n        vertices = vertices.slice(0);\n\n        if (key) {\n            for (i = n; i--; ) {\n                vertices[i] = vertices[i][key];\n            }\n        }\n\n        /* Make an array of indices into the vertex array, sorted by the\n            * vertices' x-position. Force stable sorting by comparing indices if\n            * the x-positions are equal. */\n        indices = new Array(n);\n\n        for (i = n; i--; ) {\n            indices[i] = i;\n        }\n\n        indices.sort(function(i, j) {\n            var diff = vertices[j][0] - vertices[i][0];\n            return diff !== 0 ? diff : i - j;\n        });\n\n        /* Next, find the vertices of the supertriangle (which contains all other\n            * triangles), and append them onto the end of a (copy of) the vertex\n            * array. */\n        st = supertriangle(vertices);\n        vertices.push(st[0], st[1], st[2]);\n\n        /* Initialize the open list (containing the supertriangle and nothing\n            * else) and the closed list (which is empty since we havn't processed\n            * any triangles yet). */\n        open   = [circumcircle(vertices, n + 0, n + 1, n + 2)];\n        closed = [];\n        edges  = [];\n\n        /* Incrementally add each vertex to the mesh. */\n        for (i = indices.length; i--; edges.length = 0) {\n            c = indices[i];\n\n            /* For each open triangle, check to see if the current point is\n                * inside it's circumcircle. If it is, remove the triangle and add\n                * it's edges to an edge list. */\n            for (j = open.length; j--; ) {\n                /* If this point is to the right of this triangle's circumcircle,\n                    * then this triangle should never get checked again. Remove it\n                    * from the open list, add it to the closed list, and skip. */\n                dx = vertices[c][0] - open[j].x;\n                if (dx > 0.0 && dx * dx > open[j].r) {\n                    closed.push(open[j]);\n                    open.splice(j, 1);\n                    continue;\n                }\n\n                /* If we're outside the circumcircle, skip this triangle. */\n                dy = vertices[c][1] - open[j].y;\n                if (dx * dx + dy * dy - open[j].r > EPSILON) {\n                    continue;\n                }\n\n                /* Remove the triangle and add it's edges to the edge list. */\n                edges.push(\n                    open[j].i, open[j].j,\n                    open[j].j, open[j].k,\n                    open[j].k, open[j].i\n                );\n                open.splice(j, 1);\n            }\n\n            /* Remove any doubled edges. */\n            dedup(edges);\n\n            /* Add a new triangle for each edge. */\n            for (j = edges.length; j; ) {\n                b = edges[--j];\n                a = edges[--j];\n                open.push(circumcircle(vertices, a, b, c));\n            }\n        }\n\n        /* Copy any remaining open triangles to the closed list, and then\n            * remove any triangles that share a vertex with the supertriangle,\n            * building a list of triplets that represent triangles. */\n        for (i = open.length; i--; ) {\n            closed.push(open[i]);\n        }\n        open.length = 0;\n\n        for (i = closed.length; i--; ) {\n            if (closed[i].i < n && closed[i].j < n && closed[i].k < n) {\n                open.push(closed[i].i, closed[i].j, closed[i].k);\n            }\n        }\n\n        /* Yay, we're done! */\n        return open;\n    },\n    contains: function(tri, p) {\n        /* Bounding box test first, for quick rejections. */\n        if ((p[0] < tri[0][0] && p[0] < tri[1][0] && p[0] < tri[2][0]) ||\n                (p[0] > tri[0][0] && p[0] > tri[1][0] && p[0] > tri[2][0]) ||\n                (p[1] < tri[0][1] && p[1] < tri[1][1] && p[1] < tri[2][1]) ||\n                (p[1] > tri[0][1] && p[1] > tri[1][1] && p[1] > tri[2][1])) {\n            return null;\n        }\n\n        var a = tri[1][0] - tri[0][0];\n        var b = tri[2][0] - tri[0][0];\n        var c = tri[1][1] - tri[0][1];\n        var d = tri[2][1] - tri[0][1];\n        var i = a * d - b * c;\n\n        /* Degenerate tri. */\n        if (i === 0.0) {\n            return null;\n        }\n\n        var u = (d * (p[0] - tri[0][0]) - b * (p[1] - tri[0][1])) / i,\n                v = (a * (p[1] - tri[0][1]) - c * (p[0] - tri[0][0])) / i;\n\n        /* If we're outside the tri, fail. */\n        if (u < 0.0 || v < 0.0 || (u + v) > 1.0) {\n            return null;\n        }\n\n        return [u, v];\n    }\n};\n\nexport default delaunay;\n","/**\n * @fileoverview gl-matrix - High performance matrix and vector operations\n * @author Brandon Jones\n * @author Colin MacKenzie IV\n * @version 2.2.2\n */\n\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\n(function(_global) {\n  \"use strict\";\n\n  var shim = {};\n  if (typeof(exports) === 'undefined') {\n    if(typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n      shim.exports = {};\n      define(function() {\n        return shim.exports;\n      });\n    } else {\n      // gl-matrix lives in a browser, define its namespaces in global\n      shim.exports = typeof(window) !== 'undefined' ? window : _global;\n    }\n  }\n  else {\n    // gl-matrix lives in commonjs, define its namespaces in exports\n    shim.exports = exports;\n  }\n\n  (function(exports) {\n    /* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\nif(!GLMAT_EPSILON) {\n    var GLMAT_EPSILON = 0.000001;\n}\n\nif(!GLMAT_ARRAY_TYPE) {\n    var GLMAT_ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;\n}\n\nif(!GLMAT_RANDOM) {\n    var GLMAT_RANDOM = Math.random;\n}\n\n/**\n * @class Common utilities\n * @name glMatrix\n */\nvar glMatrix = {};\n\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Type} type Array type, such as Float32Array or Array\n */\nglMatrix.setMatrixArrayType = function(type) {\n    GLMAT_ARRAY_TYPE = type;\n}\n\nif(typeof(exports) !== 'undefined') {\n    exports.glMatrix = glMatrix;\n}\n\nvar degree = Math.PI / 180;\n\n/**\n* Convert Degree To Radian\n*\n* @param {Number} Angle in Degrees\n*/\nglMatrix.toRadian = function(a){\n     return a * degree;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2 Dimensional Vector\n * @name vec2\n */\n\nvar vec2 = {};\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nvec2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = 0;\n    out[1] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nvec2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nvec2.fromValues = function(x, y) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nvec2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nvec2.set = function(out, x, y) {\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nvec2.sub = vec2.subtract;\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nvec2.mul = vec2.multiply;\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nvec2.div = vec2.divide;\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    return out;\n};\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nvec2.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    return out;\n};\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nvec2.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nvec2.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nvec2.dist = vec2.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec2.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nvec2.sqrDist = vec2.squaredDistance;\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec2.length = function (a) {\n    var x = a[0],\n        y = a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nvec2.len = vec2.length;\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec2.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nvec2.sqrLen = vec2.squaredLength;\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nvec2.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to invert\n * @returns {vec2} out\n */\nvec2.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  return out;\n};\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nvec2.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1];\n    var len = x*x + y*y;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec2.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1];\n};\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nvec2.cross = function(out, a, b) {\n    var z = a[0] * b[1] - a[1] * b[0];\n    out[0] = out[1] = 0;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nvec2.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nvec2.random = function (out, scale) {\n    scale = scale || 1.0;\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    out[0] = Math.cos(r) * scale;\n    out[1] = Math.sin(r) * scale;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y;\n    out[1] = m[1] * x + m[3] * y;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2d = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y + m[4];\n    out[1] = m[1] * x + m[3] * y + m[5];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat3 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[3] * y + m[6];\n    out[1] = m[1] * x + m[4] * y + m[7];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat4 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[4] * y + m[12];\n    out[1] = m[1] * x + m[5] * y + m[13];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec2.forEach = (function() {\n    var vec = vec2.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 2;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec2} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec2.str = function (a) {\n    return 'vec2(' + a[0] + ', ' + a[1] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec2 = vec2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3 Dimensional Vector\n * @name vec3\n */\n\nvar vec3 = {};\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nvec3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nvec3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nvec3.fromValues = function(x, y, z) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nvec3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nvec3.set = function(out, x, y, z) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nvec3.sub = vec3.subtract;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nvec3.mul = vec3.multiply;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nvec3.div = vec3.divide;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    return out;\n};\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nvec3.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    return out;\n};\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nvec3.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nvec3.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nvec3.dist = vec3.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec3.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nvec3.sqrDist = vec3.squaredDistance;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec3.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nvec3.len = vec3.length;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec3.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nvec3.sqrLen = vec3.squaredLength;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nvec3.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to invert\n * @returns {vec3} out\n */\nvec3.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  return out;\n};\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nvec3.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    var len = x*x + y*y + z*z;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec3.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n};\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.cross = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2],\n        bx = b[0], by = b[1], bz = b[2];\n\n    out[0] = ay * bz - az * by;\n    out[1] = az * bx - ax * bz;\n    out[2] = ax * by - ay * bx;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nvec3.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    var z = (GLMAT_RANDOM() * 2.0) - 1.0;\n    var zScale = Math.sqrt(1.0-z*z) * scale;\n\n    out[0] = Math.cos(r) * zScale;\n    out[1] = Math.sin(r) * zScale;\n    out[2] = z * scale;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2],\n        w = m[3] * x + m[7] * y + m[11] * z + m[15];\n    w = w || 1.0;\n    out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n    out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n    out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat3 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = x * m[0] + y * m[3] + z * m[6];\n    out[1] = x * m[1] + y * m[4] + z * m[7];\n    out[2] = x * m[2] + y * m[5] + z * m[8];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nvec3.transformQuat = function(out, a, q) {\n    // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateX = function(out, a, b, c){\n   var p = [], r=[];\n      //Translate point to the origin\n      p[0] = a[0] - b[0];\n      p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n      //perform rotation\n      r[0] = p[0];\n      r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c);\n      r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c);\n\n      //translate to correct position\n      out[0] = r[0] + b[0];\n      out[1] = r[1] + b[1];\n      out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateY = function(out, a, b, c){\n    var p = [], r=[];\n    //Translate point to the origin\n    p[0] = a[0] - b[0];\n    p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n    //perform rotation\n    r[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c);\n    r[1] = p[1];\n    r[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c);\n\n    //translate to correct position\n    out[0] = r[0] + b[0];\n    out[1] = r[1] + b[1];\n    out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateZ = function(out, a, b, c){\n    var p = [], r=[];\n    //Translate point to the origin\n    p[0] = a[0] - b[0];\n    p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n    //perform rotation\n    r[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c);\n    r[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c);\n    r[2] = p[2];\n\n    //translate to correct position\n    out[0] = r[0] + b[0];\n    out[1] = r[1] + b[1];\n    out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec3.forEach = (function() {\n    var vec = vec3.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 3;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Get the angle between two 3D vectors\n * @param {vec3} a The first operand\n * @param {vec3} b The second operand\n * @returns {Number} The angle in radians\n */\nvec3.angle = function(a, b) {\n\n    var tempA = vec3.fromValues(a[0], a[1], a[2]);\n    var tempB = vec3.fromValues(b[0], b[1], b[2]);\n\n    vec3.normalize(tempA, tempA);\n    vec3.normalize(tempB, tempB);\n\n    var cosine = vec3.dot(tempA, tempB);\n\n    if(cosine > 1.0){\n        return 0;\n    } else {\n        return Math.acos(cosine);\n    }\n};\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec3} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec3.str = function (a) {\n    return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec3 = vec3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4 Dimensional Vector\n * @name vec4\n */\n\nvar vec4 = {};\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nvec4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nvec4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nvec4.fromValues = function(x, y, z, w) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nvec4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nvec4.set = function(out, x, y, z, w) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    out[3] = a[3] + b[3];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    out[3] = a[3] - b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\nvec4.sub = vec4.subtract;\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    out[3] = a[3] * b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\nvec4.mul = vec4.multiply;\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    out[3] = a[3] / b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\nvec4.div = vec4.divide;\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    out[3] = Math.min(a[3], b[3]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    out[3] = Math.max(a[3], b[3]);\n    return out;\n};\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nvec4.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    out[3] = a[3] * b;\n    return out;\n};\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nvec4.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    out[3] = a[3] + (b[3] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nvec4.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\nvec4.dist = vec4.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec4.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\nvec4.sqrDist = vec4.squaredDistance;\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec4.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.length}\n * @function\n */\nvec4.len = vec4.length;\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec4.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\nvec4.sqrLen = vec4.squaredLength;\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nvec4.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = -a[3];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to invert\n * @returns {vec4} out\n */\nvec4.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  out[3] = 1.0 / a[3];\n  return out;\n};\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nvec4.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    var len = x*x + y*y + z*z + w*w;\n    if (len > 0) {\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n        out[3] = a[3] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec4.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n};\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nvec4.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2],\n        aw = a[3];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    out[3] = aw + t * (b[3] - aw);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nvec4.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    //TODO: This is a pretty awful way of doing this. Find something better.\n    out[0] = GLMAT_RANDOM();\n    out[1] = GLMAT_RANDOM();\n    out[2] = GLMAT_RANDOM();\n    out[3] = GLMAT_RANDOM();\n    vec4.normalize(out, out);\n    vec4.scale(out, out, scale);\n    return out;\n};\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nvec4.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2], w = a[3];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n    out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n    return out;\n};\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nvec4.transformQuat = function(out, a, q) {\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec4.forEach = (function() {\n    var vec = vec4.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 4;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec4} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec4.str = function (a) {\n    return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec4 = vec4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x2 Matrix\n * @name mat2\n */\n\nvar mat2 = {};\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {mat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nmat2.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a1 = a[1];\n        out[1] = a[2];\n        out[2] = a1;\n    } else {\n        out[0] = a[0];\n        out[1] = a[2];\n        out[2] = a[1];\n        out[3] = a[3];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n\n        // Calculate the determinant\n        det = a0 * a3 - a2 * a1;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] =  a3 * det;\n    out[1] = -a1 * det;\n    out[2] = -a2 * det;\n    out[3] =  a0 * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.adjoint = function(out, a) {\n    // Caching this value is nessecary if out == a\n    var a0 = a[0];\n    out[0] =  a[3];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] =  a0;\n\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {mat2} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2.determinant = function (a) {\n    return a[0] * a[3] - a[2] * a[1];\n};\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the first operand\n * @param {mat2} b the second operand\n * @returns {mat2} out\n */\nmat2.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n    var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    return out;\n};\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nmat2.mul = mat2.multiply;\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    return out;\n};\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nmat2.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {mat2} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2.str = function (a) {\n    return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {mat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2)))\n};\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {mat2} L the lower triangular matrix\n * @param {mat2} D the diagonal matrix\n * @param {mat2} U the upper triangular matrix\n * @param {mat2} a the input matrix to factorize\n */\n\nmat2.LDU = function (L, D, U, a) {\n    L[2] = a[2]/a[0];\n    U[0] = a[0];\n    U[1] = a[1];\n    U[3] = a[3] - L[2] * U[1];\n    return [L, D, U];\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2 = mat2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x3 Matrix\n * @name mat2d\n *\n * @description\n * A mat2d contains six elements defined as:\n * <pre>\n * [a, c, tx,\n *  b, d, ty]\n * </pre>\n * This is a short form for the 3x3 matrix:\n * <pre>\n * [a, c, tx,\n *  b, d, ty,\n *  0, 0, 1]\n * </pre>\n * The last row is ignored so the array is shorter and operations are faster.\n */\n\nvar mat2d = {};\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {mat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\nmat2d.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.invert = function(out, a) {\n    var aa = a[0], ab = a[1], ac = a[2], ad = a[3],\n        atx = a[4], aty = a[5];\n\n    var det = aa * ad - ab * ac;\n    if(!det){\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = ad * det;\n    out[1] = -ab * det;\n    out[2] = -ac * det;\n    out[3] = aa * det;\n    out[4] = (ac * aty - ad * atx) * det;\n    out[5] = (ab * atx - aa * aty) * det;\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {mat2d} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2d.determinant = function (a) {\n    return a[0] * a[3] - a[1] * a[2];\n};\n\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the first operand\n * @param {mat2d} b the second operand\n * @returns {mat2d} out\n */\nmat2d.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    out[4] = a0 * b4 + a2 * b5 + a4;\n    out[5] = a1 * b4 + a3 * b5 + a5;\n    return out;\n};\n\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\nmat2d.mul = mat2d.multiply;\n\n\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\nmat2d.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\nmat2d.translate = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0;\n    out[1] = a1;\n    out[2] = a2;\n    out[3] = a3;\n    out[4] = a0 * v0 + a2 * v1 + a4;\n    out[5] = a1 * v0 + a3 * v1 + a5;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2d\n *\n * @param {mat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2d.str = function (a) {\n    return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' +\n                    a[3] + ', ' + a[4] + ', ' + a[5] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {mat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2d.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1))\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2d = mat2d;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3x3 Matrix\n * @name mat3\n */\n\nvar mat3 = {};\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {mat4} a   the source 4x4 matrix\n * @returns {mat3} out\n */\nmat3.fromMat4 = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[4];\n    out[4] = a[5];\n    out[5] = a[6];\n    out[6] = a[8];\n    out[7] = a[9];\n    out[8] = a[10];\n    return out;\n};\n\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {mat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nmat3.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a12 = a[5];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a01;\n        out[5] = a[7];\n        out[6] = a02;\n        out[7] = a12;\n    } else {\n        out[0] = a[0];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a[1];\n        out[4] = a[4];\n        out[5] = a[7];\n        out[6] = a[2];\n        out[7] = a[5];\n        out[8] = a[8];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b01 = a22 * a11 - a12 * a21,\n        b11 = -a22 * a10 + a12 * a20,\n        b21 = a21 * a10 - a11 * a20,\n\n        // Calculate the determinant\n        det = a00 * b01 + a01 * b11 + a02 * b21;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = b01 * det;\n    out[1] = (-a22 * a01 + a02 * a21) * det;\n    out[2] = (a12 * a01 - a02 * a11) * det;\n    out[3] = b11 * det;\n    out[4] = (a22 * a00 - a02 * a20) * det;\n    out[5] = (-a12 * a00 + a02 * a10) * det;\n    out[6] = b21 * det;\n    out[7] = (-a21 * a00 + a01 * a20) * det;\n    out[8] = (a11 * a00 - a01 * a10) * det;\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    out[0] = (a11 * a22 - a12 * a21);\n    out[1] = (a02 * a21 - a01 * a22);\n    out[2] = (a01 * a12 - a02 * a11);\n    out[3] = (a12 * a20 - a10 * a22);\n    out[4] = (a00 * a22 - a02 * a20);\n    out[5] = (a02 * a10 - a00 * a12);\n    out[6] = (a10 * a21 - a11 * a20);\n    out[7] = (a01 * a20 - a00 * a21);\n    out[8] = (a00 * a11 - a01 * a10);\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat3\n *\n * @param {mat3} a the source matrix\n * @returns {Number} determinant of a\n */\nmat3.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n};\n\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the first operand\n * @param {mat3} b the second operand\n * @returns {mat3} out\n */\nmat3.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b00 = b[0], b01 = b[1], b02 = b[2],\n        b10 = b[3], b11 = b[4], b12 = b[5],\n        b20 = b[6], b21 = b[7], b22 = b[8];\n\n    out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n    out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n    out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n    out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n    out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n    out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n    out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n    out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n    out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n    return out;\n};\n\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nmat3.mul = mat3.multiply;\n\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to translate\n * @param {vec2} v vector to translate by\n * @returns {mat3} out\n */\nmat3.translate = function(out, a, v) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n        x = v[0], y = v[1];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n\n    out[3] = a10;\n    out[4] = a11;\n    out[5] = a12;\n\n    out[6] = x * a00 + y * a10 + a20;\n    out[7] = x * a01 + y * a11 + a21;\n    out[8] = x * a02 + y * a12 + a22;\n    return out;\n};\n\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.rotate = function (out, a, rad) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n\n    out[0] = c * a00 + s * a10;\n    out[1] = c * a01 + s * a11;\n    out[2] = c * a02 + s * a12;\n\n    out[3] = c * a10 - s * a00;\n    out[4] = c * a11 - s * a01;\n    out[5] = c * a12 - s * a02;\n\n    out[6] = a20;\n    out[7] = a21;\n    out[8] = a22;\n    return out;\n};\n\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nmat3.scale = function(out, a, v) {\n    var x = v[0], y = v[1];\n\n    out[0] = x * a[0];\n    out[1] = x * a[1];\n    out[2] = x * a[2];\n\n    out[3] = y * a[3];\n    out[4] = y * a[4];\n    out[5] = y * a[5];\n\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nmat3.fromMat2d = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = 0;\n\n    out[3] = a[2];\n    out[4] = a[3];\n    out[5] = 0;\n\n    out[6] = a[4];\n    out[7] = a[5];\n    out[8] = 1;\n    return out;\n};\n\n/**\n* Calculates a 3x3 matrix from the given quaternion\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {quat} q Quaternion to create matrix from\n*\n* @returns {mat3} out\n*/\nmat3.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[3] = yx - wz;\n    out[6] = zx + wy;\n\n    out[1] = yx + wz;\n    out[4] = 1 - xx - zz;\n    out[7] = zy - wx;\n\n    out[2] = zx - wy;\n    out[5] = zy + wx;\n    out[8] = 1 - xx - yy;\n\n    return out;\n};\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {mat4} a Mat4 to derive the normal matrix from\n*\n* @returns {mat3} out\n*/\nmat3.normalFromMat4 = function (out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n\n    out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n\n    out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat3\n *\n * @param {mat3} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat3.str = function (a) {\n    return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' +\n                    a[3] + ', ' + a[4] + ', ' + a[5] + ', ' +\n                    a[6] + ', ' + a[7] + ', ' + a[8] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {mat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat3.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2)))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat3 = mat3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4x4 Matrix\n * @name mat4\n */\n\nvar mat4 = {};\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nmat4.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a03 = a[3],\n            a12 = a[6], a13 = a[7],\n            a23 = a[11];\n\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a01;\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a02;\n        out[9] = a12;\n        out[11] = a[14];\n        out[12] = a03;\n        out[13] = a13;\n        out[14] = a23;\n    } else {\n        out[0] = a[0];\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a[1];\n        out[5] = a[5];\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a[2];\n        out[9] = a[6];\n        out[10] = a[10];\n        out[11] = a[14];\n        out[12] = a[3];\n        out[13] = a[7];\n        out[14] = a[11];\n        out[15] = a[15];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n    out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n    out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n    out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n    out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n    out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n    out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n    out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n    out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n    out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    out[0]  =  (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n    out[1]  = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n    out[2]  =  (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n    out[3]  = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n    out[4]  = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n    out[5]  =  (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n    out[6]  = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n    out[7]  =  (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n    out[8]  =  (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n    out[9]  = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n    out[10] =  (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n    out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n    out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n    out[13] =  (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n    out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n    out[15] =  (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nmat4.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32;\n\n    // Calculate the determinant\n    return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n    out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n    out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n    return out;\n};\n\n/**\n * Multiplies two affine mat4's\n * Add by https://github.com/pissang\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiplyAffine = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[4], a11 = a[5], a12 = a[6],\n        a20 = a[8], a21 = a[9], a22 = a[10],\n        a30 = a[12], a31 = a[13], a32 = a[14];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2];\n    out[0] = b0*a00 + b1*a10 + b2*a20;\n    out[1] = b0*a01 + b1*a11 + b2*a21;\n    out[2] = b0*a02 + b1*a12 + b2*a22;\n    // out[3] = 0;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6];\n    out[4] = b0*a00 + b1*a10 + b2*a20;\n    out[5] = b0*a01 + b1*a11 + b2*a21;\n    out[6] = b0*a02 + b1*a12 + b2*a22;\n    // out[7] = 0;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10];\n    out[8] = b0*a00 + b1*a10 + b2*a20;\n    out[9] = b0*a01 + b1*a11 + b2*a21;\n    out[10] = b0*a02 + b1*a12 + b2*a22;\n    // out[11] = 0;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + a32;\n    // out[15] = 1;\n    return out;\n};\n\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\nmat4.mul = mat4.multiply;\n\n/**\n * Alias for {@link mat4.multiplyAffine}\n * @function\n */\nmat4.mulAffine = mat4.multiplyAffine;\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nmat4.translate = function (out, a, v) {\n    var x = v[0], y = v[1], z = v[2],\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23;\n\n    if (a === out) {\n        out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n        out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n        out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n        out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n    } else {\n        a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n        a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n        a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n        out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n        out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n        out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n        out[12] = a00 * x + a10 * y + a20 * z + a[12];\n        out[13] = a01 * x + a11 * y + a21 * z + a[13];\n        out[14] = a02 * x + a12 * y + a22 * z + a[14];\n        out[15] = a03 * x + a13 * y + a23 * z + a[15];\n    }\n\n    return out;\n};\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nmat4.scale = function(out, a, v) {\n    var x = v[0], y = v[1], z = v[2];\n\n    out[0] = a[0] * x;\n    out[1] = a[1] * x;\n    out[2] = a[2] * x;\n    out[3] = a[3] * x;\n    out[4] = a[4] * y;\n    out[5] = a[5] * y;\n    out[6] = a[6] * y;\n    out[7] = a[7] * y;\n    out[8] = a[8] * z;\n    out[9] = a[9] * z;\n    out[10] = a[10] * z;\n    out[11] = a[11] * z;\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.rotate = function (out, a, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t,\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23,\n        b00, b01, b02,\n        b10, b11, b12,\n        b20, b21, b22;\n\n    if (Math.abs(len) < GLMAT_EPSILON) { return null; }\n\n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n\n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n\n    a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n    a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n    a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n    // Construct the elements of the rotation matrix\n    b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n    b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n    b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n    // Perform rotation-specific matrix multiplication\n    out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n    out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n    out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n    out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n    out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n    out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n    out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n    out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n    out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n    out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n    out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n    out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateX = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[0]  = a[0];\n        out[1]  = a[1];\n        out[2]  = a[2];\n        out[3]  = a[3];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[4] = a10 * c + a20 * s;\n    out[5] = a11 * c + a21 * s;\n    out[6] = a12 * c + a22 * s;\n    out[7] = a13 * c + a23 * s;\n    out[8] = a20 * c - a10 * s;\n    out[9] = a21 * c - a11 * s;\n    out[10] = a22 * c - a12 * s;\n    out[11] = a23 * c - a13 * s;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateY = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[4]  = a[4];\n        out[5]  = a[5];\n        out[6]  = a[6];\n        out[7]  = a[7];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c - a20 * s;\n    out[1] = a01 * c - a21 * s;\n    out[2] = a02 * c - a22 * s;\n    out[3] = a03 * c - a23 * s;\n    out[8] = a00 * s + a20 * c;\n    out[9] = a01 * s + a21 * c;\n    out[10] = a02 * s + a22 * c;\n    out[11] = a03 * s + a23 * c;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateZ = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[8]  = a[8];\n        out[9]  = a[9];\n        out[10] = a[10];\n        out[11] = a[11];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c + a10 * s;\n    out[1] = a01 * c + a11 * s;\n    out[2] = a02 * c + a12 * s;\n    out[3] = a03 * c + a13 * s;\n    out[4] = a10 * c - a00 * s;\n    out[5] = a11 * c - a01 * s;\n    out[6] = a12 * c - a02 * s;\n    out[7] = a13 * c - a03 * s;\n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslation = function (out, q, v) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - (yy + zz);\n    out[1] = xy + wz;\n    out[2] = xz - wy;\n    out[3] = 0;\n    out[4] = xy - wz;\n    out[5] = 1 - (xx + zz);\n    out[6] = yz + wx;\n    out[7] = 0;\n    out[8] = xz + wy;\n    out[9] = yz - wx;\n    out[10] = 1 - (xx + yy);\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n\n    return out;\n};\n\nmat4.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[1] = yx + wz;\n    out[2] = zx - wy;\n    out[3] = 0;\n\n    out[4] = yx - wz;\n    out[5] = 1 - xx - zz;\n    out[6] = zy + wx;\n    out[7] = 0;\n\n    out[8] = zx + wy;\n    out[9] = zy - wx;\n    out[10] = 1 - xx - yy;\n    out[11] = 0;\n\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.frustum = function (out, left, right, bottom, top, near, far) {\n    var rl = 1 / (right - left),\n        tb = 1 / (top - bottom),\n        nf = 1 / (near - far);\n    out[0] = (near * 2) * rl;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = (near * 2) * tb;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = (right + left) * rl;\n    out[9] = (top + bottom) * tb;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (far * near * 2) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspective = function (out, fovy, aspect, near, far) {\n    var f = 1.0 / Math.tan(fovy / 2),\n        nf = 1 / (near - far);\n    out[0] = f / aspect;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = f;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (2 * far * near) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.ortho = function (out, left, right, bottom, top, near, far) {\n    var lr = 1 / (left - right),\n        bt = 1 / (bottom - top),\n        nf = 1 / (near - far);\n    out[0] = -2 * lr;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = -2 * bt;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 2 * nf;\n    out[11] = 0;\n    out[12] = (left + right) * lr;\n    out[13] = (top + bottom) * bt;\n    out[14] = (far + near) * nf;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nmat4.lookAt = function (out, eye, center, up) {\n    var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n        eyex = eye[0],\n        eyey = eye[1],\n        eyez = eye[2],\n        upx = up[0],\n        upy = up[1],\n        upz = up[2],\n        centerx = center[0],\n        centery = center[1],\n        centerz = center[2];\n\n    if (Math.abs(eyex - centerx) < GLMAT_EPSILON &&\n        Math.abs(eyey - centery) < GLMAT_EPSILON &&\n        Math.abs(eyez - centerz) < GLMAT_EPSILON) {\n        return mat4.identity(out);\n    }\n\n    z0 = eyex - centerx;\n    z1 = eyey - centery;\n    z2 = eyez - centerz;\n\n    len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n    z0 *= len;\n    z1 *= len;\n    z2 *= len;\n\n    x0 = upy * z2 - upz * z1;\n    x1 = upz * z0 - upx * z2;\n    x2 = upx * z1 - upy * z0;\n    len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n    if (!len) {\n        x0 = 0;\n        x1 = 0;\n        x2 = 0;\n    } else {\n        len = 1 / len;\n        x0 *= len;\n        x1 *= len;\n        x2 *= len;\n    }\n\n    y0 = z1 * x2 - z2 * x1;\n    y1 = z2 * x0 - z0 * x2;\n    y2 = z0 * x1 - z1 * x0;\n\n    len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n    if (!len) {\n        y0 = 0;\n        y1 = 0;\n        y2 = 0;\n    } else {\n        len = 1 / len;\n        y0 *= len;\n        y1 *= len;\n        y2 *= len;\n    }\n\n    out[0] = x0;\n    out[1] = y0;\n    out[2] = z0;\n    out[3] = 0;\n    out[4] = x1;\n    out[5] = y1;\n    out[6] = z1;\n    out[7] = 0;\n    out[8] = x2;\n    out[9] = y2;\n    out[10] = z2;\n    out[11] = 0;\n    out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n    out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n    out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat4.str = function (a) {\n    return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n                    a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n                    a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' +\n                    a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {mat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat4.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) ))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat4 = mat4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class Quaternion\n * @name quat\n */\n\nvar quat = {};\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nquat.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {vec3} a the initial vector\n * @param {vec3} b the destination vector\n * @returns {quat} out\n */\nquat.rotationTo = (function() {\n    var tmpvec3 = vec3.create();\n    var xUnitVec3 = vec3.fromValues(1,0,0);\n    var yUnitVec3 = vec3.fromValues(0,1,0);\n\n    return function(out, a, b) {\n        var dot = vec3.dot(a, b);\n        if (dot < -0.999999) {\n            vec3.cross(tmpvec3, xUnitVec3, a);\n            if (vec3.length(tmpvec3) < 0.000001)\n                vec3.cross(tmpvec3, yUnitVec3, a);\n            vec3.normalize(tmpvec3, tmpvec3);\n            quat.setAxisAngle(out, tmpvec3, Math.PI);\n            return out;\n        } else if (dot > 0.999999) {\n            out[0] = 0;\n            out[1] = 0;\n            out[2] = 0;\n            out[3] = 1;\n            return out;\n        } else {\n            vec3.cross(tmpvec3, a, b);\n            out[0] = tmpvec3[0];\n            out[1] = tmpvec3[1];\n            out[2] = tmpvec3[2];\n            out[3] = 1 + dot;\n            return quat.normalize(out, out);\n        }\n    };\n})();\n\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {vec3} view  the vector representing the viewing direction\n * @param {vec3} right the vector representing the local \"right\" direction\n * @param {vec3} up    the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nquat.setAxes = (function() {\n    var matr = mat3.create();\n\n    return function(out, view, right, up) {\n        matr[0] = right[0];\n        matr[3] = right[1];\n        matr[6] = right[2];\n\n        matr[1] = up[0];\n        matr[4] = up[1];\n        matr[7] = up[2];\n\n        matr[2] = -view[0];\n        matr[5] = -view[1];\n        matr[8] = -view[2];\n\n        return quat.normalize(out, quat.fromMat3(out, matr));\n    };\n})();\n\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {quat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nquat.clone = vec4.clone;\n\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nquat.fromValues = vec4.fromValues;\n\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nquat.copy = vec4.copy;\n\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nquat.set = vec4.set;\n\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nquat.identity = function(out) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {vec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nquat.setAxisAngle = function(out, axis, rad) {\n    rad = rad * 0.5;\n    var s = Math.sin(rad);\n    out[0] = s * axis[0];\n    out[1] = s * axis[1];\n    out[2] = s * axis[2];\n    out[3] = Math.cos(rad);\n    return out;\n};\n\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n * @function\n */\nquat.add = vec4.add;\n\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n */\nquat.multiply = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    out[0] = ax * bw + aw * bx + ay * bz - az * by;\n    out[1] = ay * bw + aw * by + az * bx - ax * bz;\n    out[2] = az * bw + aw * bz + ax * by - ay * bx;\n    out[3] = aw * bw - ax * bx - ay * by - az * bz;\n    return out;\n};\n\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nquat.mul = quat.multiply;\n\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {quat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nquat.scale = vec4.scale;\n\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateX = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + aw * bx;\n    out[1] = ay * bw + az * bx;\n    out[2] = az * bw - ay * bx;\n    out[3] = aw * bw - ax * bx;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateY = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        by = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw - az * by;\n    out[1] = ay * bw + aw * by;\n    out[2] = az * bw + ax * by;\n    out[3] = aw * bw - ay * by;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateZ = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bz = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + ay * bz;\n    out[1] = ay * bw - ax * bz;\n    out[2] = az * bw + aw * bz;\n    out[3] = aw * bw - az * bz;\n    return out;\n};\n\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate W component of\n * @returns {quat} out\n */\nquat.calculateW = function (out, a) {\n    var x = a[0], y = a[1], z = a[2];\n\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n    return out;\n};\n\n/**\n * Calculates the dot product of two quat's\n *\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nquat.dot = vec4.dot;\n\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n * @function\n */\nquat.lerp = vec4.lerp;\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nquat.slerp = function (out, a, b, t) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    var        omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if ( cosom < 0.0 ) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ( (1.0 - cosom) > 0.000001 ) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    } else {\n        // \"from\" and \"to\" quaternions are very close\n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n\n    return out;\n};\n\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate inverse of\n * @returns {quat} out\n */\nquat.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        dot = a0*a0 + a1*a1 + a2*a2 + a3*a3,\n        invDot = dot ? 1.0/dot : 0;\n\n    // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n    out[0] = -a0*invDot;\n    out[1] = -a1*invDot;\n    out[2] = -a2*invDot;\n    out[3] = a3*invDot;\n    return out;\n};\n\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nquat.conjugate = function (out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Calculates the length of a quat\n *\n * @param {quat} a vector to calculate length of\n * @returns {Number} length of a\n * @function\n */\nquat.length = vec4.length;\n\n/**\n * Alias for {@link quat.length}\n * @function\n */\nquat.len = quat.length;\n\n/**\n * Calculates the squared length of a quat\n *\n * @param {quat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nquat.squaredLength = vec4.squaredLength;\n\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nquat.sqrLen = quat.squaredLength;\n\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nquat.normalize = vec4.normalize;\n\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {mat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nquat.fromMat3 = function(out, m) {\n    // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n    // article \"Quaternion Calculus and Fast Animation\".\n    var fTrace = m[0] + m[4] + m[8];\n    var fRoot;\n\n    if ( fTrace > 0.0 ) {\n        // |w| > 1/2, may as well choose w > 1/2\n        fRoot = Math.sqrt(fTrace + 1.0);  // 2w\n        out[3] = 0.5 * fRoot;\n        fRoot = 0.5/fRoot;  // 1/(4w)\n        out[0] = (m[5]-m[7])*fRoot;\n        out[1] = (m[6]-m[2])*fRoot;\n        out[2] = (m[1]-m[3])*fRoot;\n    } else {\n        // |w| <= 1/2\n        var i = 0;\n        if ( m[4] > m[0] )\n          i = 1;\n        if ( m[8] > m[i*3+i] )\n          i = 2;\n        var j = (i+1)%3;\n        var k = (i+2)%3;\n\n        fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0);\n        out[i] = 0.5 * fRoot;\n        fRoot = 0.5 / fRoot;\n        out[3] = (m[j*3+k] - m[k*3+j]) * fRoot;\n        out[j] = (m[j*3+i] + m[i*3+j]) * fRoot;\n        out[k] = (m[k*3+i] + m[i*3+k]) * fRoot;\n    }\n\n    return out;\n};\n\n/**\n * Returns a string representation of a quatenion\n *\n * @param {quat} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nquat.str = function (a) {\n    return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.quat = quat;\n}\n;\n\n\n\n\n\n\n\n\n\n\n\n\n\n  })(shim.exports);\n})(this);","import glMatrix from '../dep/glmatrix';\nvar vec2 = glMatrix.vec2;\n\n/**\n * @constructor\n * @alias clay.math.Vector2\n * @param {number} x\n * @param {number} y\n */\nvar Vector2 = function(x, y) {\n\n    x = x || 0;\n    y = y || 0;\n\n    /**\n     * Storage of Vector2, read and write of x, y will change the values in array\n     * All methods also operate on the array instead of x, y components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector2#\n     */\n    this.array = vec2.fromValues(x, y);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector2#\n     */\n    this._dirty = true;\n};\n\nVector2.prototype = {\n\n    constructor: Vector2,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    add: function(b) {\n        vec2.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x and y components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @return {clay.math.Vector2}\n     */\n    set: function(x, y) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x and y components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector2}\n     */\n    setArray: function(arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector2\n     * @return {clay.math.Vector2}\n     */\n    clone: function() {\n        return new Vector2(this.x, this.y);\n    },\n\n    /**\n     * Copy x, y from b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    copy: function(b) {\n        vec2.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Cross product of self and b, written to a Vector3 out\n     * @param  {clay.math.Vector3} out\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    cross: function(out, b) {\n        vec2.cross(out.array, this.array, b.array);\n        out._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    dist: function(b) {\n        return vec2.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    distance: function(b) {\n        return vec2.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    div: function(b) {\n        vec2.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    divide: function(b) {\n        vec2.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    dot: function(b) {\n        return vec2.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function() {\n        return vec2.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function() {\n        return vec2.length(this.array);\n    },\n\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector2} a\n     * @param  {clay.math.Vector2} b\n     * @param  {number}  t\n     * @return {clay.math.Vector2}\n     */\n    lerp: function(a, b, t) {\n        vec2.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    min: function(b) {\n        vec2.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    max: function(b) {\n        vec2.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    mul: function(b) {\n        vec2.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    multiply: function(b) {\n        vec2.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector2}\n     */\n    negate: function() {\n        vec2.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector2}\n     */\n    normalize: function() {\n        vec2.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector2}\n     */\n    random: function(scale) {\n        vec2.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector2}\n     */\n    scale: function(s) {\n        vec2.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector2} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector2}\n     */\n    scaleAndAdd: function(b, s) {\n        vec2.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    sqrDist: function(b) {\n        return vec2.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    squaredDistance: function(b) {\n        return vec2.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function() {\n        return vec2.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function() {\n        return vec2.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    sub: function(b) {\n        vec2.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    subtract: function(b) {\n        vec2.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix2 m\n     * @param  {clay.math.Matrix2} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat2: function(m) {\n        vec2.transformMat2(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix2d m\n     * @param  {clay.math.Matrix2d} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat2d: function(m) {\n        vec2.transformMat2d(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix3 m\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat3: function(m) {\n        vec2.transformMat3(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat4: function(m) {\n        vec2.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n// Getter and Setter\nif (Object.defineProperty) {\n\n    var proto = Vector2.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector2\n     * @instance\n     */\n    Object.defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector2\n     * @instance\n     */\n    Object.defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.add = function(out, a, b) {\n    vec2.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {number}  x\n * @param  {number}  y\n * @return {clay.math.Vector2}\n */\nVector2.set = function(out, x, y) {\n    vec2.set(out.array, x, y);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.copy = function(out, b) {\n    vec2.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.cross = function(out, a, b) {\n    vec2.cross(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.dist = function(a, b) {\n    return vec2.distance(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.distance = Vector2.dist;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.div = function(out, a, b) {\n    vec2.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.divide = Vector2.div;\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.dot = function(a, b) {\n    return vec2.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.len = function(b) {\n    return vec2.length(b.array);\n};\n\n// Vector2.length = Vector2.len;\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @param  {number}  t\n * @return {clay.math.Vector2}\n */\nVector2.lerp = function(out, a, b, t) {\n    vec2.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.min = function(out, a, b) {\n    vec2.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.max = function(out, a, b) {\n    vec2.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.mul = function(out, a, b) {\n    vec2.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.multiply = Vector2.mul;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @return {clay.math.Vector2}\n */\nVector2.negate = function(out, a) {\n    vec2.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @return {clay.math.Vector2}\n */\nVector2.normalize = function(out, a) {\n    vec2.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.random = function(out, scale) {\n    vec2.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.scale = function(out, a, scale) {\n    vec2.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.scaleAndAdd = function(out, a, b, scale) {\n    vec2.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.sqrDist = function(a, b) {\n    return vec2.sqrDist(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.squaredDistance = Vector2.sqrDist;\n\n/**\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.sqrLen = function(a) {\n    return vec2.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.squaredLength = Vector2.sqrLen;\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.sub = function(out, a, b) {\n    vec2.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.subtract = Vector2.sub;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Matrix2} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat2 = function(out, a, m) {\n    vec2.transformMat2(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2}  out\n * @param  {clay.math.Vector2}  a\n * @param  {clay.math.Matrix2d} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat2d = function(out, a, m) {\n    vec2.transformMat2d(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {Matrix3} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat3 = function(out, a, m) {\n    vec2.transformMat3(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat4 = function(out, a, m) {\n    vec2.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Vector2;\n","// 2D Blend clip of blend tree\n// http://docs.unity3d.com/Documentation/Manual/2DBlending.html\nimport Clip from './Clip';\nimport delaunay from '../util/delaunay';\nimport Vector2 from '../math/Vector2';\n\n/**\n * @typedef {Object} clay.animation.Blend2DClip.IClipInput\n * @property {clay.math.Vector2} position\n * @property {clay.animation.Clip} clip\n * @property {number} offset\n */\n\n/**\n * 2d blending node in animation blend tree.\n * output clip must have blend2D method\n * @constructor\n * @alias clay.animation.Blend2DClip\n * @extends clay.animation.Clip\n *\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {object[]} [opts.inputs]\n * @param {clay.math.Vector2} [opts.position]\n * @param {clay.animation.Clip} [opts.output]\n */\nvar Blend2DClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n    /**\n     * Output clip must have blend2D method\n     * @type {clay.animation.Clip}\n     */\n    this.output = opts.output || null;\n    /**\n     * @type {clay.animation.Blend2DClip.IClipInput[]}\n     */\n    this.inputs = opts.inputs || [];\n    /**\n     * @type {clay.math.Vector2}\n     */\n    this.position = new Vector2();\n\n    this._cacheTriangle = null;\n\n    this._triangles = [];\n\n    this._updateTriangles();\n};\n\nBlend2DClip.prototype = new Clip();\nBlend2DClip.prototype.constructor = Blend2DClip;\n/**\n * @param {clay.math.Vector2} position\n * @param {clay.animation.Clip} inputClip\n * @param {number} [offset]\n * @return {clay.animation.Blend2DClip.IClipInput}\n */\nBlend2DClip.prototype.addInput = function (position, inputClip, offset) {\n    var obj = {\n        position : position,\n        clip : inputClip,\n        offset : offset || 0\n    };\n    this.inputs.push(obj);\n    this.life = Math.max(inputClip.life, this.life);\n    // TODO Change to incrementally adding\n    this._updateTriangles();\n\n    return obj;\n};\n\n// Delaunay triangulate\nBlend2DClip.prototype._updateTriangles = function () {\n    var inputs = this.inputs.map(function (a) {\n        return a.position;\n    });\n    this._triangles = delaunay.triangulate(inputs, 'array');\n};\n\nBlend2DClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n    return ret;\n};\n\nBlend2DClip.prototype.setTime = function (time) {\n    var res = this._findTriangle(this.position);\n    if (!res) {\n        return;\n    }\n    // In Barycentric\n    var a = res[1]; // Percent of clip2\n    var b = res[2]; // Percent of clip3\n\n    var tri = res[0];\n\n    var in1 = this.inputs[tri.indices[0]];\n    var in2 = this.inputs[tri.indices[1]];\n    var in3 = this.inputs[tri.indices[2]];\n    var clip1 = in1.clip;\n    var clip2 = in2.clip;\n    var clip3 = in3.clip;\n\n    clip1.setTime((time + in1.offset) % clip1.life);\n    clip2.setTime((time + in2.offset) % clip2.life);\n    clip3.setTime((time + in3.offset) % clip3.life);\n\n    var c1 = clip1.output instanceof Clip ? clip1.output : clip1;\n    var c2 = clip2.output instanceof Clip ? clip2.output : clip2;\n    var c3 = clip3.output instanceof Clip ? clip3.output : clip3;\n\n    this.output.blend2D(c1, c2, c3, a, b);\n};\n\n/**\n * Clone a new Blend2D clip\n * @param {boolean} cloneInputs True if clone the input clips\n * @return {clay.animation.Blend2DClip}\n */\nBlend2DClip.prototype.clone = function (cloneInputs) {\n    var clip = Clip.prototype.clone.call(this);\n    clip.output = this.output.clone();\n    for (var i = 0; i < this.inputs.length; i++) {\n        var inputClip = cloneInputs ? this.inputs[i].clip.clone(true) : this.inputs[i].clip;\n        clip.addInput(this.inputs[i].position, inputClip, this.inputs[i].offset);\n    }\n    return clip;\n};\n\nBlend2DClip.prototype._findTriangle = function (position) {\n    if (this._cacheTriangle) {\n        var res = delaunay.contains(this._cacheTriangle.vertices, position.array);\n        if (res) {\n            return [this._cacheTriangle, res[0], res[1]];\n        }\n    }\n    for (var i = 0; i < this._triangles.length; i++) {\n        var tri = this._triangles[i];\n        var res = delaunay.contains(tri.vertices, this.position.array);\n        if (res) {\n            this._cacheTriangle = tri;\n            return [tri, res[0], res[1]];\n        }\n    }\n};\n\nexport default Blend2DClip;","import Clip from './Clip';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\nfunction keyframeSort(a, b) {\n    return a.time - b.time;\n}\n\nvar TransformTrack = function (opts) {\n\n    this.name = opts.name || '';\n    //[{\n    //  time: //ms\n    //  position:  // optional\n    //  rotation:  // optional\n    //  scale:     // optional\n    //}]\n    this.keyFrames = [];\n    if (opts.keyFrames) {\n        this.addKeyFrames(opts.keyFrames);\n    }\n\n    this.position = vec3.create();\n\n    this.rotation = quat.create();\n\n    this.scale = vec3.fromValues(1, 1, 1);\n\n    this._cacheKey = 0;\n    this._cacheTime = 0;\n};\n\nTransformTrack.prototype = Object.create(Clip.prototype);\n\nTransformTrack.prototype.constructor = TransformTrack;\n\nTransformTrack.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time, dTime, true);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n\n    return ret;\n};\n\nTransformTrack.prototype.setTime = function (time) {\n    this._interpolateField(time, 'position');\n    this._interpolateField(time, 'rotation');\n    this._interpolateField(time, 'scale');\n};\n\nTransformTrack.prototype.getMaxTime = function () {\n    var kf = this.keyFrames[this.keyFrames.length - 1];\n    return kf ? kf.time : 0;\n};\n\nTransformTrack.prototype.addKeyFrame = function (kf) {\n    for (var i = 0; i < this.keyFrames.length - 1; i++) {\n        var prevFrame = this.keyFrames[i];\n        var nextFrame = this.keyFrames[i + 1];\n        if (prevFrame.time <= kf.time && nextFrame.time >= kf.time) {\n            this.keyFrames.splice(i, 0, kf);\n            return i;\n        }\n    }\n\n    this.life = kf.time;\n    this.keyFrames.push(kf);\n};\n\nTransformTrack.prototype.addKeyFrames = function (kfs) {\n    for (var i = 0; i < kfs.length; i++) {\n        this.keyFrames.push(kfs[i]);\n    }\n\n    this.keyFrames.sort(keyframeSort);\n\n    this.life = this.keyFrames[this.keyFrames.length - 1].time;\n};\n\nTransformTrack.prototype._interpolateField = function (time, fieldName) {\n    var kfs = this.keyFrames;\n    var len = kfs.length;\n    var start;\n    var end;\n\n    if (!kfs.length) {\n        return;\n    }\n    if (time < kfs[0].time || time > kfs[kfs.length-1].time) {\n        return;\n    }\n    if (time < this._cacheTime) {\n        var s = this._cacheKey >= len-1 ? len-1 : this._cacheKey+1;\n        for (var i = s; i >= 0; i--) {\n            if (kfs[i].time <= time && kfs[i][fieldName]) {\n                start = kfs[i];\n                this._cacheKey = i;\n                this._cacheTime = time;\n            } else if (kfs[i][fieldName]) {\n                end = kfs[i];\n                break;\n            }\n        }\n    } else {\n        for (var i = this._cacheKey; i < len; i++) {\n            if (kfs[i].time <= time && kfs[i][fieldName]) {\n                start = kfs[i];\n                this._cacheKey = i;\n                this._cacheTime = time;\n            } else if (kfs[i][fieldName]) {\n                end = kfs[i];\n                break;\n            }\n        }\n    }\n\n    if (start && end) {\n        var percent = (time - start.time) / (end.time - start.time);\n        percent = Math.max(Math.min(percent, 1), 0);\n        if (fieldName === 'rotation') {\n            quat.slerp(this[fieldName], start[fieldName], end[fieldName], percent);\n        } else {\n            vec3.lerp(this[fieldName], start[fieldName], end[fieldName], percent);\n        }\n    } else {\n        this._cacheKey = 0;\n        this._cacheTime = 0;\n    }\n};\n\nTransformTrack.prototype.blend1D = function (t1, t2, w) {\n    vec3.lerp(this.position, t1.position, t2.position, w);\n    vec3.lerp(this.scale, t1.scale, t2.scale, w);\n    quat.slerp(this.rotation, t1.rotation, t2.rotation, w);\n};\n\nTransformTrack.prototype.blend2D = (function () {\n    var q1 = quat.create();\n    var q2 = quat.create();\n    return function (t1, t2, t3, f, g) {\n        var a = 1 - f - g;\n\n        this.position[0] = t1.position[0] * a + t2.position[0] * f + t3.position[0] * g;\n        this.position[1] = t1.position[1] * a + t2.position[1] * f + t3.position[1] * g;\n        this.position[2] = t1.position[2] * a + t2.position[2] * f + t3.position[2] * g;\n\n        this.scale[0] = t1.scale[0] * a + t2.scale[0] * f + t3.scale[0] * g;\n        this.scale[1] = t1.scale[1] * a + t2.scale[1] * f + t3.scale[1] * g;\n        this.scale[2] = t1.scale[2] * a + t2.scale[2] * f + t3.scale[2] * g;\n\n        // http://msdn.microsoft.com/en-us/library/windows/desktop/bb205403(v=vs.85).aspx\n        // http://msdn.microsoft.com/en-us/library/windows/desktop/microsoft.directx_sdk.quaternion.xmquaternionbarycentric(v=vs.85).aspx\n        var s = f + g;\n        if (s === 0) {\n            quat.copy(this.rotation, t1.rotation);\n        } else {\n            quat.slerp(q1, t1.rotation, t2.rotation, s);\n            quat.slerp(q2, t1.rotation, c3.rotation, s);\n            quat.slerp(this.rotation, q1, q2, g / s);\n        }\n    };\n})();\n\nTransformTrack.prototype.additiveBlend = function (t1, t2) {\n    vec3.add(this.position, t1.position, t2.position);\n    vec3.add(this.scale, t1.scale, t2.scale);\n    quat.multiply(this.rotation, t2.rotation, t1.rotation);\n};\n\nTransformTrack.prototype.subtractiveBlend = function (t1, t2) {\n    vec3.sub(this.position, t1.position, t2.position);\n    vec3.sub(this.scale, t1.scale, t2.scale);\n    quat.invert(this.rotation, t2.rotation);\n    quat.multiply(this.rotation, this.rotation, t1.rotation);\n};\n\nTransformTrack.prototype.getSubClip = function (startTime, endTime) {\n    // TODO\n    console.warn('TODO');\n};\n\nTransformTrack.prototype.clone = function () {\n    var track = TransformTrack.prototype.clone.call(this);\n    track.keyFrames = this.keyFrames;\n\n    vec3.copy(track.position, this.position);\n    quat.copy(track.rotation, this.rotation);\n    vec3.copy(track.scale, this.scale);\n\n    return track;\n};\n\n\nexport default TransformTrack;\n","// Sampler clip is especially for the animation sampler in glTF\n// Use Typed Array can reduce a lot of heap memory\n//\n// TODO Sync target transform\n\nimport TransformTrack from './TransformTrack';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\n// lerp function with offset in large array\nfunction vec3lerp(out, a, b, t, oa, ob) {\n    var ax = a[oa];\n    var ay = a[oa + 1];\n    var az = a[oa + 2];\n    out[0] = ax + t * (b[ob] - ax);\n    out[1] = ay + t * (b[ob + 1] - ay);\n    out[2] = az + t * (b[ob + 2] - az);\n\n    return out;\n}\n\nfunction quatSlerp(out, a, b, t, oa, ob) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0 + oa], ay = a[1 + oa], az = a[2 + oa], aw = a[3 + oa],\n        bx = b[0 + ob], by = b[1 + ob], bz = b[2 + ob], bw = b[3 + ob];\n\n    var omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if (cosom < 0.0) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ((1.0 - cosom) > 0.000001) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    }\n    else {\n        // 'from' and 'to' quaternions are very close\n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n\n    return out;\n}\n\n/**\n * SamplerTrack manages `position`, `rotation`, `scale` tracks in animation of single scene node.\n * @constructor\n * @alias clay.animation.SamplerTrack\n * @param {Object} [opts]\n * @param {string} [opts.name] Track name\n * @param {clay.Node} [opts.target] Target node's transform will updated automatically\n */\nvar SamplerTrack = function (opts) {\n    opts = opts || {};\n\n    this.name = opts.name || '';\n    /**\n     * @param {clay.Node}\n     */\n    this.target = opts.target || null;\n    /**\n     * @type {Float32Array}\n     */\n    this.position = vec3.create();\n    /**\n     * Rotation is represented by a quaternion\n     * @type {Float32Array}\n     */\n    this.rotation = quat.create();\n    /**\n     * @type {Float32Array}\n     */\n    this.scale = vec3.fromValues(1, 1, 1);\n\n    this.channels = {\n        time: null,\n        position: null,\n        rotation: null,\n        scale: null\n    };\n\n    this._cacheKey = 0;\n    this._cacheTime = 0;\n};\n\nSamplerTrack.prototype.setTime = function (time) {\n    if (!this.channels.time) {\n        return;\n    }\n    var channels = this.channels;\n    var len = channels.time.length;\n    var key = -1;\n    // Only one frame\n    if (len === 1) {\n        if (channels.rotation) {\n            quat.copy(this.rotation, channels.rotation);\n        }\n        if (channels.position) {\n            vec3.copy(this.position, channels.position);\n        }\n        if (channels.scale) {\n            vec3.copy(this.scale, channels.scale);\n        }\n        return;\n    }\n    // Clamp\n    else if (time <= channels.time[0]) {\n        time = channels.time[0];\n        key = 0;\n    }\n    else if (time >= channels.time[len - 1]) {\n        time = channels.time[len - 1];\n        key = len - 2;\n    }\n    else {\n        if (time < this._cacheTime) {\n            var s = Math.min(len - 1, this._cacheKey + 1);\n            for (var i = s; i >= 0; i--) {\n                if (channels.time[i - 1] <= time && channels.time[i] > time) {\n                    key = i - 1;\n                    break;\n                }\n            }\n        }\n        else {\n            for (var i = this._cacheKey; i < len - 1; i++) {\n                if (channels.time[i] <= time && channels.time[i + 1] > time) {\n                    key = i;\n                    break;\n                }\n            }\n        }\n    }\n    if (key > -1) {\n        this._cacheKey = key;\n        this._cacheTime = time;\n        var start = key;\n        var end = key + 1;\n        var startTime = channels.time[start];\n        var endTime = channels.time[end];\n        var range = endTime - startTime;\n        var percent = range === 0 ? 0 : (time - startTime) / range;\n\n        if (channels.rotation) {\n            quatSlerp(this.rotation, channels.rotation, channels.rotation, percent, start * 4, end * 4);\n        }\n        if (channels.position) {\n            vec3lerp(this.position, channels.position, channels.position, percent, start * 3, end * 3);\n        }\n        if (channels.scale) {\n            vec3lerp(this.scale, channels.scale, channels.scale, percent, start * 3, end * 3);\n        }\n    }\n    // Loop handling\n    if (key == len - 2) {\n        this._cacheKey = 0;\n        this._cacheTime = 0;\n    }\n\n    this.updateTarget();\n};\n\n/**\n * Update transform of target node manually\n */\nSamplerTrack.prototype.updateTarget = function () {\n    var channels = this.channels;\n    if (this.target) {\n        // Only update target prop if have data.\n        if (channels.position) {\n            this.target.position.setArray(this.position);\n        }\n        if (channels.rotation) {\n            this.target.rotation.setArray(this.rotation);\n        }\n        if (channels.scale) {\n            this.target.scale.setArray(this.scale);\n        }\n    }\n};\n\n/**\n * @return {number}\n */\nSamplerTrack.prototype.getMaxTime = function () {\n    return this.channels.time[this.channels.time.length - 1];\n};\n\n/**\n * @param {number} startTime\n * @param {number} endTime\n * @return {clay.animation.SamplerTrack}\n */\nSamplerTrack.prototype.getSubTrack = function (startTime, endTime) {\n\n    var subClip = new SamplerTrack({\n        name: this.name\n    });\n    var minTime = this.channels.time[0];\n    startTime = Math.min(Math.max(startTime, minTime), this.life);\n    endTime = Math.min(Math.max(endTime, minTime), this.life);\n\n    var rangeStart = this._findRange(startTime);\n    var rangeEnd = this._findRange(endTime);\n\n    var count = rangeEnd[0] - rangeStart[0] + 1;\n    if (rangeStart[1] === 0 && rangeEnd[1] === 0) {\n        count -= 1;\n    }\n    if (this.channels.rotation) {\n        subClip.channels.rotation = new Float32Array(count * 4);\n    }\n    if (this.channels.position) {\n        subClip.channels.position = new Float32Array(count * 3);\n    }\n    if (this.channels.scale) {\n        subClip.channels.scale = new Float32Array(count * 3);\n    }\n    if (this.channels.time) {\n        subClip.channels.time = new Float32Array(count);\n    }\n    // Clip at the start\n    this.setTime(startTime);\n    for (var i = 0; i < 3; i++) {\n        subClip.channels.rotation[i] = this.rotation[i];\n        subClip.channels.position[i] = this.position[i];\n        subClip.channels.scale[i] = this.scale[i];\n    }\n    subClip.channels.time[0] = 0;\n    subClip.channels.rotation[3] = this.rotation[3];\n\n    for (var i = 1; i < count-1; i++) {\n        var i2;\n        for (var j = 0; j < 3; j++) {\n            i2 = rangeStart[0] + i;\n            subClip.channels.rotation[i * 4 + j] = this.channels.rotation[i2 * 4 + j];\n            subClip.channels.position[i * 3 + j] = this.channels.position[i2 * 3 + j];\n            subClip.channels.scale[i * 3 + j] = this.channels.scale[i2 * 3 + j];\n        }\n        subClip.channels.time[i] = this.channels.time[i2] - startTime;\n        subClip.channels.rotation[i * 4 + 3] = this.channels.rotation[i2 * 4 + 3];\n    }\n    // Clip at the end\n    this.setTime(endTime);\n    for (var i = 0; i < 3; i++) {\n        subClip.channels.rotation[(count - 1) * 4 + i] = this.rotation[i];\n        subClip.channels.position[(count - 1) * 3 + i] = this.position[i];\n        subClip.channels.scale[(count - 1) * 3 + i] = this.scale[i];\n    }\n    subClip.channels.time[(count - 1)] = endTime - startTime;\n    subClip.channels.rotation[(count - 1) * 4 + 3] = this.rotation[3];\n\n    // TODO set back ?\n    subClip.life = endTime - startTime;\n    return subClip;\n};\n\nSamplerTrack.prototype._findRange = function (time) {\n    var channels = this.channels;\n    var len = channels.time.length;\n    var start = -1;\n    for (var i = 0; i < len - 1; i++) {\n        if (channels.time[i] <= time && channels.time[i+1] > time) {\n            start = i;\n        }\n    }\n    var percent = 0;\n    if (start >= 0) {\n        var startTime = channels.time[start];\n        var endTime = channels.time[start+1];\n        var percent = (time-startTime) / (endTime-startTime);\n    }\n    // Percent [0, 1)\n    return [start, percent];\n};\n\n/**\n * 1D blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n * @param  {number} w\n */\nSamplerTrack.prototype.blend1D = TransformTrack.prototype.blend1D;\n/**\n * 2D blending between three clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c3\n * @param  {number} f\n * @param  {number} g\n */\nSamplerTrack.prototype.blend2D = TransformTrack.prototype.blend2D;\n/**\n * Additive blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n */\nSamplerTrack.prototype.additiveBlend = TransformTrack.prototype.additiveBlend;\n/**\n * Subtractive blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n */\nSamplerTrack.prototype.subtractiveBlend = TransformTrack.prototype.subtractiveBlend;\n\n/**\n * Clone a new SamplerTrack\n * @return {clay.animation.SamplerTrack}\n */\nSamplerTrack.prototype.clone = function () {\n    var track = SamplerTrack.prototype.clone.call(this);\n    track.channels = {\n        time: this.channels.time || null,\n        position: this.channels.position || null,\n        rotation: this.channels.rotation || null,\n        scale: this.channels.scale || null\n    };\n    vec3.copy(track.position, this.position);\n    quat.copy(track.rotation, this.rotation);\n    vec3.copy(track.scale, this.scale);\n\n    track.target = this.target;\n    track.updateTarget();\n\n    return track;\n\n};\n\nexport default SamplerTrack;\n","/**\n * Extend a sub class from base class\n * @param {object|Function} makeDefaultOpt default option of this sub class, method of the sub can use this.xxx to access this option\n * @param {Function} [initialize] Initialize after the sub class is instantiated\n * @param {Object} [proto] Prototype methods/properties of the sub class\n * @memberOf clay.core.mixin.extend\n * @return {Function}\n */\nfunction derive(makeDefaultOpt, initialize/*optional*/, proto/*optional*/) {\n\n    if (typeof initialize == 'object') {\n        proto = initialize;\n        initialize = null;\n    }\n\n    var _super = this;\n\n    var propList;\n    if (!(makeDefaultOpt instanceof Function)) {\n        // Optimize the property iterate if it have been fixed\n        propList = [];\n        for (var propName in makeDefaultOpt) {\n            if (makeDefaultOpt.hasOwnProperty(propName)) {\n                propList.push(propName);\n            }\n        }\n    }\n\n    var sub = function(options) {\n\n        // call super constructor\n        _super.apply(this, arguments);\n\n        if (makeDefaultOpt instanceof Function) {\n            // Invoke makeDefaultOpt each time if it is a function, So we can make sure each\n            // property in the object will not be shared by mutiple instances\n            extend(this, makeDefaultOpt.call(this, options));\n        }\n        else {\n            extendWithPropList(this, makeDefaultOpt, propList);\n        }\n\n        if (this.constructor === sub) {\n            // Initialize function will be called in the order of inherit\n            var initializers = sub.__initializers__;\n            for (var i = 0; i < initializers.length; i++) {\n                initializers[i].apply(this, arguments);\n            }\n        }\n    };\n    // save super constructor\n    sub.__super__ = _super;\n    // Initialize function will be called after all the super constructor is called\n    if (!_super.__initializers__) {\n        sub.__initializers__ = [];\n    } else {\n        sub.__initializers__ = _super.__initializers__.slice();\n    }\n    if (initialize) {\n        sub.__initializers__.push(initialize);\n    }\n\n    var Ctor = function() {};\n    Ctor.prototype = _super.prototype;\n    sub.prototype = new Ctor();\n    sub.prototype.constructor = sub;\n    extend(sub.prototype, proto);\n\n    // extend the derive method as a static method;\n    sub.extend = _super.extend;\n\n    // DEPCRATED\n    sub.derive = _super.extend;\n\n    return sub;\n}\n\nfunction extend(target, source) {\n    if (!source) {\n        return;\n    }\n    for (var name in source) {\n        if (source.hasOwnProperty(name)) {\n            target[name] = source[name];\n        }\n    }\n}\n\nfunction extendWithPropList(target, source, propList) {\n    for (var i = 0; i < propList.length; i++) {\n        var propName = propList[i];\n        target[propName] = source[propName];\n    }\n}\n\n/**\n * @alias clay.core.mixin.extend\n * @mixin\n */\nexport default {\n\n    extend: derive,\n\n    // DEPCRATED\n    derive: derive\n};\n","function Handler(action, context) {\n    this.action = action;\n    this.context = context;\n}\n/**\n * @mixin\n * @alias clay.core.mixin.notifier\n */\nvar notifier = {\n    /**\n     * Trigger event\n     * @param  {string} name\n     */\n    trigger: function(name) {\n        if (!this.hasOwnProperty('__handlers__')) {\n            return;\n        }\n        if (!this.__handlers__.hasOwnProperty(name)) {\n            return;\n        }\n\n        var hdls = this.__handlers__[name];\n        var l = hdls.length, i = -1, args = arguments;\n        // Optimize advise from backbone\n        switch (args.length) {\n            case 1:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context);\n                }\n                return;\n            case 2:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1]);\n                }\n                return;\n            case 3:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2]);\n                }\n                return;\n            case 4:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2], args[3]);\n                }\n                return;\n            case 5:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2], args[3], args[4]);\n                }\n                return;\n            default:\n                while (++i < l) {\n                    hdls[i].action.apply(hdls[i].context, Array.prototype.slice.call(args, 1));\n                }\n                return;\n        }\n    },\n    /**\n     * Register event handler\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    on: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        var handlers = this.__handlers__ || (this.__handlers__={});\n        if (!handlers[name]) {\n            handlers[name] = [];\n        }\n        else {\n            if (this.has(name, action)) {\n                return;\n            }\n        }\n        var handler = new Handler(action, context || this);\n        handlers[name].push(handler);\n\n        return this;\n    },\n\n    /**\n     * Register event, event will only be triggered once and then removed\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    once: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        var self = this;\n        function wrapper() {\n            self.off(name, wrapper);\n            action.apply(this, arguments);\n        }\n        return this.on(name, wrapper, context);\n    },\n\n    /**\n     * Alias of once('before' + name)\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    before: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        name = 'before' + name;\n        return this.on(name, action, context);\n    },\n\n    /**\n     * Alias of once('after' + name)\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    after: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        name = 'after' + name;\n        return this.on(name, action, context);\n    },\n\n    /**\n     * Alias of on('success')\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    success: function(action, context) {\n        return this.once('success', action, context);\n    },\n\n    /**\n     * Alias of on('error')\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    error: function(action, context) {\n        return this.once('error', action, context);\n    },\n\n    /**\n     * Remove event listener\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    off: function(name, action) {\n\n        var handlers = this.__handlers__ || (this.__handlers__={});\n\n        if (!action) {\n            handlers[name] = [];\n            return;\n        }\n        if (handlers[name]) {\n            var hdls = handlers[name];\n            var retains = [];\n            for (var i = 0; i < hdls.length; i++) {\n                if (action && hdls[i].action !== action) {\n                    retains.push(hdls[i]);\n                }\n            }\n            handlers[name] = retains;\n        }\n\n        return this;\n    },\n\n    /**\n     * If registered the event handler\n     * @param  {string}  name\n     * @param  {Function}  action\n     * @return {boolean}\n     */\n    has: function(name, action) {\n        var handlers = this.__handlers__;\n\n        if (! handlers ||\n            ! handlers[name]) {\n            return false;\n        }\n        var hdls = handlers[name];\n        for (var i = 0; i < hdls.length; i++) {\n            if (hdls[i].action === action) {\n                return true;\n            }\n        }\n    }\n};\n\nexport default notifier;","var guid = 0;\n\nvar ArrayProto = Array.prototype;\nvar nativeForEach = ArrayProto.forEach;\n\n/**\n * Util functions\n * @namespace clay.core.util\n */\nvar util = {\n\n    /**\n     * Generate GUID\n     * @return {number}\n     * @memberOf clay.core.util\n     */\n    genGUID: function () {\n        return ++guid;\n    },\n    /**\n     * Relative path to absolute path\n     * @param  {string} path\n     * @param  {string} basePath\n     * @return {string}\n     * @memberOf clay.core.util\n     */\n    relative2absolute: function (path, basePath) {\n        if (!basePath || path.match(/^\\//)) {\n            return path;\n        }\n        var pathParts = path.split('/');\n        var basePathParts = basePath.split('/');\n\n        var item = pathParts[0];\n        while(item === '.' || item === '..') {\n            if (item === '..') {\n                basePathParts.pop();\n            }\n            pathParts.shift();\n            item = pathParts[0];\n        }\n        return basePathParts.join('/') + '/' + pathParts.join('/');\n    },\n\n    /**\n     * Extend target with source\n     * @param  {Object} target\n     * @param  {Object} source\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    extend: function (target, source) {\n        if (source) {\n            for (var name in source) {\n                if (source.hasOwnProperty(name)) {\n                    target[name] = source[name];\n                }\n            }\n        }\n        return target;\n    },\n\n    /**\n     * Extend properties to target if not exist.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    defaults: function (target, source) {\n        if (source) {\n            for (var propName in source) {\n                if (target[propName] === undefined) {\n                    target[propName] = source[propName];\n                }\n            }\n        }\n        return target;\n    },\n    /**\n     * Extend properties with a given property list to avoid for..in.. iteration.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @param  {Array.<string>} propList\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    extendWithPropList: function (target, source, propList) {\n        if (source) {\n            for (var i = 0; i < propList.length; i++) {\n                var propName = propList[i];\n                target[propName] = source[propName];\n            }\n        }\n        return target;\n    },\n    /**\n     * Extend properties to target if not exist. With a given property list avoid for..in.. iteration.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @param  {Array.<string>} propList\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    defaultsWithPropList: function (target, source, propList) {\n        if (source) {\n            for (var i = 0; i < propList.length; i++) {\n                var propName = propList[i];\n                if (target[propName] == null) {\n                    target[propName] = source[propName];\n                }\n            }\n        }\n        return target;\n    },\n    /**\n     * @param  {Object|Array} obj\n     * @param  {Function} iterator\n     * @param  {Object} [context]\n     * @memberOf clay.core.util\n     */\n    each: function (obj, iterator, context) {\n        if (!(obj && iterator)) {\n            return;\n        }\n        if (obj.forEach && obj.forEach === nativeForEach) {\n            obj.forEach(iterator, context);\n        }\n        else if (obj.length === + obj.length) {\n            for (var i = 0, len = obj.length; i < len; i++) {\n                iterator.call(context, obj[i], i, obj);\n            }\n        }\n        else {\n            for (var key in obj) {\n                if (obj.hasOwnProperty(key)) {\n                    iterator.call(context, obj[key], key, obj);\n                }\n            }\n        }\n    },\n\n    /**\n     * Is object\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isObject: function (obj) {\n        return obj === Object(obj);\n    },\n\n    /**\n     * Is array ?\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isArray: function (obj) {\n        return Array.isArray(obj);\n    },\n\n    /**\n     * Is array like, which have a length property\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isArrayLike: function (obj) {\n        if (!obj) {\n            return false;\n        }\n        else {\n            return obj.length === + obj.length;\n        }\n    },\n\n    /**\n     * @param  {} obj\n     * @return {}\n     * @memberOf clay.core.util\n     */\n    clone: function (obj) {\n        if (!util.isObject(obj)) {\n            return obj;\n        }\n        else if (util.isArray(obj)) {\n            return obj.slice();\n        }\n        else if (util.isArrayLike(obj)) { // is typed array\n            var ret = new obj.constructor(obj.length);\n            for (var i = 0; i < obj.length; i++) {\n                ret[i] = obj[i];\n            }\n            return ret;\n        }\n        else {\n            return util.extend({}, obj);\n        }\n    }\n};\n\nexport default util;\n","import extendMixin from './mixin/extend';\nimport notifierMixin from './mixin/notifier';\nimport util from './util';\n\n/**\n * Base class of all objects\n * @constructor\n * @alias clay.core.Base\n * @mixes clay.core.mixin.notifier\n */\nvar Base = function () {\n    /**\n     * @type {number}\n     */\n    this.__uid__ = util.genGUID();\n};\n\nBase.__initializers__ = [\n    function (opts) {\n        util.extend(this, opts);\n    }\n];\n\nutil.extend(Base, extendMixin);\nutil.extend(Base.prototype, notifierMixin);\n\nexport default Base;\n","import Base from '../core/Base';\nimport Animator from './Animator';\n\nvar requestAnimationFrame = window.requestAnimationFrame\n                            || window.msRequestAnimationFrame\n                            || window.mozRequestAnimationFrame\n                            || window.webkitRequestAnimationFrame\n                            || function (func){ setTimeout(func, 16); };\n\n/**\n * Animation is global timeline that schedule all clips. each frame animation will set the time of clips to current and update the states of clips\n * @constructor clay.animation.Animation\n * @extends clay.core.Base\n *\n * @example\n * var animation = new clay.animation.Animation();\n * var node = new clay.Node();\n * animation.animate(node.position)\n *     .when(1000, {\n *         x: 500,\n *         y: 500\n *     })\n *     .when(2000, {\n *         x: 100,\n *         y: 100\n *     })\n *     .when(3000, {\n *         z: 10\n *     })\n *     .start('spline');\n */\nvar Timeline = Base.extend(function () {\n    return /** @lends clay.animation.Timeline# */{\n        /**\n         * stage is an object with render method, each frame if there exists any animating clips, stage.render will be called\n         * @type {Object}\n         */\n        stage: null,\n\n        _clips: [],\n\n        _running: false,\n\n        _time: 0,\n\n        _paused: false,\n\n        _pausedTime: 0\n    };\n},\n/** @lends clay.animation.Timeline.prototype */\n{\n\n    /**\n     * Add animator\n     * @param {clay.animate.Animator} animator\n     */\n    addAnimator: function (animator) {\n        animator.animation = this;\n        var clips = animator.getClips();\n        for (var i = 0; i < clips.length; i++) {\n            this.addClip(clips[i]);\n        }\n    },\n\n    /**\n     * @param {clay.animation.Clip} clip\n     */\n    addClip: function (clip) {\n        if (this._clips.indexOf(clip) < 0) {\n            this._clips.push(clip);\n        }\n    },\n\n    /**\n     * @param  {clay.animation.Clip} clip\n     */\n    removeClip: function (clip) {\n        var idx = this._clips.indexOf(clip);\n        if (idx >= 0) {\n            this._clips.splice(idx, 1);\n        }\n    },\n\n    /**\n     * Remove animator\n     * @param {clay.animate.Animator} animator\n     */\n    removeAnimator: function (animator) {\n        var clips = animator.getClips();\n        for (var i = 0; i < clips.length; i++) {\n            this.removeClip(clips[i]);\n        }\n        animator.animation = null;\n    },\n\n    _update: function () {\n\n        var time = Date.now() - this._pausedTime;\n        var delta = time - this._time;\n        var clips = this._clips;\n        var len = clips.length;\n\n        var deferredEvents = [];\n        var deferredClips = [];\n        for (var i = 0; i < len; i++) {\n            var clip = clips[i];\n            var e = clip.step(time, delta, false);\n            // Throw out the events need to be called after\n            // stage.render, like finish\n            if (e) {\n                deferredEvents.push(e);\n                deferredClips.push(clip);\n            }\n        }\n\n        // Remove the finished clip\n        for (var i = 0; i < len;) {\n            if (clips[i]._needsRemove) {\n                clips[i] = clips[len-1];\n                clips.pop();\n                len--;\n            } else {\n                i++;\n            }\n        }\n\n        len = deferredEvents.length;\n        for (var i = 0; i < len; i++) {\n            deferredClips[i].fire(deferredEvents[i]);\n        }\n\n        this._time = time;\n\n        this.trigger('frame', delta);\n\n        if (this.stage && this.stage.render) {\n            this.stage.render();\n        }\n    },\n    /**\n     * Start running animation\n     */\n    start: function () {\n        var self = this;\n\n        this._running = true;\n        this._time = Date.now();\n\n        this._pausedTime = 0;\n\n        function step() {\n            if (self._running) {\n\n                requestAnimationFrame(step);\n\n                if (!self._paused) {\n                    self._update();\n                }\n            }\n        }\n\n        requestAnimationFrame(step);\n\n    },\n    /**\n     * Stop running animation\n     */\n    stop: function () {\n        this._running = false;\n    },\n\n    /**\n     * Pause\n     */\n    pause: function () {\n        if (!this._paused) {\n            this._pauseStart = Date.now();\n            this._paused = true;\n        }\n    },\n\n    /**\n     * Resume\n     */\n    resume: function () {\n        if (this._paused) {\n            this._pausedTime += Date.now() - this._pauseStart;\n            this._paused = false;\n        }\n    },\n\n    /**\n     * Remove all clips\n     */\n    removeClipsAll: function () {\n        this._clips = [];\n    },\n    /**\n     * Create a animator\n     * @param  {Object} target\n     * @param  {Object} [options]\n     * @param  {boolean} [options.loop]\n     * @param  {Function} [options.getter]\n     * @param  {Function} [options.setter]\n     * @param  {Function} [options.interpolater]\n     * @return {clay.animation.Animator}\n     */\n    animate: function (target, options) {\n        options = options || {};\n        var animator = new Animator(\n            target,\n            options.loop,\n            options.getter,\n            options.setter,\n            options.interpolater\n        );\n        animator.animation = this;\n        return animator;\n    }\n});\n\nexport default Timeline;\n","import Clip from './Clip';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\n/**\n *\n * Animation clip that manage a collection of {@link clay.animation.SamplerTrack}\n * @constructor\n * @alias clay.animation.TrackClip\n *\n * @extends clay.animation.Clip\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {Array.<clay.animation.SamplerTrack>} [opts.tracks]\n */\nvar TrackClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n\n    /**\n     *\n     * @type {clay.animation.SamplerTrack[]}\n     */\n    this.tracks = opts.tracks || [];\n};\n\nTrackClip.prototype = Object.create(Clip.prototype);\n\nTrackClip.prototype.constructor = TrackClip;\n\nTrackClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time, dTime, true);\n\n    if (ret !== 'finish') {\n        var time = this.getElapsedTime();\n        // TODO life may be changed.\n        if (this._range) {\n            time = this._range[0] + time;\n        }\n        this.setTime(time);\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n\n    return ret;\n};\n\n/**\n * @param {Array.<number>} range\n */\nTrackClip.prototype.setRange = function (range) {\n    this.calcLifeFromTracks();\n    this._range = range;\n    if (range) {\n        range[1] = Math.min(range[1], this.life);\n        range[0] = Math.min(range[0], this.life);\n        this.life = (range[1] - range[0]);\n    }\n};\n\nTrackClip.prototype.setTime = function (time) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        this.tracks[i].setTime(time);\n    }\n};\n\nTrackClip.prototype.calcLifeFromTracks = function () {\n    this.life = 0;\n    for (var i = 0; i < this.tracks.length; i++) {\n        this.life = Math.max(this.life, this.tracks[i].getMaxTime());\n    }\n};\n\n/**\n * @param {clay.animation.SamplerTrack} jointClip\n */\nTrackClip.prototype.addTrack = function (track) {\n    this.tracks.push(track);\n};\n\n/**\n * @param {clay.animation.SamplerTrack} jointClip\n */\nTrackClip.prototype.removeTarck = function (track) {\n    var idx = this.tracks.indexOf(track);\n    if (idx >= 0) {\n        this.tracks.splice(idx, 1);\n    }\n};\n\n/**\n * @param {number} startTime\n * @param {number} endTime\n * @param {boolean} isLoop\n * @return {clay.animation.TrackClip}\n */\nTrackClip.prototype.getSubClip = function (startTime, endTime, isLoop) {\n    var subClip = new TrackClip({\n        name: this.name\n    });\n\n    for (var i = 0; i < this.tracks.length; i++) {\n        var subTrack = this.tracks[i].getSubTrack(startTime, endTime);\n        subClip.addTrack(subTrack);\n    }\n\n    if (isLoop !== undefined) {\n        subClip.setLoop(isLoop);\n    }\n\n    subClip.life = endTime - startTime;\n\n    return subClip;\n};\n\n/**\n * 1d blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n * @param  {number} w\n */\nTrackClip.prototype.blend1D = function (clip1, clip2, w) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.blend1D(c1, c2, w);\n    }\n};\n\n/**\n * Additive blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n */\nTrackClip.prototype.additiveBlend = function (clip1, clip2) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.additiveBlend(c1, c2);\n    }\n};\n\n/**\n * Subtractive blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n */\nTrackClip.prototype.subtractiveBlend = function (clip1, clip2) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.subtractiveBlend(c1, c2);\n    }\n};\n\n/**\n * 2D blending from three skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n * @param  {clay.animation.TrackClip} clip3\n * @param  {number} f\n * @param  {number} g\n */\nTrackClip.prototype.blend2D = function (clip1, clip2, clip3, f, g) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var c3 = clip3.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.blend2D(c1, c2, c3, f, g);\n    }\n};\n\n/**\n * Copy SRT of all joints clips from another TrackClip\n * @param  {clay.animation.TrackClip} clip\n */\nTrackClip.prototype.copy = function (clip) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var sTrack = clip.tracks[i];\n        var tTrack = this.tracks[i];\n\n        vec3.copy(tTrack.position, sTrack.position);\n        vec3.copy(tTrack.scale, sTrack.scale);\n        quat.copy(tTrack.rotation, sTrack.rotation);\n    }\n};\n\nTrackClip.prototype.clone = function () {\n    var clip = Clip.prototype.clone.call(this);\n    for (var i = 0; i < this.tracks.length; i++) {\n        clip.addTrack(this.tracks[i].clone());\n    }\n    clip.life = this.life;\n    return clip;\n};\n\nexport default TrackClip;\n","var EXTENSION_LIST = [\n    'OES_texture_float',\n    'OES_texture_half_float',\n    'OES_texture_float_linear',\n    'OES_texture_half_float_linear',\n    'OES_standard_derivatives',\n    'OES_vertex_array_object',\n    'OES_element_index_uint',\n    'WEBGL_compressed_texture_s3tc',\n    'WEBGL_depth_texture',\n    'EXT_texture_filter_anisotropic',\n    'EXT_shader_texture_lod',\n    'WEBGL_draw_buffers',\n    'EXT_frag_depth',\n    'EXT_sRGB'\n];\n\nvar PARAMETER_NAMES = [\n    'MAX_TEXTURE_SIZE',\n    'MAX_CUBE_MAP_TEXTURE_SIZE'\n];\n\nfunction GLInfo(_gl) {\n    var extensions = {};\n    var parameters = {};\n\n    // Get webgl extension\n    for (var i = 0; i < EXTENSION_LIST.length; i++) {\n        var extName = EXTENSION_LIST[i];\n        createExtension(extName);\n    }\n    // Get parameters\n    for (var i = 0; i < PARAMETER_NAMES.length; i++) {\n        var name = PARAMETER_NAMES[i];\n        parameters[name] = _gl.getParameter(_gl[name]);\n    }\n\n    this.getExtension = function (name) {\n        if (!(name in extensions)) {\n            createExtension(name);\n        }\n        return extensions[name];\n    };\n\n    this.getParameter = function (name) {\n        return parameters[name];\n    };\n\n    function createExtension(name) {\n        var ext = _gl.getExtension(name);\n        if (!ext) {\n            ext = _gl.getExtension('MOZ_' + name);\n        }\n        if (!ext) {\n            ext = _gl.getExtension('WEBKIT_' + name);\n        }\n        extensions[name] = ext;\n    }\n}\n\nexport default GLInfo;\n","/**\n * @namespace clay.core.glenum\n * @see http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14\n */\nexport default {\n    /* ClearBufferMask */\n    DEPTH_BUFFER_BIT               : 0x00000100,\n    STENCIL_BUFFER_BIT             : 0x00000400,\n    COLOR_BUFFER_BIT               : 0x00004000,\n\n    /* BeginMode */\n    POINTS                         : 0x0000,\n    LINES                          : 0x0001,\n    LINE_LOOP                      : 0x0002,\n    LINE_STRIP                     : 0x0003,\n    TRIANGLES                      : 0x0004,\n    TRIANGLE_STRIP                 : 0x0005,\n    TRIANGLE_FAN                   : 0x0006,\n\n    /* AlphaFunction (not supported in ES20) */\n    /*      NEVER */\n    /*      LESS */\n    /*      EQUAL */\n    /*      LEQUAL */\n    /*      GREATER */\n    /*      NOTEQUAL */\n    /*      GEQUAL */\n    /*      ALWAYS */\n\n    /* BlendingFactorDest */\n    ZERO                           : 0,\n    ONE                            : 1,\n    SRC_COLOR                      : 0x0300,\n    ONE_MINUS_SRC_COLOR            : 0x0301,\n    SRC_ALPHA                      : 0x0302,\n    ONE_MINUS_SRC_ALPHA            : 0x0303,\n    DST_ALPHA                      : 0x0304,\n    ONE_MINUS_DST_ALPHA            : 0x0305,\n\n    /* BlendingFactorSrc */\n    /*      ZERO */\n    /*      ONE */\n    DST_COLOR                      : 0x0306,\n    ONE_MINUS_DST_COLOR            : 0x0307,\n    SRC_ALPHA_SATURATE             : 0x0308,\n    /*      SRC_ALPHA */\n    /*      ONE_MINUS_SRC_ALPHA */\n    /*      DST_ALPHA */\n    /*      ONE_MINUS_DST_ALPHA */\n\n    /* BlendEquationSeparate */\n    FUNC_ADD                       : 0x8006,\n    BLEND_EQUATION                 : 0x8009,\n    BLEND_EQUATION_RGB             : 0x8009, /* same as BLEND_EQUATION */\n    BLEND_EQUATION_ALPHA           : 0x883D,\n\n    /* BlendSubtract */\n    FUNC_SUBTRACT                  : 0x800A,\n    FUNC_REVERSE_SUBTRACT          : 0x800B,\n\n    /* Separate Blend Functions */\n    BLEND_DST_RGB                  : 0x80C8,\n    BLEND_SRC_RGB                  : 0x80C9,\n    BLEND_DST_ALPHA                : 0x80CA,\n    BLEND_SRC_ALPHA                : 0x80CB,\n    CONSTANT_COLOR                 : 0x8001,\n    ONE_MINUS_CONSTANT_COLOR       : 0x8002,\n    CONSTANT_ALPHA                 : 0x8003,\n    ONE_MINUS_CONSTANT_ALPHA       : 0x8004,\n    BLEND_COLOR                    : 0x8005,\n\n    /* Buffer Objects */\n    ARRAY_BUFFER                   : 0x8892,\n    ELEMENT_ARRAY_BUFFER           : 0x8893,\n    ARRAY_BUFFER_BINDING           : 0x8894,\n    ELEMENT_ARRAY_BUFFER_BINDING   : 0x8895,\n\n    STREAM_DRAW                    : 0x88E0,\n    STATIC_DRAW                    : 0x88E4,\n    DYNAMIC_DRAW                   : 0x88E8,\n\n    BUFFER_SIZE                    : 0x8764,\n    BUFFER_USAGE                   : 0x8765,\n\n    CURRENT_VERTEX_ATTRIB          : 0x8626,\n\n    /* CullFaceMode */\n    FRONT                          : 0x0404,\n    BACK                           : 0x0405,\n    FRONT_AND_BACK                 : 0x0408,\n\n    /* DepthFunction */\n    /*      NEVER */\n    /*      LESS */\n    /*      EQUAL */\n    /*      LEQUAL */\n    /*      GREATER */\n    /*      NOTEQUAL */\n    /*      GEQUAL */\n    /*      ALWAYS */\n\n    /* EnableCap */\n    /* TEXTURE_2D */\n    CULL_FACE                      : 0x0B44,\n    BLEND                          : 0x0BE2,\n    DITHER                         : 0x0BD0,\n    STENCIL_TEST                   : 0x0B90,\n    DEPTH_TEST                     : 0x0B71,\n    SCISSOR_TEST                   : 0x0C11,\n    POLYGON_OFFSET_FILL            : 0x8037,\n    SAMPLE_ALPHA_TO_COVERAGE       : 0x809E,\n    SAMPLE_COVERAGE                : 0x80A0,\n\n    /* ErrorCode */\n    NO_ERROR                       : 0,\n    INVALID_ENUM                   : 0x0500,\n    INVALID_VALUE                  : 0x0501,\n    INVALID_OPERATION              : 0x0502,\n    OUT_OF_MEMORY                  : 0x0505,\n\n    /* FrontFaceDirection */\n    CW                             : 0x0900,\n    CCW                            : 0x0901,\n\n    /* GetPName */\n    LINE_WIDTH                     : 0x0B21,\n    ALIASED_POINT_SIZE_RANGE       : 0x846D,\n    ALIASED_LINE_WIDTH_RANGE       : 0x846E,\n    CULL_FACE_MODE                 : 0x0B45,\n    FRONT_FACE                     : 0x0B46,\n    DEPTH_RANGE                    : 0x0B70,\n    DEPTH_WRITEMASK                : 0x0B72,\n    DEPTH_CLEAR_VALUE              : 0x0B73,\n    DEPTH_FUNC                     : 0x0B74,\n    STENCIL_CLEAR_VALUE            : 0x0B91,\n    STENCIL_FUNC                   : 0x0B92,\n    STENCIL_FAIL                   : 0x0B94,\n    STENCIL_PASS_DEPTH_FAIL        : 0x0B95,\n    STENCIL_PASS_DEPTH_PASS        : 0x0B96,\n    STENCIL_REF                    : 0x0B97,\n    STENCIL_VALUE_MASK             : 0x0B93,\n    STENCIL_WRITEMASK              : 0x0B98,\n    STENCIL_BACK_FUNC              : 0x8800,\n    STENCIL_BACK_FAIL              : 0x8801,\n    STENCIL_BACK_PASS_DEPTH_FAIL   : 0x8802,\n    STENCIL_BACK_PASS_DEPTH_PASS   : 0x8803,\n    STENCIL_BACK_REF               : 0x8CA3,\n    STENCIL_BACK_VALUE_MASK        : 0x8CA4,\n    STENCIL_BACK_WRITEMASK         : 0x8CA5,\n    VIEWPORT                       : 0x0BA2,\n    SCISSOR_BOX                    : 0x0C10,\n    /*      SCISSOR_TEST */\n    COLOR_CLEAR_VALUE              : 0x0C22,\n    COLOR_WRITEMASK                : 0x0C23,\n    UNPACK_ALIGNMENT               : 0x0CF5,\n    PACK_ALIGNMENT                 : 0x0D05,\n    MAX_TEXTURE_SIZE               : 0x0D33,\n    MAX_VIEWPORT_DIMS              : 0x0D3A,\n    SUBPIXEL_BITS                  : 0x0D50,\n    RED_BITS                       : 0x0D52,\n    GREEN_BITS                     : 0x0D53,\n    BLUE_BITS                      : 0x0D54,\n    ALPHA_BITS                     : 0x0D55,\n    DEPTH_BITS                     : 0x0D56,\n    STENCIL_BITS                   : 0x0D57,\n    POLYGON_OFFSET_UNITS           : 0x2A00,\n    /*      POLYGON_OFFSET_FILL */\n    POLYGON_OFFSET_FACTOR          : 0x8038,\n    TEXTURE_BINDING_2D             : 0x8069,\n    SAMPLE_BUFFERS                 : 0x80A8,\n    SAMPLES                        : 0x80A9,\n    SAMPLE_COVERAGE_VALUE          : 0x80AA,\n    SAMPLE_COVERAGE_INVERT         : 0x80AB,\n\n    /* GetTextureParameter */\n    /*      TEXTURE_MAG_FILTER */\n    /*      TEXTURE_MIN_FILTER */\n    /*      TEXTURE_WRAP_S */\n    /*      TEXTURE_WRAP_T */\n\n    COMPRESSED_TEXTURE_FORMATS     : 0x86A3,\n\n    /* HintMode */\n    DONT_CARE                      : 0x1100,\n    FASTEST                        : 0x1101,\n    NICEST                         : 0x1102,\n\n    /* HintTarget */\n    GENERATE_MIPMAP_HINT            : 0x8192,\n\n    /* DataType */\n    BYTE                           : 0x1400,\n    UNSIGNED_BYTE                  : 0x1401,\n    SHORT                          : 0x1402,\n    UNSIGNED_SHORT                 : 0x1403,\n    INT                            : 0x1404,\n    UNSIGNED_INT                   : 0x1405,\n    FLOAT                          : 0x1406,\n\n    /* PixelFormat */\n    DEPTH_COMPONENT                : 0x1902,\n    ALPHA                          : 0x1906,\n    RGB                            : 0x1907,\n    RGBA                           : 0x1908,\n    LUMINANCE                      : 0x1909,\n    LUMINANCE_ALPHA                : 0x190A,\n\n    /* PixelType */\n    /*      UNSIGNED_BYTE */\n    UNSIGNED_SHORT_4_4_4_4         : 0x8033,\n    UNSIGNED_SHORT_5_5_5_1         : 0x8034,\n    UNSIGNED_SHORT_5_6_5           : 0x8363,\n\n    /* Shaders */\n    FRAGMENT_SHADER                  : 0x8B30,\n    VERTEX_SHADER                    : 0x8B31,\n    MAX_VERTEX_ATTRIBS               : 0x8869,\n    MAX_VERTEX_UNIFORM_VECTORS       : 0x8DFB,\n    MAX_VARYING_VECTORS              : 0x8DFC,\n    MAX_COMBINED_TEXTURE_IMAGE_UNITS : 0x8B4D,\n    MAX_VERTEX_TEXTURE_IMAGE_UNITS   : 0x8B4C,\n    MAX_TEXTURE_IMAGE_UNITS          : 0x8872,\n    MAX_FRAGMENT_UNIFORM_VECTORS     : 0x8DFD,\n    SHADER_TYPE                      : 0x8B4F,\n    DELETE_STATUS                    : 0x8B80,\n    LINK_STATUS                      : 0x8B82,\n    VALIDATE_STATUS                  : 0x8B83,\n    ATTACHED_SHADERS                 : 0x8B85,\n    ACTIVE_UNIFORMS                  : 0x8B86,\n    ACTIVE_ATTRIBUTES                : 0x8B89,\n    SHADING_LANGUAGE_VERSION         : 0x8B8C,\n    CURRENT_PROGRAM                  : 0x8B8D,\n\n    /* StencilFunction */\n    NEVER                          : 0x0200,\n    LESS                           : 0x0201,\n    EQUAL                          : 0x0202,\n    LEQUAL                         : 0x0203,\n    GREATER                        : 0x0204,\n    NOTEQUAL                       : 0x0205,\n    GEQUAL                         : 0x0206,\n    ALWAYS                         : 0x0207,\n\n    /* StencilOp */\n    /*      ZERO */\n    KEEP                           : 0x1E00,\n    REPLACE                        : 0x1E01,\n    INCR                           : 0x1E02,\n    DECR                           : 0x1E03,\n    INVERT                         : 0x150A,\n    INCR_WRAP                      : 0x8507,\n    DECR_WRAP                      : 0x8508,\n\n    /* StringName */\n    VENDOR                         : 0x1F00,\n    RENDERER                       : 0x1F01,\n    VERSION                        : 0x1F02,\n\n    /* TextureMagFilter */\n    NEAREST                        : 0x2600,\n    LINEAR                         : 0x2601,\n\n    /* TextureMinFilter */\n    /*      NEAREST */\n    /*      LINEAR */\n    NEAREST_MIPMAP_NEAREST         : 0x2700,\n    LINEAR_MIPMAP_NEAREST          : 0x2701,\n    NEAREST_MIPMAP_LINEAR          : 0x2702,\n    LINEAR_MIPMAP_LINEAR           : 0x2703,\n\n    /* TextureParameterName */\n    TEXTURE_MAG_FILTER             : 0x2800,\n    TEXTURE_MIN_FILTER             : 0x2801,\n    TEXTURE_WRAP_S                 : 0x2802,\n    TEXTURE_WRAP_T                 : 0x2803,\n\n    /* TextureTarget */\n    TEXTURE_2D                     : 0x0DE1,\n    TEXTURE                        : 0x1702,\n\n    TEXTURE_CUBE_MAP               : 0x8513,\n    TEXTURE_BINDING_CUBE_MAP       : 0x8514,\n    TEXTURE_CUBE_MAP_POSITIVE_X    : 0x8515,\n    TEXTURE_CUBE_MAP_NEGATIVE_X    : 0x8516,\n    TEXTURE_CUBE_MAP_POSITIVE_Y    : 0x8517,\n    TEXTURE_CUBE_MAP_NEGATIVE_Y    : 0x8518,\n    TEXTURE_CUBE_MAP_POSITIVE_Z    : 0x8519,\n    TEXTURE_CUBE_MAP_NEGATIVE_Z    : 0x851A,\n    MAX_CUBE_MAP_TEXTURE_SIZE      : 0x851C,\n\n    /* TextureUnit */\n    TEXTURE0                       : 0x84C0,\n    TEXTURE1                       : 0x84C1,\n    TEXTURE2                       : 0x84C2,\n    TEXTURE3                       : 0x84C3,\n    TEXTURE4                       : 0x84C4,\n    TEXTURE5                       : 0x84C5,\n    TEXTURE6                       : 0x84C6,\n    TEXTURE7                       : 0x84C7,\n    TEXTURE8                       : 0x84C8,\n    TEXTURE9                       : 0x84C9,\n    TEXTURE10                      : 0x84CA,\n    TEXTURE11                      : 0x84CB,\n    TEXTURE12                      : 0x84CC,\n    TEXTURE13                      : 0x84CD,\n    TEXTURE14                      : 0x84CE,\n    TEXTURE15                      : 0x84CF,\n    TEXTURE16                      : 0x84D0,\n    TEXTURE17                      : 0x84D1,\n    TEXTURE18                      : 0x84D2,\n    TEXTURE19                      : 0x84D3,\n    TEXTURE20                      : 0x84D4,\n    TEXTURE21                      : 0x84D5,\n    TEXTURE22                      : 0x84D6,\n    TEXTURE23                      : 0x84D7,\n    TEXTURE24                      : 0x84D8,\n    TEXTURE25                      : 0x84D9,\n    TEXTURE26                      : 0x84DA,\n    TEXTURE27                      : 0x84DB,\n    TEXTURE28                      : 0x84DC,\n    TEXTURE29                      : 0x84DD,\n    TEXTURE30                      : 0x84DE,\n    TEXTURE31                      : 0x84DF,\n    ACTIVE_TEXTURE                 : 0x84E0,\n\n    /* TextureWrapMode */\n    REPEAT                         : 0x2901,\n    CLAMP_TO_EDGE                  : 0x812F,\n    MIRRORED_REPEAT                : 0x8370,\n\n    /* Uniform Types */\n    FLOAT_VEC2                     : 0x8B50,\n    FLOAT_VEC3                     : 0x8B51,\n    FLOAT_VEC4                     : 0x8B52,\n    INT_VEC2                       : 0x8B53,\n    INT_VEC3                       : 0x8B54,\n    INT_VEC4                       : 0x8B55,\n    BOOL                           : 0x8B56,\n    BOOL_VEC2                      : 0x8B57,\n    BOOL_VEC3                      : 0x8B58,\n    BOOL_VEC4                      : 0x8B59,\n    FLOAT_MAT2                     : 0x8B5A,\n    FLOAT_MAT3                     : 0x8B5B,\n    FLOAT_MAT4                     : 0x8B5C,\n    SAMPLER_2D                     : 0x8B5E,\n    SAMPLER_CUBE                   : 0x8B60,\n\n    /* Vertex Arrays */\n    VERTEX_ATTRIB_ARRAY_ENABLED        : 0x8622,\n    VERTEX_ATTRIB_ARRAY_SIZE           : 0x8623,\n    VERTEX_ATTRIB_ARRAY_STRIDE         : 0x8624,\n    VERTEX_ATTRIB_ARRAY_TYPE           : 0x8625,\n    VERTEX_ATTRIB_ARRAY_NORMALIZED     : 0x886A,\n    VERTEX_ATTRIB_ARRAY_POINTER        : 0x8645,\n    VERTEX_ATTRIB_ARRAY_BUFFER_BINDING : 0x889F,\n\n    /* Shader Source */\n    COMPILE_STATUS                 : 0x8B81,\n\n    /* Shader Precision-Specified Types */\n    LOW_FLOAT                      : 0x8DF0,\n    MEDIUM_FLOAT                   : 0x8DF1,\n    HIGH_FLOAT                     : 0x8DF2,\n    LOW_INT                        : 0x8DF3,\n    MEDIUM_INT                     : 0x8DF4,\n    HIGH_INT                       : 0x8DF5,\n\n    /* Framebuffer Object. */\n    FRAMEBUFFER                    : 0x8D40,\n    RENDERBUFFER                   : 0x8D41,\n\n    RGBA4                          : 0x8056,\n    RGB5_A1                        : 0x8057,\n    RGB565                         : 0x8D62,\n    DEPTH_COMPONENT16              : 0x81A5,\n    STENCIL_INDEX                  : 0x1901,\n    STENCIL_INDEX8                 : 0x8D48,\n    DEPTH_STENCIL                  : 0x84F9,\n\n    RENDERBUFFER_WIDTH             : 0x8D42,\n    RENDERBUFFER_HEIGHT            : 0x8D43,\n    RENDERBUFFER_INTERNAL_FORMAT   : 0x8D44,\n    RENDERBUFFER_RED_SIZE          : 0x8D50,\n    RENDERBUFFER_GREEN_SIZE        : 0x8D51,\n    RENDERBUFFER_BLUE_SIZE         : 0x8D52,\n    RENDERBUFFER_ALPHA_SIZE        : 0x8D53,\n    RENDERBUFFER_DEPTH_SIZE        : 0x8D54,\n    RENDERBUFFER_STENCIL_SIZE      : 0x8D55,\n\n    FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE           : 0x8CD0,\n    FRAMEBUFFER_ATTACHMENT_OBJECT_NAME           : 0x8CD1,\n    FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL         : 0x8CD2,\n    FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE : 0x8CD3,\n\n    COLOR_ATTACHMENT0              : 0x8CE0,\n    DEPTH_ATTACHMENT               : 0x8D00,\n    STENCIL_ATTACHMENT             : 0x8D20,\n    DEPTH_STENCIL_ATTACHMENT       : 0x821A,\n\n    NONE                           : 0,\n\n    FRAMEBUFFER_COMPLETE                      : 0x8CD5,\n    FRAMEBUFFER_INCOMPLETE_ATTACHMENT         : 0x8CD6,\n    FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT : 0x8CD7,\n    FRAMEBUFFER_INCOMPLETE_DIMENSIONS         : 0x8CD9,\n    FRAMEBUFFER_UNSUPPORTED                   : 0x8CDD,\n\n    FRAMEBUFFER_BINDING            : 0x8CA6,\n    RENDERBUFFER_BINDING           : 0x8CA7,\n    MAX_RENDERBUFFER_SIZE          : 0x84E8,\n\n    INVALID_FRAMEBUFFER_OPERATION  : 0x0506,\n\n    /* WebGL-specific enums */\n    UNPACK_FLIP_Y_WEBGL            : 0x9240,\n    UNPACK_PREMULTIPLY_ALPHA_WEBGL : 0x9241,\n    CONTEXT_LOST_WEBGL             : 0x9242,\n    UNPACK_COLORSPACE_CONVERSION_WEBGL : 0x9243,\n    BROWSER_DEFAULT_WEBGL          : 0x9244,\n};\n","var supportWebGL = true;\ntry {\n    var canvas = document.createElement('canvas');\n    var gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl');\n    if (!gl) {\n        throw new Error();\n    }\n} catch (e) {\n    supportWebGL = false;\n}\n\nvar vendor = {};\n\n/**\n * If support WebGL\n * @return {boolean}\n */\nvendor.supportWebGL = function () {\n    return supportWebGL;\n};\n\n\nvendor.Int8Array = typeof Int8Array == 'undefined' ? Array : Int8Array;\n\nvendor.Uint8Array = typeof Uint8Array == 'undefined' ? Array : Uint8Array;\n\nvendor.Uint16Array = typeof Uint16Array == 'undefined' ? Array : Uint16Array;\n\nvendor.Uint32Array = typeof Uint32Array == 'undefined' ? Array : Uint32Array;\n\nvendor.Int16Array = typeof Int16Array == 'undefined' ? Array : Int16Array;\n\nvendor.Float32Array = typeof Float32Array == 'undefined' ? Array : Float32Array;\n\nvendor.Float64Array = typeof Float64Array == 'undefined' ? Array : Float64Array;\n\nexport default vendor;\n","import glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\n/**\n * @constructor\n * @alias clay.math.Vector3\n * @param {number} x\n * @param {number} y\n * @param {number} z\n */\nvar Vector3 = function(x, y, z) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n\n    /**\n     * Storage of Vector3, read and write of x, y, z will change the values in array\n     * All methods also operate on the array instead of x, y, z components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector3#\n     */\n    this.array = vec3.fromValues(x, y, z);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector3#\n     */\n    this._dirty = true;\n};\n\nVector3.prototype = {\n\n    constructor : Vector3,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    add: function (b) {\n        vec3.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @return {clay.math.Vector3}\n     */\n    set: function (x, y, z) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector3}\n     */\n    setArray: function (arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector3\n     * @return {clay.math.Vector3}\n     */\n    clone: function () {\n        return new Vector3(this.x, this.y, this.z);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    copy: function (b) {\n        vec3.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Cross product of self and b, written to a Vector3 out\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    cross: function (a, b) {\n        vec3.cross(this.array, a.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    dist: function (b) {\n        return vec3.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    distance: function (b) {\n        return vec3.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    div: function (b) {\n        vec3.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    divide: function (b) {\n        vec3.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    dot: function (b) {\n        return vec3.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function () {\n        return vec3.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function () {\n        return vec3.length(this.array);\n    },\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @param  {number}  t\n     * @return {clay.math.Vector3}\n     */\n    lerp: function (a, b, t) {\n        vec3.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    min: function (b) {\n        vec3.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    max: function (b) {\n        vec3.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    mul: function (b) {\n        vec3.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    multiply: function (b) {\n        vec3.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector3}\n     */\n    negate: function () {\n        vec3.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector3}\n     */\n    normalize: function () {\n        vec3.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y, z components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector3}\n     */\n    random: function (scale) {\n        vec3.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector3}\n     */\n    scale: function (s) {\n        vec3.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector3} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector3}\n     */\n    scaleAndAdd: function (b, s) {\n        vec3.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    sqrDist: function (b) {\n        return vec3.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    squaredDistance: function (b) {\n        return vec3.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function () {\n        return vec3.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function () {\n        return vec3.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    sub: function (b) {\n        vec3.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    subtract: function (b) {\n        vec3.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix3 m\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Vector3}\n     */\n    transformMat3: function (m) {\n        vec3.transformMat3(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector3}\n     */\n    transformMat4: function (m) {\n        vec3.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Transform self with a Quaternion q\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Vector3}\n     */\n    transformQuat: function (q) {\n        vec3.transformQuat(this.array, this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Trasnform self into projection space with m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector3}\n     */\n    applyProjection: function (m) {\n        var v = this.array;\n        m = m.array;\n\n        // Perspective projection\n        if (m[15] === 0) {\n            var w = -1 / v[2];\n            v[0] = m[0] * v[0] * w;\n            v[1] = m[5] * v[1] * w;\n            v[2] = (m[10] * v[2] + m[14]) * w;\n        }\n        else {\n            v[0] = m[0] * v[0] + m[12];\n            v[1] = m[5] * v[1] + m[13];\n            v[2] = m[10] * v[2] + m[14];\n        }\n        this._dirty = true;\n\n        return this;\n    },\n\n    eulerFromQuat: function(q, order) {\n        Vector3.eulerFromQuat(this, q, order);\n    },\n\n    eulerFromMat3: function (m, order) {\n        Vector3.eulerFromMat3(this, m, order);\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Vector3.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.add = function(out, a, b) {\n    vec3.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {number}  x\n * @param  {number}  y\n * @param  {number}  z\n * @return {clay.math.Vector3}\n */\nVector3.set = function(out, x, y, z) {\n    vec3.set(out.array, x, y, z);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.copy = function(out, b) {\n    vec3.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.cross = function(out, a, b) {\n    vec3.cross(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.dist = function(a, b) {\n    return vec3.distance(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.distance = Vector3.dist;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.div = function(out, a, b) {\n    vec3.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.divide = Vector3.div;\n\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.dot = function(a, b) {\n    return vec3.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.len = function(b) {\n    return vec3.length(b.array);\n};\n\n// Vector3.length = Vector3.len;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @param  {number}  t\n * @return {clay.math.Vector3}\n */\nVector3.lerp = function(out, a, b, t) {\n    vec3.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.min = function(out, a, b) {\n    vec3.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.max = function(out, a, b) {\n    vec3.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.mul = function(out, a, b) {\n    vec3.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.multiply = Vector3.mul;\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @return {clay.math.Vector3}\n */\nVector3.negate = function(out, a) {\n    vec3.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @return {clay.math.Vector3}\n */\nVector3.normalize = function(out, a) {\n    vec3.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.random = function(out, scale) {\n    vec3.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.scale = function(out, a, scale) {\n    vec3.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.scaleAndAdd = function(out, a, b, scale) {\n    vec3.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.sqrDist = function(a, b) {\n    return vec3.sqrDist(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.squaredDistance = Vector3.sqrDist;\n/**\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.sqrLen = function(a) {\n    return vec3.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.squaredLength = Vector3.sqrLen;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.sub = function(out, a, b) {\n    vec3.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.subtract = Vector3.sub;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {Matrix3} m\n * @return {clay.math.Vector3}\n */\nVector3.transformMat3 = function(out, a, m) {\n    vec3.transformMat3(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector3}\n */\nVector3.transformMat4 = function(out, a, m) {\n    vec3.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Vector3}\n */\nVector3.transformQuat = function(out, a, q) {\n    vec3.transformQuat(out.array, a.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\nfunction clamp(val, min, max) {\n    return val < min ? min : (val > max ? max : val);\n}\nvar atan2 = Math.atan2;\nvar asin = Math.asin;\nvar abs = Math.abs;\n/**\n * Convert quaternion to euler angle\n * Quaternion must be normalized\n * From three.js\n */\nVector3.eulerFromQuat = function (out, q, order) {\n    out._dirty = true;\n    q = q.array;\n\n    var target = out.array;\n    var x = q[0], y = q[1], z = q[2], w = q[3];\n    var x2 = x * x;\n    var y2 = y * y;\n    var z2 = z * z;\n    var w2 = w * w;\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    switch (order) {\n        case 'XYZ':\n            target[0] = atan2(2 * (x * w - y * z), (w2 - x2 - y2 + z2));\n            target[1] = asin(clamp(2 * (x * z + y * w), - 1, 1));\n            target[2] = atan2(2 * (z * w - x * y), (w2 + x2 - y2 - z2));\n            break;\n        case 'YXZ':\n            target[0] = asin(clamp(2 * (x * w - y * z), - 1, 1));\n            target[1] = atan2(2 * (x * z + y * w), (w2 - x2 - y2 + z2));\n            target[2] = atan2(2 * (x * y + z * w), (w2 - x2 + y2 - z2));\n            break;\n        case 'ZXY':\n            target[0] = asin(clamp(2 * (x * w + y * z), - 1, 1));\n            target[1] = atan2(2 * (y * w - z * x), (w2 - x2 - y2 + z2));\n            target[2] = atan2(2 * (z * w - x * y), (w2 - x2 + y2 - z2));\n            break;\n        case 'ZYX':\n            target[0] = atan2(2 * (x * w + z * y), (w2 - x2 - y2 + z2));\n            target[1] = asin(clamp(2 * (y * w - x * z), - 1, 1));\n            target[2] = atan2(2 * (x * y + z * w), (w2 + x2 - y2 - z2));\n            break;\n        case 'YZX':\n            target[0] = atan2(2 * (x * w - z * y), (w2 - x2 + y2 - z2));\n            target[1] = atan2(2 * (y * w - x * z), (w2 + x2 - y2 - z2));\n            target[2] = asin(clamp(2 * (x * y + z * w), - 1, 1));\n            break;\n        case 'XZY':\n            target[0] = atan2(2 * (x * w + y * z), (w2 - x2 + y2 - z2));\n            target[1] = atan2(2 * (x * z + y * w), (w2 + x2 - y2 - z2));\n            target[2] = asin(clamp(2 * (z * w - x * y), - 1, 1));\n            break;\n        default:\n            console.warn('Unkown order: ' + order);\n    }\n    return out;\n};\n\n/**\n * Convert rotation matrix to euler angle\n * from three.js\n */\nVector3.eulerFromMat3 = function (out, m, order) {\n    // assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n    var te = m.array;\n    var m11 = te[0], m12 = te[3], m13 = te[6];\n    var m21 = te[1], m22 = te[4], m23 = te[7];\n    var m31 = te[2], m32 = te[5], m33 = te[8];\n    var target = out.array;\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    switch (order) {\n        case 'XYZ':\n            target[1] = asin(clamp(m13, -1, 1));\n            if (abs(m13) < 0.99999) {\n                target[0] = atan2(-m23, m33);\n                target[2] = atan2(-m12, m11);\n            }\n            else {\n                target[0] = atan2(m32, m22);\n                target[2] = 0;\n            }\n            break;\n        case 'YXZ':\n            target[0] = asin(-clamp(m23, -1, 1));\n            if (abs(m23) < 0.99999) {\n                target[1] = atan2(m13, m33);\n                target[2] = atan2(m21, m22);\n            }\n            else {\n                target[1] = atan2(-m31, m11);\n                target[2] = 0;\n            }\n            break;\n        case 'ZXY':\n            target[0] = asin(clamp(m32, -1, 1));\n            if (abs(m32) < 0.99999) {\n                target[1] = atan2(-m31, m33);\n                target[2] = atan2(-m12, m22);\n            }\n            else {\n                target[1] = 0;\n                target[2] = atan2(m21, m11);\n            }\n            break;\n        case 'ZYX':\n            target[1] = asin(-clamp(m31, -1, 1));\n            if (abs(m31) < 0.99999) {\n                target[0] = atan2(m32, m33);\n                target[2] = atan2(m21, m11);\n            }\n            else {\n                target[0] = 0;\n                target[2] = atan2(-m12, m22);\n            }\n            break;\n        case 'YZX':\n            target[2] = asin(clamp(m21, -1, 1));\n            if (abs(m21) < 0.99999) {\n                target[0] = atan2(-m23, m22);\n                target[1] = atan2(-m31, m11);\n            }\n            else {\n                target[0] = 0;\n                target[1] = atan2(m13, m33);\n            }\n            break;\n        case 'XZY':\n            target[2] = asin(-clamp(m12, -1, 1));\n            if (abs(m12) < 0.99999) {\n                target[0] = atan2(m32, m22);\n                target[1] = atan2(m13, m11);\n            }\n            else {\n                target[0] = atan2(-m23, m33);\n                target[1] = 0;\n            }\n            break;\n        default:\n            console.warn('Unkown order: ' + order);\n    }\n    out._dirty = true;\n\n    return out;\n};\n\n// TODO return new.\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_X = new Vector3(1, 0, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_X = new Vector3(-1, 0, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_Y = new Vector3(0, 1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_Y = new Vector3(0, -1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_Z = new Vector3(0, 0, 1);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_Z = new Vector3(0, 0, -1);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.UP = new Vector3(0, 1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.ZERO = new Vector3(0, 0, 0);\n\nexport default Vector3;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar vec3Copy = vec3.copy;\nvar vec3Set = vec3.set;\n\n/**\n * Axis aligned bounding box\n * @constructor\n * @alias clay.math.BoundingBox\n * @param {clay.math.Vector3} [min]\n * @param {clay.math.Vector3} [max]\n */\nvar BoundingBox = function (min, max) {\n\n    /**\n     * Minimum coords of bounding box\n     * @type {clay.math.Vector3}\n     */\n    this.min = min || new Vector3(Infinity, Infinity, Infinity);\n\n    /**\n     * Maximum coords of bounding box\n     * @type {clay.math.Vector3}\n     */\n    this.max = max || new Vector3(-Infinity, -Infinity, -Infinity);\n};\n\nBoundingBox.prototype = {\n\n    constructor: BoundingBox,\n    /**\n     * Update min and max coords from a vertices array\n     * @param  {array} vertices\n     */\n    updateFromVertices: function (vertices) {\n        if (vertices.length > 0) {\n            var min = this.min;\n            var max = this.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            vec3Copy(minArr, vertices[0]);\n            vec3Copy(maxArr, vertices[0]);\n            for (var i = 1; i < vertices.length; i++) {\n                var vertex = vertices[i];\n\n                if (vertex[0] < minArr[0]) { minArr[0] = vertex[0]; }\n                if (vertex[1] < minArr[1]) { minArr[1] = vertex[1]; }\n                if (vertex[2] < minArr[2]) { minArr[2] = vertex[2]; }\n\n                if (vertex[0] > maxArr[0]) { maxArr[0] = vertex[0]; }\n                if (vertex[1] > maxArr[1]) { maxArr[1] = vertex[1]; }\n                if (vertex[2] > maxArr[2]) { maxArr[2] = vertex[2]; }\n            }\n            min._dirty = true;\n            max._dirty = true;\n        }\n    },\n\n    /**\n     * Union operation with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    union: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3.min(min.array, min.array, bbox.min.array);\n        vec3.max(max.array, max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * Intersection operation with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    intersection: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3.max(min.array, min.array, bbox.min.array);\n        vec3.min(max.array, max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * If intersect with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     * @return {boolean}\n     */\n    intersectBoundingBox: function (bbox) {\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _min2 = bbox.min.array;\n        var _max2 = bbox.max.array;\n\n        return ! (_min[0] > _max2[0] || _min[1] > _max2[1] || _min[2] > _max2[2]\n            || _max[0] < _min2[0] || _max[1] < _min2[1] || _max[2] < _min2[2]);\n    },\n\n    /**\n     * If contain another bounding box entirely\n     * @param  {clay.math.BoundingBox} bbox\n     * @return {boolean}\n     */\n    containBoundingBox: function (bbox) {\n\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _min2 = bbox.min.array;\n        var _max2 = bbox.max.array;\n\n        return _min[0] <= _min2[0] && _min[1] <= _min2[1] && _min[2] <= _min2[2]\n            && _max[0] >= _max2[0] && _max[1] >= _max2[1] && _max[2] >= _max2[2];\n    },\n\n    /**\n     * If contain point entirely\n     * @param  {clay.math.Vector3} point\n     * @return {boolean}\n     */\n    containPoint: function (p) {\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _p = p.array;\n\n        return _min[0] <= _p[0] && _min[1] <= _p[1] && _min[2] <= _p[2]\n            && _max[0] >= _p[0] && _max[1] >= _p[1] && _max[2] >= _p[2];\n    },\n\n    /**\n     * If bounding box is finite\n     */\n    isFinite: function () {\n        var _min = this.min.array;\n        var _max = this.max.array;\n        return isFinite(_min[0]) && isFinite(_min[1]) && isFinite(_min[2])\n            && isFinite(_max[0]) && isFinite(_max[1]) && isFinite(_max[2]);\n    },\n\n    /**\n     * Apply an affine transform matrix to the bounding box\n     * @param  {clay.math.Matrix4} matrix\n     */\n    applyTransform: (function () {\n        // http://dev.theomader.com/transform-bounding-boxes/\n        var xa = vec3.create();\n        var xb = vec3.create();\n        var ya = vec3.create();\n        var yb = vec3.create();\n        var za = vec3.create();\n        var zb = vec3.create();\n\n        return function (matrix) {\n            var min = this.min.array;\n            var max = this.max.array;\n\n            var m = matrix.array;\n\n            xa[0] = m[0] * min[0]; xa[1] = m[1] * min[0]; xa[2] = m[2] * min[0];\n            xb[0] = m[0] * max[0]; xb[1] = m[1] * max[0]; xb[2] = m[2] * max[0];\n\n            ya[0] = m[4] * min[1]; ya[1] = m[5] * min[1]; ya[2] = m[6] * min[1];\n            yb[0] = m[4] * max[1]; yb[1] = m[5] * max[1]; yb[2] = m[6] * max[1];\n\n            za[0] = m[8] * min[2]; za[1] = m[9] * min[2]; za[2] = m[10] * min[2];\n            zb[0] = m[8] * max[2]; zb[1] = m[9] * max[2]; zb[2] = m[10] * max[2];\n\n            min[0] = Math.min(xa[0], xb[0]) + Math.min(ya[0], yb[0]) + Math.min(za[0], zb[0]) + m[12];\n            min[1] = Math.min(xa[1], xb[1]) + Math.min(ya[1], yb[1]) + Math.min(za[1], zb[1]) + m[13];\n            min[2] = Math.min(xa[2], xb[2]) + Math.min(ya[2], yb[2]) + Math.min(za[2], zb[2]) + m[14];\n\n            max[0] = Math.max(xa[0], xb[0]) + Math.max(ya[0], yb[0]) + Math.max(za[0], zb[0]) + m[12];\n            max[1] = Math.max(xa[1], xb[1]) + Math.max(ya[1], yb[1]) + Math.max(za[1], zb[1]) + m[13];\n            max[2] = Math.max(xa[2], xb[2]) + Math.max(ya[2], yb[2]) + Math.max(za[2], zb[2]) + m[14];\n\n            this.min._dirty = true;\n            this.max._dirty = true;\n\n            return this;\n        };\n    })(),\n\n    /**\n     * Apply a projection matrix to the bounding box\n     * @param  {clay.math.Matrix4} matrix\n     */\n    applyProjection: function (matrix) {\n        var min = this.min.array;\n        var max = this.max.array;\n\n        var m = matrix.array;\n        // min in min z\n        var v10 = min[0];\n        var v11 = min[1];\n        var v12 = min[2];\n        // max in min z\n        var v20 = max[0];\n        var v21 = max[1];\n        var v22 = min[2];\n        // max in max z\n        var v30 = max[0];\n        var v31 = max[1];\n        var v32 = max[2];\n\n        if (m[15] === 1) {  // Orthographic projection\n            min[0] = m[0] * v10 + m[12];\n            min[1] = m[5] * v11 + m[13];\n            max[2] = m[10] * v12 + m[14];\n\n            max[0] = m[0] * v30 + m[12];\n            max[1] = m[5] * v31 + m[13];\n            min[2] = m[10] * v32 + m[14];\n        }\n        else {\n            var w = -1 / v12;\n            min[0] = m[0] * v10 * w;\n            min[1] = m[5] * v11 * w;\n            max[2] = (m[10] * v12 + m[14]) * w;\n\n            w = -1 / v22;\n            max[0] = m[0] * v20 * w;\n            max[1] = m[5] * v21 * w;\n\n            w = -1 / v32;\n            min[2] = (m[10] * v32 + m[14]) * w;\n        }\n        this.min._dirty = true;\n        this.max._dirty = true;\n\n        return this;\n    },\n\n    updateVertices: function () {\n        var vertices = this.vertices;\n        if (!vertices) {\n            // Cube vertices\n            var vertices = [];\n            for (var i = 0; i < 8; i++) {\n                vertices[i] = vec3.fromValues(0, 0, 0);\n            }\n\n            /**\n             * Eight coords of bounding box\n             * @type {Float32Array[]}\n             */\n            this.vertices = vertices;\n        }\n        var min = this.min.array;\n        var max = this.max.array;\n        //--- min z\n        // min x\n        vec3Set(vertices[0], min[0], min[1], min[2]);\n        vec3Set(vertices[1], min[0], max[1], min[2]);\n        // max x\n        vec3Set(vertices[2], max[0], min[1], min[2]);\n        vec3Set(vertices[3], max[0], max[1], min[2]);\n\n        //-- max z\n        vec3Set(vertices[4], min[0], min[1], max[2]);\n        vec3Set(vertices[5], min[0], max[1], max[2]);\n        vec3Set(vertices[6], max[0], min[1], max[2]);\n        vec3Set(vertices[7], max[0], max[1], max[2]);\n\n        return this;\n    },\n    /**\n     * Copy values from another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    copy: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3Copy(min.array, bbox.min.array);\n        vec3Copy(max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new bounding box\n     * @return {clay.math.BoundingBox}\n     */\n    clone: function () {\n        var boundingBox = new BoundingBox();\n        boundingBox.copy(this);\n        return boundingBox;\n    }\n};\n\nexport default BoundingBox;\n","import glMatrix from '../dep/glmatrix';\nimport Vector3 from './Vector3';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar mat3 = glMatrix.mat3;\nvar quat = glMatrix.quat;\n\n/**\n * @constructor\n * @alias clay.math.Matrix4\n */\nvar Matrix4 = function() {\n\n    this._axisX = new Vector3();\n    this._axisY = new Vector3();\n    this._axisZ = new Vector3();\n\n    /**\n     * Storage of Matrix4\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix4#\n     */\n    this.array = mat4.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix4#\n     */\n    this._dirty = true;\n};\n\nMatrix4.prototype = {\n\n    constructor: Matrix4,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix4}\n     */\n    adjoint: function() {\n        mat4.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Matrix4\n     * @return {clay.math.Matrix4}\n     */\n    clone: function() {\n        return (new Matrix4()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    copy: function(a) {\n        mat4.copy(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat4.determinant(this.array);\n    },\n\n    /**\n     * Set upper 3x3 part from quaternion\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Matrix4}\n     */\n    fromQuat: function(q) {\n        mat4.fromQuat(this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from a quaternion rotation and a vector translation\n     * @param  {clay.math.Quaternion} q\n     * @param  {clay.math.Vector3} v\n     * @return {clay.math.Matrix4}\n     */\n    fromRotationTranslation: function(q, v) {\n        mat4.fromRotationTranslation(this.array, q.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from Matrix2d, it is used when converting a 2d shape to 3d space.\n     * In 3d space it is equivalent to ranslate on xy plane and rotate about z axis\n     * @param  {clay.math.Matrix2d} m2d\n     * @return {clay.math.Matrix4}\n     */\n    fromMat2d: function(m2d) {\n        Matrix4.fromMat2d(this, m2d);\n        return this;\n    },\n\n    /**\n     * Set from frustum bounds\n     * @param  {number} left\n     * @param  {number} right\n     * @param  {number} bottom\n     * @param  {number} top\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    frustum: function (left, right, bottom, top, near, far) {\n        mat4.frustum(this.array, left, right, bottom, top, near, far);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix4}\n     */\n    identity: function() {\n        mat4.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix4}\n     */\n    invert: function() {\n        mat4.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set as a matrix with the given eye position, focal point, and up axis\n     * @param  {clay.math.Vector3} eye\n     * @param  {clay.math.Vector3} center\n     * @param  {clay.math.Vector3} up\n     * @return {clay.math.Matrix4}\n     */\n    lookAt: function(eye, center, up) {\n        mat4.lookAt(this.array, eye.array, center.array, up.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    mul: function(b) {\n        mat4.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix4} a\n     * @return {clay.math.Matrix4}\n     */\n    mulLeft: function(a) {\n        mat4.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    multiply: function(b) {\n        mat4.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    multiplyLeft: function(a) {\n        mat4.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set as a orthographic projection matrix\n     * @param  {number} left\n     * @param  {number} right\n     * @param  {number} bottom\n     * @param  {number} top\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    ortho: function(left, right, bottom, top, near, far) {\n        mat4.ortho(this.array, left, right, bottom, top, near, far);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Set as a perspective projection matrix\n     * @param  {number} fovy\n     * @param  {number} aspect\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    perspective: function(fovy, aspect, near, far) {\n        mat4.perspective(this.array, fovy, aspect, near, far);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by rad about axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param  {number}   rad\n     * @param  {clay.math.Vector3} axis\n     * @return {clay.math.Matrix4}\n     */\n    rotate: function(rad, axis) {\n        mat4.rotate(this.array, this.array, rad, axis.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about X axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateX: function(rad) {\n        mat4.rotateX(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Y axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateY: function(rad) {\n        mat4.rotateY(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Z axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateZ: function(rad) {\n        mat4.rotateZ(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * Equal to right-multiply a scale matrix\n     * @param  {clay.math.Vector3}  s\n     * @return {clay.math.Matrix4}\n     */\n    scale: function(v) {\n        mat4.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v.\n     * Equal to right-multiply a translate matrix\n     * @param  {clay.math.Vector3}  v\n     * @return {clay.math.Matrix4}\n     */\n    translate: function(v) {\n        mat4.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function() {\n        mat4.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Decompose a matrix to SRT\n     * @param {clay.math.Vector3} [scale]\n     * @param {clay.math.Quaternion} rotation\n     * @param {clay.math.Vector} position\n     * @see http://msdn.microsoft.com/en-us/library/microsoft.xna.framework.matrix.decompose.aspx\n     */\n    decomposeMatrix: (function() {\n\n        var x = vec3.create();\n        var y = vec3.create();\n        var z = vec3.create();\n\n        var m3 = mat3.create();\n\n        return function(scale, rotation, position) {\n\n            var el = this.array;\n            vec3.set(x, el[0], el[1], el[2]);\n            vec3.set(y, el[4], el[5], el[6]);\n            vec3.set(z, el[8], el[9], el[10]);\n\n            var sx = vec3.length(x);\n            var sy = vec3.length(y);\n            var sz = vec3.length(z);\n\n            // if determine is negative, we need to invert one scale\n            var det = this.determinant();\n            if (det < 0) {\n                sx = -sx;\n            }\n\n            if (scale) {\n                scale.set(sx, sy, sz);\n            }\n\n            position.set(el[12], el[13], el[14]);\n\n            mat3.fromMat4(m3, el);\n            // Not like mat4, mat3 in glmatrix seems to be row-based\n            // Seems fixed in gl-matrix 2.2.2\n            // https://github.com/toji/gl-matrix/issues/114\n            // mat3.transpose(m3, m3);\n\n            m3[0] /= sx;\n            m3[1] /= sx;\n            m3[2] /= sx;\n\n            m3[3] /= sy;\n            m3[4] /= sy;\n            m3[5] /= sy;\n\n            m3[6] /= sz;\n            m3[7] /= sz;\n            m3[8] /= sz;\n\n            quat.fromMat3(rotation.array, m3);\n            quat.normalize(rotation.array, rotation.array);\n\n            rotation._dirty = true;\n            position._dirty = true;\n        };\n    })(),\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n\nif (defineProperty) {\n    var proto = Matrix4.prototype;\n    /**\n     * Z Axis of local transform\n     * @name z\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            var el = this.array;\n            this._axisZ.set(el[8], el[9], el[10]);\n            return this._axisZ;\n        },\n        set: function (v) {\n            // TODO Here has a problem\n            // If only set an item of vector will not work\n            var el = this.array;\n            v = v.array;\n            el[8] = v[0];\n            el[9] = v[1];\n            el[10] = v[2];\n\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * Y Axis of local transform\n     * @name y\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            var el = this.array;\n            this._axisY.set(el[4], el[5], el[6]);\n            return this._axisY;\n        },\n        set: function (v) {\n            var el = this.array;\n            v = v.array;\n            el[4] = v[0];\n            el[5] = v[1];\n            el[6] = v[2];\n\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * X Axis of local transform\n     * @name x\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            var el = this.array;\n            this._axisX.set(el[0], el[1], el[2]);\n            return this._axisX;\n        },\n        set: function (v) {\n            var el = this.array;\n            v = v.array;\n            el[0] = v[0];\n            el[1] = v[1];\n            el[2] = v[2];\n\n            this._dirty = true;\n        }\n    })\n}\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.adjoint = function(out, a) {\n    mat4.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.copy = function(out, a) {\n    mat4.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} a\n * @return {number}\n */\nMatrix4.determinant = function(a) {\n    return mat4.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @return {clay.math.Matrix4}\n */\nMatrix4.identity = function(out) {\n    mat4.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {number}  left\n * @param  {number}  right\n * @param  {number}  bottom\n * @param  {number}  top\n * @param  {number}  near\n * @param  {number}  far\n * @return {clay.math.Matrix4}\n */\nMatrix4.ortho = function(out, left, right, bottom, top, near, far) {\n    mat4.ortho(out.array, left, right, bottom, top, near, far);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {number}  fovy\n * @param  {number}  aspect\n * @param  {number}  near\n * @param  {number}  far\n * @return {clay.math.Matrix4}\n */\nMatrix4.perspective = function(out, fovy, aspect, near, far) {\n    mat4.perspective(out.array, fovy, aspect, near, far);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Vector3} eye\n * @param  {clay.math.Vector3} center\n * @param  {clay.math.Vector3} up\n * @return {clay.math.Matrix4}\n */\nMatrix4.lookAt = function(out, eye, center, up) {\n    mat4.lookAt(out.array, eye.array, center.array, up.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.invert = function(out, a) {\n    mat4.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Matrix4} b\n * @return {clay.math.Matrix4}\n */\nMatrix4.mul = function(out, a, b) {\n    mat4.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Matrix4} b\n * @return {clay.math.Matrix4}\n */\nMatrix4.multiply = Matrix4.mul;\n\n/**\n * @param  {clay.math.Matrix4}    out\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromQuat = function(out, q) {\n    mat4.fromQuat(out.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4}    out\n * @param  {clay.math.Quaternion} q\n * @param  {clay.math.Vector3}    v\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromRotationTranslation = function(out, q, v) {\n    mat4.fromRotationTranslation(out.array, q.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} m4\n * @param  {clay.math.Matrix2d} m2d\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromMat2d = function(m4, m2d) {\n    m4._dirty = true;\n    var m2d = m2d.array;\n    var m4 = m4.array;\n\n    m4[0] = m2d[0];\n    m4[4] = m2d[2];\n    m4[12] = m2d[4];\n\n    m4[1] = m2d[1];\n    m4[5] = m2d[3];\n    m4[13] = m2d[5];\n\n    return m4;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @param  {clay.math.Vector3} axis\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotate = function(out, a, rad, axis) {\n    mat4.rotate(out.array, a.array, rad, axis.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateX = function(out, a, rad) {\n    mat4.rotateX(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateY = function(out, a, rad) {\n    mat4.rotateY(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateZ = function(out, a, rad) {\n    mat4.rotateZ(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Vector3} v\n * @return {clay.math.Matrix4}\n */\nMatrix4.scale = function(out, a, v) {\n    mat4.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.transpose = function(out, a) {\n    mat4.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Vector3} v\n * @return {clay.math.Matrix4}\n */\nMatrix4.translate = function(out, a, v) {\n    mat4.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix4;\n","var DIRTY_PREFIX = '__dt__';\n\nvar Cache = function () {\n\n    this._contextId = 0;\n\n    this._caches = [];\n\n    this._context = {};\n};\n\nCache.prototype = {\n\n    use: function (contextId, documentSchema) {\n        var caches = this._caches;\n        if (!caches[contextId]) {\n            caches[contextId] = {};\n\n            if (documentSchema) {\n                caches[contextId] = documentSchema();\n            }\n        }\n        this._contextId = contextId;\n\n        this._context = caches[contextId];\n    },\n\n    put: function (key, value) {\n        this._context[key] = value;\n    },\n\n    get: function (key) {\n        return this._context[key];\n    },\n\n    dirty: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        this.put(key, true);\n    },\n\n    dirtyAll: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var caches = this._caches;\n        for (var i = 0; i < caches.length; i++) {\n            if (caches[i]) {\n                caches[i][key] = true;\n            }\n        }\n    },\n\n    fresh: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        this.put(key, false);\n    },\n\n    freshAll: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var caches = this._caches;\n        for (var i = 0; i < caches.length; i++) {\n            if (caches[i]) {\n                caches[i][key] = false;\n            }\n        }\n    },\n\n    isDirty: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var context = this._context;\n        return  !context.hasOwnProperty(key)\n            || context[key] === true;\n    },\n\n    deleteContext: function (contextId) {\n        delete this._caches[contextId];\n        this._context = {};\n    },\n\n    delete: function (key) {\n        delete this._context[key];\n    },\n\n    clearAll: function () {\n        this._caches = {};\n    },\n\n    getContext: function () {\n        return this._context;\n    },\n\n    eachContext : function (cb, context) {\n        var keys = Object.keys(this._caches);\n        keys.forEach(function (key) {\n            cb && cb.call(context, key);\n        });\n    },\n\n    miss: function (key) {\n        return ! this._context.hasOwnProperty(key);\n    }\n};\n\nCache.prototype.constructor = Cache;\n\nexport default Cache;\n","/**\n * Base class for all textures like compressed texture, texture2d, texturecube\n * TODO mapping\n */\nimport Base from './core/Base';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\n\n/**\n * @constructor\n * @alias clay.Texture\n * @extends clay.core.Base\n */\nvar Texture = Base.extend(\n/** @lends clay.Texture# */\n{\n    /**\n     * Texture width, readonly when the texture source is image\n     * @type {number}\n     */\n    width: 512,\n    /**\n     * Texture height, readonly when the texture source is image\n     * @type {number}\n     */\n    height: 512,\n    /**\n     * Texel data type.\n     * Possible values:\n     *  + {@link clay.Texture.UNSIGNED_BYTE}\n     *  + {@link clay.Texture.HALF_FLOAT}\n     *  + {@link clay.Texture.FLOAT}\n     *  + {@link clay.Texture.UNSIGNED_INT_24_8_WEBGL}\n     *  + {@link clay.Texture.UNSIGNED_INT}\n     * @type {number}\n     */\n    type: glenum.UNSIGNED_BYTE,\n    /**\n     * Format of texel data\n     * Possible values:\n     *  + {@link clay.Texture.RGBA}\n     *  + {@link clay.Texture.DEPTH_COMPONENT}\n     *  + {@link clay.Texture.DEPTH_STENCIL}\n     * @type {number}\n     */\n    format: glenum.RGBA,\n    /**\n     * Texture wrap. Default to be REPEAT.\n     * Possible values:\n     *  + {@link clay.Texture.CLAMP_TO_EDGE}\n     *  + {@link clay.Texture.REPEAT}\n     *  + {@link clay.Texture.MIRRORED_REPEAT}\n     * @type {number}\n     */\n    wrapS: glenum.REPEAT,\n    /**\n     * Texture wrap. Default to be REPEAT.\n     * Possible values:\n     *  + {@link clay.Texture.CLAMP_TO_EDGE}\n     *  + {@link clay.Texture.REPEAT}\n     *  + {@link clay.Texture.MIRRORED_REPEAT}\n     * @type {number}\n     */\n    wrapT: glenum.REPEAT,\n    /**\n     * Possible values:\n     *  + {@link clay.Texture.NEAREST}\n     *  + {@link clay.Texture.LINEAR}\n     *  + {@link clay.Texture.NEAREST_MIPMAP_NEAREST}\n     *  + {@link clay.Texture.LINEAR_MIPMAP_NEAREST}\n     *  + {@link clay.Texture.NEAREST_MIPMAP_LINEAR}\n     *  + {@link clay.Texture.LINEAR_MIPMAP_LINEAR}\n     * @type {number}\n     */\n    minFilter: glenum.LINEAR_MIPMAP_LINEAR,\n    /**\n     * Possible values:\n     *  + {@link clay.Texture.NEAREST}\n     *  + {@link clay.Texture.LINEAR}\n     * @type {number}\n     */\n    magFilter: glenum.LINEAR,\n    /**\n     * If enable mimap.\n     * @type {boolean}\n     */\n    useMipmap: true,\n\n    /**\n     * Anisotropic filtering, enabled if value is larger than 1\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/EXT_texture_filter_anisotropic\n     * @type {number}\n     */\n    anisotropic: 1,\n    // pixelStorei parameters, not available when texture is used as render target\n    // http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml\n    /**\n     * If flip in y axis for given image source\n     * @type {boolean}\n     * @default true\n     */\n    flipY: true,\n    /**\n     * @type {number}\n     * @default 4\n     */\n    unpackAlignment: 4,\n    /**\n     * @type {boolean}\n     * @default false\n     */\n    premultiplyAlpha: false,\n\n    /**\n     * Dynamic option for texture like video\n     * @type {boolean}\n     */\n    dynamic: false,\n\n    NPOT: false\n}, function () {\n    this._cache = new Cache();\n},\n/** @lends clay.Texture.prototype */\n{\n\n    getWebGLTexture: function (renderer) {\n        var _gl = renderer.gl;\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n\n        if (cache.miss('webgl_texture')) {\n            // In a new gl context, create new texture and set dirty true\n            cache.put('webgl_texture', _gl.createTexture());\n        }\n        if (this.dynamic) {\n            this.update(renderer);\n        }\n        else if (cache.isDirty()) {\n            this.update(renderer);\n            cache.fresh();\n        }\n\n        return cache.get('webgl_texture');\n    },\n\n    bind: function () {},\n    unbind: function () {},\n\n    /**\n     * Mark texture is dirty and update in the next frame\n     */\n    dirty: function () {\n        if (this._cache) {\n            this._cache.dirtyAll();\n        }\n    },\n\n    update: function (renderer) {},\n\n    // Update the common parameters of texture\n    updateCommon: function (renderer) {\n        var _gl = renderer.gl;\n        _gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, this.flipY);\n        _gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.premultiplyAlpha);\n        _gl.pixelStorei(_gl.UNPACK_ALIGNMENT, this.unpackAlignment);\n\n        // Use of none-power of two texture\n        // http://www.khronos.org/webgl/wiki/WebGL_and_OpenGL_Differences\n        if (this.format === glenum.DEPTH_COMPONENT) {\n            this.useMipmap = false;\n        }\n\n        var sRGBExt = renderer.getGLExtension('EXT_sRGB');\n        // Fallback\n        if (this.format === Texture.SRGB && !sRGBExt) {\n            this.format = Texture.RGB;\n        }\n        if (this.format === Texture.SRGB_ALPHA && !sRGBExt) {\n            this.format = Texture.RGBA;\n        }\n\n        this.NPOT = !this.isPowerOfTwo();\n    },\n\n    getAvailableWrapS: function () {\n        if (this.NPOT) {\n            return glenum.CLAMP_TO_EDGE;\n        }\n        return this.wrapS;\n    },\n    getAvailableWrapT: function () {\n        if (this.NPOT) {\n            return glenum.CLAMP_TO_EDGE;\n        }\n        return this.wrapT;\n    },\n    getAvailableMinFilter: function () {\n        var minFilter = this.minFilter;\n        if (this.NPOT || !this.useMipmap) {\n            if (minFilter == glenum.NEAREST_MIPMAP_NEAREST ||\n                minFilter == glenum.NEAREST_MIPMAP_LINEAR\n            ) {\n                return glenum.NEAREST;\n            }\n            else if (minFilter == glenum.LINEAR_MIPMAP_LINEAR ||\n                minFilter == glenum.LINEAR_MIPMAP_NEAREST\n            ) {\n                return glenum.LINEAR;\n            }\n            else {\n                return minFilter;\n            }\n        }\n        else {\n            return minFilter;\n        }\n    },\n    getAvailableMagFilter: function () {\n        return this.magFilter;\n    },\n\n    nextHighestPowerOfTwo: function (x) {\n        --x;\n        for (var i = 1; i < 32; i <<= 1) {\n            x = x | x >> i;\n        }\n        return x + 1;\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n\n        var webglTexture = cache.get('webgl_texture');\n        if (webglTexture){\n            renderer.gl.deleteTexture(webglTexture);\n        }\n        cache.deleteContext(renderer.__uid__);\n\n    },\n    /**\n     * Test if image of texture is valid and loaded.\n     * @return {boolean}\n     */\n    isRenderable: function () {},\n\n    /**\n     * Test if texture size is power of two\n     * @return {boolean}\n     */\n    isPowerOfTwo: function () {}\n});\n\nObject.defineProperty(Texture.prototype, 'width', {\n    get: function () {\n        return this._width;\n    },\n    set: function (value) {\n        this._width = value;\n    }\n});\nObject.defineProperty(Texture.prototype, 'height', {\n    get: function () {\n        return this._height;\n    },\n    set: function (value) {\n        this._height = value;\n    }\n});\n\n/* DataType */\n\n/**\n * @type {number}\n */\nTexture.BYTE = glenum.BYTE;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_BYTE = glenum.UNSIGNED_BYTE;\n/**\n * @type {number}\n */\nTexture.SHORT = glenum.SHORT;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_SHORT = glenum.UNSIGNED_SHORT;\n/**\n * @type {number}\n */\nTexture.INT = glenum.INT;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_INT = glenum.UNSIGNED_INT;\n/**\n * @type {number}\n */\nTexture.FLOAT = glenum.FLOAT;\n/**\n * @type {number}\n */\nTexture.HALF_FLOAT = 0x8D61;\n\n/**\n * UNSIGNED_INT_24_8_WEBGL for WEBGL_depth_texture extension\n * @type {number}\n */\nTexture.UNSIGNED_INT_24_8_WEBGL = 34042;\n\n/* PixelFormat */\n/**\n * @type {number}\n */\nTexture.DEPTH_COMPONENT = glenum.DEPTH_COMPONENT;\n/**\n * @type {number}\n */\nTexture.DEPTH_STENCIL = glenum.DEPTH_STENCIL;\n/**\n * @type {number}\n */\nTexture.ALPHA = glenum.ALPHA;\n/**\n * @type {number}\n */\nTexture.RGB = glenum.RGB;\n/**\n * @type {number}\n */\nTexture.RGBA = glenum.RGBA;\n/**\n * @type {number}\n */\nTexture.LUMINANCE = glenum.LUMINANCE;\n/**\n * @type {number}\n */\nTexture.LUMINANCE_ALPHA = glenum.LUMINANCE_ALPHA;\n\n/**\n * @see https://www.khronos.org/registry/webgl/extensions/EXT_sRGB/\n * @type {number}\n */\nTexture.SRGB = 0x8C40;\n/**\n * @see https://www.khronos.org/registry/webgl/extensions/EXT_sRGB/\n * @type {number}\n */\nTexture.SRGB_ALPHA = 0x8C42;\n\n/* Compressed Texture */\nTexture.COMPRESSED_RGB_S3TC_DXT1_EXT = 0x83F0;\nTexture.COMPRESSED_RGBA_S3TC_DXT1_EXT = 0x83F1;\nTexture.COMPRESSED_RGBA_S3TC_DXT3_EXT = 0x83F2;\nTexture.COMPRESSED_RGBA_S3TC_DXT5_EXT = 0x83F3;\n\n/* TextureMagFilter */\n/**\n * @type {number}\n */\nTexture.NEAREST = glenum.NEAREST;\n/**\n * @type {number}\n */\nTexture.LINEAR = glenum.LINEAR;\n\n/* TextureMinFilter */\n/**\n * @type {number}\n */\nTexture.NEAREST_MIPMAP_NEAREST = glenum.NEAREST_MIPMAP_NEAREST;\n/**\n * @type {number}\n */\nTexture.LINEAR_MIPMAP_NEAREST = glenum.LINEAR_MIPMAP_NEAREST;\n/**\n * @type {number}\n */\nTexture.NEAREST_MIPMAP_LINEAR = glenum.NEAREST_MIPMAP_LINEAR;\n/**\n * @type {number}\n */\nTexture.LINEAR_MIPMAP_LINEAR = glenum.LINEAR_MIPMAP_LINEAR;\n\n/* TextureWrapMode */\n/**\n * @type {number}\n */\nTexture.REPEAT = glenum.REPEAT;\n/**\n * @type {number}\n */\nTexture.CLAMP_TO_EDGE = glenum.CLAMP_TO_EDGE;\n/**\n * @type {number}\n */\nTexture.MIRRORED_REPEAT = glenum.MIRRORED_REPEAT;\n\n\nexport default Texture;\n","/**\n * Simple double linked list. Compared with array, it has O(1) remove operation.\n * @constructor\n * @alias clay.core.LinkedList\n */\nvar LinkedList = function () {\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.head = null;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.tail = null;\n\n    this._length = 0;\n};\n\n/**\n * Insert a new value at the tail\n * @param  {} val\n * @return {clay.core.LinkedList.Entry}\n */\nLinkedList.prototype.insert = function (val) {\n    var entry = new LinkedList.Entry(val);\n    this.insertEntry(entry);\n    return entry;\n};\n\n/**\n * Insert a new value at idx\n * @param {number} idx\n * @param  {} val\n * @return {clay.core.LinkedList.Entry}\n */\nLinkedList.prototype.insertAt = function (idx, val) {\n    if (idx < 0) {\n        return;\n    }\n    var next = this.head;\n    var cursor = 0;\n    while (next && cursor != idx) {\n        next = next.next;\n        cursor++;\n    }\n    if (next) {\n        var entry = new LinkedList.Entry(val);\n        var prev = next.prev;\n        if (!prev) { //next is head\n            this.head = entry;\n        }\n        else {\n            prev.next = entry;\n            entry.prev = prev;\n        }\n        entry.next = next;\n        next.prev = entry;\n    }\n    else {\n        this.insert(val);\n    }\n};\n\nLinkedList.prototype.insertBeforeEntry = function (val, next) {\n    var entry = new LinkedList.Entry(val);\n    var prev = next.prev;\n    if (!prev) { //next is head\n        this.head = entry;\n    }\n    else {\n        prev.next = entry;\n        entry.prev = prev;\n    }\n    entry.next = next;\n    next.prev = entry;\n\n    this._length++;\n};\n\n/**\n * Insert an entry at the tail\n * @param  {clay.core.LinkedList.Entry} entry\n */\nLinkedList.prototype.insertEntry = function (entry) {\n    if (!this.head) {\n        this.head = this.tail = entry;\n    }\n    else {\n        this.tail.next = entry;\n        entry.prev = this.tail;\n        this.tail = entry;\n    }\n    this._length++;\n};\n\n/**\n * Remove entry.\n * @param  {clay.core.LinkedList.Entry} entry\n */\nLinkedList.prototype.remove = function (entry) {\n    var prev = entry.prev;\n    var next = entry.next;\n    if (prev) {\n        prev.next = next;\n    }\n    else {\n        // Is head\n        this.head = next;\n    }\n    if (next) {\n        next.prev = prev;\n    }\n    else {\n        // Is tail\n        this.tail = prev;\n    }\n    entry.next = entry.prev = null;\n    this._length--;\n};\n\n/**\n * Remove entry at index.\n * @param  {number} idx\n * @return {}\n */\nLinkedList.prototype.removeAt = function (idx) {\n    if (idx < 0) {\n        return;\n    }\n    var curr = this.head;\n    var cursor = 0;\n    while (curr && cursor != idx) {\n        curr = curr.next;\n        cursor++;\n    }\n    if (curr) {\n        this.remove(curr);\n        return curr.value;\n    }\n};\n/**\n * Get head value\n * @return {}\n */\nLinkedList.prototype.getHead = function () {\n    if (this.head) {\n        return this.head.value;\n    }\n};\n/**\n * Get tail value\n * @return {}\n */\nLinkedList.prototype.getTail = function () {\n    if (this.tail) {\n        return this.tail.value;\n    }\n};\n/**\n * Get value at idx\n * @param {number} idx\n * @return {}\n */\nLinkedList.prototype.getAt = function (idx) {\n    if (idx < 0) {\n        return;\n    }\n    var curr = this.head;\n    var cursor = 0;\n    while (curr && cursor != idx) {\n        curr = curr.next;\n        cursor++;\n    }\n    return curr.value;\n};\n\n/**\n * @param  {} value\n * @return {number}\n */\nLinkedList.prototype.indexOf = function (value) {\n    var curr = this.head;\n    var cursor = 0;\n    while (curr) {\n        if (curr.value === value) {\n            return cursor;\n        }\n        curr = curr.next;\n        cursor++;\n    }\n};\n\n/**\n * @return {number}\n */\nLinkedList.prototype.length = function () {\n    return this._length;\n};\n\n/**\n * If list is empty\n */\nLinkedList.prototype.isEmpty = function () {\n    return this._length === 0;\n};\n\n/**\n * @param  {Function} cb\n * @param  {} context\n */\nLinkedList.prototype.forEach = function (cb, context) {\n    var curr = this.head;\n    var idx = 0;\n    var haveContext = typeof(context) != 'undefined';\n    while (curr) {\n        if (haveContext) {\n            cb.call(context, curr.value, idx);\n        }\n        else {\n            cb(curr.value, idx);\n        }\n        curr = curr.next;\n        idx++;\n    }\n};\n\n/**\n * Clear the list\n */\nLinkedList.prototype.clear = function () {\n    this.tail = this.head = null;\n    this._length = 0;\n};\n\n/**\n * @constructor\n * @param {} val\n */\nLinkedList.Entry = function (val) {\n    /**\n     * @type {}\n     */\n    this.value = val;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.next = null;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.prev = null;\n};\n\nexport default LinkedList;\n","import LinkedList from './LinkedList';\n\n/**\n * LRU Cache\n * @constructor\n * @alias clay.core.LRU\n */\nvar LRU = function(maxSize) {\n\n    this._list = new LinkedList();\n\n    this._map = {};\n\n    this._maxSize = maxSize || 10;\n};\n\n/**\n * Set cache max size\n * @param {number} size\n */\nLRU.prototype.setMaxSize = function(size) {\n    this._maxSize = size;\n};\n\n/**\n * @param  {string} key\n * @param  {} value\n */\nLRU.prototype.put = function(key, value) {\n    if (typeof(this._map[key]) == 'undefined') {\n        var len = this._list.length();\n        if (len >= this._maxSize && len > 0) {\n            // Remove the least recently used\n            var leastUsedEntry = this._list.head;\n            this._list.remove(leastUsedEntry);\n            delete this._map[leastUsedEntry.key];\n        }\n\n        var entry = this._list.insert(value);\n        entry.key = key;\n        this._map[key] = entry;\n    }\n};\n\n/**\n * @param  {string} key\n * @return {}\n */\nLRU.prototype.get = function(key) {\n    var entry = this._map[key];\n    if (typeof(entry) != 'undefined') {\n        // Put the latest used entry in the tail\n        if (entry !== this._list.tail) {\n            this._list.remove(entry);\n            this._list.insertEntry(entry);\n        }\n\n        return entry.value;\n    }\n};\n\n/**\n * @param {string} key\n */\nLRU.prototype.remove = function(key) {\n    var entry = this._map[key];\n    if (typeof(entry) != 'undefined') {\n        delete this._map[key];\n        this._list.remove(entry);\n    }\n};\n\n/**\n * Clear the cache\n */\nLRU.prototype.clear = function() {\n    this._list.clear();\n    this._map = {};\n};\n\nexport default LRU;\n","import LRU from '../core/LRU';\n\nvar colorUtil = {};\n\nvar kCSSColorTable = {\n    'transparent': [0,0,0,0], 'aliceblue': [240,248,255,1],\n    'antiquewhite': [250,235,215,1], 'aqua': [0,255,255,1],\n    'aquamarine': [127,255,212,1], 'azure': [240,255,255,1],\n    'beige': [245,245,220,1], 'bisque': [255,228,196,1],\n    'black': [0,0,0,1], 'blanchedalmond': [255,235,205,1],\n    'blue': [0,0,255,1], 'blueviolet': [138,43,226,1],\n    'brown': [165,42,42,1], 'burlywood': [222,184,135,1],\n    'cadetblue': [95,158,160,1], 'chartreuse': [127,255,0,1],\n    'chocolate': [210,105,30,1], 'coral': [255,127,80,1],\n    'cornflowerblue': [100,149,237,1], 'cornsilk': [255,248,220,1],\n    'crimson': [220,20,60,1], 'cyan': [0,255,255,1],\n    'darkblue': [0,0,139,1], 'darkcyan': [0,139,139,1],\n    'darkgoldenrod': [184,134,11,1], 'darkgray': [169,169,169,1],\n    'darkgreen': [0,100,0,1], 'darkgrey': [169,169,169,1],\n    'darkkhaki': [189,183,107,1], 'darkmagenta': [139,0,139,1],\n    'darkolivegreen': [85,107,47,1], 'darkorange': [255,140,0,1],\n    'darkorchid': [153,50,204,1], 'darkred': [139,0,0,1],\n    'darksalmon': [233,150,122,1], 'darkseagreen': [143,188,143,1],\n    'darkslateblue': [72,61,139,1], 'darkslategray': [47,79,79,1],\n    'darkslategrey': [47,79,79,1], 'darkturquoise': [0,206,209,1],\n    'darkviolet': [148,0,211,1], 'deeppink': [255,20,147,1],\n    'deepskyblue': [0,191,255,1], 'dimgray': [105,105,105,1],\n    'dimgrey': [105,105,105,1], 'dodgerblue': [30,144,255,1],\n    'firebrick': [178,34,34,1], 'floralwhite': [255,250,240,1],\n    'forestgreen': [34,139,34,1], 'fuchsia': [255,0,255,1],\n    'gainsboro': [220,220,220,1], 'ghostwhite': [248,248,255,1],\n    'gold': [255,215,0,1], 'goldenrod': [218,165,32,1],\n    'gray': [128,128,128,1], 'green': [0,128,0,1],\n    'greenyellow': [173,255,47,1], 'grey': [128,128,128,1],\n    'honeydew': [240,255,240,1], 'hotpink': [255,105,180,1],\n    'indianred': [205,92,92,1], 'indigo': [75,0,130,1],\n    'ivory': [255,255,240,1], 'khaki': [240,230,140,1],\n    'lavender': [230,230,250,1], 'lavenderblush': [255,240,245,1],\n    'lawngreen': [124,252,0,1], 'lemonchiffon': [255,250,205,1],\n    'lightblue': [173,216,230,1], 'lightcoral': [240,128,128,1],\n    'lightcyan': [224,255,255,1], 'lightgoldenrodyellow': [250,250,210,1],\n    'lightgray': [211,211,211,1], 'lightgreen': [144,238,144,1],\n    'lightgrey': [211,211,211,1], 'lightpink': [255,182,193,1],\n    'lightsalmon': [255,160,122,1], 'lightseagreen': [32,178,170,1],\n    'lightskyblue': [135,206,250,1], 'lightslategray': [119,136,153,1],\n    'lightslategrey': [119,136,153,1], 'lightsteelblue': [176,196,222,1],\n    'lightyellow': [255,255,224,1], 'lime': [0,255,0,1],\n    'limegreen': [50,205,50,1], 'linen': [250,240,230,1],\n    'magenta': [255,0,255,1], 'maroon': [128,0,0,1],\n    'mediumaquamarine': [102,205,170,1], 'mediumblue': [0,0,205,1],\n    'mediumorchid': [186,85,211,1], 'mediumpurple': [147,112,219,1],\n    'mediumseagreen': [60,179,113,1], 'mediumslateblue': [123,104,238,1],\n    'mediumspringgreen': [0,250,154,1], 'mediumturquoise': [72,209,204,1],\n    'mediumvioletred': [199,21,133,1], 'midnightblue': [25,25,112,1],\n    'mintcream': [245,255,250,1], 'mistyrose': [255,228,225,1],\n    'moccasin': [255,228,181,1], 'navajowhite': [255,222,173,1],\n    'navy': [0,0,128,1], 'oldlace': [253,245,230,1],\n    'olive': [128,128,0,1], 'olivedrab': [107,142,35,1],\n    'orange': [255,165,0,1], 'orangered': [255,69,0,1],\n    'orchid': [218,112,214,1], 'palegoldenrod': [238,232,170,1],\n    'palegreen': [152,251,152,1], 'paleturquoise': [175,238,238,1],\n    'palevioletred': [219,112,147,1], 'papayawhip': [255,239,213,1],\n    'peachpuff': [255,218,185,1], 'peru': [205,133,63,1],\n    'pink': [255,192,203,1], 'plum': [221,160,221,1],\n    'powderblue': [176,224,230,1], 'purple': [128,0,128,1],\n    'red': [255,0,0,1], 'rosybrown': [188,143,143,1],\n    'royalblue': [65,105,225,1], 'saddlebrown': [139,69,19,1],\n    'salmon': [250,128,114,1], 'sandybrown': [244,164,96,1],\n    'seagreen': [46,139,87,1], 'seashell': [255,245,238,1],\n    'sienna': [160,82,45,1], 'silver': [192,192,192,1],\n    'skyblue': [135,206,235,1], 'slateblue': [106,90,205,1],\n    'slategray': [112,128,144,1], 'slategrey': [112,128,144,1],\n    'snow': [255,250,250,1], 'springgreen': [0,255,127,1],\n    'steelblue': [70,130,180,1], 'tan': [210,180,140,1],\n    'teal': [0,128,128,1], 'thistle': [216,191,216,1],\n    'tomato': [255,99,71,1], 'turquoise': [64,224,208,1],\n    'violet': [238,130,238,1], 'wheat': [245,222,179,1],\n    'white': [255,255,255,1], 'whitesmoke': [245,245,245,1],\n    'yellow': [255,255,0,1], 'yellowgreen': [154,205,50,1]\n};\n\nfunction clampCssByte(i) {  // Clamp to integer 0 .. 255.\n    i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n    return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clampCssAngle(i) {  // Clamp to integer 0 .. 360.\n    i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n    return i < 0 ? 0 : i > 360 ? 360 : i;\n}\n\nfunction clampCssFloat(f) {  // Clamp to float 0.0 .. 1.0.\n    return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parseCssInt(str) {  // int or percentage.\n    if (str.length && str.charAt(str.length - 1) === '%') {\n        return clampCssByte(parseFloat(str) / 100 * 255);\n    }\n    return clampCssByte(parseInt(str, 10));\n}\n\nfunction parseCssFloat(str) {  // float or percentage.\n    if (str.length && str.charAt(str.length - 1) === '%') {\n        return clampCssFloat(parseFloat(str) / 100);\n    }\n    return clampCssFloat(parseFloat(str));\n}\n\nfunction cssHueToRgb(m1, m2, h) {\n    if (h < 0) {\n        h += 1;\n    }\n    else if (h > 1) {\n        h -= 1;\n    }\n\n    if (h * 6 < 1) {\n        return m1 + (m2 - m1) * h * 6;\n    }\n    if (h * 2 < 1) {\n        return m2;\n    }\n    if (h * 3 < 2) {\n        return m1 + (m2 - m1) * (2/3 - h) * 6;\n    }\n    return m1;\n}\n\nfunction lerpNumber(a, b, p) {\n    return a + (b - a) * p;\n}\n\nfunction setRgba(out, r, g, b, a) {\n    out[0] = r; out[1] = g; out[2] = b; out[3] = a;\n    return out;\n}\nfunction copyRgba(out, a) {\n    out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; out[3] = a[3];\n    return out;\n}\n\nvar colorCache = new LRU(20);\nvar lastRemovedArr = null;\n\nfunction putToCache(colorStr, rgbaArr) {\n    // Reuse removed array\n    if (lastRemovedArr) {\n        copyRgba(lastRemovedArr, rgbaArr);\n    }\n    lastRemovedArr = colorCache.put(colorStr, lastRemovedArr || (rgbaArr.slice()));\n}\n\n/**\n * @param {string} colorStr\n * @param {Array.<number>} out\n * @return {Array.<number>}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.parse = function (colorStr, rgbaArr) {\n    if (!colorStr) {\n        return;\n    }\n    rgbaArr = rgbaArr || [];\n\n    var cached = colorCache.get(colorStr);\n    if (cached) {\n        return copyRgba(rgbaArr, cached);\n    }\n\n    // colorStr may be not string\n    colorStr = colorStr + '';\n    // Remove all whitespace, not compliant, but should just be more accepting.\n    var str = colorStr.replace(/ /g, '').toLowerCase();\n\n    // Color keywords (and transparent) lookup.\n    if (str in kCSSColorTable) {\n        copyRgba(rgbaArr, kCSSColorTable[str]);\n        putToCache(colorStr, rgbaArr);\n        return rgbaArr;\n    }\n\n    // #abc and #abc123 syntax.\n    if (str.charAt(0) === '#') {\n        if (str.length === 4) {\n            var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n            if (!(iv >= 0 && iv <= 0xfff)) {\n                setRgba(rgbaArr, 0, 0, 0, 1);\n                return;  // Covers NaN.\n            }\n            setRgba(rgbaArr,\n                ((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n                (iv & 0xf0) | ((iv & 0xf0) >> 4),\n                (iv & 0xf) | ((iv & 0xf) << 4),\n                1\n            );\n            putToCache(colorStr, rgbaArr);\n            return rgbaArr;\n        }\n        else if (str.length === 7) {\n            var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n            if (!(iv >= 0 && iv <= 0xffffff)) {\n                setRgba(rgbaArr, 0, 0, 0, 1);\n                return;  // Covers NaN.\n            }\n            setRgba(rgbaArr,\n                (iv & 0xff0000) >> 16,\n                (iv & 0xff00) >> 8,\n                iv & 0xff,\n                1\n            );\n            putToCache(colorStr, rgbaArr);\n            return rgbaArr;\n        }\n\n        return;\n    }\n    var op = str.indexOf('('), ep = str.indexOf(')');\n    if (op !== -1 && ep + 1 === str.length) {\n        var fname = str.substr(0, op);\n        var params = str.substr(op + 1, ep - (op + 1)).split(',');\n        var alpha = 1;  // To allow case fallthrough.\n        switch (fname) {\n            case 'rgba':\n                if (params.length !== 4) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                alpha = parseCssFloat(params.pop()); // jshint ignore:line\n            // Fall through.\n            case 'rgb':\n                if (params.length !== 3) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                setRgba(rgbaArr,\n                    parseCssInt(params[0]),\n                    parseCssInt(params[1]),\n                    parseCssInt(params[2]),\n                    alpha\n                );\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            case 'hsla':\n                if (params.length !== 4) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                params[3] = parseCssFloat(params[3]);\n                hsla2rgba(params, rgbaArr);\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            case 'hsl':\n                if (params.length !== 3) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                hsla2rgba(params, rgbaArr);\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            default:\n                return;\n        }\n    }\n\n    setRgba(rgbaArr, 0, 0, 0, 1);\n    return;\n};\n\ncolorUtil.parseToFloat = function (colorStr, rgbaArr) {\n    rgbaArr = colorUtil.parse(colorStr, rgbaArr);\n    if (!rgbaArr) {\n        return;\n    }\n    rgbaArr[0] /= 255;\n    rgbaArr[1] /= 255;\n    rgbaArr[2] /= 255;\n    return rgbaArr;\n}\n\n/**\n * @param {Array.<number>} hsla\n * @param {Array.<number>} rgba\n * @return {Array.<number>} rgba\n */\nfunction hsla2rgba(hsla, rgba) {\n    var h = (((parseFloat(hsla[0]) % 360) + 360) % 360) / 360;  // 0 .. 1\n    // NOTE(deanm): According to the CSS spec s/l should only be\n    // percentages, but we don't bother and let float or percentage.\n    var s = parseCssFloat(hsla[1]);\n    var l = parseCssFloat(hsla[2]);\n    var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n    var m1 = l * 2 - m2;\n\n    rgba = rgba || [];\n    setRgba(rgba,\n        clampCssByte(cssHueToRgb(m1, m2, h + 1 / 3) * 255),\n        clampCssByte(cssHueToRgb(m1, m2, h) * 255),\n        clampCssByte(cssHueToRgb(m1, m2, h - 1 / 3) * 255),\n        1\n    );\n\n    if (hsla.length === 4) {\n        rgba[3] = hsla[3];\n    }\n\n    return rgba;\n}\n\n/**\n * @param {Array.<number>} rgba\n * @return {Array.<number>} hsla\n */\nfunction rgba2hsla(rgba) {\n    if (!rgba) {\n        return;\n    }\n\n    // RGB from 0 to 255\n    var R = rgba[0] / 255;\n    var G = rgba[1] / 255;\n    var B = rgba[2] / 255;\n\n    var vMin = Math.min(R, G, B); // Min. value of RGB\n    var vMax = Math.max(R, G, B); // Max. value of RGB\n    var delta = vMax - vMin; // Delta RGB value\n\n    var L = (vMax + vMin) / 2;\n    var H;\n    var S;\n    // HSL results from 0 to 1\n    if (delta === 0) {\n        H = 0;\n        S = 0;\n    }\n    else {\n        if (L < 0.5) {\n            S = delta / (vMax + vMin);\n        }\n        else {\n            S = delta / (2 - vMax - vMin);\n        }\n\n        var deltaR = (((vMax - R) / 6) + (delta / 2)) / delta;\n        var deltaG = (((vMax - G) / 6) + (delta / 2)) / delta;\n        var deltaB = (((vMax - B) / 6) + (delta / 2)) / delta;\n\n        if (R === vMax) {\n            H = deltaB - deltaG;\n        }\n        else if (G === vMax) {\n            H = (1 / 3) + deltaR - deltaB;\n        }\n        else if (B === vMax) {\n            H = (2 / 3) + deltaG - deltaR;\n        }\n\n        if (H < 0) {\n            H += 1;\n        }\n\n        if (H > 1) {\n            H -= 1;\n        }\n    }\n\n    var hsla = [H * 360, S, L];\n\n    if (rgba[3] != null) {\n        hsla.push(rgba[3]);\n    }\n\n    return hsla;\n}\n\n/**\n * @param {string} color\n * @param {number} level\n * @return {string}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.lift = function (color, level) {\n    var colorArr = colorUtil.parse(color);\n    if (colorArr) {\n        for (var i = 0; i < 3; i++) {\n            if (level < 0) {\n                colorArr[i] = colorArr[i] * (1 - level) | 0;\n            }\n            else {\n                colorArr[i] = ((255 - colorArr[i]) * level + colorArr[i]) | 0;\n            }\n        }\n        return colorUtil.stringify(colorArr, colorArr.length === 4 ? 'rgba' : 'rgb');\n    }\n}\n\n/**\n * @param {string} color\n * @return {string}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.toHex = function (color) {\n    var colorArr = colorUtil.parse(color);\n    if (colorArr) {\n        return ((1 << 24) + (colorArr[0] << 16) + (colorArr[1] << 8) + (+colorArr[2])).toString(16).slice(1);\n    }\n}\n\n/**\n * Map value to color. Faster than lerp methods because color is represented by rgba array.\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<Array.<number>>} colors List of rgba color array\n * @param {Array.<number>} [out] Mapped gba color array\n * @return {Array.<number>} will be null/undefined if input illegal.\n */\ncolorUtil.fastLerp = function (normalizedValue, colors, out) {\n    if (!(colors && colors.length)\n        || !(normalizedValue >= 0 && normalizedValue <= 1)\n    ) {\n        return;\n    }\n\n    out = out || [];\n\n    var value = normalizedValue * (colors.length - 1);\n    var leftIndex = Math.floor(value);\n    var rightIndex = Math.ceil(value);\n    var leftColor = colors[leftIndex];\n    var rightColor = colors[rightIndex];\n    var dv = value - leftIndex;\n    out[0] = clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv));\n    out[1] = clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv));\n    out[2] = clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv));\n    out[3] = clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv));\n\n    return out;\n}\n\n/**\n * @deprecated\n */\ncolorUtil.fastMapToColor = colorUtil.fastLerp;\n\n/**\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<string>} colors Color list.\n * @param {boolean=} fullOutput Default false.\n * @return {(string|Object)} Result color. If fullOutput,\n *                           return {color: ..., leftIndex: ..., rightIndex: ..., value: ...},\n * @memberOf module:zrender/util/color\n */\ncolorUtil.lerp = function (normalizedValue, colors, fullOutput) {\n    if (!(colors && colors.length)\n        || !(normalizedValue >= 0 && normalizedValue <= 1)\n    ) {\n        return;\n    }\n\n    var value = normalizedValue * (colors.length - 1);\n    var leftIndex = Math.floor(value);\n    var rightIndex = Math.ceil(value);\n    var leftColor = colorUtil.parse(colors[leftIndex]);\n    var rightColor = colorUtil.parse(colors[rightIndex]);\n    var dv = value - leftIndex;\n\n    var color = colorUtil.stringify(\n        [\n            clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv)),\n            clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv)),\n            clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv)),\n            clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv))\n        ],\n        'rgba'\n    );\n\n    return fullOutput\n        ? {\n            color: color,\n            leftIndex: leftIndex,\n            rightIndex: rightIndex,\n            value: value\n        }\n        : color;\n}\n\n/**\n * @deprecated\n */\ncolorUtil.mapToColor = colorUtil.lerp;\n\n/**\n * @param {string} color\n * @param {number=} h 0 ~ 360, ignore when null.\n * @param {number=} s 0 ~ 1, ignore when null.\n * @param {number=} l 0 ~ 1, ignore when null.\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\ncolorUtil.modifyHSL = function (color, h, s, l) {\n    color = colorUtil.parse(color);\n\n    if (color) {\n        color = rgba2hsla(color);\n        h != null && (color[0] = clampCssAngle(h));\n        s != null && (color[1] = parseCssFloat(s));\n        l != null && (color[2] = parseCssFloat(l));\n\n        return colorUtil.stringify(hsla2rgba(color), 'rgba');\n    }\n}\n\n/**\n * @param {string} color\n * @param {number=} alpha 0 ~ 1\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\ncolorUtil.modifyAlpha = function (color, alpha) {\n    color = colorUtil.parse(color);\n\n    if (color && alpha != null) {\n        color[3] = clampCssFloat(alpha);\n        return colorUtil.stringify(color, 'rgba');\n    }\n}\n\n/**\n * @param {Array.<number>} arrColor like [12,33,44,0.4]\n * @param {string} type 'rgba', 'hsva', ...\n * @return {string} Result color. (If input illegal, return undefined).\n */\ncolorUtil.stringify = function (arrColor, type) {\n    if (!arrColor || !arrColor.length) {\n        return;\n    }\n    var colorStr = arrColor[0] + ',' + arrColor[1] + ',' + arrColor[2];\n    if (type === 'rgba' || type === 'hsva' || type === 'hsla') {\n        colorStr += ',' + arrColor[3];\n    }\n    return type + '(' + colorStr + ')';\n};\n\n\n\nexport default colorUtil;","import Base from './core/Base';\nimport Texture from './Texture';\nimport util from './core/util';\nimport colorUtil from './core/color';\nvar parseColor = colorUtil.parseToFloat;\n\nvar programKeyCache = {};\n\nfunction getDefineCode(defines, lightsNumbers, enabledTextures) {\n    var defineKeys = Object.keys(defines);\n    defineKeys.sort();\n    var defineStr = [];\n    // Custom Defines\n    for (var i = 0; i < defineKeys.length; i++) {\n        var key = defineKeys[i];\n        var value = defines[key];\n        if (value === null) {\n            defineStr.push(key);\n        }\n        else{\n            defineStr.push(key + ' ' + value.toString());\n        }\n    }\n    return defineStr.join('\\n');\n}\n\nfunction getProgramKey(vertexDefines, fragmentDefines, enabledTextures) {\n    enabledTextures.sort();\n    var defineStr = [];\n    for (var i = 0; i < enabledTextures.length; i++) {\n        var symbol = enabledTextures[i];\n        defineStr.push(symbol);\n    }\n    var key = getDefineCode(vertexDefines) + '\\n'\n        + getDefineCode(fragmentDefines) + '\\n'\n        + defineStr.join('\\n');\n\n    if (programKeyCache[key]) {\n        return programKeyCache[key];\n    }\n\n    var id = util.genGUID();\n    programKeyCache[key] = id;\n    return id;\n}\n\n/**\n * @constructor clay.Material\n * @extends clay.core.Base\n */\nvar Material = Base.extend(function () {\n    return /** @lends clay.Material# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * @type {Object}\n         */\n        // uniforms: null,\n\n        /**\n         * @type {clay.Shader}\n         */\n        // shader: null,\n\n        /**\n         * @type {boolean}\n         */\n        depthTest: true,\n\n        /**\n         * @type {boolean}\n         */\n        depthMask: true,\n\n        /**\n         * @type {boolean}\n         */\n        transparent: false,\n        /**\n         * Blend func is a callback function when the material\n         * have custom blending\n         * The gl context will be the only argument passed in tho the\n         * blend function\n         * Detail of blend function in WebGL:\n         * http://www.khronos.org/registry/gles/specs/2.0/es_full_spec_2.0.25.pdf\n         *\n         * Example :\n         * function(_gl) {\n         *  _gl.blendEquation(_gl.FUNC_ADD);\n         *  _gl.blendFunc(_gl.SRC_ALPHA, _gl.ONE_MINUS_SRC_ALPHA);\n         * }\n         */\n        blend: null,\n\n        /**\n         * If update texture status automatically.\n         */\n        autoUpdateTextureStatus: true,\n\n        uniforms: {},\n        vertexDefines: {},\n        fragmentDefines: {},\n        _textureStatus: {},\n\n        // shadowTransparentMap : null\n\n        // PENDING enable the uniform that only used in shader.\n        _enabledUniforms: null,\n    };\n}, function () {\n    if (!this.name) {\n        this.name = 'MATERIAL_' + this.__uid__;\n    }\n\n    if (this.shader) {\n        // Keep status, mainly preset uniforms, vertexDefines and fragmentDefines\n        this.attachShader(this.shader, true);\n    }\n},\n/** @lends clay.Material.prototype */\n{\n    precision: 'highp',\n\n    bind: function(renderer, program, prevMaterial, prevProgram) {\n        var _gl = renderer.gl;\n        // PENDING Same texture in different material take different slot?\n\n        // May use shader of other material if shader code are same\n\n        // var sameProgram = prevProgram === program;\n\n        var currentTextureSlot = program.currentTextureSlot();\n\n        for (var u = 0; u < this._enabledUniforms.length; u++) {\n            var symbol = this._enabledUniforms[u];\n            var uniformValue = this.uniforms[symbol].value;\n            if (uniformValue instanceof Texture) {\n                // Reset slot\n                uniformValue.__slot = -1;\n            }\n            else if (Array.isArray(uniformValue)) {\n                for (var i = 0; i < uniformValue.length; i++) {\n                    if (uniformValue[i] instanceof Texture) {\n                        uniformValue[i].__slot = -1;\n                    }\n                }\n            }\n        }\n        // Set uniforms\n        for (var u = 0; u < this._enabledUniforms.length; u++) {\n            var symbol = this._enabledUniforms[u];\n            var uniform = this.uniforms[symbol];\n            var uniformValue = uniform.value;\n            // PENDING\n            // When binding two materials with the same shader\n            // Many uniforms will be be set twice even if they have the same value\n            // So add a evaluation to see if the uniform is really needed to be set\n            // if (prevMaterial && sameShader) {\n            //     if (prevMaterial.uniforms[symbol].value === uniformValue) {\n            //         continue;\n            //     }\n            // }\n\n            if (uniformValue === null) {\n                // FIXME Assume material with same shader have same order uniforms\n                // Or if different material use same textures,\n                // the slot will be different and still skipped because optimization\n                if (uniform.type === 't') {\n                    var slot = program.currentTextureSlot();\n                    var res = program.setUniform(_gl, '1i', symbol, slot);\n                    if (res) { // Texture is enabled\n                        // Still occupy the slot to make sure same texture in different materials have same slot.\n                        program.takeCurrentTextureSlot(renderer, null);\n                    }\n                }\n                continue;\n            }\n            else if (uniformValue instanceof Texture) {\n                if (uniformValue.__slot < 0) {\n                    var slot = program.currentTextureSlot();\n                    var res = program.setUniform(_gl, '1i', symbol, slot);\n                    if (!res) { // Texture uniform is not enabled\n                        continue;\n                    }\n                    program.takeCurrentTextureSlot(renderer, uniformValue);\n                    uniformValue.__slot = slot;\n                }\n                // Multiple uniform use same texture..\n                else {\n                    program.setUniform(_gl, '1i', symbol, uniformValue.__slot);\n                }\n            }\n            else if (Array.isArray(uniformValue)) {\n                if (uniformValue.length === 0) {\n                    continue;\n                }\n                // Texture Array\n                var exampleValue = uniformValue[0];\n\n                if (exampleValue instanceof Texture) {\n                    if (!program.hasUniform(symbol)) {\n                        continue;\n                    }\n\n                    var arr = [];\n                    for (var i = 0; i < uniformValue.length; i++) {\n                        var texture = uniformValue[i];\n\n                        if (texture.__slot < 0) {\n                            var slot = program.currentTextureSlot();\n                            arr.push(slot);\n                            program.takeCurrentTextureSlot(renderer, texture);\n                            texture.__slot = slot;\n                        }\n                        else {\n                            arr.push(texture.__slot);\n                        }\n                    }\n\n                    program.setUniform(_gl, '1iv', symbol, arr);\n                }\n                else {\n                    program.setUniform(_gl, uniform.type, symbol, uniformValue);\n                }\n            }\n            else{\n                program.setUniform(_gl, uniform.type, symbol, uniformValue);\n            }\n        }\n        // Texture slot maybe used out of material.\n        program.resetTextureSlot(currentTextureSlot);\n    },\n\n    /**\n     * Set material uniform\n     * @example\n     *  mat.setUniform('color', [1, 1, 1, 1]);\n     * @param {string} symbol\n     * @param {number|array|clay.Texture|ArrayBufferView} value\n     */\n    setUniform: function (symbol, value) {\n        if (value === undefined) {\n            console.warn('Uniform value \"' + symbol + '\" is undefined');\n        }\n        var uniform = this.uniforms[symbol];\n        if (uniform) {\n\n            if (typeof value === 'string') {\n                // Try to parse as a color. Invalid color string will return null.\n                value = parseColor(value) || value;\n            }\n\n            uniform.value = value;\n\n            if (this.autoUpdateTextureStatus && uniform.type === 't') {\n                if (value) {\n                    this.enableTexture(symbol);\n                }\n                else {\n                    this.disableTexture(symbol);\n                }\n            }\n        }\n    },\n\n    /**\n     * @param {Object} obj\n     */\n    setUniforms: function(obj) {\n        for (var key in obj) {\n            var val = obj[key];\n            this.setUniform(key, val);\n        }\n    },\n\n    // /**\n    //  * Enable a uniform\n    //  * It only have effect on the uniform exists in shader.\n    //  * @param  {string} symbol\n    //  */\n    // enableUniform: function (symbol) {\n    //     if (this.uniforms[symbol] && !this.isUniformEnabled(symbol)) {\n    //         this._enabledUniforms.push(symbol);\n    //     }\n    // },\n\n    // /**\n    //  * Disable a uniform\n    //  * It will not affect the uniform state in the shader. Because the shader uniforms is parsed from shader code with naive regex. When using micro to disable some uniforms in the shader. It will still try to set these uniforms in each rendering pass. We can disable these uniforms manually if we need this bit performance improvement. Mostly we can simply ignore it.\n    //  * @param  {string} symbol\n    //  */\n    // disableUniform: function (symbol) {\n    //     var idx = this._enabledUniforms.indexOf(symbol);\n    //     if (idx >= 0) {\n    //         this._enabledUniforms.splice(idx, 1);\n    //     }\n    // },\n\n    /**\n     * @param  {string}  symbol\n     * @return {boolean}\n     */\n    isUniformEnabled: function (symbol) {\n        return this._enabledUniforms.indexOf(symbol) >= 0;\n    },\n\n    getEnabledUniforms: function () {\n        return this._enabledUniforms;\n    },\n    getTextureUniforms: function () {\n        return this._textureUniforms;\n    },\n\n    /**\n     * Alias of setUniform and setUniforms\n     * @param {object|string} symbol\n     * @param {number|array|clay.Texture|ArrayBufferView} [value]\n     */\n    set: function (symbol, value) {\n        if (typeof(symbol) === 'object') {\n            for (var key in symbol) {\n                var val = symbol[key];\n                this.setUniform(key, val);\n            }\n        }\n        else {\n            this.setUniform(symbol, value);\n        }\n    },\n    /**\n     * Get uniform value\n     * @param  {string} symbol\n     * @return {number|array|clay.Texture|ArrayBufferView}\n     */\n    get: function (symbol) {\n        var uniform = this.uniforms[symbol];\n        if (uniform) {\n            return uniform.value;\n        }\n    },\n    /**\n     * Attach a shader instance\n     * @param  {clay.Shader} shader\n     * @param  {boolean} keepStatus If try to keep uniform and texture\n     */\n    attachShader: function(shader, keepStatus) {\n        var originalUniforms = this.uniforms;\n\n        // Ignore if uniform can use in shader.\n        this.uniforms = shader.createUniforms();\n        this.shader = shader;\n\n        var uniforms = this.uniforms;\n        this._enabledUniforms = Object.keys(uniforms);\n        // Make sure uniforms are set in same order to avoid texture slot wrong\n        this._enabledUniforms.sort();\n        this._textureUniforms = this._enabledUniforms.filter(function (uniformName) {\n            var type = this.uniforms[uniformName].type;\n            return type === 't' || type === 'tv';\n        }, this);\n\n        var originalVertexDefines = this.vertexDefines;\n        var originalFragmentDefines = this.fragmentDefines;\n\n        this.vertexDefines = util.clone(shader.vertexDefines);\n        this.fragmentDefines = util.clone(shader.fragmentDefines);\n\n        if (keepStatus) {\n            for (var symbol in originalUniforms) {\n                if (uniforms[symbol]) {\n                    uniforms[symbol].value = originalUniforms[symbol].value;\n                }\n            }\n\n            util.defaults(this.vertexDefines, originalVertexDefines);\n            util.defaults(this.fragmentDefines, originalFragmentDefines);\n        }\n\n        var textureStatus = {};\n        for (var key in shader.textures) {\n            textureStatus[key] = {\n                shaderType: shader.textures[key].shaderType,\n                type: shader.textures[key].type,\n                enabled: (keepStatus && this._textureStatus[key]) ? this._textureStatus[key].enabled : false\n            };\n        }\n\n        this._textureStatus = textureStatus;\n\n        this._programKey = '';\n    },\n\n    /**\n     * Clone a new material and keep uniforms, shader will not be cloned\n     * @return {clay.Material}\n     */\n    clone: function () {\n        var material = new this.constructor({\n            name: this.name,\n            shader: this.shader\n        });\n        for (var symbol in this.uniforms) {\n            material.uniforms[symbol].value = this.uniforms[symbol].value;\n        }\n        material.depthTest = this.depthTest;\n        material.depthMask = this.depthMask;\n        material.transparent = this.transparent;\n        material.blend = this.blend;\n\n        material.vertexDefines = util.clone(this.vertexDefines);\n        material.fragmentDefines = util.clone(this.fragmentDefines);\n        material.enableTexture(this.getEnabledTextures());\n        material.precision = this.precision;\n\n        return material;\n    },\n\n    /**\n     * Add a #define macro in shader code\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     * @param  {number} [val]\n     */\n    define: function (shaderType, symbol, val) {\n        var vertexDefines = this.vertexDefines;\n        var fragmentDefines = this.fragmentDefines;\n        if (shaderType !== 'vertex' && shaderType !== 'fragment' && shaderType !== 'both'\n            && arguments.length < 3\n        ) {\n            // shaderType default to be 'both'\n            val = symbol;\n            symbol = shaderType;\n            shaderType = 'both';\n        }\n        val = val != null ? val : null;\n        if (shaderType === 'vertex' || shaderType === 'both') {\n            if (vertexDefines[symbol] !== val) {\n                vertexDefines[symbol] = val;\n                // Mark as dirty\n                this._programKey = '';\n            }\n        }\n        if (shaderType === 'fragment' || shaderType === 'both') {\n            if (fragmentDefines[symbol] !== val) {\n                fragmentDefines[symbol] = val;\n                if (shaderType !== 'both') {\n                    this._programKey = '';\n                }\n            }\n        }\n    },\n\n    /**\n     * Remove a #define macro in shader code\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    undefine: function (shaderType, symbol) {\n        if (shaderType !== 'vertex' && shaderType !== 'fragment' && shaderType !== 'both'\n            && arguments.length < 2\n        ) {\n            // shaderType default to be 'both'\n            symbol = shaderType;\n            shaderType = 'both';\n        }\n        if (shaderType === 'vertex' || shaderType === 'both') {\n            if (this.isDefined('vertex', symbol)) {\n                delete this.vertexDefines[symbol];\n                // Mark as dirty\n                this._programKey = '';\n            }\n        }\n        if (shaderType === 'fragment' || shaderType === 'both') {\n            if (this.isDefined('fragment', symbol)) {\n                delete this.fragmentDefines[symbol];\n                if (shaderType !== 'both') {\n                    this._programKey = '';\n                }\n            }\n        }\n    },\n\n    /**\n     * If macro is defined in shader.\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    isDefined: function (shaderType, symbol) {\n        // PENDING hasOwnProperty ?\n        switch (shaderType) {\n            case 'vertex':\n                return this.vertexDefines[symbol] !== undefined;\n            case 'fragment':\n                return this.fragmentDefines[symbol] !== undefined;\n        }\n    },\n    /**\n     * Get macro value defined in shader.\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    getDefine: function (shaderType, symbol) {\n        switch(shaderType) {\n            case 'vertex':\n                return this.vertexDefines[symbol];\n            case 'fragment':\n                return this.fragmentDefines[symbol];\n        }\n    },\n    /**\n     * Enable a texture, actually it will add a #define macro in the shader code\n     * For example, if texture symbol is diffuseMap, it will add a line `#define DIFFUSEMAP_ENABLED` in the shader code\n     * @param  {string} symbol\n     */\n    enableTexture: function (symbol) {\n        if (Array.isArray(symbol)) {\n            for (var i = 0; i < symbol.length; i++) {\n                this.enableTexture(symbol[i]);\n            }\n            return;\n        }\n\n        var status = this._textureStatus[symbol];\n        if (status) {\n            var isEnabled = status.enabled;\n            if (!isEnabled) {\n                status.enabled = true;\n                this._programKey = '';\n            }\n        }\n    },\n    /**\n     * Enable all textures used in the shader\n     */\n    enableTexturesAll: function () {\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            textureStatus[symbol].enabled = true;\n        }\n\n        this._programKey = '';\n    },\n    /**\n     * Disable a texture, it remove a #define macro in the shader\n     * @param  {string} symbol\n     */\n    disableTexture: function (symbol) {\n        if (Array.isArray(symbol)) {\n            for (var i = 0; i < symbol.length; i++) {\n                this.disableTexture(symbol[i]);\n            }\n            return;\n        }\n\n        var status = this._textureStatus[symbol];\n        if (status) {\n            var isDisabled = ! status.enabled;\n            if (!isDisabled) {\n                status.enabled = false;\n                this._programKey = '';\n            }\n        }\n    },\n    /**\n     * Disable all textures used in the shader\n     */\n    disableTexturesAll: function () {\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            textureStatus[symbol].enabled = false;\n        }\n\n        this._programKey = '';\n    },\n    /**\n     * If texture of given type is enabled.\n     * @param  {string}  symbol\n     * @return {boolean}\n     */\n    isTextureEnabled: function (symbol) {\n        var textureStatus = this._textureStatus;\n        return !!textureStatus[symbol]\n            && textureStatus[symbol].enabled;\n    },\n\n    /**\n     * Get all enabled textures\n     * @return {string[]}\n     */\n    getEnabledTextures: function () {\n        var enabledTextures = [];\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            if (textureStatus[symbol].enabled) {\n                enabledTextures.push(symbol);\n            }\n        }\n        return enabledTextures;\n    },\n\n    /**\n     * Mark defines are updated.\n     */\n    dirtyDefines: function () {\n        this._programKey = '';\n    }\n});\n\nif (Object.defineProperty) {\n    Object.defineProperty(Material.prototype, 'shader', {\n        get: function () {\n            return this._shader || null;\n        },\n\n        set: function (val) {\n            // TODO\n            // console.warn('You need to use attachShader to set the shader.');\n            this._shader = val;\n        }\n    });\n\n    Object.defineProperty(Material.prototype, 'programKey', {\n        get: function () {\n            if (!this._programKey) {\n                this._programKey = getProgramKey(\n                    this.vertexDefines, this.fragmentDefines, this.getEnabledTextures()\n                );\n            }\n            return this._programKey;\n        }\n    });\n}\n\nexport default Material;\n","import vendor from '../core/vendor';\nimport Base from '../core/Base';\n\nvar SHADER_STATE_TO_ENABLE = 1;\nvar SHADER_STATE_KEEP_ENABLE = 2;\nvar SHADER_STATE_PENDING = 3;\n\n// Enable attribute operation is global to all programs\n// Here saved the list of all enabled attribute index\n// http://www.mjbshaw.com/2013/03/webgl-fixing-invalidoperation.html\nvar enabledAttributeList = {};\n\n// some util functions\nfunction addLineNumbers(string) {\n    var chunks = string.split('\\n');\n    for (var i = 0, il = chunks.length; i < il; i ++) {\n        // Chrome reports shader errors on lines\n        // starting counting from 1\n        chunks[i] = (i + 1) + ': ' + chunks[i];\n    }\n    return chunks.join('\\n');\n}\n\n// Return true or error msg if error happened\nfunction checkShaderErrorMsg(_gl, shader, shaderString) {\n    if (!_gl.getShaderParameter(shader, _gl.COMPILE_STATUS)) {\n        return [_gl.getShaderInfoLog(shader), addLineNumbers(shaderString)].join('\\n');\n    }\n}\n\nvar GLProgram = Base.extend({\n\n    uniformSemantics: {},\n    attributes: {}\n\n}, function () {\n    this._locations = {};\n\n    this._textureSlot = 0;\n\n    this._program = null;\n}, {\n\n    bind: function (renderer) {\n        this._textureSlot = 0;\n        renderer.gl.useProgram(this._program);\n    },\n\n    hasUniform: function (symbol) {\n        var location = this._locations[symbol];\n        return location !== null && location !== undefined;\n    },\n\n    useTextureSlot: function (renderer, texture, slot) {\n        if (texture) {\n            renderer.gl.activeTexture(renderer.gl.TEXTURE0 + slot);\n            // Maybe texture is not loaded yet;\n            if (texture.isRenderable()) {\n                texture.bind(renderer);\n            }\n            else {\n                // Bind texture to null\n                texture.unbind(renderer);\n            }\n        }\n    },\n\n    currentTextureSlot: function () {\n        return this._textureSlot;\n    },\n\n    resetTextureSlot: function (slot) {\n        this._textureSlot = slot || 0;\n    },\n\n    takeCurrentTextureSlot: function (renderer, texture) {\n        var textureSlot = this._textureSlot;\n\n        this.useTextureSlot(renderer, texture, textureSlot);\n\n        this._textureSlot++;\n\n        return textureSlot;\n    },\n\n    setUniform: function (_gl, type, symbol, value) {\n        var locationMap = this._locations;\n        var location = locationMap[symbol];\n        // Uniform is not existed in the shader\n        if (location === null || location === undefined) {\n            return false;\n        }\n        switch (type) {\n            case 'm4':\n                // The matrix must be created by glmatrix and can pass it directly.\n                _gl.uniformMatrix4fv(location, false, value);\n                break;\n            case '2i':\n                _gl.uniform2i(location, value[0], value[1]);\n                break;\n            case '2f':\n                _gl.uniform2f(location, value[0], value[1]);\n                break;\n            case '3i':\n                _gl.uniform3i(location, value[0], value[1], value[2]);\n                break;\n            case '3f':\n                _gl.uniform3f(location, value[0], value[1], value[2]);\n                break;\n            case '4i':\n                _gl.uniform4i(location, value[0], value[1], value[2], value[3]);\n                break;\n            case '4f':\n                _gl.uniform4f(location, value[0], value[1], value[2], value[3]);\n                break;\n            case '1i':\n                _gl.uniform1i(location, value);\n                break;\n            case '1f':\n                _gl.uniform1f(location, value);\n                break;\n            case '1fv':\n                _gl.uniform1fv(location, value);\n                break;\n            case '1iv':\n                _gl.uniform1iv(location, value);\n                break;\n            case '2iv':\n                _gl.uniform2iv(location, value);\n                break;\n            case '2fv':\n                _gl.uniform2fv(location, value);\n                break;\n            case '3iv':\n                _gl.uniform3iv(location, value);\n                break;\n            case '3fv':\n                _gl.uniform3fv(location, value);\n                break;\n            case '4iv':\n                _gl.uniform4iv(location, value);\n                break;\n            case '4fv':\n                _gl.uniform4fv(location, value);\n                break;\n            case 'm2':\n            case 'm2v':\n                _gl.uniformMatrix2fv(location, false, value);\n                break;\n            case 'm3':\n            case 'm3v':\n                _gl.uniformMatrix3fv(location, false, value);\n                break;\n            case 'm4v':\n                // Raw value\n                if (Array.isArray(value)) {\n                    var array = new vendor.Float32Array(value.length * 16);\n                    var cursor = 0;\n                    for (var i = 0; i < value.length; i++) {\n                        var item = value[i];\n                        for (var j = 0; j < 16; j++) {\n                            array[cursor++] = item[j];\n                        }\n                    }\n                    _gl.uniformMatrix4fv(location, false, array);\n                }\n                else if (value instanceof vendor.Float32Array) {   // ArrayBufferView\n                    _gl.uniformMatrix4fv(location, false, value);\n                }\n                break;\n        }\n        return true;\n    },\n\n    setUniformOfSemantic: function (_gl, semantic, val) {\n        var semanticInfo = this.uniformSemantics[semantic];\n        if (semanticInfo) {\n            return this.setUniform(_gl, semanticInfo.type, semanticInfo.symbol, val);\n        }\n        return false;\n    },\n\n    // Used for creating VAO\n    // Enable the attributes passed in and disable the rest\n    // Example Usage:\n    // enableAttributes(renderer, [\"position\", \"texcoords\"])\n    enableAttributes: function (renderer, attribList, vao) {\n        var _gl = renderer.gl;\n        var program = this._program;\n\n        var locationMap = this._locations;\n\n        var enabledAttributeListInContext;\n        if (vao) {\n            enabledAttributeListInContext = vao.__enabledAttributeList;\n        }\n        else {\n            enabledAttributeListInContext = enabledAttributeList[renderer.__uid__];\n        }\n        if (!enabledAttributeListInContext) {\n            // In vertex array object context\n            // PENDING Each vao object needs to enable attributes again?\n            if (vao) {\n                enabledAttributeListInContext\n                    = vao.__enabledAttributeList\n                    = [];\n            }\n            else {\n                enabledAttributeListInContext\n                    = enabledAttributeList[renderer.__uid__]\n                    = [];\n            }\n        }\n        var locationList = [];\n        for (var i = 0; i < attribList.length; i++) {\n            var symbol = attribList[i];\n            if (!this.attributes[symbol]) {\n                locationList[i] = -1;\n                continue;\n            }\n            var location = locationMap[symbol];\n            if (location == null) {\n                location = _gl.getAttribLocation(program, symbol);\n                // Attrib location is a number from 0 to ...\n                if (location === -1) {\n                    locationList[i] = -1;\n                    continue;\n                }\n                locationMap[symbol] = location;\n            }\n            locationList[i] = location;\n\n            if (!enabledAttributeListInContext[location]) {\n                enabledAttributeListInContext[location] = SHADER_STATE_TO_ENABLE;\n            }\n            else {\n                enabledAttributeListInContext[location] = SHADER_STATE_KEEP_ENABLE;\n            }\n        }\n\n        for (var i = 0; i < enabledAttributeListInContext.length; i++) {\n            switch(enabledAttributeListInContext[i]){\n                case SHADER_STATE_TO_ENABLE:\n                    _gl.enableVertexAttribArray(i);\n                    enabledAttributeListInContext[i] = SHADER_STATE_PENDING;\n                    break;\n                case SHADER_STATE_KEEP_ENABLE:\n                    enabledAttributeListInContext[i] = SHADER_STATE_PENDING;\n                    break;\n                // Expired\n                case SHADER_STATE_PENDING:\n                    _gl.disableVertexAttribArray(i);\n                    enabledAttributeListInContext[i] = 0;\n                    break;\n            }\n        }\n\n        return locationList;\n    },\n\n    buildProgram: function (_gl, shader, vertexShaderCode, fragmentShaderCode) {\n        var vertexShader = _gl.createShader(_gl.VERTEX_SHADER);\n        var program = _gl.createProgram();\n\n        _gl.shaderSource(vertexShader, vertexShaderCode);\n        _gl.compileShader(vertexShader);\n\n        var fragmentShader = _gl.createShader(_gl.FRAGMENT_SHADER);\n        _gl.shaderSource(fragmentShader, fragmentShaderCode);\n        _gl.compileShader(fragmentShader);\n\n        var msg = checkShaderErrorMsg(_gl, vertexShader, vertexShaderCode);\n        if (msg) {\n            return msg;\n        }\n        msg = checkShaderErrorMsg(_gl, fragmentShader, fragmentShaderCode);\n        if (msg) {\n            return msg;\n        }\n\n        _gl.attachShader(program, vertexShader);\n        _gl.attachShader(program, fragmentShader);\n        // Force the position bind to location 0;\n        if (shader.attributeSemantics['POSITION']) {\n            _gl.bindAttribLocation(program, 0, shader.attributeSemantics['POSITION'].symbol);\n        }\n        else {\n            // Else choose an attribute and bind to location 0;\n            var keys = Object.keys(this.attributes);\n            _gl.bindAttribLocation(program, 0, keys[0]);\n        }\n\n        _gl.linkProgram(program);\n\n        if (!_gl.getProgramParameter(program, _gl.LINK_STATUS)) {\n            return 'Could not link program\\n' + 'VALIDATE_STATUS: ' + _gl.getProgramParameter(program, _gl.VALIDATE_STATUS) + ', gl error [' + _gl.getError() + ']';\n        }\n\n        // Cache uniform locations\n        for (var i = 0; i < shader.uniforms.length; i++) {\n            var uniformSymbol = shader.uniforms[i];\n            this._locations[uniformSymbol] = _gl.getUniformLocation(program, uniformSymbol);\n        }\n\n        _gl.deleteShader(vertexShader);\n        _gl.deleteShader(fragmentShader);\n\n        this._program = program;\n\n        // Save code.\n        this.vertexCode = vertexShaderCode;\n        this.fragmentCode = fragmentShaderCode;\n    }\n});\n\nexport default GLProgram;","import GLProgram from './GLProgram';\n\nvar loopRegex = /for\\s*?\\(int\\s*?_idx_\\s*\\=\\s*([\\w-]+)\\;\\s*_idx_\\s*<\\s*([\\w-]+);\\s*_idx_\\s*\\+\\+\\s*\\)\\s*\\{\\{([\\s\\S]+?)(?=\\}\\})\\}\\}/g;\n\nfunction unrollLoop(shaderStr, defines, lightsNumbers) {\n    // Loop unroll from three.js, https://github.com/mrdoob/three.js/blob/master/src/renderers/webgl/WebGLProgram.js#L175\n    // In some case like shadowMap in loop use 'i' to index value much slower.\n\n    // Loop use _idx_ and increased with _idx_++ will be unrolled\n    // Use {{ }} to match the pair so the if statement will not be affected\n    // Write like following\n    // for (int _idx_ = 0; _idx_ < 4; _idx_++) {{\n    //     vec3 color = texture2D(textures[_idx_], uv).rgb;\n    // }}\n    function replace(match, start, end, snippet) {\n        var unroll = '';\n        // Try to treat as define\n        if (isNaN(start)) {\n            if (start in defines) {\n                start = defines[start];\n            }\n            else {\n                start = lightNumberDefines[start];\n            }\n        }\n        if (isNaN(end)) {\n            if (end in defines) {\n                end = defines[end];\n            }\n            else {\n                end = lightNumberDefines[end];\n            }\n        }\n        // TODO Error checking\n\n        for (var idx = parseInt(start); idx < parseInt(end); idx++) {\n            // PENDING Add scope?\n            unroll += '{'\n                + snippet\n                    .replace(/float\\s*\\(\\s*_idx_\\s*\\)/g, idx.toFixed(1))\n                    .replace(/_idx_/g, idx)\n            + '}';\n        }\n\n        return unroll;\n    }\n\n    var lightNumberDefines = {};\n    for (var lightType in lightsNumbers) {\n        lightNumberDefines[lightType + '_COUNT'] = lightsNumbers[lightType];\n    }\n    return shaderStr.replace(loopRegex, replace);\n}\n\nfunction getDefineCode(defines, lightsNumbers, enabledTextures) {\n    var defineStr = [];\n    if (lightsNumbers) {\n        for (var lightType in lightsNumbers) {\n            var count = lightsNumbers[lightType];\n            if (count > 0) {\n                defineStr.push('#define ' + lightType.toUpperCase() + '_COUNT ' + count);\n            }\n        }\n    }\n    if (enabledTextures) {\n        for (var i = 0; i < enabledTextures.length; i++) {\n            var symbol = enabledTextures[i];\n            defineStr.push('#define ' + symbol.toUpperCase() + '_ENABLED');\n        }\n    }\n    // Custom Defines\n    for (var symbol in defines) {\n        var value = defines[symbol];\n        if (value === null) {\n            defineStr.push('#define ' + symbol);\n        }\n        else{\n            defineStr.push('#define ' + symbol + ' ' + value.toString());\n        }\n    }\n    return defineStr.join('\\n');\n}\n\nfunction getExtensionCode(exts) {\n    // Extension declaration must before all non-preprocessor codes\n    // TODO vertex ? extension enum ?\n    var extensionStr = [];\n    for (var i = 0; i < exts.length; i++) {\n        extensionStr.push('#extension GL_' + exts[i] + ' : enable');\n    }\n    return extensionStr.join('\\n');\n}\n\nfunction getPrecisionCode(precision) {\n    return ['precision', precision, 'float'].join(' ') + ';\\n'\n        + ['precision', precision, 'int'].join(' ') + ';\\n'\n        // depth texture may have precision problem on iOS device.\n        + ['precision', precision, 'sampler2D'].join(' ') + ';\\n';\n}\n\nfunction ProgramManager(renderer) {\n    this._renderer = renderer;\n    this._cache = {};\n}\n\nProgramManager.prototype.getProgram = function (renderable, material, scene) {\n    var cache = this._cache;\n\n    var key = 's' + material.shader.shaderID + 'm' + material.programKey;\n    if (scene) {\n        key += 'se' + scene.getProgramKey(renderable.lightGroup);\n    }\n    if (renderable.isSkinnedMesh()) {\n        key += ',' + renderable.joints.length;\n    }\n    var program = cache[key];\n\n    if (program) {\n        return program;\n    }\n\n    var lightsNumbers = scene ? scene.getLightsNumbers(renderable.lightGroup) : {};\n    var renderer = this._renderer;\n    var _gl = renderer.gl;\n    var enabledTextures = material.getEnabledTextures();\n    var skinDefineCode = '';\n    if (renderable.isSkinnedMesh()) {\n        // TODO Add skinning code?\n        skinDefineCode = '\\n' + getDefineCode({\n            SKINNING: null,\n            JOINT_COUNT: renderable.joints.length\n        }) + '\\n';\n    }\n    // TODO Optimize key generation\n    // VERTEX\n    var vertexDefineStr = skinDefineCode + getDefineCode(material.vertexDefines, lightsNumbers, enabledTextures);\n    // FRAGMENT\n    var fragmentDefineStr = skinDefineCode + getDefineCode(material.fragmentDefines, lightsNumbers, enabledTextures);\n\n    var vertexCode = vertexDefineStr + '\\n' + material.shader.vertex;\n    var fragmentCode = getExtensionCode([\n            // TODO Not hard coded\n            'OES_standard_derivatives',\n            'EXT_shader_texture_lod'\n        ]) + '\\n'\n            + getPrecisionCode(material.precision) + '\\n'\n            + fragmentDefineStr + '\\n' + material.shader.fragment;\n\n    var finalVertexCode = unrollLoop(vertexCode, material.vertexDefines, lightsNumbers);\n    var finalFragmentCode = unrollLoop(fragmentCode, material.fragmentDefines, lightsNumbers);\n\n    var program = new GLProgram();\n    program.uniformSemantics = material.shader.uniformSemantics;\n    program.attributes = material.shader.attributes;\n    var errorMsg = program.buildProgram(_gl, material.shader, finalVertexCode, finalFragmentCode);\n    program.__error = errorMsg;\n\n    cache[key] = program;\n\n    return program;\n};\n\nexport default ProgramManager;","/**\n * Mainly do the parse and compile of shader string\n * Support shader code chunk import and export\n * Support shader semantics\n * http://www.nvidia.com/object/using_sas.html\n * https://github.com/KhronosGroup/collada2json/issues/45\n *\n * TODO: Use etpl or other string template engine\n */\nimport util from './core/util';\nimport vendor from './core/vendor';\nimport glMatrix from './dep/glmatrix';\nvar mat2 = glMatrix.mat2;\nvar mat3 = glMatrix.mat3;\nvar mat4 = glMatrix.mat4;\n\nvar uniformRegex = /uniform\\s+(bool|float|int|vec2|vec3|vec4|ivec2|ivec3|ivec4|mat2|mat3|mat4|sampler2D|samplerCube)\\s+([\\w\\,]+)?(\\[.*?\\])?\\s*(:\\s*([\\S\\s]+?))?;/g;\nvar attributeRegex = /attribute\\s+(float|int|vec2|vec3|vec4)\\s+(\\w*)\\s*(:\\s*(\\w+))?;/g;\nvar defineRegex = /#define\\s+(\\w+)?(\\s+[\\w-.]+)?\\s*;?\\s*\\n/g;\n\nvar uniformTypeMap = {\n    'bool': '1i',\n    'int': '1i',\n    'sampler2D': 't',\n    'samplerCube': 't',\n    'float': '1f',\n    'vec2': '2f',\n    'vec3': '3f',\n    'vec4': '4f',\n    'ivec2': '2i',\n    'ivec3': '3i',\n    'ivec4': '4i',\n    'mat2': 'm2',\n    'mat3': 'm3',\n    'mat4': 'm4'\n};\n\nvar uniformValueConstructor = {\n    'bool': function () {return true;},\n    'int': function () {return 0;},\n    'float': function () {return 0;},\n    'sampler2D': function () {return null;},\n    'samplerCube': function () {return null;},\n\n    'vec2': function () {return [0, 0];},\n    'vec3': function () {return [0, 0, 0];},\n    'vec4': function () {return [0, 0, 0, 0];},\n\n    'ivec2': function () {return [0, 0];},\n    'ivec3': function () {return [0, 0, 0];},\n    'ivec4': function () {return [0, 0, 0, 0];},\n\n    'mat2': function () {return mat2.create();},\n    'mat3': function () {return mat3.create();},\n    'mat4': function () {return mat4.create();},\n\n    'array': function () {return [];}\n};\n\nvar attributeSemantics = [\n    'POSITION',\n    'NORMAL',\n    'BINORMAL',\n    'TANGENT',\n    'TEXCOORD',\n    'TEXCOORD_0',\n    'TEXCOORD_1',\n    'COLOR',\n    // Skinning\n    // https://github.com/KhronosGroup/glTF/blob/master/specification/README.md#semantics\n    'JOINT',\n    'WEIGHT'\n];\nvar uniformSemantics = [\n    'SKIN_MATRIX',\n    // Information about viewport\n    'VIEWPORT_SIZE',\n    'VIEWPORT',\n    'DEVICEPIXELRATIO',\n    // Window size for window relative coordinate\n    // https://www.opengl.org/sdk/docs/man/html/gl_FragCoord.xhtml\n    'WINDOW_SIZE',\n    // Infomation about camera\n    'NEAR',\n    'FAR',\n    // Time\n    'TIME'\n];\nvar matrixSemantics = [\n    'WORLD',\n    'VIEW',\n    'PROJECTION',\n    'WORLDVIEW',\n    'VIEWPROJECTION',\n    'WORLDVIEWPROJECTION',\n    'WORLDINVERSE',\n    'VIEWINVERSE',\n    'PROJECTIONINVERSE',\n    'WORLDVIEWINVERSE',\n    'VIEWPROJECTIONINVERSE',\n    'WORLDVIEWPROJECTIONINVERSE',\n    'WORLDTRANSPOSE',\n    'VIEWTRANSPOSE',\n    'PROJECTIONTRANSPOSE',\n    'WORLDVIEWTRANSPOSE',\n    'VIEWPROJECTIONTRANSPOSE',\n    'WORLDVIEWPROJECTIONTRANSPOSE',\n    'WORLDINVERSETRANSPOSE',\n    'VIEWINVERSETRANSPOSE',\n    'PROJECTIONINVERSETRANSPOSE',\n    'WORLDVIEWINVERSETRANSPOSE',\n    'VIEWPROJECTIONINVERSETRANSPOSE',\n    'WORLDVIEWPROJECTIONINVERSETRANSPOSE'\n];\n\n\nvar shaderIDCache = {};\nvar shaderCodeCache = {};\n\nfunction getShaderID(vertex, fragment) {\n    var key = 'vertex:' + vertex + 'fragment:' + fragment;\n    if (shaderIDCache[key]) {\n        return shaderIDCache[key];\n    }\n    var id = util.genGUID();\n    shaderIDCache[key] = id;\n\n    shaderCodeCache[id] = {\n        vertex: vertex,\n        fragment: fragment\n    };\n\n    return id;\n}\n\n/**\n * @constructor\n * @extends clay.core.Base\n * @alias clay.Shader\n * @example\n * // Create a phong shader\n * var shader = new clay.Shader(\n *      clay.Shader.source('clay.standard.vertex'),\n *      clay.Shader.source('clay.standard.fragment')\n * );\n */\nfunction Shader(vertex, fragment) {\n    // First argument can be { vertex, fragment }\n    if (typeof vertex === 'object') {\n        fragment = vertex.fragment;\n        vertex = vertex.vertex;\n    }\n\n    this._shaderID = getShaderID(vertex, fragment);\n\n    this._vertexCode = Shader.parseImport(vertex);\n    this._fragmentCode = Shader.parseImport(fragment);\n\n    /**\n     * @readOnly\n     */\n    this.attributeSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.matrixSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.uniformSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.matrixSemanticKeys = [];\n    /**\n     * @readOnly\n     */\n    this.uniformTemplates = {};\n    /**\n     * @readOnly\n     */\n    this.attributes = {};\n    /**\n     * @readOnly\n     */\n    this.textures = {};\n    /**\n     * @readOnly\n     */\n    this.vertexDefines = {};\n    /**\n     * @readOnly\n     */\n    this.fragmentDefines = {};\n\n    this._parseAttributes();\n    this._parseUniforms();\n    this._parseDefines();\n}\n\nShader.prototype = {\n\n    constructor: Shader,\n\n    // Create a new uniform instance for material\n    createUniforms: function () {\n        var uniforms = {};\n\n        for (var symbol in this.uniformTemplates){\n            var uniformTpl = this.uniformTemplates[symbol];\n            uniforms[symbol] = {\n                type: uniformTpl.type,\n                value: uniformTpl.value()\n            };\n        }\n\n        return uniforms;\n    },\n\n    _parseImport: function () {\n        this._vertexCode = Shader.parseImport(this.vertex);\n        this._fragmentCode = Shader.parseImport(this.fragment);\n    },\n\n    _parseUniforms: function () {\n        var uniforms = {};\n        var self = this;\n        var shaderType = 'vertex';\n        this._uniformList = [];\n\n        this._vertexCode = this._vertexCode.replace(uniformRegex, _uniformParser);\n        shaderType = 'fragment';\n        this._fragmentCode = this._fragmentCode.replace(uniformRegex, _uniformParser);\n\n        self.matrixSemanticKeys = Object.keys(this.matrixSemantics);\n\n        function _uniformParser(str, type, symbol, isArray, semanticWrapper, semantic) {\n            if (type && symbol) {\n                var uniformType = uniformTypeMap[type];\n                var isConfigurable = true;\n                var defaultValueFunc;\n                if (uniformType) {\n                    self._uniformList.push(symbol);\n                    if (type === 'sampler2D' || type === 'samplerCube') {\n                        // Texture is default disabled\n                        self.textures[symbol] = {\n                            shaderType: shaderType,\n                            type: type\n                        };\n                    }\n                    if (isArray) {\n                        uniformType += 'v';\n                    }\n                    if (semantic) {\n                        // This case is only for SKIN_MATRIX\n                        // TODO\n                        if (attributeSemantics.indexOf(semantic) >= 0) {\n                            self.attributeSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType\n                            };\n                            isConfigurable = false;\n                        }\n                        else if (matrixSemantics.indexOf(semantic) >= 0) {\n                            var isTranspose = false;\n                            var semanticNoTranspose = semantic;\n                            if (semantic.match(/TRANSPOSE$/)) {\n                                isTranspose = true;\n                                semanticNoTranspose = semantic.slice(0, -9);\n                            }\n                            self.matrixSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType,\n                                isTranspose: isTranspose,\n                                semanticNoTranspose: semanticNoTranspose\n                            };\n                            isConfigurable = false;\n                        }\n                        else if (uniformSemantics.indexOf(semantic) >= 0) {\n                            self.uniformSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType\n                            };\n                            isConfigurable = false;\n                        }\n                        else {\n                            // The uniform is not configurable, which means it will not appear\n                            // in the material uniform properties\n                            if (semantic === 'unconfigurable') {\n                                isConfigurable = false;\n                            }\n                            else {\n                                // Uniform have a defalut value, like\n                                // uniform vec3 color: [1, 1, 1];\n                                defaultValueFunc = self._parseDefaultValue(type, semantic);\n                                if (!defaultValueFunc) {\n                                    throw new Error('Unkown semantic \"' + semantic + '\"');\n                                }\n                                else {\n                                    semantic = '';\n                                }\n                            }\n                        }\n                    }\n\n                    if (isConfigurable) {\n                        uniforms[symbol] = {\n                            type: uniformType,\n                            value: isArray ? uniformValueConstructor['array'] : (defaultValueFunc || uniformValueConstructor[type]),\n                            semantic: semantic || null\n                        };\n                    }\n                }\n                return ['uniform', type, symbol, isArray].join(' ') + ';\\n';\n            }\n        }\n\n        this.uniformTemplates = uniforms;\n    },\n\n    _parseDefaultValue: function (type, str) {\n        var arrayRegex = /\\[\\s*(.*)\\s*\\]/;\n        if (type === 'vec2' || type === 'vec3' || type === 'vec4') {\n            var arrayStr = arrayRegex.exec(str)[1];\n            if (arrayStr) {\n                var arr = arrayStr.split(/\\s*,\\s*/);\n                return function () {\n                    return new vendor.Float32Array(arr);\n                };\n            }\n            else {\n                // Invalid value\n                return;\n            }\n        }\n        else if (type === 'bool') {\n            return function () {\n                return str.toLowerCase() === 'true' ? true : false;\n            };\n        }\n        else if (type === 'float') {\n            return function () {\n                return parseFloat(str);\n            };\n        }\n        else if (type === 'int') {\n            return function () {\n                return parseInt(str);\n            };\n        }\n    },\n\n    _parseAttributes: function () {\n        var attributes = {};\n        var self = this;\n        this._vertexCode = this._vertexCode.replace(attributeRegex, _attributeParser);\n\n        function _attributeParser(str, type, symbol, semanticWrapper, semantic) {\n            if (type && symbol) {\n                var size = 1;\n                switch (type) {\n                    case 'vec4':\n                        size = 4;\n                        break;\n                    case 'vec3':\n                        size = 3;\n                        break;\n                    case 'vec2':\n                        size = 2;\n                        break;\n                    case 'float':\n                        size = 1;\n                        break;\n                }\n\n                attributes[symbol] = {\n                    // Can only be float\n                    type: 'float',\n                    size: size,\n                    semantic: semantic || null\n                };\n\n                if (semantic) {\n                    if (attributeSemantics.indexOf(semantic) < 0) {\n                        throw new Error('Unkown semantic \"' + semantic + '\"');\n                    }\n                    else {\n                        self.attributeSemantics[semantic] = {\n                            symbol: symbol,\n                            type: type\n                        };\n                    }\n                }\n            }\n\n            return ['attribute', type, symbol].join(' ') + ';\\n';\n        }\n\n        this.attributes = attributes;\n    },\n\n    _parseDefines: function () {\n        var self = this;\n        var shaderType = 'vertex';\n        this._vertexCode = this._vertexCode.replace(defineRegex, _defineParser);\n        shaderType = 'fragment';\n        this._fragmentCode = this._fragmentCode.replace(defineRegex, _defineParser);\n\n        function _defineParser(str, symbol, value) {\n            var defines = shaderType === 'vertex' ? self.vertexDefines : self.fragmentDefines;\n            if (!defines[symbol]) { // Haven't been defined by user\n                if (value == 'false') {\n                    defines[symbol] = false;\n                }\n                else if (value == 'true') {\n                    defines[symbol] = true;\n                }\n                else {\n                    defines[symbol] = value\n                        // If can parse to float\n                        ? (isNaN(parseFloat(value)) ? value.trim() : parseFloat(value))\n                        : null;\n                }\n            }\n            return '';\n        }\n    },\n\n    /**\n     * Clone a new shader\n     * @return {clay.Shader}\n     */\n    clone: function () {\n        var code = shaderCodeCache[this._shaderID];\n        var shader = new Shader(code.vertex, code.fragment);\n        return shader;\n    }\n};\n\nif (Object.defineProperty) {\n    Object.defineProperty(Shader.prototype, 'shaderID', {\n        get: function () {\n            return this._shaderID;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'vertex', {\n        get: function () {\n            return this._vertexCode;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'fragment', {\n        get: function () {\n            return this._fragmentCode;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'uniforms', {\n        get: function () {\n            return this._uniformList;\n        }\n    });\n}\n\nvar importRegex = /(@import)\\s*([0-9a-zA-Z_\\-\\.]*)/g;\nShader.parseImport = function (shaderStr) {\n    shaderStr = shaderStr.replace(importRegex, function (str, importSymbol, importName) {\n        var str = Shader.source(importName);\n        if (str) {\n            // Recursively parse\n            return Shader.parseImport(str);\n        }\n        else {\n            console.error('Shader chunk \"' + importName + '\" not existed in library');\n            return '';\n        }\n    });\n    return shaderStr;\n};\n\nvar exportRegex = /(@export)\\s*([0-9a-zA-Z_\\-\\.]*)\\s*\\n([\\s\\S]*?)@end/g;\n\n/**\n * Import shader source\n * @param  {string} shaderStr\n * @memberOf clay.Shader\n */\nShader['import'] = function (shaderStr) {\n    shaderStr.replace(exportRegex, function (str, exportSymbol, exportName, code) {\n        var code = code.replace(/(^[\\s\\t\\xa0\\u3000]+)|([\\u3000\\xa0\\s\\t]+\\x24)/g, '');\n        if (code) {\n            var parts = exportName.split('.');\n            var obj = Shader.codes;\n            var i = 0;\n            var key;\n            while (i < parts.length - 1) {\n                key = parts[i++];\n                if (!obj[key]) {\n                    obj[key] = {};\n                }\n                obj = obj[key];\n            }\n            key = parts[i];\n            obj[key] = code;\n        }\n        return code;\n    });\n};\n\n/**\n * Library to store all the loaded shader codes\n * @type {Object}\n * @readOnly\n * @memberOf clay.Shader\n */\nShader.codes = {};\n\n/**\n * Get shader source\n * @param  {string} name\n * @return {string}\n */\nShader.source = function (name) {\n    var parts = name.split('.');\n    var obj = Shader.codes;\n    var i = 0;\n    while (obj && i < parts.length) {\n        var key = parts[i++];\n        obj = obj[key];\n    }\n    if (typeof obj !== 'string') {\n        // FIXME Use default instead\n        console.error('Shader \"' + name + '\" not existed in library');\n        return '';\n    }\n    return obj;\n};\n\nexport default Shader;\n","export default \"vec3 calcAmbientSHLight(int idx, vec3 N) {\\n    int offset = 9 * idx;\\n    return ambientSHLightCoefficients[0]\\n        + ambientSHLightCoefficients[1] * N.x\\n        + ambientSHLightCoefficients[2] * N.y\\n        + ambientSHLightCoefficients[3] * N.z\\n        + ambientSHLightCoefficients[4] * N.x * N.z\\n        + ambientSHLightCoefficients[5] * N.z * N.y\\n        + ambientSHLightCoefficients[6] * N.y * N.x\\n        + ambientSHLightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\\n        + ambientSHLightCoefficients[8] * (N.x * N.x - N.y * N.y);\\n}\";\n","import calcAmbientSHLightEssl from './calcAmbientSHLight.glsl.js';\n\nvar uniformVec3Prefix = 'uniform vec3 ';\nvar uniformFloatPrefix = 'uniform float ';\nvar exportHeaderPrefix = '@export clay.header.';\nvar exportEnd = '@end';\nvar unconfigurable = ':unconfigurable;';\nexport default [\n    exportHeaderPrefix + 'directional_light',\n    uniformVec3Prefix + 'directionalLightDirection[DIRECTIONAL_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'directionalLightColor[DIRECTIONAL_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_light',\n    uniformVec3Prefix + 'ambientLightColor[AMBIENT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_sh_light',\n    uniformVec3Prefix + 'ambientSHLightColor[AMBIENT_SH_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'ambientSHLightCoefficients[AMBIENT_SH_LIGHT_COUNT * 9]' + unconfigurable,\n    calcAmbientSHLightEssl,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_cubemap_light',\n    uniformVec3Prefix + 'ambientCubemapLightColor[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    'uniform samplerCube ambientCubemapLightCubemap[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    'uniform sampler2D ambientCubemapLightBRDFLookup[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'point_light',\n    uniformVec3Prefix + 'pointLightPosition[POINT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'pointLightRange[POINT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'pointLightColor[POINT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'spot_light',\n    uniformVec3Prefix + 'spotLightPosition[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'spotLightDirection[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightRange[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightUmbraAngleCosine[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightPenumbraAngleCosine[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightFalloffFactor[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'spotLightColor[SPOT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd\n].join('\\n');\n","export default \"@export clay.prez.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n}\\n@end\\n@export clay.prez.fragment\\nvoid main()\\n{\\n    gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\\n}\\n@end\";\n","// TODO Resources like shader, texture, geometry reference management\n// Trace and find out which shader, texture, geometry can be destroyed\nimport Base from './core/Base';\nimport GLInfo from './core/GLInfo';\nimport glenum from './core/glenum';\nimport vendor from './core/vendor';\nimport BoundingBox from './math/BoundingBox';\nimport Matrix4 from './math/Matrix4';\nimport Material from './Material';\nimport Vector2 from './math/Vector2';\nimport ProgramManager from './gpu/ProgramManager';\n\n// Light header\nimport Shader from './Shader';\n\nimport lightShader from './shader/source/header/light';\nimport prezEssl from './shader/source/prez.glsl.js';\nShader['import'](lightShader);\nShader['import'](prezEssl);\n\nimport glMatrix from './dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\nvar mat4Create = mat4.create;\n\nvar errorShader = {};\n\nfunction defaultGetMaterial(renderable) {\n    return renderable.material;\n}\n\nfunction noop() {}\n\n/**\n * @constructor clay.Renderer\n */\nvar Renderer = Base.extend(function () {\n    return /** @lends clay.Renderer# */ {\n\n        /**\n         * @type {HTMLCanvasElement}\n         * @readonly\n         */\n        canvas: null,\n\n        /**\n         * Canvas width, set by resize method\n         * @type {number}\n         * @private\n         */\n        _width: 100,\n\n        /**\n         * Canvas width, set by resize method\n         * @type {number}\n         * @private\n         */\n        _height: 100,\n\n        /**\n         * Device pixel ratio, set by setDevicePixelRatio method\n         * Specially for high defination display\n         * @see http://www.khronos.org/webgl/wiki/HandlingHighDPI\n         * @type {number}\n         * @private\n         */\n        devicePixelRatio: window.devicePixelRatio || 1.0,\n\n        /**\n         * Clear color\n         * @type {number[]}\n         */\n        clearColor: [0.0, 0.0, 0.0, 0.0],\n\n        /**\n         * Default:\n         *     _gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT | _gl.STENCIL_BUFFER_BIT\n         * @type {number}\n         */\n        clearBit: 17664,\n\n        // Settings when getting context\n        // http://www.khronos.org/registry/webgl/specs/latest/#2.4\n\n        /**\n         * If enable alpha, default true\n         * @type {boolean}\n         */\n        alpha: true,\n        /**\n         * If enable depth buffer, default true\n         * @type {boolean}\n         */\n        depth: true,\n        /**\n         * If enable stencil buffer, default false\n         * @type {boolean}\n         */\n        stencil: false,\n        /**\n         * If enable antialias, default true\n         * @type {boolean}\n         */\n        antialias: true,\n        /**\n         * If enable premultiplied alpha, default true\n         * @type {boolean}\n         */\n        premultipliedAlpha: true,\n        /**\n         * If preserve drawing buffer, default false\n         * @type {boolean}\n         */\n        preserveDrawingBuffer: false,\n        /**\n         * If throw context error, usually turned on in debug mode\n         * @type {boolean}\n         */\n        throwError: true,\n        /**\n         * WebGL Context created from given canvas\n         * @type {WebGLRenderingContext}\n         */\n        gl: null,\n        /**\n         * Renderer viewport, read-only, can be set by setViewport method\n         * @type {Object}\n         */\n        viewport: {},\n\n        // Set by FrameBuffer#bind\n        __currentFrameBuffer: null,\n\n        _viewportStack: [],\n        _clearStack: [],\n\n        _sceneRendering: null\n    };\n}, function () {\n\n    if (!this.canvas) {\n        this.canvas = document.createElement('canvas');\n    }\n    var canvas = this.canvas;\n    try {\n        var opts = {\n            alpha: this.alpha,\n            depth: this.depth,\n            stencil: this.stencil,\n            antialias: this.antialias,\n            premultipliedAlpha: this.premultipliedAlpha,\n            preserveDrawingBuffer: this.preserveDrawingBuffer\n        };\n\n        this.gl = canvas.getContext('webgl', opts)\n            || canvas.getContext('experimental-webgl', opts);\n\n        if (!this.gl) {\n            throw new Error();\n        }\n\n        this._glinfo = new GLInfo(this.gl);\n\n        if (this.gl.targetRenderer) {\n            console.error('Already created a renderer');\n        }\n        this.gl.targetRenderer = this;\n\n        this.resize();\n    }\n    catch (e) {\n        throw 'Error creating WebGL Context ' + e;\n    }\n\n    // Init managers\n    this._programMgr = new ProgramManager(this);\n},\n/** @lends clay.Renderer.prototype. **/\n{\n    /**\n     * Resize the canvas\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function(width, height) {\n        var canvas = this.canvas;\n        // http://www.khronos.org/webgl/wiki/HandlingHighDPI\n        // set the display size of the canvas.\n        var dpr = this.devicePixelRatio;\n        if (width != null) {\n            canvas.style.width = width + 'px';\n            canvas.style.height = height + 'px';\n            // set the size of the drawingBuffer\n            canvas.width = width * dpr;\n            canvas.height = height * dpr;\n\n            this._width = width;\n            this._height = height;\n        }\n        else {\n            this._width = canvas.width / dpr;\n            this._height = canvas.height / dpr;\n        }\n\n        this.setViewport(0, 0, this._width, this._height);\n    },\n\n    /**\n     * Get renderer width\n     * @return {number}\n     */\n    getWidth: function () {\n        return this._width;\n    },\n\n    /**\n     * Get renderer height\n     * @return {number}\n     */\n    getHeight: function () {\n        return this._height;\n    },\n\n    /**\n     * Get viewport aspect,\n     * @return {number}\n     */\n    getViewportAspect: function () {\n        var viewport = this.viewport;\n        return viewport.width / viewport.height;\n    },\n\n    /**\n     * Set devicePixelRatio\n     * @param {number} devicePixelRatio\n     */\n    setDevicePixelRatio: function(devicePixelRatio) {\n        this.devicePixelRatio = devicePixelRatio;\n        this.resize(this._width, this._height);\n    },\n\n    /**\n     * Get devicePixelRatio\n     * @param {number} devicePixelRatio\n     */\n    getDevicePixelRatio: function () {\n        return this.devicePixelRatio;\n    },\n\n    /**\n     * Get WebGL extension\n     * @param {string} name\n     * @return {object}\n     */\n    getGLExtension: function (name) {\n        return this._glinfo.getExtension(name);\n    },\n\n    /**\n     * Get WebGL parameter\n     * @param {string} name\n     * @return {*}\n     */\n    getGLParameter: function (name) {\n        return this._glinfo.getParameter(name);\n    },\n\n    /**\n     * Set rendering viewport\n     * @param {number|Object} x\n     * @param {number} [y]\n     * @param {number} [width]\n     * @param {number} [height]\n     * @param {number} [devicePixelRatio]\n     *        Defaultly use the renderere devicePixelRatio\n     *        It needs to be 1 when setViewport is called by frameBuffer\n     *\n     * @example\n     *  setViewport(0,0,width,height,1)\n     *  setViewport({\n     *      x: 0,\n     *      y: 0,\n     *      width: width,\n     *      height: height,\n     *      devicePixelRatio: 1\n     *  })\n     */\n    setViewport: function (x, y, width, height, dpr) {\n\n        if (typeof x === 'object') {\n            var obj = x;\n\n            x = obj.x;\n            y = obj.y;\n            width = obj.width;\n            height = obj.height;\n            dpr = obj.devicePixelRatio;\n        }\n        dpr = dpr || this.devicePixelRatio;\n\n        this.gl.viewport(\n            x * dpr, y * dpr, width * dpr, height * dpr\n        );\n        // Use a fresh new object, not write property.\n        this.viewport = {\n            x: x,\n            y: y,\n            width: width,\n            height: height,\n            devicePixelRatio: dpr\n        };\n    },\n\n    /**\n     * Push current viewport into a stack\n     */\n    saveViewport: function () {\n        this._viewportStack.push(this.viewport);\n    },\n\n    /**\n     * Pop viewport from stack, restore in the renderer\n     */\n    restoreViewport: function () {\n        if (this._viewportStack.length > 0) {\n            this.setViewport(this._viewportStack.pop());\n        }\n    },\n\n    /**\n     * Push current clear into a stack\n     */\n    saveClear: function () {\n        this._clearStack.push({\n            clearBit: this.clearBit,\n            clearColor: this.clearColor\n        });\n    },\n\n    /**\n     * Pop clear from stack, restore in the renderer\n     */\n    restoreClear: function () {\n        if (this._clearStack.length > 0) {\n            var opt = this._clearStack.pop();\n            this.clearColor = opt.clearColor;\n            this.clearBit = opt.clearBit;\n        }\n    },\n\n    bindSceneRendering: function (scene) {\n        this._sceneRendering = scene;\n    },\n\n    /**\n     * Render the scene in camera to the screen or binded offline framebuffer\n     * @param  {clay.Scene}       scene\n     * @param  {clay.Camera}      camera\n     * @param  {boolean}     [notUpdateScene] If not call the scene.update methods in the rendering, default true\n     * @param  {boolean}     [preZ]           If use preZ optimization, default false\n     * @return {IRenderInfo}\n     */\n    render: function(scene, camera, notUpdateScene, preZ) {\n        var _gl = this.gl;\n\n        var clearColor = this.clearColor;\n\n        if (this.clearBit) {\n\n            // Must set depth and color mask true before clear\n            _gl.colorMask(true, true, true, true);\n            _gl.depthMask(true);\n            var viewport = this.viewport;\n            var needsScissor = false;\n            var viewportDpr = viewport.devicePixelRatio;\n            if (viewport.width !== this._width || viewport.height !== this._height\n                || (viewportDpr && viewportDpr !== this.devicePixelRatio)\n                || viewport.x || viewport.y\n            ) {\n                needsScissor = true;\n                // http://stackoverflow.com/questions/11544608/how-to-clear-a-rectangle-area-in-webgl\n                // Only clear the viewport\n                _gl.enable(_gl.SCISSOR_TEST);\n                _gl.scissor(viewport.x * viewportDpr, viewport.y * viewportDpr, viewport.width * viewportDpr, viewport.height * viewportDpr);\n            }\n            _gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n            _gl.clear(this.clearBit);\n            if (needsScissor) {\n                _gl.disable(_gl.SCISSOR_TEST);\n            }\n        }\n\n        // If the scene have been updated in the prepass like shadow map\n        // There is no need to update it again\n        if (!notUpdateScene) {\n            scene.update(false);\n        }\n        camera = camera || scene.getMainCamera();\n        if (!camera) {\n            console.error('Can\\'t find camera in the scene.');\n            return;\n        }\n        // Update if camera not mounted on the scene\n        if (!camera.getScene()) {\n            camera.update(true);\n        }\n\n        this._sceneRendering = scene;\n\n        // Reset the scene bounding box;\n        scene.viewBoundingBoxLastFrame.min.set(Infinity, Infinity, Infinity);\n        scene.viewBoundingBoxLastFrame.max.set(-Infinity, -Infinity, -Infinity);\n\n        var opaqueList = this.cullRenderList(scene.opaqueList, scene, camera);\n        var transparentList = this.cullRenderList(scene.transparentList, scene, camera);\n        var sceneMaterial = scene.material;\n\n        scene.trigger('beforerender', this, scene, camera);\n\n        // Render pre z\n        if (preZ) {\n            this.renderPreZ(opaqueList, scene, camera);\n            _gl.depthFunc(_gl.LEQUAL);\n        }\n        else {\n            _gl.depthFunc(_gl.LESS);\n        }\n\n        // Update the depth of transparent list.\n        var worldViewMat = mat4Create();\n        var posViewSpace = vec3.create();\n        for (var i = 0; i < transparentList.length; i++) {\n            var renderable = transparentList[i];\n            mat4.multiplyAffine(worldViewMat, camera.viewMatrix.array, renderable.worldTransform.array);\n            vec3.transformMat4(posViewSpace, renderable.position.array, worldViewMat);\n            renderable.__depth = posViewSpace[2];\n        }\n\n        // Render opaque list\n        scene.trigger('beforerender:opaque', this, opaqueList);\n        var opaqueRenderInfo = this.renderPass(opaqueList, camera, {\n            getMaterial: function (renderable) {\n                return sceneMaterial || renderable.material;\n            },\n            sortCompare: this.opaqueSortCompare\n        });\n\n        scene.trigger('afterrender:opaque', this, opaqueList, opaqueRenderInfo);\n        scene.trigger('beforerender:transparent', this, transparentList);\n\n        var transparentRenderInfo = this.renderPass(transparentList, camera, {\n            getMaterial: function (renderable) {\n                return sceneMaterial || renderable.material;\n            },\n            sortCompare: this.transparentSortCompare\n        });\n\n        scene.trigger('afterrender:transparent', this, transparentList, transparentRenderInfo);\n        var renderInfo = {};\n        for (var name in opaqueRenderInfo) {\n            renderInfo[name] = opaqueRenderInfo[name] + transparentRenderInfo[name];\n        }\n\n        scene.trigger('afterrender', this, scene, camera, renderInfo);\n\n        // Cleanup\n        this._sceneRendering = null;\n        return renderInfo;\n    },\n\n    getProgram: function (renderable, renderMaterial, scene) {\n        renderMaterial = renderMaterial || renderable.material;\n        return this._programMgr.getProgram(renderable, renderMaterial, scene);\n    },\n\n    validateProgram: function (program) {\n        if (program.__error) {\n            var errorMsg = program.__error;\n            if (errorShader[program.__uid__]) {\n                return;\n            }\n            errorShader[program.__uid__] = true;\n\n            if (this.throwError) {\n                throw new Error(errorMsg);\n            }\n            else {\n                this.trigger('error', errorMsg);\n            }\n        }\n\n    },\n\n    updatePrograms: function (list, scene, passConfig) {\n        var getMaterial = (passConfig && passConfig.getMaterial) || defaultGetMaterial;\n        scene = scene || null;\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n            var renderMaterial = getMaterial.call(this, renderable);\n            if (i > 0) {\n                var prevRenderable = list[i - 1];\n                var prevJointsLen = prevRenderable.joints ? prevRenderable.joints.length : 0;\n                var jointsLen = renderable.joints.length ? renderable.joints.length : 0;\n                // Keep program not change if joints, material, lightGroup are same of two renderables.\n                if (jointsLen === prevJointsLen\n                    && renderable.material === prevRenderable.material\n                    && renderable.lightGroup === prevRenderable.lightGroup\n                ) {\n                    renderable.__program = prevRenderable.__program;\n                    continue;\n                }\n            }\n\n            var program = this._programMgr.getProgram(renderable, renderMaterial, scene);\n\n            this.validateProgram(program);\n\n            renderable.__program = program;\n        }\n    },\n\n    /**\n     * Do frustum culling on render list\n     */\n    cullRenderList: function (list, scene, camera) {\n        var culledRenderList = [];\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n\n            var worldM = renderable.isSkinnedMesh() ? matrices.IDENTITY : renderable.worldTransform.array;\n            var geometry = renderable.geometry;\n\n            mat4.multiplyAffine(matrices.WORLDVIEW, camera.viewMatrix.array , worldM);\n            if (geometry.boundingBox) {\n                if (this.isFrustumCulled(\n                    renderable, scene, camera, matrices.WORLDVIEW, camera.projectionMatrix.array\n                )) {\n                    continue;\n                }\n            }\n\n            culledRenderList.push(renderable);\n        }\n\n        return culledRenderList;\n    },\n\n    /**\n     * Render a single renderable list in camera in sequence\n     * @param {clay.Renderable[]} list List of all renderables.\n     * @param {clay.Camera} camera\n     * @param {Object} [passConfig]\n     * @param {Function} [passConfig.getMaterial] Get renderable material.\n     * @param {Function} [passConfig.beforeRender] Before render each renderable.\n     * @param {Function} [passConfig.afterRender] After render each renderable\n     * @param {Function} [passConfig.ifRender] If render the renderable.\n     * @param {Function} [passConfig.sortCompare] Sort compare function.\n     * @return {IRenderInfo}\n     */\n    renderPass: function(list, camera, passConfig) {\n        var renderInfo = {\n            triangleCount: 0,\n            vertexCount: 0,\n            drawCallCount: 0,\n            meshCount: list.length,\n            renderedMeshCount: 0\n        };\n        passConfig = passConfig || {};\n        passConfig.getMaterial = passConfig.getMaterial || defaultGetMaterial;\n        passConfig.beforeRender = passConfig.beforeRender || noop;\n        passConfig.afterRender = passConfig.afterRender || noop;\n\n        this.updatePrograms(list, this._sceneRendering, passConfig);\n        if (passConfig.sortCompare) {\n            list.sort(passConfig.sortCompare);\n        }\n\n        // Some common builtin uniforms\n        var viewport = this.viewport;\n        var vDpr = viewport.devicePixelRatio;\n        var viewportUniform = [\n            viewport.x * vDpr, viewport.y * vDpr,\n            viewport.width * vDpr, viewport.height * vDpr\n        ];\n        var windowDpr = this.devicePixelRatio;\n        var windowSizeUniform = this.__currentFrameBuffer\n            ? [this.__currentFrameBuffer.getTextureWidth(), this.__currentFrameBuffer.getTextureHeight()]\n            : [this._width * windowDpr, this._height * windowDpr];\n        // DEPRECATED\n        var viewportSizeUniform = [\n            viewportUniform[2], viewportUniform[3]\n        ];\n        var time = Date.now();\n\n        // Calculate view and projection matrix\n        mat4.copy(matrices.VIEW, camera.viewMatrix.array);\n        mat4.copy(matrices.PROJECTION, camera.projectionMatrix.array);\n        mat4.multiply(matrices.VIEWPROJECTION, camera.projectionMatrix.array, matrices.VIEW);\n        mat4.copy(matrices.VIEWINVERSE, camera.worldTransform.array);\n        mat4.invert(matrices.PROJECTIONINVERSE, matrices.PROJECTION);\n        mat4.invert(matrices.VIEWPROJECTIONINVERSE, matrices.VIEWPROJECTION);\n\n        var _gl = this.gl;\n        var scene = this._sceneRendering;\n\n        var prevMaterial;\n        var prevProgram;\n\n        // Status\n        var depthTest, depthMask;\n        var culling, cullFace, frontFace;\n        var transparent;\n\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n            if (passConfig.ifRender && !passConfig.ifRender(renderable)) {\n                continue;\n            }\n\n            // Skinned mesh will transformed to joint space. Ignore the mesh transform\n            var worldM = renderable.isSkinnedMesh() ? matrices.IDENTITY : renderable.worldTransform.array;\n\n            var material = passConfig.getMaterial.call(this, renderable);\n\n            var program = renderable.__program;\n            var shader = material.shader;\n\n            mat4.copy(matrices.WORLD, worldM);\n            mat4.multiply(matrices.WORLDVIEWPROJECTION, matrices.VIEWPROJECTION , worldM);\n            if (shader.matrixSemantics.WORLDINVERSE ||\n                shader.matrixSemantics.WORLDINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDINVERSE, worldM);\n            }\n            if (shader.matrixSemantics.WORLDVIEWINVERSE ||\n                shader.matrixSemantics.WORLDVIEWINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDVIEWINVERSE, matrices.WORLDVIEW);\n            }\n            if (shader.matrixSemantics.WORLDVIEWPROJECTIONINVERSE ||\n                shader.matrixSemantics.WORLDVIEWPROJECTIONINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDVIEWPROJECTIONINVERSE, matrices.WORLDVIEWPROJECTION);\n            }\n\n            // Before render hook\n            renderable.beforeRender(this);\n            passConfig.beforeRender.call(this, renderable, material, prevMaterial);\n\n            var programChanged = program !== prevProgram;\n            if (programChanged) {\n                // Set lights number\n                program.bind(this);\n                // Set some common uniforms\n                program.setUniformOfSemantic(_gl, 'VIEWPORT', viewportUniform);\n                program.setUniformOfSemantic(_gl, 'WINDOW_SIZE', windowSizeUniform);\n                program.setUniformOfSemantic(_gl, 'NEAR', camera.near);\n                program.setUniformOfSemantic(_gl, 'FAR', camera.far);\n                program.setUniformOfSemantic(_gl, 'DEVICEPIXELRATIO', vDpr);\n                program.setUniformOfSemantic(_gl, 'TIME', time);\n                // DEPRECATED\n                program.setUniformOfSemantic(_gl, 'VIEWPORT_SIZE', viewportSizeUniform);\n\n                // Set lights uniforms\n                // TODO needs optimized\n                if (scene) {\n                    scene.setLightUniforms(program, renderable.lightGroup, this);\n                }\n            }\n            else {\n                program = prevProgram;\n            }\n\n            // Program changes also needs reset the materials.\n            if (prevMaterial !== material || programChanged) {\n                if (material.depthTest !== depthTest) {\n                    material.depthTest\n                        ? _gl.enable(_gl.DEPTH_TEST)\n                        : _gl.disable(_gl.DEPTH_TEST);\n                    depthTest = material.depthTest;\n                }\n                if (material.depthMask !== depthMask) {\n                    _gl.depthMask(material.depthMask);\n                    depthMask = material.depthMask;\n                }\n                if (material.transparent !== transparent) {\n                    material.transparent\n                        ? _gl.enable(_gl.BLEND)\n                        : _gl.disable(_gl.BLEND);\n                    transparent = material.transparent;\n                }\n                // TODO cache blending\n                if (material.transparent) {\n                    if (material.blend) {\n                        material.blend(_gl);\n                    }\n                    else {\n                        // Default blend function\n                        _gl.blendEquationSeparate(_gl.FUNC_ADD, _gl.FUNC_ADD);\n                        _gl.blendFuncSeparate(_gl.SRC_ALPHA, _gl.ONE_MINUS_SRC_ALPHA, _gl.ONE, _gl.ONE_MINUS_SRC_ALPHA);\n                    }\n                }\n\n                material.bind(this, program, prevMaterial, prevProgram);\n                prevMaterial = material;\n            }\n\n            var matrixSemanticKeys = shader.matrixSemanticKeys;\n            for (var k = 0; k < matrixSemanticKeys.length; k++) {\n                var semantic = matrixSemanticKeys[k];\n                var semanticInfo = shader.matrixSemantics[semantic];\n                var matrix = matrices[semantic];\n                if (semanticInfo.isTranspose) {\n                    var matrixNoTranspose = matrices[semanticInfo.semanticNoTranspose];\n                    mat4.transpose(matrix, matrixNoTranspose);\n                }\n                program.setUniform(_gl, semanticInfo.type, semanticInfo.symbol, matrix);\n            }\n\n            if (renderable.cullFace !== cullFace) {\n                cullFace = renderable.cullFace;\n                _gl.cullFace(cullFace);\n            }\n            if (renderable.frontFace !== frontFace) {\n                frontFace = renderable.frontFace;\n                _gl.frontFace(frontFace);\n            }\n            if (renderable.culling !== culling) {\n                culling = renderable.culling;\n                culling ? _gl.enable(_gl.CULL_FACE) : _gl.disable(_gl.CULL_FACE);\n            }\n\n            var objectRenderInfo = renderable.render(this, material, program);\n\n            if (objectRenderInfo) {\n                renderInfo.triangleCount += objectRenderInfo.triangleCount;\n                renderInfo.vertexCount += objectRenderInfo.vertexCount;\n                renderInfo.drawCallCount += objectRenderInfo.drawCallCount;\n                renderInfo.renderedMeshCount ++;\n            }\n\n            // After render hook\n            passConfig.afterRender.call(this, renderable, objectRenderInfo);\n            renderable.afterRender(this, objectRenderInfo);\n\n            prevProgram = program;\n        }\n\n        // Remove programs incase it's not updated in the other passes.\n        for (var i = 0; i < list.length; i++) {\n            list[i].__program = null;\n        }\n\n        return renderInfo;\n    },\n\n    renderPreZ: function (list, scene, camera) {\n        var _gl = this.gl;\n        var preZPassMaterial = this._prezMaterial || new Material({\n            shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'))\n        });\n        this._prezMaterial = preZPassMaterial;\n\n        _gl.colorMask(false, false, false, false);\n        _gl.depthMask(true);\n\n        // Status\n        this.renderPass(list, camera, {\n            ifRender: function (renderable) {\n                return !renderable.ignorePreZ;\n            },\n            getMaterial: function () {\n                return preZPassMaterial;\n            },\n            sort: this.opaqueSortCompare\n        });\n\n        _gl.colorMask(true, true, true, true);\n        _gl.depthMask(true);\n    },\n\n    /**\n     * If an scene object is culled by camera frustum\n     *\n     * Object can be a renderable or a light\n     *\n     * @param {clay.Node} Scene object\n     * @param {clay.Camera} camera\n     * @param {Array.<number>} worldViewMat represented with array\n     * @param {Array.<number>} projectionMat represented with array\n     */\n    isFrustumCulled: (function () {\n        // Frustum culling\n        // http://www.cse.chalmers.se/~uffe/vfc_bbox.pdf\n        var cullingBoundingBox = new BoundingBox();\n        var cullingMatrix = new Matrix4();\n        return function (object, scene, camera, worldViewMat, projectionMat) {\n            // Bounding box can be a property of object(like light) or renderable.geometry\n            var geoBBox = object.boundingBox || object.geometry.boundingBox;\n            cullingMatrix.array = worldViewMat;\n            cullingBoundingBox.copy(geoBBox);\n            cullingBoundingBox.applyTransform(cullingMatrix);\n\n            // Passingly update the scene bounding box\n            // FIXME exclude very large mesh like ground plane or terrain ?\n            // FIXME Only rendererable which cast shadow ?\n\n            // FIXME boundingBox becomes much larger after transformd.\n            if (scene && object.isRenderable() && object.castShadow) {\n                scene.viewBoundingBoxLastFrame.union(cullingBoundingBox);\n            }\n            // Ignore frustum culling if object is skinned mesh.\n            if (object.frustumCulling && !object.isSkinnedMesh())  {\n                if (!cullingBoundingBox.intersectBoundingBox(camera.frustum.boundingBox)) {\n                    return true;\n                }\n\n                cullingMatrix.array = projectionMat;\n                if (\n                    cullingBoundingBox.max.array[2] > 0 &&\n                    cullingBoundingBox.min.array[2] < 0\n                ) {\n                    // Clip in the near plane\n                    cullingBoundingBox.max.array[2] = -1e-20;\n                }\n\n                cullingBoundingBox.applyProjection(cullingMatrix);\n\n                var min = cullingBoundingBox.min.array;\n                var max = cullingBoundingBox.max.array;\n\n                if (\n                    max[0] < -1 || min[0] > 1\n                    || max[1] < -1 || min[1] > 1\n                    || max[2] < -1 || min[2] > 1\n                ) {\n                    return true;\n                }\n            }\n\n            return false;\n        };\n    })(),\n\n    /**\n     * Dispose given scene, including all geometris, textures and shaders in the scene\n     * @param {clay.Scene} scene\n     */\n    disposeScene: function(scene) {\n        this.disposeNode(scene, true, true);\n        scene.dispose();\n    },\n\n    /**\n     * Dispose given node, including all geometries, textures and shaders attached on it or its descendant\n     * @param {clay.Node} node\n     * @param {boolean} [disposeGeometry=false] If dispose the geometries used in the descendant mesh\n     * @param {boolean} [disposeTexture=false] If dispose the textures used in the descendant mesh\n     */\n    disposeNode: function(root, disposeGeometry, disposeTexture) {\n        // Dettached from parent\n        if (root.getParent()) {\n            root.getParent().remove(root);\n        }\n        root.traverse(function(node) {\n            if (node.geometry && disposeGeometry) {\n                node.geometry.dispose(this);\n            }\n            // Particle system and AmbientCubemap light need to dispose\n            if (node.dispose) {\n                node.dispose(this);\n            }\n        }, this);\n    },\n\n    /**\n     * Dispose given geometry\n     * @param {clay.Geometry} geometry\n     */\n    disposeGeometry: function(geometry) {\n        geometry.dispose(this);\n    },\n\n    /**\n     * Dispose given texture\n     * @param {clay.Texture} texture\n     */\n    disposeTexture: function(texture) {\n        texture.dispose(this);\n    },\n\n    /**\n     * Dispose given frame buffer\n     * @param {clay.FrameBuffer} frameBuffer\n     */\n    disposeFrameBuffer: function(frameBuffer) {\n        frameBuffer.dispose(this);\n    },\n\n    /**\n     * Dispose renderer\n     */\n    dispose: function () {},\n\n    /**\n     * Convert screen coords to normalized device coordinates(NDC)\n     * Screen coords can get from mouse event, it is positioned relative to canvas element\n     * NDC can be used in ray casting with Camera.prototype.castRay methods\n     *\n     * @param  {number}       x\n     * @param  {number}       y\n     * @param  {clay.math.Vector2} [out]\n     * @return {clay.math.Vector2}\n     */\n    screenToNDC: function(x, y, out) {\n        if (!out) {\n            out = new Vector2();\n        }\n        // Invert y;\n        y = this._height - y;\n\n        var viewport = this.viewport;\n        var arr = out.array;\n        arr[0] = (x - viewport.x) / viewport.width;\n        arr[0] = arr[0] * 2 - 1;\n        arr[1] = (y - viewport.y) / viewport.height;\n        arr[1] = arr[1] * 2 - 1;\n\n        return out;\n    }\n});\n\n/**\n * Opaque renderables compare function\n * @param  {clay.Renderable} x\n * @param  {clay.Renderable} y\n * @return {boolean}\n * @static\n */\nRenderer.opaqueSortCompare = Renderer.prototype.opaqueSortCompare = function(x, y) {\n    // Priority renderOrder -> program -> material -> geometry\n    if (x.renderOrder === y.renderOrder) {\n        if (x.__program === y.__program) {\n            if (x.material === y.material) {\n                return x.geometry.__uid__ - y.geometry.__uid__;\n            }\n            return x.material.__uid__ - y.material.__uid__;\n        }\n        if (x.__program  && y.__program) {\n            return x.__program.__uid__ - y.__program.__uid__;\n        }\n        return 0;\n    }\n    return x.renderOrder - y.renderOrder;\n};\n\n/**\n * Transparent renderables compare function\n * @param  {clay.Renderable} a\n * @param  {clay.Renderable} b\n * @return {boolean}\n * @static\n */\nRenderer.transparentSortCompare = Renderer.prototype.transparentSortCompare = function(x, y) {\n    // Priority renderOrder -> depth -> program -> material -> geometry\n\n    if (x.renderOrder === y.renderOrder) {\n        if (x.__depth === y.__depth) {\n            if (x.__program === y.__program) {\n                if (x.material === y.material) {\n                    return x.geometry.__uid__ - y.geometry.__uid__;\n                }\n                return x.material.__uid__ - y.material.__uid__;\n            }\n            if (x.__program  && y.__program) {\n                return x.__program.__uid__ - y.__program.__uid__;\n            }\n            return 0;\n        }\n        // Depth is negative\n        // So farther object has smaller depth value\n        return x.__depth - y.__depth;\n    }\n    return x.renderOrder - y.renderOrder;\n};\n\n// Temporary variables\nvar matrices = {\n    IDENTITY: mat4Create(),\n\n    WORLD: mat4Create(),\n    VIEW: mat4Create(),\n    PROJECTION: mat4Create(),\n    WORLDVIEW: mat4Create(),\n    VIEWPROJECTION: mat4Create(),\n    WORLDVIEWPROJECTION: mat4Create(),\n\n    WORLDINVERSE: mat4Create(),\n    VIEWINVERSE: mat4Create(),\n    PROJECTIONINVERSE: mat4Create(),\n    WORLDVIEWINVERSE: mat4Create(),\n    VIEWPROJECTIONINVERSE: mat4Create(),\n    WORLDVIEWPROJECTIONINVERSE: mat4Create(),\n\n    WORLDTRANSPOSE: mat4Create(),\n    VIEWTRANSPOSE: mat4Create(),\n    PROJECTIONTRANSPOSE: mat4Create(),\n    WORLDVIEWTRANSPOSE: mat4Create(),\n    VIEWPROJECTIONTRANSPOSE: mat4Create(),\n    WORLDVIEWPROJECTIONTRANSPOSE: mat4Create(),\n    WORLDINVERSETRANSPOSE: mat4Create(),\n    VIEWINVERSETRANSPOSE: mat4Create(),\n    PROJECTIONINVERSETRANSPOSE: mat4Create(),\n    WORLDVIEWINVERSETRANSPOSE: mat4Create(),\n    VIEWPROJECTIONINVERSETRANSPOSE: mat4Create(),\n    WORLDVIEWPROJECTIONINVERSETRANSPOSE: mat4Create()\n};\n\n/**\n * @name clay.Renderer.COLOR_BUFFER_BIT\n * @type {number}\n */\nRenderer.COLOR_BUFFER_BIT = glenum.COLOR_BUFFER_BIT;\n/**\n * @name clay.Renderer.DEPTH_BUFFER_BIT\n * @type {number}\n */\nRenderer.DEPTH_BUFFER_BIT = glenum.DEPTH_BUFFER_BIT;\n/**\n * @name clay.Renderer.STENCIL_BUFFER_BIT\n * @type {number}\n */\nRenderer.STENCIL_BUFFER_BIT = glenum.STENCIL_BUFFER_BIT;\n\nexport default Renderer;\n","import glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\n\n/**\n * @constructor\n * @alias clay.math.Quaternion\n * @param {number} x\n * @param {number} y\n * @param {number} z\n * @param {number} w\n */\nvar Quaternion = function (x, y, z, w) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n    w = w === undefined ? 1 : w;\n\n    /**\n     * Storage of Quaternion, read and write of x, y, z, w will change the values in array\n     * All methods also operate on the array instead of x, y, z, w components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Quaternion#\n     */\n    this.array = quat.fromValues(x, y, z, w);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Quaternion#\n     */\n    this._dirty = true;\n};\n\nQuaternion.prototype = {\n\n    constructor: Quaternion,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    add: function (b) {\n        quat.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate the w component from x, y, z component\n     * @return {clay.math.Quaternion}\n     */\n    calculateW: function () {\n        quat.calculateW(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @param  {number}  w\n     * @return {clay.math.Quaternion}\n     */\n    set: function (x, y, z, w) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this.array[3] = w;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y, z and w components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Quaternion}\n     */\n    setArray: function (arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n        this.array[3] = arr[3];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Quaternion\n     * @return {clay.math.Quaternion}\n     */\n    clone: function () {\n        return new Quaternion(this.x, this.y, this.z, this.w);\n    },\n\n    /**\n     * Calculates the conjugate of self If the quaternion is normalized,\n     * this function is faster than invert and produces the same result.\n     *\n     * @return {clay.math.Quaternion}\n     */\n    conjugate: function () {\n        quat.conjugate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    copy: function (b) {\n        quat.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Quaternion} b\n     * @return {number}\n     */\n    dot: function (b) {\n        return quat.dot(this.array, b.array);\n    },\n\n    /**\n     * Set from the given 3x3 rotation matrix\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Quaternion}\n     */\n    fromMat3: function (m) {\n        quat.fromMat3(this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from the given 4x4 rotation matrix\n     * The 4th column and 4th row will be droped\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Quaternion}\n     */\n    fromMat4: (function () {\n        var mat3 = glMatrix.mat3;\n        var m3 = mat3.create();\n        return function (m) {\n            mat3.fromMat4(m3, m.array);\n            // TODO Not like mat4, mat3 in glmatrix seems to be row-based\n            mat3.transpose(m3, m3);\n            quat.fromMat3(this.array, m3);\n            this._dirty = true;\n            return this;\n        };\n    })(),\n\n    /**\n     * Set to identity quaternion\n     * @return {clay.math.Quaternion}\n     */\n    identity: function () {\n        quat.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Invert self\n     * @return {clay.math.Quaternion}\n     */\n    invert: function () {\n        quat.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function () {\n        return quat.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function () {\n        return quat.length(this.array);\n    },\n\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Quaternion} a\n     * @param  {clay.math.Quaternion} b\n     * @param  {number}  t\n     * @return {clay.math.Quaternion}\n     */\n    lerp: function (a, b, t) {\n        quat.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    mul: function (b) {\n        quat.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Quaternion} a\n     * @return {clay.math.Quaternion}\n     */\n    mulLeft: function (a) {\n        quat.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    multiply: function (b) {\n        quat.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply a and self\n     * Quaternion mutiply is not commutative, so the result of mutiplyLeft is different with multiply.\n     * @param  {clay.math.Quaternion} a\n     * @return {clay.math.Quaternion}\n     */\n    multiplyLeft: function (a) {\n        quat.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Quaternion}\n     */\n    normalize: function () {\n        quat.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about X axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateX: function (rad) {\n        quat.rotateX(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Y axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateY: function (rad) {\n        quat.rotateY(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Z axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateZ: function (rad) {\n        quat.rotateZ(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Sets self to represent the shortest rotation from Vector3 a to Vector3 b.\n     * a and b needs to be normalized\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Quaternion}\n     */\n    rotationTo: function (a, b) {\n        quat.rotationTo(this.array, a.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Sets self with values corresponding to the given axes\n     * @param {clay.math.Vector3} view\n     * @param {clay.math.Vector3} right\n     * @param {clay.math.Vector3} up\n     * @return {clay.math.Quaternion}\n     */\n    setAxes: function (view, right, up) {\n        quat.setAxes(this.array, view.array, right.array, up.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Sets self with a rotation axis and rotation angle\n     * @param {clay.math.Vector3} axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    setAxisAngle: function (axis, rad) {\n        quat.setAxisAngle(this.array, axis.array, rad);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Perform spherical linear interpolation between a and b\n     * @param  {clay.math.Quaternion} a\n     * @param  {clay.math.Quaternion} b\n     * @param  {number} t\n     * @return {clay.math.Quaternion}\n     */\n    slerp: function (a, b, t) {\n        quat.slerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function () {\n        return quat.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function () {\n        return quat.squaredLength(this.array);\n    },\n\n    /**\n     * Set from euler\n     * @param {clay.math.Vector3} v\n     * @param {String} order\n     */\n    fromEuler: function (v, order) {\n        return Quaternion.fromEuler(this, v, order);\n    },\n\n    toString: function () {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Quaternion.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name w\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'w', {\n        get: function () {\n            return this.array[3];\n        },\n        set: function (value) {\n            this.array[3] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.add = function (out, a, b) {\n    quat.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {number}     x\n * @param  {number}     y\n * @param  {number}     z\n * @param  {number}     w\n * @return {clay.math.Quaternion}\n */\nQuaternion.set = function (out, x, y, z, w) {\n    quat.set(out.array, x, y, z, w);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.copy = function (out, b) {\n    quat.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.calculateW = function (out, a) {\n    quat.calculateW(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.conjugate = function (out, a) {\n    quat.conjugate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @return {clay.math.Quaternion}\n */\nQuaternion.identity = function (out) {\n    quat.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.invert = function (out, a) {\n    quat.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {number}\n */\nQuaternion.dot = function (a, b) {\n    return quat.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.len = function (a) {\n    return quat.length(a.array);\n};\n\n// Quaternion.length = Quaternion.len;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @param  {number}     t\n * @return {clay.math.Quaternion}\n */\nQuaternion.lerp = function (out, a, b, t) {\n    quat.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @param  {number}     t\n * @return {clay.math.Quaternion}\n */\nQuaternion.slerp = function (out, a, b, t) {\n    quat.slerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.mul = function (out, a, b) {\n    quat.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.multiply = Quaternion.mul;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateX = function (out, a, rad) {\n    quat.rotateX(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateY = function (out, a, rad) {\n    quat.rotateY(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateZ = function (out, a, rad) {\n    quat.rotateZ(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    axis\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.setAxisAngle = function (out, axis, rad) {\n    quat.setAxisAngle(out.array, axis.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.normalize = function (out, a) {\n    quat.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.sqrLen = function (a) {\n    return quat.sqrLen(a.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.squaredLength = Quaternion.sqrLen;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Matrix3}    m\n * @return {clay.math.Quaternion}\n */\nQuaternion.fromMat3 = function (out, m) {\n    quat.fromMat3(out.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    view\n * @param  {clay.math.Vector3}    right\n * @param  {clay.math.Vector3}    up\n * @return {clay.math.Quaternion}\n */\nQuaternion.setAxes = function (out, view, right, up) {\n    quat.setAxes(out.array, view.array, right.array, up.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    a\n * @param  {clay.math.Vector3}    b\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotationTo = function (out, a, b) {\n    quat.rotationTo(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * Set quaternion from euler\n * @param {clay.math.Quaternion} out\n * @param {clay.math.Vector3} v\n * @param {String} order\n */\nQuaternion.fromEuler = function (out, v, order) {\n\n    out._dirty = true;\n\n    v = v.array;\n    var target = out.array;\n    var c1 = Math.cos(v[0] / 2);\n    var c2 = Math.cos(v[1] / 2);\n    var c3 = Math.cos(v[2] / 2);\n    var s1 = Math.sin(v[0] / 2);\n    var s2 = Math.sin(v[1] / 2);\n    var s3 = Math.sin(v[2] / 2);\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    // http://www.mathworks.com/matlabcentral/fileexchange/\n    //  20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/\n    //  content/SpinCalc.m\n\n    switch (order) {\n        case 'XYZ':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'YXZ':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n        case 'ZXY':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'ZYX':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n        case 'YZX':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'XZY':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n    }\n};\n\nexport default Quaternion;\n","import Base from './core/Base';\nimport Vector3 from './math/Vector3';\nimport Quaternion from './math/Quaternion';\nimport Matrix4 from './math/Matrix4';\nimport glMatrix from './dep/glmatrix';\nimport BoundingBox from './math/BoundingBox';\nvar mat4 = glMatrix.mat4;\n\nvar nameId = 0;\n\n/**\n * @constructor clay.Node\n * @extends clay.core.Base\n */\nvar Node = Base.extend(\n/** @lends clay.Node# */\n{\n    /**\n     * Scene node name\n     * @type {string}\n     */\n    name: '',\n\n    /**\n     * Position relative to its parent node. aka translation.\n     * @type {clay.math.Vector3}\n     */\n    position: null,\n\n    /**\n     * Rotation relative to its parent node. Represented by a quaternion\n     * @type {clay.math.Quaternion}\n     */\n    rotation: null,\n\n    /**\n     * Scale relative to its parent node\n     * @type {clay.math.Vector3}\n     */\n    scale: null,\n\n    /**\n     * Affine transform matrix relative to its root scene.\n     * @type {clay.math.Matrix4}\n     */\n    worldTransform: null,\n\n    /**\n     * Affine transform matrix relative to its parent node.\n     * Composited with position, rotation and scale.\n     * @type {clay.math.Matrix4}\n     */\n    localTransform: null,\n\n    /**\n     * If the local transform is update from SRT(scale, rotation, translation, which is position here) each frame\n     * @type {boolean}\n     */\n    autoUpdateLocalTransform: true,\n\n    /**\n     * Parent of current scene node\n     * @type {?clay.Node}\n     * @private\n     */\n    _parent: null,\n    /**\n     * The root scene mounted. Null if it is a isolated node\n     * @type {?clay.Scene}\n     * @private\n     */\n    _scene: null,\n    /**\n     * @type {boolean}\n     * @private\n     */\n    _needsUpdateWorldTransform: true,\n    /**\n     * @type {boolean}\n     * @private\n     */\n    _inIterating: false,\n\n    // Depth for transparent list sorting\n    __depth: 0\n\n}, function () {\n\n    if (!this.name) {\n        this.name = (this.type || 'NODE') + '_' + (nameId++);\n    }\n\n    if (!this.position) {\n        this.position = new Vector3();\n    }\n    if (!this.rotation) {\n        this.rotation = new Quaternion();\n    }\n    if (!this.scale) {\n        this.scale = new Vector3(1, 1, 1);\n    }\n\n    this.worldTransform = new Matrix4();\n    this.localTransform = new Matrix4();\n\n    this._children = [];\n\n},\n/**@lends clay.Node.prototype. */\n{\n\n    /**\n     * @type {?clay.math.Vector3}\n     * @instance\n     */\n    target: null,\n    /**\n     * If node and its chilren invisible\n     * @type {boolean}\n     * @instance\n     */\n    invisible: false,\n\n    /**\n     * If Node is a skinned mesh\n     * @return {boolean}\n     */\n    isSkinnedMesh: function () {\n        return false;\n    },\n    /**\n     * Return true if it is a renderable scene node, like Mesh and ParticleSystem\n     * @return {boolean}\n     */\n    isRenderable: function () {\n        return false;\n    },\n\n    /**\n     * Set the name of the scene node\n     * @param {string} name\n     */\n    setName: function (name) {\n        var scene = this._scene;\n        if (scene) {\n            var nodeRepository = scene._nodeRepository;\n            delete nodeRepository[this.name];\n            nodeRepository[name] = this;\n        }\n        this.name = name;\n    },\n\n    /**\n     * Add a child node\n     * @param {clay.Node} node\n     */\n    add: function (node) {\n        if (this._inIterating) {\n            console.warn('Add operation can cause unpredictable error when in iterating');\n        }\n        var originalParent = node._parent;\n        if (originalParent === this) {\n            return;\n        }\n        if (originalParent) {\n            originalParent.remove(node);\n        }\n        node._parent = this;\n        this._children.push(node);\n\n        var scene = this._scene;\n        if (scene && scene !== node.scene) {\n            node.traverse(this._addSelfToScene, this);\n        }\n        // Mark children needs update transform\n        // In case child are remove and added again after parent moved\n        node._needsUpdateWorldTransform = true;\n    },\n\n    /**\n     * Remove the given child scene node\n     * @param {clay.Node} node\n     */\n    remove: function (node) {\n        if (this._inIterating) {\n            console.warn('Remove operation can cause unpredictable error when in iterating');\n        }\n        var children = this._children;\n        var idx = children.indexOf(node);\n        if (idx < 0) {\n            return;\n        }\n\n        children.splice(idx, 1);\n        node._parent = null;\n\n        if (this._scene) {\n            node.traverse(this._removeSelfFromScene, this);\n        }\n    },\n\n    /**\n     * Remove all children\n     */\n    removeAll: function () {\n        var children = this._children;\n\n        for (var idx = 0; idx < children.length; idx++) {\n            children[idx]._parent = null;\n\n            if (this._scene) {\n                children[idx].traverse(this._removeSelfFromScene, this);\n            }\n        }\n\n        this._children = [];\n    },\n\n    /**\n     * Get the scene mounted\n     * @return {clay.Scene}\n     */\n    getScene: function () {\n        return this._scene;\n    },\n\n    /**\n     * Get parent node\n     * @return {clay.Scene}\n     */\n    getParent: function () {\n        return this._parent;\n    },\n\n    _removeSelfFromScene: function (descendant) {\n        descendant._scene.removeFromScene(descendant);\n        descendant._scene = null;\n    },\n\n    _addSelfToScene: function (descendant) {\n        this._scene.addToScene(descendant);\n        descendant._scene = this._scene;\n    },\n\n    /**\n     * Return true if it is ancestor of the given scene node\n     * @param {clay.Node} node\n     */\n    isAncestor: function (node) {\n        var parent = node._parent;\n        while(parent) {\n            if (parent === this) {\n                return true;\n            }\n            parent = parent._parent;\n        }\n        return false;\n    },\n\n    /**\n     * Get a new created array of all children nodes\n     * @return {clay.Node[]}\n     */\n    children: function () {\n        return this._children.slice();\n    },\n\n    /**\n     * Get child scene node at given index.\n     * @param {number} idx\n     * @return {clay.Node}\n     */\n    childAt: function (idx) {\n        return this._children[idx];\n    },\n\n    /**\n     * Get first child with the given name\n     * @param {string} name\n     * @return {clay.Node}\n     */\n    getChildByName: function (name) {\n        var children = this._children;\n        for (var i = 0; i < children.length; i++) {\n            if (children[i].name === name) {\n                return children[i];\n            }\n        }\n    },\n\n    /**\n     * Get first descendant have the given name\n     * @param {string} name\n     * @return {clay.Node}\n     */\n    getDescendantByName: function (name) {\n        var children = this._children;\n        for (var i = 0; i < children.length; i++) {\n            var child = children[i];\n            if (child.name === name) {\n                return child;\n            } else {\n                var res = child.getDescendantByName(name);\n                if (res) {\n                    return res;\n                }\n            }\n        }\n    },\n\n    /**\n     * Query descendant node by path\n     * @param {string} path\n     * @return {clay.Node}\n     * @example\n     *  node.queryNode('root/parent/child');\n     */\n    queryNode: function (path) {\n        if (!path) {\n            return;\n        }\n        // TODO Name have slash ?\n        var pathArr = path.split('/');\n        var current = this;\n        for (var i = 0; i < pathArr.length; i++) {\n            var name = pathArr[i];\n            // Skip empty\n            if (!name) {\n                continue;\n            }\n            var found = false;\n            var children = current._children;\n            for (var j = 0; j < children.length; j++) {\n                var child = children[j];\n                if (child.name === name) {\n                    current = child;\n                    found = true;\n                    break;\n                }\n            }\n            // Early return if not found\n            if (!found) {\n                return;\n            }\n        }\n\n        return current;\n    },\n\n    /**\n     * Get query path, relative to rootNode(default is scene)\n     * @param {clay.Node} [rootNode]\n     * @return {string}\n     */\n    getPath: function (rootNode) {\n        if (!this._parent) {\n            return '/';\n        }\n\n        var current = this._parent;\n        var path = this.name;\n        while (current._parent) {\n            path = current.name + '/' + path;\n            if (current._parent == rootNode) {\n                break;\n            }\n            current = current._parent;\n        }\n        if (!current._parent && rootNode) {\n            return null;\n        }\n        return path;\n    },\n\n    /**\n     * Depth first traverse all its descendant scene nodes and\n     * @param {Function} callback\n     * @param {Node} [context]\n     * @param {Function} [filter]\n     */\n    traverse: function (callback, context, filter) {\n\n        this._inIterating = true;\n\n        if (!filter || filter.call(context, this)) {\n            callback.call(context, this);\n        }\n        var _children = this._children;\n        for(var i = 0, len = _children.length; i < len; i++) {\n            _children[i].traverse(callback, context, filter);\n        }\n\n        this._inIterating = false;\n    },\n\n    eachChild: function (callback, context, ctor) {\n        this._inIterating = true;\n\n        var _children = this._children;\n        var noCtor = ctor == null;\n        for(var i = 0, len = _children.length; i < len; i++) {\n            var child = _children[i];\n            if (noCtor || child.constructor === ctor) {\n                callback.call(context, child, i);\n            }\n        }\n\n        this._inIterating = false;\n    },\n\n    /**\n     * Set the local transform and decompose to SRT\n     * @param {clay.math.Matrix4} matrix\n     */\n    setLocalTransform: function (matrix) {\n        mat4.copy(this.localTransform.array, matrix.array);\n        this.decomposeLocalTransform();\n    },\n\n    /**\n     * Decompose the local transform to SRT\n     */\n    decomposeLocalTransform: function (keepScale) {\n        var scale = !keepScale ? this.scale: null;\n        this.localTransform.decomposeMatrix(scale, this.rotation, this.position);\n    },\n\n    /**\n     * Set the world transform and decompose to SRT\n     * @param {clay.math.Matrix4} matrix\n     */\n    setWorldTransform: function (matrix) {\n        mat4.copy(this.worldTransform.array, matrix.array);\n        this.decomposeWorldTransform();\n    },\n\n    /**\n     * Decompose the world transform to SRT\n     * @function\n     */\n    decomposeWorldTransform: (function () {\n\n        var tmp = mat4.create();\n\n        return function (keepScale) {\n            var localTransform = this.localTransform;\n            var worldTransform = this.worldTransform;\n            // Assume world transform is updated\n            if (this._parent) {\n                mat4.invert(tmp, this._parent.worldTransform.array);\n                mat4.multiply(localTransform.array, tmp, worldTransform.array);\n            } else {\n                mat4.copy(localTransform.array, worldTransform.array);\n            }\n            var scale = !keepScale ? this.scale: null;\n            localTransform.decomposeMatrix(scale, this.rotation, this.position);\n        };\n    })(),\n\n    transformNeedsUpdate: function () {\n        return this.position._dirty\n            || this.rotation._dirty\n            || this.scale._dirty;\n    },\n\n    /**\n     * Update local transform from SRT\n     * Notice that local transform will not be updated if _dirty mark of position, rotation, scale is all false\n     */\n    updateLocalTransform: function () {\n        var position = this.position;\n        var rotation = this.rotation;\n        var scale = this.scale;\n\n        if (this.transformNeedsUpdate()) {\n            var m = this.localTransform.array;\n\n            // Transform order, scale->rotation->position\n            mat4.fromRotationTranslation(m, rotation.array, position.array);\n\n            mat4.scale(m, m, scale.array);\n\n            rotation._dirty = false;\n            scale._dirty = false;\n            position._dirty = false;\n\n            this._needsUpdateWorldTransform = true;\n        }\n    },\n\n    /**\n     * Update world transform, assume its parent world transform have been updated\n     * @private\n     */\n    _updateWorldTransformTopDown: function () {\n        var localTransform = this.localTransform.array;\n        var worldTransform = this.worldTransform.array;\n        if (this._parent) {\n            mat4.multiplyAffine(\n                worldTransform,\n                this._parent.worldTransform.array,\n                localTransform\n            );\n        }\n        else {\n            mat4.copy(worldTransform, localTransform);\n        }\n    },\n\n    /**\n     * Update world transform before whole scene is updated.\n     */\n    updateWorldTransform: function () {\n        // Find the root node which transform needs update;\n        var rootNodeIsDirty = this;\n        while (rootNodeIsDirty && rootNodeIsDirty.getParent()\n            && rootNodeIsDirty.getParent().transformNeedsUpdate()\n        ) {\n            rootNodeIsDirty = rootNodeIsDirty.getParent();\n        }2\n        rootNodeIsDirty.update();\n    },\n\n    /**\n     * Update local transform and world transform recursively\n     * @param {boolean} forceUpdateWorld\n     */\n    update: function (forceUpdateWorld) {\n        if (this.autoUpdateLocalTransform) {\n            this.updateLocalTransform();\n        }\n        else {\n            // Transform is manually setted\n            forceUpdateWorld = true;\n        }\n\n        if (forceUpdateWorld || this._needsUpdateWorldTransform) {\n            this._updateWorldTransformTopDown();\n            forceUpdateWorld = true;\n            this._needsUpdateWorldTransform = false;\n        }\n\n        var children = this._children;\n        for(var i = 0, len = children.length; i < len; i++) {\n            children[i].update(forceUpdateWorld);\n        }\n    },\n\n    /**\n     * Get bounding box of node\n     * @param  {Function} [filter]\n     * @param  {clay.math.BoundingBox} [out]\n     * @return {clay.math.BoundingBox}\n     */\n    // TODO Skinning\n    getBoundingBox: (function () {\n        function defaultFilter (el) {\n            return !el.invisible && el.geometry;\n        }\n        var tmpBBox = new BoundingBox();\n        var tmpMat4 = new Matrix4();\n        var invWorldTransform = new Matrix4();\n        return function (filter, out) {\n            out = out || new BoundingBox();\n            filter = filter || defaultFilter;\n\n            if (this._parent) {\n                Matrix4.invert(invWorldTransform, this._parent.worldTransform);\n            }\n            else {\n                Matrix4.identity(invWorldTransform);\n            }\n\n            this.traverse(function (mesh) {\n                if (mesh.geometry && mesh.geometry.boundingBox) {\n                    tmpBBox.copy(mesh.geometry.boundingBox);\n                    Matrix4.multiply(tmpMat4, invWorldTransform, mesh.worldTransform);\n                    tmpBBox.applyTransform(tmpMat4);\n                    out.union(tmpBBox);\n                }\n            }, this, defaultFilter);\n\n            return out;\n        };\n    })(),\n\n    /**\n     * Get world position, extracted from world transform\n     * @param  {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    getWorldPosition: function (out) {\n        // PENDING\n        if (this.transformNeedsUpdate()) {\n            this.updateWorldTransform();\n        }\n        var m = this.worldTransform.array;\n        if (out) {\n            var arr = out.array;\n            arr[0] = m[12];\n            arr[1] = m[13];\n            arr[2] = m[14];\n            return out;\n        }\n        else {\n            return new Vector3(m[12], m[13], m[14]);\n        }\n    },\n\n    /**\n     * Clone a new node\n     * @return {Node}\n     */\n    clone: function () {\n        var node = new this.constructor();\n        var children = this._children;\n\n        node.setName(this.name);\n        node.position.copy(this.position);\n        node.rotation.copy(this.rotation);\n        node.scale.copy(this.scale);\n\n        for (var i = 0; i < children.length; i++) {\n            node.add(children[i].clone());\n        }\n        return node;\n    },\n\n    /**\n     * Rotate the node around a axis by angle degrees, axis passes through point\n     * @param {clay.math.Vector3} point Center point\n     * @param {clay.math.Vector3} axis  Center axis\n     * @param {number}       angle Rotation angle\n     * @see http://docs.unity3d.com/Documentation/ScriptReference/Transform.RotateAround.html\n     * @function\n     */\n    rotateAround: (function () {\n        var v = new Vector3();\n        var RTMatrix = new Matrix4();\n\n        // TODO improve performance\n        return function (point, axis, angle) {\n\n            v.copy(this.position).subtract(point);\n\n            var localTransform = this.localTransform;\n            localTransform.identity();\n            // parent node\n            localTransform.translate(point);\n            localTransform.rotate(angle, axis);\n\n            RTMatrix.fromRotationTranslation(this.rotation, v);\n            localTransform.multiply(RTMatrix);\n            localTransform.scale(this.scale);\n\n            this.decomposeLocalTransform();\n            this._needsUpdateWorldTransform = true;\n        };\n    })(),\n\n    /**\n     * @param {clay.math.Vector3} target\n     * @param {clay.math.Vector3} [up]\n     * @see http://www.opengl.org/sdk/docs/man2/xhtml/gluLookAt.xml\n     * @function\n     */\n    lookAt: (function () {\n        var m = new Matrix4();\n        return function (target, up) {\n            m.lookAt(this.position, target, up || this.localTransform.y).invert();\n            this.setLocalTransform(m);\n\n            this.target = target;\n        };\n    })()\n});\n\nexport default Node;\n","import Node from './Node';\n\n/**\n * @constructor clay.Light\n * @extends clay.Node\n */\nvar Light = Node.extend(function(){\n    return /** @lends clay.Light# */ {\n        /**\n         * Light RGB color\n         * @type {number[]}\n         */\n        color: [1, 1, 1],\n\n        /**\n         * Light intensity\n         * @type {number}\n         */\n        intensity: 1.0,\n\n        // Config for shadow map\n        /**\n         * If light cast shadow\n         * @type {boolean}\n         */\n        castShadow: true,\n\n        /**\n         * Shadow map size\n         * @type {number}\n         */\n        shadowResolution: 512,\n\n        /**\n         * Light group, shader with same `lightGroup` will be affected\n         *\n         * Only useful in forward rendering\n         * @type {number}\n         */\n        group: 0\n    };\n},\n/** @lends clay.Light.prototype. */\n{\n    /**\n     * Light type\n     * @type {string}\n     * @memberOf clay.Light#\n     */\n    type: '',\n\n    /**\n     * @return {clay.Light}\n     * @memberOf clay.Light.prototype\n     */\n    clone: function() {\n        var light = Node.prototype.clone.call(this);\n        light.color = Array.prototype.slice.call(this.color);\n        light.intensity = this.intensity;\n        light.castShadow = this.castShadow;\n        light.shadowResolution = this.shadowResolution;\n\n        return light;\n    }\n});\n\nexport default Light;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor\n * @alias clay.math.Plane\n * @param {clay.math.Vector3} [normal]\n * @param {number} [distance]\n */\nvar Plane = function(normal, distance) {\n    /**\n     * Normal of the plane\n     * @type {clay.math.Vector3}\n     */\n    this.normal = normal || new Vector3(0, 1, 0);\n\n    /**\n     * Constant of the plane equation, used as distance to the origin\n     * @type {number}\n     */\n    this.distance = distance || 0;\n};\n\nPlane.prototype = {\n\n    constructor: Plane,\n\n    /**\n     * Distance from a given point to the plane\n     * @param  {clay.math.Vector3} point\n     * @return {number}\n     */\n    distanceToPoint: function(point) {\n        return vec3.dot(point.array, this.normal.array) - this.distance;\n    },\n\n    /**\n     * Calculate the projection point on the plane\n     * @param  {clay.math.Vector3} point\n     * @param  {clay.math.Vector3} out\n     * @return {clay.math.Vector3}\n     */\n    projectPoint: function(point, out) {\n        if (!out) {\n            out = new Vector3();\n        }\n        var d = this.distanceToPoint(point);\n        vec3.scaleAndAdd(out.array, point.array, this.normal.array, -d);\n        out._dirty = true;\n        return out;\n    },\n\n    /**\n     * Normalize the plane's normal and calculate the distance\n     */\n    normalize: function() {\n        var invLen = 1 / vec3.len(this.normal.array);\n        vec3.scale(this.normal.array, invLen);\n        this.distance *= invLen;\n    },\n\n    /**\n     * If the plane intersect a frustum\n     * @param  {clay.math.Frustum} Frustum\n     * @return {boolean}\n     */\n    intersectFrustum: function(frustum) {\n        // Check if all coords of frustum is on plane all under plane\n        var coords = frustum.vertices;\n        var normal = this.normal.array;\n        var onPlane = vec3.dot(coords[0].array, normal) > this.distance;\n        for (var i = 1; i < 8; i++) {\n            if ((vec3.dot(coords[i].array, normal) > this.distance) != onPlane) {\n                return true;\n            }\n        }\n    },\n\n    /**\n     * Calculate the intersection point between plane and a given line\n     * @function\n     * @param {clay.math.Vector3} start start point of line\n     * @param {clay.math.Vector3} end end point of line\n     * @param {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    intersectLine: (function() {\n        var rd = vec3.create();\n        return function(start, end, out) {\n            var d0 = this.distanceToPoint(start);\n            var d1 = this.distanceToPoint(end);\n            if ((d0 > 0 && d1 > 0) || (d0 < 0 && d1 < 0)) {\n                return null;\n            }\n            // Ray intersection\n            var pn = this.normal.array;\n            var d = this.distance;\n            var ro = start.array;\n            // direction\n            vec3.sub(rd, end.array, start.array);\n            vec3.normalize(rd, rd);\n\n            var divider = vec3.dot(pn, rd);\n            // ray is parallel to the plane\n            if (divider === 0) {\n                return null;\n            }\n            if (!out) {\n                out = new Vector3();\n            }\n            var t = (vec3.dot(pn, ro) - d) / divider;\n            vec3.scaleAndAdd(out.array, ro, rd, -t);\n            out._dirty = true;\n            return out;\n        };\n    })(),\n\n    /**\n     * Apply an affine transform matrix to plane\n     * @function\n     * @return {clay.math.Matrix4}\n     */\n    applyTransform: (function() {\n        var inverseTranspose = mat4.create();\n        var normalv4 = vec4.create();\n        var pointv4 = vec4.create();\n        pointv4[3] = 1;\n        return function(m4) {\n            m4 = m4.array;\n            // Transform point on plane\n            vec3.scale(pointv4, this.normal.array, this.distance);\n            vec4.transformMat4(pointv4, pointv4, m4);\n            this.distance = vec3.dot(pointv4, this.normal.array);\n            // Transform plane normal\n            mat4.invert(inverseTranspose, m4);\n            mat4.transpose(inverseTranspose, inverseTranspose);\n            normalv4[3] = 0;\n            vec3.copy(normalv4, this.normal.array);\n            vec4.transformMat4(normalv4, normalv4, inverseTranspose);\n            vec3.copy(this.normal.array, normalv4);\n        };\n    })(),\n\n    /**\n     * Copy from another plane\n     * @param  {clay.math.Vector3} plane\n     */\n    copy: function(plane) {\n        vec3.copy(this.normal.array, plane.normal.array);\n        this.normal._dirty = true;\n        this.distance = plane.distance;\n    },\n\n    /**\n     * Clone a new plane\n     * @return {clay.math.Plane}\n     */\n    clone: function() {\n        var plane = new Plane();\n        plane.copy(this);\n        return plane;\n    }\n};\n\nexport default Plane;\n","import Vector3 from './Vector3';\nimport BoundingBox from './BoundingBox';\nimport Plane from './Plane';\n\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar vec3Set = vec3.set;\nvar vec3Copy = vec3.copy;\nvar vec3TranformMat4 = vec3.transformMat4;\nvar mathMin = Math.min;\nvar mathMax = Math.max;\n/**\n * @constructor\n * @alias clay.math.Frustum\n */\nvar Frustum = function() {\n\n    /**\n     * Eight planes to enclose the frustum\n     * @type {clay.math.Plane[]}\n     */\n    this.planes = [];\n\n    for (var i = 0; i < 6; i++) {\n        this.planes.push(new Plane());\n    }\n\n    /**\n     * Bounding box of frustum\n     * @type {clay.math.BoundingBox}\n     */\n    this.boundingBox = new BoundingBox();\n\n    /**\n     * Eight vertices of frustum\n     * @type {Float32Array[]}\n     */\n    this.vertices = [];\n    for (var i = 0; i < 8; i++) {\n        this.vertices[i] = vec3.fromValues(0, 0, 0);\n    }\n};\n\nFrustum.prototype = {\n\n    // http://web.archive.org/web/20120531231005/http://crazyjoke.free.fr/doc/3D/plane%20extraction.pdf\n    /**\n     * Set frustum from a projection matrix\n     * @param {clay.math.Matrix4} projectionMatrix\n     */\n    setFromProjection: function(projectionMatrix) {\n\n        var planes = this.planes;\n        var m = projectionMatrix.array;\n        var m0 = m[0], m1 = m[1], m2 = m[2], m3 = m[3];\n        var m4 = m[4], m5 = m[5], m6 = m[6], m7 = m[7];\n        var m8 = m[8], m9 = m[9], m10 = m[10], m11 = m[11];\n        var m12 = m[12], m13 = m[13], m14 = m[14], m15 = m[15];\n\n        // Update planes\n        vec3Set(planes[0].normal.array, m3 - m0, m7 - m4, m11 - m8);\n        planes[0].distance = -(m15 - m12);\n        planes[0].normalize();\n\n        vec3Set(planes[1].normal.array, m3 + m0, m7 + m4, m11 + m8);\n        planes[1].distance = -(m15 + m12);\n        planes[1].normalize();\n\n        vec3Set(planes[2].normal.array, m3 + m1, m7 + m5, m11 + m9);\n        planes[2].distance = -(m15 + m13);\n        planes[2].normalize();\n\n        vec3Set(planes[3].normal.array, m3 - m1, m7 - m5, m11 - m9);\n        planes[3].distance = -(m15 - m13);\n        planes[3].normalize();\n\n        vec3Set(planes[4].normal.array, m3 - m2, m7 - m6, m11 - m10);\n        planes[4].distance = -(m15 - m14);\n        planes[4].normalize();\n\n        vec3Set(planes[5].normal.array, m3 + m2, m7 + m6, m11 + m10);\n        planes[5].distance = -(m15 + m14);\n        planes[5].normalize();\n\n        // Perspective projection\n        var boundingBox = this.boundingBox;\n        if (m15 === 0)  {\n            var aspect = m5 / m0;\n            var zNear = -m14 / (m10 - 1);\n            var zFar = -m14 / (m10 + 1);\n            var farY = -zFar / m5;\n            var nearY = -zNear / m5;\n            // Update bounding box\n            boundingBox.min.set(-farY * aspect, -farY, zFar);\n            boundingBox.max.set(farY * aspect, farY, zNear);\n            // update vertices\n            var vertices = this.vertices;\n            //--- min z\n            // min x\n            vec3Set(vertices[0], -farY * aspect, -farY, zFar);\n            vec3Set(vertices[1], -farY * aspect, farY, zFar);\n            // max x\n            vec3Set(vertices[2], farY * aspect, -farY, zFar);\n            vec3Set(vertices[3], farY * aspect, farY, zFar);\n            //-- max z\n            vec3Set(vertices[4], -nearY * aspect, -nearY, zNear);\n            vec3Set(vertices[5], -nearY * aspect, nearY, zNear);\n            vec3Set(vertices[6], nearY * aspect, -nearY, zNear);\n            vec3Set(vertices[7], nearY * aspect, nearY, zNear);\n        }\n        else { // Orthographic projection\n            var left = (-1 - m12) / m0;\n            var right = (1 - m12) / m0;\n            var top = (1 - m13) / m5;\n            var bottom = (-1 - m13) / m5;\n            var near = (-1 - m14) / m10;\n            var far = (1 - m14) / m10;\n\n\n            boundingBox.min.set(Math.min(left, right), Math.min(bottom, top), Math.min(far, near));\n            boundingBox.max.set(Math.max(right, left), Math.max(top, bottom), Math.max(near, far));\n\n            var min = boundingBox.min.array;\n            var max = boundingBox.max.array;\n            var vertices = this.vertices;\n            //--- min z\n            // min x\n            vec3Set(vertices[0], min[0], min[1], min[2]);\n            vec3Set(vertices[1], min[0], max[1], min[2]);\n            // max x\n            vec3Set(vertices[2], max[0], min[1], min[2]);\n            vec3Set(vertices[3], max[0], max[1], min[2]);\n            //-- max z\n            vec3Set(vertices[4], min[0], min[1], max[2]);\n            vec3Set(vertices[5], min[0], max[1], max[2]);\n            vec3Set(vertices[6], max[0], min[1], max[2]);\n            vec3Set(vertices[7], max[0], max[1], max[2]);\n        }\n    },\n\n    /**\n     * Apply a affine transform matrix and set to the given bounding box\n     * @function\n     * @param {clay.math.BoundingBox}\n     * @param {clay.math.Matrix4}\n     * @return {clay.math.BoundingBox}\n     */\n    getTransformedBoundingBox: (function() {\n\n        var tmpVec3 = vec3.create();\n\n        return function(bbox, matrix) {\n            var vertices = this.vertices;\n\n            var m4 = matrix.array;\n            var min = bbox.min;\n            var max = bbox.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            var v = vertices[0];\n            vec3TranformMat4(tmpVec3, v, m4);\n            vec3Copy(minArr, tmpVec3);\n            vec3Copy(maxArr, tmpVec3);\n\n            for (var i = 1; i < 8; i++) {\n                v = vertices[i];\n                vec3TranformMat4(tmpVec3, v, m4);\n\n                minArr[0] = mathMin(tmpVec3[0], minArr[0]);\n                minArr[1] = mathMin(tmpVec3[1], minArr[1]);\n                minArr[2] = mathMin(tmpVec3[2], minArr[2]);\n\n                maxArr[0] = mathMax(tmpVec3[0], maxArr[0]);\n                maxArr[1] = mathMax(tmpVec3[1], maxArr[1]);\n                maxArr[2] = mathMax(tmpVec3[2], maxArr[2]);\n            }\n\n            min._dirty = true;\n            max._dirty = true;\n\n            return bbox;\n        };\n    }) ()\n};\nexport default Frustum;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar EPSILON = 1e-5;\n\n/**\n * @constructor\n * @alias clay.math.Ray\n * @param {clay.math.Vector3} [origin]\n * @param {clay.math.Vector3} [direction]\n */\nvar Ray = function (origin, direction) {\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.origin = origin || new Vector3();\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.direction = direction || new Vector3();\n};\n\nRay.prototype = {\n\n    constructor: Ray,\n\n    // http://www.siggraph.org/education/materials/HyperGraph/raytrace/rayplane_intersection.htm\n    /**\n     * Calculate intersection point between ray and a give plane\n     * @param  {clay.math.Plane} plane\n     * @param  {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    intersectPlane: function (plane, out) {\n        var pn = plane.normal.array;\n        var d = plane.distance;\n        var ro = this.origin.array;\n        var rd = this.direction.array;\n\n        var divider = vec3.dot(pn, rd);\n        // ray is parallel to the plane\n        if (divider === 0) {\n            return null;\n        }\n        if (!out) {\n            out = new Vector3();\n        }\n        var t = (vec3.dot(pn, ro) - d) / divider;\n        vec3.scaleAndAdd(out.array, ro, rd, -t);\n        out._dirty = true;\n        return out;\n    },\n\n    /**\n     * Mirror the ray against plane\n     * @param  {clay.math.Plane} plane\n     */\n    mirrorAgainstPlane: function (plane) {\n        // Distance to plane\n        var d = vec3.dot(plane.normal.array, this.direction.array);\n        vec3.scaleAndAdd(this.direction.array, this.direction.array, plane.normal.array, -d * 2);\n        this.direction._dirty = true;\n    },\n\n    distanceToPoint: (function () {\n        var v = vec3.create();\n        return function (point) {\n            vec3.sub(v, point, this.origin.array);\n            // Distance from projection point to origin\n            var b = vec3.dot(v, this.direction.array);\n            if (b < 0) {\n                return vec3.distance(this.origin.array, point);\n            }\n            // Squared distance from center to origin\n            var c2 = vec3.lenSquared(v);\n            // Squared distance from center to projection point\n            return Math.sqrt(c2 - b * b);\n        };\n    })(),\n\n    /**\n     * Calculate intersection point between ray and sphere\n     * @param  {clay.math.Vector3} center\n     * @param  {number} radius\n     * @param  {clay.math.Vector3} out\n     * @return {clay.math.Vector3}\n     */\n    intersectSphere: (function () {\n        var v = vec3.create();\n        return function (center, radius, out) {\n            var origin = this.origin.array;\n            var direction = this.direction.array;\n            center = center.array;\n            vec3.sub(v, center, origin);\n            // Distance from projection point to origin\n            var b = vec3.dot(v, direction);\n            // Squared distance from center to origin\n            var c2 = vec3.squaredLength(v);\n            // Squared distance from center to projection point\n            var d2 = c2 - b * b;\n\n            var r2 = radius * radius;\n            // No intersection\n            if (d2 > r2) {\n                return;\n            }\n\n            var a = Math.sqrt(r2 - d2);\n            // First intersect point\n            var t0 = b - a;\n            // Second intersect point\n            var t1 = b + a;\n\n            if (!out) {\n                out = new Vector3();\n            }\n            if (t0 < 0) {\n                if (t1 < 0) {\n                    return null;\n                }\n                else {\n                    vec3.scaleAndAdd(out.array, origin, direction, t1);\n                    return out;\n                }\n            }\n            else {\n                vec3.scaleAndAdd(out.array, origin, direction, t0);\n                return out;\n            }\n        };\n    })(),\n\n    // http://www.scratchapixel.com/lessons/3d-basic-lessons/lesson-7-intersecting-simple-shapes/ray-box-intersection/\n    /**\n     * Calculate intersection point between ray and bounding box\n     * @param {clay.math.BoundingBox} bbox\n     * @param {clay.math.Vector3}\n     * @return {clay.math.Vector3}\n     */\n    intersectBoundingBox: function (bbox, out) {\n        var dir = this.direction.array;\n        var origin = this.origin.array;\n        var min = bbox.min.array;\n        var max = bbox.max.array;\n\n        var invdirx = 1 / dir[0];\n        var invdiry = 1 / dir[1];\n        var invdirz = 1 / dir[2];\n\n        var tmin, tmax, tymin, tymax, tzmin, tzmax;\n        if (invdirx >= 0) {\n            tmin = (min[0] - origin[0]) * invdirx;\n            tmax = (max[0] - origin[0]) * invdirx;\n        }\n        else {\n            tmax = (min[0] - origin[0]) * invdirx;\n            tmin = (max[0] - origin[0]) * invdirx;\n        }\n        if (invdiry >= 0) {\n            tymin = (min[1] - origin[1]) * invdiry;\n            tymax = (max[1] - origin[1]) * invdiry;\n        }\n        else {\n            tymax = (min[1] - origin[1]) * invdiry;\n            tymin = (max[1] - origin[1]) * invdiry;\n        }\n\n        if ((tmin > tymax) || (tymin > tmax)) {\n            return null;\n        }\n\n        if (tymin > tmin || tmin !== tmin) {\n            tmin = tymin;\n        }\n        if (tymax < tmax || tmax !== tmax) {\n            tmax = tymax;\n        }\n\n        if (invdirz >= 0) {\n            tzmin = (min[2] - origin[2]) * invdirz;\n            tzmax = (max[2] - origin[2]) * invdirz;\n        }\n        else {\n            tzmax = (min[2] - origin[2]) * invdirz;\n            tzmin = (max[2] - origin[2]) * invdirz;\n        }\n\n        if ((tmin > tzmax) || (tzmin > tmax)) {\n            return null;\n        }\n\n        if (tzmin > tmin || tmin !== tmin) {\n            tmin = tzmin;\n        }\n        if (tzmax < tmax || tmax !== tmax) {\n            tmax = tzmax;\n        }\n        if (tmax < 0) {\n            return null;\n        }\n\n        var t = tmin >= 0 ? tmin : tmax;\n\n        if (!out) {\n            out = new Vector3();\n        }\n        vec3.scaleAndAdd(out.array, origin, dir, t);\n        return out;\n    },\n\n    // http://en.wikipedia.org/wiki/M%C3%B6ller%E2%80%93Trumbore_intersection_algorithm\n    /**\n     * Calculate intersection point between ray and three triangle vertices\n     * @param {clay.math.Vector3} a\n     * @param {clay.math.Vector3} b\n     * @param {clay.math.Vector3} c\n     * @param {boolean}           singleSided, CW triangle will be ignored\n     * @param {clay.math.Vector3} [out]\n     * @param {clay.math.Vector3} [barycenteric] barycentric coords\n     * @return {clay.math.Vector3}\n     */\n    intersectTriangle: (function () {\n\n        var eBA = vec3.create();\n        var eCA = vec3.create();\n        var AO = vec3.create();\n        var vCross = vec3.create();\n\n        return function (a, b, c, singleSided, out, barycenteric) {\n            var dir = this.direction.array;\n            var origin = this.origin.array;\n            a = a.array;\n            b = b.array;\n            c = c.array;\n\n            vec3.sub(eBA, b, a);\n            vec3.sub(eCA, c, a);\n\n            vec3.cross(vCross, eCA, dir);\n\n            var det = vec3.dot(eBA, vCross);\n\n            if (singleSided) {\n                if (det > -EPSILON) {\n                    return null;\n                }\n            }\n            else {\n                if (det > -EPSILON && det < EPSILON) {\n                    return null;\n                }\n            }\n\n            vec3.sub(AO, origin, a);\n            var u = vec3.dot(vCross, AO) / det;\n            if (u < 0 || u > 1) {\n                return null;\n            }\n\n            vec3.cross(vCross, eBA, AO);\n            var v = vec3.dot(dir, vCross) / det;\n\n            if (v < 0 || v > 1 || (u + v > 1)) {\n                return null;\n            }\n\n            vec3.cross(vCross, eBA, eCA);\n            var t = -vec3.dot(AO, vCross) / det;\n\n            if (t < 0) {\n                return null;\n            }\n\n            if (!out) {\n                out = new Vector3();\n            }\n            if (barycenteric) {\n                Vector3.set(barycenteric, (1 - u - v), u, v);\n            }\n            vec3.scaleAndAdd(out.array, origin, dir, t);\n\n            return out;\n        };\n    })(),\n\n    /**\n     * Apply an affine transform matrix to the ray\n     * @return {clay.math.Matrix4} matrix\n     */\n    applyTransform: function (matrix) {\n        Vector3.add(this.direction, this.direction, this.origin);\n        Vector3.transformMat4(this.origin, this.origin, matrix);\n        Vector3.transformMat4(this.direction, this.direction, matrix);\n\n        Vector3.sub(this.direction, this.direction, this.origin);\n        Vector3.normalize(this.direction, this.direction);\n    },\n\n    /**\n     * Copy values from another ray\n     * @param {clay.math.Ray} ray\n     */\n    copy: function (ray) {\n        Vector3.copy(this.origin, ray.origin);\n        Vector3.copy(this.direction, ray.direction);\n    },\n\n    /**\n     * Clone a new ray\n     * @return {clay.math.Ray}\n     */\n    clone: function () {\n        var ray = new Ray();\n        ray.copy(this);\n        return ray;\n    }\n};\n\nexport default Ray;\n","import Node from './Node';\nimport Matrix4 from './math/Matrix4';\nimport Frustum from './math/Frustum';\nimport Ray from './math/Ray';\n\nimport glMatrix from './dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor clay.Camera\n * @extends clay.Node\n */\nvar Camera = Node.extend(function () {\n    return /** @lends clay.Camera# */ {\n        /**\n         * Camera projection matrix\n         * @type {clay.math.Matrix4}\n         */\n        projectionMatrix: new Matrix4(),\n\n        /**\n         * Inverse of camera projection matrix\n         * @type {clay.math.Matrix4}\n         */\n        invProjectionMatrix: new Matrix4(),\n\n        /**\n         * View matrix, equal to inverse of camera's world matrix\n         * @type {clay.math.Matrix4}\n         */\n        viewMatrix: new Matrix4(),\n\n        /**\n         * Camera frustum in view space\n         * @type {clay.math.Frustum}\n         */\n        frustum: new Frustum()\n    };\n}, function () {\n    this.update(true);\n},\n/** @lends clay.Camera.prototype */\n{\n\n    update: function (force) {\n        Node.prototype.update.call(this, force);\n        Matrix4.invert(this.viewMatrix, this.worldTransform);\n\n        this.updateProjectionMatrix();\n        Matrix4.invert(this.invProjectionMatrix, this.projectionMatrix);\n\n        this.frustum.setFromProjection(this.projectionMatrix);\n    },\n\n    /**\n     * Set camera view matrix\n     */\n    setViewMatrix: function (viewMatrix) {\n        Matrix4.copy(this.viewMatrix, viewMatrix);\n        Matrix4.invert(this.worldTransform, viewMatrix);\n        this.decomposeWorldTransform();\n    },\n\n    /**\n     * Decompose camera projection matrix\n     */\n    decomposeProjectionMatrix: function () {},\n\n    /**\n     * Set camera projection matrix\n     * @param {clay.math.Matrix4} projectionMatrix\n     */\n    setProjectionMatrix: function (projectionMatrix) {\n        Matrix4.copy(this.projectionMatrix, projectionMatrix);\n        Matrix4.invert(this.invProjectionMatrix, projectionMatrix);\n        this.decomposeProjectionMatrix();\n    },\n    /**\n     * Update projection matrix, called after update\n     */\n    updateProjectionMatrix: function () {},\n\n    /**\n     * Cast a picking ray from camera near plane to far plane\n     * @function\n     * @param {clay.math.Vector2} ndc\n     * @param {clay.math.Ray} [out]\n     * @return {clay.math.Ray}\n     */\n    castRay: (function () {\n        var v4 = vec4.create();\n        return function (ndc, out) {\n            var ray = out !== undefined ? out : new Ray();\n            var x = ndc.array[0];\n            var y = ndc.array[1];\n            vec4.set(v4, x, y, -1, 1);\n            vec4.transformMat4(v4, v4, this.invProjectionMatrix.array);\n            vec4.transformMat4(v4, v4, this.worldTransform.array);\n            vec3.scale(ray.origin.array, v4, 1 / v4[3]);\n\n            vec4.set(v4, x, y, 1, 1);\n            vec4.transformMat4(v4, v4, this.invProjectionMatrix.array);\n            vec4.transformMat4(v4, v4, this.worldTransform.array);\n            vec3.scale(v4, v4, 1 / v4[3]);\n            vec3.sub(ray.direction.array, v4, ray.origin.array);\n\n            vec3.normalize(ray.direction.array, ray.direction.array);\n            ray.direction._dirty = true;\n            ray.origin._dirty = true;\n\n            return ray;\n        };\n    })()\n\n    /**\n     * @function\n     * @name clone\n     * @return {clay.Camera}\n     * @memberOf clay.Camera.prototype\n     */\n});\n\nexport default Camera;\n","import Node from './Node';\nimport Light from './Light';\nimport Camera from './Camera';\nimport BoundingBox from './math/BoundingBox';\nimport util from './core/util';\n\nvar programKeyCache = {};\n\nfunction getProgramKey(lightNumbers) {\n    var defineStr = [];\n    var lightTypes = Object.keys(lightNumbers);\n    lightTypes.sort();\n    for (var i = 0; i < lightTypes.length; i++) {\n        var lightType = lightNumbers[i];\n        defineStr.push(lightType + ' ' + lightNumbers[lightType]);\n    }\n    var key = defineStr.join('\\n');\n\n    if (programKeyCache[key]) {\n        return programKeyCache[key];\n    }\n\n    var id = util.genGUID();\n    programKeyCache[key] = id;\n    return id;\n}\n\n/**\n * @constructor clay.Scene\n * @extends clay.Node\n */\nvar Scene = Node.extend(function () {\n    return /** @lends clay.Scene# */ {\n        /**\n         * Global material of scene\n         * @type {clay.Material}\n         */\n        material: null,\n\n        /**\n         * @type {boolean}\n         */\n        autoUpdate: true,\n\n        /**\n         * Opaque renderable list, it will be updated automatically\n         * @type {clay.Renderable[]}\n         * @readonly\n         */\n        opaqueList: [],\n\n        /**\n         * Opaque renderable list, it will be updated automatically\n         * @type {clay.Renderable[]}\n         * @readonly\n         */\n        transparentList: [],\n\n        lights: [],\n\n\n        /**\n         * Scene bounding box in view space.\n         * Used when camera needs to adujst the near and far plane automatically\n         * so that the view frustum contains the visible objects as tightly as possible.\n         * Notice:\n         *  It is updated after rendering (in the step of frustum culling passingly). So may be not so accurate, but saves a lot of calculation\n         *\n         * @type {clay.math.BoundingBox}\n         */\n        viewBoundingBoxLastFrame: new BoundingBox(),\n\n        // Uniforms for shadow map.\n        shadowUniforms: {},\n\n        _cameraList: [],\n\n        // Properties to save the light information in the scene\n        // Will be set in the render function\n        _lightUniforms: {},\n\n        _previousLightNumber: {},\n\n        _lightNumber: {\n            // groupId: {\n                // POINT_LIGHT: 0,\n                // DIRECTIONAL_LIGHT: 0,\n                // SPOT_LIGHT: 0,\n                // AMBIENT_LIGHT: 0,\n                // AMBIENT_SH_LIGHT: 0\n            // }\n        },\n\n        _lightProgramKeys: {},\n\n        _opaqueObjectCount: 0,\n        _transparentObjectCount: 0,\n\n        _nodeRepository: {},\n\n    };\n}, function () {\n    this._scene = this;\n},\n/** @lends clay.Scene.prototype. */\n{\n    /**\n     * Add node to scene\n     * @param {Node} node\n     */\n    addToScene: function (node) {\n        if (node instanceof Camera) {\n            if (this._cameraList.length > 0) {\n                console.warn('Found multiple camera in one scene. Use the fist one.');\n            }\n            this._cameraList.push(node);\n        }\n        if (node.name) {\n            this._nodeRepository[node.name] = node;\n        }\n    },\n\n    /**\n     * Remove node from scene\n     * @param {Node} node\n     */\n    removeFromScene: function (node) {\n        if (node instanceof Camera) {\n            var idx = this._cameraList.indexOf(node);\n            if (idx >= 0) {\n                this._cameraList.splice(idx, 1);\n            }\n        }\n        if (node.name) {\n            delete this._nodeRepository[node.name];\n        }\n    },\n\n    /**\n     * Get node by name\n     * @param  {string} name\n     * @return {Node}\n     * @DEPRECATED\n     */\n    getNode: function (name) {\n        return this._nodeRepository[name];\n    },\n\n    /**\n     * Clone a new scene node recursively, including material, skeleton.\n     * Shader and geometry instances will not been cloned\n     * @param  {clay.Node} node\n     * @return {clay.Node}\n     */\n    cloneNode: function (node) {\n        var newNode = node.clone();\n        var materialsMap = {};\n\n        var cloneSkeleton = function (current, currentNew) {\n            if (current.skeleton) {\n                currentNew.skeleton = current.skeleton.clone(node, newNode);\n                currentNew.joints = current.joints.slice();\n            }\n            if (current.material) {\n                materialsMap[current.material.__uid__] = {\n                    oldMat: current.material\n                };\n            }\n            for (var i = 0; i < current._children.length; i++) {\n                cloneSkeleton(current._children[i], currentNew._children[i]);\n            }\n        };\n\n        cloneSkeleton(node, newNode);\n\n        for (var guid in materialsMap) {\n            materialsMap[guid].newMat = materialsMap[guid].oldMat.clone();\n        }\n\n        // Replace material\n        newNode.traverse(function (current) {\n            if (current.material) {\n                current.material = materialsMap[current.material.__uid__].newMat;\n            }\n        });\n\n        return newNode;\n    },\n\n\n    /**\n     * Scene update\n     * @param  {boolean} force\n     * @param  {boolean} notUpdateLights\n     *         Useful in deferred pipeline\n     */\n    update: function (force, notUpdateLights) {\n        if (!(this.autoUpdate || force)) {\n            return;\n        }\n        Node.prototype.update.call(this, force);\n\n        var lights = this.lights;\n        var sceneMaterialTransparent = this.material && this.material.transparent;\n\n        this._opaqueObjectCount = 0;\n        this._transparentObjectCount = 0;\n\n        lights.length = 0;\n\n        this._updateRenderList(this, sceneMaterialTransparent);\n\n        this.opaqueList.length = this._opaqueObjectCount;\n        this.transparentList.length = this._transparentObjectCount;\n\n        // reset\n        if (!notUpdateLights) {\n            this._previousLightNumber = this._lightNumber;\n\n            var lightNumber = {};\n            for (var i = 0; i < lights.length; i++) {\n                var light = lights[i];\n                var group = light.group;\n                if (!lightNumber[group]) {\n                    lightNumber[group] = {};\n                }\n                // User can use any type of light\n                lightNumber[group][light.type] = lightNumber[group][light.type] || 0;\n                lightNumber[group][light.type]++;\n            }\n            this._lightNumber = lightNumber;\n\n            for (var groupId in lightNumber) {\n                this._lightProgramKeys[groupId] = getProgramKey(lightNumber[groupId]);\n            }\n\n            this._updateLightUniforms();\n        }\n    },\n\n    getMainCamera: function () {\n        return this._cameraList[0];\n    },\n\n    // Traverse the scene and add the renderable\n    // object to the render list\n    _updateRenderList: function (parent, sceneMaterialTransparent) {\n        if (parent.invisible) {\n            return;\n        }\n\n        for (var i = 0; i < parent._children.length; i++) {\n            var child = parent._children[i];\n\n            if (child instanceof Light) {\n                this.lights.push(child);\n            }\n            else if (child.isRenderable()) {\n                if (child.material.transparent || sceneMaterialTransparent) {\n                    this.transparentList[this._transparentObjectCount++] = child;\n                }\n                else {\n                    this.opaqueList[this._opaqueObjectCount++] = child;\n                }\n            }\n            if (child._children.length > 0) {\n                this._updateRenderList(child);\n            }\n        }\n    },\n\n    _updateLightUniforms: function () {\n        var lights = this.lights;\n        // Put the light cast shadow before the light not cast shadow\n        lights.sort(lightSortFunc);\n\n        var lightUniforms = this._lightUniforms;\n        for (var group in lightUniforms) {\n            for (var symbol in lightUniforms[group]) {\n                lightUniforms[group][symbol].value.length = 0;\n            }\n        }\n        for (var i = 0; i < lights.length; i++) {\n\n            var light = lights[i];\n            var group = light.group;\n\n            for (var symbol in light.uniformTemplates) {\n                var uniformTpl = light.uniformTemplates[symbol];\n                var value = uniformTpl.value(light);\n                if (value == null) {\n                    continue;\n                }\n                if (!lightUniforms[group]) {\n                    lightUniforms[group] = {};\n                }\n                if (!lightUniforms[group][symbol]) {\n                    lightUniforms[group][symbol] = {\n                        type: '',\n                        value: []\n                    };\n                }\n                var lu = lightUniforms[group][symbol];\n                lu.type = uniformTpl.type + 'v';\n                switch (uniformTpl.type) {\n                    case '1i':\n                    case '1f':\n                    case 't':\n                        lu.value.push(value);\n                        break;\n                    case '2f':\n                    case '3f':\n                    case '4f':\n                        for (var j = 0; j < value.length; j++) {\n                            lu.value.push(value[j]);\n                        }\n                        break;\n                    default:\n                        console.error('Unkown light uniform type ' + uniformTpl.type);\n                }\n            }\n        }\n    },\n\n    getLightGroups: function () {\n        var lightGroups = [];\n        for (var groupId in this._lightNumber) {\n            lightGroups.push(groupId);\n        }\n        return lightGroups;\n    },\n\n    getNumberChangedLightGroups: function () {\n        var lightGroups = [];\n        for (var groupId in this._lightNumber) {\n            if (this.isLightNumberChanged(groupId)) {\n                lightGroups.push(groupId);\n            }\n        }\n        return lightGroups;\n    },\n\n    /**\n     * Determine if light group is different with since last frame\n     * Used to determine whether to update shader and scene's uniforms in Renderer.render\n     * @param {Shader} shader\n     * @returns {Boolean}\n     */\n    isLightNumberChanged: function (lightGroup) {\n        var prevLightNumber = this._previousLightNumber;\n        var currentLightNumber = this._lightNumber;\n        // PENDING Performance\n        for (var type in currentLightNumber[lightGroup]) {\n            if (!prevLightNumber[lightGroup]) {\n                return true;\n            }\n            if (currentLightNumber[lightGroup][type] !== prevLightNumber[lightGroup][type]) {\n                return true;\n            }\n        }\n        for (var type in prevLightNumber[lightGroup]) {\n            if (!currentLightNumber[lightGroup]) {\n                return true;\n            }\n            if (currentLightNumber[lightGroup][type] !== prevLightNumber[lightGroup][type]) {\n                return true;\n            }\n        }\n        return false;\n    },\n\n    /**\n     * Set shader's light group with scene's\n     * @param {Shader} shader\n     */\n    getLightsNumbers: function (lightGroup) {\n        return this._lightNumber[lightGroup];\n    },\n\n    getProgramKey: function (lightGroup) {\n        return this._lightProgramKeys[lightGroup];\n    },\n\n    setLightUniforms: (function () {\n        function setUniforms(uniforms, program, renderer) {\n            for (var symbol in uniforms) {\n                var lu = uniforms[symbol];\n                if (lu.type === 'tv') {\n                    if (!program.hasUniform(symbol)) {\n                        continue;\n                    }\n                    var texSlots = [];\n                    for (var i = 0; i < lu.value.length; i++) {\n                        var texture = lu.value[i];\n                        var slot = program.takeCurrentTextureSlot(renderer, texture);\n                        texSlots.push(slot);\n                    }\n                    program.setUniform(renderer.gl, '1iv', symbol, texSlots);\n                }\n                else {\n                    program.setUniform(renderer.gl, lu.type, symbol, lu.value);\n                }\n            }\n        }\n\n        return function (program, lightGroup, renderer) {\n            setUniforms(this._lightUniforms[lightGroup], program, renderer);\n            // Set shadows\n            setUniforms(this.shadowUniforms, program, renderer);\n        };\n    })(),\n\n    /**\n     * Dispose self, clear all the scene objects\n     * But resources of gl like texuture, shader will not be disposed.\n     * Mostly you should use disposeScene method in Renderer to do dispose.\n     */\n    dispose: function () {\n        this.material = null;\n        this.opaqueList = [];\n        this.transparentList = [];\n\n        this.lights = [];\n\n        this._lightUniforms = {};\n\n        this._lightNumber = {};\n        this._nodeRepository = {};\n    }\n});\n\nfunction lightSortFunc(a, b) {\n    if (b.castShadow && !a.castShadow) {\n        return true;\n    }\n}\n\nexport default Scene;\n","import Base from './core/Base';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\nimport vendor from './core/vendor';\nimport glMatrix from './dep/glmatrix';\nimport BoundingBox from './math/BoundingBox';\n\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\n\nvar vec3Create = vec3.create;\nvar vec3Add = vec3.add;\nvar vec3Set = vec3.set;\n\nfunction getArrayCtorByType (type) {\n    return ({\n        'byte': vendor.Int8Array,\n        'ubyte': vendor.Uint8Array,\n        'short': vendor.Int16Array,\n        'ushort': vendor.Uint16Array\n    })[type] || vendor.Float32Array;\n}\n\nfunction makeAttrKey(attrName) {\n    return 'attr_' + attrName;\n}\n/**\n * Geometry attribute\n * @alias clay.Geometry.Attribute\n * @constructor\n */\nfunction Attribute(name, type, size, semantic) {\n    /**\n     * Attribute name\n     * @type {string}\n     */\n    this.name = name;\n    /**\n     * Attribute type\n     * Possible values:\n     *  + `'byte'`\n     *  + `'ubyte'`\n     *  + `'short'`\n     *  + `'ushort'`\n     *  + `'float'` Most commonly used.\n     * @type {string}\n     */\n    this.type = type;\n    /**\n     * Size of attribute component. 1 - 4.\n     * @type {number}\n     */\n    this.size = size;\n    /**\n     * Semantic of this attribute.\n     * Possible values:\n     *  + `'POSITION'`\n     *  + `'NORMAL'`\n     *  + `'BINORMAL'`\n     *  + `'TANGENT'`\n     *  + `'TEXCOORD'`\n     *  + `'TEXCOORD_0'`\n     *  + `'TEXCOORD_1'`\n     *  + `'COLOR'`\n     *  + `'JOINT'`\n     *  + `'WEIGHT'`\n     *\n     * In shader, attribute with same semantic will be automatically mapped. For example:\n     * ```glsl\n     * attribute vec3 pos: POSITION\n     * ```\n     * will use the attribute value with semantic POSITION in geometry, no matter what name it used.\n     * @type {string}\n     */\n    this.semantic = semantic || '';\n\n    /**\n     * Value of the attribute.\n     * @type {TypedArray}\n     */\n    this.value = null;\n\n    // Init getter setter\n    switch (size) {\n        case 1:\n            this.get = function (idx) {\n                return this.value[idx];\n            };\n            this.set = function (idx, value) {\n                this.value[idx] = value;\n            };\n            // Copy from source to target\n            this.copy = function (target, source) {\n                this.value[target] = this.value[target];\n            };\n            break;\n        case 2:\n            this.get = function (idx, out) {\n                var arr = this.value;\n                out[0] = arr[idx * 2];\n                out[1] = arr[idx * 2 + 1];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var arr = this.value;\n                arr[idx * 2] = val[0];\n                arr[idx * 2 + 1] = val[1];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 2;\n                target *= 2;\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n            };\n            break;\n        case 3:\n            this.get = function (idx, out) {\n                var idx3 = idx * 3;\n                var arr = this.value;\n                out[0] = arr[idx3];\n                out[1] = arr[idx3 + 1];\n                out[2] = arr[idx3 + 2];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var idx3 = idx * 3;\n                var arr = this.value;\n                arr[idx3] = val[0];\n                arr[idx3 + 1] = val[1];\n                arr[idx3 + 2] = val[2];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 3;\n                target *= 3;\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n                arr[target + 2] = arr[source + 2];\n            };\n            break;\n        case 4:\n            this.get = function (idx, out) {\n                var arr = this.value;\n                var idx4 = idx * 4;\n                out[0] = arr[idx4];\n                out[1] = arr[idx4 + 1];\n                out[2] = arr[idx4 + 2];\n                out[3] = arr[idx4 + 3];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var arr = this.value;\n                var idx4 = idx * 4;\n                arr[idx4] = val[0];\n                arr[idx4 + 1] = val[1];\n                arr[idx4 + 2] = val[2];\n                arr[idx4 + 3] = val[3];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 4;\n                target *= 4;\n                // copyWithin is extremely slow\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n                arr[target + 2] = arr[source + 2];\n                arr[target + 3] = arr[source + 3];\n            };\n    }\n}\n\n/**\n * Set item value at give index. Second parameter val is number if size is 1\n * @function\n * @name clay.Geometry.Attribute#set\n * @param {number} idx\n * @param {number[]|number} val\n * @example\n * geometry.getAttribute('position').set(0, [1, 1, 1]);\n */\n\n/**\n * Get item value at give index. Second parameter out is no need if size is 1\n * @function\n * @name clay.Geometry.Attribute#set\n * @param {number} idx\n * @param {number[]} [out]\n * @example\n * geometry.getAttribute('position').get(0, out);\n */\n\n/**\n * Initialize attribute with given vertex count\n * @param {number} nVertex\n */\nAttribute.prototype.init = function (nVertex) {\n    if (!this.value || this.value.length != nVertex * this.size) {\n        var ArrayConstructor = getArrayCtorByType(this.type);\n        this.value = new ArrayConstructor(nVertex * this.size);\n    }\n};\n\n/**\n * Initialize attribute with given array. Which can be 1 dimensional or 2 dimensional\n * @param {Array} array\n * @example\n *  geometry.getAttribute('position').fromArray(\n *      [-1, 0, 0, 1, 0, 0, 0, 1, 0]\n *  );\n *  geometry.getAttribute('position').fromArray(\n *      [ [-1, 0, 0], [1, 0, 0], [0, 1, 0] ]\n *  );\n */\nAttribute.prototype.fromArray = function (array) {\n    var ArrayConstructor = getArrayCtorByType(this.type);\n    var value;\n    // Convert 2d array to flat\n    if (array[0] && (array[0].length)) {\n        var n = 0;\n        var size = this.size;\n        value = new ArrayConstructor(array.length * size);\n        for (var i = 0; i < array.length; i++) {\n            for (var j = 0; j < size; j++) {\n                value[n++] = array[i][j];\n            }\n        }\n    }\n    else {\n        value = new ArrayConstructor(array);\n    }\n    this.value = value;\n};\n\nAttribute.prototype.clone = function(copyValue) {\n    var ret = new Attribute(this.name, this.type, this.size, this.semantic);\n    // FIXME\n    if (copyValue) {\n        console.warn('todo');\n    }\n    return ret;\n};\n\nfunction AttributeBuffer(name, type, buffer, size, semantic) {\n    this.name = name;\n    this.type = type;\n    this.buffer = buffer;\n    this.size = size;\n    this.semantic = semantic;\n\n    // To be set in mesh\n    // symbol in the shader\n    this.symbol = '';\n\n    // Needs remove flag\n    this.needsRemove = false;\n}\n\nfunction IndicesBuffer(buffer) {\n    this.buffer = buffer;\n    this.count = 0;\n}\n\n/**\n * @constructor clay.Geometry\n * @extends clay.core.Base\n */\nvar Geometry = Base.extend(function () {\n    return /** @lends clay.Geometry# */ {\n        /**\n         * Attributes of geometry. Including:\n         *  + `position`\n         *  + `texcoord0`\n         *  + `texcoord1`\n         *  + `normal`\n         *  + `tangent`\n         *  + `color`\n         *  + `weight`\n         *  + `joint`\n         *  + `barycentric`\n         * @type {Object}\n         */\n        attributes: {\n            position: new Attribute('position', 'float', 3, 'POSITION'),\n            texcoord0: new Attribute('texcoord0', 'float', 2, 'TEXCOORD_0'),\n            texcoord1: new Attribute('texcoord1', 'float', 2, 'TEXCOORD_1'),\n            normal: new Attribute('normal', 'float', 3, 'NORMAL'),\n            tangent: new Attribute('tangent', 'float', 4, 'TANGENT'),\n            color: new Attribute('color', 'float', 4, 'COLOR'),\n            // Skinning attributes\n            // Each vertex can be bind to 4 bones, because the\n            // sum of weights is 1, so the weights is stored in vec3 and the last\n            // can be calculated by 1-w.x-w.y-w.z\n            weight: new Attribute('weight', 'float', 3, 'WEIGHT'),\n            joint: new Attribute('joint', 'float', 4, 'JOINT'),\n            // For wireframe display\n            // http://codeflow.org/entries/2012/aug/02/easy-wireframe-display-with-barycentric-coordinates/\n            barycentric: new Attribute('barycentric', 'float', 3, null),\n        },\n        /**\n         * Calculated bounding box of geometry.\n         * @type {clay.math.BoundingBox}\n         */\n        boundingBox: null,\n\n        /**\n         * Indices of geometry.\n         * @type {Uint16Array|Uint32Array}\n         */\n        indices: null,\n\n        /**\n         * Is vertices data dynamically updated.\n         * Attributes value can't be changed after first render if dyanmic is false.\n         * @type {boolean}\n         */\n        dynamic: true,\n\n        _enabledAttributes: null\n    };\n}, function() {\n    // Use cache\n    this._cache = new Cache();\n\n    this._attributeList = Object.keys(this.attributes);\n},\n/** @lends clay.Geometry.prototype */\n{\n    /**\n     * Main attribute will be used to count vertex number\n     * @type {string}\n     */\n    mainAttribute: 'position',\n    /**\n     * User defined picking algorithm instead of default\n     * triangle ray intersection\n     * x, y are NDC.\n     * ```typescript\n     * (x, y, renderer, camera, renderable, out) => boolean\n     * ```\n     * @type {?Function}\n     */\n    pick: null,\n\n    /**\n     * User defined ray picking algorithm instead of default\n     * triangle ray intersection\n     * ```typescript\n     * (ray: clay.math.Ray, renderable: clay.Renderable, out: Array) => boolean\n     * ```\n     * @type {?Function}\n     */\n    pickByRay: null,\n\n    /**\n     * Update boundingBox of Geometry\n     */\n    updateBoundingBox: function () {\n        var bbox = this.boundingBox;\n        if (!bbox) {\n            bbox = this.boundingBox = new BoundingBox();\n        }\n        var posArr = this.attributes.position.value;\n        if (posArr && posArr.length) {\n            var min = bbox.min;\n            var max = bbox.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            vec3.set(minArr, posArr[0], posArr[1], posArr[2]);\n            vec3.set(maxArr, posArr[0], posArr[1], posArr[2]);\n            for (var i = 3; i < posArr.length;) {\n                var x = posArr[i++];\n                var y = posArr[i++];\n                var z = posArr[i++];\n                if (x < minArr[0]) { minArr[0] = x; }\n                if (y < minArr[1]) { minArr[1] = y; }\n                if (z < minArr[2]) { minArr[2] = z; }\n\n                if (x > maxArr[0]) { maxArr[0] = x; }\n                if (y > maxArr[1]) { maxArr[1] = y; }\n                if (z > maxArr[2]) { maxArr[2] = z; }\n            }\n            min._dirty = true;\n            max._dirty = true;\n        }\n    },\n    /**\n     * Mark attributes and indices in geometry needs to update.\n     */\n    dirty: function () {\n        var enabledAttributes = this.getEnabledAttributes();\n        for (var i = 0; i < enabledAttributes.length; i++) {\n            this.dirtyAttribute(enabledAttributes[i]);\n        }\n        this.dirtyIndices();\n        this._enabledAttributes = null;\n\n        this._cache.dirty('any');\n    },\n    /**\n     * Mark the indices needs to update.\n     */\n    dirtyIndices: function () {\n        this._cache.dirtyAll('indices');\n    },\n    /**\n     * Mark the attributes needs to update.\n     * @param {string} [attrName]\n     */\n    dirtyAttribute: function (attrName) {\n        this._cache.dirtyAll(makeAttrKey(attrName));\n        this._cache.dirtyAll('attributes');\n    },\n    /**\n     * Get indices of triangle at given index.\n     * @param {number} idx\n     * @param {Array.<number>} out\n     * @return {Array.<number>}\n     */\n    getTriangleIndices: function (idx, out) {\n        if (idx < this.triangleCount && idx >= 0) {\n            if (!out) {\n                out = vec3Create();\n            }\n            var indices = this.indices;\n            out[0] = indices[idx * 3];\n            out[1] = indices[idx * 3 + 1];\n            out[2] = indices[idx * 3 + 2];\n            return out;\n        }\n    },\n\n    /**\n     * Set indices of triangle at given index.\n     * @param {number} idx\n     * @param {Array.<number>} arr\n     */\n    setTriangleIndices: function (idx, arr) {\n        var indices = this.indices;\n        indices[idx * 3] = arr[0];\n        indices[idx * 3 + 1] = arr[1];\n        indices[idx * 3 + 2] = arr[2];\n    },\n\n    isUseIndices: function () {\n        return !!this.indices;\n    },\n\n    /**\n     * Initialize indices from an array.\n     * @param {Array} array\n     */\n    initIndicesFromArray: function (array) {\n        var value;\n        var ArrayConstructor = this.vertexCount > 0xffff\n            ? vendor.Uint32Array : vendor.Uint16Array;\n        // Convert 2d array to flat\n        if (array[0] && (array[0].length)) {\n            var n = 0;\n            var size = 3;\n\n            value = new ArrayConstructor(array.length * size);\n            for (var i = 0; i < array.length; i++) {\n                for (var j = 0; j < size; j++) {\n                    value[n++] = array[i][j];\n                }\n            }\n        }\n        else {\n            value = new ArrayConstructor(array);\n        }\n\n        this.indices = value;\n    },\n    /**\n     * Create a new attribute\n     * @param {string} name\n     * @param {string} type\n     * @param {number} size\n     * @param {string} [semantic]\n     */\n    createAttribute: function (name, type, size, semantic) {\n        var attrib = new Attribute(name, type, size, semantic);\n        if (this.attributes[name]) {\n            this.removeAttribute(name);\n        }\n        this.attributes[name] = attrib;\n        this._attributeList.push(name);\n        return attrib;\n    },\n    /**\n     * Remove attribute\n     * @param {string} name\n     */\n    removeAttribute: function (name) {\n        var attributeList = this._attributeList;\n        var idx = attributeList.indexOf(name);\n        if (idx >= 0) {\n            attributeList.splice(idx, 1);\n            delete this.attributes[name];\n            return true;\n        }\n        return false;\n    },\n\n    /**\n     * Get attribute\n     * @param {string} name\n     * @return {clay.Geometry.Attribute}\n     */\n    getAttribute: function (name) {\n        return this.attributes[name];\n    },\n\n    /**\n     * Get enabled attributes name list\n     * Attribute which has the same vertex number with position is treated as a enabled attribute\n     * @return {string[]}\n     */\n    getEnabledAttributes: function () {\n        var enabledAttributes = this._enabledAttributes;\n        var attributeList = this._attributeList;\n        // Cache\n        if (enabledAttributes) {\n            return enabledAttributes;\n        }\n\n        var result = [];\n        var nVertex = this.vertexCount;\n\n        for (var i = 0; i < attributeList.length; i++) {\n            var name = attributeList[i];\n            var attrib = this.attributes[name];\n            if (attrib.value) {\n                if (attrib.value.length === nVertex * attrib.size) {\n                    result.push(name);\n                }\n            }\n        }\n\n        this._enabledAttributes = result;\n\n        return result;\n    },\n\n    getBufferChunks: function (renderer) {\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n        var isAttributesDirty = cache.isDirty('attributes');\n        var isIndicesDirty = cache.isDirty('indices');\n        if (isAttributesDirty || isIndicesDirty) {\n            this._updateBuffer(renderer.gl, isAttributesDirty, isIndicesDirty);\n            var enabledAttributes = this.getEnabledAttributes();\n            for (var i = 0; i < enabledAttributes.length; i++) {\n                cache.fresh(makeAttrKey(enabledAttributes[i]));\n            }\n            cache.fresh('attributes');\n            cache.fresh('indices');\n        }\n        cache.fresh('any');\n        return cache.get('chunks');\n    },\n\n    _updateBuffer: function (_gl, isAttributesDirty, isIndicesDirty) {\n        var cache = this._cache;\n        var chunks = cache.get('chunks');\n        var firstUpdate = false;\n        if (!chunks) {\n            chunks = [];\n            // Intialize\n            chunks[0] = {\n                attributeBuffers: [],\n                indicesBuffer: null\n            };\n            cache.put('chunks', chunks);\n            firstUpdate = true;\n        }\n\n        var chunk = chunks[0];\n        var attributeBuffers = chunk.attributeBuffers;\n        var indicesBuffer = chunk.indicesBuffer;\n\n        if (isAttributesDirty || firstUpdate) {\n            var attributeList = this.getEnabledAttributes();\n\n            var attributeBufferMap = {};\n            if (!firstUpdate) {\n                for (var i = 0; i < attributeBuffers.length; i++) {\n                    attributeBufferMap[attributeBuffers[i].name] = attributeBuffers[i];\n                }\n            }\n            // FIXME If some attributes removed\n            for (var k = 0; k < attributeList.length; k++) {\n                var name = attributeList[k];\n                var attribute = this.attributes[name];\n\n                var bufferInfo;\n\n                if (!firstUpdate) {\n                    bufferInfo = attributeBufferMap[name];\n                }\n                var buffer;\n                if (bufferInfo) {\n                    buffer = bufferInfo.buffer;\n                }\n                else {\n                    buffer = _gl.createBuffer();\n                }\n                if (cache.isDirty(makeAttrKey(name))) {\n                    // Only update when they are dirty.\n                    // TODO: Use BufferSubData?\n                    _gl.bindBuffer(_gl.ARRAY_BUFFER, buffer);\n                    _gl.bufferData(_gl.ARRAY_BUFFER, attribute.value, this.dynamic ? glenum.DYNAMIC_DRAW : glenum.STATIC_DRAW);\n                }\n\n                attributeBuffers[k] = new AttributeBuffer(name, attribute.type, buffer, attribute.size, attribute.semantic);\n            }\n            // Remove unused attributes buffers.\n            // PENDING\n            for (var i = k; i < attributeBuffers.length; i++) {\n                _gl.deleteBuffer(attributeBuffers[i].buffer);\n            }\n            attributeBuffers.length = k;\n\n        }\n\n        if (this.isUseIndices() && (isIndicesDirty || firstUpdate)) {\n            if (!indicesBuffer) {\n                indicesBuffer = new IndicesBuffer(_gl.createBuffer());\n                chunk.indicesBuffer = indicesBuffer;\n            }\n            indicesBuffer.count = this.indices.length;\n            _gl.bindBuffer(_gl.ELEMENT_ARRAY_BUFFER, indicesBuffer.buffer);\n            _gl.bufferData(_gl.ELEMENT_ARRAY_BUFFER, this.indices, this.dynamic ? glenum.DYNAMIC_DRAW : glenum.STATIC_DRAW);\n        }\n    },\n\n    /**\n     * Generate normals per vertex.\n     */\n    generateVertexNormals: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        var indices = this.indices;\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n\n        if (!normals || normals.length !== positions.length) {\n            normals = attributes.normal.value = new vendor.Float32Array(positions.length);\n        }\n        else {\n            // Reset\n            for (var i = 0; i < normals.length; i++) {\n                normals[i] = 0;\n            }\n        }\n\n        var p1 = vec3Create();\n        var p2 = vec3Create();\n        var p3 = vec3Create();\n\n        var v21 = vec3Create();\n        var v32 = vec3Create();\n\n        var n = vec3Create();\n\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var f = 0; f < len;) {\n            if (indices) {\n                i1 = indices[f++];\n                i2 = indices[f++];\n                i3 = indices[f++];\n            }\n            else {\n                i1 = f++;\n                i2 = f++;\n                i3 = f++;\n            }\n\n            vec3Set(p1, positions[i1*3], positions[i1*3+1], positions[i1*3+2]);\n            vec3Set(p2, positions[i2*3], positions[i2*3+1], positions[i2*3+2]);\n            vec3Set(p3, positions[i3*3], positions[i3*3+1], positions[i3*3+2]);\n\n            vec3.sub(v21, p1, p2);\n            vec3.sub(v32, p2, p3);\n            vec3.cross(n, v21, v32);\n            // Already be weighted by the triangle area\n            for (var i = 0; i < 3; i++) {\n                normals[i1*3+i] = normals[i1*3+i] + n[i];\n                normals[i2*3+i] = normals[i2*3+i] + n[i];\n                normals[i3*3+i] = normals[i3*3+i] + n[i];\n            }\n        }\n\n        for (var i = 0; i < normals.length;) {\n            vec3Set(n, normals[i], normals[i+1], normals[i+2]);\n            vec3.normalize(n, n);\n            normals[i++] = n[0];\n            normals[i++] = n[1];\n            normals[i++] = n[2];\n        }\n        this.dirty();\n    },\n\n    /**\n     * Generate normals per face.\n     */\n    generateFaceNormals: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        if (!this.isUniqueVertex()) {\n            this.generateUniqueVertex();\n        }\n\n        var indices = this.indices;\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n\n        var p1 = vec3Create();\n        var p2 = vec3Create();\n        var p3 = vec3Create();\n\n        var v21 = vec3Create();\n        var v32 = vec3Create();\n        var n = vec3Create();\n\n        if (!normals) {\n            normals = attributes.normal.value = new Float32Array(positions.length);\n        }\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var f = 0; f < len;) {\n            if (indices) {\n                i1 = indices[f++];\n                i2 = indices[f++];\n                i3 = indices[f++];\n            }\n            else {\n                i1 = f++;\n                i2 = f++;\n                i3 = f++;\n            }\n\n            vec3Set(p1, positions[i1*3], positions[i1*3+1], positions[i1*3+2]);\n            vec3Set(p2, positions[i2*3], positions[i2*3+1], positions[i2*3+2]);\n            vec3Set(p3, positions[i3*3], positions[i3*3+1], positions[i3*3+2]);\n\n            vec3.sub(v21, p1, p2);\n            vec3.sub(v32, p2, p3);\n            vec3.cross(n, v21, v32);\n\n            vec3.normalize(n, n);\n\n            for (var i = 0; i < 3; i++) {\n                normals[i1*3 + i] = n[i];\n                normals[i2*3 + i] = n[i];\n                normals[i3*3 + i] = n[i];\n            }\n        }\n        this.dirty();\n    },\n\n    /**\n     * Generate tangents attributes.\n     */\n    generateTangents: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        var nVertex = this.vertexCount;\n        var attributes = this.attributes;\n        if (!attributes.tangent.value) {\n            attributes.tangent.value = new Float32Array(nVertex * 4);\n        }\n        var texcoords = attributes.texcoord0.value;\n        var positions = attributes.position.value;\n        var tangents = attributes.tangent.value;\n        var normals = attributes.normal.value;\n\n        if (!texcoords) {\n            console.warn('Geometry without texcoords can\\'t generate tangents.');\n            return;\n        }\n\n        var tan1 = [];\n        var tan2 = [];\n        for (var i = 0; i < nVertex; i++) {\n            tan1[i] = [0.0, 0.0, 0.0];\n            tan2[i] = [0.0, 0.0, 0.0];\n        }\n\n        var sdir = [0.0, 0.0, 0.0];\n        var tdir = [0.0, 0.0, 0.0];\n        var indices = this.indices;\n\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var i = 0; i < len;) {\n            if (indices) {\n                i1 = indices[i++];\n                i2 = indices[i++];\n                i3 = indices[i++];\n            }\n            else {\n                i1 = i++;\n                i2 = i++;\n                i3 = i++;\n            }\n\n            var st1s = texcoords[i1 * 2],\n                st2s = texcoords[i2 * 2],\n                st3s = texcoords[i3 * 2],\n                st1t = texcoords[i1 * 2 + 1],\n                st2t = texcoords[i2 * 2 + 1],\n                st3t = texcoords[i3 * 2 + 1],\n\n                p1x = positions[i1 * 3],\n                p2x = positions[i2 * 3],\n                p3x = positions[i3 * 3],\n                p1y = positions[i1 * 3 + 1],\n                p2y = positions[i2 * 3 + 1],\n                p3y = positions[i3 * 3 + 1],\n                p1z = positions[i1 * 3 + 2],\n                p2z = positions[i2 * 3 + 2],\n                p3z = positions[i3 * 3 + 2];\n\n            var x1 = p2x - p1x,\n                x2 = p3x - p1x,\n                y1 = p2y - p1y,\n                y2 = p3y - p1y,\n                z1 = p2z - p1z,\n                z2 = p3z - p1z;\n\n            var s1 = st2s - st1s,\n                s2 = st3s - st1s,\n                t1 = st2t - st1t,\n                t2 = st3t - st1t;\n\n            var r = 1.0 / (s1 * t2 - t1 * s2);\n            sdir[0] = (t2 * x1 - t1 * x2) * r;\n            sdir[1] = (t2 * y1 - t1 * y2) * r;\n            sdir[2] = (t2 * z1 - t1 * z2) * r;\n\n            tdir[0] = (s1 * x2 - s2 * x1) * r;\n            tdir[1] = (s1 * y2 - s2 * y1) * r;\n            tdir[2] = (s1 * z2 - s2 * z1) * r;\n\n            vec3Add(tan1[i1], tan1[i1], sdir);\n            vec3Add(tan1[i2], tan1[i2], sdir);\n            vec3Add(tan1[i3], tan1[i3], sdir);\n            vec3Add(tan2[i1], tan2[i1], tdir);\n            vec3Add(tan2[i2], tan2[i2], tdir);\n            vec3Add(tan2[i3], tan2[i3], tdir);\n        }\n        var tmp = vec3Create();\n        var nCrossT = vec3Create();\n        var n = vec3Create();\n        for (var i = 0; i < nVertex; i++) {\n            n[0] = normals[i * 3];\n            n[1] = normals[i * 3 + 1];\n            n[2] = normals[i * 3 + 2];\n            var t = tan1[i];\n\n            // Gram-Schmidt orthogonalize\n            vec3.scale(tmp, n, vec3.dot(n, t));\n            vec3.sub(tmp, t, tmp);\n            vec3.normalize(tmp, tmp);\n            // Calculate handedness.\n            vec3.cross(nCrossT, n, t);\n            tangents[i * 4] = tmp[0];\n            tangents[i * 4 + 1] = tmp[1];\n            tangents[i * 4 + 2] = tmp[2];\n            // PENDING can config ?\n            tangents[i * 4 + 3] = vec3.dot(nCrossT, tan2[i]) < 0.0 ? -1.0 : 1.0;\n        }\n        this.dirty();\n    },\n\n    /**\n     * If vertices are not shared by different indices.\n     */\n    isUniqueVertex: function () {\n        if (this.isUseIndices()) {\n            return this.vertexCount === this.indices.length;\n        }\n        else {\n            return true;\n        }\n    },\n    /**\n     * Create a unique vertex for each index.\n     */\n    generateUniqueVertex: function () {\n        if (!this.vertexCount || !this.indices) {\n            return;\n        }\n\n        if (this.indices.length > 0xffff) {\n            this.indices = new vendor.Uint32Array(this.indices);\n        }\n\n        var attributes = this.attributes;\n        var indices = this.indices;\n\n        var attributeNameList = this.getEnabledAttributes();\n\n        var oldAttrValues = {};\n        for (var a = 0; a < attributeNameList.length; a++) {\n            var name = attributeNameList[a];\n            oldAttrValues[name] = attributes[name].value;\n            attributes[name].init(this.indices.length);\n        }\n\n        var cursor = 0;\n        for (var i = 0; i < indices.length; i++) {\n            var ii = indices[i];\n            for (var a = 0; a < attributeNameList.length; a++) {\n                var name = attributeNameList[a];\n                var array = attributes[name].value;\n                var size = attributes[name].size;\n\n                for (var k = 0; k < size; k++) {\n                    array[cursor * size + k] = oldAttrValues[name][ii * size + k];\n                }\n            }\n            indices[i] = cursor;\n            cursor++;\n        }\n\n        this.dirty();\n    },\n\n    /**\n     * Generate barycentric coordinates for wireframe draw.\n     */\n    generateBarycentric: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        if (!this.isUniqueVertex()) {\n            this.generateUniqueVertex();\n        }\n\n        var attributes = this.attributes;\n        var array = attributes.barycentric.value;\n        var indices = this.indices;\n        // Already existed;\n        if (array && array.length === indices.length * 3) {\n            return;\n        }\n        array = attributes.barycentric.value = new Float32Array(indices.length * 3);\n\n        for (var i = 0; i < (indices ? indices.length : this.vertexCount / 3);) {\n            for (var j = 0; j < 3; j++) {\n                var ii = indices ? indices[i++] : (i * 3 + j);\n                array[ii * 3 + j] = 1;\n            }\n        }\n        this.dirty();\n    },\n\n    /**\n     * Apply transform to geometry attributes.\n     * @param {clay.math.Matrix4} matrix\n     */\n    applyTransform: function (matrix) {\n\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n        var tangents = attributes.tangent.value;\n\n        matrix = matrix.array;\n        // Normal Matrix\n        var inverseTransposeMatrix = mat4.create();\n        mat4.invert(inverseTransposeMatrix, matrix);\n        mat4.transpose(inverseTransposeMatrix, inverseTransposeMatrix);\n\n        var vec3TransformMat4 = vec3.transformMat4;\n        var vec3ForEach = vec3.forEach;\n        vec3ForEach(positions, 3, 0, null, vec3TransformMat4, matrix);\n        if (normals) {\n            vec3ForEach(normals, 3, 0, null, vec3TransformMat4, inverseTransposeMatrix);\n        }\n        if (tangents) {\n            vec3ForEach(tangents, 4, 0, null, vec3TransformMat4, inverseTransposeMatrix);\n        }\n\n        if (this.boundingBox) {\n            this.updateBoundingBox();\n        }\n    },\n    /**\n     * Dispose geometry data in GL context.\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n        var chunks = cache.get('chunks');\n        if (chunks) {\n            for (var c = 0; c < chunks.length; c++) {\n                var chunk = chunks[c];\n\n                for (var k = 0; k < chunk.attributeBuffers.length; k++) {\n                    var attribs = chunk.attributeBuffers[k];\n                    renderer.gl.deleteBuffer(attribs.buffer);\n                }\n\n                if (chunk.indicesBuffer) {\n                    renderer.gl.deleteBuffer(chunk.indicesBuffer.buffer);\n                }\n            }\n        }\n        cache.deleteContext(renderer.__uid__);\n    }\n\n});\n\nif (Object.defineProperty) {\n    /**\n     * @name clay.Geometry#vertexCount\n     * @type {number}\n     * @readOnly\n     */\n    Object.defineProperty(Geometry.prototype, 'vertexCount', {\n\n        enumerable: false,\n\n        get: function () {\n            var mainAttribute = this.attributes[this.mainAttribute];\n            if (!mainAttribute || !mainAttribute.value) {\n                return 0;\n            }\n            return mainAttribute.value.length / mainAttribute.size;\n        }\n    });\n    /**\n     * @name clay.Geometry#triangleCount\n     * @type {number}\n     * @readOnly\n     */\n    Object.defineProperty(Geometry.prototype, 'triangleCount', {\n\n        enumerable: false,\n\n        get: function () {\n            var indices = this.indices;\n            if (!indices) {\n                return 0;\n            }\n            else {\n                return indices.length / 3;\n            }\n        }\n    });\n}\n\nGeometry.STATIC_DRAW = glenum.STATIC_DRAW;\nGeometry.DYNAMIC_DRAW = glenum.DYNAMIC_DRAW;\nGeometry.STREAM_DRAW = glenum.STREAM_DRAW;\n\nGeometry.AttributeBuffer = AttributeBuffer;\nGeometry.IndicesBuffer = IndicesBuffer;\n\nGeometry.Attribute = Attribute;\n\nexport default Geometry;\n","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\n\n/**\n * @constructor clay.geometry.Plane\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.widthSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Plane = Geometry.extend(\n/** @lends clay.geometry.Plane# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 1,\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Plane.prototype */\n{\n    /**\n     * Build plane geometry\n     */\n    build: function() {\n        var heightSegments = this.heightSegments;\n        var widthSegments = this.widthSegments;\n        var attributes = this.attributes;\n        var positions = [];\n        var texcoords = [];\n        var normals = [];\n        var faces = [];\n\n        for (var y = 0; y <= heightSegments; y++) {\n            var t = y / heightSegments;\n            for (var x = 0; x <= widthSegments; x++) {\n                var s = x / widthSegments;\n\n                positions.push([2 * s - 1, 2 * t - 1, 0]);\n                if (texcoords) {\n                    texcoords.push([s, t]);\n                }\n                if (normals) {\n                    normals.push([0, 0, 1]);\n                }\n                if (x < widthSegments && y < heightSegments) {\n                    var i = x + y * (widthSegments + 1);\n                    faces.push([i, i + 1, i + widthSegments + 1]);\n                    faces.push([i + widthSegments + 1, i + 1, i + widthSegments + 2]);\n                }\n            }\n        }\n\n        attributes.position.fromArray(positions);\n        attributes.texcoord0.fromArray(texcoords);\n        attributes.normal.fromArray(normals);\n\n        this.initIndicesFromArray(faces);\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.min.set(-1, -1, 0);\n        this.boundingBox.max.set(1, 1, 0);\n    }\n});\n\nexport default Plane;\n","import Geometry from '../Geometry';\nimport Plane from './Plane';\nimport Matrix4 from '../math/Matrix4';\nimport Vector3 from '../math/Vector3';\nimport BoundingBox from '../math/BoundingBox';\nimport vendor from '../core/vendor';\n\nvar planeMatrix = new Matrix4();\n\n/**\n * @constructor clay.geometry.Cube\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.widthSegments]\n * @param {number} [opt.heightSegments]\n * @param {number} [opt.depthSegments]\n * @param {boolean} [opt.inside]\n */\nvar Cube = Geometry.extend(\n/**@lends clay.geometry.Cube# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 1,\n    /**\n     * @type {number}\n     */\n    heightSegments: 1,\n    /**\n     * @type {number}\n     */\n    depthSegments: 1,\n    /**\n     * @type {boolean}\n     */\n    inside: false\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cube.prototype */\n{\n    /**\n     * Build cube geometry\n     */\n    build: function() {\n\n        var planes = {\n            'px': createPlane('px', this.depthSegments, this.heightSegments),\n            'nx': createPlane('nx', this.depthSegments, this.heightSegments),\n            'py': createPlane('py', this.widthSegments, this.depthSegments),\n            'ny': createPlane('ny', this.widthSegments, this.depthSegments),\n            'pz': createPlane('pz', this.widthSegments, this.heightSegments),\n            'nz': createPlane('nz', this.widthSegments, this.heightSegments),\n        };\n\n        var attrList = ['position', 'texcoord0', 'normal'];\n        var vertexNumber = 0;\n        var faceNumber = 0;\n        for (var pos in planes) {\n            vertexNumber += planes[pos].vertexCount;\n            faceNumber += planes[pos].indices.length;\n        }\n        for (var k = 0; k < attrList.length; k++) {\n            this.attributes[attrList[k]].init(vertexNumber);\n        }\n        this.indices = new vendor.Uint16Array(faceNumber);\n        var faceOffset = 0;\n        var vertexOffset = 0;\n        for (var pos in planes) {\n            var plane = planes[pos];\n            for (var k = 0; k < attrList.length; k++) {\n                var attrName = attrList[k];\n                var attrArray = plane.attributes[attrName].value;\n                var attrSize = plane.attributes[attrName].size;\n                var isNormal = attrName === 'normal';\n                for (var i = 0; i < attrArray.length; i++) {\n                    var value = attrArray[i];\n                    if (this.inside && isNormal) {\n                        value = -value;\n                    }\n                    this.attributes[attrName].value[i + attrSize * vertexOffset] = value;\n                }\n            }\n            var len = plane.indices.length;\n            for (var i = 0; i < plane.indices.length; i++) {\n                this.indices[i + faceOffset] = vertexOffset + plane.indices[this.inside ? (len - i - 1) : i];\n            }\n            faceOffset += plane.indices.length;\n            vertexOffset += plane.vertexCount;\n        }\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.max.set(1, 1, 1);\n        this.boundingBox.min.set(-1, -1, -1);\n    }\n});\n\nfunction createPlane(pos, widthSegments, heightSegments) {\n\n    planeMatrix.identity();\n\n    var plane = new Plane({\n        widthSegments: widthSegments,\n        heightSegments: heightSegments\n    });\n\n    switch(pos) {\n        case 'px':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_X);\n            Matrix4.rotateY(planeMatrix, planeMatrix, Math.PI / 2);\n            break;\n        case 'nx':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_X);\n            Matrix4.rotateY(planeMatrix, planeMatrix, -Math.PI / 2);\n            break;\n        case 'py':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_Y);\n            Matrix4.rotateX(planeMatrix, planeMatrix, -Math.PI / 2);\n            break;\n        case 'ny':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_Y);\n            Matrix4.rotateX(planeMatrix, planeMatrix, Math.PI / 2);\n            break;\n        case 'pz':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_Z);\n            break;\n        case 'nz':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_Z);\n            Matrix4.rotateY(planeMatrix, planeMatrix, Math.PI);\n            break;\n    }\n    plane.applyTransform(planeMatrix);\n    return plane;\n}\n\nexport default Cube;\n","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\n\n/**\n * @constructor clay.geometry.Sphere\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [widthSegments]\n * @param {number} [heightSegments]\n * @param {number} [phiStart]\n * @param {number} [phiLength]\n * @param {number} [thetaStart]\n * @param {number} [thetaLength]\n * @param {number} [radius]\n */\nvar Sphere = Geometry.extend(\n/** @lends clay.geometry.Sphere# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 40,\n    /**\n     * @type {number}\n     */\n    heightSegments: 20,\n\n    /**\n     * @type {number}\n     */\n    phiStart: 0,\n    /**\n     * @type {number}\n     */\n    phiLength: Math.PI * 2,\n\n    /**\n     * @type {number}\n     */\n    thetaStart: 0,\n    /**\n     * @type {number}\n     */\n    thetaLength: Math.PI,\n\n    /**\n     * @type {number}\n     */\n    radius: 1\n\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Sphere.prototype */\n{\n    /**\n     * Build sphere geometry\n     */\n    build: function() {\n        var heightSegments = this.heightSegments;\n        var widthSegments = this.widthSegments;\n\n        var positionAttr = this.attributes.position;\n        var texcoordAttr = this.attributes.texcoord0;\n        var normalAttr = this.attributes.normal;\n\n        var vertexCount = (widthSegments + 1) * (heightSegments + 1);\n        positionAttr.init(vertexCount);\n        texcoordAttr.init(vertexCount);\n        normalAttr.init(vertexCount);\n\n        var IndicesCtor = vertexCount > 0xffff ? Uint32Array : Uint16Array;\n        var indices = this.indices = new IndicesCtor(widthSegments * heightSegments * 6);\n\n        var x, y, z,\n            u, v,\n            i, j;\n\n        var radius = this.radius;\n        var phiStart = this.phiStart;\n        var phiLength = this.phiLength;\n        var thetaStart = this.thetaStart;\n        var thetaLength = this.thetaLength;\n        var radius = this.radius;\n\n        var pos = [];\n        var uv = [];\n        var offset = 0;\n        var divider = 1 / radius;\n        for (j = 0; j <= heightSegments; j ++) {\n            for (i = 0; i <= widthSegments; i ++) {\n                u = i / widthSegments;\n                v = j / heightSegments;\n\n                // X axis is inverted so texture can be mapped from left to right\n                x = -radius * Math.cos(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n                y = radius * Math.cos(thetaStart + v * thetaLength);\n                z = radius * Math.sin(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n\n                pos[0] = x; pos[1] = y; pos[2] = z;\n                uv[0] = u; uv[1] = v;\n                positionAttr.set(offset, pos);\n                texcoordAttr.set(offset, uv);\n                pos[0] *= divider;\n                pos[1] *= divider;\n                pos[2] *= divider;\n                normalAttr.set(offset, pos);\n                offset++;\n            }\n        }\n\n        var i1, i2, i3, i4;\n\n        var len = widthSegments + 1;\n\n        var n = 0;\n        for (j = 0; j < heightSegments; j ++) {\n            for (i = 0; i < widthSegments; i ++) {\n                i2 = j * len + i;\n                i1 = (j * len + i + 1);\n                i4 = (j + 1) * len + i + 1;\n                i3 = (j + 1) * len + i;\n\n                indices[n++] = i1;\n                indices[n++] = i2;\n                indices[n++] = i4;\n\n                indices[n++] = i2;\n                indices[n++] = i3;\n                indices[n++] = i4;\n            }\n        }\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.max.set(radius, radius, radius);\n        this.boundingBox.min.set(-radius, -radius, -radius);\n    }\n});\n\nexport default Sphere;\n","var mathUtil = {};\n\nmathUtil.isPowerOfTwo = function (value) {\n    return (value & (value - 1)) === 0;\n};\n\nmathUtil.nextPowerOfTwo = function (value) {\n    value --;\n    value |= value >> 1;\n    value |= value >> 2;\n    value |= value >> 4;\n    value |= value >> 8;\n    value |= value >> 16;\n    value ++;\n\n    return value;\n};\n\nmathUtil.nearestPowerOfTwo = function (value) {\n    return Math.pow( 2, Math.round( Math.log( value ) / Math.LN2 ) );\n};\n\nexport default mathUtil;\n","import Texture from './Texture';\nimport glenum from './core/glenum';\nimport mathUtil from './math/util';\nvar isPowerOfTwo = mathUtil.isPowerOfTwo;\n\n/**\n * @constructor clay.Texture2D\n * @extends clay.Texture\n *\n * @example\n *     ...\n *     var mat = new clay.Material({\n *         shader: clay.shader.library.get('clay.phong', 'diffuseMap')\n *     });\n *     var diffuseMap = new clay.Texture2D();\n *     diffuseMap.load('assets/textures/diffuse.jpg');\n *     mat.set('diffuseMap', diffuseMap);\n *     ...\n *     diffuseMap.success(function () {\n *         // Wait for the diffuse texture loaded\n *         animation.on('frame', function (frameTime) {\n *             renderer.render(scene, camera);\n *         });\n *     });\n */\nvar Texture2D = Texture.extend(function () {\n    return /** @lends clay.Texture2D# */ {\n        /**\n         * @type {?HTMLImageElement|HTMLCanvasElemnet}\n         */\n        image: null,\n        /**\n         * Pixels data. Will be ignored if image is set.\n         * @type {?Uint8Array|Float32Array}\n         */\n        pixels: null,\n        /**\n         * @type {Array.<Object>}\n         * @example\n         *     [{\n         *         image: mipmap0,\n         *         pixels: null\n         *     }, {\n         *         image: mipmap1,\n         *         pixels: null\n         *     }, ....]\n         */\n        mipmaps: []\n    };\n}, {\n    update: function (renderer) {\n\n        var _gl = renderer.gl;\n        _gl.bindTexture(_gl.TEXTURE_2D, this._cache.get('webgl_texture'));\n\n        this.updateCommon(renderer);\n\n        var glFormat = this.format;\n        var glType = this.type;\n\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS());\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT());\n\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter());\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter());\n\n        var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic');\n        if (anisotropicExt && this.anisotropic > 1) {\n            _gl.texParameterf(_gl.TEXTURE_2D, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic);\n        }\n\n        // Fallback to float type if browser don't have half float extension\n        if (glType === 36193) {\n            var halfFloatExt = renderer.getGLExtension('OES_texture_half_float');\n            if (!halfFloatExt) {\n                glType = glenum.FLOAT;\n            }\n        }\n\n        if (this.mipmaps.length) {\n            var width = this.width;\n            var height = this.height;\n            for (var i = 0; i < this.mipmaps.length; i++) {\n                var mipmap = this.mipmaps[i];\n                this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType);\n                width /= 2;\n                height /= 2;\n            }\n        }\n        else {\n            this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType);\n\n            if (this.useMipmap && !this.NPOT) {\n                _gl.generateMipmap(_gl.TEXTURE_2D);\n            }\n        }\n\n        _gl.bindTexture(_gl.TEXTURE_2D, null);\n    },\n\n    _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) {\n        if (data.image) {\n            _gl.texImage2D(_gl.TEXTURE_2D, level, glFormat, glFormat, glType, data.image);\n        }\n        else {\n            // Can be used as a blank texture when writing render to texture(RTT)\n            if (\n                glFormat <= Texture.COMPRESSED_RGBA_S3TC_DXT5_EXT\n                && glFormat >= Texture.COMPRESSED_RGB_S3TC_DXT1_EXT\n            ) {\n                _gl.compressedTexImage2D(_gl.TEXTURE_2D, level, glFormat, width, height, 0, data.pixels);\n            }\n            else {\n                // Is a render target if pixels is null\n                _gl.texImage2D(_gl.TEXTURE_2D, level, glFormat, width, height, 0, glFormat, glType, data.pixels);\n            }\n        }\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @memberOf clay.Texture2D.prototype\n     */\n    generateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        if (this.useMipmap && !this.NPOT) {\n            _gl.bindTexture(_gl.TEXTURE_2D, this._cache.get('webgl_texture'));\n            _gl.generateMipmap(_gl.TEXTURE_2D);\n        }\n    },\n\n    isPowerOfTwo: function () {\n        var width;\n        var height;\n        if (this.image) {\n            width = this.image.width;\n            height = this.image.height;\n        }\n        else {\n            width = this.width;\n            height = this.height;\n        }\n        return isPowerOfTwo(width) && isPowerOfTwo(height);\n    },\n\n    isRenderable: function () {\n        if (this.image) {\n            return this.image.nodeName === 'CANVAS'\n                || this.image.nodeName === 'VIDEO'\n                || this.image.complete;\n        }\n        else {\n            return !!(this.width && this.height);\n        }\n    },\n\n    bind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_2D, this.getWebGLTexture(renderer));\n    },\n\n    unbind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_2D, null);\n    },\n\n    load: function (src, crossOrigin) {\n        var image = new Image();\n        if (crossOrigin) {\n            image.crossOrigin = crossOrigin;\n        }\n        var self = this;\n        image.onload = function () {\n            self.dirty();\n            self.trigger('success', self);\n            image.onload = null;\n        };\n        image.onerror = function () {\n            self.trigger('error', self);\n            image.onerror = null;\n        };\n\n        image.src = src;\n        this.image = image;\n\n        return this;\n    }\n});\n\nObject.defineProperty(Texture2D.prototype, 'width', {\n    get: function () {\n        if (this.image) {\n            return this.image.width;\n        }\n        return this._width;\n    },\n    set: function (value) {\n        if (this.image) {\n            console.warn('Texture from image can\\'t set width');\n        }\n        else {\n            if (this._width !== value) {\n                this.dirty();\n            }\n            this._width = value;\n        }\n    }\n});\nObject.defineProperty(Texture2D.prototype, 'height', {\n    get: function () {\n        if (this.image) {\n            return this.image.height;\n        }\n        return this._height;\n    },\n    set: function (value) {\n        if (this.image) {\n            console.warn('Texture from image can\\'t set height');\n        }\n        else {\n            if (this._height !== value) {\n                this.dirty();\n            }\n            this._height = value;\n        }\n    }\n});\n\nexport default Texture2D;\n","import Shader from '../Shader';\n\nvar _library = {};\n\nfunction ShaderLibrary () {\n    this._pool = {};\n}\n\nShaderLibrary.prototype.get = function(name) {\n    var key = name;\n\n    if (this._pool[key]) {\n        return this._pool[key];\n    }\n    else {\n        var source = _library[name];\n        if (!source) {\n            console.error('Shader \"' + name + '\"' + ' is not in the library');\n            return;\n        }\n        var shader = new Shader(source.vertex, source.fragment);\n        this._pool[key] = shader;\n        return shader;\n    }\n};\n\nShaderLibrary.prototype.clear = function() {\n    this._pool = {};\n};\n\nfunction template(name, vertex, fragment) {\n    _library[name] = {\n        vertex: vertex,\n        fragment: fragment\n    };\n}\n\nvar defaultLibrary = new ShaderLibrary();\n\n/**\n * ### Builin shaders\n * + clay.standard\n * + clay.basic\n * + clay.lambert\n * + clay.wireframe\n *\n * @namespace clay.shader.library\n */\nexport default {\n    /**\n     * Create a new shader library.\n     */\n    createLibrary: function () {\n        return new ShaderLibrary();\n    },\n    /**\n     * Get shader from default library.\n     * @param {string} name\n     * @return {clay.Shader}\n     * @memberOf clay.shader.library\n     * @example\n     *     clay.shader.library.get('clay.standard')\n     */\n    get: function () {\n        return defaultLibrary.get.apply(defaultLibrary, arguments);\n    },\n    /**\n     * @memberOf clay.shader.library\n     * @param  {string} name\n     * @param  {string} vertex - Vertex shader code\n     * @param  {string} fragment - Fragment shader code\n     */\n    template: template,\n    clear: function () {\n        return defaultLibrary.clear();\n    }\n};\n","import Node from './Node';\nimport glenum from './core/glenum';\n\n// Cache\nvar prevDrawID = 0;\nvar prevDrawIndicesBuffer = null;\nvar prevDrawIsUseIndices = true;\n\nvar currentDrawID;\n\nvar RenderInfo = function() {\n    this.triangleCount = 0;\n    this.vertexCount = 0;\n    this.drawCallCount = 0;\n};\n\nfunction VertexArrayObject(\n    availableAttributes,\n    availableAttributeSymbols,\n    indicesBuffer\n) {\n    this.availableAttributes = availableAttributes;\n    this.availableAttributeSymbols = availableAttributeSymbols;\n    this.indicesBuffer = indicesBuffer;\n\n    this.vao = null;\n}\n/**\n * @constructor\n * @alias clay.Renderable\n * @extends clay.Node\n */\nvar Renderable = Node.extend(\n/** @lends clay.Renderable# */\n{\n    /**\n     * @type {clay.Material}\n     */\n    material: null,\n\n    /**\n     * @type {clay.Geometry}\n     */\n    geometry: null,\n\n    /**\n     * @type {number}\n     */\n    mode: glenum.TRIANGLES,\n\n    _drawCache: null,\n\n    _renderInfo: null\n}, function() {\n    this._drawCache = {};\n    this._renderInfo = new RenderInfo();\n},\n/** @lends clay.Renderable.prototype */\n{\n\n    __program: null,\n\n    /**\n     * Group of received light.\n     */\n    lightGroup: 0,\n    /**\n     * Render order, Nodes with smaller value renders before nodes with larger values.\n     * @type {Number}\n     */\n    renderOrder: 0,\n    /**\n     * Used when mode is LINES, LINE_STRIP or LINE_LOOP\n     * @type {number}\n     */\n    lineWidth: 1,\n\n    /**\n     * If enable culling\n     * @type {boolean}\n     */\n    culling: true,\n    /**\n     * Specify which side of polygon will be culled.\n     * Possible values:\n     *  + {@link clay.Renderable.BACK}\n     *  + {@link clay.Renderable.FRONT}\n     *  + {@link clay.Renderable.FRONT_AND_BACK}\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/cullFace\n     * @type {number}\n     */\n    cullFace: glenum.BACK,\n    /**\n     * Specify which side is front face.\n     * Possible values:\n     *  + {@link clay.Renderable.CW}\n     *  + {@link clay.Renderable.CCW}\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/frontFace\n     * @type {number}\n     */\n    frontFace: glenum.CCW,\n\n    /**\n     * If enable software frustum culling\n     * @type {boolean}\n     */\n    frustumCulling: true,\n    /**\n     * @type {boolean}\n     */\n    receiveShadow: true,\n    /**\n     * @type {boolean}\n     */\n    castShadow: true,\n    /**\n     * @type {boolean}\n     */\n    ignorePicking: false,\n    /**\n     * @type {boolean}\n     */\n    ignorePreZ: false,\n\n    /**\n     * @type {boolean}\n     */\n    ignoreGBuffer: false,\n\n    /**\n     * @return {boolean}\n     */\n    isRenderable: function() {\n        // TODO Shader ?\n        return this.geometry && this.material && this.material.shader && !this.invisible\n            && this.geometry.vertexCount > 0;\n    },\n\n    /**\n     * Before render hook\n     * @type {Function}\n     */\n    beforeRender: function (_gl) {},\n\n    /**\n     * Before render hook\n     * @type {Function}\n     */\n    afterRender: function (_gl, renderStat) {},\n\n    getBoundingBox: function (filter, out) {\n        out = Node.prototype.getBoundingBox.call(this, filter, out);\n        if (this.geometry && this.geometry.boundingBox) {\n            out.union(this.geometry.boundingBox);\n        }\n\n        return out;\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Material} [material]\n     * @return {Object}\n     */\n    render: function (renderer, material, program) {\n        var _gl = renderer.gl;\n        material = material || this.material;\n        // May use shader of other material if shader code are same\n        var shader = material.shader;\n        var geometry = this.geometry;\n\n        var glDrawMode = this.mode;\n\n        var nVertex = geometry.vertexCount;\n        var isUseIndices = geometry.isUseIndices();\n\n        var uintExt = renderer.getGLExtension('OES_element_index_uint');\n        var useUintExt = uintExt && nVertex > 0xffff;\n        var indicesType = useUintExt ? _gl.UNSIGNED_INT : _gl.UNSIGNED_SHORT;\n\n        var vaoExt = renderer.getGLExtension('OES_vertex_array_object');\n        // var vaoExt = null;\n\n        var isStatic = !geometry.dynamic;\n\n        var renderInfo = this._renderInfo;\n        renderInfo.vertexCount = nVertex;\n        renderInfo.triangleCount = 0;\n        renderInfo.drawCallCount = 0;\n        // Draw each chunk\n        var drawHashChanged = false;\n        // Hash with shader id in case previous material has less attributes than next material\n        currentDrawID = renderer.__uid__ + '-' + geometry.__uid__ + '-' + program.__uid__;\n\n        if (currentDrawID !== prevDrawID) {\n            drawHashChanged = true;\n        }\n        else {\n            // The cache will be invalid in the following cases\n            // 1. VAO is enabled and is binded to null after render\n            // 2. Geometry needs update\n            if (\n                // TODO Optimize\n                (vaoExt && isStatic)\n                // PENDING\n                || geometry._cache.isDirty('any')\n            ) {\n                drawHashChanged = true;\n            }\n        }\n        prevDrawID = currentDrawID;\n\n        if (!drawHashChanged) {\n            // Direct draw\n            if (prevDrawIsUseIndices) {\n                _gl.drawElements(glDrawMode, prevDrawIndicesBuffer.count, indicesType, 0);\n                renderInfo.triangleCount = prevDrawIndicesBuffer.count / 3;\n            }\n            else {\n                // FIXME Use vertex number in buffer\n                // vertexCount may get the wrong value when geometry forget to mark dirty after update\n                _gl.drawArrays(glDrawMode, 0, nVertex);\n            }\n            renderInfo.drawCallCount = 1;\n        }\n        else {\n            // Use the cache of static geometry\n            var vaoList = this._drawCache[currentDrawID];\n            if (!vaoList) {\n                var chunks = geometry.getBufferChunks(renderer);\n                if (!chunks) {  // Empty mesh\n                    return;\n                }\n                vaoList = [];\n                for (var c = 0; c < chunks.length; c++) {\n                    var chunk = chunks[c];\n                    var attributeBuffers = chunk.attributeBuffers;\n                    var indicesBuffer = chunk.indicesBuffer;\n\n                    var availableAttributes = [];\n                    var availableAttributeSymbols = [];\n                    for (var a = 0; a < attributeBuffers.length; a++) {\n                        var attributeBufferInfo = attributeBuffers[a];\n                        var name = attributeBufferInfo.name;\n                        var semantic = attributeBufferInfo.semantic;\n                        var symbol;\n                        if (semantic) {\n                            var semanticInfo = shader.attributeSemantics[semantic];\n                            symbol = semanticInfo && semanticInfo.symbol;\n                        }\n                        else {\n                            symbol = name;\n                        }\n                        if (symbol && program.attributes[symbol]) {\n                            availableAttributes.push(attributeBufferInfo);\n                            availableAttributeSymbols.push(symbol);\n                        }\n                    }\n\n                    var vao = new VertexArrayObject(\n                        availableAttributes,\n                        availableAttributeSymbols,\n                        indicesBuffer\n                    );\n                    vaoList.push(vao);\n                }\n                if (isStatic) {\n                    this._drawCache[currentDrawID] = vaoList;\n                }\n            }\n\n            for (var i = 0; i < vaoList.length; i++) {\n                var vao = vaoList[i];\n                var needsBindAttributes = true;\n\n                // Create vertex object array cost a lot\n                // So we don't use it on the dynamic object\n                if (vaoExt && isStatic) {\n                    // Use vertex array object\n                    // http://blog.tojicode.com/2012/10/oesvertexarrayobject-extension.html\n                    if (vao.vao == null) {\n                        vao.vao = vaoExt.createVertexArrayOES();\n                    }\n                    else {\n                        needsBindAttributes = false;\n                    }\n                    vaoExt.bindVertexArrayOES(vao.vao);\n                }\n\n                var availableAttributes = vao.availableAttributes;\n                var indicesBuffer = vao.indicesBuffer;\n\n                if (needsBindAttributes) {\n                    var locationList = program.enableAttributes(renderer, vao.availableAttributeSymbols, (vaoExt && isStatic && vao.vao));\n                    // Setting attributes;\n                    for (var a = 0; a < availableAttributes.length; a++) {\n                        var location = locationList[a];\n                        if (location === -1) {\n                            continue;\n                        }\n                        var attributeBufferInfo = availableAttributes[a];\n                        var buffer = attributeBufferInfo.buffer;\n                        var size = attributeBufferInfo.size;\n                        var glType;\n                        switch (attributeBufferInfo.type) {\n                            case 'float':\n                                glType = _gl.FLOAT;\n                                break;\n                            case 'byte':\n                                glType = _gl.BYTE;\n                                break;\n                            case 'ubyte':\n                                glType = _gl.UNSIGNED_BYTE;\n                                break;\n                            case 'short':\n                                glType = _gl.SHORT;\n                                break;\n                            case 'ushort':\n                                glType = _gl.UNSIGNED_SHORT;\n                                break;\n                            default:\n                                glType = _gl.FLOAT;\n                                break;\n                        }\n\n                        _gl.bindBuffer(_gl.ARRAY_BUFFER, buffer);\n                        _gl.vertexAttribPointer(location, size, glType, false, 0, 0);\n                    }\n                }\n                if (\n                    glDrawMode == glenum.LINES ||\n                    glDrawMode == glenum.LINE_STRIP ||\n                    glDrawMode == glenum.LINE_LOOP\n                ) {\n                    _gl.lineWidth(this.lineWidth);\n                }\n\n                prevDrawIndicesBuffer = indicesBuffer;\n                prevDrawIsUseIndices = geometry.isUseIndices();\n                // Do drawing\n                if (prevDrawIsUseIndices) {\n                    if (needsBindAttributes) {\n                        _gl.bindBuffer(_gl.ELEMENT_ARRAY_BUFFER, indicesBuffer.buffer);\n                    }\n                    _gl.drawElements(glDrawMode, indicesBuffer.count, indicesType, 0);\n                    renderInfo.triangleCount += indicesBuffer.count / 3;\n                } else {\n                    _gl.drawArrays(glDrawMode, 0, nVertex);\n                }\n\n                if (vaoExt && isStatic) {\n                    vaoExt.bindVertexArrayOES(null);\n                }\n\n                renderInfo.drawCallCount++;\n            }\n        }\n\n        return renderInfo;\n    },\n\n    /**\n     * Clone a new renderable\n     * @function\n     * @return {clay.Renderable}\n     */\n    clone: (function() {\n        var properties = [\n            'castShadow', 'receiveShadow',\n            'mode', 'culling', 'cullFace', 'frontFace',\n            'frustumCulling',\n            'renderOrder', 'lineWidth',\n            'ignorePicking', 'ignorePreZ', 'ignoreGBuffer'\n        ];\n        return function() {\n            var renderable = Node.prototype.clone.call(this);\n\n            renderable.geometry = this.geometry;\n            renderable.material = this.material;\n\n            for (var i = 0; i < properties.length; i++) {\n                var name = properties[i];\n                // Try not to overwrite the prototype property\n                if (renderable[name] !== this[name]) {\n                    renderable[name] = this[name];\n                }\n            }\n\n            return renderable;\n        };\n    })()\n});\n\n/**\n * @type {number}\n */\nRenderable.POINTS = glenum.POINTS;\n/**\n * @type {number}\n */\nRenderable.LINES = glenum.LINES;\n/**\n * @type {number}\n */\nRenderable.LINE_LOOP = glenum.LINE_LOOP;\n/**\n * @type {number}\n */\nRenderable.LINE_STRIP = glenum.LINE_STRIP;\n/**\n * @type {number}\n */\nRenderable.TRIANGLES = glenum.TRIANGLES;\n/**\n * @type {number}\n */\nRenderable.TRIANGLE_STRIP = glenum.TRIANGLE_STRIP;\n/**\n * @type {number}\n */\nRenderable.TRIANGLE_FAN = glenum.TRIANGLE_FAN;\n/**\n * @type {number}\n */\nRenderable.BACK = glenum.BACK;\n/**\n * @type {number}\n */\nRenderable.FRONT = glenum.FRONT;\n/**\n * @type {number}\n */\nRenderable.FRONT_AND_BACK = glenum.FRONT_AND_BACK;\n/**\n * @type {number}\n */\nRenderable.CW = glenum.CW;\n/**\n * @type {number}\n */\nRenderable.CCW = glenum.CCW;\n\nRenderable.RenderInfo = RenderInfo;\n\nexport default Renderable;\n","import Renderable from './Renderable';\nimport glenum from './core/glenum';\nimport Texture2D from './Texture2D';\n\n/**\n * @constructor clay.Mesh\n * @extends clay.Renderable\n */\nvar Mesh = Renderable.extend(\n/** @lends clay.Mesh# */\n{\n    /**\n     * Used when it is a skinned mesh\n     * @type {clay.Skeleton}\n     */\n    skeleton: null,\n    /**\n     * Joints indices Meshes can share the one skeleton instance and each mesh can use one part of joints. Joints indices indicate the index of joint in the skeleton instance\n     * @type {number[]}\n     */\n    joints: null,\n\n    /**\n     * If store the skin matrices in vertex texture\n     * @type {bool}\n     */\n    useSkinMatricesTexture: false\n\n}, function () {\n    if (!this.joints) {\n        this.joints = [];\n    }\n}, {\n\n    isSkinnedMesh: function () {\n        return !!(this.skeleton && this.joints && this.joints.length > 0);\n    },\n\n    render: function (renderer, shader, program) {\n        var _gl = renderer.gl;\n        // Set pose matrices of skinned mesh\n        if (this.skeleton) {\n            // TODO Multiple mesh share same skeleton\n            this.skeleton.update();\n\n            var skinMatricesArray = this.skeleton.getSubSkinMatrices(this.__uid__, this.joints);\n\n            // if (this.useSkinMatricesTexture) {\n            //     var size;\n            //     var numJoints = this.joints.length;\n            //     if (numJoints > 256) {\n            //         size = 64;\n            //     }\n            //     else if (numJoints > 64) {\n            //         size = 32;\n            //     }\n            //     else if (numJoints > 16) {\n            //         size = 16;\n            //     }\n            //     else {\n            //         size = 8;\n            //     }\n\n            //     var texture = this.getSkinMatricesTexture();\n            //     texture.width = size;\n            //     texture.height = size;\n\n            //     if (!texture.pixels || texture.pixels.length !== size * size * 4) {\n            //         texture.pixels = new Float32Array(size * size * 4);\n            //     }\n            //     texture.pixels.set(skinMatricesArray);\n            //     texture.dirty();\n\n            //     shader.setUniform(_gl, '1f', 'skinMatricesTextureSize', size);\n            // }\n            // else {\n            program.setUniformOfSemantic(_gl, 'SKIN_MATRIX', skinMatricesArray);\n            // }\n        }\n\n        return Renderable.prototype.render.call(this, renderer, shader, program);\n    },\n\n    getSkinMatricesTexture: function () {\n        this._skinMatricesTexture = this._skinMatricesTexture || new Texture2D({\n            type: glenum.FLOAT,\n            minFilter: glenum.NEAREST,\n            magFilter: glenum.NEAREST,\n            useMipmap: false,\n            flipY: false\n        });\n\n        return this._skinMatricesTexture;\n    }\n});\n\n// Enums\nMesh.POINTS = glenum.POINTS;\nMesh.LINES = glenum.LINES;\nMesh.LINE_LOOP = glenum.LINE_LOOP;\nMesh.LINE_STRIP = glenum.LINE_STRIP;\nMesh.TRIANGLES = glenum.TRIANGLES;\nMesh.TRIANGLE_STRIP = glenum.TRIANGLE_STRIP;\nMesh.TRIANGLE_FAN = glenum.TRIANGLE_FAN;\n\nMesh.BACK = glenum.BACK;\nMesh.FRONT = glenum.FRONT;\nMesh.FRONT_AND_BACK = glenum.FRONT_AND_BACK;\nMesh.CW = glenum.CW;\nMesh.CCW = glenum.CCW;\n\nexport default Mesh;\n","import Camera from '../Camera';\n\n/**\n * @constructor clay.camera.Perspective\n * @extends clay.Camera\n */\nvar Perspective = Camera.extend(\n/** @lends clay.camera.Perspective# */\n{\n    /**\n     * Vertical field of view in radians\n     * @type {number}\n     */\n    fov: 50,\n    /**\n     * Aspect ratio, typically viewport width / height\n     * @type {number}\n     */\n    aspect: 1,\n    /**\n     * Near bound of the frustum\n     * @type {number}\n     */\n    near: 0.1,\n    /**\n     * Far bound of the frustum\n     * @type {number}\n     */\n    far: 2000\n},\n/** @lends clay.camera.Perspective.prototype */\n{\n\n    updateProjectionMatrix: function() {\n        var rad = this.fov / 180 * Math.PI;\n        this.projectionMatrix.perspective(rad, this.aspect, this.near, this.far);\n    },\n    decomposeProjectionMatrix: function () {\n        var m = this.projectionMatrix.array;\n        var rad = Math.atan(1 / m[5]) * 2;\n        this.fov = rad / Math.PI * 180;\n        this.aspect = m[5] / m[0];\n        this.near = m[14] / (m[10] - 1);\n        this.far = m[14] / (m[10] + 1);\n    },\n    /**\n     * @return {clay.camera.Perspective}\n     */\n    clone: function() {\n        var camera = Camera.prototype.clone.call(this);\n        camera.fov = this.fov;\n        camera.aspect = this.aspect;\n        camera.near = this.near;\n        camera.far = this.far;\n\n        return camera;\n    }\n});\n\nexport default Perspective;\n","import Camera from '../Camera';\n/**\n * @constructor clay.camera.Orthographic\n * @extends clay.Camera\n */\nvar Orthographic = Camera.extend(\n/** @lends clay.camera.Orthographic# */\n{\n    /**\n     * @type {number}\n     */\n    left: -1,\n    /**\n     * @type {number}\n     */\n    right: 1,\n    /**\n     * @type {number}\n     */\n    near: -1,\n    /**\n     * @type {number}\n     */\n    far: 1,\n    /**\n     * @type {number}\n     */\n    top: 1,\n    /**\n     * @type {number}\n     */\n    bottom: -1\n},\n/** @lends clay.camera.Orthographic.prototype */\n{\n\n    updateProjectionMatrix: function() {\n        this.projectionMatrix.ortho(this.left, this.right, this.bottom, this.top, this.near, this.far);\n    },\n\n    decomposeProjectionMatrix: function () {\n        var m = this.projectionMatrix.array;\n        this.left = (-1 - m[12]) / m[0];\n        this.right = (1 - m[12]) / m[0];\n        this.top = (1 - m[13]) / m[5];\n        this.bottom = (-1 - m[13]) / m[5];\n        this.near = -(-1 - m[14]) / m[10];\n        this.far = -(1 - m[14]) / m[10];\n    },\n    /**\n     * @return {clay.camera.Orthographic}\n     */\n    clone: function() {\n        var camera = Camera.prototype.clone.call(this);\n        camera.left = this.left;\n        camera.right = this.right;\n        camera.near = this.near;\n        camera.far = this.far;\n        camera.top = this.top;\n        camera.bottom = this.bottom;\n\n        return camera;\n    }\n});\n\nexport default Orthographic;\n","function get(options) {\n\n    var xhr = new XMLHttpRequest();\n\n    xhr.open('get', options.url);\n    // With response type set browser can get and put binary data\n    // https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/Sending_and_Receiving_Binary_Data\n    // Default is text, and it can be set\n    // arraybuffer, blob, document, json, text\n    xhr.responseType = options.responseType || 'text';\n\n    if (options.onprogress) {\n        //https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/Using_XMLHttpRequest\n        xhr.onprogress = function(e) {\n            if (e.lengthComputable) {\n                var percent = e.loaded / e.total;\n                options.onprogress(percent, e.loaded, e.total);\n            }\n            else {\n                options.onprogress(null);\n            }\n        };\n    }\n    xhr.onload = function(e) {\n        if (xhr.status >= 400) {\n            options.onerror && options.onerror();\n        }\n        else {\n            options.onload && options.onload(xhr.response);\n        }\n    };\n    if (options.onerror) {\n        xhr.onerror = options.onerror;\n    }\n    xhr.send(null);\n}\n\nexport default {\n    get : get\n};\n","export default \"\\n@export clay.standard.vertex\\n#define SHADER_NAME standard\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\n#if defined(AOMAP_ENABLED)\\nattribute vec2 texcoord2 : TEXCOORD_1;\\n#endif\\nattribute vec3 normal : NORMAL;\\nattribute vec4 tangent : TANGENT;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nvarying vec3 v_Barycentric;\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\n#endif\\n#if defined(AOMAP_ENABLED)\\nvarying vec2 v_Texcoord2;\\n#endif\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n    vec3 skinnedNormal = normal;\\n    vec3 skinnedTangent = tangent.xyz;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n    skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n    v_Barycentric = barycentric;\\n    v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\n    v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\\n    v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\\n#endif\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n#if defined(AOMAP_ENABLED)\\n    v_Texcoord2 = texcoord2;\\n#endif\\n}\\n@end\\n@export clay.standard.fragment\\n#define PI 3.14159265358979\\n#define GLOSSINESS_CHANNEL 0\\n#define ROUGHNESS_CHANNEL 0\\n#define METALNESS_CHANNEL 1\\nuniform mat4 viewInverse : VIEWINVERSE;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\n#endif\\n#ifdef NORMALMAP_ENABLED\\nuniform sampler2D normalMap;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\nuniform sampler2D diffuseMap;\\n#endif\\n#ifdef SPECULARMAP_ENABLED\\nuniform sampler2D specularMap;\\n#endif\\n#ifdef USE_ROUGHNESS\\nuniform float roughness : 0.5;\\n    #ifdef ROUGHNESSMAP_ENABLED\\nuniform sampler2D roughnessMap;\\n    #endif\\n#else\\nuniform float glossiness: 0.5;\\n    #ifdef GLOSSINESSMAP_ENABLED\\nuniform sampler2D glossinessMap;\\n    #endif\\n#endif\\n#ifdef METALNESSMAP_ENABLED\\nuniform sampler2D metalnessMap;\\n#endif\\n#ifdef ENVIRONMENTMAP_ENABLED\\nuniform samplerCube environmentMap;\\n    #ifdef PARALLAX_CORRECTED\\nuniform vec3 environmentBoxMin;\\nuniform vec3 environmentBoxMax;\\n    #endif\\n#endif\\n#ifdef BRDFLOOKUP_ENABLED\\nuniform sampler2D brdfLookup;\\n#endif\\n#ifdef EMISSIVEMAP_ENABLED\\nuniform sampler2D emissiveMap;\\n#endif\\n#ifdef SSAOMAP_ENABLED\\nuniform sampler2D ssaoMap;\\nuniform vec4 viewport : VIEWPORT;\\n#endif\\n#ifdef AOMAP_ENABLED\\nuniform sampler2D aoMap;\\nuniform float aoIntensity;\\nvarying vec2 v_Texcoord2;\\n#endif\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\n#ifdef USE_METALNESS\\nuniform float metalness : 0.0;\\n#else\\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\\n#endif\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float emissionIntensity: 1;\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n#ifdef ENVIRONMENTMAP_PREFILTER\\nuniform float maxMipmapLevel: 5;\\n#endif\\n#ifdef AMBIENT_LIGHT_COUNT\\n@import clay.header.ambient_light\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n@import clay.header.ambient_sh_light\\n#endif\\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\\n@import clay.header.ambient_cubemap_light\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n@import clay.header.point_light\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n@import clay.header.directional_light\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n@import clay.header.spot_light\\n#endif\\n@import clay.util.calculate_attenuation\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.util.srgb\\n@import clay.plugin.compute_shadow_map\\n@import clay.util.parallax_correct\\n@import clay.util.ACES\\nfloat G_Smith(float g, float ndv, float ndl)\\n{\\n    float roughness = 1.0 - g;\\n    float k = roughness * roughness / 2.0;\\n    float G1V = ndv / (ndv * (1.0 - k) + k);\\n    float G1L = ndl / (ndl * (1.0 - k) + k);\\n    return G1L * G1V;\\n}\\nvec3 F_Schlick(float ndv, vec3 spec) {\\n    return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\\n}\\nfloat D_Phong(float g, float ndh) {\\n    float a = pow(8192.0, g);\\n    return (a + 2.0) / 8.0 * pow(ndh, a);\\n}\\nfloat D_GGX(float g, float ndh) {\\n    float r = 1.0 - g;\\n    float a = r * r;\\n    float tmp = ndh * ndh * (a - 1.0) + 1.0;\\n    return a / (PI * tmp * tmp);\\n}\\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\\nuniform float parallaxOcclusionScale : 0.02;\\nuniform float parallaxMaxLayers : 20;\\nuniform float parallaxMinLayers : 5;\\nuniform sampler2D parallaxOcclusionMap;\\nmat3 transpose(in mat3 inMat)\\n{\\n    vec3 i0 = inMat[0];\\n    vec3 i1 = inMat[1];\\n    vec3 i2 = inMat[2];\\n    return mat3(\\n        vec3(i0.x, i1.x, i2.x),\\n        vec3(i0.y, i1.y, i2.y),\\n        vec3(i0.z, i1.z, i2.z)\\n    );\\n}\\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\\n{\\n    float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\\n    float layerHeight = 1.0 / numLayers;\\n    float curLayerHeight = 0.0;\\n    vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\\n    vec2 curUv = uv;\\n    float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\\n    for (int i = 0; i < 30; i++) {\\n        curLayerHeight += layerHeight;\\n        curUv -= deltaUv;\\n        height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\\n        if (height < curLayerHeight) {\\n            break;\\n        }\\n    }\\n    vec2 prevUv = curUv + deltaUv;\\n    float next = height - curLayerHeight;\\n    float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\\n    return mix(curUv, prevUv, next / (next - prev));\\n}\\n#endif\\nvoid main() {\\n    vec4 albedoColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    albedoColor *= v_Color;\\n#endif\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 V = normalize(eyePos - v_WorldPosition);\\n    vec2 uv = v_Texcoord;\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\n    mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\\n#endif\\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\\n    uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 texel = texture2D(diffuseMap, uv);\\n    #ifdef SRGB_DECODE\\n    texel = sRGBToLinear(texel);\\n    #endif\\n    albedoColor.rgb *= texel.rgb;\\n    #ifdef DIFFUSEMAP_ALPHA_ALPHA\\n    albedoColor.a *= texel.a;\\n    #endif\\n#endif\\n#ifdef USE_METALNESS\\n    float m = metalness;\\n    #ifdef METALNESSMAP_ENABLED\\n    float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\\n    m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n    vec3 baseColor = albedoColor.rgb;\\n    albedoColor.rgb = baseColor * (1.0 - m);\\n    vec3 spec = mix(vec3(0.04), baseColor, m);\\n#else\\n    vec3 spec = specularColor;\\n#endif\\n#ifdef USE_ROUGHNESS\\n    float g = 1.0 - roughness;\\n    #ifdef ROUGHNESSMAP_ENABLED\\n    float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\\n    g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n#else\\n    float g = glossiness;\\n    #ifdef GLOSSINESSMAP_ENABLED\\n    float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\\n    g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n#endif\\n#ifdef SPECULARMAP_ENABLED\\n    spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\\n#endif\\n    vec3 N = v_Normal;\\n#ifdef DOUBLE_SIDED\\n    if (dot(N, V) < 0.0) {\\n        N = -N;\\n    }\\n#endif\\n#ifdef NORMALMAP_ENABLED\\n    if (dot(v_Tangent, v_Tangent) > 0.0) {\\n        vec3 normalTexel = texture2D(normalMap, uv).xyz;\\n        if (dot(normalTexel, normalTexel) > 0.0) {            N = normalTexel * 2.0 - 1.0;\\n            tbn[1] = -tbn[1];\\n            N = normalize(tbn * N);\\n        }\\n    }\\n#endif\\n    vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\\n    vec3 specularTerm = vec3(0.0, 0.0, 0.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    vec3 fresnelTerm = F_Schlick(ndv, spec);\\n#ifdef AMBIENT_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseTerm += ambientLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsPoint[POINT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\\n    }\\n#endif\\n    for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\\n    {{\\n        vec3 lightPosition = pointLightPosition[_idx_];\\n        vec3 lc = pointLightColor[_idx_];\\n        float range = pointLightRange[_idx_];\\n        vec3 L = lightPosition - v_WorldPosition;\\n        float dist = length(L);\\n        float attenuation = lightAttenuation(dist, range);\\n        L /= dist;\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n        if(shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsPoint[_idx_];\\n        }\\n#endif\\n        vec3 li = lc * ndl * attenuation * shadowContrib;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }}\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\\n    }\\n#endif\\n    for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\\n    {{\\n        vec3 L = -normalize(directionalLightDirection[_idx_]);\\n        vec3 lc = directionalLightColor[_idx_];\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n        if(shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsDir[_idx_];\\n        }\\n#endif\\n        vec3 li = lc * ndl * shadowContrib;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }}\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsSpot[SPOT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\\n    }\\n#endif\\n    for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = spotLightPosition[i];\\n        vec3 spotLightDirection = -normalize(spotLightDirection[i]);\\n        vec3 lc = spotLightColor[i];\\n        float range = spotLightRange[i];\\n        float a = spotLightUmbraAngleCosine[i];\\n        float b = spotLightPenumbraAngleCosine[i];\\n        float falloffFactor = spotLightFalloffFactor[i];\\n        vec3 L = lightPosition - v_WorldPosition;\\n        float dist = length(L);\\n        float attenuation = lightAttenuation(dist, range);\\n        L /= dist;\\n        float c = dot(spotLightDirection, L);\\n        float falloff;\\n        falloff = clamp((c - a) /( b - a), 0.0, 1.0);\\n        falloff = pow(falloff, falloffFactor);\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n        if (shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsSpot[i];\\n        }\\n#endif\\n        vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }\\n#endif\\n    vec4 outColor = albedoColor;\\n    outColor.rgb *= diffuseTerm;\\n    outColor.rgb += specularTerm;\\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\\n    vec3 L = reflect(-V, N);\\n    float rough2 = clamp(1.0 - g, 0.0, 1.0);\\n    float bias2 = rough2 * 5.0;\\n    vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\\n    vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\\n    vec3 envTexel2;\\n    for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\\n    {{\\n        envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\\n        outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\\n    }}\\n#endif\\n#ifdef ENVIRONMENTMAP_ENABLED\\n    vec3 envWeight = g * fresnelTerm;\\n    vec3 L = reflect(-V, N);\\n    #ifdef PARALLAX_CORRECTED\\n    L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\\n    #endif\\n    #ifdef ENVIRONMENTMAP_PREFILTER\\n    float rough = clamp(1.0 - g, 0.0, 1.0);\\n    float bias = rough * maxMipmapLevel;\\n    vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\\n        #ifdef BRDFLOOKUP_ENABLED\\n    vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\\n    envWeight = spec * brdfParam.x + brdfParam.y;\\n        #endif\\n    #else\\n    vec3 envTexel = textureCube(environmentMap, L).xyz;\\n    #endif\\n    outColor.rgb += envTexel * envWeight;\\n#endif\\n    float aoFactor = 1.0;\\n#ifdef SSAOMAP_ENABLED\\n    aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\\n#endif\\n#ifdef AOMAP_ENABLED\\n    aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\\n#endif\\n    outColor.rgb *= aoFactor;\\n    vec3 lEmission = emission;\\n#ifdef EMISSIVEMAP_ENABLED\\n    lEmission *= texture2D(emissiveMap, uv).rgb;\\n#endif\\n    outColor.rgb += lEmission * emissionIntensity;\\n#ifdef GAMMA_ENCODE\\n    outColor.rgb = pow(outColor.rgb, vec3(1 / 2.2));\\n#endif\\n    if(lineWidth > 0.)\\n    {\\n        outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef ALPHA_TEST\\n    if (outColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    outColor.rgb = ACESToneMapping(outColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    outColor = linearTosRGB(outColor);\\n#endif\\n    gl_FragColor = encodeHDR(outColor);\\n}\\n@end\\n@export clay.standardMR.vertex\\n@import clay.standard.vertex\\n@end\\n@export clay.standardMR.fragment\\n#define USE_METALNESS\\n#define USE_ROUGHNESS\\n@import clay.standard.fragment\\n@end\";\n","import Material from './Material';\n\nimport Shader from './Shader';\nimport standardEssl from './shader/source/standard.glsl.js';\nimport util from './core/util';\n\n// Import standard shader\nShader['import'](standardEssl);\n\nvar TEXTURE_PROPERTIES = ['diffuseMap', 'normalMap', 'roughnessMap', 'metalnessMap', 'emissiveMap', 'environmentMap', 'brdfLookup', 'ssaoMap', 'aoMap'];\nvar SIMPLE_PROPERTIES = ['color', 'emission', 'emissionIntensity', 'alpha', 'roughness', 'metalness', 'uvRepeat', 'uvOffset', 'aoIntensity', 'alphaCutoff'];\nvar PROPERTIES_CHANGE_SHADER = ['linear', 'encodeRGBM', 'decodeRGBM', 'doubleSided', 'alphaTest', 'roughnessChannel', 'metalnessChannel', 'environmentMapPrefiltered'];\n\nvar NUM_DEFINE_MAP = {\n    'roughnessChannel': 'ROUGHNESS_CHANNEL',\n    'metalnessChannel': 'METALNESS_CHANNEL'\n};\nvar BOOL_DEFINE_MAP = {\n    'linear': 'SRGB_DECODE',\n    'encodeRGBM': 'RGBM_ENCODE',\n    'decodeRGBM': 'RGBM_DECODE',\n    'doubleSided': 'DOUBLE_SIDED',\n    'alphaTest': 'ALPHA_TEST',\n    'environmentMapPrefiltered': 'ENVIRONMENTMAP_PREFILTER'\n}\n\n\nvar standardShader;\n/**\n * Standard material without custom shader.\n * @constructor clay.StandardMaterial\n * @extends clay.Base\n * @example\n * var mat = new clay.StandardMaterial({\n *     color: [1, 1, 1],\n *     diffuseMap: diffuseTexture\n * });\n * mat.roughness = 1;\n */\nvar StandardMaterial = Material.extend(function () {\n    if (!standardShader) {\n        standardShader = new Shader(Shader.source('clay.standard.vertex'), Shader.source('clay.standard.fragment'));\n    }\n    return /** @lends clay.StandardMaterial# */ {\n        shader: standardShader\n    };\n}, function (option) {\n    // PENDING\n    util.extend(this, option);\n    // Extend after shader is created.\n    util.defaults(this, /** @lends clay.StandardMaterial# */  {\n        /**\n         * @type {Array.<number>}\n         * @default [1, 1, 1]\n         */\n        color: [1, 1, 1],\n\n        /**\n         * @type {Array.<number>}\n         * @default [0, 0, 0]\n         */\n        emission: [0, 0, 0],\n\n        /**\n         * @type {number}\n         * @default 0\n         */\n        emissionIntensity: 0,\n\n        /**\n         * @type {number}\n         * @default 0.5\n         */\n        roughness: 0.5,\n\n        /**\n         * @type {number}\n         * @default 0\n         */\n        metalness: 0,\n\n        /**\n         * @type {number}\n         * @default 1\n         */\n        alpha: 1,\n\n        /**\n         * @type {boolean}\n         */\n        alphaTest: false,\n\n        /**\n         * Cutoff threshold for alpha test\n         * @type {number}\n         */\n        alphaCutoff: 0.9,\n\n        /**\n         * @type {boolean}\n         */\n        // TODO Must disable culling.\n        doubleSided: false,\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.TextureCube}\n         */\n\n        /**\n         * @type {clay.math.BoundingBox}\n         */\n\n        /**\n         * BRDF Lookup is generated by clay.util.cubemap.integrateBrdf\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {Array.<number>}\n         * @default [1, 1]\n         */\n        uvRepeat: [1, 1],\n\n        /**\n         * @type {Array.<number>}\n         * @default [0, 0]\n         */\n        uvOffset: [0, 0],\n\n        /**\n         * @type {number}\n         * @default 1\n         */\n        aoIntensity: 1,\n\n        /**\n         * @type {boolean}\n         */\n        environmentMapPrefiltered: false,\n\n        /**\n         * @type {boolean}\n         */\n        linear: false,\n\n        /**\n         * @type {boolean}\n         */\n        encodeRGBM: false,\n\n        /**\n         * @type {boolean}\n         */\n        decodeRGBM: false,\n\n        /**\n         * @type {Number}\n         */\n        roughnessChannel: 0,\n        /**\n         * @type {Number}\n         */\n        metalnessChannel: 1\n    });\n\n    this.define('fragment', 'USE_METALNESS');\n    this.define('fragment', 'USE_ROUGHNESS');\n}, {\n    clone: function () {\n        var material = new StandardMaterial({\n            name: this.name\n        });\n        TEXTURE_PROPERTIES.forEach(function (propName) {\n            if (this[propName]) {\n                material[propName] = this[propName];\n            }\n        }, this);\n        SIMPLE_PROPERTIES.concat(PROPERTIES_CHANGE_SHADER).forEach(function (propName) {\n            material[propName] = this[propName];\n        }, this);\n        return material;\n    }\n});\n\nSIMPLE_PROPERTIES.forEach(function (propName) {\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this.get(propName);\n        },\n        set: function (value) {\n            this.setUniform(propName, value);\n        }\n    });\n});\n\nTEXTURE_PROPERTIES.forEach(function (propName) {\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this.get(propName);\n        },\n        set: function (value) {\n            this.setUniform(propName, value);\n        }\n    });\n});\n\nPROPERTIES_CHANGE_SHADER.forEach(function (propName) {\n    var privateKey = '_' + propName;\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this[privateKey];\n        },\n        set: function (value) {\n            this[privateKey] = value;\n            if (propName in NUM_DEFINE_MAP) {\n                var defineName = NUM_DEFINE_MAP[propName];\n                this.define('fragment', defineName, value);\n            }\n            else {\n                var defineName = BOOL_DEFINE_MAP[propName];\n                value ? this.define('fragment', defineName) : this.undefine('fragment', defineName);\n            }\n        }\n    });\n});\n\nObject.defineProperty(StandardMaterial.prototype, 'environmentBox', {\n    get: function () {\n        var envBox = this._environmentBox;\n        if (envBox) {\n            envBox.min.setArray(this.get('environmentBoxMin'));\n            envBox.max.setArray(this.get('environmentBoxMax'));\n        }\n        return envBox;\n    },\n\n    set: function (value) {\n        this._environmentBox = value;\n\n        var uniforms = this.uniforms = this.uniforms || {};\n        uniforms['environmentBoxMin'] = uniforms['environmentBoxMin'] || {\n            value: null\n        };\n        uniforms['environmentBoxMax'] = uniforms['environmentBoxMax'] || {\n            value: null\n        };\n\n        // TODO Can't detect operation like box.min = new Vector()\n        if (value) {\n            this.setUniform('environmentBoxMin', value.min.array);\n            this.setUniform('environmentBoxMax', value.max.array);\n        }\n\n        if (value) {\n            this.define('fragment', 'PARALLAX_CORRECTED');\n        }\n        else {\n            this.undefine('fragment', 'PARALLAX_CORRECTED');\n        }\n    }\n});\n\nexport default StandardMaterial;\n","import Base from './core/Base';\n\n/**\n * @constructor clay.Joint\n * @extends clay.core.Base\n */\nvar Joint = Base.extend(\n/** @lends clay.Joint# */\n{\n    // https://github.com/KhronosGroup/glTF/issues/193#issuecomment-29216576\n    /**\n     * Joint name\n     * @type {string}\n     */\n    name: '',\n    /**\n     * Index of joint in the skeleton\n     * @type {number}\n     */\n    index: -1,\n\n    /**\n     * Scene node attached to\n     * @type {clay.Node}\n     */\n    node: null,\n\n    /**\n     * Root scene node of the skeleton, which parent node is null or don't have a joint\n     * @type {clay.Node}\n     */\n    rootNode: null\n});\n\nexport default Joint;\n","import Base from './core/Base';\nimport Joint from './Joint';\n\nimport glMatrix from './dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\n\n/**\n * @constructor clay.Skeleton\n */\nvar Skeleton = Base.extend(function () {\n    return /** @lends clay.Skeleton# */{\n\n        /**\n         * Relative root node that not affect transform of joint.\n         * @type {clay.Node}\n         */\n        relativeRootNode: null,\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * joints\n         * @type {Array.<clay.Joint>}\n         */\n        joints: [],\n\n        _clips: [],\n\n        // Matrix to joint space (relative to root joint)\n        _invBindPoseMatricesArray: null,\n\n        // Use subarray instead of copy back each time computing matrix\n        // http://jsperf.com/subarray-vs-copy-for-array-transform/5\n        _jointMatricesSubArrays: [],\n\n        // jointMatrix * currentPoseMatrix\n        // worldTransform is relative to the root bone\n        // still in model space not world space\n        _skinMatricesArray: null,\n\n        _skinMatricesSubArrays: [],\n\n        _subSkinMatricesArray: {}\n    };\n},\n/** @lends clay.Skeleton.prototype */\n{\n\n    /**\n     * Add a skinning clip and create a map between clip and skeleton\n     * @param {clay.animation.SkinningClip} clip\n     * @param {Object} [mapRule] Map between joint name in skeleton and joint name in clip\n     */\n    addClip: function (clip, mapRule) {\n        // Clip have been exists in\n        for (var i = 0; i < this._clips.length; i++) {\n            if (this._clips[i].clip === clip) {\n                return;\n            }\n        }\n        // Map the joint index in skeleton to joint pose index in clip\n        var maps = [];\n        for (var i = 0; i < this.joints.length; i++) {\n            maps[i] = -1;\n        }\n        // Create avatar\n        for (var i = 0; i < clip.tracks.length; i++) {\n            for (var j = 0; j < this.joints.length; j++) {\n                var joint = this.joints[j];\n                var track = clip.tracks[i];\n                var jointName = joint.name;\n                if (mapRule) {\n                    jointName = mapRule[jointName];\n                }\n                if (track.name === jointName) {\n                    maps[j] = i;\n                    break;\n                }\n            }\n        }\n\n        this._clips.push({\n            maps: maps,\n            clip: clip\n        });\n\n        return this._clips.length - 1;\n    },\n\n    /**\n     * @param {clay.animation.SkinningClip} clip\n     */\n    removeClip: function (clip) {\n        var idx = -1;\n        for (var i = 0; i < this._clips.length; i++) {\n            if (this._clips[i].clip === clip) {\n                idx = i;\n                break;\n            }\n        }\n        if (idx > 0) {\n            this._clips.splice(idx, 1);\n        }\n    },\n    /**\n     * Remove all clips\n     */\n    removeClipsAll: function () {\n        this._clips = [];\n    },\n\n    /**\n     * Get clip by index\n     * @param  {number} index\n     */\n    getClip: function (index) {\n        if (this._clips[index]) {\n            return this._clips[index].clip;\n        }\n    },\n\n    /**\n     * @return {number}\n     */\n    getClipNumber: function () {\n        return this._clips.length;\n    },\n\n    /**\n     * Calculate joint matrices from node transform\n     * @function\n     */\n    updateJointMatrices: (function () {\n\n        var m4 = mat4.create();\n\n        return function () {\n            this._invBindPoseMatricesArray = new Float32Array(this.joints.length * 16);\n            this._skinMatricesArray = new Float32Array(this.joints.length * 16);\n\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                // if (this.relativeRootNode) {\n                //     mat4.invert(m4, this.relativeRootNode.worldTransform.array);\n                //     mat4.multiply(\n                //         m4,\n                //         m4,\n                //         joint.node.worldTransform.array\n                //     );\n                //     mat4.invert(m4, m4);\n                // }\n                // else {\n                    mat4.copy(m4, joint.node.worldTransform.array);\n                    mat4.invert(m4, m4);\n                // }\n\n                var offset = i * 16;\n                for (var j = 0; j < 16; j++) {\n                    this._invBindPoseMatricesArray[offset + j] = m4[j];\n                }\n            }\n\n            this.updateMatricesSubArrays();\n        };\n    })(),\n\n    setJointMatricesArray: function (arr) {\n        this._invBindPoseMatricesArray = arr;\n        this._skinMatricesArray = new Float32Array(arr.length);\n        this.updateMatricesSubArrays();\n    },\n\n    updateMatricesSubArrays: function () {\n        for (var i = 0; i < this.joints.length; i++) {\n            this._jointMatricesSubArrays[i] = this._invBindPoseMatricesArray.subarray(i * 16, (i+1) * 16);\n            this._skinMatricesSubArrays[i] = this._skinMatricesArray.subarray(i * 16, (i+1) * 16);\n        }\n    },\n\n    /**\n     * Update skinning matrices\n     */\n    update: (function () {\n        // var m4 = mat4.create();\n        return function () {\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                mat4.multiply(\n                    this._skinMatricesSubArrays[i],\n                    joint.node.worldTransform.array,\n                    this._jointMatricesSubArrays[i]\n                );\n\n                // Joint space is relative to root, if have\n                // if (this.relativeRootNode) {\n                //     mat4.invert(m4, this.relativeRootNode.worldTransform.array);\n                //     mat4.multiply(\n                //         this._skinMatricesSubArrays[i],\n                //         m4,\n                //         this._skinMatricesSubArrays[i]\n                //     );\n                // }\n            }\n        };\n    })(),\n\n    getSubSkinMatrices: function (meshId, joints) {\n        var subArray = this._subSkinMatricesArray[meshId];\n        if (!subArray) {\n            subArray\n                = this._subSkinMatricesArray[meshId]\n                = new Float32Array(joints.length * 16);\n        }\n        var cursor = 0;\n        for (var i = 0; i < joints.length; i++) {\n            var idx = joints[i];\n            for (var j = 0; j < 16; j++) {\n                subArray[cursor++] = this._skinMatricesArray[idx * 16 + j];\n            }\n        }\n        return subArray;\n    },\n\n    /**\n     * Set pose and update skinning matrices\n     * @param {number} clipIndex\n     */\n    setPose: function (clipIndex) {\n        if (this._clips[clipIndex]) {\n            var clip = this._clips[clipIndex].clip;\n            var maps = this._clips[clipIndex].maps;\n\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                if (maps[i] === -1) {\n                    continue;\n                }\n                var pose = clip.tracks[maps[i]];\n\n                // Not update if there is no data.\n                // PENDING If sync pose.position, pose.rotation, pose.scale\n                if (pose.channels.position) {\n                    vec3.copy(joint.node.position.array, pose.position);\n                }\n                if (pose.channels.rotation) {\n                    quat.copy(joint.node.rotation.array, pose.rotation);\n                }\n                if (pose.channels.scale) {\n                    vec3.copy(joint.node.scale.array, pose.scale);\n                }\n\n                joint.node.position._dirty = true;\n                joint.node.rotation._dirty = true;\n                joint.node.scale._dirty = true;\n            }\n        }\n        this.update();\n    },\n\n    clone: function (rootNode, newRootNode) {\n        var skeleton = new Skeleton();\n        skeleton.name = this.name;\n\n        for (var i = 0; i < this.joints.length; i++) {\n            var newJoint = new Joint();\n            newJoint.name = this.joints[i].name;\n            newJoint.index = this.joints[i].index;\n\n            var path = this.joints[i].node.getPath(rootNode);\n            var rootNodePath = this.joints[i].rootNode.getPath(rootNode);\n\n            if (path != null && rootNodePath != null) {\n                newJoint.node = newRootNode.queryNode(path);\n            }\n            else {\n                // PENDING\n                console.warn('Something wrong in clone, may be the skeleton root nodes is not mounted on the cloned root node.')\n            }\n            skeleton.joints.push(newJoint);\n        }\n\n        if (this._invBindPoseMatricesArray) {\n            var len = this._invBindPoseMatricesArray.length;\n            skeleton._invBindPoseMatricesArray = new Float32Array(len);\n            for (var i = 0; i < len; i++) {\n                skeleton._invBindPoseMatricesArray[i] = this._invBindPoseMatricesArray[i];\n            }\n\n            skeleton._skinMatricesArray = new Float32Array(len);\n\n            skeleton.updateMatricesSubArrays();\n        }\n\n        skeleton.update();\n\n        return skeleton;\n    }\n});\n\nexport default Skeleton;\n","export default \"\\n@export clay.util.rand\\nhighp float rand(vec2 uv) {\\n    const highp float a = 12.9898, b = 78.233, c = 43758.5453;\\n    highp float dt = dot(uv.xy, vec2(a,b)), sn = mod(dt, 3.141592653589793);\\n    return fract(sin(sn) * c);\\n}\\n@end\\n@export clay.util.calculate_attenuation\\nuniform float attenuationFactor : 5.0;\\nfloat lightAttenuation(float dist, float range)\\n{\\n    float attenuation = 1.0;\\n    attenuation = dist*dist/(range*range+1.0);\\n    float att_s = attenuationFactor;\\n    attenuation = 1.0/(attenuation*att_s+1.0);\\n    att_s = 1.0/(att_s+1.0);\\n    attenuation = attenuation - att_s;\\n    attenuation /= 1.0 - att_s;\\n    return clamp(attenuation, 0.0, 1.0);\\n}\\n@end\\n@export clay.util.edge_factor\\nfloat edgeFactor(float width)\\n{\\n    vec3 d = fwidth(v_Barycentric);\\n    vec3 a3 = smoothstep(vec3(0.0), d * width, v_Barycentric);\\n    return min(min(a3.x, a3.y), a3.z);\\n}\\n@end\\n@export clay.util.encode_float\\nvec4 encodeFloat(const in float depth)\\n{\\n    const vec4 bitShifts = vec4(256.0*256.0*256.0, 256.0*256.0, 256.0, 1.0);\\n    const vec4 bit_mask  = vec4(0.0, 1.0/256.0, 1.0/256.0, 1.0/256.0);\\n    vec4 res = fract(depth * bitShifts);\\n    res -= res.xxyz * bit_mask;\\n    return res;\\n}\\n@end\\n@export clay.util.decode_float\\nfloat decodeFloat(const in vec4 color)\\n{\\n    const vec4 bitShifts = vec4(1.0/(256.0*256.0*256.0), 1.0/(256.0*256.0), 1.0/256.0, 1.0);\\n    return dot(color, bitShifts);\\n}\\n@end\\n@export clay.util.float\\n@import clay.util.encode_float\\n@import clay.util.decode_float\\n@end\\n@export clay.util.rgbm_decode\\nvec3 RGBMDecode(vec4 rgbm, float range) {\\n  return range * rgbm.rgb * rgbm.a;\\n}\\n@end\\n@export clay.util.rgbm_encode\\nvec4 RGBMEncode(vec3 color, float range) {\\n    if (dot(color, color) == 0.0) {\\n        return vec4(0.0);\\n    }\\n    vec4 rgbm;\\n    color /= range;\\n    rgbm.a = clamp(max(max(color.r, color.g), max(color.b, 1e-6)), 0.0, 1.0);\\n    rgbm.a = ceil(rgbm.a * 255.0) / 255.0;\\n    rgbm.rgb = color / rgbm.a;\\n    return rgbm;\\n}\\n@end\\n@export clay.util.rgbm\\n@import clay.util.rgbm_decode\\n@import clay.util.rgbm_encode\\nvec4 decodeHDR(vec4 color)\\n{\\n#if defined(RGBM_DECODE) || defined(RGBM)\\n    return vec4(RGBMDecode(color, 51.5), 1.0);\\n#else\\n    return color;\\n#endif\\n}\\nvec4 encodeHDR(vec4 color)\\n{\\n#if defined(RGBM_ENCODE) || defined(RGBM)\\n    return RGBMEncode(color.xyz, 51.5);\\n#else\\n    return color;\\n#endif\\n}\\n@end\\n@export clay.util.srgb\\nvec4 sRGBToLinear(in vec4 value) {\\n    return vec4(mix(pow(value.rgb * 0.9478672986 + vec3(0.0521327014), vec3(2.4)), value.rgb * 0.0773993808, vec3(lessThanEqual(value.rgb, vec3(0.04045)))), value.w);\\n}\\nvec4 linearTosRGB(in vec4 value) {\\n    return vec4(mix(pow(value.rgb, vec3(0.41666)) * 1.055 - vec3(0.055), value.rgb * 12.92, vec3(lessThanEqual(value.rgb, vec3(0.0031308)))), value.w);\\n}\\n@end\\n@export clay.chunk.skinning_header\\n#ifdef SKINNING\\nattribute vec3 weight : WEIGHT;\\nattribute vec4 joint : JOINT;\\nuniform mat4 skinMatrix[JOINT_COUNT] : SKIN_MATRIX;\\nmat4 getSkinMatrix(float idx) {\\n    return skinMatrix[int(idx)];\\n}\\n#endif\\n@end\\n@export clay.chunk.skin_matrix\\nmat4 skinMatrixWS = getSkinMatrix(joint.x) * weight.x;\\nif (weight.y > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.y) * weight.y;\\n}\\nif (weight.z > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.z) * weight.z;\\n}\\nfloat weightW = 1.0-weight.x-weight.y-weight.z;\\nif (weightW > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.w) * weightW;\\n}\\n@end\\n@export clay.util.parallax_correct\\nvec3 parallaxCorrect(in vec3 dir, in vec3 pos, in vec3 boxMin, in vec3 boxMax) {\\n    vec3 first = (boxMax - pos) / dir;\\n    vec3 second = (boxMin - pos) / dir;\\n    vec3 further = max(first, second);\\n    float dist = min(further.x, min(further.y, further.z));\\n    vec3 fixedPos = pos + dir * dist;\\n    vec3 boxCenter = (boxMax + boxMin) * 0.5;\\n    return normalize(fixedPos - boxCenter);\\n}\\n@end\\n@export clay.util.clamp_sample\\nvec4 clampSample(const in sampler2D texture, const in vec2 coord)\\n{\\n#ifdef STEREO\\n    float eye = step(0.5, coord.x) * 0.5;\\n    vec2 coordClamped = clamp(coord, vec2(eye, 0.0), vec2(0.5 + eye, 1.0));\\n#else\\n    vec2 coordClamped = clamp(coord, vec2(0.0), vec2(1.0));\\n#endif\\n    return texture2D(texture, coordClamped);\\n}\\n@end\\n@export clay.util.ACES\\nvec3 ACESToneMapping(vec3 color)\\n{\\n    const float A = 2.51;\\n    const float B = 0.03;\\n    const float C = 2.43;\\n    const float D = 0.59;\\n    const float E = 0.14;\\n    return (color * (A * color + B)) / (color * (C * color + D) + E);\\n}\\n@end\";\n","export default \"@export clay.basic.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec2 texcoord : TEXCOORD_0;\\nattribute vec3 position : POSITION;\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Barycentric;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_Barycentric = barycentric;\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n}\\n@end\\n@export clay.basic.fragment\\nvarying vec2 v_Texcoord;\\nuniform sampler2D diffuseMap;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.util.srgb\\n@import clay.util.ACES\\nvoid main()\\n{\\n#ifdef RENDER_TEXCOORD\\n    gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\\n    return;\\n#endif\\n    gl_FragColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    gl_FragColor *= v_Color;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\\n#ifdef SRGB_DECODE\\n    tex = sRGBToLinear(tex);\\n#endif\\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\\n    gl_FragColor.a = tex.a;\\n#endif\\n    gl_FragColor.rgb *= tex.rgb;\\n#endif\\n    gl_FragColor.rgb += emission;\\n    if( lineWidth > 0.)\\n    {\\n        gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef GAMMA_ENCODE\\n    gl_FragColor.rgb = pow(gl_FragColor.rgb, vec3(1 / 2.2));\\n#endif\\n#ifdef ALPHA_TEST\\n    if (gl_FragColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    gl_FragColor = linearTosRGB(gl_FragColor);\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n}\\n@end\";\n","export default \"\\n@export clay.lambert.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\nattribute vec3 normal : NORMAL;\\nattribute vec3 barycentric;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nvarying vec3 v_Barycentric;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n    vec3 skinnedNormal = normal;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4( skinnedPosition, 1.0 );\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_Normal = normalize( ( worldInverseTranspose * vec4(skinnedNormal, 0.0) ).xyz );\\n    v_WorldPosition = ( world * vec4( skinnedPosition, 1.0) ).xyz;\\n    v_Barycentric = barycentric;\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n}\\n@end\\n@export clay.lambert.fragment\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nuniform sampler2D diffuseMap;\\nuniform sampler2D alphaMap;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\n#ifdef AMBIENT_LIGHT_COUNT\\n@import clay.header.ambient_light\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n@import clay.header.ambient_sh_light\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n@import clay.header.point_light\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n@import clay.header.directional_light\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n@import clay.header.spot_light\\n#endif\\n@import clay.util.calculate_attenuation\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.plugin.compute_shadow_map\\n@import clay.util.ACES\\nvoid main()\\n{\\n#ifdef RENDER_NORMAL\\n    gl_FragColor = vec4(v_Normal * 0.5 + 0.5, 1.0);\\n    return;\\n#endif\\n#ifdef RENDER_TEXCOORD\\n    gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\\n    return;\\n#endif\\n    gl_FragColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    gl_FragColor *= v_Color;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 tex = texture2D( diffuseMap, v_Texcoord );\\n#ifdef SRGB_DECODE\\n    tex.rgb = pow(tex.rgb, vec3(2.2));\\n#endif\\n    gl_FragColor.rgb *= tex.rgb;\\n#ifdef DIFFUSEMAP_ALPHA_ALPHA\\n    gl_FragColor.a *= tex.a;\\n#endif\\n#endif\\n    vec3 diffuseColor = vec3(0.0, 0.0, 0.0);\\n#ifdef AMBIENT_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\\n    {\\n        diffuseColor += ambientLightColor[_idx_];\\n    }\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseColor += calcAmbientSHLight(_idx_, v_Normal) * ambientSHLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsPoint[POINT_LIGHT_COUNT];\\n    if( shadowEnabled )\\n    {\\n        computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\\n    }\\n#endif\\n    for(int i = 0; i < POINT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = pointLightPosition[i];\\n        vec3 lightColor = pointLightColor[i];\\n        float range = pointLightRange[i];\\n        vec3 lightDirection = lightPosition - v_WorldPosition;\\n        float dist = length(lightDirection);\\n        float attenuation = lightAttenuation(dist, range);\\n        lightDirection /= dist;\\n        float ndl = dot( v_Normal, lightDirection );\\n        float shadowContrib = 1.0;\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsPoint[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * attenuation * shadowContrib;\\n    }\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\\n    }\\n#endif\\n    for(int i = 0; i < DIRECTIONAL_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightDirection = -directionalLightDirection[i];\\n        vec3 lightColor = directionalLightColor[i];\\n        float ndl = dot(v_Normal, normalize(lightDirection));\\n        float shadowContrib = 1.0;\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsDir[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * shadowContrib;\\n    }\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsSpot[SPOT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\\n    }\\n#endif\\n    for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = -spotLightPosition[i];\\n        vec3 spotLightDirection = -normalize( spotLightDirection[i] );\\n        vec3 lightColor = spotLightColor[i];\\n        float range = spotLightRange[i];\\n        float a = spotLightUmbraAngleCosine[i];\\n        float b = spotLightPenumbraAngleCosine[i];\\n        float falloffFactor = spotLightFalloffFactor[i];\\n        vec3 lightDirection = lightPosition - v_WorldPosition;\\n        float dist = length(lightDirection);\\n        float attenuation = lightAttenuation(dist, range);\\n        lightDirection /= dist;\\n        float c = dot(spotLightDirection, lightDirection);\\n        float falloff;\\n        falloff = clamp((c - a) /( b - a), 0.0, 1.0);\\n        falloff = pow(falloff, falloffFactor);\\n        float ndl = dot(v_Normal, lightDirection);\\n        ndl = clamp(ndl, 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsSpot[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * ndl * attenuation * (1.0-falloff) * shadowContrib;\\n    }\\n#endif\\n    gl_FragColor.rgb *= diffuseColor;\\n    gl_FragColor.rgb += emission;\\n    if(lineWidth > 0.)\\n    {\\n        gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef ALPHA_TEST\\n    if (gl_FragColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    gl_FragColor = linearTosRGB(gl_FragColor);\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n}\\n@end\";\n","export default \"@export clay.wireframe.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 world : WORLD;\\nattribute vec3 position : POSITION;\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec3 v_Barycentric;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\\n    v_Barycentric = barycentric;\\n}\\n@end\\n@export clay.wireframe.fragment\\nuniform vec3 color : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\nuniform float lineWidth : 1.0;\\nvarying vec3 v_Barycentric;\\n@import clay.util.edge_factor\\nvoid main()\\n{\\n    gl_FragColor.rgb = color;\\n    gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\\n}\\n@end\";\n","export default \"@export clay.skybox.vertex\\nuniform mat4 world : WORLD;\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nvarying vec3 v_WorldPosition;\\nvoid main()\\n{\\n    v_WorldPosition = (world * vec4(position, 1.0)).xyz;\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n}\\n@end\\n@export clay.skybox.fragment\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform samplerCube environmentMap;\\nuniform float lod: 0.0;\\nvarying vec3 v_WorldPosition;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 viewDirection = normalize(v_WorldPosition - eyePos);\\n    vec3 tex = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod)).rgb;\\n#ifdef SRGB_DECODE\\n    tex.rgb = pow(tex.rgb, vec3(2.2));\\n#endif\\n    gl_FragColor = encodeHDR(vec4(tex, 1.0));\\n}\\n@end\";\n","export default \"@export clay.compositor.coloradjust\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float brightness : 0.0;\\nuniform float contrast : 1.0;\\nuniform float exposure : 0.0;\\nuniform float gamma : 1.0;\\nuniform float saturation : 1.0;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\\n    color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\\n    color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\\n    color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\\n    float luminance = dot( color, w );\\n    color = mix(vec3(luminance), color, saturation);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.brightness\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float brightness : 0.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = tex.rgb + vec3(brightness);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.contrast\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float contrast : 1.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.exposure\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float exposure : 0.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = tex.rgb * pow(2.0, exposure);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.gamma\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float gamma : 1.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = pow(tex.rgb, vec3(gamma));\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.saturation\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float saturation : 1.0;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = tex.rgb;\\n    float luminance = dot(color, w);\\n    color = mix(vec3(luminance), color, saturation);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\";\n","export default \"@export clay.compositor.kernel.gaussian_9\\nfloat gaussianKernel[9];\\ngaussianKernel[0] = 0.07;\\ngaussianKernel[1] = 0.09;\\ngaussianKernel[2] = 0.12;\\ngaussianKernel[3] = 0.14;\\ngaussianKernel[4] = 0.16;\\ngaussianKernel[5] = 0.14;\\ngaussianKernel[6] = 0.12;\\ngaussianKernel[7] = 0.09;\\ngaussianKernel[8] = 0.07;\\n@end\\n@export clay.compositor.kernel.gaussian_13\\nfloat gaussianKernel[13];\\ngaussianKernel[0] = 0.02;\\ngaussianKernel[1] = 0.03;\\ngaussianKernel[2] = 0.06;\\ngaussianKernel[3] = 0.08;\\ngaussianKernel[4] = 0.11;\\ngaussianKernel[5] = 0.13;\\ngaussianKernel[6] = 0.14;\\ngaussianKernel[7] = 0.13;\\ngaussianKernel[8] = 0.11;\\ngaussianKernel[9] = 0.08;\\ngaussianKernel[10] = 0.06;\\ngaussianKernel[11] = 0.03;\\ngaussianKernel[12] = 0.02;\\n@end\\n@export clay.compositor.gaussian_blur\\n#define SHADER_NAME gaussian_blur\\nuniform sampler2D texture;varying vec2 v_Texcoord;\\nuniform float blurSize : 2.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\nuniform float blurDir : 0.0;\\n@import clay.util.rgbm\\n@import clay.util.clamp_sample\\nvoid main (void)\\n{\\n    @import clay.compositor.kernel.gaussian_9\\n    vec2 off = blurSize / textureSize;\\n    off *= vec2(1.0 - blurDir, blurDir);\\n    vec4 sum = vec4(0.0);\\n    float weightAll = 0.0;\\n    for (int i = 0; i < 9; i++) {\\n        float w = gaussianKernel[i];\\n        vec4 texel = decodeHDR(clampSample(texture, v_Texcoord + float(i - 4) * off));\\n        sum += texel * w;\\n        weightAll += w;\\n    }\\n    gl_FragColor = encodeHDR(sum / max(weightAll, 0.01));\\n}\\n@end\\n\";\n","export default \"@export clay.compositor.hdr.log_lum\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\\n    float luminance = dot(tex.rgb, w);\\n    luminance = log(luminance + 0.001);\\n    gl_FragColor = encodeHDR(vec4(vec3(luminance), 1.0));\\n}\\n@end\\n@export clay.compositor.hdr.lum_adaption\\nvarying vec2 v_Texcoord;\\nuniform sampler2D adaptedLum;\\nuniform sampler2D currentLum;\\nuniform float frameTime : 0.02;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    float fAdaptedLum = decodeHDR(texture2D(adaptedLum, vec2(0.5, 0.5))).r;\\n    float fCurrentLum = exp(encodeHDR(texture2D(currentLum, vec2(0.5, 0.5))).r);\\n    fAdaptedLum += (fCurrentLum - fAdaptedLum) * (1.0 - pow(0.98, 30.0 * frameTime));\\n    gl_FragColor = encodeHDR(vec4(vec3(fAdaptedLum), 1.0));\\n}\\n@end\\n@export clay.compositor.lum\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord );\\n    float luminance = dot(tex.rgb, w);\\n    gl_FragColor = vec4(vec3(luminance), 1.0);\\n}\\n@end\";\n","export default \"\\n@export clay.compositor.lut\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform sampler2D lookup;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    float blueColor = tex.b * 63.0;\\n    vec2 quad1;\\n    quad1.y = floor(floor(blueColor) / 8.0);\\n    quad1.x = floor(blueColor) - (quad1.y * 8.0);\\n    vec2 quad2;\\n    quad2.y = floor(ceil(blueColor) / 8.0);\\n    quad2.x = ceil(blueColor) - (quad2.y * 8.0);\\n    vec2 texPos1;\\n    texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\\n    texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\\n    vec2 texPos2;\\n    texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\\n    texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\\n    vec4 newColor1 = texture2D(lookup, texPos1);\\n    vec4 newColor2 = texture2D(lookup, texPos2);\\n    vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\\n    gl_FragColor = vec4(newColor.rgb, tex.w);\\n}\\n@end\";\n","export default \"@export clay.compositor.vignette\\n#define OUTPUT_ALPHA\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float darkness: 1;\\nuniform float offset: 1;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\\n    gl_FragColor.rgb = texel.rgb;\\n    vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(offset);\\n    gl_FragColor = encodeHDR(vec4(mix(texel.rgb, vec3(1.0 - darkness), dot(uv, uv)), texel.a));\\n}\\n@end\";\n","export default \"@export clay.compositor.output\\n#define OUTPUT_ALPHA\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\\n    gl_FragColor.rgb = tex.rgb;\\n#ifdef OUTPUT_ALPHA\\n    gl_FragColor.a = tex.a;\\n#else\\n    gl_FragColor.a = 1.0;\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#ifdef PREMULTIPLY_ALPHA\\n    gl_FragColor.rgb *= gl_FragColor.a;\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.bright\\nuniform sampler2D texture;\\nuniform float threshold : 1;\\nuniform float scale : 1.0;\\nuniform vec2 textureSize: [512, 512];\\nvarying vec2 v_Texcoord;\\nconst vec3 lumWeight = vec3(0.2125, 0.7154, 0.0721);\\n@import clay.util.rgbm\\nvec4 median(vec4 a, vec4 b, vec4 c)\\n{\\n    return a + b + c - min(min(a, b), c) - max(max(a, b), c);\\n}\\nvoid main()\\n{\\n    vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\\n#ifdef ANTI_FLICKER\\n    vec3 d = 1.0 / textureSize.xyx * vec3(1.0, 1.0, 0.0);\\n    vec4 s1 = decodeHDR(texture2D(texture, v_Texcoord - d.xz));\\n    vec4 s2 = decodeHDR(texture2D(texture, v_Texcoord + d.xz));\\n    vec4 s3 = decodeHDR(texture2D(texture, v_Texcoord - d.zy));\\n    vec4 s4 = decodeHDR(texture2D(texture, v_Texcoord + d.zy));\\n    texel = median(median(texel, s1, s2), s3, s4);\\n#endif\\n    float lum = dot(texel.rgb , lumWeight);\\n    vec4 color;\\n    if (lum > threshold && texel.a > 0.0)\\n    {\\n        color = vec4(texel.rgb * scale, texel.a * scale);\\n    }\\n    else\\n    {\\n        color = vec4(0.0);\\n    }\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\\n\";\n","export default \"@export clay.compositor.downsample\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nfloat brightness(vec3 c)\\n{\\n    return max(max(c.r, c.g), c.b);\\n}\\n@import clay.util.clamp_sample\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n#ifdef ANTI_FLICKER\\n    vec3 s1 = decodeHDR(clampSample(texture, v_Texcoord + d.xy)).rgb;\\n    vec3 s2 = decodeHDR(clampSample(texture, v_Texcoord + d.zy)).rgb;\\n    vec3 s3 = decodeHDR(clampSample(texture, v_Texcoord + d.xw)).rgb;\\n    vec3 s4 = decodeHDR(clampSample(texture, v_Texcoord + d.zw)).rgb;\\n    float s1w = 1.0 / (brightness(s1) + 1.0);\\n    float s2w = 1.0 / (brightness(s2) + 1.0);\\n    float s3w = 1.0 / (brightness(s3) + 1.0);\\n    float s4w = 1.0 / (brightness(s4) + 1.0);\\n    float oneDivideSum = 1.0 / (s1w + s2w + s3w + s4w);\\n    vec4 color = vec4(\\n        (s1 * s1w + s2 * s2w + s3 * s3w + s4 * s4w) * oneDivideSum,\\n        1.0\\n    );\\n#else\\n    vec4 color = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\\n    color *= 0.25;\\n#endif\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\";\n","export default \"\\n@export clay.compositor.upsample\\n#define HIGH_QUALITY\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.clamp_sample\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    vec4 s;\\n    s  = decodeHDR(clampSample(texture, v_Texcoord - d.xy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord - d.wy)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord - d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zw)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord       )) * 4.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xw)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.wy)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    gl_FragColor = encodeHDR(s / 16.0);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    vec4 s;\\n    s  = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\\n    gl_FragColor = encodeHDR(s / 4.0);\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.hdr.composite\\nuniform sampler2D texture;\\n#ifdef BLOOM_ENABLED\\nuniform sampler2D bloom;\\n#endif\\n#ifdef LENSFLARE_ENABLED\\nuniform sampler2D lensflare;\\nuniform sampler2D lensdirt;\\n#endif\\n#ifdef LUM_ENABLED\\nuniform sampler2D lum;\\n#endif\\n#ifdef LUT_ENABLED\\nuniform sampler2D lut;\\n#endif\\n#ifdef COLOR_CORRECTION\\nuniform float brightness : 0.0;\\nuniform float contrast : 1.0;\\nuniform float saturation : 1.0;\\n#endif\\n#ifdef VIGNETTE\\nuniform float vignetteDarkness: 1.0;\\nuniform float vignetteOffset: 1.0;\\n#endif\\nuniform float exposure : 1.0;\\nuniform float bloomIntensity : 0.25;\\nuniform float lensflareIntensity : 1;\\nvarying vec2 v_Texcoord;\\n@import clay.util.srgb\\nvec3 ACESToneMapping(vec3 color)\\n{\\n    const float A = 2.51;\\n    const float B = 0.03;\\n    const float C = 2.43;\\n    const float D = 0.59;\\n    const float E = 0.14;\\n    return (color * (A * color + B)) / (color * (C * color + D) + E);\\n}\\nfloat eyeAdaption(float fLum)\\n{\\n    return mix(0.2, fLum, 0.5);\\n}\\n#ifdef LUT_ENABLED\\nvec3 lutTransform(vec3 color) {\\n    float blueColor = color.b * 63.0;\\n    vec2 quad1;\\n    quad1.y = floor(floor(blueColor) / 8.0);\\n    quad1.x = floor(blueColor) - (quad1.y * 8.0);\\n    vec2 quad2;\\n    quad2.y = floor(ceil(blueColor) / 8.0);\\n    quad2.x = ceil(blueColor) - (quad2.y * 8.0);\\n    vec2 texPos1;\\n    texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\\n    texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\\n    vec2 texPos2;\\n    texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\\n    texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\\n    vec4 newColor1 = texture2D(lut, texPos1);\\n    vec4 newColor2 = texture2D(lut, texPos2);\\n    vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\\n    return newColor.rgb;\\n}\\n#endif\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 texel = vec4(0.0);\\n    vec4 originalTexel = vec4(0.0);\\n#ifdef TEXTURE_ENABLED\\n    texel = decodeHDR(texture2D(texture, v_Texcoord));\\n    originalTexel = texel;\\n#endif\\n#ifdef BLOOM_ENABLED\\n    vec4 bloomTexel = decodeHDR(texture2D(bloom, v_Texcoord));\\n    texel.rgb += bloomTexel.rgb * bloomIntensity;\\n    texel.a += bloomTexel.a * bloomIntensity;\\n#endif\\n#ifdef LENSFLARE_ENABLED\\n    texel += decodeHDR(texture2D(lensflare, v_Texcoord)) * texture2D(lensdirt, v_Texcoord) * lensflareIntensity;\\n#endif\\n    texel.a = min(texel.a, 1.0);\\n#ifdef LUM_ENABLED\\n    float fLum = texture2D(lum, vec2(0.5, 0.5)).r;\\n    float adaptedLumDest = 3.0 / (max(0.1, 1.0 + 10.0*eyeAdaption(fLum)));\\n    float exposureBias = adaptedLumDest * exposure;\\n#else\\n    float exposureBias = exposure;\\n#endif\\n    texel.rgb *= exposureBias;\\n    texel.rgb = ACESToneMapping(texel.rgb);\\n    texel = linearTosRGB(texel);\\n#ifdef LUT_ENABLED\\n    texel.rgb = lutTransform(clamp(texel.rgb,vec3(0.0),vec3(1.0)));\\n#endif\\n#ifdef COLOR_CORRECTION\\n    texel.rgb = clamp(texel.rgb + vec3(brightness), 0.0, 1.0);\\n    texel.rgb = clamp((texel.rgb - vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\\n    float lum = dot(texel.rgb, vec3(0.2125, 0.7154, 0.0721));\\n    texel.rgb = mix(vec3(lum), texel.rgb, saturation);\\n#endif\\n#ifdef VIGNETTE\\n    vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(vignetteOffset);\\n    texel.rgb = mix(texel.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\\n#endif\\n    gl_FragColor = encodeHDR(texel);\\n#ifdef DEBUG\\n    #if DEBUG == 1\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(texture, v_Texcoord)));\\n    #elif DEBUG == 2\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(bloom, v_Texcoord)) * bloomIntensity);\\n    #elif DEBUG == 3\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(lensflare, v_Texcoord) * lensflareIntensity));\\n    #endif\\n#endif\\n    if (originalTexel.a <= 0.01 && gl_FragColor.a > 1e-5) {\\n        gl_FragColor.a = dot(gl_FragColor.rgb, vec3(0.2125, 0.7154, 0.0721));\\n    }\\n#ifdef PREMULTIPLY_ALPHA\\n    gl_FragColor.rgb *= gl_FragColor.a;\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.dof.coc\\nuniform sampler2D depth;\\nuniform float zNear: 0.1;\\nuniform float zFar: 2000;\\nuniform float focalDist: 3;\\nuniform float focalRange: 1;\\nuniform float focalLength: 30;\\nuniform float fstop: 2.8;\\nvarying vec2 v_Texcoord;\\n@import clay.util.encode_float\\nvoid main()\\n{\\n    float z = texture2D(depth, v_Texcoord).r * 2.0 - 1.0;\\n    float dist = 2.0 * zNear * zFar / (zFar + zNear - z * (zFar - zNear));\\n    float aperture = focalLength / fstop;\\n    float coc;\\n    float uppper = focalDist + focalRange;\\n    float lower = focalDist - focalRange;\\n    if (dist <= uppper && dist >= lower) {\\n        coc = 0.5;\\n    }\\n    else {\\n        float focalAdjusted = dist > uppper ? uppper : lower;\\n        coc = abs(aperture * (focalLength * (dist - focalAdjusted)) / (dist * (focalAdjusted - focalLength)));\\n        coc = clamp(coc, 0.0, 0.4) / 0.4000001;\\n        if (dist < lower) {\\n            coc = -coc;\\n        }\\n        coc = coc * 0.5 + 0.5;\\n    }\\n    gl_FragColor = encodeFloat(coc);\\n}\\n@end\\n@export clay.compositor.dof.premultiply\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nvoid main() {\\n    float fCoc = max(abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0), 0.1);\\n    gl_FragColor = encodeHDR(\\n        vec4(decodeHDR(texture2D(texture, v_Texcoord)).rgb * fCoc, 1.0)\\n    );\\n}\\n@end\\n@export clay.compositor.dof.min_coc\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\\n    gl_FragColor = encodeFloat(fCoc);\\n}\\n@end\\n@export clay.compositor.dof.max_coc\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\\n    gl_FragColor = encodeFloat(fCoc);\\n}\\n@end\\n@export clay.compositor.dof.coc_upsample\\n#define HIGH_QUALITY\\nuniform sampler2D coc;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.float\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    float s;\\n    s  = decodeFloat(texture2D(coc, v_Texcoord - d.xy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord - d.wy)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord - d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zw)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord       )) * 4.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xw)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.wy)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    gl_FragColor = encodeFloat(s / 16.0);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    float s;\\n    s  = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xw));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zw));\\n    gl_FragColor = encodeFloat(s / 4.0);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.upsample\\n#define HIGH_QUALITY\\nuniform sampler2D coc;\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nfloat tap(vec2 uv, inout vec4 color, float baseWeight) {\\n    float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * baseWeight;\\n    color += decodeHDR(texture2D(texture, uv)) * weight;\\n    return weight;\\n}\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    vec4 color = vec4(0.0);\\n    float baseWeight = 1.0 / 16.0;\\n    float w  = tap(v_Texcoord - d.xy, color, baseWeight);\\n    w += tap(v_Texcoord - d.wy, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord - d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.zw, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord       , color, baseWeight * 4.0);\\n    w += tap(v_Texcoord + d.xw, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord + d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.wy, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord + d.xy, color, baseWeight);\\n    gl_FragColor = encodeHDR(color / w);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    vec4 color = vec4(0.0);\\n    float baseWeight = 1.0 / 4.0;\\n    float w  = tap(v_Texcoord + d.xy, color, baseWeight);\\n    w += tap(v_Texcoord + d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.xw, color, baseWeight);\\n    w += tap(v_Texcoord + d.zw, color, baseWeight);\\n    gl_FragColor = encodeHDR(color / w);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.downsample\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nuniform vec2 textureSize : [512, 512];\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nfloat tap(vec2 uv, inout vec4 color) {\\n    float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * 0.25;\\n    color += decodeHDR(texture2D(texture, uv)) * weight;\\n    return weight;\\n}\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    vec4 color = vec4(0.0);\\n    float weight = tap(v_Texcoord + d.xy, color);\\n    weight += tap(v_Texcoord + d.zy, color);\\n    weight += tap(v_Texcoord + d.xw, color);\\n    weight += tap(v_Texcoord + d.zw, color);\\n    color /= weight;\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_frag\\n@import clay.util.float\\nvec4 doBlur(sampler2D targetTexture, vec2 offset) {\\n#ifdef BLUR_COC\\n    float cocSum = 0.0;\\n#else\\n    vec4 color = vec4(0.0);\\n#endif\\n    float weightSum = 0.0;\\n    float kernelWeight = 1.0 / float(KERNEL_SIZE);\\n    for (int i = 0; i < KERNEL_SIZE; i++) {\\n        vec2 coord = v_Texcoord + offset * float(i);\\n        float w = kernelWeight;\\n#ifdef BLUR_COC\\n        float fCoc = decodeFloat(texture2D(targetTexture, coord)) * 2.0 - 1.0;\\n        cocSum += clamp(fCoc, -1.0, 0.0) * w;\\n#else\\n        float fCoc = decodeFloat(texture2D(coc, coord)) * 2.0 - 1.0;\\n        vec4 texel = texture2D(targetTexture, coord);\\n    #if !defined(BLUR_NEARFIELD)\\n        w *= abs(fCoc);\\n    #endif\\n        color += decodeHDR(texel) * w;\\n#endif\\n        weightSum += w;\\n    }\\n#ifdef BLUR_COC\\n    return encodeFloat(clamp(cocSum / weightSum, -1.0, 0.0) * 0.5 + 0.5);\\n#else\\n    return color / weightSum;\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_1\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    gl_FragColor = doBlur(texture, vec2(0.0, offset.y));\\n#if !defined(BLUR_COC)\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_2\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    offset.y /= 2.0;\\n    gl_FragColor = doBlur(texture, -offset);\\n#if !defined(BLUR_COC)\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_3\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture1;\\nuniform sampler2D texture2;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    offset.y /= 2.0;\\n    vec2 vDownRight = vec2(offset.x, -offset.y);\\n    vec4 texel1 = doBlur(texture1, -offset);\\n    vec4 texel2 = doBlur(texture1, vDownRight);\\n    vec4 texel3 = doBlur(texture2, vDownRight);\\n#ifdef BLUR_COC\\n    float coc1 = decodeFloat(texel1) * 2.0 - 1.0;\\n    float coc2 = decodeFloat(texel2) * 2.0 - 1.0;\\n    float coc3 = decodeFloat(texel3) * 2.0 - 1.0;\\n    gl_FragColor = encodeFloat(\\n        ((coc1 + coc2 + coc3) / 3.0) * 0.5 + 0.5\\n    );\\n#else\\n    vec4 color = (texel1 + texel2 + texel3) / 3.0;\\n    gl_FragColor = encodeHDR(color);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.composite\\n#define DEBUG 0\\nuniform sampler2D original;\\nuniform sampler2D blurred;\\nuniform sampler2D nearfield;\\nuniform sampler2D coc;\\nuniform sampler2D nearcoc;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 blurredColor = decodeHDR(texture2D(blurred, v_Texcoord));\\n    vec4 originalColor = decodeHDR(texture2D(original, v_Texcoord));\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord));\\n    fCoc = abs(fCoc * 2.0 - 1.0);\\n    float weight = smoothstep(0.0, 1.0, fCoc);\\n#ifdef NEARFIELD_ENABLED\\n    vec4 nearfieldColor = decodeHDR(texture2D(nearfield, v_Texcoord));\\n    float fNearCoc = decodeFloat(texture2D(nearcoc, v_Texcoord));\\n    fNearCoc = abs(fNearCoc * 2.0 - 1.0);\\n    gl_FragColor = encodeHDR(\\n        mix(\\n            nearfieldColor, mix(originalColor, blurredColor, weight),\\n            pow(1.0 - fNearCoc, 4.0)\\n        )\\n    );\\n#else\\n    gl_FragColor = encodeHDR(mix(originalColor, blurredColor, weight));\\n#endif\\n#if DEBUG == 1\\n    gl_FragColor = vec4(vec3(fCoc), 1.0);\\n#elif DEBUG == 2\\n    gl_FragColor = vec4(vec3(fNearCoc), 1.0);\\n#elif DEBUG == 3\\n    gl_FragColor = encodeHDR(blurredColor);\\n#elif DEBUG == 4\\n    gl_FragColor = encodeHDR(nearfieldColor);\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.lensflare\\n#define SAMPLE_NUMBER 8\\nuniform sampler2D texture;\\nuniform sampler2D lenscolor;\\nuniform vec2 textureSize : [512, 512];\\nuniform float dispersal : 0.3;\\nuniform float haloWidth : 0.4;\\nuniform float distortion : 1.0;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nvec4 textureDistorted(\\n    in vec2 texcoord,\\n    in vec2 direction,\\n    in vec3 distortion\\n) {\\n    return vec4(\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.r)).r,\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.g)).g,\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.b)).b,\\n        1.0\\n    );\\n}\\nvoid main()\\n{\\n    vec2 texcoord = -v_Texcoord + vec2(1.0);    vec2 textureOffset = 1.0 / textureSize;\\n    vec2 ghostVec = (vec2(0.5) - texcoord) * dispersal;\\n    vec2 haloVec = normalize(ghostVec) * haloWidth;\\n    vec3 distortion = vec3(-textureOffset.x * distortion, 0.0, textureOffset.x * distortion);\\n    vec4 result = vec4(0.0);\\n    for (int i = 0; i < SAMPLE_NUMBER; i++)\\n    {\\n        vec2 offset = fract(texcoord + ghostVec * float(i));\\n        float weight = length(vec2(0.5) - offset) / length(vec2(0.5));\\n        weight = pow(1.0 - weight, 10.0);\\n        result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\\n    }\\n    result *= texture2D(lenscolor, vec2(length(vec2(0.5) - texcoord)) / length(vec2(0.5)));\\n    float weight = length(vec2(0.5) - fract(texcoord + haloVec)) / length(vec2(0.5));\\n    weight = pow(1.0 - weight, 10.0);\\n    vec2 offset = fract(texcoord + haloVec);\\n    result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\\n    gl_FragColor = result;\\n}\\n@end\";\n","export default \"@export clay.compositor.blend\\n#define SHADER_NAME blend\\n#ifdef TEXTURE1_ENABLED\\nuniform sampler2D texture1;\\nuniform float weight1 : 1.0;\\n#endif\\n#ifdef TEXTURE2_ENABLED\\nuniform sampler2D texture2;\\nuniform float weight2 : 1.0;\\n#endif\\n#ifdef TEXTURE3_ENABLED\\nuniform sampler2D texture3;\\nuniform float weight3 : 1.0;\\n#endif\\n#ifdef TEXTURE4_ENABLED\\nuniform sampler2D texture4;\\nuniform float weight4 : 1.0;\\n#endif\\n#ifdef TEXTURE5_ENABLED\\nuniform sampler2D texture5;\\nuniform float weight5 : 1.0;\\n#endif\\n#ifdef TEXTURE6_ENABLED\\nuniform sampler2D texture6;\\nuniform float weight6 : 1.0;\\n#endif\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = vec4(0.0);\\n#ifdef TEXTURE1_ENABLED\\n    tex += decodeHDR(texture2D(texture1, v_Texcoord)) * weight1;\\n#endif\\n#ifdef TEXTURE2_ENABLED\\n    tex += decodeHDR(texture2D(texture2, v_Texcoord)) * weight2;\\n#endif\\n#ifdef TEXTURE3_ENABLED\\n    tex += decodeHDR(texture2D(texture3, v_Texcoord)) * weight3;\\n#endif\\n#ifdef TEXTURE4_ENABLED\\n    tex += decodeHDR(texture2D(texture4, v_Texcoord)) * weight4;\\n#endif\\n#ifdef TEXTURE5_ENABLED\\n    tex += decodeHDR(texture2D(texture5, v_Texcoord)) * weight5;\\n#endif\\n#ifdef TEXTURE6_ENABLED\\n    tex += decodeHDR(texture2D(texture6, v_Texcoord)) * weight6;\\n#endif\\n    gl_FragColor = encodeHDR(tex);\\n}\\n@end\";\n","export default \"@export clay.compositor.fxaa\\nuniform sampler2D texture;\\nuniform vec4 viewport : VIEWPORT;\\nvarying vec2 v_Texcoord;\\n#define FXAA_REDUCE_MIN   (1.0/128.0)\\n#define FXAA_REDUCE_MUL   (1.0/8.0)\\n#define FXAA_SPAN_MAX     8.0\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec2 resolution = 1.0 / viewport.zw;\\n    vec3 rgbNW =  decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, -1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbNE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, -1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbSW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, 1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbSE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, 1.0 ) ) * resolution ) ).xyz;\\n    vec4 rgbaM  = decodeHDR( texture2D( texture,  gl_FragCoord.xy  * resolution ) );\\n    vec3 rgbM  = rgbaM.xyz;\\n    float opacity  = rgbaM.w;\\n    vec3 luma = vec3( 0.299, 0.587, 0.114 );\\n    float lumaNW = dot( rgbNW, luma );\\n    float lumaNE = dot( rgbNE, luma );\\n    float lumaSW = dot( rgbSW, luma );\\n    float lumaSE = dot( rgbSE, luma );\\n    float lumaM  = dot( rgbM,  luma );\\n    float lumaMin = min( lumaM, min( min( lumaNW, lumaNE ), min( lumaSW, lumaSE ) ) );\\n    float lumaMax = max( lumaM, max( max( lumaNW, lumaNE) , max( lumaSW, lumaSE ) ) );\\n    vec2 dir;\\n    dir.x = -((lumaNW + lumaNE) - (lumaSW + lumaSE));\\n    dir.y =  ((lumaNW + lumaSW) - (lumaNE + lumaSE));\\n    float dirReduce = max( ( lumaNW + lumaNE + lumaSW + lumaSE ) * ( 0.25 * FXAA_REDUCE_MUL ), FXAA_REDUCE_MIN );\\n    float rcpDirMin = 1.0 / ( min( abs( dir.x ), abs( dir.y ) ) + dirReduce );\\n    dir = min( vec2( FXAA_SPAN_MAX,  FXAA_SPAN_MAX),\\n          max( vec2(-FXAA_SPAN_MAX, -FXAA_SPAN_MAX),\\n                dir * rcpDirMin)) * resolution;\\n    vec3 rgbA = decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * ( 1.0 / 3.0 - 0.5 ) ) ).xyz;\\n    rgbA += decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * ( 2.0 / 3.0 - 0.5 ) ) ).xyz;\\n    rgbA *= 0.5;\\n    vec3 rgbB = decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * -0.5 ) ).xyz;\\n    rgbB += decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * 0.5 ) ).xyz;\\n    rgbB *= 0.25;\\n    rgbB += rgbA * 0.5;\\n    float lumaB = dot( rgbB, luma );\\n    if ( ( lumaB < lumaMin ) || ( lumaB > lumaMax ) )\\n    {\\n        gl_FragColor = vec4( rgbA, opacity );\\n    }\\n    else {\\n        gl_FragColor = vec4( rgbB, opacity );\\n    }\\n}\\n@end\";\n","export default \"@export clay.compositor.fxaa3\\nuniform sampler2D texture;\\nuniform vec4 viewport : VIEWPORT;\\nuniform float subpixel: 0.75;\\nuniform float edgeThreshold: 0.125;\\nuniform float edgeThresholdMin: 0.0625;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nfloat FxaaLuma(vec4 rgba) { return rgba.y; }\\nvec4 FxaaPixelShader(\\n    vec2 pos\\n    ,sampler2D tex\\n    ,vec2 fxaaQualityRcpFrame\\n    ,float fxaaQualitySubpix\\n    ,float fxaaQualityEdgeThreshold\\n    ,float fxaaQualityEdgeThresholdMin\\n) {\\n    vec2 posM;\\n    posM.x = pos.x;\\n    posM.y = pos.y;\\n    vec4 rgbyM = decodeHDR(texture2D(texture, posM, 0.0));\\n    float lumaS = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaN = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float maxSM = max(lumaS, rgbyM.y);\\n    float minSM = min(lumaS, rgbyM.y);\\n    float maxESM = max(lumaE, maxSM);\\n    float minESM = min(lumaE, minSM);\\n    float maxWN = max(lumaN, lumaW);\\n    float minWN = min(lumaN, lumaW);\\n    float rangeMax = max(maxWN, maxESM);\\n    float rangeMin = min(minWN, minESM);\\n    float rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;\\n    float range = rangeMax - rangeMin;\\n    float rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);\\n    bool earlyExit = range < rangeMaxClamped;\\n    if(earlyExit) return rgbyM;\\n    float lumaNW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaSE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaNE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaSW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaNS = lumaN + lumaS;\\n    float lumaWE = lumaW + lumaE;\\n    float subpixRcpRange = 1.0/range;\\n    float subpixNSWE = lumaNS + lumaWE;\\n    float edgeHorz1 = (-2.0 * rgbyM.y) + lumaNS;\\n    float edgeVert1 = (-2.0 * rgbyM.y) + lumaWE;\\n    float lumaNESE = lumaNE + lumaSE;\\n    float lumaNWNE = lumaNW + lumaNE;\\n    float edgeHorz2 = (-2.0 * lumaE) + lumaNESE;\\n    float edgeVert2 = (-2.0 * lumaN) + lumaNWNE;\\n    float lumaNWSW = lumaNW + lumaSW;\\n    float lumaSWSE = lumaSW + lumaSE;\\n    float edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);\\n    float edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);\\n    float edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;\\n    float edgeVert3 = (-2.0 * lumaS) + lumaSWSE;\\n    float edgeHorz = abs(edgeHorz3) + edgeHorz4;\\n    float edgeVert = abs(edgeVert3) + edgeVert4;\\n    float subpixNWSWNESE = lumaNWSW + lumaNESE;\\n    float lengthSign = fxaaQualityRcpFrame.x;\\n    bool horzSpan = edgeHorz >= edgeVert;\\n    float subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;\\n    if(!horzSpan) lumaN = lumaW;\\n    if(!horzSpan) lumaS = lumaE;\\n    if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;\\n    float subpixB = (subpixA * (1.0/12.0)) - rgbyM.y;\\n    float gradientN = lumaN - rgbyM.y;\\n    float gradientS = lumaS - rgbyM.y;\\n    float lumaNN = lumaN + rgbyM.y;\\n    float lumaSS = lumaS + rgbyM.y;\\n    bool pairN = abs(gradientN) >= abs(gradientS);\\n    float gradient = max(abs(gradientN), abs(gradientS));\\n    if(pairN) lengthSign = -lengthSign;\\n    float subpixC = clamp(abs(subpixB) * subpixRcpRange, 0.0, 1.0);\\n    vec2 posB;\\n    posB.x = posM.x;\\n    posB.y = posM.y;\\n    vec2 offNP;\\n    offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;\\n    offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;\\n    if(!horzSpan) posB.x += lengthSign * 0.5;\\n    if( horzSpan) posB.y += lengthSign * 0.5;\\n    vec2 posN;\\n    posN.x = posB.x - offNP.x * 1.0;\\n    posN.y = posB.y - offNP.y * 1.0;\\n    vec2 posP;\\n    posP.x = posB.x + offNP.x * 1.0;\\n    posP.y = posB.y + offNP.y * 1.0;\\n    float subpixD = ((-2.0)*subpixC) + 3.0;\\n    float lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN, 0.0)));\\n    float subpixE = subpixC * subpixC;\\n    float lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP, 0.0)));\\n    if(!pairN) lumaNN = lumaSS;\\n    float gradientScaled = gradient * 1.0/4.0;\\n    float lumaMM = rgbyM.y - lumaNN * 0.5;\\n    float subpixF = subpixD * subpixE;\\n    bool lumaMLTZero = lumaMM < 0.0;\\n    lumaEndN -= lumaNN * 0.5;\\n    lumaEndP -= lumaNN * 0.5;\\n    bool doneN = abs(lumaEndN) >= gradientScaled;\\n    bool doneP = abs(lumaEndP) >= gradientScaled;\\n    if(!doneN) posN.x -= offNP.x * 1.5;\\n    if(!doneN) posN.y -= offNP.y * 1.5;\\n    bool doneNP = (!doneN) || (!doneP);\\n    if(!doneP) posP.x += offNP.x * 1.5;\\n    if(!doneP) posP.y += offNP.y * 1.5;\\n    if(doneNP) {\\n        if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n        if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n        if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n        if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n        doneN = abs(lumaEndN) >= gradientScaled;\\n        doneP = abs(lumaEndP) >= gradientScaled;\\n        if(!doneN) posN.x -= offNP.x * 2.0;\\n        if(!doneN) posN.y -= offNP.y * 2.0;\\n        doneNP = (!doneN) || (!doneP);\\n        if(!doneP) posP.x += offNP.x * 2.0;\\n        if(!doneP) posP.y += offNP.y * 2.0;\\n        if(doneNP) {\\n            if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n            if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n            if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n            if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n            doneN = abs(lumaEndN) >= gradientScaled;\\n            doneP = abs(lumaEndP) >= gradientScaled;\\n            if(!doneN) posN.x -= offNP.x * 4.0;\\n            if(!doneN) posN.y -= offNP.y * 4.0;\\n            doneNP = (!doneN) || (!doneP);\\n            if(!doneP) posP.x += offNP.x * 4.0;\\n            if(!doneP) posP.y += offNP.y * 4.0;\\n            if(doneNP) {\\n                if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n                if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n                if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n                if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n                doneN = abs(lumaEndN) >= gradientScaled;\\n                doneP = abs(lumaEndP) >= gradientScaled;\\n                if(!doneN) posN.x -= offNP.x * 12.0;\\n                if(!doneN) posN.y -= offNP.y * 12.0;\\n                doneNP = (!doneN) || (!doneP);\\n                if(!doneP) posP.x += offNP.x * 12.0;\\n                if(!doneP) posP.y += offNP.y * 12.0;\\n            }\\n        }\\n    }\\n    float dstN = posM.x - posN.x;\\n    float dstP = posP.x - posM.x;\\n    if(!horzSpan) dstN = posM.y - posN.y;\\n    if(!horzSpan) dstP = posP.y - posM.y;\\n    bool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;\\n    float spanLength = (dstP + dstN);\\n    bool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;\\n    float spanLengthRcp = 1.0/spanLength;\\n    bool directionN = dstN < dstP;\\n    float dst = min(dstN, dstP);\\n    bool goodSpan = directionN ? goodSpanN : goodSpanP;\\n    float subpixG = subpixF * subpixF;\\n    float pixelOffset = (dst * (-spanLengthRcp)) + 0.5;\\n    float subpixH = subpixG * fxaaQualitySubpix;\\n    float pixelOffsetGood = goodSpan ? pixelOffset : 0.0;\\n    float pixelOffsetSubpix = max(pixelOffsetGood, subpixH);\\n    if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;\\n    if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;\\n    return vec4(decodeHDR(texture2D(texture, posM, 0.0)).xyz, rgbyM.y);\\n}\\nvoid main()\\n{\\n    vec4 color = FxaaPixelShader(\\n        v_Texcoord,\\n        texture,\\n        vec2(1.0) / viewport.zw,\\n        subpixel,\\n        edgeThreshold,\\n        edgeThresholdMin\\n    );\\n    gl_FragColor = vec4(color.rgb, 1.0);\\n}\\n@end\";\n","import lightEssl from './source/header/light';\nimport utilEssl from './source/util.glsl.js';\n\nimport basicEssl from './source/basic.glsl.js';\nimport lambertEssl from './source/lambert.glsl.js';\nimport standardEssl from './source/standard.glsl.js';\nimport wireframeEssl from './source/wireframe.glsl.js';\nimport skyboxEssl from './source/skybox.glsl.js';\nimport prezEssl from './source/prez.glsl.js';\n\nimport library from './library';\nimport Shader from '../Shader';\n\n\nShader['import'](lightEssl);\nShader['import'](utilEssl);\n\n// Some build in shaders\nShader['import'](basicEssl);\nShader['import'](lambertEssl);\nShader['import'](standardEssl);\nShader['import'](wireframeEssl);\nShader['import'](skyboxEssl);\nShader['import'](prezEssl);\n\nlibrary.template('clay.basic', Shader.source('clay.basic.vertex'), Shader.source('clay.basic.fragment'));\nlibrary.template('clay.lambert', Shader.source('clay.lambert.vertex'), Shader.source('clay.lambert.fragment'));\nlibrary.template('clay.wireframe', Shader.source('clay.wireframe.vertex'), Shader.source('clay.wireframe.fragment'));\nlibrary.template('clay.skybox', Shader.source('clay.skybox.vertex'), Shader.source('clay.skybox.fragment'));\nlibrary.template('clay.prez', Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'));\nlibrary.template('clay.standard', Shader.source('clay.standard.vertex'), Shader.source('clay.standard.fragment'));\nlibrary.template('clay.standardMR', Shader.source('clay.standardMR.vertex'), Shader.source('clay.standardMR.fragment'));\n\n\nimport coloradjustEssl from './source/compositor/coloradjust.glsl.js';\nimport blurEssl from './source/compositor/blur.glsl.js';\nimport lumEssl from './source/compositor/lum.glsl.js';\nimport lutEssl from './source/compositor/lut.glsl.js';\nimport vigentteEssl from './source/compositor/vignette.glsl.js';\nimport outputEssl from './source/compositor/output.glsl.js';\nimport brightEssl from './source/compositor/bright.glsl.js';\nimport downsampleEssl from './source/compositor/downsample.glsl.js';\nimport upsampleEssl from './source/compositor/upsample.glsl.js';\nimport hdrEssl from './source/compositor/hdr.glsl.js';\nimport dofEssl from './source/compositor/dof.glsl.js';\nimport lensflareEssl from './source/compositor/lensflare.glsl.js';\nimport blendEssl from './source/compositor/blend.glsl.js';\n\nimport fxaaEssl from './source/compositor/fxaa.glsl.js';\nimport fxaa3Essl from './source/compositor/fxaa3.glsl.js';\n\n// Some build in shaders\nShader['import'](coloradjustEssl);\nShader['import'](blurEssl);\nShader['import'](lumEssl);\nShader['import'](lutEssl);\nShader['import'](vigentteEssl);\nShader['import'](outputEssl);\nShader['import'](brightEssl);\nShader['import'](downsampleEssl);\nShader['import'](upsampleEssl);\nShader['import'](hdrEssl);\nShader['import'](dofEssl);\nShader['import'](lensflareEssl);\nShader['import'](blendEssl);\n\nShader['import'](fxaaEssl);\nShader['import'](fxaa3Essl);\n","/**\n * glTF Loader\n * Specification https://github.com/KhronosGroup/glTF/blob/master/specification/README.md\n *\n * TODO Morph targets\n */\nimport Base from '../core/Base';\nimport request from '../core/request';\nimport util from '../core/util';\nimport vendor from '../core/vendor';\n\nimport Scene from '../Scene';\nimport Material from '../Material';\nimport StandardMaterial from '../StandardMaterial';\nimport Mesh from '../Mesh';\nimport Node from '../Node';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport shaderLibrary from '../shader/library';\nimport Skeleton from '../Skeleton';\nimport Joint from '../Joint';\nimport PerspectiveCamera from '../camera/Perspective';\nimport OrthographicCamera from '../camera/Orthographic';\nimport glenum from '../core/glenum';\n\nimport BoundingBox from '../math/BoundingBox';\n\nimport TrackClip from '../animation/TrackClip';\nimport SamplerTrack from '../animation/SamplerTrack';\n\nimport Geometry from '../Geometry';\n\n// Import builtin shader\nimport '../shader/builtin';\nimport Shader from '../Shader';\n\nvar semanticAttributeMap = {\n    'NORMAL': 'normal',\n    'POSITION': 'position',\n    'TEXCOORD_0': 'texcoord0',\n    'TEXCOORD_1': 'texcoord1',\n    'WEIGHTS_0': 'weight',\n    'JOINTS_0': 'joint',\n    'COLOR': 'color'\n};\n\nvar ARRAY_CTOR_MAP = {\n    5120: vendor.Int8Array,\n    5121: vendor.Uint8Array,\n    5122: vendor.Int16Array,\n    5123: vendor.Uint16Array,\n    5125: vendor.Uint32Array,\n    5126: vendor.Float32Array\n};\nvar SIZE_MAP = {\n    SCALAR: 1,\n    VEC2: 2,\n    VEC3: 3,\n    VEC4: 4,\n    MAT2: 4,\n    MAT3: 9,\n    MAT4: 16\n};\n\nfunction getAccessorData(json, lib, accessorIdx, isIndices) {\n    var accessorInfo = json.accessors[accessorIdx];\n\n    var buffer = lib.bufferViews[accessorInfo.bufferView];\n    var byteOffset = accessorInfo.byteOffset || 0;\n    var ArrayCtor = ARRAY_CTOR_MAP[accessorInfo.componentType] || vendor.Float32Array;\n\n    var size = SIZE_MAP[accessorInfo.type];\n    if (size == null && isIndices) {\n        size = 1;\n    }\n    var arr = new ArrayCtor(buffer, byteOffset, size * accessorInfo.count);\n\n    var quantizeExtension = accessorInfo.extensions && accessorInfo.extensions['WEB3D_quantized_attributes'];\n    if (quantizeExtension) {\n        var decodedArr = new vendor.Float32Array(size * accessorInfo.count);\n        var decodeMatrix = quantizeExtension.decodeMatrix;\n        var decodeOffset, decodeScale;\n        var decodeOffset = new Array(size);\n        var decodeScale = new Array(size);\n        for (var k = 0; k < size; k++) {\n            decodeOffset[k] = decodeMatrix[size * (size + 1) + k];\n            decodeScale[k] = decodeMatrix[k * (size + 1) + k];\n        }\n        for (var i = 0; i < accessorInfo.count; i++) {\n            for (var k = 0; k < size; k++) {\n                decodedArr[i * size + k] = arr[i * size + k] * decodeScale[k] + decodeOffset[k];\n            }\n        }\n\n        arr = decodedArr;\n    }\n    return arr;\n}\n\n/**\n * @typedef {Object} clay.loader.GLTF.IResult\n * @property {Object} json\n * @property {clay.Scene} scene\n * @property {clay.Node} rootNode\n * @property {clay.Camera[]} cameras\n * @property {clay.Texture[]} textures\n * @property {clay.Material[]} materials\n * @property {clay.Skeleton[]} skeletons\n * @property {clay.Mesh[]} meshes\n * @property {clay.animation.TrackClip[]} clips\n * @property {clay.Node[]} nodes\n */\n\n/**\n * @constructor clay.loader.GLTF\n * @extends clay.core.Base\n */\nvar GLTFLoader = Base.extend(\n/** @lends clay.loader.GLTF# */\n{\n    /**\n     *\n     * @type {clay.Node}\n     */\n    rootNode: null,\n    /**\n     * Root path for uri parsing.\n     * @type {string}\n     */\n    rootPath: null,\n\n    /**\n     * Root path for texture uri parsing. Defaultly use the rootPath\n     * @type {string}\n     */\n    textureRootPath: null,\n\n    /**\n     * Root path for buffer uri parsing. Defaultly use the rootPath\n     * @type {string}\n     */\n    bufferRootPath: null,\n\n    /**\n     * Shader used when creating the materials.\n     * @type {string|clay.Shader}\n     * @default 'clay.standard'\n     */\n    shader: 'clay.standard',\n\n    /**\n     * If use {@link clay.StandardMaterial}\n     * @type {string}\n     */\n    useStandardMaterial: false,\n\n    /**\n     * If loading the cameras.\n     * @type {boolean}\n     */\n    includeCamera: true,\n\n    /**\n     * If loading the animations.\n     * @type {boolean}\n     */\n    includeAnimation: true,\n    /**\n     * If loading the meshes\n     * @type {boolean}\n     */\n    includeMesh: true,\n    /**\n     * If loading the textures.\n     * @type {boolean}\n     */\n    includeTexture: true,\n\n    /**\n     * @type {string}\n     */\n    crossOrigin: '',\n    /**\n     * @type {boolean}\n     * @see https://github.com/KhronosGroup/glTF/issues/674\n     */\n    textureFlipY: false,\n\n    shaderLibrary: null\n},\nfunction () {\n    if (!this.shaderLibrary) {\n        this.shaderLibrary = shaderLibrary.createLibrary();\n    }\n},\n/** @lends clay.loader.GLTF.prototype */\n{\n    /**\n     * @param {string} url\n     */\n    load: function (url) {\n        var self = this;\n        var isBinary = url.endsWith('.glb');\n\n        if (this.rootPath == null) {\n            this.rootPath = url.slice(0, url.lastIndexOf('/'));\n        }\n\n        request.get({\n            url: url,\n            onprogress: function (percent, loaded, total) {\n                self.trigger('progress', percent, loaded, total);\n            },\n            onerror: function (e) {\n                self.trigger('error', e);\n            },\n            responseType: isBinary ? 'arraybuffer' : 'text',\n            onload: function (data) {\n                if (isBinary) {\n                    self.parseBinary(data);\n                }\n                else {\n                    self.parse(JSON.parse(data));\n                }\n            }\n        });\n    },\n\n    /**\n     * Parse glTF binary\n     * @param {ArrayBuffer} buffer\n     * @return {clay.loader.GLTF.IResult}\n     */\n    parseBinary: function (buffer) {\n        var header = new Uint32Array(buffer, 0, 4);\n        if (header[0] !== 0x46546C67) {\n            this.trigger('error', 'Invalid glTF binary format: Invalid header');\n            return;\n        }\n        if (header[0] < 2) {\n            this.trigger('error', 'Only glTF2.0 is supported.');\n            return;\n        }\n\n        var dataView = new DataView(buffer, 12);\n\n        var json;\n        var buffers = [];\n        // Read chunks\n        for (var i = 0; i < dataView.byteLength;) {\n            var chunkLength = dataView.getUint32(i, true);\n            i += 4;\n            var chunkType = dataView.getUint32(i, true);\n            i += 4;\n\n            // json\n            if (chunkType === 0x4E4F534A) {\n                var arr = new Uint8Array(buffer, i + 12, chunkLength);\n                // TODO, for the browser not support TextDecoder.\n                var decoder = new TextDecoder();\n                var str = decoder.decode(arr);\n                try {\n                    json = JSON.parse(str);\n                }\n                catch (e) {\n                    this.trigger('error', 'JSON Parse error:' + e.toString());\n                    return;\n                }\n            }\n            else if (chunkType === 0x004E4942) {\n                buffers.push(buffer.slice(i + 12, i + 12 + chunkLength));\n            }\n\n            i += chunkLength;\n        }\n        if (!json) {\n            this.trigger('error', 'Invalid glTF binary format: Can\\'t find JSON.');\n            return;\n        }\n\n        return this.parse(json, buffers);\n    },\n\n    /**\n     * @param {Object} json\n     * @param {ArrayBuffer[]} [buffer]\n     * @return {clay.loader.GLTF.IResult}\n     */\n    parse: function (json, buffers) {\n        var self = this;\n\n        var lib = {\n            json: json,\n            buffers: [],\n            bufferViews: [],\n            materials: [],\n            textures: [],\n            meshes: [],\n            joints: [],\n            skeletons: [],\n            cameras: [],\n            nodes: [],\n            clips: []\n        };\n        // Mount on the root node if given\n        var rootNode = this.rootNode || new Scene();\n\n        var loading = 0;\n        function checkLoad() {\n            loading--;\n            if (loading === 0) {\n                afterLoadBuffer();\n            }\n        }\n        // If already load buffers\n        if (buffers) {\n            lib.buffers = buffers.slice();\n            afterLoadBuffer(true);\n        }\n        else {\n            // Load buffers\n            util.each(json.buffers, function (bufferInfo, idx) {\n                loading++;\n                var path = bufferInfo.uri;\n\n                self._loadBuffer(path, function (buffer) {\n                    lib.buffers[idx] = buffer;\n                    checkLoad();\n                }, checkLoad);\n            });\n        }\n\n        function getResult() {\n            return {\n                json: json,\n                scene: self.rootNode ? null : rootNode,\n                rootNode: self.rootNode ? rootNode : null,\n                cameras: lib.cameras,\n                textures: lib.textures,\n                materials: lib.materials,\n                skeletons: lib.skeletons,\n                meshes: lib.meshes,\n                clips: lib.clips,\n                nodes: lib.nodes\n            };\n        }\n\n        function afterLoadBuffer(immediately) {\n            // Buffer not load complete.\n            if (lib.buffers.length !== json.buffers.length) {\n                setTimeout(function () {\n                    self.trigger('error', 'Buffer not load complete.');\n                });\n                return;\n            }\n\n            json.bufferViews.forEach(function (bufferViewInfo, idx) {\n                // PENDING Performance\n                lib.bufferViews[idx] = lib.buffers[bufferViewInfo.buffer]\n                    .slice(bufferViewInfo.byteOffset || 0, (bufferViewInfo.byteOffset || 0) + (bufferViewInfo.byteLength || 0));\n            });\n            lib.buffers = null;\n            if (self.includeMesh) {\n                if (self.includeTexture) {\n                    self._parseTextures(json, lib);\n                }\n                self._parseMaterials(json, lib);\n                self._parseMeshes(json, lib);\n            }\n            self._parseNodes(json, lib);\n\n            // Only support one scene.\n            if (json.scenes) {\n                var sceneInfo = json.scenes[json.scene || 0]; // Default use the first scene.\n                if (sceneInfo) {\n                    for (var i = 0; i < sceneInfo.nodes.length; i++) {\n                        var node = lib.nodes[sceneInfo.nodes[i]];\n                        node.update();\n                        rootNode.add(node);\n                    }\n                }\n            }\n\n            if (self.includeMesh) {\n                self._parseSkins(json, lib);\n            }\n\n            if (self.includeAnimation) {\n                self._parseAnimations(json, lib);\n            }\n            if (immediately) {\n                setTimeout(function () {\n                    self.trigger('success', getResult());\n                });\n            }\n            else {\n                self.trigger('success', getResult());\n            }\n        }\n\n        return getResult();\n    },\n\n    /**\n     * Binary file path resolver. User can override it\n     * @param {string} path\n     */\n    resolveBinaryPath: function (path) {\n        if (path && path.match(/^data:(.*?)base64,/)) {\n            return path;\n        }\n\n        var rootPath = this.bufferRootPath;\n        if (rootPath == null) {\n            rootPath = this.rootPath;\n        }\n        return util.relative2absolute(path, rootPath);\n    },\n\n    /**\n     * Texture file path resolver. User can override it\n     * @param {string} path\n     */\n    resolveTexturePath: function (path) {\n        if (path && path.match(/^data:(.*?)base64,/)) {\n            return path;\n        }\n\n        var rootPath = this.textureRootPath;\n        if (rootPath == null) {\n            rootPath = this.rootPath;\n        }\n        return util.relative2absolute(path, rootPath);\n    },\n\n    _getShader: function () {\n        if (typeof this.shader === 'string') {\n            return this.shaderLibrary.get(this.shader);\n        }\n        else if (this.shader instanceof Shader) {\n            return this.shader;\n        }\n    },\n\n    _loadBuffer: function (path, onsuccess, onerror) {\n        request.get({\n            url: this.resolveBinaryPath(path),\n            responseType: 'arraybuffer',\n            onload: function (buffer) {\n                onsuccess && onsuccess(buffer);\n            },\n            onerror: function (buffer) {\n                onerror && onerror(buffer);\n            }\n        });\n    },\n\n    // https://github.com/KhronosGroup/glTF/issues/100\n    // https://github.com/KhronosGroup/glTF/issues/193\n    _parseSkins: function (json, lib) {\n\n        // Create skeletons and joints\n        var haveInvBindMatrices = false;\n        util.each(json.skins, function (skinInfo, idx) {\n            var skeleton = new Skeleton({\n                name: skinInfo.name\n            });\n            for (var i = 0; i < skinInfo.joints.length; i++) {\n                var nodeIdx = skinInfo.joints[i];\n                var node = lib.nodes[nodeIdx];\n                var joint = new Joint({\n                    name: node.name,\n                    node: node,\n                    index: skeleton.joints.length\n                });\n                skeleton.joints.push(joint);\n            }\n            skeleton.relativeRootNode = lib.nodes[skinInfo.skeleton] || this.rootNode;\n            if (skinInfo.inverseBindMatrices) {\n                haveInvBindMatrices = true;\n                var IBMInfo = json.accessors[skinInfo.inverseBindMatrices];\n                var buffer = lib.bufferViews[IBMInfo.bufferView];\n\n                var offset = IBMInfo.byteOffset || 0;\n                var size = IBMInfo.count * 16;\n\n                var array = new vendor.Float32Array(buffer, offset, size);\n\n                skeleton.setJointMatricesArray(array);\n            }\n            else {\n                skeleton.updateJointMatrices();\n            }\n            lib.skeletons[idx] = skeleton;\n        }, this);\n\n        function enableSkinningForMesh(mesh, skeleton, jointIndices) {\n            mesh.skeleton = skeleton;\n            mesh.joints = jointIndices;\n        }\n\n        function getJointIndex(joint) {\n            return joint.index;\n        }\n\n        util.each(json.nodes, function (nodeInfo, nodeIdx) {\n            if (nodeInfo.skin != null) {\n                var skinIdx = nodeInfo.skin;\n                var skeleton = lib.skeletons[skinIdx];\n\n                var node = lib.nodes[nodeIdx];\n                var jointIndices = skeleton.joints.map(getJointIndex);\n                if (node instanceof Mesh) {\n                    enableSkinningForMesh(node, skeleton, jointIndices);\n                }\n                else {\n                    // Mesh have multiple primitives\n                    var children = node.children();\n                    for (var i = 0; i < children.length; i++) {\n                        enableSkinningForMesh(children[i], skeleton, jointIndices);\n                    }\n                }\n            }\n        }, this);\n    },\n\n    _parseTextures: function (json, lib) {\n        util.each(json.textures, function (textureInfo, idx){\n            // samplers is optional\n            var samplerInfo = (json.samplers && json.samplers[textureInfo.sampler]) || {};\n            var parameters = {};\n            ['wrapS', 'wrapT', 'magFilter', 'minFilter'].forEach(function (name) {\n                var value = samplerInfo[name];\n                if (value != null) {\n                    parameters[name] = value;\n                }\n            });\n            util.defaults(parameters, {\n                wrapS: Texture.REPEAT,\n                wrapT: Texture.REPEAT,\n                flipY: this.textureFlipY\n            });\n\n            var target = textureInfo.target || glenum.TEXTURE_2D;\n            var format = textureInfo.format;\n            if (format != null) {\n                parameters.format = format;\n            }\n\n            if (target === glenum.TEXTURE_2D) {\n                var texture = new Texture2D(parameters);\n                var imageInfo = json.images[textureInfo.source];\n                var uri;\n                if (imageInfo.uri) {\n                    uri = this.resolveTexturePath(imageInfo.uri);\n                }\n                else if (imageInfo.bufferView != null) {\n                    uri = URL.createObjectURL(new Blob([lib.bufferViews[imageInfo.bufferView]], {\n                        type: imageInfo.mimeType\n                    }));\n                }\n                if (uri) {\n                    texture.load(uri, this.crossOrigin);\n                    lib.textures[idx] = texture;\n                }\n            }\n        }, this);\n    },\n\n    _KHRCommonMaterialToStandard: function (materialInfo, lib) {\n        var uniforms = {};\n        var commonMaterialInfo = materialInfo.extensions['KHR_materials_common'];\n        uniforms = commonMaterialInfo.values || {};\n\n        if (typeof uniforms.diffuse === 'number') {\n            uniforms.diffuse = lib.textures[uniforms.diffuse] || null;\n        }\n        if (typeof uniforms.emission === 'number') {\n            uniforms.emission = lib.textures[uniforms.emission] || null;\n        }\n\n        var enabledTextures = [];\n        if (uniforms['diffuse'] instanceof Texture2D) {\n            enabledTextures.push('diffuseMap');\n        }\n        if (materialInfo.normalTexture) {\n            enabledTextures.push('normalMap');\n        }\n        if (uniforms['emission'] instanceof Texture2D) {\n            enabledTextures.push('emissiveMap');\n        }\n        var material;\n        var isStandardMaterial = this.useStandardMaterial;\n        if (isStandardMaterial) {\n            material = new StandardMaterial({\n                name: materialInfo.name,\n                doubleSided: materialInfo.doubleSided\n            });\n        }\n        else {\n            material = new Material({\n                name: materialInfo.name,\n                shader: this._getShader()\n            });\n\n            material.define('fragment', 'USE_ROUGHNESS');\n            material.define('fragment', 'USE_METALNESS');\n\n            if (materialInfo.doubleSided) {\n                material.define('fragment', 'DOUBLE_SIDED');\n            }\n        }\n\n        if (uniforms.transparent) {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        var diffuseProp = uniforms['diffuse'];\n        if (diffuseProp) {\n            // Color\n            if (Array.isArray(diffuseProp)) {\n                diffuseProp = diffuseProp.slice(0, 3);\n                isStandardMaterial ? (material.color = diffuseProp)\n                    : material.set('color', diffuseProp);\n            }\n            else { // Texture\n                isStandardMaterial ? (material.diffuseMap = diffuseProp)\n                    : material.set('diffuseMap', diffuseProp);\n            }\n        }\n        var emissionProp = uniforms['emission'];\n        if (emissionProp != null) {\n            // Color\n            if (Array.isArray(emissionProp)) {\n                emissionProp = emissionProp.slice(0, 3);\n                isStandardMaterial ? (material.emission = emissionProp)\n                    : material.set('emission', emissionProp);\n            }\n            else { // Texture\n                isStandardMaterial ? (material.emissiveMap = emissionProp)\n                    : material.set('emissiveMap', emissionProp);\n            }\n        }\n        if (materialInfo.normalTexture != null) {\n            // TODO texCoord\n            var normalTextureIndex = materialInfo.normalTexture.index;\n            if (isStandardMaterial) {\n                material.normalMap = lib.textures[normalTextureIndex] || null;\n            }\n            else {\n                material.set('normalMap', lib.textures[normalTextureIndex] || null);\n            }\n        }\n        if (uniforms['shininess'] != null) {\n            var glossiness = Math.log(uniforms['shininess']) / Math.log(8192);\n            // Uniform glossiness\n            material.set('glossiness', glossiness);\n            material.set('roughness', 1 - glossiness);\n        }\n        else {\n            material.set('glossiness', 0.3);\n            material.set('roughness', 0.3);\n        }\n        if (uniforms['specular'] != null) {\n            material.set('specularColor', uniforms['specular'].slice(0, 3));\n        }\n        if (uniforms['transparency'] != null) {\n            material.set('alpha', uniforms['transparency']);\n        }\n\n        return material;\n    },\n\n    _pbrMetallicRoughnessToStandard: function (materialInfo, metallicRoughnessMatInfo, lib) {\n        var alphaTest = materialInfo.alphaMode === 'MASK';\n\n        var isStandardMaterial = this.useStandardMaterial;\n        var material;\n        var diffuseMap, roughnessMap, metalnessMap, normalMap, emissiveMap;\n        var enabledTextures = [];\n            // TODO texCoord\n        if (metallicRoughnessMatInfo.baseColorTexture) {\n            diffuseMap = lib.textures[metallicRoughnessMatInfo.baseColorTexture.index] || null;\n            diffuseMap && enabledTextures.push('diffuseMap');\n        }\n        if (metallicRoughnessMatInfo.metallicRoughnessTexture) {\n            roughnessMap = metalnessMap = lib.textures[metallicRoughnessMatInfo.metallicRoughnessTexture.index] || null;\n            roughnessMap && enabledTextures.push('metalnessMap', 'roughnessMap');\n        }\n        if (materialInfo.normalTexture) {\n            normalMap = lib.textures[materialInfo.normalTexture.index] || null;\n            normalMap && enabledTextures.push('normalMap');\n        }\n        if (materialInfo.emissiveTexture) {\n            emissiveMap = lib.textures[materialInfo.emissiveTexture.index] || null;\n            emissiveMap && enabledTextures.push('emissiveMap');\n        }\n        var baseColor = metallicRoughnessMatInfo.baseColorFactor || [1, 1, 1, 1];\n\n        var commonProperties = {\n            diffuseMap: diffuseMap || null,\n            roughnessMap: roughnessMap || null,\n            metalnessMap: metalnessMap || null,\n            normalMap: normalMap || null,\n            emissiveMap: emissiveMap || null,\n            color: baseColor.slice(0, 3),\n            alpha: baseColor[3],\n            metalness: metallicRoughnessMatInfo.metallicFactor || 0,\n            roughness: metallicRoughnessMatInfo.roughnessFactor || 0,\n            emission: materialInfo.emissiveFactor || [0, 0, 0],\n            alphaCutoff: materialInfo.alphaCutoff || 0\n        };\n        if (commonProperties.roughnessMap) {\n            // In glTF metallicFactor will do multiply, which is different from StandardMaterial.\n            // So simply ignore it\n            commonProperties.metalness = 0.5;\n            commonProperties.roughness = 0.5;\n        }\n        if (isStandardMaterial) {\n            material = new StandardMaterial(util.extend({\n                name: materialInfo.name,\n                alphaTest: alphaTest,\n                doubleSided: materialInfo.doubleSided,\n                // G channel\n                roughnessChannel: 1,\n                // B Channel\n                metalnessChannel: 2\n            }, commonProperties));\n        }\n        else {\n\n            material = new Material({\n                name: materialInfo.name,\n                shader: this._getShader()\n            });\n\n            material.define('fragment', 'USE_ROUGHNESS');\n            material.define('fragment', 'USE_METALNESS');\n            material.define('fragment', 'ROUGHNESS_CHANNEL', 1);\n            material.define('fragment', 'METALNESS_CHANNEL', 2);\n\n            if (alphaTest) {\n                material.define('fragment', 'ALPHA_TEST');\n            }\n            if (materialInfo.doubleSided) {\n                material.define('fragment', 'DOUBLE_SIDED');\n            }\n\n            material.set(commonProperties);\n        }\n\n        if (materialInfo.alphaMode === 'BLEND') {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        return material;\n    },\n\n    _pbrSpecularGlossinessToStandard: function (materialInfo, specularGlossinessMatInfo, lib) {\n        var alphaTest = materialInfo.alphaMode === 'MASK';\n\n        if (this.useStandardMaterial) {\n            console.error('StandardMaterial doesn\\'t support specular glossiness workflow yet');\n        }\n\n        var material;\n        var diffuseMap, glossinessMap, specularMap, normalMap, emissiveMap;\n        var enabledTextures = [];\n            // TODO texCoord\n        if (specularGlossinessMatInfo.diffuseTexture) {\n            diffuseMap = lib.textures[specularGlossinessMatInfo.diffuseTexture.index] || null;\n            diffuseMap && enabledTextures.push('diffuseMap');\n        }\n        if (specularGlossinessMatInfo.specularGlossinessTexture) {\n            glossinessMap = specularMap = lib.textures[specularGlossinessMatInfo.specularGlossinessTexture.index] || null;\n            glossinessMap && enabledTextures.push('specularMap', 'glossinessMap');\n        }\n        if (materialInfo.normalTexture) {\n            normalMap = lib.textures[materialInfo.normalTexture.index] || null;\n            normalMap && enabledTextures.push('normalMap');\n        }\n        if (materialInfo.emissiveTexture) {\n            emissiveMap = lib.textures[materialInfo.emissiveTexture.index] || null;\n            emissiveMap && enabledTextures.push('emissiveMap');\n        }\n        var diffuseColor = specularGlossinessMatInfo.diffuseFactor || [1, 1, 1, 1];\n\n        var commonProperties = {\n            diffuseMap: diffuseMap || null,\n            glossinessMap: glossinessMap || null,\n            specularMap: specularMap || null,\n            normalMap: normalMap || null,\n            emissiveMap: emissiveMap || null,\n            color: diffuseColor.slice(0, 3),\n            alpha: diffuseColor[3],\n            specularColor: specularGlossinessMatInfo.specularFactor || [1, 1, 1],\n            glossiness: specularGlossinessMatInfo.glossinessFactor || 0,\n            emission: materialInfo.emissiveFactor || [0, 0, 0],\n            alphaCutoff: materialInfo.alphaCutoff == null ? 0.9 : materialInfo.alphaCutoff\n        };\n        if (commonProperties.glossinessMap) {\n            // Ignore specularFactor\n            commonProperties.glossiness = 0.5;\n        }\n        if (commonProperties.specularMap) {\n            // Ignore specularFactor\n            commonProperties.specularColor = [1, 1, 1];\n        }\n\n        material = new Material({\n            name: materialInfo.name,\n            shader: this._getShader()\n        });\n\n        material.define('fragment', 'GLOSSINESS_CHANNEL', 3);\n\n        if (alphaTest) {\n            material.define('fragment', 'ALPHA_TEST');\n        }\n        if (materialInfo.doubleSided) {\n            material.define('fragment', 'DOUBLE_SIDED');\n        }\n\n        material.set(commonProperties);\n\n        if (materialInfo.alphaMode === 'BLEND') {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        return material;\n    },\n\n    _parseMaterials: function (json, lib) {\n        util.each(json.materials, function (materialInfo, idx) {\n            if (materialInfo.extensions && materialInfo.extensions['KHR_materials_common']) {\n                lib.materials[idx] = this._KHRCommonMaterialToStandard(materialInfo, lib);\n            }\n            else if (materialInfo.extensions && materialInfo.extensions['KHR_materials_pbrSpecularGlossiness']) {\n                lib.materials[idx] = this._pbrSpecularGlossinessToStandard(materialInfo, materialInfo.extensions['KHR_materials_pbrSpecularGlossiness'], lib);\n            }\n            else {\n                lib.materials[idx] = this._pbrMetallicRoughnessToStandard(materialInfo, materialInfo.pbrMetallicRoughness || {}, lib);\n            }\n        }, this);\n    },\n\n    _parseMeshes: function (json, lib) {\n        var self = this;\n\n        util.each(json.meshes, function (meshInfo, idx) {\n            lib.meshes[idx] = [];\n            // Geometry\n            for (var pp = 0; pp < meshInfo.primitives.length; pp++) {\n                var primitiveInfo = meshInfo.primitives[pp];\n                var geometry = new Geometry({\n                    dynamic: false,\n                    // PENDIGN\n                    name: meshInfo.name,\n                    boundingBox: new BoundingBox()\n                });\n                // Parse attributes\n                var semantics = Object.keys(primitiveInfo.attributes);\n                for (var ss = 0; ss < semantics.length; ss++) {\n                    var semantic = semantics[ss];\n                    var accessorIdx = primitiveInfo.attributes[semantic];\n                    var attributeInfo = json.accessors[accessorIdx];\n                    var attributeName = semanticAttributeMap[semantic];\n                    if (!attributeName) {\n                        continue;\n                    }\n                    var size = SIZE_MAP[attributeInfo.type];\n                    var attributeArray = getAccessorData(json, lib, accessorIdx);\n                    // WebGL attribute buffer not support uint32.\n                    // Direct use Float32Array may also have issue.\n                    if (attributeArray instanceof vendor.Uint32Array) {\n                        attributeArray = new Float32Array(attributeArray);\n                    }\n                    if (semantic === 'WEIGHTS_0' && size === 4) {\n                        // Weight data in QTEK has only 3 component, the last component can be evaluated since it is normalized\n                        var weightArray = new attributeArray.constructor(attributeInfo.count * 3);\n                        for (var i = 0; i < attributeInfo.count; i++) {\n                            var i4 = i * 4, i3 = i * 3;\n                            var w1 = attributeArray[i4], w2 = attributeArray[i4 + 1], w3 = attributeArray[i4 + 2], w4 = attributeArray[i4 + 3];\n                            var wSum = w1 + w2 + w3 + w4;\n                            weightArray[i3] = w1 / wSum;\n                            weightArray[i3 + 1] = w2 / wSum;\n                            weightArray[i3 + 2] = w3 / wSum;\n                        }\n                        geometry.attributes[attributeName].value = weightArray;\n                    }\n                    else {\n                        geometry.attributes[attributeName].value = attributeArray;\n                    }\n                    var attributeType = 'float';\n                    if (attributeArray instanceof vendor.Uint16Array) {\n                        attributeType = 'ushort';\n                    }\n                    else if (attributeArray instanceof vendor.Int16Array) {\n                        attributeType = 'short';\n                    }\n                    else if (attributeArray instanceof vendor.Uint8Array) {\n                        attributeType = 'ubyte';\n                    }\n                    else if (attributeArray instanceof vendor.Int8Array) {\n                        attributeType = 'byte';\n                    }\n                    geometry.attributes[attributeName].type = attributeType;\n\n                    if (semantic === 'POSITION') {\n                        // Bounding Box\n                        var min = attributeInfo.min;\n                        var max = attributeInfo.max;\n                        if (min) {\n                            geometry.boundingBox.min.set(min[0], min[1], min[2]);\n                        }\n                        if (max) {\n                            geometry.boundingBox.max.set(max[0], max[1], max[2]);\n                        }\n                    }\n                }\n\n                // Parse indices\n                if (primitiveInfo.indices != null) {\n                    geometry.indices = getAccessorData(json, lib, primitiveInfo.indices, true);\n                    if (geometry.vertexCount <= 0xffff && geometry.indices instanceof vendor.Uint32Array) {\n                        geometry.indices = new vendor.Uint16Array(geometry.indices);\n                    }\n                    if(geometry.indices instanceof vendor.Uint8Array) {\n                        geometry.indices = new vendor.Uint16Array(geometry.indices);\n                    }\n                }\n\n                var material = lib.materials[primitiveInfo.material];\n                var materialInfo = (json.materials || [])[primitiveInfo.material];\n                // Use default material\n                if (!material) {\n                    material = new Material({\n                        shader: self._getShader()\n                    });\n                }\n                var mesh = new Mesh({\n                    geometry: geometry,\n                    material: material,\n                    mode: [Mesh.POINTS, Mesh.LINES, Mesh.LINE_LOOP, Mesh.LINE_STRIP, Mesh.TRIANGLES, Mesh.TRIANGLE_STRIP, Mesh.TRIANGLE_FAN][primitiveInfo.mode] || Mesh.TRIANGLES,\n                    ignoreGBuffer: material.transparent\n                });\n                if (materialInfo != null) {\n                    mesh.culling = !materialInfo.doubleSided;\n                }\n                if (!mesh.geometry.attributes.normal.value) {\n                    mesh.geometry.generateVertexNormals();\n                }\n                if (((material instanceof StandardMaterial) && material.normalMap)\n                    || (material.isTextureEnabled('normalMap'))\n                ) {\n                    if (!mesh.geometry.attributes.tangent.value) {\n                        mesh.geometry.generateTangents();\n                    }\n                }\n\n                mesh.name = GLTFLoader.generateMeshName(json.meshes, idx, pp);\n\n                lib.meshes[idx].push(mesh);\n            }\n        }, this);\n    },\n\n    _instanceCamera: function (json, nodeInfo) {\n        var cameraInfo = json.cameras[nodeInfo.camera];\n\n        if (cameraInfo.type === 'perspective') {\n            var perspectiveInfo = cameraInfo.perspective || {};\n            return new PerspectiveCamera({\n                name: nodeInfo.name,\n                aspect: perspectiveInfo.aspectRatio,\n                fov: perspectiveInfo.yfov,\n                far: perspectiveInfo.zfar,\n                near: perspectiveInfo.znear\n            });\n        }\n        else {\n            var orthographicInfo = cameraInfo.orthographic || {};\n            return new OrthographicCamera({\n                name: nodeInfo.name,\n                top: orthographicInfo.ymag,\n                right: orthographicInfo.xmag,\n                left: -orthographicInfo.xmag,\n                bottom: -orthographicInfo.ymag,\n                near: orthographicInfo.znear,\n                far: orthographicInfo.zfar\n            });\n        }\n    },\n\n    _parseNodes: function (json, lib) {\n\n        function instanceMesh(mesh) {\n            return new Mesh({\n                name: mesh.name,\n                geometry: mesh.geometry,\n                material: mesh.material,\n                culling: mesh.culling,\n                mode: mesh.mode\n            });\n        }\n\n        util.each(json.nodes, function (nodeInfo, idx) {\n            var node;\n            if (nodeInfo.camera != null && this.includeCamera) {\n                node = this._instanceCamera(json, nodeInfo);\n                lib.cameras.push(node);\n            }\n            else if (nodeInfo.mesh != null && this.includeMesh) {\n                var primitives = lib.meshes[nodeInfo.mesh];\n                if (primitives) {\n                    if (primitives.length === 1) {\n                        // Replace the node with mesh directly\n                        node = instanceMesh(primitives[0]);\n                        node.setName(nodeInfo.name);\n                    }\n                    else {\n                        node = new Node();\n                        node.setName(nodeInfo.name);\n                        for (var j = 0; j < primitives.length; j++) {\n                            node.add(instanceMesh(primitives[j]));\n                        }\n                    }\n                }\n            }\n            else {\n                node = new Node();\n                // PENDING Dulplicate name.\n                node.setName(nodeInfo.name);\n            }\n            if (nodeInfo.matrix) {\n                node.localTransform.setArray(nodeInfo.matrix);\n                node.decomposeLocalTransform();\n            }\n            else {\n                if (nodeInfo.translation) {\n                    node.position.setArray(nodeInfo.translation);\n                }\n                if (nodeInfo.rotation) {\n                    node.rotation.setArray(nodeInfo.rotation);\n                }\n                if (nodeInfo.scale) {\n                    node.scale.setArray(nodeInfo.scale);\n                }\n            }\n\n            lib.nodes[idx] = node;\n        }, this);\n\n        // Build hierarchy\n        util.each(json.nodes, function (nodeInfo, idx) {\n            var node = lib.nodes[idx];\n            if (nodeInfo.children) {\n                for (var i = 0; i < nodeInfo.children.length; i++) {\n                    var childIdx = nodeInfo.children[i];\n                    var child = lib.nodes[childIdx];\n                    node.add(child);\n                }\n            }\n        });\n        },\n\n    _parseAnimations: function (json, lib) {\n        function checkChannelPath(channelInfo) {\n            if (channelInfo.path === 'weights') {\n                console.warn('GLTFLoader not support morph targets yet.');\n                return false;\n            }\n            return true;\n        }\n\n        function getChannelHash(channelInfo, animationInfo) {\n            return channelInfo.target.node + '_' + animationInfo.samplers[channelInfo.sampler].input;\n        }\n\n        var timeAccessorMultiplied = {};\n        util.each(json.animations, function (animationInfo, idx) {\n            var channels = animationInfo.channels.filter(checkChannelPath);\n\n            if (!channels.length) {\n                return;\n            }\n            var tracks = {};\n            for (var i = 0; i < channels.length; i++) {\n                var channelInfo = channels[i];\n                var channelHash = getChannelHash(channelInfo, animationInfo);\n\n                var targetNode = lib.nodes[channelInfo.target.node];\n                var track = tracks[channelHash];\n                var samplerInfo = animationInfo.samplers[channelInfo.sampler];\n\n                if (!track) {\n                    track = tracks[channelHash] = new SamplerTrack({\n                        name: targetNode ? targetNode.name : '',\n                        target: targetNode\n                    });\n                    track.targetNodeIndex = channelInfo.target.node;\n                    track.channels.time = getAccessorData(json, lib, samplerInfo.input);\n                    var frameLen = track.channels.time.length;\n                    if (!timeAccessorMultiplied[samplerInfo.input]) {\n                        for (var k = 0; k < frameLen; k++) {\n                            track.channels.time[k] *= 1000;\n                        }\n                        timeAccessorMultiplied[samplerInfo.input] = true;\n                    }\n                }\n\n                var interpolation = samplerInfo.interpolation || 'LINEAR';\n                if (interpolation !== 'LINEAR') {\n                    console.warn('GLTFLoader only support LINEAR interpolation.');\n                }\n\n                var path = channelInfo.target.path;\n                if (path === 'translation') {\n                    path = 'position';\n                }\n\n                track.channels[path] = getAccessorData(json, lib, samplerInfo.output);\n            }\n            var clip = new TrackClip({\n                name: animationInfo.name,\n                loop: true\n            });\n            for (var hash in tracks) {\n                clip.addTrack(tracks[hash]);\n            }\n            clip.calcLifeFromTracks();\n            lib.clips.push(clip);\n        }, this);\n\n\n        // PENDING\n        var maxLife = lib.clips.reduce(function (maxTime, clip) {\n            return Math.max(maxTime, clip.life);\n        }, 0);\n        lib.clips.forEach(function (clip) {\n            clip.life = maxLife;\n        });\n\n        return lib.clips;\n    }\n});\n\nGLTFLoader.generateMeshName = function (meshes, idx, primitiveIdx) {\n    var meshInfo = meshes[idx];\n    var meshName = meshInfo.name || ('mesh_' + idx);\n    return primitiveIdx === 0 ? meshName : (meshName + '$' + primitiveIdx);\n};\n\nexport default GLTFLoader;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Directional\n * @extends clay.Light\n *\n * @example\n *     var light = new clay.light.Directional({\n *         intensity: 0.5,\n *         color: [1.0, 0.0, 0.0]\n *     });\n *     light.position.set(10, 10, 10);\n *     light.lookAt(clay.math.Vector3.ZERO);\n *     scene.add(light);\n */\nvar DirectionalLight = Light.extend(\n/** @lends clay.light.Directional# */\n{\n    /**\n     * @type {number}\n     */\n    shadowBias: 0.001,\n    /**\n     * @type {number}\n     */\n    shadowSlopeScale: 2.0,\n    /**\n     * Shadow cascade.\n     * Use PSSM technique when it is larger than 1 and have a unique directional light in scene.\n     * @type {number}\n     */\n    shadowCascade: 1,\n\n    /**\n     * Available when shadowCascade is larger than 1 and have a unique directional light in scene.\n     * @type {number}\n     */\n    cascadeSplitLogFactor: 0.2\n}, {\n\n    type: 'DIRECTIONAL_LIGHT',\n\n    uniformTemplates: {\n        directionalLightDirection: {\n            type: '3f',\n            value: function (instance) {\n                instance.__dir = instance.__dir || new Vector3();\n                // Direction is target to eye\n                return instance.__dir.copy(instance.worldTransform.z).normalize().negate().array;\n            }\n        },\n        directionalLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Directional}\n     * @memberOf clay.light.Directional.prototype\n     */\n    clone: function () {\n        var light = Light.prototype.clone.call(this);\n        light.shadowBias = this.shadowBias;\n        light.shadowSlopeScale = this.shadowSlopeScale;\n        return light;\n    }\n});\n\nexport default DirectionalLight;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Point\n * @extends clay.Light\n */\nvar PointLight = Light.extend(\n/** @lends clay.light.Point# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    castShadow: false\n}, {\n\n    type: 'POINT_LIGHT',\n\n    uniformTemplates: {\n        pointLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        pointLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n        pointLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color,\n                    intensity = instance.intensity;\n                return [ color[0]*intensity, color[1]*intensity, color[2]*intensity ];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Point}\n     * @memberOf clay.light.Point.prototype\n     */\n    clone: function() {\n        var light = Light.prototype.clone.call(this);\n        light.range = this.range;\n        return light;\n    }\n});\n\nexport default PointLight;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Spot\n * @extends clay.Light\n */\nvar SpotLight = Light.extend(\n/**@lends clay.light.Spot */\n{\n    /**\n     * @type {number}\n     */\n    range: 20,\n    /**\n     * @type {number}\n     */\n    umbraAngle: 30,\n    /**\n     * @type {number}\n     */\n    penumbraAngle: 45,\n    /**\n     * @type {number}\n     */\n    falloffFactor: 2.0,\n    /**\n     * @type {number}\n     */\n    shadowBias: 0.0002,\n    /**\n     * @type {number}\n     */\n    shadowSlopeScale: 2.0\n},{\n\n    type: 'SPOT_LIGHT',\n\n    uniformTemplates: {\n        spotLightPosition: {\n            type: '3f',\n            value: function (instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        spotLightRange: {\n            type: '1f',\n            value: function (instance) {\n                return instance.range;\n            }\n        },\n        spotLightUmbraAngleCosine: {\n            type: '1f',\n            value: function (instance) {\n                return Math.cos(instance.umbraAngle * Math.PI / 180);\n            }\n        },\n        spotLightPenumbraAngleCosine: {\n            type: '1f',\n            value: function (instance) {\n                return Math.cos(instance.penumbraAngle * Math.PI / 180);\n            }\n        },\n        spotLightFalloffFactor: {\n            type: '1f',\n            value: function (instance) {\n                return instance.falloffFactor;\n            }\n        },\n        spotLightDirection: {\n            type: '3f',\n            value: function (instance) {\n                instance.__dir = instance.__dir || new Vector3();\n                // Direction is target to eye\n                return instance.__dir.copy(instance.worldTransform.z).negate().array;\n            }\n        },\n        spotLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Spot}\n     * @memberOf clay.light.Spot.prototype\n     */\n    clone: function () {\n        var light = Light.prototype.clone.call(this);\n        light.range = this.range;\n        light.umbraAngle = this.umbraAngle;\n        light.penumbraAngle = this.penumbraAngle;\n        light.falloffFactor = this.falloffFactor;\n        light.shadowBias = this.shadowBias;\n        light.shadowSlopeScale = this.shadowSlopeScale;\n        return light;\n    }\n});\n\nexport default SpotLight;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Ambient\n * @extends clay.Light\n */\nvar AmbientLight = Light.extend({\n\n    castShadow: false\n\n}, {\n\n    type: 'AMBIENT_LIGHT',\n\n    uniformTemplates: {\n        ambientLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.Ambient}\n     * @memberOf clay.light.Ambient.prototype\n     */\n});\n\nexport default AmbientLight;\n","import Texture from './Texture';\nimport glenum from './core/glenum';\nimport util from './core/util';\nimport mathUtil from './math/util';\nvar isPowerOfTwo = mathUtil.isPowerOfTwo;\n\nvar targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * @constructor clay.TextureCube\n * @extends clay.Texture\n *\n * @example\n *     ...\n *     var mat = new clay.Material({\n *         shader: clay.shader.library.get('clay.phong', 'environmentMap')\n *     });\n *     var envMap = new clay.TextureCube();\n *     envMap.load({\n *         'px': 'assets/textures/sky/px.jpg',\n *         'nx': 'assets/textures/sky/nx.jpg'\n *         'py': 'assets/textures/sky/py.jpg'\n *         'ny': 'assets/textures/sky/ny.jpg'\n *         'pz': 'assets/textures/sky/pz.jpg'\n *         'nz': 'assets/textures/sky/nz.jpg'\n *     });\n *     mat.set('environmentMap', envMap);\n *     ...\n *     envMap.success(function () {\n *         // Wait for the sky texture loaded\n *         animation.on('frame', function (frameTime) {\n *             renderer.render(scene, camera);\n *         });\n *     });\n */\nvar TextureCube = Texture.extend(function () {\n    return /** @lends clay.TextureCube# */{\n        /**\n         * @type {Object}\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} px\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} nx\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} py\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} ny\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} pz\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} nz\n         */\n        image: {\n            px: null,\n            nx: null,\n            py: null,\n            ny: null,\n            pz: null,\n            nz: null\n        },\n        /**\n         * Pixels data of each side. Will be ignored if images are set.\n         * @type {Object}\n         * @property {?Uint8Array} px\n         * @property {?Uint8Array} nx\n         * @property {?Uint8Array} py\n         * @property {?Uint8Array} ny\n         * @property {?Uint8Array} pz\n         * @property {?Uint8Array} nz\n         */\n        pixels: {\n            px: null,\n            nx: null,\n            py: null,\n            ny: null,\n            pz: null,\n            nz: null\n        },\n\n        /**\n         * @type {Array.<Object>}\n         */\n        mipmaps: []\n    };\n}, {\n    update: function (renderer) {\n        var _gl = renderer.gl;\n        _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture'));\n\n        this.updateCommon(renderer);\n\n        var glFormat = this.format;\n        var glType = this.type;\n\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS());\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT());\n\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter());\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter());\n\n        var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic');\n        if (anisotropicExt && this.anisotropic > 1) {\n            _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic);\n        }\n\n        // Fallback to float type if browser don't have half float extension\n        if (glType === 36193) {\n            var halfFloatExt = renderer.getGLExtension('OES_texture_half_float');\n            if (!halfFloatExt) {\n                glType = glenum.FLOAT;\n            }\n        }\n\n        if (this.mipmaps.length) {\n            var width = this.width;\n            var height = this.height;\n            for (var i = 0; i < this.mipmaps.length; i++) {\n                var mipmap = this.mipmaps[i];\n                this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType);\n                width /= 2;\n                height /= 2;\n            }\n        }\n        else {\n            this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType);\n\n            if (!this.NPOT && this.useMipmap) {\n                _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP);\n            }\n        }\n\n        _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null);\n    },\n\n    _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) {\n        for (var i = 0; i < 6; i++) {\n            var target = targetList[i];\n            var img = data.image && data.image[target];\n            if (img) {\n                _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img);\n            }\n            else {\n                _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]);\n            }\n        }\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @memberOf clay.TextureCube.prototype\n     */\n    generateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        if (this.useMipmap && !this.NPOT) {\n            _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture'));\n            _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP);\n        }\n    },\n\n    bind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer));\n    },\n\n    unbind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null);\n    },\n\n    // Overwrite the isPowerOfTwo method\n    isPowerOfTwo: function () {\n        if (this.image.px) {\n            return isPowerOfTwo(this.image.px.width)\n                && isPowerOfTwo(this.image.px.height);\n        }\n        else {\n            return isPowerOfTwo(this.width)\n                && isPowerOfTwo(this.height);\n        }\n    },\n\n    isRenderable: function () {\n        if (this.image.px) {\n            return isImageRenderable(this.image.px)\n                && isImageRenderable(this.image.nx)\n                && isImageRenderable(this.image.py)\n                && isImageRenderable(this.image.ny)\n                && isImageRenderable(this.image.pz)\n                && isImageRenderable(this.image.nz);\n        }\n        else {\n            return !!(this.width && this.height);\n        }\n    },\n\n    load: function (imageList, crossOrigin) {\n        var loading = 0;\n        var self = this;\n        util.each(imageList, function (src, target){\n            var image = new Image();\n            if (crossOrigin) {\n                image.crossOrigin = crossOrigin;\n            }\n            image.onload = function () {\n                loading --;\n                if (loading === 0){\n                    self.dirty();\n                    self.trigger('success', self);\n                }\n                image.onload = null;\n            };\n            image.onerror = function () {\n                loading --;\n                image.onerror = null;\n            };\n\n            loading++;\n            image.src = src;\n            self.image[target] = image;\n        });\n\n        return this;\n    }\n});\n\nObject.defineProperty(TextureCube.prototype, 'width', {\n    get: function () {\n        if (this.image && this.image.px) {\n            return this.image.px.width;\n        }\n        return this._width;\n    },\n    set: function (value) {\n        if (this.image && this.image.px) {\n            console.warn('Texture from image can\\'t set width');\n        }\n        else {\n            if (this._width !== value) {\n                this.dirty();\n            }\n            this._width = value;\n        }\n    }\n});\nObject.defineProperty(TextureCube.prototype, 'height', {\n    get: function () {\n        if (this.image && this.image.px) {\n            return this.image.px.height;\n        }\n        return this._height;\n    },\n    set: function (value) {\n        if (this.image && this.image.px) {\n            console.warn('Texture from image can\\'t set height');\n        }\n        else {\n            if (this._height !== value) {\n                this.dirty();\n            }\n            this._height = value;\n        }\n    }\n});\nfunction isImageRenderable(image) {\n    return image.nodeName === 'CANVAS' ||\n            image.nodeName === 'VIDEO' ||\n            image.complete;\n}\n\nexport default TextureCube;\n","import Base from './core/Base';\nimport Texture from './Texture';\nimport TextureCube from './TextureCube';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\n\nvar KEY_FRAMEBUFFER = 'framebuffer';\nvar KEY_RENDERBUFFER = 'renderbuffer';\nvar KEY_RENDERBUFFER_WIDTH = KEY_RENDERBUFFER + '_width';\nvar KEY_RENDERBUFFER_HEIGHT = KEY_RENDERBUFFER + '_height';\nvar KEY_RENDERBUFFER_ATTACHED = KEY_RENDERBUFFER + '_attached';\nvar KEY_DEPTHTEXTURE_ATTACHED = 'depthtexture_attached';\n\nvar GL_FRAMEBUFFER = glenum.FRAMEBUFFER;\nvar GL_RENDERBUFFER = glenum.RENDERBUFFER;\nvar GL_DEPTH_ATTACHMENT = glenum.DEPTH_ATTACHMENT;\nvar GL_COLOR_ATTACHMENT0 = glenum.COLOR_ATTACHMENT0;\n/**\n * @constructor clay.FrameBuffer\n * @extends clay.core.Base\n */\nvar FrameBuffer = Base.extend(\n/** @lends clay.FrameBuffer# */\n{\n    /**\n     * If use depth buffer\n     * @type {boolean}\n     */\n    depthBuffer: true,\n\n    /**\n     * @type {Object}\n     */\n    viewport: null,\n\n    _width: 0,\n    _height: 0,\n\n    _textures: null,\n\n    _boundRenderer: null,\n}, function () {\n    // Use cache\n    this._cache = new Cache();\n\n    this._textures = {};\n},\n\n/**@lends clay.FrameBuffer.prototype. */\n{\n    /**\n     * Get attached texture width\n     * {number}\n     */\n    // FIXME Can't use before #bind\n    getTextureWidth: function () {\n        return this._width;\n    },\n\n    /**\n     * Get attached texture height\n     * {number}\n     */\n    getTextureHeight: function () {\n        return this._height;\n    },\n\n    /**\n     * Bind the framebuffer to given renderer before rendering\n     * @param  {clay.Renderer} renderer\n     */\n    bind: function (renderer) {\n\n        if (renderer.__currentFrameBuffer) {\n            // Already bound\n            if (renderer.__currentFrameBuffer === this) {\n                return;\n            }\n\n            console.warn('Renderer already bound with another framebuffer. Unbind it first');\n        }\n        renderer.__currentFrameBuffer = this;\n\n        var _gl = renderer.gl;\n\n        _gl.bindFramebuffer(GL_FRAMEBUFFER, this._getFrameBufferGL(renderer));\n        this._boundRenderer = renderer;\n        var cache = this._cache;\n\n        cache.put('viewport', renderer.viewport);\n\n        var hasTextureAttached = false;\n        var width;\n        var height;\n        for (var attachment in this._textures) {\n            hasTextureAttached = true;\n            var obj = this._textures[attachment];\n            if (obj) {\n                // TODO Do width, height checking, make sure size are same\n                width = obj.texture.width;\n                height = obj.texture.height;\n                // Attach textures\n                this._doAttach(renderer, obj.texture, attachment, obj.target);\n            }\n        }\n\n        this._width = width;\n        this._height = height;\n\n        if (!hasTextureAttached && this.depthBuffer) {\n            console.error('Must attach texture before bind, or renderbuffer may have incorrect width and height.')\n        }\n\n        if (this.viewport) {\n            renderer.setViewport(this.viewport);\n        }\n        else {\n            renderer.setViewport(0, 0, width, height, 1);\n        }\n\n        var attachedTextures = cache.get('attached_textures');\n        if (attachedTextures) {\n            for (var attachment in attachedTextures) {\n                if (!this._textures[attachment]) {\n                    var target = attachedTextures[attachment];\n                    this._doDetach(_gl, attachment, target);\n                }\n            }\n        }\n        if (!cache.get(KEY_DEPTHTEXTURE_ATTACHED) && this.depthBuffer) {\n            // Create a new render buffer\n            if (cache.miss(KEY_RENDERBUFFER)) {\n                cache.put(KEY_RENDERBUFFER, _gl.createRenderbuffer());\n            }\n            var renderbuffer = cache.get(KEY_RENDERBUFFER);\n\n            if (width !== cache.get(KEY_RENDERBUFFER_WIDTH)\n                    || height !== cache.get(KEY_RENDERBUFFER_HEIGHT)) {\n                _gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer);\n                _gl.renderbufferStorage(GL_RENDERBUFFER, _gl.DEPTH_COMPONENT16, width, height);\n                cache.put(KEY_RENDERBUFFER_WIDTH, width);\n                cache.put(KEY_RENDERBUFFER_HEIGHT, height);\n                _gl.bindRenderbuffer(GL_RENDERBUFFER, null);\n            }\n            if (!cache.get(KEY_RENDERBUFFER_ATTACHED)) {\n                _gl.framebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, renderbuffer);\n                cache.put(KEY_RENDERBUFFER_ATTACHED, true);\n            }\n        }\n    },\n\n    /**\n     * Unbind the frame buffer after rendering\n     * @param  {clay.Renderer} renderer\n     */\n    unbind: function (renderer) {\n        // Remove status record on renderer\n        renderer.__currentFrameBuffer = null;\n\n        var _gl = renderer.gl;\n\n        _gl.bindFramebuffer(GL_FRAMEBUFFER, null);\n        this._boundRenderer = null;\n\n        this._cache.use(renderer.__uid__);\n        var viewport = this._cache.get('viewport');\n        // Reset viewport;\n        if (viewport) {\n            renderer.setViewport(viewport);\n        }\n\n        this.updateMipmap(renderer);\n    },\n\n    // Because the data of texture is changed over time,\n    // Here update the mipmaps of texture each time after rendered;\n    updateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        for (var attachment in this._textures) {\n            var obj = this._textures[attachment];\n            if (obj) {\n                var texture = obj.texture;\n                // FIXME some texture format can't generate mipmap\n                if (!texture.NPOT && texture.useMipmap\n                    && texture.minFilter === Texture.LINEAR_MIPMAP_LINEAR) {\n                    var target = texture instanceof TextureCube ? glenum.TEXTURE_CUBE_MAP : glenum.TEXTURE_2D;\n                    _gl.bindTexture(target, texture.getWebGLTexture(renderer));\n                    _gl.generateMipmap(target);\n                    _gl.bindTexture(target, null);\n                }\n            }\n        }\n    },\n\n\n    // 0x8CD5, 36053, FRAMEBUFFER_COMPLETE\n    // 0x8CD6, 36054, FRAMEBUFFER_INCOMPLETE_ATTACHMENT\n    // 0x8CD7, 36055, FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\n    // 0x8CD9, 36057, FRAMEBUFFER_INCOMPLETE_DIMENSIONS\n    // 0x8CDD, 36061, FRAMEBUFFER_UNSUPPORTED\n    checkStatus: function (_gl) {\n        return _gl.checkFramebufferStatus(GL_FRAMEBUFFER);\n    },\n\n    _getFrameBufferGL: function (renderer) {\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n\n        if (cache.miss(KEY_FRAMEBUFFER)) {\n            cache.put(KEY_FRAMEBUFFER, renderer.gl.createFramebuffer());\n        }\n\n        return cache.get(KEY_FRAMEBUFFER);\n    },\n\n    /**\n     * Attach a texture(RTT) to the framebuffer\n     * @param  {clay.Texture} texture\n     * @param  {number} [attachment=gl.COLOR_ATTACHMENT0]\n     * @param  {number} [target=gl.TEXTURE_2D]\n     */\n    attach: function (texture, attachment, target) {\n\n        if (!texture.width) {\n            throw new Error('The texture attached to color buffer is not a valid.');\n        }\n        // TODO width and height check\n\n        // If the depth_texture extension is enabled, developers\n        // Can attach a depth texture to the depth buffer\n        // http://blog.tojicode.com/2012/07/using-webgldepthtexture.html\n        attachment = attachment || GL_COLOR_ATTACHMENT0;\n        target = target || glenum.TEXTURE_2D;\n\n        var boundRenderer = this._boundRenderer;\n        var _gl = boundRenderer && boundRenderer.gl;\n        var attachedTextures;\n\n        if (_gl) {\n            var cache = this._cache;\n            cache.use(boundRenderer.__uid__);\n            attachedTextures = cache.get('attached_textures');\n        }\n\n        // Check if texture attached\n        var previous = this._textures[attachment];\n        if (previous && previous.target === target\n            && previous.texture === texture\n            && (attachedTextures && attachedTextures[attachment] != null)\n        ) {\n            return;\n        }\n\n        var canAttach = true;\n        if (boundRenderer) {\n            canAttach = this._doAttach(boundRenderer, texture, attachment, target);\n            // Set viewport again incase attached to different size textures.\n            if (!this.viewport) {\n                boundRenderer.setViewport(0, 0, texture.width, texture.height, 1);\n            }\n        }\n\n        if (canAttach) {\n            this._textures[attachment] = this._textures[attachment] || {};\n            this._textures[attachment].texture = texture;\n            this._textures[attachment].target = target;\n        }\n    },\n\n    _doAttach: function (renderer, texture, attachment, target) {\n        var _gl = renderer.gl;\n        // Make sure texture is always updated\n        // Because texture width or height may be changed and in this we can't be notified\n        // FIXME awkward;\n        var webglTexture = texture.getWebGLTexture(renderer);\n        // Assume cache has been used.\n        var attachedTextures = this._cache.get('attached_textures');\n        if (attachedTextures && attachedTextures[attachment]) {\n            var obj = attachedTextures[attachment];\n            // Check if texture and target not changed\n            if (obj.texture === texture && obj.target === target) {\n                return;\n            }\n        }\n        attachment = +attachment;\n\n        var canAttach = true;\n        if (attachment === GL_DEPTH_ATTACHMENT || attachment === glenum.DEPTH_STENCIL_ATTACHMENT) {\n            var extension = renderer.getGLExtension('WEBGL_depth_texture');\n\n            if (!extension) {\n                console.error('Depth texture is not supported by the browser');\n                canAttach = false;\n            }\n            if (texture.format !== glenum.DEPTH_COMPONENT\n                && texture.format !== glenum.DEPTH_STENCIL\n            ) {\n                console.error('The texture attached to depth buffer is not a valid.');\n                canAttach = false;\n            }\n\n            // Dispose render buffer created previous\n            if (canAttach) {\n                var renderbuffer = this._cache.get(KEY_RENDERBUFFER);\n                if (renderbuffer) {\n                    _gl.framebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, null);\n                    _gl.deleteRenderbuffer(renderbuffer);\n                    this._cache.put(KEY_RENDERBUFFER, false);\n                }\n\n                this._cache.put(KEY_RENDERBUFFER_ATTACHED, false);\n                this._cache.put(KEY_DEPTHTEXTURE_ATTACHED, true);\n            }\n        }\n\n        // Mipmap level can only be 0\n        _gl.framebufferTexture2D(GL_FRAMEBUFFER, attachment, target, webglTexture, 0);\n\n        if (!attachedTextures) {\n            attachedTextures = {};\n            this._cache.put('attached_textures', attachedTextures);\n        }\n        attachedTextures[attachment] = attachedTextures[attachment] || {};\n        attachedTextures[attachment].texture = texture;\n        attachedTextures[attachment].target = target;\n\n        return canAttach;\n    },\n\n    _doDetach: function (_gl, attachment, target) {\n        // Detach a texture from framebuffer\n        // https://github.com/KhronosGroup/WebGL/blob/master/conformance-suites/1.0.0/conformance/framebuffer-test.html#L145\n        _gl.framebufferTexture2D(GL_FRAMEBUFFER, attachment, target, null, 0);\n\n        // Assume cache has been used.\n        var attachedTextures = this._cache.get('attached_textures');\n        if (attachedTextures && attachedTextures[attachment]) {\n            attachedTextures[attachment] = null;\n        }\n\n        if (attachment === GL_DEPTH_ATTACHMENT || attachment === glenum.DEPTH_STENCIL_ATTACHMENT) {\n            this._cache.put(KEY_DEPTHTEXTURE_ATTACHED, false);\n        }\n    },\n\n    /**\n     * Detach a texture\n     * @param  {number} [attachment=gl.COLOR_ATTACHMENT0]\n     * @param  {number} [target=gl.TEXTURE_2D]\n     */\n    detach: function (attachment, target) {\n        // TODO depth extension check ?\n        this._textures[attachment] = null;\n        if (this._boundRenderer) {\n            var cache = this._cache;\n            cache.use(this._boundRenderer.__uid__);\n            this._doDetach(this._boundRenderer.gl, attachment, target);\n        }\n    },\n    /**\n     * Dispose\n     * @param  {WebGLRenderingContext} _gl\n     */\n    dispose: function (renderer) {\n\n        var _gl = renderer.gl;\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n\n        var renderBuffer = cache.get(KEY_RENDERBUFFER);\n        if (renderBuffer) {\n            _gl.deleteRenderbuffer(renderBuffer);\n        }\n        var frameBuffer = cache.get(KEY_FRAMEBUFFER);\n        if (frameBuffer) {\n            _gl.deleteFramebuffer(frameBuffer);\n        }\n        cache.deleteContext(renderer.__uid__);\n\n        // Clear cache for reusing\n        this._textures = {};\n\n    }\n});\n\nFrameBuffer.DEPTH_ATTACHMENT = GL_DEPTH_ATTACHMENT;\nFrameBuffer.COLOR_ATTACHMENT0 = GL_COLOR_ATTACHMENT0;\nFrameBuffer.STENCIL_ATTACHMENT = glenum.STENCIL_ATTACHMENT;\nFrameBuffer.DEPTH_STENCIL_ATTACHMENT = glenum.DEPTH_STENCIL_ATTACHMENT;\n\nexport default FrameBuffer;\n","export default \"\\n@export clay.compositor.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    v_Texcoord = texcoord;\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n}\\n@end\";\n","import Base from '../core/Base';\nimport OrthoCamera from '../camera/Orthographic';\nimport Plane from '../geometry/Plane';\nimport Shader from '../Shader';\nimport Material from '../Material';\nimport Mesh from '../Mesh';\nimport glenum from '../core/glenum';\nimport vertexEssl from '../shader/source/compositor/vertex.glsl.js';\n\nShader['import'](vertexEssl);\n\nvar planeGeo = new Plane();\nvar mesh = new Mesh({\n    geometry: planeGeo,\n    frustumCulling: false\n});\nvar camera = new OrthoCamera();\n\n/**\n * @constructor clay.compositor.Pass\n * @extends clay.core.Base\n */\nvar Pass = Base.extend(function () {\n    return /** @lends clay.compositor.Pass# */ {\n        /**\n         * Fragment shader string\n         * @type {string}\n         */\n        // PENDING shader or fragment ?\n        fragment : '',\n\n        /**\n         * @type {Object}\n         */\n        outputs : null,\n\n        /**\n         * @type {clay.Material}\n         */\n        material : null,\n\n        /**\n         * @type {Boolean}\n         */\n        blendWithPrevious: false,\n\n        /**\n         * @type {Boolean}\n         */\n        clearColor: false,\n\n        /**\n         * @type {Boolean}\n         */\n        clearDepth: true\n    };\n}, function() {\n\n    var shader = new Shader(Shader.source('clay.compositor.vertex'), this.fragment);\n    var material = new Material({\n        shader: shader\n    });\n    material.enableTexturesAll();\n\n    this.material = material;\n\n},\n/** @lends clay.compositor.Pass.prototype */\n{\n    /**\n     * @param {string} name\n     * @param {} value\n     */\n    setUniform : function(name, value) {\n        this.material.setUniform(name, value);\n    },\n    /**\n     * @param  {string} name\n     * @return {}\n     */\n    getUniform : function(name) {\n        var uniform = this.material.uniforms[name];\n        if (uniform) {\n            return uniform.value;\n        }\n    },\n    /**\n     * @param  {clay.Texture} texture\n     * @param  {number} attachment\n     */\n    attachOutput : function(texture, attachment) {\n        if (!this.outputs) {\n            this.outputs = {};\n        }\n        attachment = attachment || glenum.COLOR_ATTACHMENT0;\n        this.outputs[attachment] = texture;\n    },\n    /**\n     * @param  {clay.Texture} texture\n     */\n    detachOutput : function(texture) {\n        for (var attachment in this.outputs) {\n            if (this.outputs[attachment] === texture) {\n                this.outputs[attachment] = null;\n            }\n        }\n    },\n\n    bind : function(renderer, frameBuffer) {\n\n        if (this.outputs) {\n            for (var attachment in this.outputs) {\n                var texture = this.outputs[attachment];\n                if (texture) {\n                    frameBuffer.attach(texture, attachment);\n                }\n            }\n        }\n\n        if (frameBuffer) {\n            frameBuffer.bind(renderer);\n        }\n    },\n\n    unbind : function(renderer, frameBuffer) {\n        frameBuffer.unbind(renderer);\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.FrameBuffer} [frameBuffer]\n     */\n    render : function(renderer, frameBuffer) {\n\n        var _gl = renderer.gl;\n\n        if (frameBuffer) {\n            this.bind(renderer, frameBuffer);\n            // MRT Support in chrome\n            // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html\n            var ext = renderer.getGLExtension('EXT_draw_buffers');\n            if (ext && this.outputs) {\n                var bufs = [];\n                for (var attachment in this.outputs) {\n                    attachment = +attachment;\n                    if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) {\n                        bufs.push(attachment);\n                    }\n                }\n                ext.drawBuffersEXT(bufs);\n            }\n        }\n\n        this.trigger('beforerender', this, renderer);\n\n        // FIXME Don't clear in each pass in default, let the color overwrite the buffer\n        // FIXME pixels may be discard\n        var clearBit = this.clearDepth ? _gl.DEPTH_BUFFER_BIT : 0;\n        _gl.depthMask(true);\n        if (this.clearColor) {\n            clearBit = clearBit | _gl.COLOR_BUFFER_BIT;\n            _gl.colorMask(true, true, true, true);\n            var cc = this.clearColor;\n            if (Array.isArray(cc)) {\n                _gl.clearColor(cc[0], cc[1], cc[2], cc[3]);\n            }\n        }\n        _gl.clear(clearBit);\n\n        if (this.blendWithPrevious) {\n            // Blend with previous rendered scene in the final output\n            // FIXME Configure blend.\n            // FIXME It will cause screen blink？\n            _gl.enable(_gl.BLEND);\n            this.material.transparent = true;\n        }\n        else {\n            _gl.disable(_gl.BLEND);\n            this.material.transparent = false;\n        }\n\n        this.renderQuad(renderer);\n\n        this.trigger('afterrender', this, renderer);\n\n        if (frameBuffer) {\n            this.unbind(renderer, frameBuffer);\n        }\n    },\n\n    /**\n     * Simply do quad rendering\n     */\n    renderQuad: function (renderer) {\n        mesh.material = this.material;\n        renderer.renderPass([mesh], camera);\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {}\n});\n\nexport default Pass;\n","// TODO Should not derived from mesh?\nimport Mesh from '../Mesh';\nimport CubeGeometry from '../geometry/Cube';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport skyboxEssl from '../shader/source/skybox.glsl.js';\nShader.import(skyboxEssl);\n/**\n * @constructor clay.plugin.Skybox\n *\n * @example\n *     var skyTex = new clay.TextureCube();\n *     skyTex.load({\n *         'px': 'assets/textures/sky/px.jpg',\n *         'nx': 'assets/textures/sky/nx.jpg'\n *         'py': 'assets/textures/sky/py.jpg'\n *         'ny': 'assets/textures/sky/ny.jpg'\n *         'pz': 'assets/textures/sky/pz.jpg'\n *         'nz': 'assets/textures/sky/nz.jpg'\n *     });\n *     var skybox = new clay.plugin.Skybox({\n *         scene: scene\n *     });\n *     skybox.material.set('environmentMap', skyTex);\n */\nvar Skybox = Mesh.extend(function () {\n\n    var skyboxShader = new Shader({\n        vertex: Shader.source('clay.skybox.vertex'),\n        fragment: Shader.source('clay.skybox.fragment')\n    });\n    var material = new Material({\n        shader: skyboxShader,\n        depthMask: false\n    });\n\n    return {\n        /**\n         * @type {clay.Scene}\n         * @memberOf clay.plugin.Skybox.prototype\n         */\n        scene: null,\n\n        geometry: new CubeGeometry(),\n\n        material: material,\n\n        environmentMap: null,\n\n        culling: false\n    };\n}, function () {\n    var scene = this.scene;\n    if (scene) {\n        this.attachScene(scene);\n    }\n    if (this.environmentMap) {\n        this.setEnvironmentMap(this.environmentMap);\n    }\n}, /** @lends clay.plugin.Skybox# */ {\n    /**\n     * Attach the skybox to the scene\n     * @param  {clay.Scene} scene\n     */\n    attachScene: function (scene) {\n        if (this.scene) {\n            this.detachScene();\n        }\n        this.scene = scene;\n        scene.on('beforerender', this._beforeRenderScene, this);\n    },\n    /**\n     * Detach from scene\n     */\n    detachScene: function () {\n        if (this.scene) {\n            this.scene.off('beforerender', this._beforeRenderScene);\n        }\n        this.scene = null;\n    },\n\n    /**\n     * Dispose skybox\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this.detachScene();\n        this.geometry.dispose(renderer);\n    },\n    /**\n     * Set environment map\n     * @param {clay.TextureCube} envMap\n     */\n    setEnvironmentMap: function (envMap) {\n        this.material.set('environmentMap', envMap);\n    },\n    /**\n     * Get environment map\n     * @return {clay.TextureCube}\n     */\n    getEnvironmentMap: function () {\n        return this.material.get('environmentMap');\n    },\n\n    _beforeRenderScene: function(renderer, scene, camera) {\n        this.renderSkybox(renderer, camera);\n    },\n\n    renderSkybox: function (renderer, camera) {\n        this.position.copy(camera.getWorldPosition());\n        this.update();\n        // Don't remember to disable blend\n        renderer.gl.disable(renderer.gl.BLEND);\n        renderer.renderPass([this], camera);\n    }\n});\n\nexport default Skybox;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\nimport PerspectiveCamera from '../camera/Perspective';\nimport FrameBuffer from '../FrameBuffer';\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * Pass rendering scene to a environment cube map\n *\n * @constructor clay.prePass.EnvironmentMap\n * @extends clay.core.Base\n * @example\n *     // Example of car reflection\n *     var envMap = new clay.TextureCube({\n *         width: 256,\n *         height: 256\n *     });\n *     var envPass = new clay.prePass.EnvironmentMap({\n *         position: car.position,\n *         texture: envMap\n *     });\n *     var carBody = car.getChildByName('body');\n *     carBody.material.enableTexture('environmentMap');\n *     carBody.material.set('environmentMap', envMap);\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         envPass.render(renderer, scene);\n *         renderer.render(scene, camera);\n *     });\n */\nvar EnvironmentMapPass = Base.extend(function() {\n    var ret = /** @lends clay.prePass.EnvironmentMap# */ {\n        /**\n         * Camera position\n         * @type {clay.math.Vector3}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        position: new Vector3(),\n        /**\n         * Camera far plane\n         * @type {number}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        far: 1000,\n        /**\n         * Camera near plane\n         * @type {number}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        near: 0.1,\n        /**\n         * Environment cube map\n         * @type {clay.TextureCube}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        texture: null,\n\n        /**\n         * Used if you wan't have shadow in environment map\n         * @type {clay.prePass.ShadowMap}\n         */\n        shadowMapPass: null,\n    };\n    var cameras = ret._cameras = {\n        px: new PerspectiveCamera({ fov: 90 }),\n        nx: new PerspectiveCamera({ fov: 90 }),\n        py: new PerspectiveCamera({ fov: 90 }),\n        ny: new PerspectiveCamera({ fov: 90 }),\n        pz: new PerspectiveCamera({ fov: 90 }),\n        nz: new PerspectiveCamera({ fov: 90 })\n    };\n    cameras.px.lookAt(Vector3.POSITIVE_X, Vector3.NEGATIVE_Y);\n    cameras.nx.lookAt(Vector3.NEGATIVE_X, Vector3.NEGATIVE_Y);\n    cameras.py.lookAt(Vector3.POSITIVE_Y, Vector3.POSITIVE_Z);\n    cameras.ny.lookAt(Vector3.NEGATIVE_Y, Vector3.NEGATIVE_Z);\n    cameras.pz.lookAt(Vector3.POSITIVE_Z, Vector3.NEGATIVE_Y);\n    cameras.nz.lookAt(Vector3.NEGATIVE_Z, Vector3.NEGATIVE_Y);\n\n    // FIXME In windows, use one framebuffer only renders one side of cubemap\n    ret._frameBuffer = new FrameBuffer();\n\n    return ret;\n},  /** @lends clay.prePass.EnvironmentMap# */ {\n    /**\n     * @param  {string} target\n     * @return  {clay.Camera}\n     */\n    getCamera: function (target) {\n        return this._cameras[target];\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Scene} scene\n     * @param  {boolean} [notUpdateScene=false]\n     */\n    render: function(renderer, scene, notUpdateScene) {\n        var _gl = renderer.gl;\n        if (!notUpdateScene) {\n            scene.update();\n        }\n        // Tweak fov\n        // http://the-witness.net/news/2012/02/seamless-cube-map-filtering/\n        var n = this.texture.width;\n        var fov = 2 * Math.atan(n / (n - 0.5)) / Math.PI * 180;\n\n        for (var i = 0; i < 6; i++) {\n            var target = targets[i];\n            var camera = this._cameras[target];\n            Vector3.copy(camera.position, this.position);\n\n            camera.far = this.far;\n            camera.near = this.near;\n            camera.fov = fov;\n\n            if (this.shadowMapPass) {\n                camera.update();\n\n                // update boundingBoxLastFrame\n                var bbox = scene.getBoundingBox();\n                bbox.applyTransform(camera.viewMatrix);\n                scene.viewBoundingBoxLastFrame.copy(bbox);\n\n                this.shadowMapPass.render(renderer, scene, camera, true);\n            }\n            this._frameBuffer.attach(\n                this.texture, _gl.COLOR_ATTACHMENT0,\n                _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i\n            );\n            this._frameBuffer.bind(renderer);\n            renderer.render(scene, camera, true);\n            this._frameBuffer.unbind(renderer);\n        }\n    },\n    /**\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._frameBuffer.dispose(renderer);\n    }\n});\n\nexport default EnvironmentMapPass;\n","import Mesh from '../Mesh';\nimport SphereGeometry from '../geometry/Sphere';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport basicEssl from '../shader/source/basic.glsl.js';\nShader.import(basicEssl);\n/**\n * @constructor clay.plugin.Skydome\n *\n * @example\n *     var skyTex = new clay.Texture2D();\n *     skyTex.load('assets/textures/sky.jpg');\n *     var skydome = new clay.plugin.Skydome({\n *         scene: scene\n *     });\n *     skydome.material.set('diffuseMap', skyTex);\n */\nvar Skydome = Mesh.extend(function () {\n\n    var skydomeShader = new Shader(Shader.source('clay.basic.vertex'), Shader.source('clay.basic.fragment'));\n\n    var material = new Material({\n        shader: skydomeShader,\n        depthMask: false\n    });\n    material.enableTexture('diffuseMap');\n\n    return {\n        /**\n         * @type {clay.Scene}\n         * @memberOf clay.plugin.Skydome#\n         */\n        scene: null,\n\n        geometry: new SphereGeometry({\n            widthSegments: 30,\n            heightSegments: 30,\n            // thetaLength: Math.PI / 2\n        }),\n\n        material: material,\n\n        environmentMap: null,\n\n        culling: false\n    };\n}, function () {\n    var scene = this.scene;\n    if (scene) {\n        this.attachScene(scene);\n    }\n\n    if (this.environmentMap) {\n        this.setEnvironmentMap(this.environmentMap);\n    }\n}, {\n    /**\n     * Attach the skybox to the scene\n     * @param  {clay.Scene} scene\n     * @memberOf clay.plugin.Skydome.prototype\n     */\n    attachScene: function (scene) {\n        if (this.scene) {\n            this.detachScene();\n        }\n        this.scene = scene;\n        scene.on('beforerender', this._beforeRenderScene, this);\n    },\n    /**\n     * Detach from scene\n     * @memberOf clay.plugin.Skydome.prototype\n     */\n    detachScene: function () {\n        if (this.scene) {\n            this.scene.off('beforerender', this._beforeRenderScene);\n        }\n        this.scene = null;\n    },\n\n    _beforeRenderScene: function (renderer, scene, camera) {\n        this.position.copy(camera.getWorldPosition());\n        this.update();\n        renderer.renderPass([this], camera);\n    },\n\n    setEnvironmentMap: function (envMap) {\n        this.material.set('diffuseMap', envMap);\n    },\n\n    getEnvironmentMap: function () {\n        return this.material.get('diffuseMap');\n    },\n\n    dispose: function (renderer) {\n        this.detachScene();\n        this.geometry.dispose(renderer);\n    }\n});\n\nexport default Skydome;\n","import Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\n\n// http://msdn.microsoft.com/en-us/library/windows/desktop/bb943991(v=vs.85).aspx\n// https://github.com/toji/webgl-texture-utils/blob/master/texture-util/dds.js\nvar DDS_MAGIC = 0x20534444;\n\nvar DDSD_CAPS = 0x1;\nvar DDSD_HEIGHT = 0x2;\nvar DDSD_WIDTH = 0x4;\nvar DDSD_PITCH = 0x8;\nvar DDSD_PIXELFORMAT = 0x1000;\nvar DDSD_MIPMAPCOUNT = 0x20000;\nvar DDSD_LINEARSIZE = 0x80000;\nvar DDSD_DEPTH = 0x800000;\n\nvar DDSCAPS_COMPLEX = 0x8;\nvar DDSCAPS_MIPMAP = 0x400000;\nvar DDSCAPS_TEXTURE = 0x1000;\n\nvar DDSCAPS2_CUBEMAP = 0x200;\nvar DDSCAPS2_CUBEMAP_POSITIVEX = 0x400;\nvar DDSCAPS2_CUBEMAP_NEGATIVEX = 0x800;\nvar DDSCAPS2_CUBEMAP_POSITIVEY = 0x1000;\nvar DDSCAPS2_CUBEMAP_NEGATIVEY = 0x2000;\nvar DDSCAPS2_CUBEMAP_POSITIVEZ = 0x4000;\nvar DDSCAPS2_CUBEMAP_NEGATIVEZ = 0x8000;\nvar DDSCAPS2_VOLUME = 0x200000;\n\nvar DDPF_ALPHAPIXELS = 0x1;\nvar DDPF_ALPHA = 0x2;\nvar DDPF_FOURCC = 0x4;\nvar DDPF_RGB = 0x40;\nvar DDPF_YUV = 0x200;\nvar DDPF_LUMINANCE = 0x20000;\n\nfunction fourCCToInt32(value) {\n    return value.charCodeAt(0) +\n        (value.charCodeAt(1) << 8) +\n        (value.charCodeAt(2) << 16) +\n        (value.charCodeAt(3) << 24);\n}\n\nfunction int32ToFourCC(value) {\n    return String.fromCharCode(\n        value & 0xff,\n        (value >> 8) & 0xff,\n        (value >> 16) & 0xff,\n        (value >> 24) & 0xff\n    );\n}\n\nvar headerLengthInt = 31; // The header length in 32 bit ints\n\nvar FOURCC_DXT1 = fourCCToInt32('DXT1');\nvar FOURCC_DXT3 = fourCCToInt32('DXT3');\nvar FOURCC_DXT5 = fourCCToInt32('DXT5');\n    // Offsets into the header array\nvar off_magic = 0;\n\nvar off_size = 1;\nvar off_flags = 2;\nvar off_height = 3;\nvar off_width = 4;\n\nvar off_mipmapCount = 7;\n\nvar off_pfFlags = 20;\nvar off_pfFourCC = 21;\n\nvar off_caps = 27;\nvar off_caps2 = 28;\nvar off_caps3 = 29;\nvar off_caps4 = 30;\n\nvar ret = {\n    parse: function(arrayBuffer, out) {\n        var header = new Int32Array(arrayBuffer, 0, headerLengthInt);\n        if (header[off_magic] !== DDS_MAGIC) {\n            return null;\n        }\n        if (!header(off_pfFlags) & DDPF_FOURCC) {\n            return null;\n        }\n\n        var fourCC = header(off_pfFourCC);\n        var width = header[off_width];\n        var height = header[off_height];\n        var isCubeMap = header[off_caps2] & DDSCAPS2_CUBEMAP;\n        var hasMipmap = header[off_flags] & DDSD_MIPMAPCOUNT;\n        var blockBytes, internalFormat;\n        switch(fourCC) {\n            case FOURCC_DXT1:\n                blockBytes = 8;\n                internalFormat = Texture.COMPRESSED_RGB_S3TC_DXT1_EXT;\n                break;\n            case FOURCC_DXT3:\n                blockBytes = 16;\n                internalFormat = Texture.COMPRESSED_RGBA_S3TC_DXT3_EXT;\n                break;\n            case FOURCC_DXT5:\n                blockBytes = 16;\n                internalFormat = Texture.COMPRESSED_RGBA_S3TC_DXT5_EXT;\n                break;\n            default:\n                return null;\n        }\n        var dataOffset = header[off_size] + 4;\n        // TODO: Suppose all face are existed\n        var faceNumber = isCubeMap ? 6 : 1;\n        var mipmapCount = 1;\n        if (hasMipmap) {\n            mipmapCount = Math.max(1, header[off_mipmapCount]);\n        }\n\n        var textures = [];\n        for (var f = 0; f < faceNumber; f++) {\n            var _width = width;\n            var _height = height;\n            textures[f] = new Texture2D({\n                width : _width,\n                height : _height,\n                format : internalFormat\n            });\n            var mipmaps = [];\n            for (var i = 0; i < mipmapCount; i++) {\n                var dataLength = Math.max(4, _width) / 4 * Math.max(4, _height) / 4 * blockBytes;\n                var byteArray = new Uint8Array(arrayBuffer, dataOffset, dataLength);\n\n                dataOffset += dataLength;\n                _width *= 0.5;\n                _height *= 0.5;\n                mipmaps[i] = byteArray;\n            }\n            textures[f].pixels = mipmaps[0];\n            if (hasMipmap) {\n                textures[f].mipmaps = mipmaps;\n            }\n        }\n        // TODO\n        // return isCubeMap ? textures : textures[0];\n        if (out) {\n            out.width = textures[0].width;\n            out.height = textures[0].height;\n            out.format = textures[0].format;\n            out.pixels = textures[0].pixels;\n            out.mipmaps = textures[0].mipmaps;\n        }\n        else {\n            return textures[0];\n        }\n    }\n};\n\nexport default ret;\n","import Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nvar toChar = String.fromCharCode;\n\nvar MINELEN = 8;\nvar MAXELEN = 0x7fff;\nfunction rgbe2float(rgbe, buffer, offset, exposure) {\n    if (rgbe[3] > 0) {\n        var f = Math.pow(2.0, rgbe[3] - 128 - 8 + exposure);\n        buffer[offset + 0] = rgbe[0] * f;\n        buffer[offset + 1] = rgbe[1] * f;\n        buffer[offset + 2] = rgbe[2] * f;\n    }\n    else {\n        buffer[offset + 0] = 0;\n        buffer[offset + 1] = 0;\n        buffer[offset + 2] = 0;\n    }\n    buffer[offset + 3] = 1.0;\n    return buffer;\n}\n\nfunction uint82string(array, offset, size) {\n    var str = '';\n    for (var i = offset; i < size; i++) {\n        str += toChar(array[i]);\n    }\n    return str;\n}\n\nfunction copyrgbe(s, t) {\n    t[0] = s[0];\n    t[1] = s[1];\n    t[2] = s[2];\n    t[3] = s[3];\n}\n\n// TODO : check\nfunction oldReadColors(scan, buffer, offset, xmax) {\n    var rshift = 0, x = 0, len = xmax;\n    while (len > 0) {\n        scan[x][0] = buffer[offset++];\n        scan[x][1] = buffer[offset++];\n        scan[x][2] = buffer[offset++];\n        scan[x][3] = buffer[offset++];\n        if (scan[x][0] === 1 && scan[x][1] === 1 && scan[x][2] === 1) {\n            // exp is count of repeated pixels\n            for (var i = (scan[x][3] << rshift) >>> 0; i > 0; i--) {\n                copyrgbe(scan[x-1], scan[x]);\n                x++;\n                len--;\n            }\n            rshift += 8;\n        } else {\n            x++;\n            len--;\n            rshift = 0;\n        }\n    }\n    return offset;\n}\n\nfunction readColors(scan, buffer, offset, xmax) {\n    if ((xmax < MINELEN) | (xmax > MAXELEN)) {\n        return oldReadColors(scan, buffer, offset, xmax);\n    }\n    var i = buffer[offset++];\n    if (i != 2) {\n        return oldReadColors(scan, buffer, offset - 1, xmax);\n    }\n    scan[0][1] = buffer[offset++];\n    scan[0][2] = buffer[offset++];\n\n    i = buffer[offset++];\n    if ((((scan[0][2] << 8) >>> 0) | i) >>> 0 !== xmax) {\n        return null;\n    }\n    for (var i = 0; i < 4; i++) {\n        for (var x = 0; x < xmax;) {\n            var code = buffer[offset++];\n            if (code > 128) {\n                code = (code & 127) >>> 0;\n                var val = buffer[offset++];\n                while (code--) {\n                    scan[x++][i] = val;\n                }\n            } else {\n                while (code--) {\n                    scan[x++][i] = buffer[offset++];\n                }\n            }\n        }\n    }\n    return offset;\n}\n\n\nvar ret = {\n    // http://www.graphics.cornell.edu/~bjw/rgbe.html\n    // Blender source\n    // http://radsite.lbl.gov/radiance/refer/Notes/picture_format.html\n    parseRGBE: function(arrayBuffer, texture, exposure) {\n        if (exposure == null) {\n            exposure = 0;\n        }\n        var data = new Uint8Array(arrayBuffer);\n        var size = data.length;\n        if (uint82string(data, 0, 2) !== '#?') {\n            return;\n        }\n        // find empty line, next line is resolution info\n        for (var i = 2; i < size; i++) {\n            if (toChar(data[i]) === '\\n' && toChar(data[i+1]) === '\\n') {\n                break;\n            }\n        }\n        if (i >= size) { // not found\n            return;\n        }\n        // find resolution info line\n        i += 2;\n        var str = '';\n        for (; i < size; i++) {\n            var _char = toChar(data[i]);\n            if (_char === '\\n') {\n                break;\n            }\n            str += _char;\n        }\n        // -Y M +X N\n        var tmp = str.split(' ');\n        var height = parseInt(tmp[1]);\n        var width = parseInt(tmp[3]);\n        if (!width || !height) {\n            return;\n        }\n\n        // read and decode actual data\n        var offset = i+1;\n        var scanline = [];\n        // memzero\n        for (var x = 0; x < width; x++) {\n            scanline[x] = [];\n            for (var j = 0; j < 4; j++) {\n                scanline[x][j] = 0;\n            }\n        }\n        var pixels = new Float32Array(width * height * 4);\n        var offset2 = 0;\n        for (var y = 0; y < height; y++) {\n            var offset = readColors(scanline, data, offset, width);\n            if (!offset) {\n                return null;\n            }\n            for (var x = 0; x < width; x++) {\n                rgbe2float(scanline[x], pixels, offset2, exposure);\n                offset2 += 4;\n            }\n        }\n\n        if (!texture) {\n            texture = new Texture2D();\n        }\n        texture.width = width;\n        texture.height = height;\n        texture.pixels = pixels;\n        // HALF_FLOAT can't use Float32Array\n        texture.type = Texture.FLOAT;\n        return texture;\n    },\n\n    parseRGBEFromPNG: function(png) {\n\n    }\n};\n\nexport default ret;\n","import Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport request from '../core/request';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport Skydome from '../plugin/Skydome';\nimport Scene from '../Scene';\n\nimport dds from './dds';\nimport hdr from './hdr';\n\n/**\n * @alias clay.util.texture\n */\nvar textureUtil = {\n    /**\n     * @param  {string|object} path\n     * @param  {object} [option]\n     * @param  {Function} [onsuccess]\n     * @param  {Function} [onerror]\n     * @return {clay.Texture}\n     */\n    loadTexture: function (path, option, onsuccess, onerror) {\n        var texture;\n        if (typeof(option) === 'function') {\n            onsuccess = option;\n            onerror = onsuccess;\n            option = {};\n        }\n        else {\n            option = option || {};\n        }\n        if (typeof(path) === 'string') {\n            if (path.match(/.hdr$/) || option.fileType === 'hdr') {\n                texture = new Texture2D({\n                    width: 0,\n                    height: 0\n                });\n                textureUtil._fetchTexture(\n                    path,\n                    function (data) {\n                        hdr.parseRGBE(data, texture, option.exposure);\n                        texture.dirty();\n                        onsuccess && onsuccess(texture);\n                    },\n                    onerror\n                );\n                return texture;\n            }\n            else if (path.match(/.dds$/) || option.fileType === 'dds') {\n                texture = new Texture2D({\n                    width: 0,\n                    height: 0\n                });\n                textureUtil._fetchTexture(\n                    path,\n                    function (data) {\n                        dds.parse(data, texture);\n                        texture.dirty();\n                        onsuccess && onsuccess(texture);\n                    },\n                    onerror\n                );\n            }\n            else {\n                texture = new Texture2D();\n                texture.load(path);\n                texture.success(onsuccess);\n                texture.error(onerror);\n            }\n        }\n        else if (typeof(path) == 'object' && typeof(path.px) !== 'undefined') {\n            var texture = new TextureCube();\n            texture.load(path);\n            texture.success(onsuccess);\n            texture.error(onerror);\n        }\n        return texture;\n    },\n\n    /**\n     * Load a panorama texture and render it to a cube map\n     * @param  {clay.Renderer} renderer\n     * @param  {string} path\n     * @param  {clay.TextureCube} cubeMap\n     * @param  {object} [option]\n     * @param  {boolean} [option.encodeRGBM]\n     * @param  {number} [option.exposure]\n     * @param  {Function} [onsuccess]\n     * @param  {Function} [onerror]\n     */\n    loadPanorama: function (renderer, path, cubeMap, option, onsuccess, onerror) {\n        var self = this;\n\n        if (typeof(option) === 'function') {\n            onsuccess = option;\n            onerror = onsuccess;\n            option = {};\n        }\n        else {\n            option = option || {};\n        }\n\n        textureUtil.loadTexture(path, option, function (texture) {\n            // PENDING\n            texture.flipY = option.flipY || false;\n            self.panoramaToCubeMap(renderer, texture, cubeMap, option);\n            texture.dispose(renderer);\n            onsuccess && onsuccess(cubeMap);\n        }, onerror);\n    },\n\n    /**\n     * Render a panorama texture to a cube map\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Texture2D} panoramaMap\n     * @param  {clay.TextureCube} cubeMap\n     * @param  {Object} option\n     * @param  {boolean} [option.encodeRGBM]\n     */\n    panoramaToCubeMap: function (renderer, panoramaMap, cubeMap, option) {\n        var environmentMapPass = new EnvironmentMapPass();\n        var skydome = new Skydome({\n            scene: new Scene()\n        });\n        skydome.material.set('diffuseMap', panoramaMap);\n\n        option = option || {};\n        if (option.encodeRGBM) {\n            skydome.material.define('fragment', 'RGBM_ENCODE');\n        }\n\n        environmentMapPass.texture = cubeMap;\n        environmentMapPass.render(renderer, skydome.scene);\n        environmentMapPass.texture = null;\n        environmentMapPass.dispose(renderer);\n        return cubeMap;\n    },\n\n    /**\n     * Convert height map to normal map\n     * @param {HTMLImageElement|HTMLCanvasElement} image\n     * @param {boolean} [checkBump=false]\n     * @return {HTMLCanvasElement}\n     */\n    heightToNormal: function (image, checkBump) {\n        var canvas = document.createElement('canvas');\n        var width = canvas.width = image.width;\n        var height = canvas.height = image.height;\n        var ctx = canvas.getContext('2d');\n        ctx.drawImage(image, 0, 0, width, height);\n        checkBump = checkBump || false;\n        var srcData = ctx.getImageData(0, 0, width, height);\n        var dstData = ctx.createImageData(width, height);\n        for (var i = 0; i < srcData.data.length; i += 4) {\n            if (checkBump) {\n                var r = srcData.data[i];\n                var g = srcData.data[i + 1];\n                var b = srcData.data[i + 2];\n                var diff = Math.abs(r - g) + Math.abs(g - b);\n                if (diff > 20) {\n                    console.warn('Given image is not a height map');\n                    return image;\n                }\n            }\n            // Modified from http://mrdoob.com/lab/javascript/height2normal/\n            var x1, y1, x2, y2;\n            if (i % (width * 4) === 0) {\n                // left edge\n                x1 = srcData.data[i];\n                x2 = srcData.data[i + 4];\n            }\n            else if (i % (width * 4) === (width - 1) * 4) {\n                // right edge\n                x1 = srcData.data[i - 4];\n                x2 = srcData.data[i];\n            }\n            else {\n                x1 = srcData.data[i - 4];\n                x2 = srcData.data[i + 4];\n            }\n\n            if (i < width * 4) {\n                // top edge\n                y1 = srcData.data[i];\n                y2 = srcData.data[i + width * 4];\n            }\n            else if (i > width * (height - 1) * 4) {\n                // bottom edge\n                y1 = srcData.data[i - width * 4];\n                y2 = srcData.data[i];\n            }\n            else {\n                y1 = srcData.data[i - width * 4];\n                y2 = srcData.data[i + width * 4];\n            }\n\n            dstData.data[i] = (x1 - x2) + 127;\n            dstData.data[i + 1] = (y1 - y2) + 127;\n            dstData.data[i + 2] = 255;\n            dstData.data[i + 3] = 255;\n        }\n        ctx.putImageData(dstData, 0, 0);\n        return canvas;\n    },\n\n    /**\n     * Convert height map to normal map\n     * @param {HTMLImageElement|HTMLCanvasElement} image\n     * @param {boolean} [checkBump=false]\n     * @param {number} [threshold=20]\n     * @return {HTMLCanvasElement}\n     */\n    isHeightImage: function (img, downScaleSize, threshold) {\n        if (!img || !img.width || !img.height) {\n            return false;\n        }\n\n        var canvas = document.createElement('canvas');\n        var ctx = canvas.getContext('2d');\n        var size = downScaleSize || 32;\n        threshold = threshold || 20;\n        canvas.width = canvas.height = size;\n        ctx.drawImage(img, 0, 0, size, size);\n        var srcData = ctx.getImageData(0, 0, size, size);\n        for (var i = 0; i < srcData.data.length; i += 4) {\n            var r = srcData.data[i];\n            var g = srcData.data[i + 1];\n            var b = srcData.data[i + 2];\n            var diff = Math.abs(r - g) + Math.abs(g - b);\n            if (diff > threshold) {\n                return false;\n            }\n        }\n        return true;\n    },\n\n    _fetchTexture: function (path, onsuccess, onerror) {\n        request.get({\n            url: path,\n            responseType: 'arraybuffer',\n            onload: onsuccess,\n            onerror: onerror\n        });\n    },\n\n    /**\n     * Create a chessboard texture\n     * @param  {number} [size]\n     * @param  {number} [unitSize]\n     * @param  {string} [color1]\n     * @param  {string} [color2]\n     * @return {clay.Texture2D}\n     */\n    createChessboard: function (size, unitSize, color1, color2) {\n        size = size || 512;\n        unitSize = unitSize || 64;\n        color1 = color1 || 'black';\n        color2 = color2 || 'white';\n\n        var repeat = Math.ceil(size / unitSize);\n\n        var canvas = document.createElement('canvas');\n        canvas.width = size;\n        canvas.height = size;\n        var ctx = canvas.getContext('2d');\n        ctx.fillStyle = color2;\n        ctx.fillRect(0, 0, size, size);\n\n        ctx.fillStyle = color1;\n        for (var i = 0; i < repeat; i++) {\n            for (var j = 0; j < repeat; j++) {\n                var isFill = j % 2 ? (i % 2) : (i % 2 - 1);\n                if (isFill) {\n                    ctx.fillRect(i * unitSize, j * unitSize, unitSize, unitSize);\n                }\n            }\n        }\n\n        var texture = new Texture2D({\n            image: canvas,\n            anisotropic: 8\n        });\n\n        return texture;\n    },\n\n    /**\n     * Create a blank pure color 1x1 texture\n     * @param  {string} color\n     * @return {clay.Texture2D}\n     */\n    createBlank: function (color) {\n        var canvas = document.createElement('canvas');\n        canvas.width = 1;\n        canvas.height = 1;\n        var ctx = canvas.getContext('2d');\n        ctx.fillStyle = color;\n        ctx.fillRect(0, 0, 1, 1);\n\n        var texture = new Texture2D({\n            image: canvas\n        });\n\n        return texture;\n    }\n};\n\nexport default textureUtil;\n","export default \"#define SAMPLE_NUMBER 1024\\n#define PI 3.14159265358979\\nuniform sampler2D normalDistribution;\\nuniform vec2 viewportSize : [512, 256];\\nconst vec3 N = vec3(0.0, 0.0, 1.0);\\nconst float fSampleNumber = float(SAMPLE_NUMBER);\\nvec3 importanceSampleNormal(float i, float roughness, vec3 N) {\\n    vec3 H = texture2D(normalDistribution, vec2(roughness, i)).rgb;\\n    vec3 upVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0);\\n    vec3 tangentX = normalize(cross(upVector, N));\\n    vec3 tangentY = cross(N, tangentX);\\n    return tangentX * H.x + tangentY * H.y + N * H.z;\\n}\\nfloat G_Smith(float roughness, float NoV, float NoL) {\\n    float k = roughness * roughness / 2.0;\\n    float G1V = NoV / (NoV * (1.0 - k) + k);\\n    float G1L = NoL / (NoL * (1.0 - k) + k);\\n    return G1L * G1V;\\n}\\nvoid main() {\\n    vec2 uv = gl_FragCoord.xy / viewportSize;\\n    float NoV = uv.x;\\n    float roughness = uv.y;\\n    vec3 V;\\n    V.x = sqrt(1.0 - NoV * NoV);\\n    V.y = 0.0;\\n    V.z = NoV;\\n    float A = 0.0;\\n    float B = 0.0;\\n    for (int i = 0; i < SAMPLE_NUMBER; i++) {\\n        vec3 H = importanceSampleNormal(float(i) / fSampleNumber, roughness, N);\\n        vec3 L = reflect(-V, H);\\n        float NoL = clamp(L.z, 0.0, 1.0);\\n        float NoH = clamp(H.z, 0.0, 1.0);\\n        float VoH = clamp(dot(V, H), 0.0, 1.0);\\n        if (NoL > 0.0) {\\n            float G = G_Smith(roughness, NoV, NoL);\\n            float G_Vis = G * VoH / (NoH * NoV);\\n            float Fc = pow(1.0 - VoH, 5.0);\\n            A += (1.0 - Fc) * G_Vis;\\n            B += Fc * G_Vis;\\n        }\\n    }\\n    gl_FragColor = vec4(vec2(A, B) / fSampleNumber, 0.0, 1.0);\\n}\\n\";\n","export default \"#define SAMPLE_NUMBER 1024\\n#define PI 3.14159265358979\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform samplerCube environmentMap;\\nuniform sampler2D normalDistribution;\\nuniform float roughness : 0.5;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_WorldPosition;\\nconst float fSampleNumber = float(SAMPLE_NUMBER);\\n@import clay.util.rgbm\\nvec3 importanceSampleNormal(float i, float roughness, vec3 N) {\\n    vec3 H = texture2D(normalDistribution, vec2(roughness, i)).rgb;\\n    vec3 upVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0);\\n    vec3 tangentX = normalize(cross(upVector, N));\\n    vec3 tangentY = cross(N, tangentX);\\n    return tangentX * H.x + tangentY * H.y + N * H.z;\\n}\\nvoid main() {\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 V = normalize(v_WorldPosition - eyePos);\\n    vec3 N = V;\\n    vec3 R = V;\\n    vec3 prefilteredColor = vec3(0.0);\\n    float totalWeight = 0.0;\\n    for (int i = 0; i < SAMPLE_NUMBER; i++) {\\n        vec3 H = importanceSampleNormal(float(i) / fSampleNumber, roughness, N);\\n        vec3 L = reflect(-V, H);\\n        float NoL = clamp(dot(N, L), 0.0, 1.0);\\n        if (NoL > 0.0) {\\n            prefilteredColor += decodeHDR(textureCube(environmentMap, L)).rgb * NoL;\\n            totalWeight += NoL;\\n        }\\n    }\\n    gl_FragColor = encodeHDR(vec4(prefilteredColor / totalWeight, 1.0));\\n}\\n\";\n","// Cubemap prefilter utility\n// http://www.unrealengine.com/files/downloads/2013SiggraphPresentationsNotes.pdf\n// http://http.developer.nvidia.com/GPUGems3/gpugems3_ch20.html\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport Texture from '../Texture';\nimport FrameBuffer from '../FrameBuffer';\nimport Pass from '../compositor/Pass';\nimport Material from '../Material';\nimport Shader from '../Shader';\nimport Skybox from '../plugin/Skybox';\nimport Scene from '../Scene';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport vendor from '../core/vendor';\nimport textureUtil from './texture';\n\nimport integrateBRDFShaderCode from './shader/integrateBRDF.glsl.js';\nimport prefilterFragCode from './shader/prefilter.glsl.js';\n\nvar cubemapUtil = {};\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * @name clay.util.cubemap.prefilterEnvironmentMap\n * @param  {clay.Renderer} renderer\n * @param  {clay.Texture} envMap\n * @param  {Object} [textureOpts]\n * @param  {number} [textureOpts.width=64]\n * @param  {number} [textureOpts.height=64]\n * @param  {number} [textureOpts.type]\n * @param  {boolean} [textureOpts.encodeRGBM=false]\n * @param  {boolean} [textureOpts.decodeRGBM=false]\n * @param  {clay.Texture2D} [normalDistribution]\n * @param  {clay.Texture2D} [brdfLookup]\n */\ncubemapUtil.prefilterEnvironmentMap = function (\n    renderer, envMap, textureOpts, normalDistribution, brdfLookup\n) {\n    // Not create other renderer, it is easy having issue of cross reference of resources like framebuffer\n    // PENDING preserveDrawingBuffer?\n    if (!brdfLookup || !normalDistribution) {\n        normalDistribution = cubemapUtil.generateNormalDistribution();\n        brdfLookup = cubemapUtil.integrateBRDF(renderer, normalDistribution);\n    }\n    textureOpts = textureOpts || {};\n\n    var width = textureOpts.width || 64;\n    var height = textureOpts.height || 64;\n\n    var textureType = textureOpts.type || envMap.type;\n\n    // Use same type with given envMap\n    var prefilteredCubeMap = new TextureCube({\n        width: width,\n        height: height,\n        type: textureType,\n        flipY: false,\n        mipmaps: []\n    });\n\n    if (!prefilteredCubeMap.isPowerOfTwo()) {\n        console.warn('Width and height must be power of two to enable mipmap.');\n    }\n\n    var size = Math.min(width, height);\n    var mipmapNum = Math.log(size) / Math.log(2) + 1;\n\n    var prefilterMaterial = new Material({\n        shader: new Shader({\n            vertex: Shader.source('clay.skybox.vertex'),\n            fragment: prefilterFragCode\n        })\n    });\n    prefilterMaterial.set('normalDistribution', normalDistribution);\n\n    textureOpts.encodeRGBM && prefilterMaterial.define('fragment', 'RGBM_ENCODE');\n    textureOpts.decodeRGBM && prefilterMaterial.define('fragment', 'RGBM_DECODE');\n\n    var dummyScene = new Scene();\n    var skyEnv;\n\n    if (envMap instanceof Texture2D) {\n        // Convert panorama to cubemap\n        var envCubemap = new TextureCube({\n            width: width,\n            height: height,\n            // FIXME FLOAT type will cause GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT error on iOS\n            type: textureType === Texture.FLOAT ?\n                    Texture.HALF_FLOAT : textureType\n        });\n        textureUtil.panoramaToCubeMap(renderer, envMap, envCubemap, {\n            // PENDING encodeRGBM so it can be decoded as RGBM\n            encodeRGBM: textureOpts.decodeRGBM\n        });\n        envMap = envCubemap;\n    }\n    skyEnv = new Skybox({\n        scene: dummyScene,\n        material: prefilterMaterial\n    });\n    skyEnv.material.set('environmentMap', envMap);\n\n    var envMapPass = new EnvironmentMapPass({\n        texture: prefilteredCubeMap\n    });\n\n    // Force to be UNSIGNED_BYTE\n    if (textureOpts.encodeRGBM) {\n        textureType = prefilteredCubeMap.type = Texture.UNSIGNED_BYTE;\n    }\n\n    var renderTargetTmp = new Texture2D({\n        width: width,\n        height: height,\n        type: textureType\n    });\n    var frameBuffer = new FrameBuffer({\n        depthBuffer: false\n    });\n    var ArrayCtor = vendor[textureType === Texture.UNSIGNED_BYTE ? 'Uint8Array' : 'Float32Array'];\n    for (var i = 0; i < mipmapNum; i++) {\n        prefilteredCubeMap.mipmaps[i] = {\n            pixels: {}\n        };\n        skyEnv.material.set('roughness', i / (targets.length - 1));\n\n        // Tweak fov\n        // http://the-witness.net/news/2012/02/seamless-cube-map-filtering/\n        var n = renderTargetTmp.width;\n        var fov = 2 * Math.atan(n / (n - 0.5)) / Math.PI * 180;\n\n        for (var j = 0; j < targets.length; j++) {\n            var pixels = new ArrayCtor(renderTargetTmp.width * renderTargetTmp.height * 4);\n            frameBuffer.attach(renderTargetTmp);\n            frameBuffer.bind(renderer);\n\n            var camera = envMapPass.getCamera(targets[j]);\n            camera.fov = fov;\n            renderer.render(dummyScene, camera);\n            renderer.gl.readPixels(\n                0, 0, renderTargetTmp.width, renderTargetTmp.height,\n                Texture.RGBA, textureType, pixels\n            );\n\n            // var canvas = document.createElement('canvas');\n            // var ctx = canvas.getContext('2d');\n            // canvas.width = renderTargetTmp.width;\n            // canvas.height = renderTargetTmp.height;\n            // var imageData = ctx.createImageData(renderTargetTmp.width, renderTargetTmp.height);\n            // for (var k = 0; k < pixels.length; k++) {\n            //     imageData.data[k] = pixels[k];\n            // }\n            // ctx.putImageData(imageData, 0, 0);\n            // document.body.appendChild(canvas);\n\n            frameBuffer.unbind(renderer);\n            prefilteredCubeMap.mipmaps[i].pixels[targets[j]] = pixels;\n        }\n\n        renderTargetTmp.width /= 2;\n        renderTargetTmp.height /= 2;\n        renderTargetTmp.dirty();\n    }\n\n    frameBuffer.dispose(renderer);\n    renderTargetTmp.dispose(renderer);\n    skyEnv.dispose(renderer);\n    // Remove gpu resource allucated in renderer\n    normalDistribution.dispose(renderer);\n\n    // renderer.dispose();\n\n    return {\n        environmentMap: prefilteredCubeMap,\n        brdfLookup: brdfLookup,\n        normalDistribution: normalDistribution,\n        maxMipmapLevel: mipmapNum\n    };\n};\n\ncubemapUtil.integrateBRDF = function (renderer, normalDistribution) {\n    normalDistribution = normalDistribution || cubemapUtil.generateNormalDistribution();\n    var framebuffer = new FrameBuffer({\n        depthBuffer: false\n    });\n    var pass = new Pass({\n        fragment: integrateBRDFShaderCode\n    });\n\n    var texture = new Texture2D({\n        width: 512,\n        height: 256,\n        type: Texture.HALF_FLOAT,\n        minFilter: Texture.NEAREST,\n        magFilter: Texture.NEAREST,\n        useMipmap: false\n    });\n    pass.setUniform('normalDistribution', normalDistribution);\n    pass.setUniform('viewportSize', [512, 256]);\n    pass.attachOutput(texture);\n    pass.render(renderer, framebuffer);\n\n    // FIXME Only chrome and firefox can readPixels with float type.\n    // framebuffer.bind(renderer);\n    // var pixels = new Float32Array(512 * 256 * 4);\n    // renderer.gl.readPixels(\n    //     0, 0, texture.width, texture.height,\n    //     Texture.RGBA, Texture.FLOAT, pixels\n    // );\n    // texture.pixels = pixels;\n    // texture.flipY = false;\n    // texture.dirty();\n    // framebuffer.unbind(renderer);\n\n    framebuffer.dispose(renderer);\n\n    return texture;\n};\n\ncubemapUtil.generateNormalDistribution = function (roughnessLevels, sampleSize) {\n\n    // http://holger.dammertz.org/stuff/notes_HammersleyOnHemisphere.html\n    // GLSL not support bit operation, use lookup instead\n    // V -> i / N, U -> roughness\n    var roughnessLevels = roughnessLevels || 256;\n    var sampleSize = sampleSize || 1024;\n\n    var normalDistribution = new Texture2D({\n        width: roughnessLevels,\n        height: sampleSize,\n        type: Texture.FLOAT,\n        minFilter: Texture.NEAREST,\n        magFilter: Texture.NEAREST,\n        useMipmap: false\n    });\n    var pixels = new Float32Array(sampleSize * roughnessLevels * 4);\n    for (var i = 0; i < sampleSize; i++) {\n        var x = i / sampleSize;\n        // http://holger.dammertz.org/stuff/notes_HammersleyOnHemisphere.html\n        // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators\n        // http://stackoverflow.com/questions/1908492/unsigned-integer-in-javascript\n        // http://stackoverflow.com/questions/1822350/what-is-the-javascript-operator-and-how-do-you-use-it\n        var y = (i << 16 | i >>> 16) >>> 0;\n        y = ((y & 1431655765) << 1 | (y & 2863311530) >>> 1) >>> 0;\n        y = ((y & 858993459) << 2 | (y & 3435973836) >>> 2) >>> 0;\n        y = ((y & 252645135) << 4 | (y & 4042322160) >>> 4) >>> 0;\n        y = (((y & 16711935) << 8 | (y & 4278255360) >>> 8) >>> 0) / 4294967296;\n\n        for (var j = 0; j < roughnessLevels; j++) {\n            var roughness = j / roughnessLevels;\n            var a = roughness * roughness;\n            var phi = 2.0 * Math.PI * x;\n            // CDF\n            var cosTheta = Math.sqrt((1 - y) / (1 + (a * a - 1.0) * y));\n            var sinTheta = Math.sqrt(1.0 - cosTheta * cosTheta);\n            var offset = (i * roughnessLevels + j) * 4;\n            pixels[offset] = sinTheta * Math.cos(phi);\n            pixels[offset + 1] = sinTheta * Math.sin(phi);\n            pixels[offset + 2] = cosTheta;\n            pixels[offset + 3] = 1.0;\n        }\n    }\n    normalDistribution.pixels = pixels;\n\n    return normalDistribution;\n};\n\nexport default cubemapUtil;\n","// https://docs.unrealengine.com/latest/INT/Engine/Rendering/LightingAndShadows/AmbientCubemap/\nimport Light from '../Light';\nimport cubemapUtil from '../util/cubemap';\n\n/**\n * Ambient cubemap light provides specular parts of Image Based Lighting.\n * Which is a basic requirement for Physically Based Rendering\n * @constructor clay.light.AmbientCubemap\n * @extends clay.Light\n */\nvar AmbientCubemapLight = Light.extend({\n\n    /**\n     * @type {clay.TextureCube}\n     * @memberOf clay.light.AmbientCubemap#\n     */\n    cubemap: null,\n\n    // TODO\n    // range: 100,\n\n    castShadow: false,\n\n    _normalDistribution: null,\n    _brdfLookup: null\n\n}, /** @lends clay.light.AmbientCubemap# */ {\n\n    type: 'AMBIENT_CUBEMAP_LIGHT',\n\n    /**\n     * Do prefitering the cubemap\n     * @param {clay.Renderer} renderer\n     * @param {number} [size=32]\n     */\n    prefilter: function (renderer, size) {\n        if (!this._brdfLookup) {\n            this._normalDistribution = cubemapUtil.generateNormalDistribution();\n            this._brdfLookup = cubemapUtil.integrateBRDF(renderer, this._normalDistribution);\n        }\n        var cubemap = this.cubemap;\n        if (cubemap.__prefiltered) {\n            return;\n        }\n\n        var result = cubemapUtil.prefilterEnvironmentMap(\n            renderer, cubemap, {\n                encodeRGBM: true,\n                width: size,\n                height: size\n            }, this._normalDistribution, this._brdfLookup\n        );\n        this.cubemap = result.environmentMap;\n        this.cubemap.__prefiltered = true;\n\n        cubemap.dispose(renderer);\n    },\n\n    uniformTemplates: {\n        ambientCubemapLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        },\n\n        ambientCubemapLightCubemap: {\n            type: 't',\n            value: function (instance) {\n                return instance.cubemap;\n            }\n        },\n\n        ambientCubemapLightBRDFLookup: {\n            type: 't',\n            value: function (instance) {\n                return instance._brdfLookup;\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.AmbientCubemap}\n     * @memberOf clay.light.AmbientCubemap.prototype\n     */\n});\n\nexport default AmbientCubemapLight;\n","import Light from '../Light';\nimport vendor from '../core/vendor';\n\n/**\n * Spherical Harmonic Ambient Light\n * @constructor clay.light.AmbientSH\n * @extends clay.Light\n */\nvar AmbientSHLight = Light.extend({\n\n    castShadow: false,\n\n    /**\n     * Spherical Harmonic Coefficients\n     * @type {Array.<number>}\n     * @memberOf clay.light.AmbientSH#\n     */\n    coefficients: [],\n\n}, function () {\n    this._coefficientsTmpArr = new vendor.Float32Array(9 * 3);\n}, {\n\n    type: 'AMBIENT_SH_LIGHT',\n\n    uniformTemplates: {\n        ambientSHLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        },\n\n        ambientSHLightCoefficients: {\n            type: '3f',\n            value: function (instance) {\n                var coefficientsTmpArr = instance._coefficientsTmpArr;\n                for (var i = 0; i < instance.coefficients.length; i++) {\n                    coefficientsTmpArr[i] = instance.coefficients[i];\n                }\n                return coefficientsTmpArr;\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.Ambient}\n     * @memberOf clay.light.Ambient.prototype\n     */\n});\n\nexport default AmbientSHLight;\n","import Texture2D from '../Texture2D';\nimport glenum from '../core/glenum';\nimport util from '../core/util';\n\nvar TexturePool = function () {\n\n    this._pool = {};\n\n    this._allocatedTextures = [];\n};\n\nTexturePool.prototype = {\n\n    constructor: TexturePool,\n\n    get: function (parameters) {\n        var key = generateKey(parameters);\n        if (!this._pool.hasOwnProperty(key)) {\n            this._pool[key] = [];\n        }\n        var list = this._pool[key];\n        if (!list.length) {\n            var texture = new Texture2D(parameters);\n            this._allocatedTextures.push(texture);\n            return texture;\n        }\n        return list.pop();\n    },\n\n    put: function (texture) {\n        var key = generateKey(texture);\n        if (!this._pool.hasOwnProperty(key)) {\n            this._pool[key] = [];\n        }\n        var list = this._pool[key];\n        list.push(texture);\n    },\n\n    clear: function (renderer) {\n        for (var i = 0; i < this._allocatedTextures.length; i++) {\n            this._allocatedTextures[i].dispose(renderer);\n        }\n        this._pool = {};\n        this._allocatedTextures = [];\n    }\n};\n\nvar defaultParams = {\n    width: 512,\n    height: 512,\n    type: glenum.UNSIGNED_BYTE,\n    format: glenum.RGBA,\n    wrapS: glenum.CLAMP_TO_EDGE,\n    wrapT: glenum.CLAMP_TO_EDGE,\n    minFilter: glenum.LINEAR_MIPMAP_LINEAR,\n    magFilter: glenum.LINEAR,\n    useMipmap: true,\n    anisotropic: 1,\n    flipY: true,\n    unpackAlignment: 4,\n    premultiplyAlpha: false\n};\n\nvar defaultParamPropList = Object.keys(defaultParams);\n\nfunction generateKey(parameters) {\n    util.defaultsWithPropList(parameters, defaultParams, defaultParamPropList);\n    fallBack(parameters);\n\n    var key = '';\n    for (var i = 0; i < defaultParamPropList.length; i++) {\n        var name = defaultParamPropList[i];\n        var chunk = parameters[name].toString();\n        key += chunk;\n    }\n    return key;\n}\n\nfunction fallBack(target) {\n\n    var IPOT = isPowerOfTwo(target.width, target.height);\n\n    if (target.format === glenum.DEPTH_COMPONENT) {\n        target.useMipmap = false;\n    }\n\n    if (!IPOT || !target.useMipmap) {\n        if (target.minFilter == glenum.NEAREST_MIPMAP_NEAREST ||\n            target.minFilter == glenum.NEAREST_MIPMAP_LINEAR) {\n            target.minFilter = glenum.NEAREST;\n        } else if (\n            target.minFilter == glenum.LINEAR_MIPMAP_LINEAR ||\n            target.minFilter == glenum.LINEAR_MIPMAP_NEAREST\n        ) {\n            target.minFilter = glenum.LINEAR;\n        }\n    }\n    if (!IPOT) {\n        target.wrapS = glenum.CLAMP_TO_EDGE;\n        target.wrapT = glenum.CLAMP_TO_EDGE;\n    }\n}\n\nfunction isPowerOfTwo(width, height) {\n    return (width & (width-1)) === 0 &&\n            (height & (height-1)) === 0;\n}\n\nexport default TexturePool;\n","export default \"@export clay.sm.depth.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n#ifdef SHADOW_TRANSPARENT\\nattribute vec2 texcoord : TEXCOORD_0;\\n#endif\\n@import clay.chunk.skinning_header\\nvarying vec4 v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\nvarying vec2 v_Texcoord;\\n#endif\\nvoid main(){\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    v_ViewPosition = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    gl_Position = v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\n    v_Texcoord = texcoord;\\n#endif\\n}\\n@end\\n@export clay.sm.depth.fragment\\nvarying vec4 v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\nvarying vec2 v_Texcoord;\\n#endif\\nuniform float bias : 0.001;\\nuniform float slopeScale : 1.0;\\n#ifdef SHADOW_TRANSPARENT\\nuniform sampler2D transparentMap;\\n#endif\\n@import clay.util.encode_float\\nvoid main(){\\n    float depth = v_ViewPosition.z / v_ViewPosition.w;\\n#ifdef USE_VSM\\n    depth = depth * 0.5 + 0.5;\\n    float moment1 = depth;\\n    float moment2 = depth * depth;\\n    float dx = dFdx(depth);\\n    float dy = dFdy(depth);\\n    moment2 += 0.25*(dx*dx+dy*dy);\\n    gl_FragColor = vec4(moment1, moment2, 0.0, 1.0);\\n#else\\n    float dx = dFdx(depth);\\n    float dy = dFdy(depth);\\n    depth += sqrt(dx*dx + dy*dy) * slopeScale + bias;\\n#ifdef SHADOW_TRANSPARENT\\n    if (texture2D(transparentMap, v_Texcoord).a <= 0.1) {\\n        gl_FragColor = encodeFloat(0.9999);\\n        return;\\n    }\\n#endif\\n    gl_FragColor = encodeFloat(depth * 0.5 + 0.5);\\n#endif\\n}\\n@end\\n@export clay.sm.debug_depth\\nuniform sampler2D depthMap;\\nvarying vec2 v_Texcoord;\\n@import clay.util.decode_float\\nvoid main() {\\n    vec4 tex = texture2D(depthMap, v_Texcoord);\\n#ifdef USE_VSM\\n    gl_FragColor = vec4(tex.rgb, 1.0);\\n#else\\n    float depth = decodeFloat(tex);\\n    gl_FragColor = vec4(depth, depth, depth, 1.0);\\n#endif\\n}\\n@end\\n@export clay.sm.distance.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 world : WORLD;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvarying vec3 v_WorldPosition;\\nvoid main (){\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition , 1.0);\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n}\\n@end\\n@export clay.sm.distance.fragment\\nuniform vec3 lightPosition;\\nuniform float range : 100;\\nvarying vec3 v_WorldPosition;\\n@import clay.util.encode_float\\nvoid main(){\\n    float dist = distance(lightPosition, v_WorldPosition);\\n#ifdef USE_VSM\\n    gl_FragColor = vec4(dist, dist * dist, 0.0, 0.0);\\n#else\\n    dist = dist / range;\\n    gl_FragColor = encodeFloat(dist);\\n#endif\\n}\\n@end\\n@export clay.plugin.shadow_map_common\\n@import clay.util.decode_float\\nfloat tapShadowMap(sampler2D map, vec2 uv, float z){\\n    vec4 tex = texture2D(map, uv);\\n    return step(z, decodeFloat(tex) * 2.0 - 1.0);\\n}\\nfloat pcf(sampler2D map, vec2 uv, float z, float textureSize, vec2 scale) {\\n    float shadowContrib = tapShadowMap(map, uv, z);\\n    vec2 offset = vec2(1.0 / textureSize) * scale;\\n#ifdef PCF_KERNEL_SIZE\\n    for (int _idx_ = 0; _idx_ < PCF_KERNEL_SIZE; _idx_++) {{\\n        shadowContrib += tapShadowMap(map, uv + offset * pcfKernel[_idx_], z);\\n    }}\\n    return shadowContrib / float(PCF_KERNEL_SIZE + 1);\\n#else\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, 0.0), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(0.0, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, 0.0), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, -offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, -offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(0.0, -offset.y), z);\\n    return shadowContrib / 9.0;\\n#endif\\n}\\nfloat pcf(sampler2D map, vec2 uv, float z, float textureSize) {\\n    return pcf(map, uv, z, textureSize, vec2(1.0));\\n}\\nfloat chebyshevUpperBound(vec2 moments, float z){\\n    float p = 0.0;\\n    z = z * 0.5 + 0.5;\\n    if (z <= moments.x) {\\n        p = 1.0;\\n    }\\n    float variance = moments.y - moments.x * moments.x;\\n    variance = max(variance, 0.0000001);\\n    float mD = moments.x - z;\\n    float pMax = variance / (variance + mD * mD);\\n    pMax = clamp((pMax-0.4)/(1.0-0.4), 0.0, 1.0);\\n    return max(p, pMax);\\n}\\nfloat computeShadowContrib(\\n    sampler2D map, mat4 lightVPM, vec3 position, float textureSize, vec2 scale, vec2 offset\\n) {\\n    vec4 posInLightSpace = lightVPM * vec4(position, 1.0);\\n    posInLightSpace.xyz /= posInLightSpace.w;\\n    float z = posInLightSpace.z;\\n    if(all(greaterThan(posInLightSpace.xyz, vec3(-0.99, -0.99, -1.0))) &&\\n        all(lessThan(posInLightSpace.xyz, vec3(0.99, 0.99, 1.0)))){\\n        vec2 uv = (posInLightSpace.xy+1.0) / 2.0;\\n        #ifdef USE_VSM\\n            vec2 moments = texture2D(map, uv * scale + offset).xy;\\n            return chebyshevUpperBound(moments, z);\\n        #else\\n            return pcf(map, uv * scale + offset, z, textureSize, scale);\\n        #endif\\n    }\\n    return 1.0;\\n}\\nfloat computeShadowContrib(sampler2D map, mat4 lightVPM, vec3 position, float textureSize) {\\n    return computeShadowContrib(map, lightVPM, position, textureSize, vec2(1.0), vec2(0.0));\\n}\\nfloat computeShadowContribOmni(samplerCube map, vec3 direction, float range)\\n{\\n    float dist = length(direction);\\n    vec4 shadowTex = textureCube(map, direction);\\n#ifdef USE_VSM\\n    vec2 moments = shadowTex.xy;\\n    float variance = moments.y - moments.x * moments.x;\\n    float mD = moments.x - dist;\\n    float p = variance / (variance + mD * mD);\\n    if(moments.x + 0.001 < dist){\\n        return clamp(p, 0.0, 1.0);\\n    }else{\\n        return 1.0;\\n    }\\n#else\\n    return step(dist, (decodeFloat(shadowTex) + 0.0002) * range);\\n#endif\\n}\\n@end\\n@export clay.plugin.compute_shadow_map\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT) || defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT) || defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n#ifdef SPOT_LIGHT_SHADOWMAP_COUNT\\nuniform sampler2D spotLightShadowMaps[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform mat4 spotLightMatrices[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform float spotLightShadowMapSizes[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_SHADOWMAP_COUNT\\n#if defined(SHADOW_CASCADE)\\nuniform sampler2D directionalLightShadowMaps[1]:unconfigurable;\\nuniform mat4 directionalLightMatrices[SHADOW_CASCADE]:unconfigurable;\\nuniform float directionalLightShadowMapSizes[1]:unconfigurable;\\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE]:unconfigurable;\\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE]:unconfigurable;\\n#else\\nuniform sampler2D directionalLightShadowMaps[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform mat4 directionalLightMatrices[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform float directionalLightShadowMapSizes[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\n#endif\\n#ifdef POINT_LIGHT_SHADOWMAP_COUNT\\nuniform samplerCube pointLightShadowMaps[POINT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\nuniform bool shadowEnabled : true;\\n#ifdef PCF_KERNEL_SIZE\\nuniform vec2 pcfKernel[PCF_KERNEL_SIZE];\\n#endif\\n@import clay.plugin.shadow_map_common\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\nvoid computeShadowOfSpotLights(vec3 position, inout float shadowContribs[SPOT_LIGHT_COUNT] ) {\\n    float shadowContrib;\\n    for(int _idx_ = 0; _idx_ < SPOT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        shadowContrib = computeShadowContrib(\\n            spotLightShadowMaps[_idx_], spotLightMatrices[_idx_], position,\\n            spotLightShadowMapSizes[_idx_]\\n        );\\n        shadowContribs[_idx_] = shadowContrib;\\n    }}\\n    for(int _idx_ = SPOT_LIGHT_SHADOWMAP_COUNT; _idx_ < SPOT_LIGHT_COUNT; _idx_++){{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n#ifdef SHADOW_CASCADE\\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\\n    float depth = (2.0 * gl_FragCoord.z - gl_DepthRange.near - gl_DepthRange.far)\\n                    / (gl_DepthRange.far - gl_DepthRange.near);\\n    float shadowContrib;\\n    shadowContribs[0] = 1.0;\\n    for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\\n        if (\\n            depth >= shadowCascadeClipsNear[_idx_] &&\\n            depth <= shadowCascadeClipsFar[_idx_]\\n        ) {\\n            shadowContrib = computeShadowContrib(\\n                directionalLightShadowMaps[0], directionalLightMatrices[_idx_], position,\\n                directionalLightShadowMapSizes[0],\\n                vec2(1.0 / float(SHADOW_CASCADE), 1.0),\\n                vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\\n            );\\n            shadowContribs[0] = shadowContrib;\\n        }\\n    }}\\n    for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#else\\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\\n    float shadowContrib;\\n    for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        shadowContrib = computeShadowContrib(\\n            directionalLightShadowMaps[_idx_], directionalLightMatrices[_idx_], position,\\n            directionalLightShadowMapSizes[_idx_]\\n        );\\n        shadowContribs[_idx_] = shadowContrib;\\n    }}\\n    for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#endif\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\nvoid computeShadowOfPointLights(vec3 position, inout float shadowContribs[POINT_LIGHT_COUNT] ){\\n    vec3 lightPosition;\\n    vec3 direction;\\n    for(int _idx_ = 0; _idx_ < POINT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        lightPosition = pointLightPosition[_idx_];\\n        direction = position - lightPosition;\\n        shadowContribs[_idx_] = computeShadowContribOmni(pointLightShadowMaps[_idx_], direction, pointLightRange[_idx_]);\\n    }}\\n    for(int _idx_ = POINT_LIGHT_SHADOWMAP_COUNT; _idx_ < POINT_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#endif\\n@end\";\n","import Base from '../core/Base';\nimport glenum from '../core/glenum';\nimport Vector3 from '../math/Vector3';\nimport BoundingBox from '../math/BoundingBox';\nimport Frustum from '../math/Frustum';\nimport Matrix4 from '../math/Matrix4';\nimport Renderer from '../Renderer';\nimport Shader from '../Shader';\nimport Light from '../Light';\nimport Mesh from '../Mesh';\nimport SpotLight from '../light/Spot';\nimport DirectionalLight from '../light/Directional';\nimport PointLight from '../light/Point';\nimport shaderLibrary from '../shader/library';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport PerspectiveCamera from '../camera/Perspective';\nimport OrthoCamera from '../camera/Orthographic';\n\nimport Pass from '../compositor/Pass';\nimport TexturePool from '../compositor/TexturePool';\n\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\nimport shadowmapEssl from '../shader/source/shadowmap.glsl.js';\nShader['import'](shadowmapEssl);\n\n/**\n * Pass rendering shadow map.\n *\n * @constructor clay.prePass.ShadowMap\n * @extends clay.core.Base\n * @example\n *     var shadowMapPass = new clay.prePass.ShadowMap({\n *         softShadow: clay.prePass.ShadowMap.VSM\n *     });\n *     ...\n *     animation.on('frame', function (frameTime) {\n *         shadowMapPass.render(renderer, scene, camera);\n *         renderer.render(scene, camera);\n *     });\n */\nvar ShadowMapPass = Base.extend(function () {\n    return /** @lends clay.prePass.ShadowMap# */ {\n        /**\n         * Soft shadow technique.\n         * Can be {@link clay.prePass.ShadowMap.PCF} or {@link clay.prePass.ShadowMap.VSM}\n         * @type {number}\n         */\n        softShadow: ShadowMapPass.PCF,\n\n        /**\n         * Soft shadow blur size\n         * @type {number}\n         */\n        shadowBlur: 1.0,\n\n        lightFrustumBias: 'auto',\n\n        kernelPCF: new Float32Array([\n            1, 0,\n            1, 1,\n            -1, 1,\n            0, 1,\n            -1, 0,\n            -1, -1,\n            1, -1,\n            0, -1\n        ]),\n\n        precision: 'mediump',\n\n        _lastRenderNotCastShadow: false,\n\n        _frameBuffer: new FrameBuffer(),\n\n        _textures: {},\n        _shadowMapNumber: {\n            'POINT_LIGHT': 0,\n            'DIRECTIONAL_LIGHT': 0,\n            'SPOT_LIGHT': 0\n        },\n\n        _depthMaterials: {},\n        _distanceMaterials: {},\n\n        _opaqueCasters: [],\n        _receivers: [],\n        _lightsCastShadow: [],\n\n        _lightCameras: {},\n        _lightMaterials: {},\n\n        _texturePool: new TexturePool()\n    };\n}, function () {\n    // Gaussian filter pass for VSM\n    this._gaussianPassH = new Pass({\n        fragment: Shader.source('clay.compositor.gaussian_blur')\n    });\n    this._gaussianPassV = new Pass({\n        fragment: Shader.source('clay.compositor.gaussian_blur')\n    });\n    this._gaussianPassH.setUniform('blurSize', this.shadowBlur);\n    this._gaussianPassH.setUniform('blurDir', 0.0);\n    this._gaussianPassV.setUniform('blurSize', this.shadowBlur);\n    this._gaussianPassV.setUniform('blurDir', 1.0);\n\n    this._outputDepthPass = new Pass({\n        fragment: Shader.source('clay.sm.debug_depth')\n    });\n}, {\n    /**\n     * Render scene to shadow textures\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Scene} scene\n     * @param  {clay.Camera} sceneCamera\n     * @param  {boolean} [notUpdateScene=false]\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    render: function (renderer, scene, sceneCamera, notUpdateScene) {\n        if (!sceneCamera) {\n            sceneCamera = scene.getMainCamera();\n        }\n        this.trigger('beforerender', this, renderer, scene, sceneCamera);\n        this._renderShadowPass(renderer, scene, sceneCamera, notUpdateScene);\n        this.trigger('afterrender', this, renderer, scene, sceneCamera);\n    },\n\n    /**\n     * Debug rendering of shadow textures\n     * @param  {clay.Renderer} renderer\n     * @param  {number} size\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    renderDebug: function (renderer, size) {\n        renderer.saveClear();\n        var viewport = renderer.viewport;\n        var x = 0, y = 0;\n        var width = size || viewport.width / 4;\n        var height = width;\n        if (this.softShadow === ShadowMapPass.VSM) {\n            this._outputDepthPass.material.define('fragment', 'USE_VSM');\n        }\n        else {\n            this._outputDepthPass.material.undefine('fragment', 'USE_VSM');\n        }\n        for (var name in this._textures) {\n            var texture = this._textures[name];\n            renderer.setViewport(x, y, width * texture.width / texture.height, height);\n            this._outputDepthPass.setUniform('depthMap', texture);\n            this._outputDepthPass.render(renderer);\n            x += width * texture.width / texture.height;\n        }\n        renderer.setViewport(viewport);\n        renderer.restoreClear();\n    },\n\n    _updateCasterAndReceiver: function (renderer, mesh) {\n        if (mesh.castShadow) {\n            this._opaqueCasters.push(mesh);\n        }\n        if (mesh.receiveShadow) {\n            this._receivers.push(mesh);\n            mesh.material.set('shadowEnabled', 1);\n\n            mesh.material.set('pcfKernel', this.kernelPCF);\n        }\n        else {\n            mesh.material.set('shadowEnabled', 0);\n        }\n\n        if (!mesh.material.shader && mesh.material.updateShader) {\n            mesh.material.updateShader(renderer);\n        }\n        if (this.softShadow === ShadowMapPass.VSM) {\n            mesh.material.define('fragment', 'USE_VSM');\n            mesh.material.undefine('fragment', 'PCF_KERNEL_SIZE');\n        }\n        else {\n            mesh.material.undefine('fragment', 'USE_VSM');\n            var kernelPCF = this.kernelPCF;\n            if (kernelPCF && kernelPCF.length) {\n                mesh.material.define('fragment', 'PCF_KERNEL_SIZE', kernelPCF.length / 2);\n            }\n            else {\n                mesh.material.undefine('fragment', 'PCF_KERNEL_SIZE');\n            }\n        }\n    },\n\n    _update: function (renderer, scene) {\n        for (var i = 0; i < scene.opaqueList.length; i++) {\n            this._updateCasterAndReceiver(renderer, scene.opaqueList[i]);\n        }\n        for (var i = 0; i < scene.transparentList.length; i++) {\n            // TODO Transparent object receive shadow will be very slow\n            // in stealth demo, still not find the reason\n            this._updateCasterAndReceiver(renderer, scene.transparentList[i]);\n        }\n        for (var i = 0; i < scene.lights.length; i++) {\n            var light = scene.lights[i];\n            if (light.castShadow) {\n                this._lightsCastShadow.push(light);\n            }\n        }\n    },\n\n    _renderShadowPass: function (renderer, scene, sceneCamera, notUpdateScene) {\n        // reset\n        for (var name in this._shadowMapNumber) {\n            this._shadowMapNumber[name] = 0;\n        }\n        this._lightsCastShadow.length = 0;\n        this._opaqueCasters.length = 0;\n        this._receivers.length = 0;\n\n        var _gl = renderer.gl;\n\n        if (!notUpdateScene) {\n            scene.update();\n        }\n        if (sceneCamera) {\n            sceneCamera.update();\n        }\n\n        this._update(renderer, scene);\n\n        // Needs to update the receivers again if shadows come from 1 to 0.\n        if (!this._lightsCastShadow.length && this._lastRenderNotCastShadow) {\n            return;\n        }\n\n        this._lastRenderNotCastShadow = this._lightsCastShadow === 0;\n\n        _gl.enable(_gl.DEPTH_TEST);\n        _gl.depthMask(true);\n        _gl.disable(_gl.BLEND);\n\n        // Clear with high-z, so the part not rendered will not been shadowed\n        // TODO\n        // TODO restore\n        _gl.clearColor(1.0, 1.0, 1.0, 1.0);\n\n        // Shadow uniforms\n        var spotLightShadowMaps = [];\n        var spotLightMatrices = [];\n        var directionalLightShadowMaps = [];\n        var directionalLightMatrices = [];\n        var shadowCascadeClips = [];\n        var pointLightShadowMaps = [];\n\n        var dirLightHasCascade;\n        // Create textures for shadow map\n        for (var i = 0; i < this._lightsCastShadow.length; i++) {\n            var light = this._lightsCastShadow[i];\n            if (light instanceof DirectionalLight) {\n\n                if (dirLightHasCascade) {\n                    console.warn('Only one direectional light supported with shadow cascade');\n                    continue;\n                }\n                if (light.shadowCascade > 4) {\n                    console.warn('Support at most 4 cascade');\n                    continue;\n                }\n                if (light.shadowCascade > 1) {\n                    dirLightHasCascade = light.shadowCascade;\n                }\n\n                this.renderDirectionalLightShadow(\n                    renderer,\n                    scene,\n                    sceneCamera,\n                    light,\n                    this._opaqueCasters,\n                    shadowCascadeClips,\n                    directionalLightMatrices,\n                    directionalLightShadowMaps\n                );\n            }\n            else if (light instanceof SpotLight) {\n                this.renderSpotLightShadow(\n                    renderer,\n                    scene,\n                    light,\n                    this._opaqueCasters,\n                    spotLightMatrices,\n                    spotLightShadowMaps\n                );\n            }\n            else if (light instanceof PointLight) {\n                this.renderPointLightShadow(\n                    renderer,\n                    scene,\n                    light,\n                    this._opaqueCasters,\n                    pointLightShadowMaps\n                );\n            }\n\n            this._shadowMapNumber[light.type]++;\n        }\n\n        for (var lightType in this._shadowMapNumber) {\n            var number = this._shadowMapNumber[lightType];\n            var key = lightType + '_SHADOWMAP_COUNT';\n            for (var i = 0; i < this._receivers.length; i++) {\n                var mesh = this._receivers[i];\n                var material = mesh.material;\n                if (material.fragmentDefines[key] !== number) {\n                    if (number > 0) {\n                        material.define('fragment', key, number);\n                    }\n                    else if (material.isDefined('fragment', key)) {\n                        material.undefine('fragment', key);\n                    }\n                }\n            }\n        }\n        for (var i = 0; i < this._receivers.length; i++) {\n            var mesh = this._receivers[i];\n            var material = mesh.material;\n            if (dirLightHasCascade) {\n                material.define('fragment', 'SHADOW_CASCADE', dirLightHasCascade.shadowCascade);\n            }\n            else {\n                material.undefine('fragment', 'SHADOW_CASCADE');\n            }\n        }\n\n        var shadowUniforms = scene.shadowUniforms;\n\n        function getSize(texture) {\n            return texture.height;\n        }\n        if (directionalLightShadowMaps.length > 0) {\n            var directionalLightShadowMapSizes = directionalLightShadowMaps.map(getSize);\n            shadowUniforms.directionalLightShadowMaps = { value: directionalLightShadowMaps, type: 'tv' };\n            shadowUniforms.directionalLightMatrices = { value: directionalLightMatrices, type: 'm4v' };\n            shadowUniforms.directionalLightShadowMapSizes = { value: directionalLightShadowMapSizes, type: '1fv' };\n            if (dirLightHasCascade) {\n                var shadowCascadeClipsNear = shadowCascadeClips.slice();\n                var shadowCascadeClipsFar = shadowCascadeClips.slice();\n                shadowCascadeClipsNear.pop();\n                shadowCascadeClipsFar.shift();\n\n                // Iterate from far to near\n                shadowCascadeClipsNear.reverse();\n                shadowCascadeClipsFar.reverse();\n                // directionalLightShadowMaps.reverse();\n                directionalLightMatrices.reverse();\n                shadowUniforms.shadowCascadeClipsNear = { value: shadowCascadeClipsNear, type: '1fv' };\n                shadowUniforms.shadowCascadeClipsFar = { value: shadowCascadeClipsFar, type: '1fv' };\n            }\n        }\n\n        if (spotLightShadowMaps.length > 0) {\n            var spotLightShadowMapSizes = spotLightShadowMaps.map(getSize);\n            var shadowUniforms = scene.shadowUniforms;\n            shadowUniforms.spotLightShadowMaps = { value: spotLightShadowMaps, type: 'tv' };\n            shadowUniforms.spotLightMatrices = { value: spotLightMatrices, type: 'm4v' };\n            shadowUniforms.spotLightShadowMapSizes = { value: spotLightShadowMapSizes, type: '1fv' };\n        }\n\n        if (pointLightShadowMaps.length > 0) {\n            shadowUniforms.pointLightShadowMaps = { value: pointLightShadowMaps, type: 'tv' };\n        }\n    },\n\n    renderDirectionalLightShadow: (function () {\n\n        var splitFrustum = new Frustum();\n        var splitProjMatrix = new Matrix4();\n        var cropBBox = new BoundingBox();\n        var cropMatrix = new Matrix4();\n        var lightViewMatrix = new Matrix4();\n        var lightViewProjMatrix = new Matrix4();\n        var lightProjMatrix = new Matrix4();\n\n        return function (renderer, scene, sceneCamera, light, casters, shadowCascadeClips, directionalLightMatrices, directionalLightShadowMaps) {\n\n            var defaultShadowMaterial = this._getDepthMaterial(light);\n            var passConfig = {\n                getMaterial: function (renderable) {\n                    return renderable.shadowDepthMaterial || defaultShadowMaterial;\n                },\n                sortCompare: Renderer.opaqueSortCompare\n            };\n\n            // First frame\n            if (!scene.viewBoundingBoxLastFrame.isFinite()) {\n                var boundingBox = scene.getBoundingBox();\n                scene.viewBoundingBoxLastFrame\n                    .copy(boundingBox).applyTransform(sceneCamera.viewMatrix);\n            }\n            // Considering moving speed since the bounding box is from last frame\n            // TODO: add a bias\n            var clippedFar = Math.min(-scene.viewBoundingBoxLastFrame.min.z, sceneCamera.far);\n            var clippedNear = Math.max(-scene.viewBoundingBoxLastFrame.max.z, sceneCamera.near);\n\n            var lightCamera = this._getDirectionalLightCamera(light, scene, sceneCamera);\n\n            var lvpMat4Arr = lightViewProjMatrix.array;\n            lightProjMatrix.copy(lightCamera.projectionMatrix);\n            mat4.invert(lightViewMatrix.array, lightCamera.worldTransform.array);\n            mat4.multiply(lightViewMatrix.array, lightViewMatrix.array, sceneCamera.worldTransform.array);\n            mat4.multiply(lvpMat4Arr, lightProjMatrix.array, lightViewMatrix.array);\n\n            var clipPlanes = [];\n            var isPerspective = sceneCamera instanceof PerspectiveCamera;\n\n            var scaleZ = (sceneCamera.near + sceneCamera.far) / (sceneCamera.near - sceneCamera.far);\n            var offsetZ = 2 * sceneCamera.near * sceneCamera.far / (sceneCamera.near - sceneCamera.far);\n            for (var i = 0; i <= light.shadowCascade; i++) {\n                var clog = clippedNear * Math.pow(clippedFar / clippedNear, i / light.shadowCascade);\n                var cuni = clippedNear + (clippedFar - clippedNear) * i / light.shadowCascade;\n                var c = clog * light.cascadeSplitLogFactor + cuni * (1 - light.cascadeSplitLogFactor);\n                clipPlanes.push(c);\n                shadowCascadeClips.push(-(-c * scaleZ + offsetZ) / -c);\n            }\n            var texture = this._getTexture(light, light.shadowCascade);\n            directionalLightShadowMaps.push(texture);\n\n            var viewport = renderer.viewport;\n\n            var _gl = renderer.gl;\n            this._frameBuffer.attach(texture);\n            this._frameBuffer.bind(renderer);\n            _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n            for (var i = 0; i < light.shadowCascade; i++) {\n                // Get the splitted frustum\n                var nearPlane = clipPlanes[i];\n                var farPlane = clipPlanes[i + 1];\n                if (isPerspective) {\n                    mat4.perspective(splitProjMatrix.array, sceneCamera.fov / 180 * Math.PI, sceneCamera.aspect, nearPlane, farPlane);\n                }\n                else {\n                    mat4.ortho(\n                        splitProjMatrix.array,\n                        sceneCamera.left, sceneCamera.right, sceneCamera.bottom, sceneCamera.top,\n                        nearPlane, farPlane\n                    );\n                }\n                splitFrustum.setFromProjection(splitProjMatrix);\n                splitFrustum.getTransformedBoundingBox(cropBBox, lightViewMatrix);\n                cropBBox.applyProjection(lightProjMatrix);\n                var _min = cropBBox.min.array;\n                var _max = cropBBox.max.array;\n                _min[0] = Math.max(_min[0], -1);\n                _min[1] = Math.max(_min[1], -1);\n                _max[0] = Math.min(_max[0], 1);\n                _max[1] = Math.min(_max[1], 1);\n                cropMatrix.ortho(_min[0], _max[0], _min[1], _max[1], 1, -1);\n                lightCamera.projectionMatrix.multiplyLeft(cropMatrix);\n\n                var shadowSize = light.shadowResolution || 512;\n\n                // Reversed, left to right => far to near\n                renderer.setViewport((light.shadowCascade - i - 1) * shadowSize, 0, shadowSize, shadowSize, 1);\n\n                renderer.renderPass(casters, lightCamera, passConfig);\n\n                // Filter for VSM\n                if (this.softShadow === ShadowMapPass.VSM) {\n                    this._gaussianFilter(renderer, texture, texture.width);\n                }\n\n                var matrix = new Matrix4();\n                matrix.copy(lightCamera.viewMatrix)\n                    .multiplyLeft(lightCamera.projectionMatrix);\n\n                directionalLightMatrices.push(matrix.array);\n\n                lightCamera.projectionMatrix.copy(lightProjMatrix);\n            }\n\n            this._frameBuffer.unbind(renderer);\n\n            renderer.setViewport(viewport);\n        };\n    })(),\n\n    renderSpotLightShadow: function (renderer, scene, light, casters, spotLightMatrices, spotLightShadowMaps) {\n\n        var texture = this._getTexture(light);\n        var lightCamera = this._getSpotLightCamera(light);\n        var _gl = renderer.gl;\n\n        this._frameBuffer.attach(texture);\n        this._frameBuffer.bind(renderer);\n\n        _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n        var defaultShadowMaterial = this._getDepthMaterial(light);\n        var passConfig = {\n            getMaterial: function (renderable) {\n                return renderable.shadowDepthMaterial || defaultShadowMaterial;\n            },\n            sortCompare: Renderer.opaqueSortCompare\n        };\n\n        renderer.renderPass(renderer.cullRenderList(casters, null, lightCamera), lightCamera, passConfig);\n\n        this._frameBuffer.unbind(renderer);\n\n        // Filter for VSM\n        if (this.softShadow === ShadowMapPass.VSM) {\n            this._gaussianFilter(renderer, texture, texture.width);\n        }\n\n        var matrix = new Matrix4();\n        matrix.copy(lightCamera.worldTransform)\n            .invert()\n            .multiplyLeft(lightCamera.projectionMatrix);\n\n        spotLightShadowMaps.push(texture);\n        spotLightMatrices.push(matrix.array);\n    },\n\n    renderPointLightShadow: function (renderer, scene, light, casters, pointLightShadowMaps) {\n        var texture = this._getTexture(light);\n        var _gl = renderer.gl;\n        pointLightShadowMaps.push(texture);\n\n        var defaultShadowMaterial = this._getDepthMaterial(light);\n        var passConfig = {\n            getMaterial: function (renderable) {\n                return renderable.shadowDepthMaterial || defaultShadowMaterial;\n            },\n            sortCompare: Renderer.opaqueSortCompare\n        };\n\n        for (var i = 0; i < 6; i++) {\n            var target = targets[i];\n            var camera = this._getPointLightCamera(light, target);\n\n            this._frameBuffer.attach(texture, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i);\n            this._frameBuffer.bind(renderer);\n            _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n            renderer.renderPass(renderer.cullRenderList(casters, null, camera), camera, passConfig);\n        }\n\n        this._frameBuffer.unbind(renderer);\n    },\n\n    _getDepthMaterial: function (light) {\n        var shadowMaterial = this._lightMaterials[light.__uid__];\n        var isPointLight = light instanceof PointLight;\n        if (!shadowMaterial) {\n            var shaderPrefix = isPointLight ? 'clay.sm.distance.' : 'clay.sm.depth.';\n            shadowMaterial = new Material({\n                precision: this.precision,\n                shader: new Shader(Shader.source(shaderPrefix + 'vertex'), Shader.source(shaderPrefix + 'fragment'))\n            });\n\n            this._lightMaterials[light.__uid__] = shadowMaterial;\n        }\n        if (light.shadowSlopeScale != null) {\n            shadowMaterial.setUniform('slopeScale', light.shadowSlopeScale);\n        }\n        if (light.shadowBias != null) {\n            shadowMaterial.setUniform('shadowBias', light.shadowBias);\n        }\n        if (this.softShadow === ShadowMapPass.VSM) {\n            shadowMaterial.define('fragment', 'USE_VSM');\n        }\n        else {\n            shadowMaterial.undefine('fragment', 'USE_VSM');\n        }\n\n        if (isPointLight) {\n            shadowMaterial.set('lightPosition', light.getWorldPosition().array);\n            shadowMaterial.set('range', light.range);\n        }\n\n        return shadowMaterial;\n    },\n\n    _gaussianFilter: function (renderer, texture, size) {\n        var parameter = {\n            width: size,\n            height: size,\n            type: Texture.FLOAT\n        };\n        var tmpTexture = this._texturePool.get(parameter);\n\n        this._frameBuffer.attach(tmpTexture);\n        this._frameBuffer.bind(renderer);\n        this._gaussianPassH.setUniform('texture', texture);\n        this._gaussianPassH.setUniform('textureWidth', size);\n        this._gaussianPassH.render(renderer);\n\n        this._frameBuffer.attach(texture);\n        this._gaussianPassV.setUniform('texture', tmpTexture);\n        this._gaussianPassV.setUniform('textureHeight', size);\n        this._gaussianPassV.render(renderer);\n        this._frameBuffer.unbind(renderer);\n\n        this._texturePool.put(tmpTexture);\n    },\n\n    _getTexture: function (light, cascade) {\n        var key = light.__uid__;\n        var texture = this._textures[key];\n        var resolution = light.shadowResolution || 512;\n        cascade = cascade || 1;\n        if (!texture) {\n            if (light instanceof PointLight) {\n                texture = new TextureCube();\n            }\n            else {\n                texture = new Texture2D();\n            }\n            // At most 4 cascade\n            // TODO share with height ?\n            texture.width = resolution * cascade;\n            texture.height = resolution;\n            if (this.softShadow === ShadowMapPass.VSM) {\n                texture.type = Texture.FLOAT;\n                texture.anisotropic = 4;\n            }\n            else {\n                texture.minFilter = glenum.NEAREST;\n                texture.magFilter = glenum.NEAREST;\n                texture.useMipmap = false;\n            }\n            this._textures[key] = texture;\n        }\n\n        return texture;\n    },\n\n    _getPointLightCamera: function (light, target) {\n        if (!this._lightCameras.point) {\n            this._lightCameras.point = {\n                px: new PerspectiveCamera(),\n                nx: new PerspectiveCamera(),\n                py: new PerspectiveCamera(),\n                ny: new PerspectiveCamera(),\n                pz: new PerspectiveCamera(),\n                nz: new PerspectiveCamera()\n            };\n        }\n        var camera = this._lightCameras.point[target];\n\n        camera.far = light.range;\n        camera.fov = 90;\n        camera.position.set(0, 0, 0);\n        switch (target) {\n            case 'px':\n                camera.lookAt(Vector3.POSITIVE_X, Vector3.NEGATIVE_Y);\n                break;\n            case 'nx':\n                camera.lookAt(Vector3.NEGATIVE_X, Vector3.NEGATIVE_Y);\n                break;\n            case 'py':\n                camera.lookAt(Vector3.POSITIVE_Y, Vector3.POSITIVE_Z);\n                break;\n            case 'ny':\n                camera.lookAt(Vector3.NEGATIVE_Y, Vector3.NEGATIVE_Z);\n                break;\n            case 'pz':\n                camera.lookAt(Vector3.POSITIVE_Z, Vector3.NEGATIVE_Y);\n                break;\n            case 'nz':\n                camera.lookAt(Vector3.NEGATIVE_Z, Vector3.NEGATIVE_Y);\n                break;\n        }\n        light.getWorldPosition(camera.position);\n        camera.update();\n\n        return camera;\n    },\n\n    _getDirectionalLightCamera: (function () {\n        var lightViewMatrix = new Matrix4();\n        var sceneViewBoundingBox = new BoundingBox();\n        var lightViewBBox = new BoundingBox();\n        // Camera of directional light will be adjusted\n        // to contain the view frustum and scene bounding box as tightly as possible\n        return function (light, scene, sceneCamera) {\n            if (!this._lightCameras.directional) {\n                this._lightCameras.directional = new OrthoCamera();\n            }\n            var camera = this._lightCameras.directional;\n\n            sceneViewBoundingBox.copy(scene.viewBoundingBoxLastFrame);\n            sceneViewBoundingBox.intersection(sceneCamera.frustum.boundingBox);\n            // Move to the center of frustum(in world space)\n            camera.position\n                .copy(sceneViewBoundingBox.min)\n                .add(sceneViewBoundingBox.max)\n                .scale(0.5)\n                .transformMat4(sceneCamera.worldTransform);\n            camera.rotation.copy(light.rotation);\n            camera.scale.copy(light.scale);\n            camera.updateWorldTransform();\n\n            // Transform to light view space\n            Matrix4.invert(lightViewMatrix, camera.worldTransform);\n            Matrix4.multiply(lightViewMatrix, lightViewMatrix, sceneCamera.worldTransform);\n\n            lightViewBBox.copy(sceneViewBoundingBox).applyTransform(lightViewMatrix);\n\n            var min = lightViewBBox.min.array;\n            var max = lightViewBBox.max.array;\n\n            // Move camera to adjust the near to 0\n            camera.position.set((min[0] + max[0]) / 2, (min[1] + max[1]) / 2, max[2])\n                .transformMat4(camera.worldTransform);\n            camera.near = 0;\n            camera.far = -min[2] + max[2];\n            // Make sure receivers not in the frustum will stil receive the shadow.\n            if (isNaN(this.lightFrustumBias)) {\n                camera.far *= 4;\n            }\n            else {\n                camera.far += this.lightFrustumBias;\n            }\n            camera.left = min[0];\n            camera.right = max[0];\n            camera.top = max[1];\n            camera.bottom = min[1];\n            camera.update(true);\n\n            return camera;\n        };\n    })(),\n\n    _getSpotLightCamera: function (light) {\n        if (!this._lightCameras.spot) {\n            this._lightCameras.spot = new PerspectiveCamera();\n        }\n        var camera = this._lightCameras.spot;\n        // Update properties\n        camera.fov = light.penumbraAngle * 2;\n        camera.far = light.range;\n        camera.worldTransform.copy(light.worldTransform);\n        camera.updateProjectionMatrix();\n        mat4.invert(camera.viewMatrix.array, camera.worldTransform.array);\n\n        return camera;\n    },\n\n    /**\n     * @param  {clay.Renderer|WebGLRenderingContext} [renderer]\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    // PENDING Renderer or WebGLRenderingContext\n    dispose: function (renderer) {\n        var _gl = renderer.gl || renderer;\n\n        if (this._frameBuffer) {\n            this._frameBuffer.dispose(_gl);\n        }\n\n        for (var name in this._textures) {\n            this._textures[name].dispose(_gl);\n        }\n\n        this._texturePool.clear(renderer.gl);\n\n        this._depthMaterials = {};\n        this._distanceMaterials = {};\n        this._textures = {};\n        this._lightCameras = {};\n        this._shadowMapNumber = {\n            'POINT_LIGHT': 0,\n            'DIRECTIONAL_LIGHT': 0,\n            'SPOT_LIGHT': 0\n        };\n        this._meshMaterials = {};\n\n        for (var i = 0; i < this._receivers.length; i++) {\n            var mesh = this._receivers[i];\n            // Mesh may be disposed\n            if (mesh.material && mesh.material.shader) {\n                var material = mesh.material;\n                var shader = material.shader;\n                shader.undefine('fragment', 'POINT_LIGHT_SHADOW_COUNT');\n                shader.undefine('fragment', 'DIRECTIONAL_LIGHT_SHADOW_COUNT');\n                shader.undefine('fragment', 'AMBIENT_LIGHT_SHADOW_COUNT');\n                material.set('shadowEnabled', 0);\n            }\n        }\n\n        this._opaqueCasters = [];\n        this._receivers = [];\n        this._lightsCastShadow = [];\n    }\n});\n\n/**\n * @name clay.prePass.ShadowMap.VSM\n * @type {number}\n */\nShadowMapPass.VSM = 1;\n\n/**\n * @name clay.prePass.ShadowMap.PCF\n * @type {number}\n */\nShadowMapPass.PCF = 2;\n\nexport default ShadowMapPass;\n","import Base from '../core/Base';\nimport Ray from '../math/Ray';\nimport Vector2 from '../math/Vector2';\nimport Vector3 from '../math/Vector3';\nimport Matrix4 from '../math/Matrix4';\nimport Renderable from '../Renderable';\nimport glenum from '../core/glenum';\nimport glmatrix from '../dep/glmatrix';\n\nvar vec3 = glmatrix.vec3;\n\n/**\n * @constructor clay.picking.RayPicking\n * @extends clay.core.Base\n */\nvar RayPicking = Base.extend(\n/** @lends clay.picking.RayPicking# */\n{\n    /**\n     * Target scene\n     * @type {clay.Scene}\n     */\n    scene: null,\n    /**\n     * Target camera\n     * @type {clay.Camera}\n     */\n    camera: null,\n    /**\n     * Target renderer\n     * @type {clay.Renderer}\n     */\n    renderer: null\n}, function () {\n    this._ray = new Ray();\n    this._ndc = new Vector2();\n},\n/** @lends clay.picking.RayPicking.prototype */\n{\n\n    /**\n     * Pick the nearest intersection object in the scene\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @param  {boolean} [forcePickAll=false] ignore ignorePicking\n     * @return {clay.picking.RayPicking~Intersection}\n     */\n    pick: function (x, y, forcePickAll) {\n        var out = this.pickAll(x, y, [], forcePickAll);\n        return out[0] || null;\n    },\n\n    /**\n     * Pick all intersection objects, wich will be sorted from near to far\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @param  {Array} [output]\n     * @param  {boolean} [forcePickAll=false] ignore ignorePicking\n     * @return {Array.<clay.picking.RayPicking~Intersection>}\n     */\n    pickAll: function (x, y, output, forcePickAll) {\n        this.renderer.screenToNDC(x, y, this._ndc);\n        this.camera.castRay(this._ndc, this._ray);\n\n        output = output || [];\n\n        this._intersectNode(this.scene, output, forcePickAll || false);\n\n        output.sort(this._intersectionCompareFunc);\n\n        return output;\n    },\n\n    _intersectNode: function (node, out, forcePickAll) {\n        if ((node instanceof Renderable) && node.isRenderable()) {\n            if ((!node.ignorePicking || forcePickAll)\n                && (\n                    // Only triangle mesh support ray picking\n                    (node.mode === glenum.TRIANGLES && node.geometry.isUseIndices())\n                    // Or if geometry has it's own pickByRay, pick, implementation\n                    || node.geometry.pickByRay\n                    || node.geometry.pick\n                )\n            ) {\n                this._intersectRenderable(node, out);\n            }\n        }\n        for (var i = 0; i < node._children.length; i++) {\n            this._intersectNode(node._children[i], out, forcePickAll);\n        }\n    },\n\n    _intersectRenderable: (function () {\n\n        var v1 = new Vector3();\n        var v2 = new Vector3();\n        var v3 = new Vector3();\n        var ray = new Ray();\n        var worldInverse = new Matrix4();\n\n        return function (renderable, out) {\n\n            var isSkinnedMesh = renderable.isSkinnedMesh();\n            ray.copy(this._ray);\n            Matrix4.invert(worldInverse, renderable.worldTransform);\n\n            // Skinned mesh will ignore the world transform.\n            if (!isSkinnedMesh) {\n                ray.applyTransform(worldInverse);\n            }\n\n            var geometry = renderable.geometry;\n            // Ignore bounding box of skinned mesh?\n            if (!isSkinnedMesh) {\n                if (geometry.boundingBox) {\n                    if (!ray.intersectBoundingBox(geometry.boundingBox)) {\n                        return;\n                    }\n                }\n            }\n            // Use user defined picking algorithm\n            if (geometry.pick) {\n                geometry.pick(\n                    this._ndc.x, this._ndc.y,\n                    this.renderer,\n                    this.camera,\n                    renderable, out\n                );\n                return;\n            }\n            // Use user defined ray picking algorithm\n            else if (geometry.pickByRay) {\n                geometry.pickByRay(ray, renderable, out);\n                return;\n            }\n\n            var cullBack = (renderable.cullFace === glenum.BACK && renderable.frontFace === glenum.CCW)\n                        || (renderable.cullFace === glenum.FRONT && renderable.frontFace === glenum.CW);\n\n            var point;\n            var indices = geometry.indices;\n            var positionAttr = geometry.attributes.position;\n            var weightAttr = geometry.attributes.weight;\n            var jointAttr = geometry.attributes.joint;\n            var skinMatricesArray;\n            var skinMatrices = [];\n            // Check if valid.\n            if (!positionAttr || !positionAttr.value || !indices) {\n                return;\n            }\n            if (isSkinnedMesh) {\n                skinMatricesArray = renderable.skeleton.getSubSkinMatrices(renderable.__uid__, renderable.joints);\n                for (var i = 0; i < renderable.joints.length; i++) {\n                    skinMatrices[i] = skinMatrices[i] || [];\n                    for (var k = 0; k < 16; k++) {\n                        skinMatrices[i][k] = skinMatricesArray[i * 16 + k];\n                    }\n                }\n                var pos = [];\n                var weight = [];\n                var joint = [];\n                var skinnedPos = [];\n                var tmp = [];\n                var skinnedPositionAttr = geometry.attributes.skinnedPosition;\n                if (!skinnedPositionAttr || !skinnedPositionAttr.value) {\n                    geometry.createAttribute('skinnedPosition', 'f', 3);\n                    skinnedPositionAttr = geometry.attributes.skinnedPosition;\n                    skinnedPositionAttr.init(geometry.vertexCount);\n                }\n                for (var i = 0; i < geometry.vertexCount; i++) {\n                    positionAttr.get(i, pos);\n                    weightAttr.get(i, weight);\n                    jointAttr.get(i, joint);\n                    weight[3] = 1 - weight[0] - weight[1] - weight[2];\n                    vec3.set(skinnedPos, 0, 0, 0);\n                    for (var k = 0; k < 4; k++) {\n                        if (joint[k] >= 0 && weight[k] > 1e-4) {\n                            vec3.transformMat4(tmp, pos, skinMatrices[joint[k]]);\n                            vec3.scaleAndAdd(skinnedPos, skinnedPos, tmp, weight[k]);\n                        }\n                    }\n                    skinnedPositionAttr.set(i, skinnedPos);\n                }\n            }\n\n            for (var i = 0; i < indices.length; i += 3) {\n                var i1 = indices[i];\n                var i2 = indices[i + 1];\n                var i3 = indices[i + 2];\n                var finalPosAttr = isSkinnedMesh\n                    ? geometry.attributes.skinnedPosition\n                    : positionAttr;\n                finalPosAttr.get(i1, v1.array);\n                finalPosAttr.get(i2, v2.array);\n                finalPosAttr.get(i3, v3.array);\n\n                if (cullBack) {\n                    point = ray.intersectTriangle(v1, v2, v3, renderable.culling);\n                }\n                else {\n                    point = ray.intersectTriangle(v1, v3, v2, renderable.culling);\n                }\n                if (point) {\n                    var pointW = new Vector3();\n                    if (!isSkinnedMesh) {\n                        Vector3.transformMat4(pointW, point, renderable.worldTransform);\n                    }\n                    else {\n                        // TODO point maybe not right.\n                        Vector3.copy(pointW, point);\n                    }\n                    out.push(new RayPicking.Intersection(\n                        point, pointW, renderable, [i1, i2, i3], i / 3,\n                        Vector3.dist(pointW, this._ray.origin)\n                    ));\n                }\n            }\n        };\n    })(),\n\n    _intersectionCompareFunc: function (a, b) {\n        return a.distance - b.distance;\n    }\n});\n\n/**\n * @constructor clay.picking.RayPicking~Intersection\n * @param {clay.math.Vector3} point\n * @param {clay.math.Vector3} pointWorld\n * @param {clay.Node} target\n * @param {Array.<number>} triangle\n * @param {number} triangleIndex\n * @param {number} distance\n */\nRayPicking.Intersection = function (point, pointWorld, target, triangle, triangleIndex, distance) {\n    /**\n     * Intersection point in local transform coordinates\n     * @type {clay.math.Vector3}\n     */\n    this.point = point;\n    /**\n     * Intersection point in world transform coordinates\n     * @type {clay.math.Vector3}\n     */\n    this.pointWorld = pointWorld;\n    /**\n     * Intersection scene node\n     * @type {clay.Node}\n     */\n    this.target = target;\n    /**\n     * Intersection triangle, which is an array of vertex index\n     * @type {Array.<number>}\n     */\n    this.triangle = triangle;\n    /**\n     * Index of intersection triangle.\n     */\n    this.triangleIndex = triangleIndex;\n    /**\n     * Distance from intersection point to ray origin\n     * @type {number}\n     */\n    this.distance = distance;\n};\n\nexport default RayPicking;\n","// Spherical Harmonic Helpers\nimport Texture from '../Texture';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture2D from '../Texture2D';\nimport Pass from '../compositor/Pass';\nimport vendor from '../core/vendor';\nimport Skybox from '../plugin/Skybox';\nimport Skydome from '../plugin/Skydome';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport Scene from '../Scene';\nimport glmatrix from '../dep/glmatrix';\nvar vec3 = glmatrix.vec3;\nvar sh = {};\n\nimport projectEnvMapShaderCode from './shader/projectEnvMap.glsl.js';\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n// Project on gpu, but needs browser to support readPixels as Float32Array.\nfunction projectEnvironmentMapGPU(renderer, envMap) {\n    var shTexture = new Texture2D({\n        width: 9,\n        height: 1,\n        type: Texture.FLOAT\n    });\n    var pass = new Pass({\n        fragment: projectEnvMapShaderCode\n    });\n    pass.material.define('fragment', 'TEXTURE_SIZE', envMap.width);\n    pass.setUniform('environmentMap', envMap);\n\n    var framebuffer = new FrameBuffer();\n    framebuffer.attach(shTexture);\n    pass.render(renderer, framebuffer);\n\n    framebuffer.bind(renderer);\n    // TODO Only chrome and firefox support Float32Array\n    var pixels = new vendor.Float32Array(9 * 4);\n    renderer.gl.readPixels(0, 0, 9, 1, Texture.RGBA, Texture.FLOAT, pixels);\n\n    var coeff = new vendor.Float32Array(9 * 3);\n    for (var i = 0; i < 9; i++) {\n        coeff[i * 3] = pixels[i * 4];\n        coeff[i * 3 + 1] = pixels[i * 4 + 1];\n        coeff[i * 3 + 2] = pixels[i * 4 + 2];\n    }\n    framebuffer.unbind(renderer);\n\n    framebuffer.dispose(renderer);\n    pass.dispose(renderer);\n    return coeff;\n}\n\nfunction harmonics(normal, index){\n    var x = normal[0];\n    var y = normal[1];\n    var z = normal[2];\n\n    if (index === 0) {\n        return 1.0;\n    }\n    else if (index === 1) {\n        return x;\n    }\n    else if (index === 2) {\n        return y;\n    }\n    else if (index === 3) {\n        return z;\n    }\n    else if (index === 4) {\n        return x * z;\n    }\n    else if (index === 5) {\n        return y * z;\n    }\n    else if (index === 6) {\n        return x * y;\n    }\n    else if (index === 7) {\n        return 3.0 * z * z - 1.0;\n    }\n    else {\n        return x * x - y * y;\n    }\n}\n\nvar normalTransform = {\n    px: [2, 1, 0, -1, -1, 1],\n    nx: [2, 1, 0, 1, -1, -1],\n    py: [0, 2, 1, 1, -1, -1],\n    ny: [0, 2, 1, 1, 1, 1],\n    pz: [0, 1, 2, -1, -1, -1],\n    nz: [0, 1, 2, 1, -1, 1]\n};\n\n// Project on cpu.\nfunction projectEnvironmentMapCPU(renderer, cubePixels, width, height) {\n    var coeff = new vendor.Float32Array(9 * 3);\n    var normal = vec3.create();\n    var texel = vec3.create();\n    var fetchNormal = vec3.create();\n    for (var m = 0; m < 9; m++) {\n        var result = vec3.create();\n        for (var k = 0; k < targets.length; k++) {\n            var pixels = cubePixels[targets[k]];\n\n            var sideResult = vec3.create();\n            var divider = 0;\n            var i = 0;\n            var transform = normalTransform[targets[k]];\n            for (var y = 0; y < height; y++) {\n                for (var x = 0; x < width; x++) {\n\n                    normal[0] = x / (width - 1.0) * 2.0 - 1.0;\n                    // TODO Flip y?\n                    normal[1] = y / (height - 1.0) * 2.0 - 1.0;\n                    normal[2] = -1.0;\n                    vec3.normalize(normal, normal);\n\n                    fetchNormal[0] = normal[transform[0]] * transform[3];\n                    fetchNormal[1] = normal[transform[1]] * transform[4];\n                    fetchNormal[2] = normal[transform[2]] * transform[5];\n\n                    texel[0] = pixels[i++] / 255;\n                    texel[1] = pixels[i++] / 255;\n                    texel[2] = pixels[i++] / 255;\n                    // RGBM Decode\n                    var scale = pixels[i++] / 255 * 51.5;\n                    texel[0] *= scale;\n                    texel[1] *= scale;\n                    texel[2] *= scale;\n\n                    vec3.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]);\n                    // -normal.z equals cos(theta) of Lambertian\n                    divider += -normal[2];\n                }\n            }\n            vec3.scaleAndAdd(result, result, sideResult, 1 / divider);\n        }\n\n        coeff[m * 3] = result[0] / 6.0;\n        coeff[m * 3 + 1] = result[1] / 6.0;\n        coeff[m * 3 + 2] = result[2] / 6.0;\n    }\n    return coeff;\n}\n\n/**\n * @param  {clay.Renderer} renderer\n * @param  {clay.Texture} envMap\n * @param  {Object} [textureOpts]\n * @param  {Object} [textureOpts.lod]\n * @param  {boolean} [textureOpts.decodeRGBM]\n */\nsh.projectEnvironmentMap = function (renderer, envMap, opts) {\n\n    // TODO sRGB\n\n    opts = opts || {};\n    opts.lod = opts.lod || 0;\n\n    var skybox;\n    var dummyScene = new Scene();\n    var size = 64;\n    if (envMap instanceof Texture2D) {\n        skybox = new Skydome({\n            scene: dummyScene,\n            environmentMap: envMap\n        });\n    }\n    else {\n        size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width;\n        skybox = new Skybox({\n            scene: dummyScene,\n            environmentMap: envMap\n        });\n    }\n    // Convert to rgbm\n    var width = Math.ceil(size / Math.pow(2, opts.lod));\n    var height = Math.ceil(size / Math.pow(2, opts.lod));\n    var rgbmTexture = new Texture2D({\n        width: width,\n        height: height\n    });\n    var framebuffer = new FrameBuffer();\n    skybox.material.define('fragment', 'RGBM_ENCODE');\n    if (opts.decodeRGBM) {\n        skybox.material.define('fragment', 'RGBM_DECODE');\n    }\n    skybox.material.set('lod', opts.lod);\n    var envMapPass = new EnvironmentMapPass({\n        texture: rgbmTexture\n    });\n    var cubePixels = {};\n    for (var i = 0; i < targets.length; i++) {\n        cubePixels[targets[i]] = new Uint8Array(width * height * 4);\n        var camera = envMapPass.getCamera(targets[i]);\n        camera.fov = 90;\n        framebuffer.attach(rgbmTexture);\n        framebuffer.bind(renderer);\n        renderer.render(dummyScene, camera);\n        renderer.gl.readPixels(\n            0, 0, width, height,\n            Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets[i]]\n        );\n        framebuffer.unbind(renderer);\n    }\n\n    skybox.dispose(renderer);\n    framebuffer.dispose(renderer);\n    rgbmTexture.dispose(renderer);\n\n    return projectEnvironmentMapCPU(renderer, cubePixels, width, height);\n};\n\nexport default sh;\n","\n/**\n * Helpers for creating a common 3d application.\n * @namespace clay.application\n */\n\n // TODO createCompositor\n // TODO mobile. scroll events.\n // TODO Dispose test. geoCache test.\n // TODO fitModel, normal generation.\n // TODO Skybox, Skydome.\n // TODO Particle ?\nimport Renderer from './Renderer';\nimport Scene from './Scene';\nimport Timeline from './animation/Timeline';\nimport CubeGeo from './geometry/Cube';\nimport SphereGeo from './geometry/Sphere';\nimport PlaneGeo from './geometry/Plane';\nimport Texture2D from './Texture2D';\nimport Texture from './Texture';\nimport shaderLibrary from './shader/library';\nimport Mesh from './Mesh';\nimport Material from './Material';\nimport PerspectiveCamera from './camera/Perspective';\nimport OrthographicCamera from './camera/Orthographic';\nimport Vector3 from './math/Vector3';\nimport GLTFLoader from './loader/GLTF';\nimport Node from './Node';\nimport DirectionalLight from './light/Directional';\nimport PointLight from './light/Point';\nimport SpotLight from './light/Spot';\nimport AmbientLight from './light/Ambient';\nimport AmbientCubemapLight from './light/AmbientCubemap';\nimport AmbientSHLight from './light/AmbientSH';\nimport ShadowMapPass from './prePass/ShadowMap';\nimport RayPicking from './picking/RayPicking';\nimport LRUCache from './core/LRU';\nimport util from './core/util';\nimport shUtil from './util/sh';\nimport textureUtil from './util/texture';\n\nimport colorUtil from './core/color';\nvar parseColor = colorUtil.parseToFloat;\n\nimport './shader/builtin';\nimport Shader from './Shader';\n\n/**\n * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike\n */\n/**\n * @typedef {string|Array.<number>} Color\n */\n/**\n * @typedef {HTMLDomElement|string} DomQuery\n */\n\n/**\n * @constructor\n * @alias clay.application.App3D\n * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector`\n * @param {Object} appNS\n * @param {Function} appNS.init Initialization callback that will be called when initing app.\n *                      You can return a promise in init to start the loop asynchronously when the promise is resolved.\n * @param {Function} appNS.loop Loop callback that will be called each frame.\n * @param {Function} appNS.beforeRender\n * @param {Function} appNS.afterRender\n * @param {number} [appNS.width] Container width.\n * @param {number} [appNS.height] Container height.\n * @param {number} [appNS.devicePixelRatio]\n * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect\n * @param {boolean} [appNS.graphic.shadow=false] If enable shadow\n * @param {boolean} [appNS.graphic.linear=false] If use linear space\n * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping.\n * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex.\n */\nfunction App3D(dom, appNS) {\n\n    appNS = appNS || {};\n    appNS.graphic = appNS.graphic || {};\n\n    if (typeof dom === 'string') {\n        dom = document.querySelector(dom);\n    }\n\n    if (!dom) { throw new Error('Invalid dom'); }\n\n    var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS';\n    var rendererOpts = {};\n    isDomCanvas && (rendererOpts.canvas = dom);\n    appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio);\n\n    var gRenderer = new Renderer(rendererOpts);\n    var gWidth = appNS.width || dom.clientWidth;\n    var gHeight = appNS.height || dom.clientHeight;\n\n    var gScene = new Scene();\n    var gTimeline = new Timeline();\n    var gShadowPass = appNS.graphic.shadow && new ShadowMapPass();\n    var gRayPicking = appNS.event && new RayPicking({\n        scene: gScene,\n        renderer: gRenderer\n    });\n\n    !isDomCanvas && dom.appendChild(gRenderer.canvas);\n\n    gRenderer.resize(gWidth, gHeight);\n\n    var gFrameTime = 0;\n    var gElapsedTime = 0;\n\n    gTimeline.start();\n\n    Object.defineProperties(this, {\n        /**\n         * Container dom element\n         * @name clay.application.App3D#container\n         * @type {HTMLDomElement}\n         */\n        container: { get: function () { return dom; } },\n        /**\n         * @name clay.application.App3D#renderer\n         * @type {clay.Renderer}\n         */\n        renderer: { get: function () { return gRenderer; }},\n        /**\n         * @name clay.application.App3D#scene\n         * @type {clay.Renderer}\n         */\n        scene: { get: function () { return gScene; }},\n        /**\n         * @name clay.application.App3D#timeline\n         * @type {clay.Renderer}\n         */\n        timeline: { get: function () { return gTimeline; }},\n        /**\n         * Time elapsed since last frame. Can be used in loop to calculate the movement.\n         * @name clay.application.App3D#frameTime\n         * @type {number}\n         */\n        frameTime: { get: function () { return gFrameTime; }},\n        /**\n         * Time elapsed since application created.\n         * @name clay.application.App3D#elapsedTime\n         * @type {number}\n         */\n        elapsedTime: { get: function () { return gElapsedTime; }}\n    });\n\n    /**\n     * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given.\n     * @function\n     * @memberOf {clay.application.App3D}\n     * @param {number} [width]\n     * @param {number} [height]\n     */\n    this.resize = function (width, height) {\n        gWidth = width || appNS.width || dom.clientWidth;\n        gHeight = height || dom.height || dom.clientHeight;\n        gRenderer.resize(gWidth, gHeight);\n    };\n\n    /**\n     * Dispose the application\n     * @function\n     */\n    this.dispose = function () {\n        this._disposed = true;\n\n        if (appNS.dispose) {\n            appNS.dispose(this);\n        }\n        gTimeline.stop();\n        gRenderer.disposeScene(gScene);\n        gShadowPass && gShadowPass.dispose(gRenderer);\n\n        dom.innerHTML = '';\n        ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) {\n            this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType));\n        });\n    };\n\n    gRayPicking && this._initMouseEvents(gRayPicking);\n\n    this._geoCache = new LRUCache(20);\n    this._texCache = new LRUCache(20);\n\n    // Do init the application.\n    var initPromise = Promise.resolve(appNS.init && appNS.init(this));\n    // Use the inited camera.\n    gRayPicking && (gRayPicking.camera = gScene.getMainCamera());\n\n    var gTexturesList = {};\n    var gGeometriesList = {};\n\n    if (!appNS.loop) {\n        console.warn('Miss loop method.');\n    }\n\n    var self = this;\n    initPromise.then(function () {\n        appNS.loop && gTimeline.on('frame', function (frameTime) {\n            gFrameTime = frameTime;\n            gElapsedTime += frameTime;\n            appNS.loop(self);\n\n            gScene.update();\n            self._updateGraphicOptions(appNS.graphic, gScene.opaqueList);\n            self._updateGraphicOptions(appNS.graphic, gScene.transparentList);\n\n            gRayPicking && (gRayPicking.camera = gScene.getMainCamera());\n            // Render shadow pass\n            gShadowPass && gShadowPass.render(gRenderer, gScene, null, true);\n\n            appNS.beforeRender && appNS.beforeRender(self);\n            self._doRender(gRenderer, gScene, true);\n            appNS.afterRender && appNS.afterRender(self);\n\n            // Mark all resources unused;\n            markUnused(gTexturesList);\n            markUnused(gGeometriesList);\n\n            // Collect resources used in this frame.\n            var newTexturesList = [];\n            var newGeometriesList = [];\n            collectResources(gScene, newTexturesList, newGeometriesList);\n\n            // Dispose those unsed resources.\n            checkAndDispose(gRenderer, gTexturesList);\n            checkAndDispose(gRenderer, gGeometriesList);\n\n            gTexturesList = newTexturesList;\n            gGeometriesList = newGeometriesList;\n        });\n    });\n}\n\nfunction isImageLikeElement(val) {\n    return val instanceof Image\n        || val instanceof HTMLCanvasElement\n        || val instanceof HTMLVideoElement;\n}\n\nfunction getKeyFromImageLike(val) {\n    typeof val === 'string'\n        ? val : (val.__key__ || (val.__key__ = util.genGUID()));\n}\n\nfunction makeHandlerName(eveType) {\n    return '_' + eveType + 'Handler';\n}\n\nfunction packageEvent(eventType, pickResult, offsetX, offsetY) {\n    var event = util.clone(pickResult);\n    event.type = eventType;\n    event.offsetX = offsetX;\n    event.offsetY = offsetY;\n    return event;\n}\n\nfunction bubblingEvent(target, event) {\n    while (target && !event.cancelBubble) {\n        target.trigger(event.type, event);\n        target = target.getParent();\n    }\n}\n\nApp3D.prototype._initMouseEvents = function (rayPicking) {\n    var dom = this.container;\n\n    var oldTarget = null;\n    ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) {\n        dom.addEventListener(eveType, this[makeHandlerName(eveType)] = function (e) {\n            if (!rayPicking.camera) { // Not have camera yet.\n                return;\n            }\n\n            var box = dom.getBoundingClientRect();\n            var offsetX = e.clientX - box.left;\n            var offsetY = e.clientY - box.top;\n\n            var pickResult = rayPicking.pick(offsetX, offsetY);\n\n            if (pickResult) {\n                // Just ignore silent element.\n                if (pickResult.target.silent) {\n                    return;\n                }\n\n                if (eveType === 'mousemove') {\n                    var targetChanged = pickResult.target !== oldTarget;\n                    if (targetChanged) {\n                        oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', {\n                            target: oldTarget\n                        }, offsetX, offsetY));\n                    }\n                    bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY));\n                    if (targetChanged) {\n                        bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY));\n                    }\n                }\n                else {\n                    bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY));\n                }\n                oldTarget = pickResult.target;\n            }\n            else if (oldTarget) {\n                bubblingEvent(oldTarget, packageEvent('mouseout', {\n                    target: oldTarget\n                }, offsetX, offsetY));\n                oldTarget = null;\n            }\n        });\n    }, this);\n};\n\nApp3D.prototype._updateGraphicOptions = function (graphicOpts, list) {\n    var enableTonemapping = !!graphicOpts.tonemapping;\n    var isLinearSpace = !!graphicOpts.linear;\n\n    var prevMaterial;\n\n    for (var i = 0; i < list.length; i++) {\n        var mat = list[i].material;\n        if (mat === prevMaterial) {\n            continue;\n        }\n\n        enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING');\n        if (isLinearSpace) {\n            mat.define('fragment', 'SRGB_ENCODE');\n            mat.define('fragment', 'SRGB_DECODE');\n        }\n        else {\n            mat.undefine('fragment', 'SRGB_ENCODE');\n            mat.undefine('fragment', 'SRGB_DECODE');\n        }\n\n        prevMaterial = mat;\n    }\n};\n\nApp3D.prototype._doRender = function (renderer, scene) {\n    var camera = scene.getMainCamera();\n    camera.aspect = renderer.getViewportAspect();\n    renderer.render(scene);\n};\n\n\nfunction markUnused(resourceList) {\n    for (var i = 0; i < resourceList.length; i++) {\n        resourceList[i].__used__ = 0;\n    }\n}\n\nfunction checkAndDispose(renderer, resourceList) {\n    for (var i = 0; i < resourceList.length; i++) {\n        if (!resourceList[i].__used__) {\n            resourceList[i].dispose(renderer);\n        }\n    }\n}\n\nfunction updateUsed(resource, list) {\n    resource.__used__ = resource.__used__ || 0;\n    resource.__used__++;\n    if (resource.__used__ === 1) {\n        // Don't push to the list twice.\n        list.push(resource);\n    }\n}\nfunction collectResources(scene, textureResourceList, geometryResourceList) {\n    function trackQueue(queue) {\n        var prevMaterial;\n        var prevGeometry;\n        for (var i = 0; i < queue.length; i++) {\n            var renderable = queue[i];\n            var geometry = renderable.geometry;\n            var material = renderable.material;\n\n            // TODO optimize!!\n            if (material !== prevMaterial) {\n                var textureUniforms = material.getTextureUniforms();\n                for (var u = 0; u < textureUniforms.length; u++) {\n                    var uniformName = textureUniforms[u];\n                    var val = material.uniforms[uniformName].value;\n                    if (!val) {\n                        continue;\n                    }\n                    if (val instanceof Texture) {\n                        updateUsed(val, textureResourceList);\n                    }\n                    else if (val instanceof Array) {\n                        for (var k = 0; k < val.length; k++) {\n                            if (val[k] instanceof Texture) {\n                                updateUsed(val[k], textureResourceList);\n                            }\n                        }\n                    }\n                }\n            }\n            if (geometry !== prevGeometry) {\n                updateUsed(geometry, geometryResourceList);\n            }\n\n            prevMaterial = material;\n            prevGeometry = geometry;\n        }\n    }\n\n    trackQueue(scene.opaqueList);\n    trackQueue(scene.transparentList);\n\n    for (var k = 0; k < scene.lights.length; k++) {\n        // Track AmbientCubemap\n        if (scene.lights[k].cubemap) {\n            updateUsed(scene.lights[k].cubemap, textureResourceList);\n        }\n    }\n}\n/**\n * Load a texture from image or string.\n * @param {ImageLike} img\n * @param {Object} [opts] Texture options.\n * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY}\n * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic}\n * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS}\n * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT}\n * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter}\n * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter}\n * @param {number} [opts.exposure] Only be used when source is a HDR image.\n * @param {boolean} [useCache] If use cache.\n * @return {Promise}\n * @example\n *  app.loadTexture('diffuseMap.jpg')\n *      .then(function (texture) {\n *          material.set('diffuseMap', texture);\n *      });\n */\nApp3D.prototype.loadTexture = function (urlOrImg, opts, useCache) {\n    var self = this;\n    var key = getKeyFromImageLike(urlOrImg);\n    if (useCache) {\n        if (this._texCache.get(key)) {\n            return this._texCache.get(key);\n        }\n    }\n    // TODO Promise ?\n    var promise = new Promise(function (resolve, reject) {\n        var texture = self.loadTextureSync(urlOrImg, opts);\n        if (!texture.isRenderable()) {\n            texture.success(function () {\n                if (self._disposed) {\n                    return;\n                }\n                resolve(texture);\n            });\n            texture.error(function () {\n                if (self._disposed) {\n                    return;\n                }\n                reject();\n            });\n        }\n        else {\n            resolve(texture);\n        }\n    });\n    if (useCache) {\n        this._texCache.put(key, promise);\n    }\n    return promise;\n};\n\n/**\n * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded.\n * @param {ImageLike} img\n * @param {Object} [opts] Texture options.\n * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY}\n * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic}\n * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS}\n * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT}\n * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter}\n * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter}\n * @param {number} [opts.exposure] Only be used when source is a HDR image.\n * @return {Promise}\n * @example\n *  var texture = app.loadTexture('diffuseMap.jpg', {\n *      anisotropic: 8,\n *      flipY: false\n *  });\n *  material.set('diffuseMap', texture);\n */\nApp3D.prototype.loadTextureSync = function (urlOrImg, opts) {\n    var texture = new Texture2D(opts);\n    if (typeof urlOrImg === 'string') {\n        if (urlOrImg.match(/.hdr$|^data:application\\/octet-stream/)) {\n            texture = textureUtil.loadTexture(urlOrImg, {\n                exposure: opts && opts.exposure,\n                fileType: 'hdr'\n            }, function () {\n                texture.dirty();\n                texture.trigger('success');\n            });\n        }\n        else {\n            texture.load(urlOrImg);\n        }\n    }\n    else if (isImageLikeElement(urlOrImg)) {\n        texture.image = urlOrImg;\n        texture.dynamic = urlOrImg instanceof HTMLVideoElement;\n    }\n    return texture;\n};\n\n/**\n * Create a material.\n * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms.\n *                                 Uniforms can be `color`, `alpha` `diffuseMap` etc.\n * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow.\n * @param {boolean} [transparent=false] If material is transparent.\n * @return {clay.Material}\n */\nApp3D.prototype.createMaterial = function (matConfig) {\n    matConfig = matConfig || {};\n    matConfig.shader = matConfig.shader || 'clay.standardMR';\n    var shader = matConfig.shader instanceof Shader ? matConfig.shader : shaderLibrary.get(matConfig.shader);\n    var material = new Material({\n        shader: shader\n    });\n    function makeTextureSetter(key) {\n        return function (texture) {\n            material.setUniform(key, texture);\n        };\n    }\n    for (var key in matConfig) {\n        if (material.uniforms[key]) {\n            var val = matConfig[key];\n            if (material.uniforms[key].type === 't' || isImageLikeElement(val)) {\n                // Try to load a texture.\n                this.loadTexture(val).then(makeTextureSetter(key));\n            }\n            else {\n                material.setUniform(key, val);\n            }\n        }\n    }\n\n    if (matConfig.transparent) {\n        matConfig.depthMask = false;\n        matConfig.transparent = true;\n    }\n    return material;\n};\n\n/**\n * Create a cube mesh and add it to the scene or the given parent node.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of cube.\n *          Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a white cube.\n *  app.createCube()\n */\nApp3D.prototype.createCube = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv, subdiv];\n    }\n\n    var geoKey = 'cube-' + subdiv.join('-');\n    var cube = this._geoCache.get(geoKey);\n    if (!cube) {\n        cube = new CubeGeo({\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1],\n            depthSegments: subdiv[2]\n        });\n        this._geoCache.put(geoKey, cube);\n    }\n    return this.createMesh(cube, material, parentNode);\n};\n\n/**\n * Create a cube mesh that camera is inside the cube.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of cube.\n *          Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a white cube inside.\n *  app.createCubeInside()\n */\nApp3D.prototype.createCubeInside = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv, subdiv];\n    }\n    var geoKey = 'cubeInside-' + subdiv.join('-');\n    var cube = this._geoCache.get(geoKey);\n    if (!cube) {\n        cube = new CubeGeo({\n            inside: true,\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1],\n            depthSegments: subdiv[2]\n        });\n        this._geoCache.put(geoKey, cube);\n    }\n\n    return this.createMesh(cube, material, parentNode);\n};\n\n/**\n * Create a sphere mesh and add it to the scene or the given parent node.\n * @function\n * @param {number} [subdivision=20] Subdivision of sphere.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a semi-transparent sphere.\n *  app.createSphere(20, {\n *      color: [0, 0, 1],\n *      transparent: true,\n *      alpha: 0.5\n *  })\n */\nApp3D.prototype.createSphere = function (subdivision, material, parentNode) {\n    if (subdivision == null) {\n        subdivision = 20;\n    }\n    var geoKey = 'sphere-' + subdivision;\n    var sphere = this._geoCache.get(geoKey);\n    if (!sphere) {\n        sphere = new SphereGeo({\n            widthSegments: subdivision * 2,\n            heightSegments: subdivision\n        });\n        this._geoCache.put(geoKey, sphere);\n    }\n    return this.createMesh(sphere, material, parentNode);\n};\n\n/**\n * Create a plane mesh and add it to the scene or the given parent node.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of plane.\n *          Can be a number to represent both width and height dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a red color plane.\n *  app.createPlane(1, {\n *      color: [1, 0, 0]\n *  })\n */\nApp3D.prototype.createPlane = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv];\n    }\n    var geoKey = 'plane-' + subdiv.join('-');\n    var planeGeo = this._geoCache.get(geoKey);\n    if (!planeGeo) {\n        planeGeo = new PlaneGeo({\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1]\n        });\n        this._geoCache.put(geoKey, planeGeo);\n    }\n    return this.createMesh(planeGeo, material, parentNode);\n};\n\n/**\n * Create a general mesh with given geometry instance and material config.\n * @param {*} geometry\n */\nApp3D.prototype.createMesh = function (geometry, mat, parentNode) {\n    var mesh = new Mesh({\n        geometry: geometry,\n        material: mat instanceof Material ? mat : this.createMaterial(mat)\n    });\n    parentNode = parentNode || this.scene;\n    parentNode.add(mesh);\n    return mesh;\n};\n\n/**\n * Create a perspective or orthographic camera and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} position\n * @param {Array.<number>|clay.math.Vector3} target\n * @param {string} [type=\"perspective\"] Can be 'perspective' or 'orthographic'(in short 'ortho')\n * @return {clay.camera.Perspective}\n */\nApp3D.prototype.createCamera = function (position, target, type) {\n    var CameraCtor;\n    if (type === 'ortho' || type === 'orthographic') {\n        CameraCtor = OrthographicCamera;\n    }\n    else {\n        if (type && type !== 'perspective') {\n            console.error('Unkown camera type ' + type + '. Use default perspective camera');\n        }\n        CameraCtor = PerspectiveCamera;\n    }\n\n    var camera = new CameraCtor();\n    if (position instanceof Vector3) {\n        camera.position.copy(position);\n    }\n    else if (position instanceof Array) {\n        camera.position.setArray(position);\n    }\n\n    if (target instanceof Array) {\n        target = new Vector3(target[0], target[1], target[2]);\n    }\n    if (target instanceof Vector3) {\n        camera.lookAt(target);\n    }\n\n    this.scene.add(camera);\n\n    return camera;\n};\n\n/**\n * Create a directional light and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} dir A Vector3 or array to represent the direction.\n * @param {Color} [color='#fff'] Color of directional light, default to be white.\n * @param {number} [intensity] Intensity of directional light, default to be 1.\n *\n * @example\n *  app.createDirectionalLight([-1, -1, -1], '#fff', 2);\n */\nApp3D.prototype.createDirectionalLight = function (dir, color, intensity) {\n    var light = new DirectionalLight();\n    if (dir instanceof Vector3) {\n        dir = dir.array;\n    }\n    light.position.setArray(dir).negate();\n    light.lookAt(Vector3.ZERO);\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n    return light;\n};\n\n/**\n * Create a spot light and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} position Position of the spot light.\n * @param {Array.<number>|clay.math.Vector3} [target] Target position where spot light points to.\n * @param {number} [range=20] Falloff range of spot light. Default to be 20.\n * @param {Color} [color='#fff'] Color of spot light, default to be white.\n * @param {number} [intensity=1] Intensity of spot light, default to be 1.\n * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line.\n * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line.\n *\n * @example\n *  app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900);\n */\nApp3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) {\n    var light = new SpotLight();\n    light.position.setArray(position instanceof Vector3 ? position.array : position);\n\n    if (target instanceof Array) {\n        target = new Vector3(target[0], target[1], target[2]);\n    }\n    if (target instanceof Vector3) {\n        light.lookAt(target);\n    }\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    range != null && (light.range = range);\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n    umbraAngle != null && (light.umbraAngle = umbraAngle);\n    penumbraAngle != null && (light.penumbraAngle = penumbraAngle);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create a point light.\n * @param {Array.<number>|clay.math.Vector3} position Position of point light..\n * @param {number} [range=100] Falloff range of point light.\n * @param {Color} [color='#fff'] Color of point light.\n * @param {number} [intensity=1] Intensity of point light.\n */\nApp3D.prototype.createPointLight = function (position, range, color, intensity) {\n    var light = new PointLight();\n    light.position.setArray(position instanceof Vector3 ? position.array : position);\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    range != null && (light.range = range);\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create a ambient light.\n * @param {Color} [color='#fff'] Color of ambient light.\n * @param {number} [intensity=1] Intensity of ambient light.\n */\nApp3D.prototype.createAmbientLight = function (color, intensity) {\n    var light = new AmbientLight();\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create an cubemap ambient light and an spherical harmonic ambient light\n * for specular and diffuse lighting in PBR rendering\n * @param {ImageLike} [envImage] Panorama environment image, HDR format is better.\n * @param {number} [specularIntenstity=0.7] Intensity of specular light.\n * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light.\n * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR.\n * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering.\n */\nApp3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) {\n    var self = this;\n    if (exposure == null) {\n        exposure = 1;\n    }\n    if (prefilteredCubemapSize == null) {\n        prefilteredCubemapSize = 32;\n    }\n\n    var scene = this.scene;\n\n    return this.loadTexture(envImage, {\n        exposure: exposure\n    }).then(function (envTexture) {\n        var specLight = new AmbientCubemapLight({\n            intensity: specIntensity != null ? specIntensity : 0.7\n        });\n        specLight.cubemap = envTexture;\n        envTexture.flipY = false;\n        // TODO Cache prefilter ?\n        specLight.prefilter(self.renderer, 32);\n\n        var diffLight = new AmbientSHLight({\n            intensity: diffIntensity != null ? diffIntensity : 0.7,\n            coefficients: shUtil.projectEnvironmentMap(\n                self.renderer, specLight.cubemap, {\n                    lod: 1\n                }\n            )\n        });\n        scene.add(specLight);\n        scene.add(diffLight);\n\n        return {\n            specular: specLight,\n            diffuse: diffLight,\n            // Original environment map\n            environmentMap: envTexture\n        };\n    });\n};\n\n/**\n * Load a [glTF](https://github.com/KhronosGroup/glTF) format model.\n * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script,\n * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application.\n * @param {string} url\n * @param {Object} opts\n * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'.\n * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded.\n * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model.\n * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z'\n * @param {boolean} [opts.textureFlipY=false]\n * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file.\n * @return {Promise}\n */\nApp3D.prototype.loadModel = function (url, opts) {\n    if (typeof url !== 'string') {\n        throw new Error('Invalid URL.');\n    }\n\n    opts = opts || {};\n    if (opts.autoPlayAnimation == null) {\n        opts.autoPlayAnimation = true;\n    }\n    var shader = opts.shader || 'clay.standard';\n\n    var loaderOpts = {\n        rootNode: new Node(),\n        shader: shader,\n        textureRootPath: opts.textureRootPath,\n        crossOrigin: 'Anonymous',\n        textureFlipY: opts.textureFlipY\n    };\n    if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') {\n        loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2);\n    }\n\n    var loader = new GLTFLoader(loaderOpts);\n\n    var scene = this.scene;\n    var timeline = this.timeline;\n    var self = this;\n\n    return new Promise(function (resolve, reject) {\n        function afterLoad(result) {\n            if (self._disposed) {\n                return;\n            }\n\n            scene.add(result.rootNode);\n            if (opts.autoPlayAnimation) {\n                result.clips.forEach(function (clip) {\n                    timeline.addClip(clip);\n                });\n            }\n            resolve(result);\n        }\n        loader.success(function (result) {\n            if (self._disposed) {\n                return;\n            }\n\n            if (!opts.waitTextureLoaded) {\n                afterLoad(result);\n            }\n            else {\n                Promise.all(result.textures.map(function (texture) {\n                    if (texture.isRenderable()) {\n                        return Promise.resolve(texture);\n                    }\n                    return new Promise(function (resolve) {\n                        texture.success(resolve);\n                        texture.error(resolve);\n                    });\n                })).then(function () {\n                    afterLoad(result);\n                }).catch(function () {\n                    afterLoad(result);\n                });\n            }\n        });\n        loader.error(function () {\n            reject();\n        });\n        loader.load(url);\n    });\n};\n\n\nexport default {\n    App3D: App3D,\n    /**\n     * Create a 3D application that will manage the app initialization and loop.\n     * @name clay.application.create\n     * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector`\n     * @param {Object} appNS\n     * @param {Function} init Initialization callback that will be called when initing app.\n     * @param {Function} loop Loop callback that will be called each frame.\n     * @param {number} [width] Container width.\n     * @param {number} [height] Container height.\n     * @param {number} [devicePixelRatio]\n     * @return {clay.application.App3D}\n     *\n     * @example\n     *  clay.application.create('#app', {\n     *      init: function (app) {\n     *          app.createCube();\n     *          var camera = app.createCamera();\n     *          camera.position.set(0, 0, 2);\n     *      },\n     *      loop: function () { // noop }\n     *  })\n     */\n    create: function (dom, appNS) {\n        return new App3D(dom, appNS);\n    }\n};","import notifier from '../core/mixin/notifier';\nimport request from '../core/request';\nimport util  from '../core/util';\n\n/**\n * @constructor\n * @alias clay.async.Task\n * @mixes clay.core.mixin.notifier\n */\nvar Task = function() {\n    this._fullfilled = false;\n    this._rejected = false;\n};\n/**\n * Task successed\n * @param {} data\n */\nTask.prototype.resolve = function(data) {\n    this._fullfilled = true;\n    this._rejected = false;\n    this.trigger('success', data);\n};\n/**\n * Task failed\n * @param {} err\n */\nTask.prototype.reject = function(err) {\n    this._rejected = true;\n    this._fullfilled = false;\n    this.trigger('error', err);\n};\n/**\n * If task successed\n * @return {boolean}\n */\nTask.prototype.isFullfilled = function() {\n    return this._fullfilled;\n};\n/**\n * If task failed\n * @return {boolean}\n */\nTask.prototype.isRejected = function() {\n    return this._rejected;\n};\n/**\n * If task finished, either successed or failed\n * @return {boolean}\n */\nTask.prototype.isSettled = function() {\n    return this._fullfilled || this._rejected;\n};\n\nutil.extend(Task.prototype, notifier);\n\nfunction makeRequestTask(url, responseType) {\n    var task = new Task();\n    request.get({\n        url: url,\n        responseType: responseType,\n        onload: function(res) {\n            task.resolve(res);\n        },\n        onerror: function(error) {\n            task.reject(error);\n        }\n    });\n    return task;\n}\n/**\n * Make a request task\n * @param  {string|object|object[]|string[]} url\n * @param  {string} [responseType]\n * @example\n *     var task = Task.makeRequestTask('./a.json');\n *     var task = Task.makeRequestTask({\n *         url: 'b.bin',\n *         responseType: 'arraybuffer'\n *     });\n *     var tasks = Task.makeRequestTask(['./a.json', './b.json']);\n *     var tasks = Task.makeRequestTask([\n *         {url: 'a.json'},\n *         {url: 'b.bin', responseType: 'arraybuffer'}\n *     ]);\n * @return {clay.async.Task|clay.async.Task[]}\n */\nTask.makeRequestTask = function(url, responseType) {\n    if (typeof url === 'string') {\n        return makeRequestTask(url, responseType);\n    } else if (url.url) {   //  Configure object\n        var obj = url;\n        return makeRequestTask(obj.url, obj.responseType);\n    } else if (Array.isArray(url)) {  // Url list\n        var urlList = url;\n        var tasks = [];\n        urlList.forEach(function(obj) {\n            var url, responseType;\n            if (typeof obj === 'string') {\n                url = obj;\n            } else if (Object(obj) === obj) {\n                url = obj.url;\n                responseType = obj.responseType;\n            }\n            tasks.push(makeRequestTask(url, responseType));\n        });\n        return tasks;\n    }\n};\n/**\n * @return {clay.async.Task}\n */\nTask.makeTask = function() {\n    return new Task();\n};\n\nutil.extend(Task.prototype, notifier);\n\nexport default Task;\n","import util from '../core/util';\nimport Task from './Task';\n\n/**\n * @constructor\n * @alias clay.async.TaskGroup\n * @extends clay.async.Task\n */\nvar TaskGroup = function () {\n\n    Task.apply(this, arguments);\n\n    this._tasks = [];\n\n    this._fulfilledNumber = 0;\n\n    this._rejectedNumber = 0;\n};\n\nvar Ctor = function (){};\nCtor.prototype = Task.prototype;\nTaskGroup.prototype = new Ctor();\n\nTaskGroup.prototype.constructor = TaskGroup;\n\n/**\n * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}.\n * @param  {Array.<clay.async.Task>} tasks\n * @chainable\n * @example\n *     // Load texture list\n *     var list = ['a.jpg', 'b.jpg', 'c.jpg']\n *     var textures = list.map(function (src) {\n *         var texture = new clay.Texture2D();\n *         texture.load(src);\n *         return texture;\n *     });\n *     var taskGroup = new clay.async.TaskGroup();\n *     taskGroup.all(textures).success(function () {\n *         // Do some thing after all textures loaded\n *     });\n */\nTaskGroup.prototype.all = function (tasks) {\n    var count = 0;\n    var self = this;\n    var data = [];\n    this._tasks = tasks;\n    this._fulfilledNumber = 0;\n    this._rejectedNumber = 0;\n\n    util.each(tasks, function (task, idx) {\n        if (!task || !task.once) {\n            return;\n        }\n        count++;\n        task.once('success', function (res) {\n            count--;\n\n            self._fulfilledNumber++;\n            // TODO\n            // Some tasks like texture, loader are not inherited from task\n            // We need to set the states here\n            task._fulfilled = true;\n            task._rejected = false;\n\n            data[idx] = res;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n        task.once('error', function () {\n\n            self._rejectedNumber ++;\n\n            task._fulfilled = false;\n            task._rejected = true;\n\n            self.reject(task);\n        });\n    });\n    if (count === 0) {\n        setTimeout(function () {\n            self.resolve(data);\n        });\n        return this;\n    }\n    return this;\n};\n/**\n * Wait for all given tasks finished, either successed or failed\n * @param  {Array.<clay.async.Task>} tasks\n * @return {clay.async.TaskGroup}\n */\nTaskGroup.prototype.allSettled = function (tasks) {\n    var count = 0;\n    var self = this;\n    var data = [];\n    if (tasks.length === 0) {\n        setTimeout(function () {\n            self.trigger('success', data);\n        });\n        return this;\n    }\n    this._tasks = tasks;\n\n    util.each(tasks, function (task, idx) {\n        if (!task || !task.once) {\n            return;\n        }\n        count++;\n        task.once('success', function (res) {\n            count--;\n\n            self._fulfilledNumber++;\n\n            task._fulfilled = true;\n            task._rejected = false;\n\n            data[idx] = res;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n        task.once('error', function (err) {\n            count--;\n\n            self._rejectedNumber++;\n\n            task._fulfilled = false;\n            task._rejected = true;\n\n            // TODO\n            data[idx] = null;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n    });\n    return this;\n};\n/**\n * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getFulfilledNumber = function (recursive) {\n    if (recursive) {\n        var nFulfilled = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nFulfilled += task.getFulfilledNumber(recursive);\n            } else if(task._fulfilled) {\n                nFulfilled += 1;\n            }\n        }\n        return nFulfilled;\n    } else {\n        return this._fulfilledNumber;\n    }\n};\n\n/**\n * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getRejectedNumber = function (recursive) {\n    if (recursive) {\n        var nRejected = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nRejected += task.getRejectedNumber(recursive);\n            } else if(task._rejected) {\n                nRejected += 1;\n            }\n        }\n        return nRejected;\n    } else {\n        return this._rejectedNumber;\n    }\n};\n\n/**\n * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getSettledNumber = function (recursive) {\n\n    if (recursive) {\n        var nSettled = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nSettled += task.getSettledNumber(recursive);\n            } else if(task._rejected || task._fulfilled) {\n                nSettled += 1;\n            }\n        }\n        return nSettled;\n    } else {\n        return this._fulfilledNumber + this._rejectedNumber;\n    }\n};\n\n/**\n * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getTaskNumber = function (recursive) {\n    if (recursive) {\n        var nTask = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nTask += task.getTaskNumber(recursive);\n            } else {\n                nTask += 1;\n            }\n        }\n        return nTask;\n    } else {\n        return this._tasks.length;\n    }\n};\n\nexport default TaskGroup;\n","import Base from '../core/Base';\n\nvar CanvasMaterial = Base.extend({\n\n    color: [1, 1, 1, 1],\n\n    opacity: 1,\n\n    pointSize: 0,\n\n    pointShape: 'rectangle'\n});\n\nexport default CanvasMaterial;\n","import Base from '../core/Base';\nimport glMatrix from '../dep/glmatrix';\nimport glenum from '../core/glenum';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\nvar vec3Set = vec3.set;\nvar vec3Create = vec3.create;\n\nvar vec4Create = vec4.create;\n\nvar round = Math.round;\n\nvar PRIMITIVE_TRIANGLE = 1;\nvar PRIMITIVE_LINE = 2;\nvar PRIMITIVE_POINT = 3;\n\nfunction PrimitivePool(constructor) {\n    this.ctor = constructor;\n\n    this._data = [];\n\n    this._size = 0;\n}\n\nPrimitivePool.prototype = {\n    pick: function () {\n        var data = this._data;\n        var size = this._size;\n        var obj = data[size];\n        if (! obj) {\n            // Constructor must have no parameters\n            obj = new this.ctor();\n            data[size] = obj;\n        }\n        this._size++;\n        return obj;\n    },\n\n    reset: function () {\n        this._size = 0;\n    },\n\n    shrink: function () {\n        this._data.length = this._size;\n    },\n\n    clear: function () {\n        this._data = [];\n        this._size = 0;\n    }\n}\n\nfunction Triangle() {\n    this.vertices = [vec4Create(), vec4Create(), vec4Create()];\n    this.color = vec4Create();\n\n    this.depth = 0;\n}\n\nTriangle.prototype.type = PRIMITIVE_TRIANGLE;\n\nfunction Point() {\n    // Here use an array to make it more convinient to proccessing in _setPrimitive method\n    this.vertices = [vec4Create()];\n\n    this.color = vec4Create();\n\n    this.depth = 0;\n}\n\nPoint.prototype.type = PRIMITIVE_POINT;\n\nfunction Line() {\n    this.vertices = [vec4Create(), vec4Create()];\n    this.color = vec4Create();\n\n    this.depth = 0;\n\n    this.lineWidth = 1;\n}\n\nLine.prototype.type = PRIMITIVE_LINE;\n\nfunction depthSortFunc(x, y) {\n    // Sort from far to near, which in depth of projection space is from larger to smaller\n    return y.depth - x.depth;\n}\n\nfunction vec3ToColorStr(v3) {\n    return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')';\n}\n\nfunction vec4ToColorStr(v4) {\n    return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')';\n}\n\nvar CanvasRenderer = Base.extend({\n\n    canvas: null,\n\n    _width: 100,\n\n    _height: 100,\n\n    devicePixelRatio: window.devicePixelRatio || 1.0,\n\n    color: [0.0, 0.0, 0.0, 0.0],\n\n    clear: true,\n\n    ctx: null,\n\n    // Cached primitive list, including triangle, line, point\n    _primitives: [],\n\n    // Triangle pool\n    _triangles: new PrimitivePool(Triangle),\n\n    // Line pool\n    _lines: new PrimitivePool(Line),\n\n    // Point pool\n    _points: new PrimitivePool(Point)\n}, function () {\n    if (! this.canvas) {\n        this.canvas = document.createElement('canvas');\n    }\n    var canvas = this.canvas;\n\n    try {\n        this.ctx = canvas.getContext('2d');\n        var ctx = this.ctx;\n        if (!ctx) {\n            throw new Error();\n        }\n    }\n    catch (e) {\n        throw 'Error creating WebGL Context ' + e;\n    }\n\n    this.resize();\n}, {\n\n    resize: function (width, height) {\n        var dpr = this.devicePixelRatio;\n        var canvas = this.canvas;\n        if (width != null) {\n            canvas.style.width = width + 'px';\n            canvas.style.height = height + 'px';\n            canvas.width = width * dpr;\n            canvas.height = height * dpr;\n\n            this._width = width;\n            this._height = height;\n        }\n        else {\n            this._width = canvas.width / dpr;\n            this._height = canvas.height / dpr;\n        }\n    },\n\n    getWidth: function () {\n        return this._width;\n    },\n\n    getHeight: function () {\n        return this._height;\n    },\n\n    getViewportAspect: function () {\n        return this._width / this._height;\n    },\n\n    render: function (scene, camera) {\n\n        if (this.clear) {\n            var color = this.color;\n            var ctx = this.ctx;\n            var dpr = this.devicePixelRatio;\n            var w = this._width * dpr;\n            var h = this._height * dpr;\n            if (color && color[3] === 0) {\n                ctx.clearRect(0, 0, w, h);\n            }\n            else {\n                // Has transparency\n                if (color[3] < 1) {\n                    ctx.clearRect(0, 0, w, h);\n                }\n                ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color);\n                ctx.fillRect(0, 0, w, h);\n            }\n        }\n\n        scene.update();\n        camera.update();\n\n        var opaqueList = scene.opaqueList;\n        var transparentList = scene.transparentList;\n        var sceneMaterial = scene.material;\n\n        var list = opaqueList.concat(transparentList);\n\n        this.renderPass(list, camera);\n    },\n\n    renderPass: function (list, camera) {\n        var viewProj = mat4.create();\n        mat4.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array);\n        var worldViewProjMat = mat4.create();\n        var posViewSpace = vec3.create();\n\n        var primitives = this._primitives;\n        var trianglesPool = this._triangles;\n        var linesPool = this._lines;\n        var pointsPool = this._points;\n\n        trianglesPool.reset();\n        linesPool.reset();\n        pointsPool.reset();\n\n        var nPrimitive = 0;\n\n        var indices = [0, 0, 0];\n        var matColor = [];\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n\n            mat4.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array);\n\n            var geometry = renderable.geometry;\n            var material = renderable.material;\n            var attributes = geometry.attributes;\n\n            // alpha is default 1\n            if (material.color.length == 3) {\n                vec3.copy(matColor, material.color);\n                matColor[3] = 1;\n            }\n            else {\n                vec4.copy(matColor, material.color);\n            }\n\n            var nVertex = geometry.vertexCount;\n            // Only support TRIANGLES, LINES, POINTS draw modes\n            switch (renderable.mode) {\n                case glenum.TRIANGLES:\n                    if (geometry.isUseIndices()) {\n                        var nFace = geometry.triangleCount;\n                        for (var j = 0; j < nFace; j++) {\n                            geometry.getFace(j, indices);\n\n                            var triangle = trianglesPool.pick();\n                            triangle.material = material;\n\n                            var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor);\n\n                            if (! clipped) {\n                                primitives[nPrimitive++] = triangle;\n                            }\n                        }\n                    }\n                    else {\n                        for (var j = 0; j < nVertex;) {\n                            indices[0] = j++;\n                            indices[1] = j++;\n                            indices[2] = j++;\n\n                            var triangle = trianglesPool.pick();\n                            triangle.material = material;\n\n                            var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor);\n\n                            if (! clipped) {\n                                primitives[nPrimitive++] = triangle;\n                            }\n                        }\n                    }\n                    break;\n                case glenum.LINES:\n                    // LINES mode can't use face\n                    for (var j = 0; j < nVertex;) {\n                        indices[0] = j++;\n                        indices[1] = j++;\n                        var line = linesPool.pick();\n                        line.material = material;\n                        line.lineWidth = renderable.lineWidth;\n\n                        var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor);\n\n                        if (! clipped) {\n                            primitives[nPrimitive++] = line;\n                        }\n                    }\n                    break;\n                case glenum.POINTS:\n                    for (var j = 0; j < nVertex; j++) {\n                        indices[0] = j;\n                        var point = pointsPool.pick();\n                        point.material = material;\n\n                        var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor);\n\n                        if (! clipped) {\n                            primitives[nPrimitive++] = point;\n                        }\n                    }\n                    // POINTS mode can't use face\n                    break;\n            }\n        }\n\n        trianglesPool.shrink();\n        linesPool.shrink();\n        pointsPool.shrink();\n\n        primitives.length = nPrimitive;\n\n        primitives.sort(depthSortFunc);\n        this._drawPrimitives(primitives);\n    },\n\n    _setPrimitive: (function () {\n        var vertexColor = vec4Create();\n        return function (primitive, indices, size, attributes, worldViewProjMat, matColor) {\n            var colorAttrib = attributes.color;\n            var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0;\n            var priColor = primitive.color;\n\n            primitive.depth = 0;\n            if (useVertexColor) {\n                vec4.set(priColor, 0, 0, 0, 0);\n            }\n\n            var clipped = true;\n\n            var percent = 1 / size;\n            for (var i = 0; i < size; i++) {\n                var coord = primitive.vertices[i];\n                attributes.position.get(indices[i], coord);\n                coord[3] = 1;\n                vec4.transformMat4(coord, coord, worldViewProjMat);\n                if (useVertexColor) {\n                    colorAttrib.get(indices[i], vertexColor);\n                    // Average vertex color\n                    // Each primitive only call fill or stroke once\n                    // So color must be the same\n                    vec4.scaleAndAdd(priColor, priColor, vertexColor, percent);\n                }\n\n                // Clipping\n                var x = coord[0];\n                var y = coord[1];\n                var z = coord[2];\n                var w = coord[3];\n\n                // TODO Point clipping\n                if (x > -w && x < w && y > -w && y < w && z > -w && z < w) {\n                    clipped = false;\n                }\n\n                var invW = 1 / w;\n                coord[0] = x * invW;\n                coord[1] = y * invW;\n                coord[2] = z * invW;\n                // Use primitive average depth;\n                primitive.depth += coord[2];\n            }\n\n            if (! clipped) {\n                primitive.depth /= size;\n\n                if (useVertexColor) {\n                    vec4.mul(priColor, priColor, matColor);\n                }\n                else {\n                    vec4.copy(priColor, matColor);\n                }\n            }\n\n            return clipped;\n        }\n    })(),\n\n    _drawPrimitives: function (primitives) {\n        var ctx = this.ctx;\n        ctx.save();\n\n        var prevMaterial;\n\n        var dpr = this.devicePixelRatio;\n        var width = this._width * dpr;\n        var height = this._height * dpr;\n        var halfWidth = width / 2;\n        var halfHeight = height / 2;\n\n        var prevLineWidth;\n        var prevStrokeColor;\n\n        for (var i = 0; i < primitives.length; i++) {\n            var primitive = primitives[i];\n            var vertices = primitive.vertices;\n\n            var primitiveType = primitive.type;\n            var material = primitive.material;\n            if (material !== prevMaterial) {\n                // Set material\n                ctx.globalAlpha = material.opacity;\n                prevMaterial = material;\n            }\n\n            var colorStr = vec4ToColorStr(primitive.color);\n            switch (primitiveType) {\n                case PRIMITIVE_TRIANGLE:\n                    var v0 = vertices[0];\n                    var v1 = vertices[1];\n                    var v2 = vertices[2];\n                    ctx.fillStyle = colorStr;\n                    ctx.beginPath();\n                    ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight);\n                    ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight);\n                    ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight);\n                    ctx.closePath();\n                    ctx.fill();\n                    break;\n                case PRIMITIVE_LINE:\n                    var v0 = vertices[0];\n                    var v1 = vertices[1];\n                    var lineWidth = primitive.lineWidth;\n                    if (prevStrokeColor !== colorStr) {\n                        prevStrokeColor = ctx.strokeStyle = colorStr;\n                    }\n                    if (lineWidth !== prevLineWidth) {\n                        ctx.lineWidth = prevLineWidth = lineWidth;\n                    }\n                    ctx.beginPath();\n                    ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight);\n                    ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight);\n                    ctx.stroke();\n                    break;\n                case PRIMITIVE_POINT:\n                    var pointSize = material.pointSize;\n                    var pointShape = material.pointShape;\n                    var halfSize = pointSize / 2;\n                    if (pointSize > 0) {\n                        var v0 = vertices[0];\n                        var cx = (v0[0] + 1) * halfWidth;\n                        var cy = (-v0[1] + 1) * halfHeight;\n\n                        ctx.fillStyle = colorStr;\n                        if (pointShape === 'rectangle') {\n                            ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize);\n                        }\n                        else if (pointShape === 'circle') {\n                            ctx.beginPath();\n                            ctx.arc(cx, cy, halfSize, 0, Math.PI * 2);\n                            ctx.fill();\n                        }\n                    }\n                    break;\n            }\n        }\n\n        ctx.restore();\n    },\n\n    dispose: function () {\n        this._triangles.clear();\n        this._lines.clear();\n        this._points.clear();\n        this._primitives = [];\n\n        this.ctx = null;\n        this.canvas = null;\n    }\n});\n\nexport default CanvasRenderer;\n","import Base from '../core/Base';\n\n// PENDING\n// Use topological sort ?\n\n/**\n * Node of graph based post processing.\n *\n * @constructor clay.compositor.Node\n * @extends clay.core.Base\n *\n */\nvar Node = Base.extend(function () {\n    return /** @lends clay.compositor.Node# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * Input links, will be updated by the graph\n         * @example:\n         *     inputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        inputLinks: {},\n\n        /**\n         * Output links, will be updated by the graph\n         * @example:\n         *     outputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        outputLinks: {},\n\n        // Save the output texture of previous frame\n        // Will be used when there exist a circular reference\n        _prevOutputTextures: {},\n        _outputTextures: {},\n\n        // Example: { name: 2 }\n        _outputReferences: {},\n\n        _rendering: false,\n        // If rendered in this frame\n        _rendered: false,\n\n        _compositor: null\n    };\n},\n/** @lends clay.compositor.Node.prototype */\n{\n\n    // TODO Remove parameter function callback\n    updateParameter: function (outputName, renderer) {\n        var outputInfo = this.outputs[outputName];\n        var parameters = outputInfo.parameters;\n        var parametersCopy = outputInfo._parametersCopy;\n        if (!parametersCopy) {\n            parametersCopy = outputInfo._parametersCopy = {};\n        }\n        if (parameters) {\n            for (var key in parameters) {\n                if (key !== 'width' && key !== 'height') {\n                    parametersCopy[key] = parameters[key];\n                }\n            }\n        }\n        var width, height;\n        if (parameters.width instanceof Function) {\n            width = parameters.width.call(this, renderer);\n        }\n        else {\n            width = parameters.width;\n        }\n        if (parameters.height instanceof Function) {\n            height = parameters.height.call(this, renderer);\n        }\n        else {\n            height = parameters.height;\n        }\n        if (\n            parametersCopy.width !== width\n            || parametersCopy.height !== height\n        ) {\n            if (this._outputTextures[outputName]) {\n                this._outputTextures[outputName].dispose(renderer.gl);\n            }\n        }\n        parametersCopy.width = width;\n        parametersCopy.height = height;\n\n        return parametersCopy;\n    },\n\n    /**\n     * Set parameter\n     * @param {string} name\n     * @param {} value\n     */\n    setParameter: function (name, value) {},\n    /**\n     * Get parameter value\n     * @param  {string} name\n     * @return {}\n     */\n    getParameter: function (name) {},\n    /**\n     * Set parameters\n     * @param {Object} obj\n     */\n    setParameters: function (obj) {\n        for (var name in obj) {\n            this.setParameter(name, obj[name]);\n        }\n    },\n\n    render: function () {},\n\n    getOutput: function (renderer /*optional*/, name) {\n        if (name == null) {\n            // Return the output texture without rendering\n            name = renderer;\n            return this._outputTextures[name];\n        }\n        var outputInfo = this.outputs[name];\n        if (!outputInfo) {\n            return ;\n        }\n\n        // Already been rendered in this frame\n        if (this._rendered) {\n            // Force return texture in last frame\n            if (outputInfo.outputLastFrame) {\n                return this._prevOutputTextures[name];\n            }\n            else {\n                return this._outputTextures[name];\n            }\n        }\n        else if (\n            // TODO\n            this._rendering   // Solve Circular Reference\n        ) {\n            if (!this._prevOutputTextures[name]) {\n                // Create a blank texture at first pass\n                this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {});\n            }\n            return this._prevOutputTextures[name];\n        }\n\n        this.render(renderer);\n\n        return this._outputTextures[name];\n    },\n\n    removeReference: function (outputName) {\n        this._outputReferences[outputName]--;\n        if (this._outputReferences[outputName] === 0) {\n            var outputInfo = this.outputs[outputName];\n            if (outputInfo.keepLastFrame) {\n                if (this._prevOutputTextures[outputName]) {\n                    this._compositor.releaseTexture(this._prevOutputTextures[outputName]);\n                }\n                this._prevOutputTextures[outputName] = this._outputTextures[outputName];\n            }\n            else {\n                // Output of this node have alreay been used by all other nodes\n                // Put the texture back to the pool.\n                this._compositor.releaseTexture(this._outputTextures[outputName]);\n            }\n        }\n    },\n\n    link: function (inputPinName, fromNode, fromPinName) {\n\n        // The relationship from output pin to input pin is one-on-multiple\n        this.inputLinks[inputPinName] = {\n            node: fromNode,\n            pin: fromPinName\n        };\n        if (!fromNode.outputLinks[fromPinName]) {\n            fromNode.outputLinks[fromPinName] = [];\n        }\n        fromNode.outputLinks[fromPinName].push({\n            node: this,\n            pin: inputPinName\n        });\n\n        // Enabled the pin texture in shader\n        this.pass.material.enableTexture(inputPinName);\n    },\n\n    clear: function () {\n        this.inputLinks = {};\n        this.outputLinks = {};\n    },\n\n    updateReference: function (outputName) {\n        if (!this._rendering) {\n            this._rendering = true;\n            for (var inputName in this.inputLinks) {\n                var link = this.inputLinks[inputName];\n                link.node.updateReference(link.pin);\n            }\n            this._rendering = false;\n        }\n        if (outputName) {\n            this._outputReferences[outputName] ++;\n        }\n    },\n\n    beforeFrame: function () {\n        this._rendered = false;\n\n        for (var name in this.outputLinks) {\n            this._outputReferences[name] = 0;\n        }\n    },\n\n    afterFrame: function () {\n        // Put back all the textures to pool\n        for (var name in this.outputLinks) {\n            if (this._outputReferences[name] > 0) {\n                var outputInfo = this.outputs[name];\n                if (outputInfo.keepLastFrame) {\n                    if (this._prevOutputTextures[name]) {\n                        this._compositor.releaseTexture(this._prevOutputTextures[name]);\n                    }\n                    this._prevOutputTextures[name] = this._outputTextures[name];\n                }\n                else {\n                    this._compositor.releaseTexture(this._outputTextures[name]);\n                }\n            }\n        }\n    }\n});\n\nexport default Node;\n","import Base from '../core/Base';\nimport GraphNode from './Node';\n\n/**\n * @constructor clay.compositor.Graph\n * @extends clay.core.Base\n */\nvar Graph = Base.extend(function () {\n    return /** @lends clay.compositor.Graph# */ {\n        /**\n         * @type {Array.<clay.compositor.Node>}\n         */\n        nodes: []\n    };\n},\n/** @lends clay.compositor.Graph.prototype */\n{\n\n    /**\n     * Mark to update\n     */\n    dirty: function () {\n        this._dirty = true;\n    },\n    /**\n     * @param {clay.compositor.Node} node\n     */\n    addNode: function (node) {\n\n        if (this.nodes.indexOf(node) >= 0) {\n            return;\n        }\n\n        this.nodes.push(node);\n\n        this._dirty = true;\n    },\n    /**\n     * @param  {clay.compositor.Node|string} node\n     */\n    removeNode: function (node) {\n        if (typeof node === 'string') {\n            node = this.getNodeByName(node);\n        }\n        var idx = this.nodes.indexOf(node);\n        if (idx >= 0) {\n            this.nodes.splice(idx, 1);\n            this._dirty = true;\n        }\n    },\n    /**\n     * @param {string} name\n     * @return {clay.compositor.Node}\n     */\n    getNodeByName: function (name) {\n        for (var i = 0; i < this.nodes.length; i++) {\n            if (this.nodes[i].name === name) {\n                return this.nodes[i];\n            }\n        }\n    },\n    /**\n     * Update links of graph\n     */\n    update: function () {\n        for (var i = 0; i < this.nodes.length; i++) {\n            this.nodes[i].clear();\n        }\n        // Traverse all the nodes and build the graph\n        for (var i = 0; i < this.nodes.length; i++) {\n            var node = this.nodes[i];\n\n            if (!node.inputs) {\n                continue;\n            }\n            for (var inputName in node.inputs) {\n                if (!node.inputs[inputName]) {\n                    continue;\n                }\n                if (node.pass && !node.pass.material.isUniformEnabled(inputName)) {\n                    console.warn('Pin '  + node.name + '.' + inputName + ' not used.');\n                    continue;\n                }\n                var fromPinInfo = node.inputs[inputName];\n\n                var fromPin = this.findPin(fromPinInfo);\n                if (fromPin) {\n                    node.link(inputName, fromPin.node, fromPin.pin);\n                }\n                else {\n                    if (typeof fromPinInfo === 'string') {\n                        console.warn('Node ' + fromPinInfo + ' not exist');\n                    }\n                    else {\n                        console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist');\n                    }\n                }\n            }\n        }\n    },\n\n    findPin: function (input) {\n        var node;\n        // Try to take input as a directly a node\n        if (typeof input === 'string' || input instanceof GraphNode) {\n            input = {\n                node: input\n            };\n        }\n\n        if (typeof input.node === 'string') {\n            for (var i = 0; i < this.nodes.length; i++) {\n                var tmp = this.nodes[i];\n                if (tmp.name === input.node) {\n                    node = tmp;\n                }\n            }\n        }\n        else {\n            node = input.node;\n        }\n        if (node) {\n            var inputPin = input.pin;\n            if (!inputPin) {\n                // Use first pin defaultly\n                if (node.outputs) {\n                    inputPin = Object.keys(node.outputs)[0];\n                }\n            }\n            if (node.outputs[inputPin]) {\n                return {\n                    node: node,\n                    pin: inputPin\n                };\n            }\n        }\n    }\n});\n\nexport default Graph;\n","import Graph from './Graph';\nimport TexturePool from './TexturePool';\nimport FrameBuffer from '../FrameBuffer';\n\n/**\n * Compositor provide graph based post processing\n *\n * @constructor clay.compositor.Compositor\n * @extends clay.compositor.Graph\n *\n */\nvar Compositor = Graph.extend(function() {\n    return {\n        // Output node\n        _outputs: [],\n\n        _texturePool: new TexturePool(),\n\n        _frameBuffer: new FrameBuffer({\n            depthBuffer: false\n        })\n    };\n},\n/** @lends clay.compositor.Compositor.prototype */\n{\n    addNode: function(node) {\n        Graph.prototype.addNode.call(this, node);\n        node._compositor = this;\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    render: function(renderer, frameBuffer) {\n        if (this._dirty) {\n            this.update();\n            this._dirty = false;\n\n            this._outputs.length = 0;\n            for (var i = 0; i < this.nodes.length; i++) {\n                if (!this.nodes[i].outputs) {\n                    this._outputs.push(this.nodes[i]);\n                }\n            }\n        }\n\n        for (var i = 0; i < this.nodes.length; i++) {\n            // Update the reference number of each output texture\n            this.nodes[i].beforeFrame();\n        }\n\n        for (var i = 0; i < this._outputs.length; i++) {\n            this._outputs[i].updateReference();\n        }\n\n        for (var i = 0; i < this._outputs.length; i++) {\n            this._outputs[i].render(renderer, frameBuffer);\n        }\n\n        for (var i = 0; i < this.nodes.length; i++) {\n            // Clear up\n            this.nodes[i].afterFrame();\n        }\n    },\n\n    allocateTexture: function (parameters) {\n        return this._texturePool.get(parameters);\n    },\n\n    releaseTexture: function (parameters) {\n        this._texturePool.put(parameters);\n    },\n\n    getFrameBuffer: function () {\n        return this._frameBuffer;\n    },\n\n    /**\n     * Dispose compositor\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._texturePool.clear(renderer);\n    }\n});\n\nexport default Compositor;\n","import Node from './Node';\nimport glenum from '../core/glenum';\nimport FrameBuffer from '../FrameBuffer';\n\n/**\n * @constructor clay.compositor.SceneNode\n * @extends clay.compositor.Node\n */\nvar SceneNode = Node.extend(\n/** @lends clay.compositor.SceneNode# */\n{\n    name: 'scene',\n    /**\n     * @type {clay.Scene}\n     */\n    scene: null,\n    /**\n     * @type {clay.Camera}\n     */\n    camera: null,\n    /**\n     * @type {boolean}\n     */\n    autoUpdateScene: true,\n    /**\n     * @type {boolean}\n     */\n    preZ: false\n\n}, function() {\n    this.frameBuffer = new FrameBuffer();\n}, {\n    render: function(renderer) {\n\n        this._rendering = true;\n        var _gl = renderer.gl;\n\n        this.trigger('beforerender');\n\n        var renderInfo;\n\n        if (!this.outputs) {\n\n            renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ);\n\n        }\n        else {\n\n            var frameBuffer = this.frameBuffer;\n            for (var name in this.outputs) {\n                var parameters = this.updateParameter(name, renderer);\n                var outputInfo = this.outputs[name];\n                var texture = this._compositor.allocateTexture(parameters);\n                this._outputTextures[name] = texture;\n\n                var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0;\n                if (typeof(attachment) == 'string') {\n                    attachment = _gl[attachment];\n                }\n                frameBuffer.attach(texture, attachment);\n            }\n            frameBuffer.bind(renderer);\n\n            // MRT Support in chrome\n            // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html\n            var ext = renderer.getGLExtension('EXT_draw_buffers');\n            if (ext) {\n                var bufs = [];\n                for (var attachment in this.outputs) {\n                    attachment = parseInt(attachment);\n                    if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) {\n                        bufs.push(attachment);\n                    }\n                }\n                ext.drawBuffersEXT(bufs);\n            }\n\n            // Always clear\n            // PENDING\n            renderer.saveClear();\n            renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT;\n            renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ);\n            renderer.restoreClear();\n\n            frameBuffer.unbind(renderer);\n        }\n\n        this.trigger('afterrender', renderInfo);\n\n        this._rendering = false;\n        this._rendered = true;\n    }\n});\n\nexport default SceneNode;\n","import Node from './Node';\n\n/**\n * @constructor clay.compositor.TextureNode\n * @extends clay.compositor.Node\n */\nvar TextureNode = Node.extend(function() {\n    return /** @lends clay.compositor.TextureNode# */ {\n        /**\n         * @type {clay.Texture2D}\n         */\n        texture: null,\n\n        // Texture node must have output without parameters\n        outputs: {\n            color: {}\n        }\n    };\n}, function () {\n}, {\n\n    getOutput: function (renderer, name) {\n        return this.texture;\n    },\n\n    // Do nothing\n    beforeFrame: function () {},\n    afterFrame: function () {}\n});\n\nexport default TextureNode;\n","// TODO Shader library\nimport Pass from './Pass';\nimport Node from './Node';\n\n// TODO curlnoise demo wrong\n\n// PENDING\n// Use topological sort ?\n\n/**\n * Filter node\n *\n * @constructor clay.compositor.FilterNode\n * @extends clay.compositor.Node\n *\n * @example\n    var node = new clay.compositor.Node({\n        name: 'fxaa',\n        shader: clay.Shader.source('clay.compositor.fxaa'),\n        inputs: {\n            texture: {\n                    node: 'scene',\n                    pin: 'color'\n            }\n        },\n        // Multiple outputs is preserved for MRT support in WebGL2.0\n        outputs: {\n            color: {\n                attachment: clay.FrameBuffer.COLOR_ATTACHMENT0\n                parameters: {\n                    format: clay.Texture.RGBA,\n                    width: 512,\n                    height: 512\n                },\n                // Node will keep the RTT rendered in last frame\n                keepLastFrame: true,\n                // Force the node output the RTT rendered in last frame\n                outputLastFrame: true\n            }\n        }\n    });\n    *\n    */\nvar FilterNode = Node.extend(function () {\n    return /** @lends clay.compositor.Node# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * @type {Object}\n         */\n        inputs: {},\n\n        /**\n         * @type {Object}\n         */\n        outputs: null,\n\n        /**\n         * @type {string}\n         */\n        shader: '',\n\n        /**\n         * Input links, will be updated by the graph\n         * @example:\n         *     inputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        inputLinks: {},\n\n        /**\n         * Output links, will be updated by the graph\n         * @example:\n         *     outputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        outputLinks: {},\n\n        /**\n         * @type {clay.compositor.Pass}\n         */\n        pass: null,\n\n        // Save the output texture of previous frame\n        // Will be used when there exist a circular reference\n        _prevOutputTextures: {},\n        _outputTextures: {},\n\n        // Example: { name: 2 }\n        _outputReferences: {},\n\n        _rendering: false,\n        // If rendered in this frame\n        _rendered: false,\n\n        _compositor: null\n    };\n}, function () {\n\n    var pass = new Pass({\n        fragment: this.shader\n    });\n    this.pass = pass;\n},\n/** @lends clay.compositor.Node.prototype */\n{\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    render: function (renderer, frameBuffer) {\n        this.trigger('beforerender', renderer);\n\n        this._rendering = true;\n\n        var _gl = renderer.gl;\n\n        for (var inputName in this.inputLinks) {\n            var link = this.inputLinks[inputName];\n            var inputTexture = link.node.getOutput(renderer, link.pin);\n            this.pass.setUniform(inputName, inputTexture);\n        }\n        // Output\n        if (!this.outputs) {\n            this.pass.outputs = null;\n\n            this._compositor.getFrameBuffer().unbind(renderer);\n\n            this.pass.render(renderer, frameBuffer);\n        }\n        else {\n            this.pass.outputs = {};\n\n            var attachedTextures = {};\n            for (var name in this.outputs) {\n                var parameters = this.updateParameter(name, renderer);\n                if (isNaN(parameters.width)) {\n                    this.updateParameter(name, renderer);\n                }\n                var outputInfo = this.outputs[name];\n                var texture = this._compositor.allocateTexture(parameters);\n                this._outputTextures[name] = texture;\n                var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0;\n                if (typeof(attachment) == 'string') {\n                    attachment = _gl[attachment];\n                }\n                attachedTextures[attachment] = texture;\n            }\n            this._compositor.getFrameBuffer().bind(renderer);\n\n            for (var attachment in attachedTextures) {\n                // FIXME attachment changes in different nodes\n                this._compositor.getFrameBuffer().attach(\n                    attachedTextures[attachment], attachment\n                );\n            }\n\n            this.pass.render(renderer);\n\n            // Because the data of texture is changed over time,\n            // Here update the mipmaps of texture each time after rendered;\n            this._compositor.getFrameBuffer().updateMipmap(renderer.gl);\n        }\n\n        for (var inputName in this.inputLinks) {\n            var link = this.inputLinks[inputName];\n            link.node.removeReference(link.pin);\n        }\n\n        this._rendering = false;\n        this._rendered = true;\n\n        this.trigger('afterrender', renderer);\n    },\n\n    // TODO Remove parameter function callback\n    updateParameter: function (outputName, renderer) {\n        var outputInfo = this.outputs[outputName];\n        var parameters = outputInfo.parameters;\n        var parametersCopy = outputInfo._parametersCopy;\n        if (!parametersCopy) {\n            parametersCopy = outputInfo._parametersCopy = {};\n        }\n        if (parameters) {\n            for (var key in parameters) {\n                if (key !== 'width' && key !== 'height') {\n                    parametersCopy[key] = parameters[key];\n                }\n            }\n        }\n        var width, height;\n        if (parameters.width instanceof Function) {\n            width = parameters.width.call(this, renderer);\n        }\n        else {\n            width = parameters.width;\n        }\n        if (parameters.height instanceof Function) {\n            height = parameters.height.call(this, renderer);\n        }\n        else {\n            height = parameters.height;\n        }\n        if (\n            parametersCopy.width !== width\n            || parametersCopy.height !== height\n        ) {\n            if (this._outputTextures[outputName]) {\n                this._outputTextures[outputName].dispose(renderer);\n            }\n        }\n        parametersCopy.width = width;\n        parametersCopy.height = height;\n\n        return parametersCopy;\n    },\n\n    /**\n     * Set parameter\n     * @param {string} name\n     * @param {} value\n     */\n    setParameter: function (name, value) {\n        this.pass.setUniform(name, value);\n    },\n    /**\n     * Get parameter value\n     * @param  {string} name\n     * @return {}\n     */\n    getParameter: function (name) {\n        return this.pass.getUniform(name);\n    },\n    /**\n     * Set parameters\n     * @param {Object} obj\n     */\n    setParameters: function (obj) {\n        for (var name in obj) {\n            this.setParameter(name, obj[name]);\n        }\n    },\n    // /**\n    //  * Set shader code\n    //  * @param {string} shaderStr\n    //  */\n    // setShader: function (shaderStr) {\n    //     var material = this.pass.material;\n    //     material.shader.setFragment(shaderStr);\n    //     material.attachShader(material.shader, true);\n    // },\n    /**\n     * Proxy of pass.material.define('fragment', xxx);\n     * @param  {string} symbol\n     * @param  {number} [val]\n     */\n    define: function (symbol, val) {\n        this.pass.material.define('fragment', symbol, val);\n    },\n\n    /**\n     * Proxy of pass.material.undefine('fragment', xxx)\n     * @param  {string} symbol\n     */\n    undefine: function (symbol) {\n        this.pass.material.undefine('fragment', symbol);\n    },\n\n    removeReference: function (outputName) {\n        this._outputReferences[outputName]--;\n        if (this._outputReferences[outputName] === 0) {\n            var outputInfo = this.outputs[outputName];\n            if (outputInfo.keepLastFrame) {\n                if (this._prevOutputTextures[outputName]) {\n                    this._compositor.releaseTexture(this._prevOutputTextures[outputName]);\n                }\n                this._prevOutputTextures[outputName] = this._outputTextures[outputName];\n            }\n            else {\n                // Output of this node have alreay been used by all other nodes\n                // Put the texture back to the pool.\n                this._compositor.releaseTexture(this._outputTextures[outputName]);\n            }\n        }\n    },\n\n    clear: function () {\n        Node.prototype.clear.call(this);\n\n        // Default disable all texture\n        this.pass.material.disableTexturesAll();\n    }\n});\n\nexport default FilterNode;\n","import util from '../core/util';\nimport Compositor from './Compositor';\nimport CompoSceneNode from './SceneNode';\nimport CompoTextureNode from './TextureNode';\nimport CompoFilterNode from './FilterNode';\nimport Shader from '../Shader';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\n\nvar shaderSourceReg = /^#source\\((.*?)\\)/;\n\n/**\n * @param {Object} json\n * @param {Object} [opts]\n * @return {clay.compositor.Compositor}\n */\nfunction createCompositor(json, opts) {\n    var compositor = new Compositor();\n    opts = opts || {};\n\n    var lib = {\n        textures: {},\n        parameters: {}\n    };\n    var afterLoad = function(shaderLib, textureLib) {\n        for (var i = 0; i < json.nodes.length; i++) {\n            var nodeInfo = json.nodes[i];\n            var node = createNode(nodeInfo, lib, opts);\n            if (node) {\n                compositor.addNode(node);\n            }\n        }\n    };\n\n    for (var name in json.parameters) {\n        var paramInfo = json.parameters[name];\n        lib.parameters[name] = convertParameter(paramInfo);\n    }\n    // TODO load texture asynchronous\n    loadTextures(json, lib, opts, function(textureLib) {\n        lib.textures = textureLib;\n        afterLoad();\n    });\n\n    return compositor;\n}\n\nfunction createNode(nodeInfo, lib, opts) {\n    var type = nodeInfo.type || 'filter';\n    var shaderSource;\n    var inputs;\n    var outputs;\n\n    if (type === 'filter') {\n        var shaderExp = nodeInfo.shader.trim();\n        var res = shaderSourceReg.exec(shaderExp);\n        if (res) {\n            shaderSource = Shader.source(res[1].trim());\n        }\n        else if (shaderExp.charAt(0) === '#') {\n            shaderSource = lib.shaders[shaderExp.substr(1)];\n        }\n        if (!shaderSource) {\n            shaderSource = shaderExp;\n        }\n        if (!shaderSource) {\n            return;\n        }\n    }\n\n    if (nodeInfo.inputs) {\n        inputs = {};\n        for (var name in nodeInfo.inputs) {\n            if (typeof nodeInfo.inputs[name] === 'string') {\n                inputs[name] = nodeInfo.inputs[name];\n            }\n            else {\n                inputs[name] = {\n                    node: nodeInfo.inputs[name].node,\n                    pin: nodeInfo.inputs[name].pin\n                };\n            }\n        }\n    }\n    if (nodeInfo.outputs) {\n        outputs = {};\n        for (var name in nodeInfo.outputs) {\n            var outputInfo = nodeInfo.outputs[name];\n            outputs[name] = {};\n            if (outputInfo.attachment != null) {\n                outputs[name].attachment = outputInfo.attachment;\n            }\n            if (outputInfo.keepLastFrame != null) {\n                outputs[name].keepLastFrame = outputInfo.keepLastFrame;\n            }\n            if (outputInfo.outputLastFrame != null) {\n                outputs[name].outputLastFrame = outputInfo.outputLastFrame;\n            }\n            if (outputInfo.parameters) {\n                outputs[name].parameters = convertParameter(outputInfo.parameters);\n            }\n        }\n    }\n    var node;\n    if (type === 'scene') {\n        node = new CompoSceneNode({\n            name: nodeInfo.name,\n            scene: opts.scene,\n            camera: opts.camera,\n            outputs: outputs\n        });\n    }\n    else if (type === 'texture') {\n        node = new CompoTextureNode({\n            name: nodeInfo.name,\n            outputs: outputs\n        });\n    }\n    // Default is filter\n    else {\n        node = new CompoFilterNode({\n            name: nodeInfo.name,\n            shader: shaderSource,\n            inputs: inputs,\n            outputs: outputs\n        });\n    }\n    if (node) {\n        if (nodeInfo.parameters) {\n            for (var name in nodeInfo.parameters) {\n                var val = nodeInfo.parameters[name];\n                if (typeof(val) === 'string') {\n                    val = val.trim();\n                    if (val.charAt(0) === '#') {\n                        val = lib.textures[val.substr(1)];\n                    }\n                    else {\n                        node.on(\n                            'beforerender', createSizeSetHandler(\n                                name, tryConvertExpr(val)\n                            )\n                        );\n                    }\n                }\n                node.setParameter(name, val);\n            }\n        }\n        if (nodeInfo.defines && node.pass) {\n            for (var name in nodeInfo.defines) {\n                var val = nodeInfo.defines[name];\n                node.pass.material.define('fragment', name, val);\n            }\n        }\n    }\n    return node;\n}\n\nfunction convertParameter(paramInfo) {\n    var param = {};\n    if (!paramInfo) {\n        return param;\n    }\n    ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap']\n        .forEach(function(name) {\n            var val = paramInfo[name];\n            if (val != null) {\n                // Convert string to enum\n                if (typeof val === 'string') {\n                    val = Texture[val];\n                }\n                param[name] = val;\n            }\n        });\n    ['width', 'height']\n        .forEach(function(name) {\n            if (paramInfo[name] != null) {\n                var val = paramInfo[name];\n                if (typeof val === 'string') {\n                    val = val.trim();\n                    param[name] = createSizeParser(\n                        name, tryConvertExpr(val)\n                    );\n                }\n                else {\n                    param[name] = val;\n                }\n            }\n        });\n    if (paramInfo.useMipmap != null) {\n        param.useMipmap = paramInfo.useMipmap;\n    }\n    return param;\n}\n\nfunction loadTextures(json, lib, opts, callback) {\n    if (!json.textures) {\n        callback({});\n        return;\n    }\n    var textures = {};\n    var loading = 0;\n\n    var cbd = false;\n    var textureRootPath = opts.textureRootPath;\n    util.each(json.textures, function(textureInfo, name) {\n        var texture;\n        var path = textureInfo.path;\n        var parameters = convertParameter(textureInfo.parameters);\n        if (Array.isArray(path) && path.length === 6) {\n            if (textureRootPath) {\n                path = path.map(function(item) {\n                    return util.relative2absolute(item, textureRootPath);\n                });\n            }\n            texture = new TextureCube(parameters);\n        }\n        else if(typeof path === 'string') {\n            if (textureRootPath) {\n                path = util.relative2absolute(path, textureRootPath);\n            }\n            texture = new Texture2D(parameters);\n        }\n        else {\n            return;\n        }\n\n        texture.load(path);\n        loading++;\n        texture.once('success', function() {\n            textures[name] = texture;\n            loading--;\n            if (loading === 0) {\n                callback(textures);\n                cbd = true;\n            }\n        });\n    });\n\n    if (loading === 0 && !cbd) {\n        callback(textures);\n    }\n}\n\nfunction createSizeSetHandler(name, exprFunc) {\n    return function (renderer) {\n        // PENDING viewport size or window size\n        var dpr = renderer.getDevicePixelRatio();\n        // PENDING If multiply dpr ?\n        var width = renderer.getWidth();\n        var height = renderer.getHeight();\n        var result = exprFunc(width, height, dpr);\n        this.setParameter(name, result);\n    };\n}\n\nfunction createSizeParser(name, exprFunc) {\n    return function (renderer) {\n        var dpr = renderer.getDevicePixelRatio();\n        var width = renderer.getWidth();\n        var height = renderer.getHeight();\n        return exprFunc(width, height, dpr);\n    };\n}\n\nfunction tryConvertExpr(string) {\n    // PENDING\n    var exprRes = /^expr\\((.*)\\)$/.exec(string);\n    if (exprRes) {\n        try {\n            var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]);\n            // Try run t\n            func(1, 1);\n\n            return func;\n        }\n        catch (e) {\n            throw new Error('Invalid expression.');\n        }\n    }\n}\n\nexport default createCompositor;\n","export default \"@export clay.deferred.gbuffer.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat;\\nuniform vec2 uvOffset;\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\n#ifdef FIRST_PASS\\nattribute vec3 normal : NORMAL;\\n#endif\\n@import clay.chunk.skinning_header\\n#ifdef FIRST_PASS\\nvarying vec3 v_Normal;\\nattribute vec4 tangent : TANGENT;\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\nvarying vec3 v_WorldPosition;\\n#endif\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef FIRST_PASS\\n    vec3 skinnedNormal = normal;\\n    vec3 skinnedTangent = tangent.xyz;\\n    bool hasTangent = dot(tangent, tangent) > 0.0;\\n#endif\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    #ifdef FIRST_PASS\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n    if (hasTangent) {\\n        skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\\n    }\\n    #endif\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n#ifdef FIRST_PASS\\n    v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\\n    if (hasTangent) {\\n        v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\\n        v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\\n    }\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n#endif\\n}\\n@end\\n@export clay.deferred.gbuffer1.fragment\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform float glossiness;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nuniform sampler2D normalMap;\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\nuniform sampler2D roughGlossMap;\\nuniform bool useRoughGlossMap;\\nuniform bool useRoughness;\\nuniform bool doubleSided;\\nuniform int roughGlossChannel: 0;\\nfloat indexingTexel(in vec4 texel, in int idx) {\\n    if (idx == 3) return texel.a;\\n    else if (idx == 1) return texel.g;\\n    else if (idx == 2) return texel.b;\\n    else return texel.r;\\n}\\nvoid main()\\n{\\n    vec3 N = v_Normal;\\n    if (doubleSided) {\\n        vec3 eyePos = viewInverse[3].xyz;\\n        vec3 V = eyePos - v_WorldPosition;\\n        if (dot(N, V) < 0.0) {\\n            N = -N;\\n        }\\n    }\\n    if (dot(v_Tangent, v_Tangent) > 0.0) {\\n        vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\\n        if (dot(normalTexel, normalTexel) > 0.0) {            N = normalTexel * 2.0 - 1.0;\\n            mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\\n            N = normalize(tbn * N);\\n        }\\n    }\\n    gl_FragColor.rgb = (N + 1.0) * 0.5;\\n    float g = glossiness;\\n    if (useRoughGlossMap) {\\n        float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\\n        if (useRoughness) {\\n            g2 = 1.0 - g2;\\n        }\\n        g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    }\\n    gl_FragColor.a = g + 0.005;\\n}\\n@end\\n@export clay.deferred.gbuffer2.fragment\\nuniform sampler2D diffuseMap;\\nuniform sampler2D metalnessMap;\\nuniform vec3 color;\\nuniform float metalness;\\nuniform bool useMetalnessMap;\\nuniform bool linear;\\nvarying vec2 v_Texcoord;\\n@import clay.util.srgb\\nvoid main ()\\n{\\n    float m = metalness;\\n    if (useMetalnessMap) {\\n        vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\\n        m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\\n    }\\n    vec4 texel = texture2D(diffuseMap, v_Texcoord);\\n    if (linear) {\\n        texel = sRGBToLinear(texel);\\n    }\\n    gl_FragColor.rgb = texel.rgb * color;\\n    gl_FragColor.a = m + 0.005;\\n}\\n@end\\n@export clay.deferred.gbuffer.debug\\n@import clay.deferred.chunk.light_head\\nuniform int debug: 0;\\nvoid main ()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    if (debug == 0) {\\n        gl_FragColor = vec4(N, 1.0);\\n    }\\n    else if (debug == 1) {\\n        gl_FragColor = vec4(vec3(z), 1.0);\\n    }\\n    else if (debug == 2) {\\n        gl_FragColor = vec4(position, 1.0);\\n    }\\n    else if (debug == 3) {\\n        gl_FragColor = vec4(vec3(glossiness), 1.0);\\n    }\\n    else if (debug == 4) {\\n        gl_FragColor = vec4(vec3(metalness), 1.0);\\n    }\\n    else {\\n        gl_FragColor = vec4(albedo, 1.0);\\n    }\\n}\\n@end\";\n","export default \"@export clay.deferred.chunk.light_head\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture2;\\nuniform sampler2D gBufferTexture3;\\nuniform vec2 windowSize: WINDOW_SIZE;\\nuniform vec4 viewport: VIEWPORT;\\nuniform mat4 viewProjectionInv;\\n#ifdef DEPTH_ENCODED\\n@import clay.util.decode_float\\n#endif\\n@end\\n@export clay.deferred.chunk.gbuffer_read\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    vec4 texel3 = texture2D(gBufferTexture3, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    float glossiness = texel1.a;\\n    float metalness = texel3.a;\\n    vec3 N = texel1.rgb * 2.0 - 1.0;\\n    float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\\n    vec2 xy = uv2 * 2.0 - 1.0;\\n    vec4 projectedPos = vec4(xy, z, 1.0);\\n    vec4 p4 = viewProjectionInv * projectedPos;\\n    vec3 position = p4.xyz / p4.w;\\n    vec3 albedo = texel3.rgb;\\n    vec3 diffuseColor = albedo * (1.0 - metalness);\\n    vec3 specularColor = mix(vec3(0.04), albedo, metalness);\\n@end\\n@export clay.deferred.chunk.light_equation\\nfloat D_Phong(in float g, in float ndh) {\\n    float a = pow(8192.0, g);\\n    return (a + 2.0) / 8.0 * pow(ndh, a);\\n}\\nfloat D_GGX(in float g, in float ndh) {\\n    float r = 1.0 - g;\\n    float a = r * r;\\n    float tmp = ndh * ndh * (a - 1.0) + 1.0;\\n    return a / (3.1415926 * tmp * tmp);\\n}\\nvec3 F_Schlick(in float ndv, vec3 spec) {\\n    return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\\n}\\nvec3 lightEquation(\\n    in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\\n    in float ndl, in float ndh, in float ndv, in float g\\n)\\n{\\n    return ndl * lightColor\\n        * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\\n}\\n@end\";\n","import Base from '../core/Base';\nimport Texture2D from '../Texture2D';\nimport Texture from '../Texture';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport Shader from '../Shader';\nimport ForwardRenderer from '../Renderer';\nimport Pass from '../compositor/Pass';\nimport Matrix4 from '../math/Matrix4';\n\nimport gbufferEssl from '../shader/source/deferred/gbuffer.glsl.js';\nimport chunkEssl from '../shader/source/deferred/chunk.glsl.js';\n\nShader.import(gbufferEssl);\nShader.import(chunkEssl);\n\nfunction createFillCanvas(color) {\n    var canvas = document.createElement('canvas');\n    canvas.width = canvas.height = 1;\n    var ctx = canvas.getContext('2d');\n    ctx.fillStyle = color || '#000';\n    ctx.fillRect(0, 0, 1, 1);\n\n    return canvas;\n}\n\nfunction attachTextureToSlot(renderer, program, symbol, texture, slot) {\n    var gl = renderer.gl;\n    program.setUniform(gl, '1i', symbol, slot);\n\n    gl.activeTexture(gl.TEXTURE0 + slot);\n    // Maybe texture is not loaded yet;\n    if (texture.isRenderable()) {\n        texture.bind(renderer);\n    }\n    else {\n        // Bind texture to null\n        texture.unbind(renderer);\n    }\n}\n\n// TODO Use globalShader insteadof globalMaterial?\nfunction getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) {\n\n    var previousNormalMap;\n    var previousRougGlossMap;\n    var previousRenderable;\n\n    return function (renderable, gBufferMat, prevMaterial) {\n        // Material not change\n        if (previousRenderable && previousRenderable.material === renderable.material) {\n            return;\n        }\n\n        var standardMaterial = renderable.material;\n        var program = renderable.__program;\n\n        var glossiness;\n        var roughGlossMap;\n        var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS');\n        var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED');\n        var roughGlossChannel;\n        if (useRoughnessWorkflow) {\n            glossiness = 1.0 - standardMaterial.get('roughness');\n            roughGlossMap = standardMaterial.get('roughnessMap');\n            roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL');\n        }\n        else {\n            glossiness = standardMaterial.get('glossiness');\n            roughGlossMap = standardMaterial.get('glossinessMap');\n            roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL');\n        }\n        var useRoughGlossMap = !!roughGlossMap;\n\n        var normalMap = standardMaterial.get('normalMap') || defaultNormalMap;\n        var uvRepeat = standardMaterial.get('uvRepeat');\n        var uvOffset = standardMaterial.get('uvOffset');\n\n        roughGlossMap = roughGlossMap || defaultRoughnessMap;\n\n        if (prevMaterial !== gBufferMat) {\n            gBufferMat.set('glossiness', glossiness);\n            gBufferMat.set('normalMap', normalMap);\n            gBufferMat.set('roughGlossMap', roughGlossMap);\n            gBufferMat.set('useRoughGlossMap', +useRoughGlossMap);\n            gBufferMat.set('useRoughness', +useRoughnessWorkflow);\n            gBufferMat.set('doubleSided', +doubleSided);\n            gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0);\n            gBufferMat.set('uvRepeat', uvRepeat);\n            gBufferMat.set('uvOffset', uvOffset);\n        }\n        else {\n            program.setUniform(\n                gl, '1f', 'glossiness', glossiness\n            );\n\n            if (previousNormalMap !== normalMap) {\n                attachTextureToSlot(this, program, 'normalMap', normalMap, 0);\n            }\n            if (previousRougGlossMap !== roughGlossMap) {\n                attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1);\n            }\n            program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap);\n            program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow);\n            program.setUniform(gl, '1i', 'doubleSided', +doubleSided);\n            program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0);\n            if (uvRepeat != null) {\n                program.setUniform(gl, '2f', 'uvRepeat', uvRepeat);\n            }\n            if (uvOffset != null) {\n                program.setUniform(gl, '2f', 'uvOffset', uvOffset);\n            }\n        }\n\n        previousNormalMap = normalMap;\n        previousRougGlossMap = roughGlossMap;\n\n        previousRenderable = renderable;\n    };\n}\n\nfunction getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) {\n    var previousDiffuseMap;\n    var previousRenderable;\n    var previousMetalnessMap;\n\n    return function (renderable, gBufferMat, prevMaterial) {\n        // Material not change\n        if (previousRenderable && previousRenderable.material === renderable.material) {\n            return;\n        }\n\n        var program = renderable.__program;\n        var standardMaterial = renderable.material;\n\n        var color = standardMaterial.get('color');\n        var metalness = standardMaterial.get('metalness');\n\n        var diffuseMap = standardMaterial.get('diffuseMap');\n        var metalnessMap = standardMaterial.get('metalnessMap');\n\n        var uvRepeat = standardMaterial.get('uvRepeat');\n        var uvOffset = standardMaterial.get('uvOffset');\n\n        var useMetalnessMap = !!metalnessMap;\n\n        diffuseMap = diffuseMap || defaultDiffuseMap;\n        metalnessMap = metalnessMap || defaultMetalnessMap;\n\n        if (prevMaterial !== gBufferMat) {\n            gBufferMat.set('color', color);\n            gBufferMat.set('metalness', metalness);\n            gBufferMat.set('diffuseMap', diffuseMap);\n            gBufferMat.set('metalnessMap', metalnessMap);\n            gBufferMat.set('useMetalnessMap', +useMetalnessMap);\n            gBufferMat.set('uvRepeat', uvRepeat);\n            gBufferMat.set('uvOffset', uvOffset);\n\n            gBufferMat.set('linear', +standardMaterial.linear);\n        }\n        else {\n            program.setUniform(gl, '1f', 'metalness', metalness);\n\n            program.setUniform(gl, '3f', 'color', color);\n            if (previousDiffuseMap !== diffuseMap) {\n                attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0);\n            }\n            if (previousMetalnessMap !== metalnessMap) {\n                attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1);\n            }\n            program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap);\n            program.setUniform(gl, '2f', 'uvRepeat', uvRepeat);\n            program.setUniform(gl, '2f', 'uvOffset', uvOffset);\n\n            program.setUniform(gl, '1i', 'linear', +standardMaterial.linear);\n        }\n\n        previousDiffuseMap = diffuseMap;\n        previousMetalnessMap = metalnessMap;\n\n        previousRenderable = renderable;\n    };\n}\n\n/**\n * GBuffer is provided for deferred rendering and SSAO, SSR pass.\n * It will do two passes rendering to three target textures. See\n * + {@link clay.deferred.GBuffer#getTargetTexture1}\n * + {@link clay.deferred.GBuffer#getTargetTexture2}\n * + {@link clay.deferred.GBuffer#getTargetTexture3}\n * @constructor\n * @alias clay.deferred.GBuffer\n * @extends clay.core.Base\n */\nvar GBuffer = Base.extend(function () {\n\n    return {\n\n        enableTargetTexture1: true,\n\n        enableTargetTexture2: true,\n\n        enableTargetTexture3: true,\n\n        renderTransparent: false,\n\n        _renderList: [],\n        // - R: normal.x\n        // - G: normal.y\n        // - B: normal.z\n        // - A: glossiness\n        _gBufferTex1: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST,\n            // PENDING\n            type: Texture.HALF_FLOAT\n        }),\n\n        // - R: depth\n        _gBufferTex2: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST,\n            // format: Texture.DEPTH_COMPONENT,\n            // type: Texture.UNSIGNED_INT\n\n            format: Texture.DEPTH_STENCIL,\n            type: Texture.UNSIGNED_INT_24_8_WEBGL\n        }),\n\n        // - R: albedo.r\n        // - G: albedo.g\n        // - B: albedo.b\n        // - A: metalness\n        _gBufferTex3: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST\n        }),\n\n        _defaultNormalMap: new Texture2D({\n            image: createFillCanvas('#000')\n        }),\n        _defaultRoughnessMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n        _defaultMetalnessMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n        _defaultDiffuseMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n\n        _frameBuffer: new FrameBuffer(),\n\n        _gBufferMaterial1: new Material({\n            shader: new Shader(\n                Shader.source('clay.deferred.gbuffer.vertex'),\n                Shader.source('clay.deferred.gbuffer1.fragment')\n            ),\n            vertexDefines: {\n                FIRST_PASS: null\n            },\n            fragmentDefines: {\n                FIRST_PASS: null\n            }\n        }),\n        _gBufferMaterial2: new Material({\n            shader: new Shader(\n                Shader.source('clay.deferred.gbuffer.vertex'),\n                Shader.source('clay.deferred.gbuffer2.fragment')\n            )\n        }),\n\n        _debugPass: new Pass({\n            fragment: Shader.source('clay.deferred.gbuffer.debug')\n        })\n    };\n}, /** @lends clay.deferred.GBuffer# */{\n\n    /**\n     * Set G Buffer size.\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function (width, height) {\n        if (this._gBufferTex1.width === width\n            && this._gBufferTex1.height === height\n        ) {\n            return;\n        }\n        this._gBufferTex1.width = width;\n        this._gBufferTex1.height = height;\n\n        this._gBufferTex2.width = width;\n        this._gBufferTex2.height = height;\n\n        this._gBufferTex3.width = width;\n        this._gBufferTex3.height = height;\n    },\n\n    // TODO is dpr needed?\n    setViewport: function (x, y, width, height, dpr) {\n        var viewport;\n        if (typeof x === 'object') {\n            viewport = x;\n        }\n        else {\n            viewport = {\n                x: x, y: y,\n                width: width, height: height,\n                devicePixelRatio: dpr || 1\n            };\n        }\n        this._frameBuffer.viewport = viewport;\n    },\n\n    getViewport: function () {\n        if (this._frameBuffer.viewport) {\n            return this._frameBuffer.viewport;\n        }\n        else {\n            return {\n                x: 0, y: 0,\n                width: this._gBufferTex1.width,\n                height: this._gBufferTex1.height,\n                devicePixelRatio: 1\n            };\n        }\n    },\n\n    /**\n     * Update G Buffer\n     * @param {clay.Renderer} renderer\n     * @param {clay.Scene} scene\n     * @param {clay.camera.Perspective} camera\n     */\n    update: function (renderer, scene, camera) {\n\n        var gl = renderer.gl;\n\n        var frameBuffer = this._frameBuffer;\n        var viewport = frameBuffer.viewport;\n        var opaqueList = scene.opaqueList;\n        var transparentList = scene.transparentList;\n\n        var offset = 0;\n        var renderList = this._renderList;\n        for (var i = 0; i < opaqueList.length; i++) {\n            if (!opaqueList[i].ignoreGBuffer) {\n                renderList[offset++] = opaqueList[i];\n            }\n        }\n        if (this.renderTransparent) {\n            for (var i = 0; i < transparentList.length; i++) {\n                if (!transparentList[i].ignoreGBuffer) {\n                    renderList[offset++] = transparentList[i];\n                }\n            }\n        }\n        renderList.length = offset;\n\n        gl.clearColor(0, 0, 0, 0);\n        gl.depthMask(true);\n        gl.colorMask(true, true, true, true);\n        gl.disable(gl.BLEND);\n\n        var enableTargetTexture1 = this.enableTargetTexture1;\n        var enableTargetTexture2 = this.enableTargetTexture2;\n        var enableTargetTexture3 = this.enableTargetTexture3;\n        if (!enableTargetTexture1 && !enableTargetTexture3) {\n            console.warn('Can\\'t disable targetTexture1 targetTexture3 both');\n            enableTargetTexture1 = true;\n        }\n\n        if (enableTargetTexture2) {\n            frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT);\n        }\n\n        // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow\n        renderer.bindSceneRendering(scene);\n        if (enableTargetTexture1) {\n            // Pass 1\n            frameBuffer.attach(this._gBufferTex1);\n            frameBuffer.bind(renderer);\n\n            if (viewport) {\n                var dpr = viewport.devicePixelRatio;\n                // use scissor to make sure only clear the viewport\n                gl.enable(gl.SCISSOR_TEST);\n                gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n            }\n            gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n            if (viewport) {\n                gl.disable(gl.SCISSOR_TEST);\n            }\n            var gBufferMaterial1 = this._gBufferMaterial1;\n            var passConfig = {\n                getMaterial: function () {\n                    return gBufferMaterial1;\n                },\n                beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap),\n                sortCompare: renderer.opaqueSortCompare\n            };\n            // FIXME Use MRT if possible\n            renderer.renderPass(renderList, camera, passConfig);\n\n        }\n        if (enableTargetTexture3) {\n\n            // Pass 2\n            frameBuffer.attach(this._gBufferTex3);\n            frameBuffer.bind(renderer);\n\n            if (viewport) {\n                var dpr = viewport.devicePixelRatio;\n                // use scissor to make sure only clear the viewport\n                gl.enable(gl.SCISSOR_TEST);\n                gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n            }\n            gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n            if (viewport) {\n                gl.disable(gl.SCISSOR_TEST);\n            }\n\n            var gBufferMaterial2 = this._gBufferMaterial2;\n            var passConfig = {\n                getMaterial: function () {\n                    return gBufferMaterial2;\n                },\n                beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap),\n                sortCompare: renderer.opaqueSortCompare\n            };\n            renderer.renderPass(renderList, camera, passConfig);\n        }\n\n        renderer.bindSceneRendering(null);\n        frameBuffer.unbind(renderer);\n    },\n\n    renderDebug: function (renderer, camera, type, viewport) {\n        var debugTypes = {\n            normal: 0,\n            depth: 1,\n            position: 2,\n            glossiness: 3,\n            metalness: 4,\n            albedo: 5\n        };\n        if (debugTypes[type] == null) {\n            console.warn('Unkown type \"' + type + '\"');\n            // Default use normal\n            type = 'normal';\n        }\n\n        renderer.saveClear();\n        renderer.saveViewport();\n        renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT;\n\n        if (viewport) {\n            renderer.setViewport(viewport);\n        }\n        var viewProjectionInv = new Matrix4();\n        Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix);\n\n        var debugPass = this._debugPass;\n        debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]);\n        debugPass.setUniform('gBufferTexture1', this._gBufferTex1);\n        debugPass.setUniform('gBufferTexture2', this._gBufferTex2);\n        debugPass.setUniform('gBufferTexture3', this._gBufferTex3);\n        debugPass.setUniform('debug', debugTypes[type]);\n        debugPass.setUniform('viewProjectionInv', viewProjectionInv.array);\n        debugPass.render(renderer);\n\n        renderer.restoreViewport();\n        renderer.restoreClear();\n    },\n\n    /**\n     * Get first target texture.\n     * Channel storage:\n     * + R: normal.x * 0.5 + 0.5\n     * + G: normal.y * 0.5 + 0.5\n     * + B: normal.z * 0.5 + 0.5\n     * + A: glossiness\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture1: function () {\n        return this._gBufferTex1;\n    },\n\n    /**\n     * Get second target texture.\n     * Channel storage:\n     * + R: depth\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture2: function () {\n        return this._gBufferTex2;\n    },\n\n    /**\n     * Get third target texture.\n     * Channel storage:\n     * + R: albedo.r\n     * + G: albedo.g\n     * + B: albedo.b\n     * + A: metalness\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture3: function () {\n        return this._gBufferTex3;\n    },\n\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n    }\n});\n\nexport default GBuffer;","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar vec2 = glMatrix.vec2;\n\n/**\n * @constructor clay.geometry.Cone\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.topRadius]\n * @param {number} [opt.bottomRadius]\n * @param {number} [opt.height]\n * @param {number} [opt.capSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Cone = Geometry.extend(\n/** @lends clay.geometry.Cone# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    topRadius: 0,\n\n    /**\n     * @type {number}\n     */\n    bottomRadius: 1,\n\n    /**\n     * @type {number}\n     */\n    height: 2,\n\n    /**\n     * @type {number}\n     */\n    capSegments: 20,\n\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cone.prototype */\n{\n    /**\n     * Build cone geometry\n     */\n    build: function() {\n        var positions = [];\n        var texcoords = [];\n        var faces = [];\n        positions.length = 0;\n        texcoords.length = 0;\n        faces.length = 0;\n        // Top cap\n        var capSegRadial = Math.PI * 2 / this.capSegments;\n\n        var topCap = [];\n        var bottomCap = [];\n\n        var r1 = this.topRadius;\n        var r2 = this.bottomRadius;\n        var y = this.height / 2;\n\n        var c1 = vec3.fromValues(0, y, 0);\n        var c2 = vec3.fromValues(0, -y, 0);\n        for (var i = 0; i < this.capSegments; i++) {\n            var theta = i * capSegRadial;\n            var x = r1 * Math.sin(theta);\n            var z = r1 * Math.cos(theta);\n            topCap.push(vec3.fromValues(x, y, z));\n\n            x = r2 * Math.sin(theta);\n            z = r2 * Math.cos(theta);\n            bottomCap.push(vec3.fromValues(x, -y, z));\n        }\n\n        // Build top cap\n        positions.push(c1);\n        // FIXME\n        texcoords.push(vec2.fromValues(0, 1));\n        var n = this.capSegments;\n        for (var i = 0; i < n; i++) {\n            positions.push(topCap[i]);\n            // FIXME\n            texcoords.push(vec2.fromValues(i / n, 0));\n            faces.push([0, i+1, (i+1) % n + 1]);\n        }\n\n        // Build bottom cap\n        var offset = positions.length;\n        positions.push(c2);\n        texcoords.push(vec2.fromValues(0, 1));\n        for (var i = 0; i < n; i++) {\n            positions.push(bottomCap[i]);\n            // FIXME\n            texcoords.push(vec2.fromValues(i / n, 0));\n            faces.push([offset, offset+((i+1) % n + 1), offset+i+1]);\n        }\n\n        // Build side\n        offset = positions.length;\n        var n2 = this.heightSegments;\n        for (var i = 0; i < n; i++) {\n            for (var j = 0; j < n2+1; j++) {\n                var v = j / n2;\n                positions.push(vec3.lerp(vec3.create(), topCap[i], bottomCap[i], v));\n                texcoords.push(vec2.fromValues(i / n, v));\n            }\n        }\n        for (var i = 0; i < n; i++) {\n            for (var j = 0; j < n2; j++) {\n                var i1 = i * (n2 + 1) + j;\n                var i2 = ((i + 1) % n) * (n2 + 1) + j;\n                var i3 = ((i + 1) % n) * (n2 + 1) + j + 1;\n                var i4 = i * (n2 + 1) + j + 1;\n                faces.push([offset+i2, offset+i1, offset+i4]);\n                faces.push([offset+i4, offset+i3, offset+i2]);\n            }\n        }\n\n        this.attributes.position.fromArray(positions);\n        this.attributes.texcoord0.fromArray(texcoords);\n\n        this.initIndicesFromArray(faces);\n\n        this.generateVertexNormals();\n\n        this.boundingBox = new BoundingBox();\n        var r = Math.max(this.topRadius, this.bottomRadius);\n        this.boundingBox.min.set(-r, -this.height/2, -r);\n        this.boundingBox.max.set(r, this.height/2, r);\n    }\n});\n\nexport default Cone;\n","import Geometry from '../Geometry';\nimport ConeGeometry from './Cone';\n\n/**\n * @constructor clay.geometry.Cylinder\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.radius]\n * @param {number} [opt.height]\n * @param {number} [opt.capSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Cylinder = Geometry.extend(\n/** @lends clay.geometry.Cylinder# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    radius: 1,\n\n    /**\n     * @type {number}\n     */\n    height: 2,\n\n    /**\n     * @type {number}\n     */\n    capSegments: 50,\n\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cylinder.prototype */\n{\n    /**\n     * Build cylinder geometry\n     */\n    build: function() {\n        var cone = new ConeGeometry({\n            topRadius: this.radius,\n            bottomRadius: this.radius,\n            capSegments: this.capSegments,\n            heightSegments: this.heightSegments,\n            height: this.height\n        });\n\n        this.attributes.position.value = cone.attributes.position.value;\n        this.attributes.normal.value = cone.attributes.normal.value;\n        this.attributes.texcoord0.value = cone.attributes.texcoord0.value;\n        this.indices = cone.indices;\n\n        this.boundingBox = cone.boundingBox;\n    }\n});\n\nexport default Cylinder;\n","export default \"@export clay.deferred.light_volume.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n    v_Position = position;\\n}\\n@end\";\n","export default \"@export clay.deferred.spot_light\\n@import clay.deferred.chunk.light_head\\n@import clay.deferred.chunk.light_equation\\n@import clay.util.calculate_attenuation\\nuniform vec3 lightPosition;\\nuniform vec3 lightDirection;\\nuniform vec3 lightColor;\\nuniform float umbraAngleCosine;\\nuniform float penumbraAngleCosine;\\nuniform float lightRange;\\nuniform float falloffFactor;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform sampler2D lightShadowMap;\\nuniform mat4 lightMatrix;\\nuniform float lightShadowMapSize;\\n#endif\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    L /= dist;\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    float c = dot(-normalize(lightDirection), L);\\n    float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\\n    falloff = pow(falloff, falloffFactor);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = computeShadowContrib(\\n        lightShadowMap, lightMatrix, position, lightShadowMapSize\\n    );\\n    gl_FragColor.rgb *= shadowContrib;\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\\n\";\n","export default \"@export clay.deferred.directional_light\\n@import clay.deferred.chunk.light_head\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightDirection;\\nuniform vec3 lightColor;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform sampler2D lightShadowMap;\\nuniform float lightShadowMapSize;\\nuniform mat4 lightMatrices[SHADOW_CASCADE];\\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\\n#endif\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = -normalize(lightDirection);\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    gl_FragColor.rgb = lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = 1.0;\\n    for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\\n        if (\\n            z >= shadowCascadeClipsNear[_idx_] &&\\n            z <= shadowCascadeClipsFar[_idx_]\\n        ) {\\n            shadowContrib = computeShadowContrib(\\n                lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\\n                vec2(1.0 / float(SHADOW_CASCADE), 1.0),\\n                vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\\n            );\\n        }\\n    }}\\n    gl_FragColor.rgb *= shadowContrib;\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\\n\";\n","export default \"@export clay.deferred.ambient_light\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture3;\\nuniform vec3 lightColor;\\nuniform vec2 windowSize: WINDOW_SIZE;\\nvoid main()\\n{\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\\n    gl_FragColor.rgb = lightColor * albedo;\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.ambient_sh_light\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture3;\\nuniform vec3 lightColor;\\nuniform vec3 lightCoefficients[9];\\nuniform vec2 windowSize: WINDOW_SIZE;\\nvec3 calcAmbientSHLight(vec3 N) {\\n    return lightCoefficients[0]\\n        + lightCoefficients[1] * N.x\\n        + lightCoefficients[2] * N.y\\n        + lightCoefficients[3] * N.z\\n        + lightCoefficients[4] * N.x * N.z\\n        + lightCoefficients[5] * N.z * N.y\\n        + lightCoefficients[6] * N.y * N.x\\n        + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\\n        + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\\n}\\nvoid main()\\n{\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    vec3 N = texel1.rgb * 2.0 - 1.0;\\n    vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\\n    gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.ambient_cubemap_light\\n@import clay.deferred.chunk.light_head\\nuniform vec3 lightColor;\\nuniform samplerCube lightCubemap;\\nuniform sampler2D brdfLookup;\\nuniform vec3 eyePosition;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 L = reflect(-V, N);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float rough = clamp(1.0 - glossiness, 0.0, 1.0);\\n    float bias = rough * 5.0;\\n    vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\\n    vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\\n    vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\\n    gl_FragColor.rgb = lightColor * envTexel * envWeight;\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.point_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform samplerCube lightShadowMap;\\nuniform float lightShadowMapSize;\\n#endif\\nvarying vec3 v_Position;\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    L /= dist;\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    gl_FragColor.rgb = attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = computeShadowContribOmni(\\n        lightShadowMap, -L * dist, lightRange\\n    );\\n    gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.sphere_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform float lightRadius;\\nuniform vec3 eyePosition;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    vec3 R = reflect(V, N);\\n    float tmp = dot(L, R);\\n    vec3 cToR = tmp * R - L;\\n    float d = length(cToR);\\n    L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\\n    L = normalize(L);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    gl_FragColor.rgb = lightColor * ndl * attenuation;\\n    glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\\n    gl_FragColor.rgb = attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.tube_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform vec3 lightExtend;\\nuniform vec3 eyePosition;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 R = reflect(V, N);\\n    vec3 L0 = lightPosition - lightExtend - position;\\n    vec3 L1 = lightPosition + lightExtend - position;\\n    vec3 LD = L1 - L0;\\n    float len0 = length(L0);\\n    float len1 = length(L1);\\n    float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\\n    float LDDotR = dot(R, LD);\\n    float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\\n    t = clamp(t, 0.0, 1.0);\\n    L = L0 + t * LD;\\n    float dist = length(L);\\n    L /= dist;\\n    vec3 H = normalize(L + V);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\\n    gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\\n        * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","// Light-pre pass deferred rendering\n// http://www.realtimerendering.com/blog/deferred-lighting-approaches/\nimport Base from '../core/Base';\nimport Shader from '../Shader';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport FullQuadPass from '../compositor/Pass';\nimport Texture2D from '../Texture2D';\nimport Texture from '../Texture';\nimport Mesh from '../Mesh';\nimport SphereGeo from '../geometry/Sphere';\nimport ConeGeo from '../geometry/Cone';\nimport CylinderGeo from '../geometry/Cylinder';\nimport Matrix4 from '../math/Matrix4';\nimport Vector3 from '../math/Vector3';\nimport GBuffer from './GBuffer';\n\nimport prezGlsl from '../shader/source/prez.glsl.js';\nimport utilGlsl from '../shader/source/util.glsl.js';\n\nimport lightvolumeGlsl from '../shader/source/deferred/lightvolume.glsl.js';\n// Light shaders\nimport spotGlsl from '../shader/source/deferred/spot.glsl.js';\nimport directionalGlsl from '../shader/source/deferred/directional.glsl.js';\nimport ambientGlsl from '../shader/source/deferred/ambient.glsl.js';\nimport ambientshGlsl from '../shader/source/deferred/ambientsh.glsl.js';\nimport ambientcubemapGlsl from '../shader/source/deferred/ambientcubemap.glsl.js';\nimport pointGlsl from '../shader/source/deferred/point.glsl.js';\nimport sphereGlsl from '../shader/source/deferred/sphere.glsl.js';\nimport tubeGlsl from '../shader/source/deferred/tube.glsl.js';\n\nShader.import(prezGlsl);\nShader.import(utilGlsl);\nShader.import(lightvolumeGlsl);\n\n// Light shaders\nShader.import(spotGlsl);\nShader.import(directionalGlsl);\nShader.import(ambientGlsl);\nShader.import(ambientshGlsl);\nShader.import(ambientcubemapGlsl);\nShader.import(pointGlsl);\nShader.import(sphereGlsl);\nShader.import(tubeGlsl);\n\nShader.import(prezGlsl);\n\n/**\n * Deferred renderer\n * @constructor\n * @alias clay.deferred.Renderer\n * @extends clay.core.Base\n */\nvar DeferredRenderer = Base.extend(function () {\n\n    var fullQuadVertex = Shader.source('clay.compositor.vertex');\n    var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex');\n\n    var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light'));\n\n    var lightAccumulateBlendFunc = function (gl) {\n        gl.blendEquation(gl.FUNC_ADD);\n        gl.blendFunc(gl.ONE, gl.ONE);\n    };\n\n    var createLightPassMat = function (shader) {\n        return new Material({\n            shader: shader,\n            blend: lightAccumulateBlendFunc,\n            transparent: true,\n            depthMask: false\n        });\n    };\n\n    var createVolumeShader = function (name) {\n        return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name));\n    };\n\n    // Rotate and positioning to fit the spot light\n    // Which the cusp of cone pointing to the positive z\n    // and positioned on the origin\n    var coneGeo = new ConeGeo({\n        capSegments: 10\n    });\n    var mat = new Matrix4();\n    mat.rotateX(Math.PI / 2)\n        .translate(new Vector3(0, -1, 0));\n\n    coneGeo.applyTransform(mat);\n\n    var cylinderGeo = new CylinderGeo({\n        capSegments: 10\n    });\n    // Align with x axis\n    mat.identity().rotateZ(Math.PI / 2);\n    cylinderGeo.applyTransform(mat);\n\n    return /** @lends clay.deferred.Renderer# */ {\n\n        /**\n         * Provide ShadowMapPass for shadow rendering.\n         * @type {clay.prePass.ShadowMap}\n         */\n        shadowMapPass: null,\n        /**\n         * If enable auto resizing from given defualt renderer size.\n         * @type {boolean}\n         */\n        autoResize: true,\n\n        _createLightPassMat: createLightPassMat,\n\n        _gBuffer: new GBuffer(),\n\n        _lightAccumFrameBuffer: new FrameBuffer({\n            depthBuffer: false\n        }),\n\n        _lightAccumTex: new Texture2D({\n            // FIXME Device not support float texture\n            type: Texture.HALF_FLOAT,\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST\n        }),\n\n        _fullQuadPass: new FullQuadPass({\n            blendWithPrevious: true\n        }),\n\n        _directionalLightMat: createLightPassMat(directionalLightShader),\n\n        _ambientMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_light')\n        )),\n        _ambientSHMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light')\n        )),\n        _ambientCubemapMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light')\n        )),\n\n        _spotLightShader: createVolumeShader('spot_light'),\n        _pointLightShader: createVolumeShader('point_light'),\n\n        _sphereLightShader: createVolumeShader('sphere_light'),\n        _tubeLightShader: createVolumeShader('tube_light'),\n\n        _lightSphereGeo: new SphereGeo({\n            widthSegments: 10,\n            heightSegements: 10\n        }),\n\n        _lightConeGeo: coneGeo,\n\n        _lightCylinderGeo: cylinderGeo,\n\n        _outputPass: new FullQuadPass({\n            fragment: Shader.source('clay.compositor.output')\n        })\n    };\n}, /** @lends clay.deferred.Renderer# */ {\n    /**\n     * Do render\n     * @param {clay.Renderer} renderer\n     * @param {clay.Scene} scene\n     * @param {clay.Camera} camera\n     * @param {Object} [opts]\n     * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture\n     * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow.\n     * @param {boolean} [opts.notUpdateScene = true] If not update the scene.\n     */\n    render: function (renderer, scene, camera, opts) {\n\n        opts = opts || {};\n        opts.renderToTarget = opts.renderToTarget || false;\n        opts.notUpdateShadow = opts.notUpdateShadow || false;\n        opts.notUpdateScene = opts.notUpdateScene || false;\n\n        if (!opts.notUpdateScene) {\n            scene.update(false, true);\n        }\n\n        camera.update(true);\n\n        // PENDING For stereo rendering\n        var dpr = renderer.getDevicePixelRatio();\n        if (this.autoResize\n            && (renderer.getWidth() * dpr !== this._lightAccumTex.width\n            || renderer.getHeight() * dpr !== this._lightAccumTex.height)\n        ) {\n            this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr);\n        }\n\n        this._gBuffer.update(renderer, scene, camera);\n\n        // Accumulate light buffer\n        this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow);\n\n        if (!opts.renderToTarget) {\n            this._outputPass.setUniform('texture', this._lightAccumTex);\n\n            this._outputPass.render(renderer);\n            // this._gBuffer.renderDebug(renderer, camera, 'normal');\n        }\n    },\n\n    /**\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture: function () {\n        return this._lightAccumTex;\n    },\n\n    /**\n     * @return {clay.FrameBuffer}\n     */\n    getTargetFrameBuffer: function () {\n        return this._lightAccumFrameBuffer;\n    },\n\n    /**\n     * @return {clay.deferred.GBuffer}\n     */\n    getGBuffer: function () {\n        return this._gBuffer;\n    },\n\n    // TODO is dpr needed?\n    setViewport: function (x, y, width, height, dpr) {\n        this._gBuffer.setViewport(x, y, width, height, dpr);\n        this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport();\n    },\n\n    // getFullQuadLightPass: function () {\n    //     return this._fullQuadPass;\n    // },\n\n    /**\n     * Set renderer size.\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function (width, height) {\n        this._lightAccumTex.width = width;\n        this._lightAccumTex.height = height;\n\n        // PENDING viewport ?\n        this._gBuffer.resize(width, height);\n    },\n\n    _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) {\n        var gl = renderer.gl;\n        var lightAccumTex = this._lightAccumTex;\n        var lightAccumFrameBuffer = this._lightAccumFrameBuffer;\n\n        var eyePosition = camera.getWorldPosition().array;\n\n        // Update volume meshes\n        for (var i = 0; i < scene.lights.length; i++) {\n            this._updateLightProxy(scene.lights[i]);\n        }\n\n        var shadowMapPass = this.shadowMapPass;\n        if (shadowMapPass && updateShadow) {\n            gl.clearColor(1, 1, 1, 1);\n            this._prepareLightShadow(renderer, scene, camera);\n        }\n\n        this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow);\n\n        lightAccumFrameBuffer.attach(lightAccumTex);\n        lightAccumFrameBuffer.bind(renderer);\n        var clearColor = renderer.clearColor;\n\n        var viewport = lightAccumFrameBuffer.viewport;\n        if (viewport) {\n            var dpr = viewport.devicePixelRatio;\n            // use scissor to make sure only clear the viewport\n            gl.enable(gl.SCISSOR_TEST);\n            gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n        }\n        gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n        gl.clear(gl.COLOR_BUFFER_BIT);\n        gl.enable(gl.BLEND);\n        if (viewport) {\n            gl.disable(gl.SCISSOR_TEST);\n        }\n\n        this.trigger('startlightaccumulate', renderer, scene, camera);\n\n        var viewProjectionInv = new Matrix4();\n        Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix);\n\n        var volumeMeshList = [];\n\n        for (var i = 0; i < scene.lights.length; i++) {\n            var light = scene.lights[i];\n            var uTpl = light.uniformTemplates;\n\n            var volumeMesh = light.volumeMesh || light.__volumeMesh;\n\n            if (volumeMesh) {\n                var material = volumeMesh.material;\n                // Volume mesh will affect the scene bounding box when rendering\n                // if castShadow is true\n                volumeMesh.castShadow = false;\n\n                var unknownLightType = false;\n                switch (light.type) {\n                    case 'POINT_LIGHT':\n                        material.setUniform('lightColor', uTpl.pointLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.pointLightRange.value(light));\n                        material.setUniform('lightPosition', uTpl.pointLightPosition.value(light));\n                        break;\n                    case 'SPOT_LIGHT':\n                        material.setUniform('lightPosition', uTpl.spotLightPosition.value(light));\n                        material.setUniform('lightColor', uTpl.spotLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.spotLightRange.value(light));\n                        material.setUniform('lightDirection', uTpl.spotLightDirection.value(light));\n                        material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light));\n                        material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light));\n                        material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light));\n                        break;\n                    case 'SPHERE_LIGHT':\n                        material.setUniform('lightColor', uTpl.sphereLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.sphereLightRange.value(light));\n                        material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light));\n                        material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light));\n                        break;\n                    case 'TUBE_LIGHT':\n                        material.setUniform('lightColor', uTpl.tubeLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.tubeLightRange.value(light));\n                        material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light));\n                        material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light));\n                        break;\n                    default:\n                        unknownLightType = true;\n                }\n\n                if (unknownLightType) {\n                    continue;\n                }\n\n                material.setUniform('eyePosition', eyePosition);\n                material.setUniform('viewProjectionInv', viewProjectionInv.array);\n                material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1());\n                material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2());\n                material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3());\n\n                volumeMeshList.push(volumeMesh);\n\n            }\n            else {\n                var pass = this._fullQuadPass;\n                var unknownLightType = false;\n                // Full quad light\n                switch (light.type) {\n                    case 'AMBIENT_LIGHT':\n                        pass.material = this._ambientMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light));\n                        break;\n                    case 'AMBIENT_SH_LIGHT':\n                        pass.material = this._ambientSHMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light));\n                        pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light));\n                        break;\n                    case 'AMBIENT_CUBEMAP_LIGHT':\n                        pass.material = this._ambientCubemapMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light));\n                        pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light));\n                        pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light));\n                        break;\n                    case 'DIRECTIONAL_LIGHT':\n                        var hasShadow = shadowMapPass && light.castShadow;\n                        pass.material = this._directionalLightMat;\n                        pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED');\n                        if (hasShadow) {\n                            pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade);\n                        }\n                        pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light));\n                        pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light));\n                        break;\n                    default:\n                        // Unkonw light type\n                        unknownLightType = true;\n                }\n                if (unknownLightType) {\n                    continue;\n                }\n\n                var passMaterial = pass.material;\n                passMaterial.setUniform('eyePosition', eyePosition);\n                passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array);\n                passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1());\n                passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2());\n                passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3());\n\n                // TODO\n                if (shadowMapPass && light.castShadow) {\n                    passMaterial.setUniform('lightShadowMap', light.__shadowMap);\n                    passMaterial.setUniform('lightMatrices', light.__lightMatrices);\n                    passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear);\n                    passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar);\n\n                    passMaterial.setUniform('lightShadowMapSize', light.shadowResolution);\n                }\n\n                pass.renderQuad(renderer);\n            }\n        }\n\n        this._renderVolumeMeshList(renderer, camera, volumeMeshList);\n\n        this.trigger('lightaccumulate', renderer, scene, camera);\n\n        lightAccumFrameBuffer.unbind(renderer);\n\n        this.trigger('afterlightaccumulate', renderer, scene, camera);\n\n    },\n\n    _prepareLightShadow: (function () {\n        var worldView = new Matrix4();\n        return function (renderer, scene, camera) {\n            var shadowCasters;\n\n            shadowCasters = this._shadowCasters || (this._shadowCasters = []);\n            var count = 0;\n            var list = scene.opaqueList;\n            for (var i = 0; i < list.length; i++) {\n                if (list[i].castShadow) {\n                    shadowCasters[count++] = list[i];\n                }\n            }\n            shadowCasters.length = count;\n\n            for (var i = 0; i < scene.lights.length; i++) {\n                var light = scene.lights[i];\n                var volumeMesh = light.volumeMesh || light.__volumeMesh;\n                if (!light.castShadow) {\n                    continue;\n                }\n\n                switch (light.type) {\n                    case 'POINT_LIGHT':\n                    case 'SPOT_LIGHT':\n                        // Frustum culling\n                        Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform);\n                        if (renderer.isFrustumCulled(\n                            volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array\n                        )) {\n                            continue;\n                        }\n\n                        this._prepareSingleLightShadow(\n                            renderer, scene, camera, light, shadowCasters, volumeMesh.material\n                        );\n                        break;\n                    case 'DIRECTIONAL_LIGHT':\n                        this._prepareSingleLightShadow(\n                            renderer, scene, camera, light, shadowCasters, null\n                        );\n                }\n            }\n        };\n    })(),\n\n    _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) {\n        switch (light.type) {\n            case 'POINT_LIGHT':\n                var shadowMaps = [];\n                this.shadowMapPass.renderPointLightShadow(\n                    renderer, scene, light, casters, shadowMaps\n                );\n                material.setUniform('lightShadowMap', shadowMaps[0]);\n                material.setUniform('lightShadowMapSize', light.shadowResolution);\n                break;\n            case 'SPOT_LIGHT':\n                var shadowMaps = [];\n                var lightMatrices = [];\n                this.shadowMapPass.renderSpotLightShadow(\n                    renderer, scene, light, casters, lightMatrices, shadowMaps\n                );\n                material.setUniform('lightShadowMap', shadowMaps[0]);\n                material.setUniform('lightMatrix', lightMatrices[0]);\n                material.setUniform('lightShadowMapSize', light.shadowResolution);\n                break;\n            case 'DIRECTIONAL_LIGHT':\n                var shadowMaps = [];\n                var lightMatrices = [];\n                var cascadeClips = [];\n                this.shadowMapPass.renderDirectionalLightShadow(\n                    renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps\n                );\n                var cascadeClipsNear = cascadeClips.slice();\n                var cascadeClipsFar = cascadeClips.slice();\n                cascadeClipsNear.pop();\n                cascadeClipsFar.shift();\n\n                // Iterate from far to near\n                cascadeClipsNear.reverse();\n                cascadeClipsFar.reverse();\n                lightMatrices.reverse();\n\n                light.__cascadeClipsNear = cascadeClipsNear;\n                light.__cascadeClipsFar = cascadeClipsFar;\n                light.__shadowMap = shadowMaps[0];\n                light.__lightMatrices = lightMatrices;\n                break;\n        }\n    },\n\n    // Update light volume mesh\n    // Light volume mesh is rendered in light accumulate pass instead of full quad.\n    // It will reduce pixels significantly when local light is relatively small.\n    // And we can use custom volume mesh to shape the light.\n    //\n    // See \"Deferred Shading Optimizations\" in GDC2011\n    _updateLightProxy: function (light) {\n        var volumeMesh;\n        if (light.volumeMesh) {\n            volumeMesh = light.volumeMesh;\n        }\n        else {\n            switch (light.type) {\n                // Only local light (point and spot) needs volume mesh.\n                // Directional and ambient light renders in full quad\n                case 'POINT_LIGHT':\n                case 'SPHERE_LIGHT':\n                    var shader = light.type === 'SPHERE_LIGHT'\n                        ? this._sphereLightShader : this._pointLightShader;\n                    // Volume mesh created automatically\n                    if (!light.__volumeMesh) {\n                        light.__volumeMesh = new Mesh({\n                            material: this._createLightPassMat(shader),\n                            geometry: this._lightSphereGeo,\n                            // Disable culling\n                            // if light volume mesh intersect camera near plane\n                            // We need mesh inside can still be rendered\n                            culling: false\n                        });\n                    }\n                    volumeMesh = light.__volumeMesh;\n                    var r = light.range + (light.radius || 0);\n                    volumeMesh.scale.set(r, r, r);\n                    break;\n                case 'SPOT_LIGHT':\n                    light.__volumeMesh = light.__volumeMesh || new Mesh({\n                        material: this._createLightPassMat(this._spotLightShader),\n                        geometry: this._lightConeGeo,\n                        culling: false\n                    });\n                    volumeMesh = light.__volumeMesh;\n                    var aspect = Math.tan(light.penumbraAngle * Math.PI / 180);\n                    var range = light.range;\n                    volumeMesh.scale.set(aspect * range, aspect * range, range / 2);\n                    break;\n                case 'TUBE_LIGHT':\n                    light.__volumeMesh = light.__volumeMesh || new Mesh({\n                        material: this._createLightPassMat(this._tubeLightShader),\n                        geometry: this._lightCylinderGeo,\n                        culling: false\n                    });\n                    volumeMesh = light.__volumeMesh;\n                    var range = light.range;\n                    volumeMesh.scale.set(light.length / 2 + range, range, range);\n                    break;\n            }\n        }\n        if (volumeMesh) {\n            volumeMesh.update();\n            // Apply light transform\n            Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform);\n            var hasShadow = this.shadowMapPass && light.castShadow;\n            volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED');\n        }\n    },\n\n    _renderVolumeMeshList: (function () {\n        var worldViewProjection = new Matrix4();\n        var worldView = new Matrix4();\n        var preZMaterial = new Material({\n            shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'))\n        });\n        return function (renderer, camera, volumeMeshList) {\n            var gl = renderer.gl;\n\n            gl.enable(gl.DEPTH_TEST);\n            gl.disable(gl.CULL_FACE);\n            gl.blendEquation(gl.FUNC_ADD);\n            gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE);\n            gl.depthFunc(gl.LEQUAL);\n\n            gl.clear(gl.DEPTH_BUFFER_BIT);\n\n            var viewport = renderer.viewport;\n            var dpr = viewport.devicePixelRatio;\n            var viewportUniform = [\n                viewport.x * dpr, viewport.y * dpr,\n                viewport.width * dpr, viewport.height * dpr\n            ];\n\n            var windowSizeUniform = [\n                this._lightAccumTex.width,\n                this._lightAccumTex.height\n            ];\n\n            for (var i = 0; i < volumeMeshList.length; i++) {\n                var volumeMesh = volumeMeshList[i];\n\n                // Frustum culling\n                Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform);\n                if (renderer.isFrustumCulled(\n                    volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array\n                )) {\n                    continue;\n                }\n\n                // Use prez to avoid one pixel rendered twice\n                gl.colorMask(false, false, false, false);\n                gl.depthMask(true);\n                // depthMask must be enabled before clear DEPTH_BUFFER\n                gl.clear(gl.DEPTH_BUFFER_BIT);\n\n                Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView);\n\n                var preZProgram = renderer.getProgram(volumeMesh, preZMaterial);\n                volumeMesh.__program = preZProgram;\n                renderer.validateProgram(preZProgram);\n                preZProgram.bind(renderer);\n\n                var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION;\n                preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array);\n                volumeMesh.render(renderer, preZMaterial, preZProgram);\n\n                // Render light\n                gl.colorMask(true, true, true, true);\n                gl.depthMask(false);\n                var program = renderer.getProgram(volumeMesh, volumeMesh.material);\n                volumeMesh.__program = program;\n                renderer.validateProgram(program);\n                program.bind(renderer);\n\n                var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION;\n                // Set some common uniforms\n                program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array);\n                program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform);\n                program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform);\n\n                volumeMesh.material.bind(renderer, program);\n                volumeMesh.render(renderer, volumeMesh.material, program);\n            }\n\n            gl.depthFunc(gl.LESS);\n        };\n    })(),\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._gBuffer.dispose(renderer);\n\n        this._lightAccumFrameBuffer.dispose(renderer);\n        this._lightAccumTex.dispose(renderer);\n\n        this._lightConeGeo.dispose(renderer);\n        this._lightCylinderGeo.dispose(renderer);\n        this._lightSphereGeo.dispose(renderer);\n\n        this._fullQuadPass.dispose(renderer);\n        this._outputPass.dispose(renderer);\n\n        this._directionalLightMat.dispose(renderer);\n\n        this.shadowMapPass.dispose(renderer);\n    }\n});\n\nexport default DeferredRenderer;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Sphere\n * @extends {clay.Light}\n */\nvar SphereLight = Light.extend(\n/** @lends clay.light.Sphere# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    radius: 5\n}, {\n\n    type: 'SPHERE_LIGHT',\n\n    uniformTemplates: {\n        sphereLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        sphereLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n        sphereLightRadius: {\n            type: '1f',\n            value: function(instance) {\n                return instance.radius;\n            }\n        },\n        sphereLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n});\n\nexport default SphereLight;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Tube\n * @extends {clay.Light}\n */\nvar TubeLight = Light.extend(\n/** @lends clay.light.Tube# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    length: 10\n}, {\n\n    type: 'TUBE_LIGHT',\n\n    uniformTemplates: {\n        tubeLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n\n        tubeLightExtend: {\n            type: '3f',\n            value: (function() {\n                var x = new Vector3();\n                return function(instance) {\n                    // Extend in x axis\n                    return x.copy(instance.worldTransform.x)\n                        .normalize().scale(instance.length / 2).array;\n                };\n            })()\n        },\n\n        tubeLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n\n        tubeLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n});\n\nexport default TubeLight;\n","import Base from '../core/Base';\nimport request from '../core/request';\nimport createCompositor from '../compositor/createCompositor';\n\n/**\n * @constructor clay.loader.FX\n * @extends clay.core.Base\n */\nvar FXLoader = Base.extend(\n/** @lends clay.loader.FX# */\n{\n    /**\n     * @type {string}\n     */\n    rootPath: '',\n    /**\n     * @type {string}\n     */\n    textureRootPath: '',\n    /**\n     * @type {string}\n     */\n    shaderRootPath: '',\n\n    /**\n     * @type {clay.Scene}\n     */\n    scene: null,\n\n    /**\n     * @type {clay.Camera}\n     */\n    camera: null\n},\n/** @lends clay.loader.FX.prototype */\n{\n    /**\n     * @param  {string} url\n     */\n    load: function(url) {\n        var self = this;\n\n        if (!this.rootPath) {\n            this.rootPath = url.slice(0, url.lastIndexOf('/'));\n        }\n\n        request.get({\n            url: url,\n            onprogress: function(percent, loaded, total) {\n                self.trigger('progress', percent, loaded, total);\n            },\n            onerror: function(e) {\n                self.trigger('error', e);\n            },\n            responseType: 'text',\n            onload: function (data) {\n                createCompositor(JSON.parse(data), {\n                    textureRootPath: this.textureRootPath || this.rootPath,\n                    camera: this.camera,\n                    scene: this.scene\n                });\n            }\n        });\n    }\n});\n\nexport default FXLoader;\n","import glMatrix from '../dep/glmatrix';\nvar mat2 = glMatrix.mat2;\n\n/**\n * @constructor\n * @alias clay.math.Matrix2\n */\nvar Matrix2 = function() {\n\n    /**\n     * Storage of Matrix2\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix2#\n     */\n    this.array = mat2.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix2#\n     */\n    this._dirty = true;\n};\n\nMatrix2.prototype = {\n\n    constructor: Matrix2,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Clone a new Matrix2\n     * @return {clay.math.Matrix2}\n     */\n    clone: function() {\n        return (new Matrix2()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    copy: function(b) {\n        mat2.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix2}\n     */\n    adjoint: function() {\n        mat2.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat2.determinant(this.array);\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix2}\n     */\n    identity: function() {\n        mat2.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix2}\n     */\n    invert: function() {\n        mat2.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    mul: function(b) {\n        mat2.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix2} a\n     * @return {clay.math.Matrix2}\n     */\n    mulLeft: function(a) {\n        mat2.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    multiply: function(b) {\n        mat2.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix2} a\n     * @return {clay.math.Matrix2}\n     */\n    multiplyLeft: function(a) {\n        mat2.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix2}\n     */\n    rotate: function(rad) {\n        mat2.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix2}\n     */\n    scale: function(v) {\n        mat2.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function() {\n        mat2.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n/**\n * @param  {Matrix2} out\n * @param  {Matrix2} a\n * @return {Matrix2}\n */\nMatrix2.adjoint = function(out, a) {\n    mat2.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @return {clay.math.Matrix2}\n */\nMatrix2.copy = function(out, a) {\n    mat2.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} a\n * @return {number}\n */\nMatrix2.determinant = function(a) {\n    return mat2.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @return {clay.math.Matrix2}\n */\nMatrix2.identity = function(out) {\n    mat2.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @return {clay.math.Matrix2}\n */\nMatrix2.invert = function(out, a) {\n    mat2.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Matrix2} b\n * @return {clay.math.Matrix2}\n */\nMatrix2.mul = function(out, a, b) {\n    mat2.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Matrix2} b\n * @return {clay.math.Matrix2}\n */\nMatrix2.multiply = Matrix2.mul;\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {number}   rad\n * @return {clay.math.Matrix2}\n */\nMatrix2.rotate = function(out, a, rad) {\n    mat2.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2}\n */\nMatrix2.scale = function(out, a, v) {\n    mat2.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {Matrix2} out\n * @param  {Matrix2} a\n * @return {Matrix2}\n */\nMatrix2.transpose = function(out, a) {\n    mat2.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix2;\n","import glMatrix from '../dep/glmatrix';\nvar mat2d = glMatrix.mat2d;\n\n/**\n * @constructor\n * @alias clay.math.Matrix2d\n */\nvar Matrix2d = function() {\n    /**\n     * Storage of Matrix2d\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix2d#\n     */\n    this.array = mat2d.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix2d#\n     */\n    this._dirty = true;\n};\n\nMatrix2d.prototype = {\n\n    constructor: Matrix2d,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Clone a new Matrix2d\n     * @return {clay.math.Matrix2d}\n     */\n    clone: function() {\n        return (new Matrix2d()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    copy: function(b) {\n        mat2d.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat2d.determinant(this.array);\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix2d}\n     */\n    identity: function() {\n        mat2d.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix2d}\n     */\n    invert: function() {\n        mat2d.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    mul: function(b) {\n        mat2d.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix2d}\n     */\n    mulLeft: function(b) {\n        mat2d.mul(this.array, b.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    multiply: function(b) {\n        mat2d.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix2d}\n     */\n    multiplyLeft: function(b) {\n        mat2d.multiply(this.array, b.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix2d}\n     */\n    rotate: function(rad) {\n        mat2d.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix2d}\n     */\n    scale: function(s) {\n        mat2d.scale(this.array, this.array, s.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v\n     * @param  {clay.math.Vector2}  v\n     * @return {clay.math.Matrix2d}\n     */\n    translate: function(v) {\n        mat2d.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.copy = function(out, a) {\n    mat2d.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} a\n * @return {number}\n */\nMatrix2d.determinant = function(a) {\n    return mat2d.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.identity = function(out) {\n    mat2d.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.invert = function(out, a) {\n    mat2d.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Matrix2d} b\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.mul = function(out, a, b) {\n    mat2d.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Matrix2d} b\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.multiply = Matrix2d.mul;\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {number}   rad\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.rotate = function(out, a, rad) {\n    mat2d.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.scale = function(out, a, v) {\n    mat2d.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.translate = function(out, a, v) {\n    mat2d.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix2d;\n","import glMatrix from '../dep/glmatrix';\nvar mat3 = glMatrix.mat3;\n\n/**\n * @constructor\n * @alias clay.math.Matrix3\n */\nvar Matrix3 = function () {\n\n    /**\n     * Storage of Matrix3\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix3#\n     */\n    this.array = mat3.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix3#\n     */\n    this._dirty = true;\n};\n\nMatrix3.prototype = {\n\n    constructor: Matrix3,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix3}\n     */\n    adjoint: function () {\n        mat3.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Matrix3\n     * @return {clay.math.Matrix3}\n     */\n    clone: function () {\n        return (new Matrix3()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    copy: function (b) {\n        mat3.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function () {\n        return mat3.determinant(this.array);\n    },\n\n    /**\n     * Copy the values from Matrix2d a\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix3}\n     */\n    fromMat2d: function (a) {\n        mat3.fromMat2d(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Copies the upper-left 3x3 values of Matrix4\n     * @param  {clay.math.Matrix4} a\n     * @return {clay.math.Matrix3}\n     */\n    fromMat4: function (a) {\n        mat3.fromMat4(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculates a rotation matrix from the given quaternion\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Matrix3}\n     */\n    fromQuat: function (q) {\n        mat3.fromQuat(this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix3}\n     */\n    identity: function () {\n        mat3.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix3}\n     */\n    invert: function () {\n        mat3.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    mul: function (b) {\n        mat3.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    mulLeft: function (a) {\n        mat3.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    multiply: function (b) {\n        mat3.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    multiplyLeft: function (a) {\n        mat3.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix3}\n     */\n    rotate: function (rad) {\n        mat3.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix3}\n     */\n    scale: function (v) {\n        mat3.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v\n     * @param  {clay.math.Vector2}  v\n     * @return {clay.math.Matrix3}\n     */\n    translate: function (v) {\n        mat3.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n     * @param {clay.math.Matrix4} a\n     */\n    normalFromMat4: function (a) {\n        mat3.normalFromMat4(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function () {\n        mat3.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function () {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.adjoint = function (out, a) {\n    mat3.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.copy = function (out, a) {\n    mat3.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} a\n * @return {number}\n */\nMatrix3.determinant = function (a) {\n    return mat3.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @return {clay.math.Matrix3}\n */\nMatrix3.identity = function (out) {\n    mat3.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.invert = function (out, a) {\n    mat3.invert(out.array, a.array);\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Matrix3} b\n * @return {clay.math.Matrix3}\n */\nMatrix3.mul = function (out, a, b) {\n    mat3.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Matrix3} b\n * @return {clay.math.Matrix3}\n */\nMatrix3.multiply = Matrix3.mul;\n\n/**\n * @param  {clay.math.Matrix3}  out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromMat2d = function (out, a) {\n    mat3.fromMat2d(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromMat4 = function (out, a) {\n    mat3.fromMat4(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3}    out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromQuat = function (out, q) {\n    mat3.fromQuat(out.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.normalFromMat4 = function (out, a) {\n    mat3.normalFromMat4(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {number}  rad\n * @return {clay.math.Matrix3}\n */\nMatrix3.rotate = function (out, a, rad) {\n    mat3.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Vector2} v\n * @return {clay.math.Matrix3}\n */\nMatrix3.scale = function (out, a, v) {\n    mat3.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.transpose = function (out, a) {\n    mat3.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Vector2} v\n * @return {clay.math.Matrix3}\n */\nMatrix3.translate = function (out, a, v) {\n    mat3.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix3;\n","import Vector3 from './Vector3';\nimport Vector2 from './Vector2';\n\n/**\n * Random or constant 1d, 2d, 3d vector generator\n * @constructor\n * @alias clay.math.Value\n */\nvar Value = function() {};\n\n/**\n * @function\n * @param {number|clay.math.Vector2|clay.math.Vector3} [out]\n * @return {number|clay.math.Vector2|clay.math.Vector3}\n */\nValue.prototype.get = function(out) {};\n\n// Constant\nvar ConstantValue = function(val) {\n    this.get = function() {\n        return val;\n    };\n};\nConstantValue.prototype = new Value();\nConstantValue.prototype.constructor = ConstantValue;\n\n// Vector\nvar VectorValue = function(val) {\n    var Constructor = val.constructor;\n    this.get = function(out) {\n        if (!out) {\n            out = new Constructor();\n        }\n        out.copy(val);\n        return out;\n    };\n};\nVectorValue.prototype = new Value();\nVectorValue.prototype.constructor = VectorValue;\n//Random 1D\nvar Random1D = function(min, max) {\n    var range = max - min;\n    this.get = function() {\n        return Math.random() * range + min;\n    };\n};\nRandom1D.prototype = new Value();\nRandom1D.prototype.constructor = Random1D;\n\n// Random2D\nvar Random2D = function(min, max) {\n    var rangeX = max.x - min.x;\n    var rangeY = max.y - min.y;\n\n    this.get = function(out) {\n        if (!out) {\n            out = new Vector2();\n        }\n        Vector2.set(\n            out,\n            rangeX * Math.random() + min.array[0],\n            rangeY * Math.random() + min.array[1]\n        );\n\n        return out;\n    };\n};\nRandom2D.prototype = new Value();\nRandom2D.prototype.constructor = Random2D;\n\nvar Random3D = function(min, max) {\n    var rangeX = max.x - min.x;\n    var rangeY = max.y - min.y;\n    var rangeZ = max.z - min.z;\n\n    this.get = function(out) {\n        if (!out) {\n            out = new Vector3();\n        }\n        Vector3.set(\n            out,\n            rangeX * Math.random() + min.array[0],\n            rangeY * Math.random() + min.array[1],\n            rangeZ * Math.random() + min.array[2]\n        );\n\n        return out;\n    };\n};\nRandom3D.prototype = new Value();\nRandom3D.prototype.constructor = Random3D;\n\n// Factory methods\n\n/**\n * Create a constant 1d value generator\n * @param  {number} constant\n * @return {clay.math.Value}\n */\nValue.constant = function(constant) {\n    return new ConstantValue(constant);\n};\n\n/**\n * Create a constant vector value(2d or 3d) generator\n * @param  {clay.math.Vector2|clay.math.Vector3} vector\n * @return {clay.math.Value}\n */\nValue.vector = function(vector) {\n    return new VectorValue(vector);\n};\n\n/**\n * Create a random 1d value generator\n * @param  {number} min\n * @param  {number} max\n * @return {clay.math.Value}\n */\nValue.random1D = function(min, max) {\n    return new Random1D(min, max);\n};\n\n/**\n * Create a random 2d value generator\n * @param  {clay.math.Vector2} min\n * @param  {clay.math.Vector2} max\n * @return {clay.math.Value}\n */\nValue.random2D = function(min, max) {\n    return new Random2D(min, max);\n};\n\n/**\n * Create a random 3d value generator\n * @param  {clay.math.Vector3} min\n * @param  {clay.math.Vector3} max\n * @return {clay.math.Value}\n */\nValue.random3D = function(min, max) {\n    return new Random3D(min, max);\n};\n\nexport default Value;\n","import glMatrix from '../dep/glmatrix';\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor\n * @alias clay.math.Vector4\n * @param {number} x\n * @param {number} y\n * @param {number} z\n * @param {number} w\n */\nvar Vector4 = function(x, y, z, w) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n    w = w || 0;\n\n    /**\n     * Storage of Vector4, read and write of x, y, z, w will change the values in array\n     * All methods also operate on the array instead of x, y, z, w components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector4#\n     */\n    this.array = vec4.fromValues(x, y, z, w);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector4#\n     */\n    this._dirty = true;\n};\n\nVector4.prototype = {\n\n    constructor: Vector4,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    add: function(b) {\n        vec4.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @param  {number}  w\n     * @return {clay.math.Vector4}\n     */\n    set: function(x, y, z, w) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this.array[3] = w;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y, z and w components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector4}\n     */\n    setArray: function(arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n        this.array[3] = arr[3];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector4\n     * @return {clay.math.Vector4}\n     */\n    clone: function() {\n        return new Vector4(this.x, this.y, this.z, this.w);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    copy: function(b) {\n        vec4.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    dist: function(b) {\n        return vec4.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    distance: function(b) {\n        return vec4.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    div: function(b) {\n        vec4.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    divide: function(b) {\n        vec4.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    dot: function(b) {\n        return vec4.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function() {\n        return vec4.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function() {\n        return vec4.length(this.array);\n    },\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector4} a\n     * @param  {clay.math.Vector4} b\n     * @param  {number}  t\n     * @return {clay.math.Vector4}\n     */\n    lerp: function(a, b, t) {\n        vec4.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    min: function(b) {\n        vec4.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    max: function(b) {\n        vec4.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    mul: function(b) {\n        vec4.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    multiply: function(b) {\n        vec4.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector4}\n     */\n    negate: function() {\n        vec4.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector4}\n     */\n    normalize: function() {\n        vec4.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y, z, w components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector4}\n     */\n    random: function(scale) {\n        vec4.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector4}\n     */\n    scale: function(s) {\n        vec4.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector4} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector4}\n     */\n    scaleAndAdd: function(b, s) {\n        vec4.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    sqrDist: function(b) {\n        return vec4.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    squaredDistance: function(b) {\n        return vec4.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function() {\n        return vec4.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function() {\n        return vec4.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    sub: function(b) {\n        vec4.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    subtract: function(b) {\n        vec4.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector4}\n     */\n    transformMat4: function(m) {\n        vec4.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Quaternion q\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Vector4}\n     */\n    transformQuat: function(q) {\n        vec4.transformQuat(this.array, this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Vector4.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name w\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'w', {\n        get: function () {\n            return this.array[3];\n        },\n        set: function (value) {\n            this.array[3] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.add = function(out, a, b) {\n    vec4.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {number}  x\n * @param  {number}  y\n * @param  {number}  z\n * @return {clay.math.Vector4}\n */\nVector4.set = function(out, x, y, z, w) {\n    vec4.set(out.array, x, y, z, w);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.copy = function(out, b) {\n    vec4.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.dist = function(a, b) {\n    return vec4.distance(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.distance = Vector4.dist;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.div = function(out, a, b) {\n    vec4.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.divide = Vector4.div;\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.dot = function(a, b) {\n    return vec4.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.len = function(b) {\n    return vec4.length(b.array);\n};\n\n// Vector4.length = Vector4.len;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @param  {number}  t\n * @return {clay.math.Vector4}\n */\nVector4.lerp = function(out, a, b, t) {\n    vec4.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.min = function(out, a, b) {\n    vec4.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.max = function(out, a, b) {\n    vec4.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.mul = function(out, a, b) {\n    vec4.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.multiply = Vector4.mul;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @return {clay.math.Vector4}\n */\nVector4.negate = function(out, a) {\n    vec4.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @return {clay.math.Vector4}\n */\nVector4.normalize = function(out, a) {\n    vec4.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.random = function(out, scale) {\n    vec4.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.scale = function(out, a, scale) {\n    vec4.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.scaleAndAdd = function(out, a, b, scale) {\n    vec4.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.sqrDist = function(a, b) {\n    return vec4.sqrDist(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.squaredDistance = Vector4.sqrDist;\n\n/**\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.sqrLen = function(a) {\n    return vec4.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.squaredLength = Vector4.sqrLen;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.sub = function(out, a, b) {\n    vec4.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.subtract = Vector4.sub;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector4}\n */\nVector4.transformMat4 = function(out, a, m) {\n    vec4.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Vector4}\n */\nVector4.transformQuat = function(out, a, q) {\n    vec4.transformQuat(out.array, a.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Vector4;\n","import Vector3 from '../math/Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\n/**\n * @constructor\n * @alias clay.particle.Particle\n */\nvar Particle = function() {\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.position = new Vector3();\n\n    /**\n     * Use euler angle to represent particle rotation\n     * @type {clay.math.Vector3}\n     */\n    this.rotation = new Vector3();\n\n    /**\n     * @type {?clay.math.Vector3}\n     */\n    this.velocity = null;\n\n    /**\n     * @type {?clay.math.Vector3}\n     */\n    this.angularVelocity = null;\n\n    /**\n     * @type {number}\n     */\n    this.life = 1;\n\n    /**\n     * @type {number}\n     */\n    this.age = 0;\n\n    /**\n     * @type {number}\n     */\n    this.spriteSize = 1;\n\n    /**\n     * @type {number}\n     */\n    this.weight = 1;\n\n    /**\n     * @type {clay.particle.Emitter}\n     */\n    this.emitter = null;\n};\n\n/**\n * Update particle position\n * @param  {number} deltaTime\n */\nParticle.prototype.update = function(deltaTime) {\n    if (this.velocity) {\n        vec3.scaleAndAdd(this.position.array, this.position.array, this.velocity.array, deltaTime);\n    }\n    if (this.angularVelocity) {\n        vec3.scaleAndAdd(this.rotation.array, this.rotation.array, this.angularVelocity.array, deltaTime);\n    }\n};\n\nexport default Particle;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\nimport Particle from './Particle';\nimport Value from '../math/Value';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 =  glMatrix.vec3;\n\n/**\n * @constructor clay.particle.Emitter\n * @extends clay.core.Base\n */\nvar Emitter = Base.extend(\n/** @lends clay.particle.Emitter# */\n{\n    /**\n     * Maximum number of particles created by this emitter\n     * @type {number}\n     */\n    max: 1000,\n    /**\n     * Number of particles created by this emitter each shot\n     * @type {number}\n     */\n    amount: 20,\n\n    // Init status for each particle\n    /**\n     * Particle life generator\n     * @type {?clay.math.Value.<number>}\n     */\n    life: null,\n    /**\n     * Particle position generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    position: null,\n    /**\n     * Particle rotation generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    rotation: null,\n    /**\n     * Particle velocity generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    velocity: null,\n    /**\n     * Particle angular velocity generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    angularVelocity: null,\n    /**\n     * Particle sprite size generator\n     * @type {?clay.math.Value.<number>}\n     */\n    spriteSize: null,\n    /**\n     * Particle weight generator\n     * @type {?clay.math.Value.<number>}\n     */\n    weight: null,\n\n    _particlePool: null\n\n}, function() {\n\n    this._particlePool = [];\n\n    // TODO Reduce heap memory\n    for (var i = 0; i < this.max; i++) {\n        var particle = new Particle();\n        particle.emitter = this;\n        this._particlePool.push(particle);\n\n        if (this.velocity) {\n            particle.velocity = new Vector3();\n        }\n        if (this.angularVelocity) {\n            particle.angularVelocity = new Vector3();\n        }\n    }\n},\n/** @lends clay.particle.Emitter.prototype */\n{\n    /**\n     * Emitter number of particles and push them to a given particle list. Emmit number is defined by amount property\n     * @param  {Array.<clay.particle.Particle>} out\n     */\n    emit: function(out) {\n        var amount = Math.min(this._particlePool.length, this.amount);\n\n        var particle;\n        for (var i = 0; i < amount; i++) {\n            particle = this._particlePool.pop();\n            // Initialize particle status\n            if (this.position) {\n                this.position.get(particle.position);\n            }\n            if (this.rotation) {\n                this.rotation.get(particle.rotation);\n            }\n            if (this.velocity) {\n                this.velocity.get(particle.velocity);\n            }\n            if (this.angularVelocity) {\n                this.angularVelocity.get(particle.angularVelocity);\n            }\n            if (this.life) {\n                particle.life = this.life.get();\n            }\n            if (this.spriteSize) {\n                particle.spriteSize = this.spriteSize.get();\n            }\n            if (this.weight) {\n                particle.weight = this.weight.get();\n            }\n            particle.age = 0;\n\n            out.push(particle);\n        }\n    },\n    /**\n     * Kill a dead particle and put it back in the pool\n     * @param  {clay.particle.Particle} particle\n     */\n    kill: function(particle) {\n        this._particlePool.push(particle);\n    }\n});\n\n/**\n * Create a constant 1d value generator. Alias for {@link clay.math.Value.constant}\n * @function clay.particle.Emitter.constant\n */\nEmitter.constant = Value.constant;\n\n/**\n * Create a constant vector value(2d or 3d) generator. Alias for {@link clay.math.Value.vector}\n * @function clay.particle.Emitter.vector\n */\nEmitter.vector = Value.vector;\n\n/**\n * Create a random 1d value generator. Alias for {@link clay.math.Value.random1D}\n * @function clay.particle.Emitter.random1D\n */\nEmitter.random1D = Value.random1D;\n\n/**\n * Create a random 2d value generator. Alias for {@link clay.math.Value.random2D}\n * @function clay.particle.Emitter.random2D\n */\nEmitter.random2D = Value.random2D;\n\n/**\n * Create a random 3d value generator. Alias for {@link clay.math.Value.random3D}\n * @function clay.particle.Emitter.random3D\n */\nEmitter.random3D = Value.random3D;\n\nexport default Emitter;\n","import Base from '../core/Base';\n/**\n * @constructor clay.particle.Field\n * @extends clay.core.Base\n */\nvar Field = Base.extend({}, {\n    /**\n     * Apply a field to the particle and update the particle velocity\n     * @param  {clay.math.Vector3} velocity\n     * @param  {clay.math.Vector3} position\n     * @param  {number} weight\n     * @param  {number} deltaTime\n     * @memberOf clay.particle.Field.prototype\n     */\n    applyTo: function(velocity, position, weight, deltaTime) {}\n});\n\nexport default Field;\n","import Field from './Field';\nimport Vector3 from '../math/Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 =  glMatrix.vec3;\n\n/**\n * @constructor clay.particle.ForceField\n * @extends clay.particle.Field\n */\nvar ForceField = Field.extend(function() {\n    return {\n        force: new Vector3()\n    };\n}, {\n    applyTo: function(velocity, position, weight, deltaTime) {\n        if (weight > 0) {\n            vec3.scaleAndAdd(velocity.array, velocity.array, this.force.array, deltaTime / weight);\n        }\n    }\n});\n\nexport default ForceField;\n","export default \"@export clay.particle.vertex\\nuniform mat4 worldView : WORLDVIEW;\\nuniform mat4 projection : PROJECTION;\\nattribute vec3 position : POSITION;\\nattribute vec3 normal : NORMAL;\\n#ifdef UV_ANIMATION\\nattribute vec2 texcoord0 : TEXCOORD_0;\\nattribute vec2 texcoord1 : TEXCOORD_1;\\nvarying vec2 v_Uv0;\\nvarying vec2 v_Uv1;\\n#endif\\nvarying float v_Age;\\nvoid main() {\\n    v_Age = normal.x;\\n    float rotation = normal.y;\\n    vec4 worldViewPosition = worldView * vec4(position, 1.0);\\n    gl_Position = projection * worldViewPosition;\\n    float w = gl_Position.w;\\n    gl_PointSize = normal.z * projection[0].x / w;\\n    #ifdef UV_ANIMATION\\n        v_Uv0 = texcoord0;\\n        v_Uv1 = texcoord1;\\n    #endif\\n}\\n@end\\n@export clay.particle.fragment\\nuniform sampler2D sprite;\\nuniform sampler2D gradient;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform float alpha : 1.0;\\nvarying float v_Age;\\n#ifdef UV_ANIMATION\\nvarying vec2 v_Uv0;\\nvarying vec2 v_Uv1;\\n#endif\\nvoid main() {\\n    vec4 color = vec4(color, alpha);\\n    #ifdef SPRITE_ENABLED\\n        #ifdef UV_ANIMATION\\n            color *= texture2D(sprite, mix(v_Uv0, v_Uv1, gl_PointCoord));\\n        #else\\n            color *= texture2D(sprite, gl_PointCoord);\\n        #endif\\n    #endif\\n    #ifdef GRADIENT_ENABLED\\n        color *= texture2D(gradient, vec2(v_Age, 0.5));\\n    #endif\\n    gl_FragColor = color;\\n}\\n@end\";\n","import Renderable from '../Renderable';\n\nimport Geometry from '../Geometry';\nimport Material from '../Material';\nimport Shader from '../Shader';\n\nimport particleEssl from './particle.glsl.js';\nShader['import'](particleEssl);\n\nvar particleShader = new Shader(Shader.source('clay.particle.vertex'), Shader.source('clay.particle.fragment'));\n\n/**\n * @constructor clay.particle.ParticleRenderable\n * @extends clay.Renderable\n *\n * @example\n *     var particleRenderable = new clay.particle.ParticleRenderable({\n *         spriteAnimationTileX: 4,\n *         spriteAnimationTileY: 4,\n *         spriteAnimationRepeat: 1\n *     });\n *     scene.add(particleRenderable);\n *     // Enable uv animation in the shader\n *     particleRenderable.material.define('both', 'UV_ANIMATION');\n *     var Emitter = clay.particle.Emitter;\n *     var Vector3 = clay.math.Vector3;\n *     var emitter = new Emitter({\n *         max: 2000,\n *         amount: 100,\n *         life: Emitter.random1D(10, 20),\n *         position: Emitter.vector(new Vector3()),\n *         velocity: Emitter.random3D(new Vector3(-10, 0, -10), new Vector3(10, 0, 10));\n *     });\n *     particleRenderable.addEmitter(emitter);\n *     var gravityField = new clay.particle.ForceField();\n *     gravityField.force.y = -10;\n *     particleRenderable.addField(gravityField);\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         particleRenderable.updateParticles(frameTime);\n *         renderer.render(scene, camera);\n *     });\n */\nvar ParticleRenderable = Renderable.extend(\n/** @lends clay.particle.ParticleRenderable# */\n{\n    /**\n     * @type {boolean}\n     */\n    loop: true,\n    /**\n     * @type {boolean}\n     */\n    oneshot: false,\n    /**\n     * Duration of particle system in milliseconds\n     * @type {number}\n     */\n    duration: 1,\n\n    // UV Animation\n    /**\n     * @type {number}\n     */\n    spriteAnimationTileX: 1,\n    /**\n     * @type {number}\n     */\n    spriteAnimationTileY: 1,\n    /**\n     * @type {number}\n     */\n    spriteAnimationRepeat: 0,\n\n    mode: Renderable.POINTS,\n\n    ignorePicking: true,\n\n    _elapsedTime: 0,\n\n    _emitting: true\n\n}, function(){\n\n    this.geometry = new Geometry({\n        dynamic: true\n    });\n\n    if (!this.material) {\n        this.material = new Material({\n            shader: particleShader,\n            transparent: true,\n            depthMask: false\n        });\n\n        this.material.enableTexture('sprite');\n    }\n\n    this._particles = [];\n    this._fields = [];\n    this._emitters = [];\n},\n/** @lends clay.particle.ParticleRenderable.prototype */\n{\n\n    culling: false,\n\n    frustumCulling: false,\n\n    castShadow: false,\n    receiveShadow: false,\n\n    /**\n     * Add emitter\n     * @param {clay.particle.Emitter} emitter\n     */\n    addEmitter: function(emitter) {\n        this._emitters.push(emitter);\n    },\n\n    /**\n     * Remove emitter\n     * @param {clay.particle.Emitter} emitter\n     */\n    removeEmitter: function(emitter) {\n        this._emitters.splice(this._emitters.indexOf(emitter), 1);\n    },\n\n    /**\n     * Add field\n     * @param {clay.particle.Field} field\n     */\n    addField: function(field) {\n        this._fields.push(field);\n    },\n\n    /**\n     * Remove field\n     * @param {clay.particle.Field} field\n     */\n    removeField: function(field) {\n        this._fields.splice(this._fields.indexOf(field), 1);\n    },\n\n    /**\n     * Reset the particle system.\n     */\n    reset: function() {\n        // Put all the particles back\n        for (var i = 0; i < this._particles.length; i++) {\n            var p = this._particles[i];\n            p.emitter.kill(p);\n        }\n        this._particles.length = 0;\n        this._elapsedTime = 0;\n        this._emitting = true;\n    },\n\n    /**\n     * @param  {number} deltaTime\n     */\n    updateParticles: function(deltaTime) {\n\n        // MS => Seconds\n        deltaTime /= 1000;\n        this._elapsedTime += deltaTime;\n\n        var particles = this._particles;\n\n        if (this._emitting) {\n            for (var i = 0; i < this._emitters.length; i++) {\n                this._emitters[i].emit(particles);\n            }\n            if (this.oneshot) {\n                this._emitting = false;\n            }\n        }\n\n        // Aging\n        var len = particles.length;\n        for (var i = 0; i < len;) {\n            var p = particles[i];\n            p.age += deltaTime;\n            if (p.age >= p.life) {\n                p.emitter.kill(p);\n                particles[i] = particles[len-1];\n                particles.pop();\n                len--;\n            } else {\n                i++;\n            }\n        }\n\n        for (var i = 0; i < len; i++) {\n            // Update\n            var p = particles[i];\n            if (this._fields.length > 0) {\n                for (var j = 0; j < this._fields.length; j++) {\n                    this._fields[j].applyTo(p.velocity, p.position, p.weight, deltaTime);\n                }\n            }\n            p.update(deltaTime);\n        }\n\n        this._updateVertices();\n    },\n\n    _updateVertices: function() {\n        var geometry = this.geometry;\n        // If has uv animation\n        var animTileX = this.spriteAnimationTileX;\n        var animTileY = this.spriteAnimationTileY;\n        var animRepeat = this.spriteAnimationRepeat;\n        var nUvAnimFrame = animTileY * animTileX * animRepeat;\n        var hasUvAnimation = nUvAnimFrame > 1;\n        var positions = geometry.attributes.position.value;\n        // Put particle status in normal\n        var normals = geometry.attributes.normal.value;\n        var uvs = geometry.attributes.texcoord0.value;\n        var uvs2 = geometry.attributes.texcoord1.value;\n\n        var len = this._particles.length;\n        if (!positions || positions.length !== len * 3) {\n            // TODO Optimize\n            positions = geometry.attributes.position.value = new Float32Array(len * 3);\n            normals = geometry.attributes.normal.value = new Float32Array(len * 3);\n            if (hasUvAnimation) {\n                uvs = geometry.attributes.texcoord0.value = new Float32Array(len * 2);\n                uvs2 = geometry.attributes.texcoord1.value = new Float32Array(len * 2);\n            }\n        }\n\n        var invAnimTileX = 1 / animTileX;\n        for (var i = 0; i < len; i++) {\n            var particle = this._particles[i];\n            var offset = i * 3;\n            for (var j = 0; j < 3; j++) {\n                positions[offset + j] = particle.position.array[j];\n                normals[offset] = particle.age / particle.life;\n                // normals[offset + 1] = particle.rotation;\n                normals[offset + 1] = 0;\n                normals[offset + 2] = particle.spriteSize;\n            }\n            var offset2 = i * 2;\n            if (hasUvAnimation) {\n                // TODO\n                var p = particle.age / particle.life;\n                var stage = Math.round(p * (nUvAnimFrame - 1)) * animRepeat;\n                var v = Math.floor(stage * invAnimTileX);\n                var u = stage - v * animTileX;\n                uvs[offset2] = u / animTileX;\n                uvs[offset2 + 1] = 1 - v / animTileY;\n                uvs2[offset2] = (u + 1) / animTileX;\n                uvs2[offset2 + 1] = 1 - (v + 1) / animTileY;\n            }\n        }\n\n        geometry.dirty();\n    },\n\n    /**\n     * @return {boolean}\n     */\n    isFinished: function() {\n        return this._elapsedTime > this.duration && !this.loop;\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function(renderer) {\n        // Put all the particles back\n        for (var i = 0; i < this._particles.length; i++) {\n            var p = this._particles[i];\n            p.emitter.kill(p);\n        }\n        this.geometry.dispose(renderer);\n        // TODO Dispose texture ?\n    },\n\n    /**\n     * @return {clay.particle.ParticleRenderable}\n     */\n    clone: function() {\n        var particleRenderable = new ParticleRenderable({\n            material: this.material\n        });\n        particleRenderable.loop = this.loop;\n        particleRenderable.duration = this.duration;\n        particleRenderable.oneshot = this.oneshot;\n        particleRenderable.spriteAnimationRepeat = this.spriteAnimationRepeat;\n        particleRenderable.spriteAnimationTileY = this.spriteAnimationTileY;\n        particleRenderable.spriteAnimationTileX = this.spriteAnimationTileX;\n\n        particleRenderable.position.copy(this.position);\n        particleRenderable.rotation.copy(this.rotation);\n        particleRenderable.scale.copy(this.scale);\n\n        for (var i = 0; i < this._children.length; i++) {\n            particleRenderable.add(this._children[i].clone());\n        }\n        return particleRenderable;\n    }\n});\n\nexport default ParticleRenderable;\n","export default \"@export clay.picking.color.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvoid main(){\\n    vec3 skinnedPosition = position;\\n    #ifdef SKINNING\\n        @import clay.chunk.skin_matrix\\n        skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    #endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n}\\n@end\\n@end\\n@export clay.picking.color.fragment\\nuniform vec4 color : [1.0, 1.0, 1.0, 1.0];\\nvoid main() {\\n    gl_FragColor = color;\\n}\\n@end\";\n","import Base from '../core/Base';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture2D from '../Texture2D';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport colorEssl from './color.glsl.js';\nShader.import(colorEssl);\n\n/**\n * Pixel picking is gpu based picking, which is fast and accurate.\n * But not like ray picking, it can't get the intersection point and triangle.\n * @constructor clay.picking.PixelPicking\n * @extends clay.core.Base\n */\nvar PixelPicking = Base.extend(function() {\n    return /** @lends clay.picking.PixelPicking# */ {\n        /**\n         * Target renderer\n         * @type {clay.Renderer}\n         */\n        renderer: null,\n        /**\n         * Downsample ratio of hidden frame buffer\n         * @type {number}\n         */\n        downSampleRatio: 1,\n\n        width: 100,\n        height: 100,\n\n        lookupOffset: 1,\n\n        _frameBuffer: null,\n        _texture: null,\n        _shader: null,\n\n        _idMaterials: [],\n        _lookupTable: [],\n\n        _meshMaterials: [],\n\n        _idOffset: 0\n    };\n}, function() {\n    if (this.renderer) {\n        this.width = this.renderer.getWidth();\n        this.height = this.renderer.getHeight();\n    }\n    this._init();\n}, /** @lends clay.picking.PixelPicking.prototype */ {\n    _init: function() {\n        this._texture = new Texture2D({\n            width: this.width * this.downSampleRatio,\n            height: this.height * this.downSampleRatio\n        });\n        this._frameBuffer = new FrameBuffer();\n\n        this._shader = new Shader(Shader.source('clay.picking.color.vertex'), Shader.source('clay.picking.color.fragment'));\n    },\n    /**\n     * Set picking presision\n     * @param {number} ratio\n     */\n    setPrecision: function(ratio) {\n        this._texture.width = this.width * ratio;\n        this._texture.height = this.height * ratio;\n        this.downSampleRatio = ratio;\n    },\n    resize: function(width, height) {\n        this._texture.width = width * this.downSampleRatio;\n        this._texture.height = height * this.downSampleRatio;\n        this.width = width;\n        this.height = height;\n        this._texture.dirty();\n    },\n    /**\n     * Update the picking framebuffer\n     * @param {number} ratio\n     */\n    update: function(scene, camera) {\n        var renderer = this.renderer;\n        if (renderer.getWidth() !== this.width || renderer.getHeight() !== this.height) {\n            this.resize(renderer.width, renderer.height);\n        }\n\n        this._frameBuffer.attach(this._texture);\n        this._frameBuffer.bind(renderer);\n        this._idOffset = this.lookupOffset;\n        this._setMaterial(scene);\n        renderer.render(scene, camera);\n        this._restoreMaterial();\n        this._frameBuffer.unbind(renderer);\n    },\n\n    _setMaterial: function(root) {\n        for (var i =0; i < root._children.length; i++) {\n            var child = root._children[i];\n            if (child.geometry && child.material && child.material.shader) {\n                var id = this._idOffset++;\n                var idx = id - this.lookupOffset;\n                var material = this._idMaterials[idx];\n                if (!material) {\n                    material = new Material({\n                        shader: this._shader\n                    });\n                    var color = packID(id);\n                    color[0] /= 255;\n                    color[1] /= 255;\n                    color[2] /= 255;\n                    color[3] = 1.0;\n                    material.set('color', color);\n                    this._idMaterials[idx] = material;\n                }\n                this._meshMaterials[idx] = child.material;\n                this._lookupTable[idx] = child;\n                child.material = material;\n            }\n            if (child._children.length) {\n                this._setMaterial(child);\n            }\n        }\n    },\n\n    /**\n     * Pick the object\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @return {clay.Node}\n     */\n    pick: function(x, y) {\n        var renderer = this.renderer;\n\n        var ratio = this.downSampleRatio;\n        x = Math.ceil(ratio * x);\n        y = Math.ceil(ratio * (this.height - y));\n\n        this._frameBuffer.bind(renderer);\n        var pixel = new Uint8Array(4);\n        var _gl = renderer.gl;\n        // TODO out of bounds ?\n        // preserveDrawingBuffer ?\n        _gl.readPixels(x, y, 1, 1, _gl.RGBA, _gl.UNSIGNED_BYTE, pixel);\n        this._frameBuffer.unbind(renderer);\n        // Skip interpolated pixel because of anti alias\n        if (pixel[3] === 255) {\n            var id = unpackID(pixel[0], pixel[1], pixel[2]);\n            if (id) {\n                var el = this._lookupTable[id - this.lookupOffset];\n                return el;\n            }\n        }\n    },\n\n    _restoreMaterial: function() {\n        for (var i = 0; i < this._lookupTable.length; i++) {\n            this._lookupTable[i].material = this._meshMaterials[i];\n        }\n    },\n\n    dispose: function(renderer) {\n        this._frameBuffer.dispose(renderer);\n    }\n});\n\nfunction packID(id){\n    var r = id >> 16;\n    var g = (id - (r << 8)) >> 8;\n    var b = id - (r << 16) - (g<<8);\n    return [r, g, b];\n}\n\nfunction unpackID(r, g, b){\n    return (r << 16) + (g<<8) + b;\n}\n\nexport default PixelPicking;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.plugin.FreeControl\n * @example\n *     var control = new clay.plugin.FreeControl({\n *         target: camera,\n *         domElement: renderer.canvas\n *     });\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         control.update(frameTime);\n *         renderer.render(scene, camera);\n *     });\n */\nvar FreeControl = Base.extend(function() {\n    return /** @lends clay.plugin.FreeControl# */ {\n        /**\n         * Scene node to control, mostly it is a camera\n         * @type {clay.Node}\n         */\n        target: null,\n\n        /**\n         * Target dom to bind with mouse events\n         * @type {HTMLElement}\n         */\n        domElement: null,\n\n        /**\n         * Mouse move sensitivity\n         * @type {number}\n         */\n        sensitivity: 1,\n\n        /**\n         * Target move speed\n         * @type {number}\n         */\n        speed: 0.4,\n\n        /**\n         * Up axis\n         * @type {clay.math.Vector3}\n         */\n        up: new Vector3(0, 1, 0),\n\n        /**\n         * If lock vertical movement\n         * @type {boolean}\n         */\n        verticalMoveLock: false,\n\n        /**\n         * @type {clay.animation.Animation}\n         */\n        animation: null,\n\n        _moveForward: false,\n        _moveBackward: false,\n        _moveLeft: false,\n        _moveRight: false,\n\n        _offsetPitch: 0,\n        _offsetRoll: 0\n    };\n}, function() {\n    this._lockChange = this._lockChange.bind(this);\n    this._keyDown = this._keyDown.bind(this);\n    this._keyUp = this._keyUp.bind(this);\n    this._mouseMove = this._mouseMove.bind(this);\n\n    if (this.domElement) {\n        this.enable();\n    }\n},\n/** @lends clay.plugin.FreeControl.prototype */\n{\n    /**\n     * Enable control\n     */\n    enable: function() {\n        // Use pointer lock\n        // http://www.html5rocks.com/en/tutorials/pointerlock/intro/\n        var el = this.domElement;\n\n        //Must request pointer lock after click event, can't not do it directly\n        //Why ? ?\n        el.addEventListener('click', this._requestPointerLock);\n\n        document.addEventListener('pointerlockchange', this._lockChange);\n        document.addEventListener('mozpointerlockchange', this._lockChange);\n        document.addEventListener('webkitpointerlockchange', this._lockChange);\n\n        document.addEventListener('keydown', this._keyDown);\n        document.addEventListener('keyup', this._keyUp);\n\n        if (this.animation) {\n            this.animation.on('frame', this._detectMovementChange, this);\n        }\n    },\n\n    /**\n     * Disable control\n     */\n    disable: function() {\n\n        this.target.off('beforeupdate', this._beforeUpdateCamera);\n\n        var el = this.domElement;\n\n        el.exitPointerLock = el.exitPointerLock\n            || el.mozExitPointerLock\n            || el.webkitExitPointerLock;\n\n        if (el.exitPointerLock) {\n            el.exitPointerLock();\n        }\n\n        this.domElement.removeEventListener('click', this._requestPointerLock);\n\n        document.removeEventListener('pointerlockchange', this._lockChange);\n        document.removeEventListener('mozpointerlockchange', this._lockChange);\n        document.removeEventListener('webkitpointerlockchange', this._lockChange);\n\n        document.removeEventListener('keydown', this._keyDown);\n        document.removeEventListener('keyup', this._keyUp);\n\n        if (this.animation) {\n            this.animation.off('frame', this._detectMovementChange);\n        }\n    },\n\n    _requestPointerLock: function() {\n        var el = this;\n        el.requestPointerLock = el.requestPointerLock\n            || el.mozRequestPointerLock\n            || el.webkitRequestPointerLock;\n\n        el.requestPointerLock();\n    },\n\n    /**\n     * Control update. Should be invoked every frame\n     * @param {number} frameTime Frame time\n     */\n    update: function(frameTime) {\n        var target = this.target;\n\n        var position = this.target.position;\n        var xAxis = target.localTransform.x.normalize();\n        var zAxis = target.localTransform.z.normalize();\n\n        if (this.verticalMoveLock) {\n            zAxis.y = 0;\n            zAxis.normalize();\n        }\n\n        var speed = this.speed * frameTime / 20;\n\n        if (this._moveForward) {\n            // Opposite direction of z\n            position.scaleAndAdd(zAxis, -speed);\n        }\n        if (this._moveBackward) {\n            position.scaleAndAdd(zAxis, speed);\n        }\n        if (this._moveLeft) {\n            position.scaleAndAdd(xAxis, -speed / 2);\n        }\n        if (this._moveRight) {\n            position.scaleAndAdd(xAxis, speed / 2);\n        }\n\n        target.rotateAround(target.position, this.up, -this._offsetPitch * frameTime * Math.PI / 360);\n        var xAxis = target.localTransform.x;\n        target.rotateAround(target.position, xAxis, -this._offsetRoll * frameTime * Math.PI / 360);\n\n        this._offsetRoll = this._offsetPitch = 0;\n    },\n\n    _lockChange: function() {\n        if (\n            document.pointerLockElement === this.domElement\n            || document.mozPointerLockElement === this.domElement\n            || document.webkitPointerLockElement === this.domElement\n        ) {\n            document.addEventListener('mousemove', this._mouseMove, false);\n        } else {\n            document.removeEventListener('mousemove', this._mouseMove);\n        }\n    },\n\n    _mouseMove: function(e) {\n        var dx = e.movementX || e.mozMovementX || e.webkitMovementX || 0;\n        var dy = e.movementY || e.mozMovementY || e.webkitMovementY || 0;\n\n        this._offsetPitch += dx * this.sensitivity / 200;\n        this._offsetRoll += dy * this.sensitivity / 200;\n\n        // Trigger change event to remind renderer do render\n        this.trigger('change');\n    },\n\n    _detectMovementChange: function () {\n        if (this._moveForward || this._moveBackward || this._moveLeft || this._moveRight) {\n            this.trigger('change');\n        }\n    },\n\n    _keyDown: function(e) {\n        switch(e.keyCode) {\n            case 87: //w\n            case 37: //up arrow\n                this._moveForward = true;\n                break;\n            case 83: //s\n            case 40: //down arrow\n                this._moveBackward = true;\n                break;\n            case 65: //a\n            case 37: //left arrow\n                this._moveLeft = true;\n                break;\n            case 68: //d\n            case 39: //right arrow\n                this._moveRight = true;\n                break;\n        }\n        // Trigger change event to remind renderer do render\n        this.trigger('change');\n    },\n\n    _keyUp: function(e) {\n        switch(e.keyCode) {\n            case 87: //w\n            case 37: //up arrow\n                this._moveForward = false;\n                break;\n            case 83: //s\n            case 40: //down arrow\n                this._moveBackward = false;\n                break;\n            case 65: //a\n            case 37: //left arrow\n                this._moveLeft = false;\n                break;\n            case 68: //d\n            case 39: //right arrow\n                this._moveRight = false;\n                break;\n        }\n    }\n});\n\nexport default FreeControl;\n","var GestureMgr = function () {\n\n    this._track = [];\n};\n\nGestureMgr.prototype = {\n\n    constructor: GestureMgr,\n\n    recognize: function (event, target, root) {\n        this._doTrack(event, target, root);\n        return this._recognize(event);\n    },\n\n    clear: function () {\n        this._track.length = 0;\n        return this;\n    },\n\n    _doTrack: function (event, target, root) {\n        var touches = event.targetTouches;\n\n        if (!touches) {\n            return;\n        }\n\n        var trackItem = {\n            points: [],\n            touches: [],\n            target: target,\n            event: event\n        };\n\n        for (var i = 0, len = touches.length; i < len; i++) {\n            var touch = touches[i];\n            trackItem.points.push([touch.clientX, touch.clientY]);\n            trackItem.touches.push(touch);\n        }\n\n        this._track.push(trackItem);\n    },\n\n    _recognize: function (event) {\n        for (var eventName in recognizers) {\n            if (recognizers.hasOwnProperty(eventName)) {\n                var gestureInfo = recognizers[eventName](this._track, event);\n                if (gestureInfo) {\n                    return gestureInfo;\n                }\n            }\n        }\n    }\n};\n\nfunction dist(pointPair) {\n    var dx = pointPair[1][0] - pointPair[0][0];\n    var dy = pointPair[1][1] - pointPair[0][1];\n\n    return Math.sqrt(dx * dx + dy * dy);\n}\n\nfunction center(pointPair) {\n    return [\n        (pointPair[0][0] + pointPair[1][0]) / 2,\n        (pointPair[0][1] + pointPair[1][1]) / 2\n    ];\n}\n\nvar recognizers = {\n\n    pinch: function (track, event) {\n        var trackLen = track.length;\n\n        if (!trackLen) {\n            return;\n        }\n\n        var pinchEnd = (track[trackLen - 1] || {}).points;\n        var pinchPre = (track[trackLen - 2] || {}).points || pinchEnd;\n\n        if (pinchPre\n            && pinchPre.length > 1\n            && pinchEnd\n            && pinchEnd.length > 1\n        ) {\n            var pinchScale = dist(pinchEnd) / dist(pinchPre);\n            !isFinite(pinchScale) && (pinchScale = 1);\n\n            event.pinchScale = pinchScale;\n\n            var pinchCenter = center(pinchEnd);\n            event.pinchX = pinchCenter[0];\n            event.pinchY = pinchCenter[1];\n\n            return {\n                type: 'pinch',\n                target: track[0].target,\n                event: event\n            };\n        }\n    }\n};\n\nexport default GestureMgr;\n","import Mesh from '../Mesh';\nimport Geometry from '../Geometry';\nimport Plane from '../math/Plane';\nimport Vector3 from '../math/Vector3';\nimport Matrix4 from '../math/Matrix4';\nimport Ray from '../math/Ray';\n\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\nvar uvs = [[0, 0], [0, 1], [1, 1], [1, 0]];\nvar tris = [0, 1, 2, 2, 3, 0];\n\nvar InfinitePlane = Mesh.extend({\n\n    camera: null,\n\n    plane: null,\n\n    maxGrid: 0,\n\n    // TODO\n    frustumCulling: false\n\n}, function () {\n    var geometry = this.geometry = new Geometry({\n        dynamic: true\n    });\n    geometry.attributes.position.init(6);\n    geometry.attributes.normal.init(6);\n    geometry.attributes.texcoord0.init(6);\n    geometry.indices = new Uint16Array(6);\n\n    this.plane = new Plane();\n}, {\n\n    updateGeometry: function () {\n\n        var coords = this._unProjectGrid();\n        if (!coords) {\n            return;\n        }\n        var positionAttr = this.geometry.attributes.position;\n        var normalAttr = this.geometry.attributes.normal;\n        var texcoords = this.geometry.attributes.texcoord0;\n        var indices = this.geometry.indices;\n\n        for (var i = 0; i < 6; i++) {\n            var idx = tris[i];\n            positionAttr.set(i, coords[idx].array);\n            normalAttr.set(i, this.plane.normal.array);\n            texcoords.set(i, uvs[idx]);\n            indices[i] = i;\n        }\n        this.geometry.dirty();\n    },\n\n    // http://fileadmin.cs.lth.se/graphics/theses/projects/projgrid/\n    _unProjectGrid: (function () {\n\n        var planeViewSpace = new Plane();\n        var lines = [\n            0, 1, 0, 2, 1, 3, 2, 3,\n            4, 5, 4, 6, 5, 7, 6, 7,\n            0, 4, 1, 5, 2, 6, 3, 7\n        ];\n\n        var start = new Vector3();\n        var end = new Vector3();\n\n        var points = [];\n\n        // 1----2\n        // |    |\n        // 0----3\n        var coords = [];\n        for (var i = 0; i < 4; i++) {\n            coords[i] = new Vector3(0, 0);\n        }\n\n        var ray = new Ray();\n\n        return function () {\n            planeViewSpace.copy(this.plane);\n            planeViewSpace.applyTransform(this.camera.viewMatrix);\n\n            var frustumVertices = this.camera.frustum.vertices;\n\n            var nPoints = 0;\n            // Intersect with lines of frustum\n            for (var i = 0; i < 12; i++) {\n                start.array = frustumVertices[lines[i * 2]];\n                end.array = frustumVertices[lines[i * 2 + 1]];\n\n                var point = planeViewSpace.intersectLine(start, end, points[nPoints]);\n                if (point) {\n                    if (!points[nPoints]) {\n                        points[nPoints] = point;\n                    }\n                    nPoints++;\n                }\n            }\n            if (nPoints === 0) {\n                return;\n            }\n            for (var i = 0; i < nPoints; i++) {\n                points[i].applyProjection(this.camera.projectionMatrix);\n            }\n            var minX = points[0].array[0];\n            var minY = points[0].array[1];\n            var maxX = points[0].array[0];\n            var maxY = points[0].array[1];\n            for (var i = 1; i < nPoints; i++) {\n                maxX = Math.max(maxX, points[i].array[0]);\n                maxY = Math.max(maxY, points[i].array[1]);\n                minX = Math.min(minX, points[i].array[0]);\n                minY = Math.min(minY, points[i].array[1]);\n            }\n            if (minX == maxX || minY == maxY) {\n                return;\n            }\n            coords[0].array[0] = minX;\n            coords[0].array[1] = minY;\n            coords[1].array[0] = minX;\n            coords[1].array[1] = maxY;\n            coords[2].array[0] = maxX;\n            coords[2].array[1] = maxY;\n            coords[3].array[0] = maxX;\n            coords[3].array[1] = minY;\n\n            for (var i = 0; i < 4; i++) {\n                this.camera.castRay(coords[i], ray);\n                ray.intersectPlane(this.plane, coords[i]);\n            }\n\n            return coords;\n        };\n    })()\n});\n\nexport default InfinitePlane;\n","import Base from '../core/Base';\nimport Vector2 from '../math/Vector2';\nimport Vector3 from '../math/Vector3';\nimport GestureMgr from './GestureMgr';\n\nfunction firstNotNull() {\n    for (var i = 0, len = arguments.length; i < len; i++) {\n        if (arguments[i] != null) {\n            return arguments[i];\n        }\n    }\n}\n\nfunction convertToArray(val) {\n    if (!Array.isArray(val)) {\n        val = [val, val];\n    }\n    return val;\n}\n\n/**\n * @constructor\n * @alias clay.plugin.OrbitControl\n */\nvar OrbitControl = Base.extend(function () {\n\n    return /** @lends clay.plugin.OrbitControl# */ {\n\n        timeline: null,\n\n        /**\n         * @type {HTMLDomElement}\n         */\n        domElement: null,\n\n        /**\n         * @type {clay.Node}\n         */\n        target: null,\n        /**\n         * @type {clay.math.Vector3}\n         */\n        _center: new Vector3(),\n\n        /**\n         * Minimum distance to the center\n         * @type {number}\n         * @default 0.5\n         */\n        minDistance: 0.1,\n\n        /**\n         * Maximum distance to the center\n         * @type {number}\n         * @default 2\n         */\n        maxDistance: 1000,\n\n        /**\n         * Minimum alpha rotation\n         */\n        minAlpha: -90,\n\n        /**\n         * Maximum alpha rotation\n         */\n        maxAlpha: 90,\n\n        /**\n         * Minimum beta rotation\n         */\n        minBeta: -Infinity,\n        /**\n         * Maximum beta rotation\n         */\n        maxBeta: Infinity,\n\n        /**\n         * Start auto rotating after still for the given time\n         */\n        autoRotateAfterStill: 0,\n\n        /**\n         * Direction of autoRotate. cw or ccw when looking top down.\n         */\n        autoRotateDirection: 'cw',\n\n        /**\n         * Degree per second\n         */\n        autoRotateSpeed: 60,\n\n        /**\n         * Pan or rotate\n         * @type {String}\n         */\n        _mode: 'rotate',\n\n        /**\n         * @param {number}\n         */\n        damping: 0.8,\n\n        /**\n         * @param {number}\n         */\n        rotateSensitivity: 1,\n\n        /**\n         * @param {number}\n         */\n        zoomSensitivity: 1,\n\n        /**\n         * @param {number}\n         */\n        panSensitivity: 1,\n\n        _needsUpdate: false,\n\n        _rotating: false,\n\n        // Rotation around yAxis\n        _phi: 0,\n        // Rotation around xAxis\n        _theta: 0,\n\n        _mouseX: 0,\n        _mouseY: 0,\n\n        _rotateVelocity: new Vector2(),\n\n        _panVelocity: new Vector2(),\n\n        _distance: 20,\n\n        _zoomSpeed: 0,\n\n        _stillTimeout: 0,\n\n        _animators: [],\n\n        _gestureMgr: new GestureMgr()\n    };\n}, function () {\n    // Each OrbitControl has it's own handler\n    this._mouseDownHandler = this._mouseDownHandler.bind(this);\n    this._mouseWheelHandler = this._mouseWheelHandler.bind(this);\n    this._mouseMoveHandler = this._mouseMoveHandler.bind(this);\n    this._mouseUpHandler = this._mouseUpHandler.bind(this);\n    this._pinchHandler = this._pinchHandler.bind(this);\n\n    this.update = this.update.bind(this);\n\n    this.init();\n}, /** @lends clay.plugin.OrbitControl# */ {\n    /**\n     * Initialize.\n     * Mouse event binding\n     */\n    init: function () {\n        var dom = this.domElement;\n\n        dom.addEventListener('touchstart', this._mouseDownHandler);\n\n        dom.addEventListener('mousedown', this._mouseDownHandler);\n        dom.addEventListener('mousewheel', this._mouseWheelHandler);\n\n        if (this.timeline) {\n            this.timeline.on('frame', this.update);\n        }\n    },\n\n    /**\n     * Dispose.\n     * Mouse event unbinding\n     */\n    dispose: function () {\n        var dom = this.domElement;\n\n        dom.removeEventListener('touchstart', this._mouseDownHandler);\n        dom.removeEventListener('touchmove', this._mouseMoveHandler);\n        dom.removeEventListener('touchend', this._mouseUpHandler);\n\n        dom.removeEventListener('mousedown', this._mouseDownHandler);\n        dom.removeEventListener('mousemove', this._mouseMoveHandler);\n        dom.removeEventListener('mouseup', this._mouseUpHandler);\n        dom.removeEventListener('mousewheel', this._mouseWheelHandler);\n\n        if (this.timeline) {\n            this.timeline.off('frame', this.update);\n        }\n        this.stopAllAnimation();\n    },\n\n    /**\n     * Get distance\n     * @return {number}\n     */\n    getDistance: function () {\n        return this._distance;\n    },\n\n    /**\n     * Set distance\n     * @param {number} distance\n     */\n    setDistance: function (distance) {\n        this._distance = distance;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Get alpha rotation\n     * Alpha angle for top-down rotation. Positive to rotate to top.\n     *\n     * Which means camera rotation around x axis.\n     */\n    getAlpha: function () {\n        return this._theta / Math.PI * 180;\n    },\n\n    /**\n     * Get beta rotation\n     * Beta angle for left-right rotation. Positive to rotate to right.\n     *\n     * Which means camera rotation around y axis.\n     */\n    getBeta: function () {\n        return -this._phi / Math.PI * 180;\n    },\n\n    /**\n     * Get control center\n     * @return {Array.<number>}\n     */\n    getCenter: function () {\n        return this._center.toArray();\n    },\n\n    /**\n     * Set alpha rotation angle\n     * @param {number} alpha\n     */\n    setAlpha: function (alpha) {\n        alpha = Math.max(Math.min(this.maxAlpha, alpha), this.minAlpha);\n\n        this._theta = alpha / 180 * Math.PI;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Set beta rotation angle\n     * @param {number} beta\n     */\n    setBeta: function (beta) {\n        beta = Math.max(Math.min(this.maxBeta, beta), this.minBeta);\n\n        this._phi = -beta / 180 * Math.PI;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Set control center\n     * @param {Array.<number>} center\n     */\n    setCenter: function (centerArr) {\n        this._center.setArray(centerArr);\n    },\n\n    setOption: function (opts) {\n        opts = opts || {};\n\n        ['autoRotate', 'autoRotateAfterStill',\n            'autoRotateDirection', 'autoRotateSpeed',\n            'damping',\n            'minDistance', 'maxDistance',\n            'minAlpha', 'maxAlpha', 'minBeta', 'maxBeta',\n            'rotateSensitivity', 'zoomSensitivity', 'panSensitivity'\n        ].forEach(function (key) {\n            if (opts[key] != null) {\n                this[key] = opts[key];\n            }\n        }, this);\n\n        if (opts.distance != null) {\n            this.setDistance(opts.distance);\n        }\n\n        if (opts.alpha != null) {\n            this.setAlpha(opts.alpha);\n        }\n        if (opts.beta != null) {\n            this.setBeta(opts.beta);\n        }\n\n        if (opts.center) {\n            this.setCenter(opts.center);\n        }\n    },\n\n    /**\n     * @param {Object} opts\n     * @param {number} opts.distance\n     * @param {number} opts.alpha\n     * @param {number} opts.beta\n     * @param {number} [opts.duration=1000]\n     * @param {number} [opts.easing='linear']\n     * @param {number} [opts.done]\n     */\n    animateTo: function (opts) {\n        var self = this;\n\n        var obj = {};\n        var target = {};\n        var timeline = this.timeline;\n        if (!timeline) {\n            return;\n        }\n        if (opts.distance != null) {\n            obj.distance = this.getDistance();\n            target.distance = opts.distance;\n        }\n        if (opts.alpha != null) {\n            obj.alpha = this.getAlpha();\n            target.alpha = opts.alpha;\n        }\n        if (opts.beta != null) {\n            obj.beta = this.getBeta();\n            target.beta = opts.beta;\n        }\n        if (opts.center != null) {\n            obj.center = this.getCenter();\n            target.center = opts.center;\n        }\n\n        return this._addAnimator(\n            timeline.animate(obj)\n                .when(opts.duration || 1000, target)\n                .during(function () {\n                    if (obj.alpha != null) {\n                        self.setAlpha(obj.alpha);\n                    }\n                    if (obj.beta != null) {\n                        self.setBeta(obj.beta);\n                    }\n                    if (obj.distance != null) {\n                        self.setDistance(obj.distance);\n                    }\n                    if (obj.center != null) {\n                        self.setCenter(obj.center);\n                    }\n                    self._needsUpdate = true;\n                })\n                .done(opts.done)\n        ).start(opts.easing || 'linear');\n    },\n\n    /**\n     * Stop all animations\n     */\n    stopAllAnimation: function () {\n        for (var i = 0; i < this._animators.length; i++) {\n            this._animators[i].stop();\n        }\n        this._animators.length = 0;\n    },\n\n    _isAnimating: function () {\n        return this._animators.length > 0;\n    },\n    /**\n     * Call update each frame\n     * @param  {number} deltaTime Frame time\n     */\n    update: function (deltaTime) {\n\n        deltaTime = deltaTime || 16;\n\n        if (this._rotating) {\n            var radian = (this.autoRotateDirection === 'cw' ? 1 : -1)\n                * this.autoRotateSpeed / 180 * Math.PI;\n            this._phi -= radian * deltaTime / 1000;\n            this._needsUpdate = true;\n        }\n        else if (this._rotateVelocity.len() > 0) {\n            this._needsUpdate = true;\n        }\n\n        if (Math.abs(this._zoomSpeed) > 0.01 || this._panVelocity.len() > 0) {\n            this._needsUpdate = true;\n        }\n\n        if (!this._needsUpdate) {\n            return;\n        }\n\n        // Fixed deltaTime\n        this._updateDistance(Math.min(deltaTime, 50));\n        this._updatePan(Math.min(deltaTime, 50));\n\n        this._updateRotate(Math.min(deltaTime, 50));\n\n        this._updateTransform();\n\n        this.target.update();\n\n        this.trigger('update');\n\n        this._needsUpdate = false;\n    },\n\n    _updateRotate: function (deltaTime) {\n        var velocity = this._rotateVelocity;\n        this._phi = velocity.y * deltaTime / 20 + this._phi;\n        this._theta = velocity.x * deltaTime / 20 + this._theta;\n\n        this.setAlpha(this.getAlpha());\n        this.setBeta(this.getBeta());\n\n        this._vectorDamping(velocity, this.damping);\n    },\n\n    _updateDistance: function (deltaTime) {\n        this._setDistance(this._distance + this._zoomSpeed * deltaTime / 20);\n        this._zoomSpeed *= this.damping;\n    },\n\n    _setDistance: function (distance) {\n        this._distance = Math.max(Math.min(distance, this.maxDistance), this.minDistance);\n    },\n\n    _updatePan: function (deltaTime) {\n        var velocity = this._panVelocity;\n        var len = this._distance;\n\n        var target = this.target;\n        var yAxis = target.worldTransform.y;\n        var xAxis = target.worldTransform.x;\n\n        // PENDING\n        this._center\n            .scaleAndAdd(xAxis, -velocity.x * len / 200)\n            .scaleAndAdd(yAxis, -velocity.y * len / 200);\n\n        this._vectorDamping(velocity, 0);\n    },\n\n    _updateTransform: function () {\n        var camera = this.target;\n\n        var dir = new Vector3();\n        var theta = this._theta + Math.PI / 2;\n        var phi = this._phi + Math.PI / 2;\n        var r = Math.sin(theta);\n\n        dir.x = r * Math.cos(phi);\n        dir.y = -Math.cos(theta);\n        dir.z = r * Math.sin(phi);\n\n        camera.position.copy(this._center).scaleAndAdd(dir, this._distance);\n        camera.rotation.identity()\n            // First around y, then around x\n            .rotateY(-this._phi)\n            .rotateX(-this._theta);\n    },\n\n    _startCountingStill: function () {\n        clearTimeout(this._stillTimeout);\n\n        var time = this.autoRotateAfterStill;\n        var self = this;\n        if (!isNaN(time) && time > 0) {\n            this._stillTimeout = setTimeout(function () {\n                self._rotating = true;\n            }, time * 1000);\n        }\n    },\n\n    _vectorDamping: function (v, damping) {\n        var speed = v.len();\n        speed = speed * damping;\n        if (speed < 1e-4) {\n            speed = 0;\n        }\n        v.normalize().scale(speed);\n    },\n\n    decomposeTransform: function () {\n        if (!this.target) {\n            return;\n        }\n\n        // FIXME euler order......\n        // FIXME alpha is not certain when beta is 90 or -90\n        // var euler = new Vector3();\n        // euler.eulerFromMat3(\n        //    new Matrix3().fromQuat(this.target.rotation), 'ZYX'\n        // );\n        // euler.eulerFromQuat(\n        //     this.target.rotation.normalize(), 'ZYX'\n        // );\n        this.target.updateWorldTransform();\n\n        var forward = this.target.worldTransform.z;\n        var alpha = Math.asin(forward.y);\n        var beta = Math.atan2(forward.x, forward.z);\n\n        this._theta = alpha;\n        this._phi = -beta;\n\n        this.setBeta(this.getBeta());\n        this.setAlpha(this.getAlpha());\n\n        this._setDistance(this.target.position.dist(this._center));\n    },\n\n    _mouseDownHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var x = e.clientX;\n        var y = e.clientY;\n        // Touch\n        if (e.targetTouches) {\n            var touch = e.targetTouches[0];\n            x = touch.clientX;\n            y = touch.clientY;\n\n            this._mode = 'rotate';\n\n            this._processGesture(e, 'start');\n        }\n\n        var dom = this.domElement;\n        dom.addEventListener('touchmove', this._mouseMoveHandler);\n        dom.addEventListener('touchend', this._mouseUpHandler);\n\n        dom.addEventListener('mousemove', this._mouseMoveHandler);\n        dom.addEventListener('mouseup', this._mouseUpHandler);\n\n        if (e.button === 0) {\n            this._mode = 'rotate';\n        }\n        else if (e.button === 1) {\n            this._mode = 'pan';\n        }\n\n        // Reset rotate velocity\n        this._rotateVelocity.set(0, 0);\n        this._rotating = false;\n        if (this.autoRotate) {\n            this._startCountingStill();\n        }\n\n        this._mouseX = x;\n        this._mouseY = y;\n    },\n\n    _mouseMoveHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var x = e.clientX;\n        var y = e.clientY;\n\n        var haveGesture;\n        // Touch\n        if (e.targetTouches) {\n            var touch = e.targetTouches[0];\n            x = touch.clientX;\n            y = touch.clientY;\n\n            haveGesture = this._processGesture(e, 'change');\n        }\n\n        var panSensitivity = convertToArray(this.panSensitivity);\n        var rotateSensitivity = convertToArray(this.rotateSensitivity);\n\n        if (!haveGesture) {\n            if (this._mode === 'rotate') {\n                this._rotateVelocity.y = (x - this._mouseX) / this.domElement.clientHeight * 2 * rotateSensitivity[0];\n                this._rotateVelocity.x = (y - this._mouseY) / this.domElement.clientWidth * 2 * rotateSensitivity[1];\n            }\n            else if (this._mode === 'pan') {\n                this._panVelocity.x = (x - this._mouseX) / this.domElement.clientWidth * panSensitivity[0] * 400;\n                this._panVelocity.y = (-y + this._mouseY) / this.domElement.clientHeight * panSensitivity[1] * 400;\n            }\n        }\n\n        this._mouseX = x;\n        this._mouseY = y;\n\n        e.preventDefault();\n    },\n\n    _mouseWheelHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var delta = e.wheelDelta // Webkit\n                || -e.detail; // Firefox\n        if (delta === 0) {\n            return;\n        }\n        this._zoomHandler(e, delta > 0 ? -1 : 1);\n    },\n\n    _pinchHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        this._zoomHandler(e, e.pinchScale > 1 ? -0.4 : 0.4);\n    },\n\n    _zoomHandler: function (e, delta) {\n\n        var distance = Math.max(Math.min(\n            this._distance - this.minDistance,\n            this.maxDistance - this._distance\n        ));\n        this._zoomSpeed = delta * Math.max(distance / 40 * this.zoomSensitivity, 0.2);\n\n        this._rotating = false;\n\n        if (this.autoRotate && this._mode === 'rotate') {\n            this._startCountingStill();\n        }\n\n        e.preventDefault();\n    },\n\n    _mouseUpHandler: function (event) {\n        var dom = this.domElement;\n        dom.removeEventListener('touchmove', this._mouseMoveHandler);\n        dom.removeEventListener('touchend', this._mouseUpHandler);\n        dom.removeEventListener('mousemove', this._mouseMoveHandler);\n        dom.removeEventListener('mouseup', this._mouseUpHandler);\n\n        this._processGesture(event, 'end');\n    },\n\n    _addAnimator: function (animator) {\n        var animators = this._animators;\n        animators.push(animator);\n        animator.done(function () {\n            var idx = animators.indexOf(animator);\n            if (idx >= 0) {\n                animators.splice(idx, 1);\n            }\n        });\n        return animator;\n    },\n\n\n    _processGesture: function (event, stage) {\n        var gestureMgr = this._gestureMgr;\n\n        stage === 'start' && gestureMgr.clear();\n\n        var gestureInfo = gestureMgr.recognize(\n            event,\n            null,\n            this.domElement\n        );\n\n        stage === 'end' && gestureMgr.clear();\n\n        // Do not do any preventDefault here. Upper application do that if necessary.\n        if (gestureInfo) {\n            var type = gestureInfo.type;\n            event.gestureEvent = type;\n\n            this._pinchHandler(gestureInfo.event);\n        }\n\n        return gestureInfo;\n    }\n});\n\n/**\n * If auto rotate the target\n * @type {boolean}\n * @default false\n */\nObject.defineProperty(OrbitControl.prototype, 'autoRotate', {\n    get: function () {\n        return this._autoRotate;\n    },\n    set: function (val) {\n        this._autoRotate = val;\n        this._rotating = val;\n    }\n});\n\nObject.defineProperty(OrbitControl.prototype, 'target', {\n    get: function () {\n        return this._target;\n    },\n    set: function (val) {\n        if (val && val.target) {\n            this.setCenter(val.target.toArray());\n        }\n        this._target = val;\n        this.decomposeTransform();\n    }\n});\n\n\nexport default OrbitControl;\n","/**\n * StaticGeometry can not be changed once they've been setup\n */\nimport Geometry from './Geometry';\n/**\n * @constructor clay.StaticGeometry\n * @extends clay.Geometry\n */\nvar StaticGeometry = Geometry.extend({\n    dynamic: false\n});\nexport default StaticGeometry;\n","// TODO test\nimport Geometry from '../Geometry';\nimport Mesh from '../Mesh';\nimport Node from '../Node';\nimport StandardMaterial from '../StandardMaterial';\nimport BoundingBox from '../math/BoundingBox';\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\n/**\n * @namespace clay.util.mesh\n */\nvar meshUtil = {\n    /**\n     * Merge multiple meshes to one.\n     * Note that these meshes must have the same material\n     *\n     * @param {Array.<clay.Mesh>} meshes\n     * @param {boolean} applyWorldTransform\n     * @return clay.Mesh\n     * @memberOf clay.util.mesh\n     */\n    merge: function (meshes, applyWorldTransform) {\n\n        if (! meshes.length) {\n            return;\n        }\n\n        var templateMesh = meshes[0];\n        var templateGeo = templateMesh.geometry;\n        var material = templateMesh.material;\n\n        var geometry = new Geometry({\n            dynamic: false\n        });\n        geometry.boundingBox = new BoundingBox();\n\n        var attributeNames = templateGeo.getEnabledAttributes();\n\n        for (var i = 0; i < attributeNames.length; i++) {\n            var name = attributeNames[i];\n            var attr = templateGeo.attributes[name];\n            // Extend custom attributes\n            if (!geometry.attributes[name]) {\n                geometry.attributes[name] = attr.clone(false);\n            }\n        }\n\n        var inverseTransposeMatrix = mat4.create();\n        // Initialize the array data and merge bounding box\n        var nVertex = 0;\n        var nFace = 0;\n        for (var k = 0; k < meshes.length; k++) {\n            var currentGeo = meshes[k].geometry;\n            if (currentGeo.boundingBox) {\n                currentGeo.boundingBox.applyTransform(applyWorldTransform ? meshes[k].worldTransform : meshes[k].localTransform);\n                geometry.boundingBox.union(currentGeo.boundingBox);\n            }\n            nVertex += currentGeo.vertexCount;\n            nFace += currentGeo.triangleCount;\n        }\n        for (var n = 0; n < attributeNames.length; n++) {\n            var name = attributeNames[n];\n            var attrib = geometry.attributes[name];\n            attrib.init(nVertex);\n        }\n        if (nVertex >= 0xffff) {\n            geometry.indices = new Uint32Array(nFace * 3);\n        }\n        else {\n            geometry.indices = new Uint16Array(nFace * 3);\n        }\n\n        var vertexOffset = 0;\n        var indicesOffset = 0;\n        var useIndices = templateGeo.isUseIndices();\n\n        for (var mm = 0; mm < meshes.length; mm++) {\n            var mesh = meshes[mm];\n            var currentGeo = mesh.geometry;\n\n            var nVertex = currentGeo.vertexCount;\n\n            var matrix = applyWorldTransform ? mesh.worldTransform.array : mesh.localTransform.array;\n            mat4.invert(inverseTransposeMatrix, matrix);\n            mat4.transpose(inverseTransposeMatrix, inverseTransposeMatrix);\n\n            for (var nn = 0; nn < attributeNames.length; nn++) {\n                var name = attributeNames[nn];\n                var currentAttr = currentGeo.attributes[name];\n                var targetAttr = geometry.attributes[name];\n                // Skip the unused attributes;\n                if (!currentAttr.value.length) {\n                    continue;\n                }\n                var len = currentAttr.value.length;\n                var size = currentAttr.size;\n                var offset = vertexOffset * size;\n                var count = len / size;\n                for (var i = 0; i < len; i++) {\n                    targetAttr.value[offset + i] = currentAttr.value[i];\n                }\n                // Transform position, normal and tangent\n                if (name === 'position') {\n                    vec3.forEach(targetAttr.value, size, offset, count, vec3.transformMat4, matrix);\n                }\n                else if (name === 'normal' || name === 'tangent') {\n                    vec3.forEach(targetAttr.value, size, offset, count, vec3.transformMat4, inverseTransposeMatrix);\n                }\n            }\n\n            if (useIndices) {\n                var len = currentGeo.indices.length;\n                for (var i = 0; i < len; i++) {\n                    geometry.indices[i + indicesOffset] = currentGeo.indices[i] + vertexOffset;\n                }\n                indicesOffset += len;\n            }\n\n            vertexOffset += nVertex;\n        }\n\n        return new Mesh({\n            material: material,\n            geometry: geometry\n        });\n    },\n\n    /**\n     * Split mesh into sub meshes, each mesh will have maxJointNumber joints.\n     * @param {clay.Mesh} mesh\n     * @param {number} maxJointNumber\n     * @param {boolean} inPlace\n     * @return {clay.Node}\n     *\n     * @memberOf clay.util.mesh\n     */\n\n    // FIXME, Have issues on some models\n    splitByJoints: function (mesh, maxJointNumber, inPlace) {\n        var geometry = mesh.geometry;\n        var skeleton = mesh.skeleton;\n        var material = mesh.material;\n        var joints = mesh.joints;\n        if (!geometry || !skeleton || !joints.length) {\n            return;\n        }\n        if (joints.length < maxJointNumber) {\n            return mesh;\n        }\n\n\n        var indices = geometry.indices;\n\n        var faceLen = geometry.triangleCount;\n        var rest = faceLen;\n        var isFaceAdded = [];\n        var jointValues = geometry.attributes.joint.value;\n        for (var i = 0; i < faceLen; i++) {\n            isFaceAdded[i] = false;\n        }\n        var addedJointIdxPerFace = [];\n\n        var buckets = [];\n\n        var getJointByIndex = function (idx) {\n            return joints[idx];\n        };\n        while (rest > 0) {\n            var bucketTriangles = [];\n            var bucketJointReverseMap = [];\n            var bucketJoints = [];\n            var subJointNumber = 0;\n            for (var i = 0; i < joints.length; i++) {\n                bucketJointReverseMap[i] = -1;\n            }\n            for (var f = 0; f < faceLen; f++) {\n                if (isFaceAdded[f]) {\n                    continue;\n                }\n                var canAddToBucket = true;\n                var addedNumber = 0;\n                for (var i = 0; i < 3; i++) {\n\n                    var idx = indices[f * 3 + i];\n\n                    for (var j = 0; j < 4; j++) {\n                        var jointIdx = jointValues[idx * 4 + j];\n\n                        if (jointIdx >= 0) {\n                            if (bucketJointReverseMap[jointIdx] === -1) {\n                                if (subJointNumber < maxJointNumber) {\n                                    bucketJointReverseMap[jointIdx] = subJointNumber;\n                                    bucketJoints[subJointNumber++] = jointIdx;\n                                    addedJointIdxPerFace[addedNumber++] = jointIdx;\n                                }\n                                else {\n                                    canAddToBucket = false;\n                                }\n                            }\n                        }\n                    }\n                }\n                if (!canAddToBucket) {\n                    // Reverse operation\n                    for (var i = 0; i < addedNumber; i++) {\n                        bucketJointReverseMap[addedJointIdxPerFace[i]] = -1;\n                        bucketJoints.pop();\n                        subJointNumber--;\n                    }\n                }\n                else {\n                    bucketTriangles.push(indices.subarray(f * 3, (f + 1) * 3));\n\n                    isFaceAdded[f] = true;\n                    rest--;\n                }\n            }\n            buckets.push({\n                triangles: bucketTriangles,\n                joints: bucketJoints.map(getJointByIndex),\n                jointReverseMap: bucketJointReverseMap\n            });\n        }\n\n        var root = new Node({\n            name: mesh.name\n        });\n        var attribNames = geometry.getEnabledAttributes();\n\n        attribNames.splice(attribNames.indexOf('joint'), 1);\n        // Map from old vertex index to new vertex index\n        var newIndices = [];\n        for (var b = 0; b < buckets.length; b++) {\n            var bucket = buckets[b];\n            var jointReverseMap = bucket.jointReverseMap;\n            var subJointNumber = bucket.joints.length;\n\n            var subMat = material.clone();\n            subMat.name = [material.name, b].join('-');\n\n            var subGeo = new Geometry();\n\n            var subMesh = new Mesh({\n                name: [mesh.name, i].join('-'),\n                material: subMat,\n                geometry: subGeo,\n                skeleton: skeleton,\n                joints: bucket.joints.slice()\n            });\n            var nVertex = 0;\n            var nVertex2 = geometry.vertexCount;\n            for (var i = 0; i < nVertex2; i++) {\n                newIndices[i] = -1;\n            }\n            // Count sub geo number\n            for (var f = 0; f < bucket.triangles.length; f++) {\n                var face = bucket.triangles[f];\n                for (var i = 0; i < 3; i++) {\n                    var idx = face[i];\n                    if (newIndices[idx] === -1) {\n                        newIndices[idx] = nVertex;\n                        nVertex++;\n                    }\n                }\n            }\n            for (var a = 0; a < attribNames.length; a++) {\n                var attribName = attribNames[a];\n                var subAttrib = subGeo.attributes[attribName];\n                subAttrib.init(nVertex);\n            }\n            subGeo.attributes.joint.value = new Float32Array(nVertex * 4);\n\n            if (nVertex > 0xffff) {\n                subGeo.indices = new Uint32Array(bucket.triangles.length * 3);\n            }\n            else {\n                subGeo.indices = new Uint16Array(bucket.triangles.length * 3);\n            }\n\n            var indicesOffset = 0;\n            nVertex = 0;\n            for (var i = 0; i < nVertex2; i++) {\n                newIndices[i] = -1;\n            }\n\n            for (var f = 0; f < bucket.triangles.length; f++) {\n                var triangle = bucket.triangles[f];\n                for (var i = 0; i < 3; i++) {\n\n                    var idx = triangle[i];\n\n                    if (newIndices[idx] === -1) {\n                        newIndices[idx] = nVertex;\n                        for (var a = 0; a < attribNames.length; a++) {\n                            var attribName = attribNames[a];\n                            var attrib = geometry.attributes[attribName];\n                            var subAttrib = subGeo.attributes[attribName];\n                            var size = attrib.size;\n\n                            for (var j = 0; j < size; j++) {\n                                subAttrib.value[nVertex * size + j] = attrib.value[idx * size + j];\n                            }\n                        }\n                        for (var j = 0; j < 4; j++) {\n                            var jointIdx = geometry.attributes.joint.value[idx * 4 + j];\n                            var offset = nVertex * 4 + j;\n                            if (jointIdx >= 0) {\n                                subGeo.attributes.joint.value[offset] = jointReverseMap[jointIdx];\n                            }\n                            else {\n                                subGeo.attributes.joint.value[offset] = -1;\n                            }\n                        }\n                        nVertex++;\n                    }\n                    subGeo.indices[indicesOffset++] = newIndices[idx];\n                }\n            }\n            subGeo.updateBoundingBox();\n\n            root.add(subMesh);\n        }\n        var children = mesh.children();\n        for (var i = 0; i < children.length; i++) {\n            root.add(children[i]);\n        }\n        root.position.copy(mesh.position);\n        root.rotation.copy(mesh.rotation);\n        root.scale.copy(mesh.scale);\n\n        if (inPlace) {\n            if (mesh.getParent()) {\n                var parent = mesh.getParent();\n                parent.remove(mesh);\n                parent.add(root);\n            }\n        }\n        return root;\n    }\n};\n\nexport default meshUtil;\n","import util from '../core/util';\nimport Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\nimport Vector3 from '../math/Vector3';\n\nvar META = {\n    version: 1.0,\n    type: 'Geometry',\n    generator: 'util.transferable.toObject'\n};\n\n/**\n * @alias clay.util.transferable\n */\nvar transferableUtil = {\n    /**\n     * Convert geometry to a object containing transferable data\n     * @param {Geometry} geometry geometry\n     * @param {Boolean} shallow whether shallow copy\n     * @returns {Object} { data : data, buffers : buffers }, buffers is the transferable list\n     */\n    toObject : function (geometry, shallow) {\n        if (!geometry) {\n            return null;\n        }\n        var data = {\n            metadata : util.extend({}, META)\n        };\n        //transferable buffers\n        var buffers = [];\n\n        //dynamic\n        data.dynamic = geometry.dynamic;\n\n        //bounding box\n        if (geometry.boundingBox) {\n            data.boundingBox = {\n                min : geometry.boundingBox.min.toArray(),\n                max : geometry.boundingBox.max.toArray()\n            };\n        }\n\n        //indices\n        if (geometry.indices && geometry.indices.length > 0) {\n            data.indices = copyIfNecessary(geometry.indices, shallow);\n            buffers.push(data.indices.buffer);\n        }\n\n        //attributes\n        data.attributes = {};\n        for (var p in geometry.attributes) { \n            if (geometry.attributes.hasOwnProperty(p)) {\n                var attr = geometry.attributes[p];\n                //ignore empty attributes\n                if (attr && attr.value && attr.value.length > 0) {\n                    attr = data.attributes[p] = copyAttribute(attr, shallow);\n                    buffers.push(attr.value.buffer);\n                }\n            }\n        }\n\n        return {\n            data : data,\n            buffers : buffers\n        };\n    },\n    \n    /**\n     * Reproduce a geometry from object generated by toObject\n     * @param {Object} object object generated by toObject\n     * @returns {Geometry} geometry\n     */\n    toGeometry : function (object) {\n        if (!object) {\n            return null;\n        }\n        if (object.data && object.buffers) {\n            return transferableUtil.toGeometry(object.data);\n        }\n        if (!object.metadata || object.metadata.generator !== META.generator) {\n            throw new Error('[util.transferable.toGeometry] the object is not generated by util.transferable.');\n        }\n\n        //basic options\n        var options = {\n            dynamic : object.dynamic,\n            indices : object.indices\n        };\n\n        if (object.boundingBox) {\n            var min = new Vector3().setArray(object.boundingBox.min);\n            var max = new Vector3().setArray(object.boundingBox.max);\n            options.boundingBox = new BoundingBox(min, max);\n        }\n\n        //attributes\n        var attributes = {};\n        for (var p in object.attributes) {\n            if (object.attributes.hasOwnProperty(p)) {\n                var attr = object.attributes[p];\n                attributes[p] = new Geometry.Attribute(attr.name, attr.type, attr.size, attr.semantic);\n                attributes[p].value = attr.value;\n            }\n        }\n        options.attributes = attributes;\n\n        return new Geometry(options);\n    }\n    \n}\n\nfunction copyAttribute(attr, shallow) {\n    return {\n        name : attr.name,\n        type : attr.type,\n        size : attr.size,\n        semantic : attr.semantic,\n        value : copyIfNecessary(attr.value, shallow)\n    };\n}\n\nfunction copyIfNecessary(arr, shallow) {\n    if (!shallow) {\n        return new arr.constructor(arr);\n    } else {\n        return arr;\n    }\n}\n\nexport default transferableUtil;\n","/**\n * @name clay.version\n */\nexport default '1.0.0-rc.1';\n","export default \"@export clay.vr.disorter.output.vertex\\nattribute vec2 texcoord: TEXCOORD_0;\\nattribute vec3 position: POSITION;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    v_Texcoord = texcoord;\\n    gl_Position = vec4(position.xy, 0.5, 1.0);\\n}\\n@end\\n@export clay.vr.disorter.output.fragment\\nuniform sampler2D texture;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    gl_FragColor = texture2D(texture, v_Texcoord);\\n}\\n@end\";\n","// https://github.com/googlevr/webvr-polyfill/blob/master/src/cardboard-distorter.js\n\n// Use webvr may have scale problem.\n// https://github.com/googlevr/webvr-polyfill/issues/140\n// https://github.com/googlevr/webvr-polyfill/search?q=SCALE&type=Issues&utf8=%E2%9C%93\n// https://github.com/googlevr/webvr-polyfill/issues/147\n\n\nimport Mesh from '../Mesh';\nimport Material from '../Material';\nimport Geometry from '../Geometry';\nimport Shader from '../Shader';\nimport Base from '../core/Base';\nimport PerspectiveCamera from '../camera/Perspective';\n\nimport outputEssl from './output.glsl.js';\n\nShader.import(outputEssl);\n\nfunction lerp (a, b, t) {\n    return a * (1 - t) + b * t;\n}\n\nvar CardboardDistorter = Base.extend(function () {\n    return {\n\n        clearColor: [0, 0, 0, 1],\n\n        _mesh: new Mesh({\n            geometry: new Geometry({\n                dynamic: true\n            }),\n            culling: false,\n            material: new Material({\n                // FIXME Why disable depthMask will be wrong\n                // depthMask: false,\n                depthTest: false,\n                shader: new Shader({\n                    vertex: Shader.source('clay.vr.disorter.output.vertex'),\n                    fragment: Shader.source('clay.vr.disorter.output.fragment')\n                })\n            })\n        }),\n        _fakeCamera: new PerspectiveCamera()\n    };\n}, {\n\n    render: function (renderer, sourceTexture) {\n        var clearColor = this.clearColor;\n        var gl = renderer.gl;\n        gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n        gl.clear(gl.COLOR_BUFFER_BIT);\n\n        gl.disable(gl.BLEND);\n\n        this._mesh.material.set('texture', sourceTexture);\n\n        // Full size?\n        renderer.saveViewport();\n        renderer.setViewport(0, 0, renderer.getWidth(), renderer.getHeight());\n        renderer.renderPass([this._mesh], this._fakeCamera);\n        renderer.restoreViewport();\n        // this._mesh.material.shader.bind(renderer);\n        // this._mesh.material.bind(renderer);\n        // this._mesh.render(renderer.gl);\n    },\n\n    updateFromVRDisplay: function (vrDisplay) {\n\n        // FIXME\n        if (vrDisplay.deviceInfo_) {\n            // Hardcoded mesh size\n            this._updateMesh(20, 20, vrDisplay.deviceInfo_);\n        }\n        else {\n            console.warn('Cant get vrDisplay.deviceInfo_, seems code changed');\n        }\n    },\n\n    _updateMesh: function (width, height, deviceInfo) {\n\n        var positionAttr = this._mesh.geometry.attributes.position;\n        var texcoordAttr = this._mesh.geometry.attributes.texcoord0;\n        positionAttr.init(2 * width * height);\n        texcoordAttr.init(2 * width * height);\n\n        var lensFrustum = deviceInfo.getLeftEyeVisibleTanAngles();\n        var noLensFrustum = deviceInfo.getLeftEyeNoLensTanAngles();\n        var viewport = deviceInfo.getLeftEyeVisibleScreenRect(noLensFrustum);\n        var vidx = 0;\n\n        var pos = [];\n        var uv = [];\n\n        // Vertices\n        for (var e = 0; e < 2; e++) {\n            for (var j = 0; j < height; j++) {\n                for (var i = 0; i < width; i++, vidx++) {\n                    var u = i / (width - 1);\n                    var v = j / (height - 1);\n\n                    // Grid points regularly spaced in StreoScreen, and barrel distorted in\n                    // the mesh.\n                    var s = u;\n                    var t = v;\n                    var x = lerp(lensFrustum[0], lensFrustum[2], u);\n                    var y = lerp(lensFrustum[3], lensFrustum[1], v);\n                    var d = Math.sqrt(x * x + y * y);\n                    var r = deviceInfo.distortion.distortInverse(d);\n                    var p = x * r / d;\n                    var q = y * r / d;\n                    u = (p - noLensFrustum[0]) / (noLensFrustum[2] - noLensFrustum[0]);\n                    v = (q - noLensFrustum[3]) / (noLensFrustum[1] - noLensFrustum[3]);\n\n                    // Convert u,v to mesh screen coordinates.\n                    var aspect = deviceInfo.device.widthMeters / deviceInfo.device.heightMeters;\n\n                    // FIXME: The original Unity plugin multiplied U by the aspect ratio\n                    // and didn't multiply either value by 2, but that seems to get it\n                    // really close to correct looking for me. I hate this kind of \"Don't\n                    // know why it works\" code though, and wold love a more logical\n                    // explanation of what needs to happen here.\n                    u = (viewport.x + u * viewport.width - 0.5) * 2.0; //* aspect;\n                    v = (viewport.y + v * viewport.height - 0.5) * 2.0;\n\n                    pos[0] = u;\n                    pos[1] = v;\n                    pos[2] = 0;\n\n                    uv[0] = s * 0.5 + e * 0.5;\n                    uv[1] = t;\n\n                    positionAttr.set(vidx, pos);\n                    texcoordAttr.set(vidx, uv);\n                }\n            }\n\n            var w = lensFrustum[2] - lensFrustum[0];\n            lensFrustum[0] = -(w + lensFrustum[0]);\n            lensFrustum[2] = w - lensFrustum[2];\n            w = noLensFrustum[2] - noLensFrustum[0];\n            noLensFrustum[0] = -(w + noLensFrustum[0]);\n            noLensFrustum[2] = w - noLensFrustum[2];\n            viewport.x = 1 - (viewport.x + viewport.width);\n        }\n\n        // Indices\n        var indices = new Uint16Array(2 * (width - 1) * (height - 1) * 6);\n        var halfwidth = width / 2;\n        var halfheight = height / 2;\n        var vidx = 0;\n        var iidx = 0;\n        for (var e = 0; e < 2; e++) {\n            for (var j = 0; j < height; j++) {\n                for (var i = 0; i < width; i++, vidx++) {\n                    if (i === 0 || j === 0) {\n                        continue;\n                    }\n                    // Build a quad.  Lower right and upper left quadrants have quads with\n                    // the triangle diagonal flipped to get the vignette to interpolate\n                    // correctly.\n                    if ((i <= halfwidth) == (j <= halfheight)) {\n                        // Quad diagonal lower left to upper right.\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - width - 1;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx - width - 1;\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - 1;\n                    }\n                    else {\n                        // Quad diagonal upper left to lower right.\n                        indices[iidx++] = vidx - 1;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx - 1;\n                        indices[iidx++] = vidx - width - 1;\n                    }\n                }\n            }\n        }\n\n        this._mesh.geometry.indices = indices;\n\n        this._mesh.geometry.dirty();\n    }\n});\n\nexport default CardboardDistorter;\n","import Base from '../Node';\nimport Camera from '../camera/Perspective';\nimport Matrix4 from '../math/Matrix4';\n\nvar tmpProjectionMatrix = new Matrix4();\n\nvar StereoCamera = Base.extend(function () {\n    return {\n\n        aspect: 0.5,\n\n        _leftCamera: new Camera(),\n\n        _rightCamera: new Camera(),\n\n        _eyeLeft: new Matrix4(),\n        _eyeRight: new Matrix4(),\n\n        _frameData: null\n    };\n}, {\n\n    updateFromCamera: function (camera, focus, zoom, eyeSep) {\n        if (camera.transformNeedsUpdate()) {\n            console.warn('Node transform is not updated');\n        }\n\n        focus = focus == null ? 10 : focus;\n        zoom = zoom == null ? 1 : zoom;\n        eyeSep = eyeSep == null ? 0.064 : eyeSep;\n\n        var fov = camera.fov;\n        var aspect = camera.aspect * this.aspect;\n        var near = camera.near;\n\n        // Off-axis stereoscopic effect based on\n        // http://paulbourke.net/stereographics/stereorender/\n\n        tmpProjectionMatrix.copy(camera.projectionMatrix);\n        var eyeSep = eyeSep / 2;\n        var eyeSepOnProjection = eyeSep * near / focus;\n        var ymax = (near * Math.tan(Math.PI / 180 * fov * 0.5 ) ) / zoom;\n        var xmin, xmax;\n\n        // translate xOffset\n        this._eyeLeft.array[12] = - eyeSep;\n        this._eyeRight.array[12] = eyeSep;\n\n        // for left eye\n        xmin = - ymax * aspect + eyeSepOnProjection;\n        xmax = ymax * aspect + eyeSepOnProjection;\n\n        tmpProjectionMatrix.array[0] = 2 * near / (xmax - xmin);\n        tmpProjectionMatrix.array[8] = (xmax + xmin ) / (xmax - xmin);\n\n        this._leftCamera.projectionMatrix.copy(tmpProjectionMatrix);\n\n        // for right eye\n        xmin = - ymax * aspect - eyeSepOnProjection;\n        xmax = ymax * aspect - eyeSepOnProjection;\n\n        tmpProjectionMatrix.array[0] = 2 * near / (xmax - xmin);\n        tmpProjectionMatrix.array[8] = (xmax + xmin ) / (xmax - xmin);\n\n        this._rightCamera.projectionMatrix.copy(tmpProjectionMatrix);\n\n        this._leftCamera.worldTransform\n            .copy(camera.worldTransform)\n            .multiply(this._eyeLeft);\n\n        this._rightCamera.worldTransform\n            .copy(camera.worldTransform)\n            .multiply(this._eyeRight);\n\n        this._leftCamera.decomposeWorldTransform();\n        this._leftCamera.decomposeProjectionMatrix();\n\n        this._rightCamera.decomposeWorldTransform();\n        this._rightCamera.decomposeProjectionMatrix();\n    },\n\n    updateFromVRDisplay: function (vrDisplay, parentNode) {\n\n        if (typeof VRFrameData === 'undefined') {\n            return;\n        }\n\n        var frameData = this._frameData || (this._frameData = new VRFrameData());\n        vrDisplay.getFrameData(frameData);\n        var leftCamera = this._leftCamera;\n        var rightCamera = this._rightCamera;\n\n        leftCamera.projectionMatrix.setArray(frameData.leftProjectionMatrix);\n        leftCamera.decomposeProjectionMatrix();\n        leftCamera.viewMatrix.setArray(frameData.leftViewMatrix);\n        leftCamera.setViewMatrix(leftCamera.viewMatrix);\n\n        rightCamera.projectionMatrix.setArray(frameData.rightProjectionMatrix);\n        rightCamera.decomposeProjectionMatrix();\n        rightCamera.viewMatrix.setArray(frameData.rightViewMatrix);\n        rightCamera.setViewMatrix(rightCamera.viewMatrix);\n\n        if (parentNode && parentNode.worldTransform) {\n            if (parentNode.transformNeedsUpdate()) {\n                console.warn('Node transform is not updated');\n            }\n            leftCamera.worldTransform.multiplyLeft(parentNode.worldTransform);\n            leftCamera.decomposeWorldTransform();\n            rightCamera.worldTransform.multiplyLeft(parentNode.worldTransform);\n            rightCamera.decomposeWorldTransform();\n        }\n    },\n\n    getLeftCamera: function () {\n        return this._leftCamera;\n    },\n\n    getRightCamera: function () {\n        return this._rightCamera;\n    }\n});\n\nexport default StereoCamera;\n","/** @namespace clay */\n/** @namespace clay.math */\n/** @namespace clay.animation */\n/** @namespace clay.async */\n/** @namespace clay.camera */\n/** @namespace clay.compositor */\n/** @namespace clay.core */\n/** @namespace clay.geometry */\n/** @namespace clay.helper */\n/** @namespace clay.light */\n/** @namespace clay.loader */\n/** @namespace clay.particleSystem */\n/** @namespace clay.plugin */\n/** @namespace clay.prePass */\n/** @namespace clay.shader */\n/** @namespace clay.texture */\n/** @namespace clay.util */\n\nimport Animator$0 from './animation/Animator';\nimport Blend1DClip$1 from './animation/Blend1DClip';\nimport Blend2DClip$2 from './animation/Blend2DClip';\nimport Clip$3 from './animation/Clip';\nimport easing$4 from './animation/easing';\nimport SamplerTrack$5 from './animation/SamplerTrack';\nimport Timeline$6 from './animation/Timeline';\nimport TrackClip$7 from './animation/TrackClip';\nimport TransformTrack$8 from './animation/TransformTrack';\nimport application$9 from './application';\nimport Task$10 from './async/Task';\nimport TaskGroup$11 from './async/TaskGroup';\nimport Camera$12 from './Camera';\nimport Orthographic$13 from './camera/Orthographic';\nimport Perspective$14 from './camera/Perspective';\nimport Material$15 from './canvas/Material';\nimport Renderer$16 from './canvas/Renderer';\nimport Compositor$17 from './compositor/Compositor';\nimport createCompositor$18 from './compositor/createCompositor';\nimport FilterNode$19 from './compositor/FilterNode';\nimport Graph$20 from './compositor/Graph';\nimport Node$21 from './compositor/Node';\nimport Pass$22 from './compositor/Pass';\nimport SceneNode$23 from './compositor/SceneNode';\nimport TextureNode$24 from './compositor/TextureNode';\nimport TexturePool$25 from './compositor/TexturePool';\nimport Base$26 from './core/Base';\nimport Cache$27 from './core/Cache';\nimport color$28 from './core/color';\nimport glenum$29 from './core/glenum';\nimport GLInfo$30 from './core/GLInfo';\nimport LinkedList$31 from './core/LinkedList';\nimport LRU$32 from './core/LRU';\nimport extend$33 from './core/mixin/extend';\nimport notifier$34 from './core/mixin/notifier';\nimport request$35 from './core/request';\nimport util$36 from './core/util';\nimport vendor$37 from './core/vendor';\nimport GBuffer$38 from './deferred/GBuffer';\nimport Renderer$39 from './deferred/Renderer';\nimport glmatrix$40 from './dep/glmatrix';\nimport FrameBuffer$41 from './FrameBuffer';\nimport Geometry$42 from './Geometry';\nimport Cone$43 from './geometry/Cone';\nimport Cube$44 from './geometry/Cube';\nimport Cylinder$45 from './geometry/Cylinder';\nimport Plane$46 from './geometry/Plane';\nimport Sphere$47 from './geometry/Sphere';\nimport GLProgram$48 from './gpu/GLProgram';\nimport ProgramManager$49 from './gpu/ProgramManager';\nimport Joint$50 from './Joint';\nimport Light$51 from './Light';\nimport Ambient$52 from './light/Ambient';\nimport AmbientCubemap$53 from './light/AmbientCubemap';\nimport AmbientSH$54 from './light/AmbientSH';\nimport Directional$55 from './light/Directional';\nimport Point$56 from './light/Point';\nimport Sphere$57 from './light/Sphere';\nimport Spot$58 from './light/Spot';\nimport Tube$59 from './light/Tube';\nimport FX$60 from './loader/FX';\nimport GLTF$61 from './loader/GLTF';\nimport Material$62 from './Material';\nimport BoundingBox$63 from './math/BoundingBox';\nimport Frustum$64 from './math/Frustum';\nimport Matrix2$65 from './math/Matrix2';\nimport Matrix2d$66 from './math/Matrix2d';\nimport Matrix3$67 from './math/Matrix3';\nimport Matrix4$68 from './math/Matrix4';\nimport Plane$69 from './math/Plane';\nimport Quaternion$70 from './math/Quaternion';\nimport Ray$71 from './math/Ray';\nimport util$72 from './math/util';\nimport Value$73 from './math/Value';\nimport Vector2$74 from './math/Vector2';\nimport Vector3$75 from './math/Vector3';\nimport Vector4$76 from './math/Vector4';\nimport Mesh$77 from './Mesh';\nimport Node$78 from './Node';\nimport Emitter$79 from './particle/Emitter';\nimport Field$80 from './particle/Field';\nimport ForceField$81 from './particle/ForceField';\nimport Particle$82 from './particle/Particle';\nimport ParticleRenderable$83 from './particle/ParticleRenderable';\nimport PixelPicking$84 from './picking/PixelPicking';\nimport RayPicking$85 from './picking/RayPicking';\nimport FreeControl$86 from './plugin/FreeControl';\nimport GestureMgr$87 from './plugin/GestureMgr';\nimport InfinitePlane$88 from './plugin/InfinitePlane';\nimport OrbitControl$89 from './plugin/OrbitControl';\nimport Skybox$90 from './plugin/Skybox';\nimport Skydome$91 from './plugin/Skydome';\nimport EnvironmentMap$92 from './prePass/EnvironmentMap';\nimport ShadowMap$93 from './prePass/ShadowMap';\nimport Renderable$94 from './Renderable';\nimport Renderer$95 from './Renderer';\nimport Scene$96 from './Scene';\nimport Shader$97 from './Shader';\nimport library$98 from './shader/library';\nimport light$99 from './shader/source/header/light';\nimport Skeleton$100 from './Skeleton';\nimport StandardMaterial$101 from './StandardMaterial';\nimport StaticGeometry$102 from './StaticGeometry';\nimport Texture$103 from './Texture';\nimport Texture2D$104 from './Texture2D';\nimport TextureCube$105 from './TextureCube';\nimport cubemap$106 from './util/cubemap';\nimport dds$107 from './util/dds';\nimport delaunay$108 from './util/delaunay';\nimport hdr$109 from './util/hdr';\nimport mesh$110 from './util/mesh';\nimport sh$111 from './util/sh';\nimport texture$112 from './util/texture';\nimport transferable$113 from './util/transferable';\nimport version$114 from './version';\nimport CardboardDistorter$115 from './vr/CardboardDistorter';\nimport StereoCamera$116 from './vr/StereoCamera';\n\n\nvar animation = {\n    Animator : Animator$0,\n    Blend1DClip : Blend1DClip$1,\n    Blend2DClip : Blend2DClip$2,\n    Clip : Clip$3,\n    easing : easing$4,\n    SamplerTrack : SamplerTrack$5,\n    Timeline : Timeline$6,\n    TrackClip : TrackClip$7,\n    TransformTrack : TransformTrack$8\n};\nexport { animation };\n\nexport { application$9 as application };\n\nvar async = {\n    Task : Task$10,\n    TaskGroup : TaskGroup$11\n};\nexport { async };\n\nexport { Camera$12 as Camera };\n\nvar camera = {\n    Orthographic : Orthographic$13,\n    Perspective : Perspective$14\n};\nexport { camera };\n\n\nvar canvas = {\n    Material : Material$15,\n    Renderer : Renderer$16\n};\nexport { canvas };\n\n\nvar compositor = {\n    Compositor : Compositor$17,\n    createCompositor : createCompositor$18,\n    FilterNode : FilterNode$19,\n    Graph : Graph$20,\n    Node : Node$21,\n    Pass : Pass$22,\n    SceneNode : SceneNode$23,\n    TextureNode : TextureNode$24,\n    TexturePool : TexturePool$25\n};\nexport { compositor };\n\n\nvar core = {\n    Base : Base$26,\n    Cache : Cache$27,\n    color : color$28,\n    glenum : glenum$29,\n    GLInfo : GLInfo$30,\n    LinkedList : LinkedList$31,\n    LRU : LRU$32,\n    mixin : {\n        extend : extend$33,\n        notifier : notifier$34\n    },\n    request : request$35,\n    util : util$36,\n    vendor : vendor$37\n};\nexport { core };\n\n\nvar deferred = {\n    GBuffer : GBuffer$38,\n    Renderer : Renderer$39\n};\nexport { deferred };\n\n\nvar dep = {\n    glmatrix : glmatrix$40\n};\nexport { dep };\n\nexport { FrameBuffer$41 as FrameBuffer };\nexport { Geometry$42 as Geometry };\n\nvar geometry = {\n    Cone : Cone$43,\n    Cube : Cube$44,\n    Cylinder : Cylinder$45,\n    Plane : Plane$46,\n    Sphere : Sphere$47\n};\nexport { geometry };\n\n\nvar gpu = {\n    GLProgram : GLProgram$48,\n    ProgramManager : ProgramManager$49\n};\nexport { gpu };\n\nexport { Joint$50 as Joint };\nexport { Light$51 as Light };\n\nvar light = {\n    Ambient : Ambient$52,\n    AmbientCubemap : AmbientCubemap$53,\n    AmbientSH : AmbientSH$54,\n    Directional : Directional$55,\n    Point : Point$56,\n    Sphere : Sphere$57,\n    Spot : Spot$58,\n    Tube : Tube$59\n};\nexport { light };\n\n\nvar loader = {\n    FX : FX$60,\n    GLTF : GLTF$61\n};\nexport { loader };\n\nexport { Material$62 as Material };\n\nvar math = {\n    BoundingBox : BoundingBox$63,\n    Frustum : Frustum$64,\n    Matrix2 : Matrix2$65,\n    Matrix2d : Matrix2d$66,\n    Matrix3 : Matrix3$67,\n    Matrix4 : Matrix4$68,\n    Plane : Plane$69,\n    Quaternion : Quaternion$70,\n    Ray : Ray$71,\n    util : util$72,\n    Value : Value$73,\n    Vector2 : Vector2$74,\n    Vector3 : Vector3$75,\n    Vector4 : Vector4$76\n};\nexport { math };\n\nexport { Mesh$77 as Mesh };\nexport { Node$78 as Node };\n\nvar particle = {\n    Emitter : Emitter$79,\n    Field : Field$80,\n    ForceField : ForceField$81,\n    Particle : Particle$82,\n    ParticleRenderable : ParticleRenderable$83\n};\nexport { particle };\n\n\nvar picking = {\n    PixelPicking : PixelPicking$84,\n    RayPicking : RayPicking$85\n};\nexport { picking };\n\n\nvar plugin = {\n    FreeControl : FreeControl$86,\n    GestureMgr : GestureMgr$87,\n    InfinitePlane : InfinitePlane$88,\n    OrbitControl : OrbitControl$89,\n    Skybox : Skybox$90,\n    Skydome : Skydome$91\n};\nexport { plugin };\n\n\nvar prePass = {\n    EnvironmentMap : EnvironmentMap$92,\n    ShadowMap : ShadowMap$93\n};\nexport { prePass };\n\nexport { Renderable$94 as Renderable };\nexport { Renderer$95 as Renderer };\nexport { Scene$96 as Scene };\nexport { Shader$97 as Shader };\n\nvar shader = {\n    library : library$98,\n    source : {\n    header : {\n        light : light$99\n    }\n    }\n};\nexport { shader };\n\nexport { Skeleton$100 as Skeleton };\nexport { StandardMaterial$101 as StandardMaterial };\nexport { StaticGeometry$102 as StaticGeometry };\nexport { Texture$103 as Texture };\nexport { Texture2D$104 as Texture2D };\nexport { TextureCube$105 as TextureCube };\n\nvar util = {\n    cubemap : cubemap$106,\n    dds : dds$107,\n    delaunay : delaunay$108,\n    hdr : hdr$109,\n    mesh : mesh$110,\n    sh : sh$111,\n    texture : texture$112,\n    transferable : transferable$113\n};\nexport { util };\n\nexport { version$114 as version };\n\nvar vr = {\n    CardboardDistorter : CardboardDistorter$115,\n    StereoCamera : StereoCamera$116\n};\nexport { vr };\n;\n"],"names":["easing","Easing","this","glMatrix","quat","vec3","util","notifierMixin","canvas","proto","mat4","defineProperty","LRU","parseColor","getDefineCode","mat3","lightShader","prezEssl","noop","vec4","Plane","vec3Set","vec3Copy","EPSILON","programKeyCache","getProgramKey","Cube","Sphere","Perspective","Orthographic","utilEssl","shaderLibrary","PerspectiveCamera","OrthographicCamera","isPowerOfTwo","camera","OrthoCamera","CubeGeometry","targets","SphereGeometry","ret","hdr","dds","LRUCache","CubeGeo","SphereGeo","PlaneGeo","shUtil","Node","GraphNode","SceneNode","TextureNode","FilterNode","CompoSceneNode","CompoTextureNode","CompoFilterNode","vec2","Cone","Cylinder","ConeGeometry","ConeGeo","CylinderGeo","FullQuadPass","mat2","outputEssl","Base","Camera","Animator$0","Blend1DClip$1","Blend2DClip$2","Clip$3","easing$4","SamplerTrack$5","Timeline$6","TrackClip$7","TransformTrack$8","Task$10","TaskGroup$11","Orthographic$13","Perspective$14","Material$15","Renderer$16","Compositor$17","createCompositor$18","FilterNode$19","Graph$20","Node$21","Pass$22","SceneNode$23","TextureNode$24","TexturePool$25","Base$26","Cache$27","color$28","glenum$29","GLInfo$30","LinkedList$31","LRU$32","extend$33","notifier$34","request$35","util$36","vendor$37","GBuffer$38","Renderer$39","glmatrix$40","Cone$43","Cube$44","Cylinder$45","Plane$46","Sphere$47","GLProgram$48","ProgramManager$49","Ambient$52","AmbientCubemap$53","AmbientSH$54","Directional$55","Point$56","Sphere$57","Spot$58","Tube$59","FX$60","GLTF$61","BoundingBox$63","Frustum$64","Matrix2$65","Matrix2d$66","Matrix3$67","Matrix4$68","Plane$69","Quaternion$70","Ray$71","util$72","Value$73","Vector2$74","Vector3$75","Vector4$76","Emitter$79","Field$80","ForceField$81","Particle$82","ParticleRenderable$83","PixelPicking$84","RayPicking$85","FreeControl$86","GestureMgr$87","InfinitePlane$88","OrbitControl$89","Skybox$90","Skydome$91","EnvironmentMap$92","ShadowMap$93","library$98","light$99","cubemap$106","dds$107","delaunay$108","hdr$109","mesh$110","sh$111","texture$112","transferable$113","CardboardDistorter$115","StereoCamera$116"],"mappings":"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AC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;;IAEpD,OAAO,GAAG,CAAC;CACd,CAAC;;;;;;;;;AASF,IAAI,CAAC,OAAO,GAAG,SAAS,GAAG,EAAE,CAAC,EAAE;IAC5B,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAC9C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAC9C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC;QAChD,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;IAEvD,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,C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AC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;;IAGvD,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE3C,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE3C,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IAC7C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE5C,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IAC/C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAA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AAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;QAEjD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QACvD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QACvD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;;QAEzD,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,G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AAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;;IAGjD,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACtE,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACtE,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;;;IAGtE,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAA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pE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;;YAEpE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;YACrE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;;YAErE,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;YAE1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,C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G,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,E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"} diff --git a/dist/claygl.js b/dist/claygl.js index 820754be0..6851245af 100644 --- a/dist/claygl.js +++ b/dist/claygl.js @@ -599,9 +599,6 @@ Clip.prototype = { }; Clip.prototype.constructor = Clip; -/** - * @module echarts/animation/Animator - */ var arraySlice = Array.prototype.slice; function defaultGetter(target, key) { @@ -621,7 +618,8 @@ function interpolateArray(p0, p1, percent, out, arrDim) { for (var i = 0; i < len; i++) { out[i] = interpolateNumber(p0[i], p1[i], percent); } - } else { + } + else { var len2 = p0[0].length; for (var i = 0; i < len; i++) { for (var j = 0; j < len2; j++) { @@ -758,10 +756,10 @@ function isArraySame(arr0, arr1, arrDim) { return true; } -function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, interpolater) { +function createTrackClip(animator, globalEasing, oneTrackDone, keyframes, propName, interpolater, maxTime) { var getter = animator._getter; var setter = animator._setter; - var useSpline = easing === 'spline'; + var useSpline = globalEasing === 'spline'; var trackLen = keyframes.length; if (!trackLen) { @@ -782,16 +780,17 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in return a.time - b.time; }); - var trackMaxTime = keyframes[trackLen - 1].time; // Percents of each keyframe var kfPercents = []; // Value of each keyframe var kfValues = []; + // Easing funcs of each keyframe. + var kfEasings = []; var prevValue = keyframes[0].value; var isAllValueEqual = true; for (var i = 0; i < trackLen; i++) { - kfPercents.push(keyframes[i].time / trackMaxTime); + kfPercents.push(keyframes[i].time / maxTime); // Assume value is a color when it is a string var value = keyframes[i].value; @@ -804,6 +803,7 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in prevValue = value; kfValues.push(value); + kfEasings.push(keyframes[i].easing); } if (isAllValueEqual) { return; @@ -834,7 +834,7 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in var onframe = function(target, percent) { // Find the range keyframes // kf1-----kf2---------current--------kf3 - // find kf2(i) and kf3(i+1) and do interpolation + // find kf2(i) and kf3(i + 1) and do interpolation if (percent < cachePercent) { // Start from next key start = Math.min(cacheKey + 1, trackLen - 1); @@ -843,24 +843,30 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in break; } } - i = Math.min(i, trackLen-2); - } else { + i = Math.min(i, trackLen - 2); + } + else { for (i = cacheKey; i < trackLen; i++) { if (kfPercents[i] > percent) { break; } } - i = Math.min(i-1, trackLen-2); + i = Math.min(i - 1, trackLen - 2); } cacheKey = i; cachePercent = percent; - var range = (kfPercents[i+1] - kfPercents[i]); + var range = (kfPercents[i + 1] - kfPercents[i]); if (range === 0) { return; - } else { + } + else { w = (percent - kfPercents[i]) / range; + // Clamp 0 - 1 + w = Math.max(Math.min(1, w), 0); } + w = kfEasings[i + 1](w); + if (useSpline) { p1 = kfValues[i]; p0 = kfValues[i === 0 ? i : i - 1]; @@ -875,20 +881,23 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in p0, p1, p2, p3, w ) ); - } else if (isValueArray) { + } + else if (isValueArray) { catmullRomInterpolateArray( p0, p1, p2, p3, w, w*w, w*w*w, getter(target, propName), arrDim ); - } else { + } + else { setter( target, propName, catmullRomInterpolate(p0, p1, p2, p3, w, w*w, w*w*w) ); } - } else { + } + else { if (interpolater) { setter( target, @@ -901,13 +910,15 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in ) ); } + else if (isValueArray) { interpolateArray( kfValues[i], kfValues[i+1], w, getter(target, propName), arrDim ); - } else { + } + else { setter( target, propName, @@ -919,15 +930,15 @@ function createTrackClip(animator, easing, oneTrackDone, keyframes, propName, in var clip = new Clip({ target: animator._target, - life: trackMaxTime, + life: maxTime, loop: animator._loop, delay: animator._delay, onframe: onframe, onfinish: oneTrackDone }); - if (easing && easing !== 'spline') { - clip.setEasing(easing); + if (globalEasing && globalEasing !== 'spline') { + clip.setEasing(globalEasing); } return clip; @@ -964,6 +975,14 @@ function Animator(target, loop, getter, setter, interpolater) { this._onframeList = []; this._clipList = []; + + this._maxTime = 0; + + this._lastKFTime = 0; +} + +function noopEasing(w) { + return w; } Animator.prototype = { @@ -971,12 +990,17 @@ Animator.prototype = { constructor: Animator, /** - * @param {number} time Keyframe time using millisecond - * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {number} time Keyframe time using millisecond + * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {string|Function} [easing] * @return {clay.animation.Animator} * @memberOf clay.animation.Animator.prototype */ - when: function (time, props) { + when: function (time, props, easing$$1) { + + this._maxTime = Math.max(time, this._maxTime); + + easing$$1 = (typeof easing$$1 === 'function' ? easing$$1 : easing[easing$$1]) || noopEasing; for (var propName in props) { if (!this._tracks[propName]) { this._tracks[propName] = []; @@ -989,17 +1013,31 @@ Animator.prototype = { time: 0, value: cloneValue( this._getter(this._target, propName) - ) + ), + easing: easing$$1 }); } } this._tracks[propName].push({ time: parseInt(time), - value: props[propName] + value: props[propName], + easing: easing$$1 }); } return this; }, + /** + * @param {number} time Keyframe elapsed time since last keyframe + * @param {Object} props A key-value object. Value can be number, 1d and 2d array + * @param {string|Function} [easing] + * @return {clay.animation.Animator} + * @memberOf clay.animation.Animator.prototype + */ + then: function (duringTime, props, easing$$1) { + this.when(duringTime + this._lastKFTime, props, easing$$1); + this._lastKFTime += duringTime; + return this; + }, /** * callback when running animation * @param {Function} callback callback have two args, animating target and current percent @@ -1029,7 +1067,7 @@ Animator.prototype = { * @return {clay.animation.Animator} * @memberOf clay.animation.Animator.prototype */ - start: function (easing) { + start: function (globalEasing) { var self = this; var clipCount = 0; @@ -1044,8 +1082,8 @@ Animator.prototype = { var lastClip; for (var propName in this._tracks) { var clip = createTrackClip( - this, easing, oneTrackDone, - this._tracks[propName], propName, self._interpolater + this, globalEasing, oneTrackDone, + this._tracks[propName], propName, self._interpolater, self._maxTime ); if (clip) { this._clipList.push(clip); @@ -11014,6 +11052,11 @@ var Texture = Base.extend( * @default true */ flipY: true, + + /** + * A flag to indicate if texture source is sRGB + */ + sRGB: true, /** * @type {number} * @default 4 @@ -11652,6 +11695,9 @@ LRU$1.prototype.clear = function() { this._map = {}; }; +/** + * @namespace clay.core.color + */ var colorUtil = {}; var kCSSColorTable = { @@ -11804,10 +11850,10 @@ function putToCache(colorStr, rgbaArr) { } /** + * @name clay.core.color.parse * @param {string} colorStr * @param {Array.} out * @return {Array.} - * @memberOf module:zrender/util/color */ colorUtil.parse = function (colorStr, rgbaArr) { if (!colorStr) { @@ -11931,6 +11977,7 @@ colorUtil.parseToFloat = function (colorStr, rgbaArr) { }; /** + * @name clay.core.color.hsla2rgba * @param {Array.} hsla * @param {Array.} rgba * @return {Array.} rgba @@ -11960,6 +12007,7 @@ function hsla2rgba(hsla, rgba) { } /** + * @name clay.core.color.rgba2hsla * @param {Array.} rgba * @return {Array.} hsla */ @@ -12026,10 +12074,10 @@ function rgba2hsla(rgba) { } /** + * @name clay.core.color.lift * @param {string} color * @param {number} level * @return {string} - * @memberOf module:zrender/util/color */ colorUtil.lift = function (color, level) { var colorArr = colorUtil.parse(color); @@ -12047,9 +12095,9 @@ colorUtil.lift = function (color, level) { }; /** + * @name clay.core.color.toHex * @param {string} color * @return {string} - * @memberOf module:zrender/util/color */ colorUtil.toHex = function (color) { var colorArr = colorUtil.parse(color); @@ -12060,6 +12108,7 @@ colorUtil.toHex = function (color) { /** * Map value to color. Faster than lerp methods because color is represented by rgba array. + * @name clay.core.color * @param {number} normalizedValue A float between 0 and 1. * @param {Array.>} colors List of rgba color array * @param {Array.} [out] Mapped gba color array @@ -12088,9 +12137,6 @@ colorUtil.fastLerp = function (normalizedValue, colors, out) { return out; }; -/** - * @deprecated - */ colorUtil.fastMapToColor = colorUtil.fastLerp; /** @@ -12099,7 +12145,6 @@ colorUtil.fastMapToColor = colorUtil.fastLerp; * @param {boolean=} fullOutput Default false. * @return {(string|Object)} Result color. If fullOutput, * return {color: ..., leftIndex: ..., rightIndex: ..., value: ...}, - * @memberOf module:zrender/util/color */ colorUtil.lerp = function (normalizedValue, colors, fullOutput) { if (!(colors && colors.length) @@ -12141,12 +12186,12 @@ colorUtil.lerp = function (normalizedValue, colors, fullOutput) { colorUtil.mapToColor = colorUtil.lerp; /** + * @name clay.core.color * @param {string} color * @param {number=} h 0 ~ 360, ignore when null. * @param {number=} s 0 ~ 1, ignore when null. * @param {number=} l 0 ~ 1, ignore when null. * @return {string} Color string in rgba format. - * @memberOf module:zrender/util/color */ colorUtil.modifyHSL = function (color, h, s, l) { color = colorUtil.parse(color); @@ -12165,7 +12210,6 @@ colorUtil.modifyHSL = function (color, h, s, l) { * @param {string} color * @param {number=} alpha 0 ~ 1 * @return {string} Color string in rgba format. - * @memberOf module:zrender/util/color */ colorUtil.modifyAlpha = function (color, alpha) { color = colorUtil.parse(color); @@ -14302,7 +14346,6 @@ var Renderer = Base.extend(function () { } // Render opaque list - scene.trigger('beforerender:opaque', this, opaqueList); var opaqueRenderInfo = this.renderPass(opaqueList, camera, { getMaterial: function (renderable) { return sceneMaterial || renderable.material; @@ -14310,9 +14353,6 @@ var Renderer = Base.extend(function () { sortCompare: this.opaqueSortCompare }); - scene.trigger('afterrender:opaque', this, opaqueList, opaqueRenderInfo); - scene.trigger('beforerender:transparent', this, transparentList); - var transparentRenderInfo = this.renderPass(transparentList, camera, { getMaterial: function (renderable) { return sceneMaterial || renderable.material; @@ -14320,7 +14360,6 @@ var Renderer = Base.extend(function () { sortCompare: this.transparentSortCompare }); - scene.trigger('afterrender:transparent', this, transparentList, transparentRenderInfo); var renderInfo = {}; for (var name in opaqueRenderInfo) { renderInfo[name] = opaqueRenderInfo[name] + transparentRenderInfo[name]; @@ -14423,6 +14462,8 @@ var Renderer = Base.extend(function () { * @return {IRenderInfo} */ renderPass: function(list, camera, passConfig) { + this.trigger('beforerenderpass', this, list, camera, passConfig); + var renderInfo = { triangleCount: 0, vertexCount: 0, @@ -14613,6 +14654,8 @@ var Renderer = Base.extend(function () { list[i].__program = null; } + this.trigger('afterrenderpass', this, list, camera, passConfig); + return renderInfo; }, @@ -19019,6 +19062,104 @@ var Sphere$1 = Geometry.extend( } }); +/** + * @constructor clay.geometry.ParametricSurface + * @extends clay.Geometry + * @param {Object} [opt] + * @param {Object} [generator] + * @param {Function} generator.x + * @param {Function} generator.y + * @param {Function} generator.z + * @param {Array} [generator.u=[0, 1, 0.05]] + * @param {Array} [generator.v=[0, 1, 0.05]] + */ +var ParametricSurface$1 = Geometry.extend( +/** @lends clay.geometry.ParametricSurface# */ +{ + dynamic: false, + /** + * @type {Object} + */ + generator: null + +}, function() { + this.build(); +}, +/** @lends clay.geometry.ParametricSurface.prototype */ +{ + /** + * Build parametric surface geometry + */ + build: function () { + var generator = this.generator; + + if (!generator || !generator.x || !generator.y || !generator.z) { + throw new Error('Invalid generator'); + } + var xFunc = generator.x; + var yFunc = generator.y; + var zFunc = generator.z; + var uRange = generator.u || [0, 1, 0.05]; + var vRange = generator.v || [0, 1, 0.05]; + + var uNum = Math.floor((uRange[1] - uRange[0] + uRange[2]) / uRange[2]); + var vNum = Math.floor((vRange[1] - vRange[0] + vRange[2]) / vRange[2]); + + if (!isFinite(uNum) || !isFinite(vNum)) { + throw new Error('Infinite generator'); + } + + var vertexNum = uNum * vNum; + this.attributes.position.init(vertexNum); + this.attributes.texcoord0.init(vertexNum); + + var pos = []; + var texcoord = []; + var nVertex = 0; + for (var j = 0; j < vNum; j++) { + for (var i = 0; i < uNum; i++) { + var u = i * uRange[2] + uRange[0]; + var v = j * vRange[2] + vRange[0]; + pos[0] = xFunc(u, v); + pos[1] = yFunc(u, v); + pos[2] = zFunc(u, v); + + texcoord[0] = i / (uNum - 1); + texcoord[1] = j / (vNum - 1); + + this.attributes.position.set(nVertex, pos); + this.attributes.texcoord0.set(nVertex, texcoord); + nVertex++; + } + } + + var IndicesCtor = vertexNum > 0xffff ? Uint32Array : Uint16Array; + var nIndices = (uNum - 1) * (vNum - 1) * 6; + var indices = this.indices = new IndicesCtor(nIndices); + + var n = 0; + for (var j = 0; j < vNum - 1; j++) { + for (var i = 0; i < uNum - 1; i++) { + var i2 = j * uNum + i; + var i1 = (j * uNum + i + 1); + var i4 = (j + 1) * uNum + i + 1; + var i3 = (j + 1) * uNum + i; + + indices[n++] = i1; + indices[n++] = i2; + indices[n++] = i4; + + indices[n++] = i2; + indices[n++] = i3; + indices[n++] = i4; + } + } + + this.generateVertexNormals(); + this.updateBoundingBox(); + } +}); + var mathUtil = {}; mathUtil.isPowerOfTwo = function (value) { @@ -19264,6 +19405,271 @@ Object.defineProperty(Texture2D.prototype, 'height', { } }); +var isPowerOfTwo$1 = mathUtil.isPowerOfTwo; + +var targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; + +/** + * @constructor clay.TextureCube + * @extends clay.Texture + * + * @example + * ... + * var mat = new clay.Material({ + * shader: clay.shader.library.get('clay.phong', 'environmentMap') + * }); + * var envMap = new clay.TextureCube(); + * envMap.load({ + * 'px': 'assets/textures/sky/px.jpg', + * 'nx': 'assets/textures/sky/nx.jpg' + * 'py': 'assets/textures/sky/py.jpg' + * 'ny': 'assets/textures/sky/ny.jpg' + * 'pz': 'assets/textures/sky/pz.jpg' + * 'nz': 'assets/textures/sky/nz.jpg' + * }); + * mat.set('environmentMap', envMap); + * ... + * envMap.success(function () { + * // Wait for the sky texture loaded + * animation.on('frame', function (frameTime) { + * renderer.render(scene, camera); + * }); + * }); + */ +var TextureCube = Texture.extend(function () { + return /** @lends clay.TextureCube# */{ + + /** + * @type {boolean} + * @default false + */ + // PENDING cubemap should not flipY in default. + // flipY: false, + + /** + * @type {Object} + * @property {?HTMLImageElement|HTMLCanvasElemnet} px + * @property {?HTMLImageElement|HTMLCanvasElemnet} nx + * @property {?HTMLImageElement|HTMLCanvasElemnet} py + * @property {?HTMLImageElement|HTMLCanvasElemnet} ny + * @property {?HTMLImageElement|HTMLCanvasElemnet} pz + * @property {?HTMLImageElement|HTMLCanvasElemnet} nz + */ + image: { + px: null, + nx: null, + py: null, + ny: null, + pz: null, + nz: null + }, + /** + * Pixels data of each side. Will be ignored if images are set. + * @type {Object} + * @property {?Uint8Array} px + * @property {?Uint8Array} nx + * @property {?Uint8Array} py + * @property {?Uint8Array} ny + * @property {?Uint8Array} pz + * @property {?Uint8Array} nz + */ + pixels: { + px: null, + nx: null, + py: null, + ny: null, + pz: null, + nz: null + }, + + /** + * @type {Array.} + */ + mipmaps: [] + }; +}, { + update: function (renderer) { + var _gl = renderer.gl; + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); + + this.updateCommon(renderer); + + var glFormat = this.format; + var glType = this.type; + + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS()); + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT()); + + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter()); + _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter()); + + var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic'); + if (anisotropicExt && this.anisotropic > 1) { + _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic); + } + + // Fallback to float type if browser don't have half float extension + if (glType === 36193) { + var halfFloatExt = renderer.getGLExtension('OES_texture_half_float'); + if (!halfFloatExt) { + glType = glenum.FLOAT; + } + } + + if (this.mipmaps.length) { + var width = this.width; + var height = this.height; + for (var i = 0; i < this.mipmaps.length; i++) { + var mipmap = this.mipmaps[i]; + this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType); + width /= 2; + height /= 2; + } + } + else { + this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType); + + if (!this.NPOT && this.useMipmap) { + _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); + } + } + + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null); + }, + + _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) { + for (var i = 0; i < 6; i++) { + var target = targetList[i]; + var img = data.image && data.image[target]; + if (img) { + _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img); + } + else { + _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]); + } + } + }, + + /** + * @param {clay.Renderer} renderer + * @memberOf clay.TextureCube.prototype + */ + generateMipmap: function (renderer) { + var _gl = renderer.gl; + if (this.useMipmap && !this.NPOT) { + _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); + _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); + } + }, + + bind: function (renderer) { + renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer)); + }, + + unbind: function (renderer) { + renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null); + }, + + // Overwrite the isPowerOfTwo method + isPowerOfTwo: function () { + if (this.image.px) { + return isPowerOfTwo$1(this.image.px.width) + && isPowerOfTwo$1(this.image.px.height); + } + else { + return isPowerOfTwo$1(this.width) + && isPowerOfTwo$1(this.height); + } + }, + + isRenderable: function () { + if (this.image.px) { + return isImageRenderable(this.image.px) + && isImageRenderable(this.image.nx) + && isImageRenderable(this.image.py) + && isImageRenderable(this.image.ny) + && isImageRenderable(this.image.pz) + && isImageRenderable(this.image.nz); + } + else { + return !!(this.width && this.height); + } + }, + + load: function (imageList, crossOrigin) { + var loading = 0; + var self = this; + util$1.each(imageList, function (src, target){ + var image = new Image(); + if (crossOrigin) { + image.crossOrigin = crossOrigin; + } + image.onload = function () { + loading --; + if (loading === 0){ + self.dirty(); + self.trigger('success', self); + } + image.onload = null; + }; + image.onerror = function () { + loading --; + image.onerror = null; + }; + + loading++; + image.src = src; + self.image[target] = image; + }); + + return this; + } +}); + +Object.defineProperty(TextureCube.prototype, 'width', { + get: function () { + if (this.image && this.image.px) { + return this.image.px.width; + } + return this._width; + }, + set: function (value) { + if (this.image && this.image.px) { + console.warn('Texture from image can\'t set width'); + } + else { + if (this._width !== value) { + this.dirty(); + } + this._width = value; + } + } +}); +Object.defineProperty(TextureCube.prototype, 'height', { + get: function () { + if (this.image && this.image.px) { + return this.image.px.height; + } + return this._height; + }, + set: function (value) { + if (this.image && this.image.px) { + console.warn('Texture from image can\'t set height'); + } + else { + if (this._height !== value) { + this.dirty(); + } + this._height = value; + } + } +}); +function isImageRenderable(image) { + return image.nodeName === 'CANVAS' || + image.nodeName === 'VIDEO' || + image.complete; +} + var _library = {}; function ShaderLibrary () { @@ -20050,7 +20456,7 @@ var request = { get : get }; -var standardEssl = "\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n#ifdef GAMMA_ENCODE\n outColor.rgb = pow(outColor.rgb, vec3(1 / 2.2));\n#endif\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end"; +var standardEssl = "\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end"; // Import standard shader Shader['import'](standardEssl); @@ -20668,13 +21074,13 @@ var Skeleton = Base.extend(function () { var utilGlsl = "\n@export clay.util.rand\nhighp float rand(vec2 uv) {\n const highp float a = 12.9898, b = 78.233, c = 43758.5453;\n highp float dt = dot(uv.xy, vec2(a,b)), sn = mod(dt, 3.141592653589793);\n return fract(sin(sn) * c);\n}\n@end\n@export clay.util.calculate_attenuation\nuniform float attenuationFactor : 5.0;\nfloat lightAttenuation(float dist, float range)\n{\n float attenuation = 1.0;\n attenuation = dist*dist/(range*range+1.0);\n float att_s = attenuationFactor;\n attenuation = 1.0/(attenuation*att_s+1.0);\n att_s = 1.0/(att_s+1.0);\n attenuation = attenuation - att_s;\n attenuation /= 1.0 - att_s;\n return clamp(attenuation, 0.0, 1.0);\n}\n@end\n@export clay.util.edge_factor\nfloat edgeFactor(float width)\n{\n vec3 d = fwidth(v_Barycentric);\n vec3 a3 = smoothstep(vec3(0.0), d * width, v_Barycentric);\n return min(min(a3.x, a3.y), a3.z);\n}\n@end\n@export clay.util.encode_float\nvec4 encodeFloat(const in float depth)\n{\n const vec4 bitShifts = vec4(256.0*256.0*256.0, 256.0*256.0, 256.0, 1.0);\n const vec4 bit_mask = vec4(0.0, 1.0/256.0, 1.0/256.0, 1.0/256.0);\n vec4 res = fract(depth * bitShifts);\n res -= res.xxyz * bit_mask;\n return res;\n}\n@end\n@export clay.util.decode_float\nfloat decodeFloat(const in vec4 color)\n{\n const vec4 bitShifts = vec4(1.0/(256.0*256.0*256.0), 1.0/(256.0*256.0), 1.0/256.0, 1.0);\n return dot(color, bitShifts);\n}\n@end\n@export clay.util.float\n@import clay.util.encode_float\n@import clay.util.decode_float\n@end\n@export clay.util.rgbm_decode\nvec3 RGBMDecode(vec4 rgbm, float range) {\n return range * rgbm.rgb * rgbm.a;\n}\n@end\n@export clay.util.rgbm_encode\nvec4 RGBMEncode(vec3 color, float range) {\n if (dot(color, color) == 0.0) {\n return vec4(0.0);\n }\n vec4 rgbm;\n color /= range;\n rgbm.a = clamp(max(max(color.r, color.g), max(color.b, 1e-6)), 0.0, 1.0);\n rgbm.a = ceil(rgbm.a * 255.0) / 255.0;\n rgbm.rgb = color / rgbm.a;\n return rgbm;\n}\n@end\n@export clay.util.rgbm\n@import clay.util.rgbm_decode\n@import clay.util.rgbm_encode\nvec4 decodeHDR(vec4 color)\n{\n#if defined(RGBM_DECODE) || defined(RGBM)\n return vec4(RGBMDecode(color, 51.5), 1.0);\n#else\n return color;\n#endif\n}\nvec4 encodeHDR(vec4 color)\n{\n#if defined(RGBM_ENCODE) || defined(RGBM)\n return RGBMEncode(color.xyz, 51.5);\n#else\n return color;\n#endif\n}\n@end\n@export clay.util.srgb\nvec4 sRGBToLinear(in vec4 value) {\n return vec4(mix(pow(value.rgb * 0.9478672986 + vec3(0.0521327014), vec3(2.4)), value.rgb * 0.0773993808, vec3(lessThanEqual(value.rgb, vec3(0.04045)))), value.w);\n}\nvec4 linearTosRGB(in vec4 value) {\n return vec4(mix(pow(value.rgb, vec3(0.41666)) * 1.055 - vec3(0.055), value.rgb * 12.92, vec3(lessThanEqual(value.rgb, vec3(0.0031308)))), value.w);\n}\n@end\n@export clay.chunk.skinning_header\n#ifdef SKINNING\nattribute vec3 weight : WEIGHT;\nattribute vec4 joint : JOINT;\nuniform mat4 skinMatrix[JOINT_COUNT] : SKIN_MATRIX;\nmat4 getSkinMatrix(float idx) {\n return skinMatrix[int(idx)];\n}\n#endif\n@end\n@export clay.chunk.skin_matrix\nmat4 skinMatrixWS = getSkinMatrix(joint.x) * weight.x;\nif (weight.y > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.y) * weight.y;\n}\nif (weight.z > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.z) * weight.z;\n}\nfloat weightW = 1.0-weight.x-weight.y-weight.z;\nif (weightW > 1e-4)\n{\n skinMatrixWS += getSkinMatrix(joint.w) * weightW;\n}\n@end\n@export clay.util.parallax_correct\nvec3 parallaxCorrect(in vec3 dir, in vec3 pos, in vec3 boxMin, in vec3 boxMax) {\n vec3 first = (boxMax - pos) / dir;\n vec3 second = (boxMin - pos) / dir;\n vec3 further = max(first, second);\n float dist = min(further.x, min(further.y, further.z));\n vec3 fixedPos = pos + dir * dist;\n vec3 boxCenter = (boxMax + boxMin) * 0.5;\n return normalize(fixedPos - boxCenter);\n}\n@end\n@export clay.util.clamp_sample\nvec4 clampSample(const in sampler2D texture, const in vec2 coord)\n{\n#ifdef STEREO\n float eye = step(0.5, coord.x) * 0.5;\n vec2 coordClamped = clamp(coord, vec2(eye, 0.0), vec2(0.5 + eye, 1.0));\n#else\n vec2 coordClamped = clamp(coord, vec2(0.0), vec2(1.0));\n#endif\n return texture2D(texture, coordClamped);\n}\n@end\n@export clay.util.ACES\nvec3 ACESToneMapping(vec3 color)\n{\n const float A = 2.51;\n const float B = 0.03;\n const float C = 2.43;\n const float D = 0.59;\n const float E = 0.14;\n return (color * (A * color + B)) / (color * (C * color + D) + E);\n}\n@end"; -var basicEssl = "@export clay.basic.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Barycentric = barycentric;\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.basic.fragment\nvarying vec2 v_Texcoord;\nuniform sampler2D diffuseMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\n#ifdef SRGB_DECODE\n tex = sRGBToLinear(tex);\n#endif\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\n gl_FragColor.a = tex.a;\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#endif\n gl_FragColor.rgb += emission;\n if( lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef GAMMA_ENCODE\n gl_FragColor.rgb = pow(gl_FragColor.rgb, vec3(1 / 2.2));\n#endif\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; +var basicEssl = "@export clay.basic.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Barycentric = barycentric;\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.basic.fragment\nvarying vec2 v_Texcoord;\nuniform sampler2D diffuseMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\n#ifdef SRGB_DECODE\n tex = sRGBToLinear(tex);\n#endif\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\n gl_FragColor.a = tex.a;\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#endif\n gl_FragColor.rgb += emission;\n if( lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; var lambertEssl = "\n@export clay.lambert.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\nattribute vec3 normal : NORMAL;\nattribute vec3 barycentric;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4( skinnedPosition, 1.0 );\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_Normal = normalize( ( worldInverseTranspose * vec4(skinnedNormal, 0.0) ).xyz );\n v_WorldPosition = ( world * vec4( skinnedPosition, 1.0) ).xyz;\n v_Barycentric = barycentric;\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n}\n@end\n@export clay.lambert.fragment\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D diffuseMap;\nuniform sampler2D alphaMap;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.plugin.compute_shadow_map\n@import clay.util.ACES\nvoid main()\n{\n#ifdef RENDER_NORMAL\n gl_FragColor = vec4(v_Normal * 0.5 + 0.5, 1.0);\n return;\n#endif\n#ifdef RENDER_TEXCOORD\n gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\n return;\n#endif\n gl_FragColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n gl_FragColor *= v_Color;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 tex = texture2D( diffuseMap, v_Texcoord );\n#ifdef SRGB_DECODE\n tex.rgb = pow(tex.rgb, vec3(2.2));\n#endif\n gl_FragColor.rgb *= tex.rgb;\n#ifdef DIFFUSEMAP_ALPHA_ALPHA\n gl_FragColor.a *= tex.a;\n#endif\n#endif\n vec3 diffuseColor = vec3(0.0, 0.0, 0.0);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {\n diffuseColor += ambientLightColor[_idx_];\n }\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseColor += calcAmbientSHLight(_idx_, v_Normal) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if( shadowEnabled )\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int i = 0; i < POINT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = pointLightPosition[i];\n vec3 lightColor = pointLightColor[i];\n float range = pointLightRange[i];\n vec3 lightDirection = lightPosition - v_WorldPosition;\n float dist = length(lightDirection);\n float attenuation = lightAttenuation(dist, range);\n lightDirection /= dist;\n float ndl = dot( v_Normal, lightDirection );\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsPoint[i];\n }\n#endif\n diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * attenuation * shadowContrib;\n }\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int i = 0; i < DIRECTIONAL_LIGHT_COUNT; i++)\n {\n vec3 lightDirection = -directionalLightDirection[i];\n vec3 lightColor = directionalLightColor[i];\n float ndl = dot(v_Normal, normalize(lightDirection));\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsDir[i];\n }\n#endif\n diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * shadowContrib;\n }\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = -spotLightPosition[i];\n vec3 spotLightDirection = -normalize( spotLightDirection[i] );\n vec3 lightColor = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 lightDirection = lightPosition - v_WorldPosition;\n float dist = length(lightDirection);\n float attenuation = lightAttenuation(dist, range);\n lightDirection /= dist;\n float c = dot(spotLightDirection, lightDirection);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n float ndl = dot(v_Normal, lightDirection);\n ndl = clamp(ndl, 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if( shadowEnabled )\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n diffuseColor += lightColor * ndl * attenuation * (1.0-falloff) * shadowContrib;\n }\n#endif\n gl_FragColor.rgb *= diffuseColor;\n gl_FragColor.rgb += emission;\n if(lineWidth > 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"; var wireframeEssl = "@export clay.wireframe.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 world : WORLD;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\n v_Barycentric = barycentric;\n}\n@end\n@export clay.wireframe.fragment\nuniform vec3 color : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\nuniform float lineWidth : 1.0;\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\nvoid main()\n{\n gl_FragColor.rgb = color;\n gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\n}\n@end"; -var skyboxEssl = "@export clay.skybox.vertex\nuniform mat4 world : WORLD;\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_WorldPosition;\nvoid main()\n{\n v_WorldPosition = (world * vec4(position, 1.0)).xyz;\n gl_Position = worldViewProjection * vec4(position, 1.0);\n}\n@end\n@export clay.skybox.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform samplerCube environmentMap;\nuniform float lod: 0.0;\nvarying vec3 v_WorldPosition;\n@import clay.util.rgbm\nvoid main()\n{\n vec3 eyePos = viewInverse[3].xyz;\n vec3 viewDirection = normalize(v_WorldPosition - eyePos);\n vec3 tex = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod)).rgb;\n#ifdef SRGB_DECODE\n tex.rgb = pow(tex.rgb, vec3(2.2));\n#endif\n gl_FragColor = encodeHDR(vec4(tex, 1.0));\n}\n@end"; +var skyboxEssl = "@export clay.skybox.vertex\nuniform mat4 world : WORLD;\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_WorldPosition;\nvoid main()\n{\n v_WorldPosition = (world * vec4(position, 1.0)).xyz;\n gl_Position = worldViewProjection * vec4(position, 1.0);\n}\n@end\n@export clay.skybox.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform samplerCube environmentMap;\nuniform float lod: 0.0;\nvarying vec3 v_WorldPosition;\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.util.ACES\nvoid main()\n{\n vec3 eyePos = viewInverse[3].xyz;\n vec3 viewDirection = normalize(v_WorldPosition - eyePos);\n#ifdef LOD\n vec4 texel = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod));\n#else\n vec4 texel = decodeHDR(textureCube(environmentMap, viewDirection));\n#endif\n#ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n#endif\n#ifdef TONEMAPPING\n texel.rgb = ACESToneMapping(texel.rgb);\n#endif\n#ifdef SRGB_ENCODE\n texel = linearTosRGB(texel);\n#endif\n gl_FragColor = encodeHDR(vec4(texel.rgb, 1.0));\n}\n@end"; var coloradjustEssl = "@export clay.compositor.coloradjust\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float exposure : 0.0;\nuniform float gamma : 1.0;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\n color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\n color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\n float luminance = dot( color, w );\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.brightness\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = tex.rgb + vec3(brightness);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.contrast\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float contrast : 1.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.exposure\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float exposure : 0.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb * pow(2.0, exposure);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.gamma\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float gamma : 1.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = pow(tex.rgb, vec3(gamma));\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.saturation\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb;\n float luminance = dot(color, w);\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end"; @@ -21056,7 +21462,7 @@ function () { textures: lib.textures, materials: lib.materials, skeletons: lib.skeletons, - meshes: lib.meshes, + meshes: lib.instancedMeshes, clips: lib.clips, nodes: lib.nodes }; @@ -21425,6 +21831,7 @@ function () { metalness: metallicRoughnessMatInfo.metallicFactor || 0, roughness: metallicRoughnessMatInfo.roughnessFactor || 0, emission: materialInfo.emissiveFactor || [0, 0, 0], + emissionIntensity: 1, alphaCutoff: materialInfo.alphaCutoff || 0 }; if (commonProperties.roughnessMap) { @@ -21515,6 +21922,7 @@ function () { specularColor: specularGlossinessMatInfo.specularFactor || [1, 1, 1], glossiness: specularGlossinessMatInfo.glossinessFactor || 0, emission: materialInfo.emissiveFactor || [0, 0, 0], + emissionIntensity: 1, alphaCutoff: materialInfo.alphaCutoff == null ? 0.9 : materialInfo.alphaCutoff }; if (commonProperties.glossinessMap) { @@ -21725,6 +22133,8 @@ function () { }); } + lib.instancedMeshes = []; + util$1.each(json.nodes, function (nodeInfo, idx) { var node; if (nodeInfo.camera != null && this.includeCamera) { @@ -21738,12 +22148,15 @@ function () { // Replace the node with mesh directly node = instanceMesh(primitives[0]); node.setName(nodeInfo.name); + lib.instancedMeshes.push(node); } else { node = new Node(); node.setName(nodeInfo.name); for (var j = 0; j < primitives.length; j++) { - node.add(instanceMesh(primitives[j])); + var newMesh = instanceMesh(primitives[j]); + node.add(newMesh); + lib.instancedMeshes.push(newMesh); } } } @@ -22124,263 +22537,6 @@ var AmbientLight = Light.extend({ */ }); -var isPowerOfTwo$1 = mathUtil.isPowerOfTwo; - -var targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; - -/** - * @constructor clay.TextureCube - * @extends clay.Texture - * - * @example - * ... - * var mat = new clay.Material({ - * shader: clay.shader.library.get('clay.phong', 'environmentMap') - * }); - * var envMap = new clay.TextureCube(); - * envMap.load({ - * 'px': 'assets/textures/sky/px.jpg', - * 'nx': 'assets/textures/sky/nx.jpg' - * 'py': 'assets/textures/sky/py.jpg' - * 'ny': 'assets/textures/sky/ny.jpg' - * 'pz': 'assets/textures/sky/pz.jpg' - * 'nz': 'assets/textures/sky/nz.jpg' - * }); - * mat.set('environmentMap', envMap); - * ... - * envMap.success(function () { - * // Wait for the sky texture loaded - * animation.on('frame', function (frameTime) { - * renderer.render(scene, camera); - * }); - * }); - */ -var TextureCube = Texture.extend(function () { - return /** @lends clay.TextureCube# */{ - /** - * @type {Object} - * @property {?HTMLImageElement|HTMLCanvasElemnet} px - * @property {?HTMLImageElement|HTMLCanvasElemnet} nx - * @property {?HTMLImageElement|HTMLCanvasElemnet} py - * @property {?HTMLImageElement|HTMLCanvasElemnet} ny - * @property {?HTMLImageElement|HTMLCanvasElemnet} pz - * @property {?HTMLImageElement|HTMLCanvasElemnet} nz - */ - image: { - px: null, - nx: null, - py: null, - ny: null, - pz: null, - nz: null - }, - /** - * Pixels data of each side. Will be ignored if images are set. - * @type {Object} - * @property {?Uint8Array} px - * @property {?Uint8Array} nx - * @property {?Uint8Array} py - * @property {?Uint8Array} ny - * @property {?Uint8Array} pz - * @property {?Uint8Array} nz - */ - pixels: { - px: null, - nx: null, - py: null, - ny: null, - pz: null, - nz: null - }, - - /** - * @type {Array.} - */ - mipmaps: [] - }; -}, { - update: function (renderer) { - var _gl = renderer.gl; - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); - - this.updateCommon(renderer); - - var glFormat = this.format; - var glType = this.type; - - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS()); - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT()); - - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter()); - _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter()); - - var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic'); - if (anisotropicExt && this.anisotropic > 1) { - _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic); - } - - // Fallback to float type if browser don't have half float extension - if (glType === 36193) { - var halfFloatExt = renderer.getGLExtension('OES_texture_half_float'); - if (!halfFloatExt) { - glType = glenum.FLOAT; - } - } - - if (this.mipmaps.length) { - var width = this.width; - var height = this.height; - for (var i = 0; i < this.mipmaps.length; i++) { - var mipmap = this.mipmaps[i]; - this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType); - width /= 2; - height /= 2; - } - } - else { - this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType); - - if (!this.NPOT && this.useMipmap) { - _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); - } - } - - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null); - }, - - _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) { - for (var i = 0; i < 6; i++) { - var target = targetList[i]; - var img = data.image && data.image[target]; - if (img) { - _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img); - } - else { - _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]); - } - } - }, - - /** - * @param {clay.Renderer} renderer - * @memberOf clay.TextureCube.prototype - */ - generateMipmap: function (renderer) { - var _gl = renderer.gl; - if (this.useMipmap && !this.NPOT) { - _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture')); - _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP); - } - }, - - bind: function (renderer) { - renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer)); - }, - - unbind: function (renderer) { - renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null); - }, - - // Overwrite the isPowerOfTwo method - isPowerOfTwo: function () { - if (this.image.px) { - return isPowerOfTwo$1(this.image.px.width) - && isPowerOfTwo$1(this.image.px.height); - } - else { - return isPowerOfTwo$1(this.width) - && isPowerOfTwo$1(this.height); - } - }, - - isRenderable: function () { - if (this.image.px) { - return isImageRenderable(this.image.px) - && isImageRenderable(this.image.nx) - && isImageRenderable(this.image.py) - && isImageRenderable(this.image.ny) - && isImageRenderable(this.image.pz) - && isImageRenderable(this.image.nz); - } - else { - return !!(this.width && this.height); - } - }, - - load: function (imageList, crossOrigin) { - var loading = 0; - var self = this; - util$1.each(imageList, function (src, target){ - var image = new Image(); - if (crossOrigin) { - image.crossOrigin = crossOrigin; - } - image.onload = function () { - loading --; - if (loading === 0){ - self.dirty(); - self.trigger('success', self); - } - image.onload = null; - }; - image.onerror = function () { - loading --; - image.onerror = null; - }; - - loading++; - image.src = src; - self.image[target] = image; - }); - - return this; - } -}); - -Object.defineProperty(TextureCube.prototype, 'width', { - get: function () { - if (this.image && this.image.px) { - return this.image.px.width; - } - return this._width; - }, - set: function (value) { - if (this.image && this.image.px) { - console.warn('Texture from image can\'t set width'); - } - else { - if (this._width !== value) { - this.dirty(); - } - this._width = value; - } - } -}); -Object.defineProperty(TextureCube.prototype, 'height', { - get: function () { - if (this.image && this.image.px) { - return this.image.px.height; - } - return this._height; - }, - set: function (value) { - if (this.image && this.image.px) { - console.warn('Texture from image can\'t set height'); - } - else { - if (this._height !== value) { - this.dirty(); - } - this._height = value; - } - } -}); -function isImageRenderable(image) { - return image.nodeName === 'CANVAS' || - image.nodeName === 'VIDEO' || - image.complete; -} - var KEY_FRAMEBUFFER = 'framebuffer'; var KEY_RENDERBUFFER = 'renderbuffer'; var KEY_RENDERBUFFER_WIDTH = KEY_RENDERBUFFER + '_width'; @@ -23025,6 +23181,8 @@ var Skybox = Mesh.extend(function () { if (this.scene) { this.detachScene(); } + scene.skybox = this; + this.scene = scene; scene.on('beforerender', this._beforeRenderScene, this); }, @@ -23034,6 +23192,7 @@ var Skybox = Mesh.extend(function () { detachScene: function () { if (this.scene) { this.scene.off('beforerender', this._beforeRenderScene); + this.scene.skybox = null; } this.scene = null; }, @@ -23070,6 +23229,12 @@ var Skybox = Mesh.extend(function () { this.update(); // Don't remember to disable blend renderer.gl.disable(renderer.gl.BLEND); + if (this.material.get('lod') > 0) { + this.material.define('fragment', 'LOD'); + } + else { + this.material.undefine('fragment', 'LOD'); + } renderer.renderPass([this], camera); } }); @@ -23271,6 +23436,8 @@ var Skydome = Mesh.extend(function () { if (this.scene) { this.detachScene(); } + scene.skydome = this; + this.scene = scene; scene.on('beforerender', this._beforeRenderScene, this); }, @@ -23281,6 +23448,7 @@ var Skydome = Mesh.extend(function () { detachScene: function () { if (this.scene) { this.scene.off('beforerender', this._beforeRenderScene); + this.scene.skydome = null; } this.scene = null; }, @@ -23616,7 +23784,8 @@ var textureUtil = { if (path.match(/.hdr$/) || option.fileType === 'hdr') { texture = new Texture2D({ width: 0, - height: 0 + height: 0, + sRGB: false }); textureUtil._fetchTexture( path, @@ -23712,6 +23881,9 @@ var textureUtil = { skydome.material.define('fragment', 'RGBM_ENCODE'); } + // Share sRGB + cubeMap.sRGB = panoramaMap.sRGB; + environmentMapPass.texture = cubeMap; environmentMapPass.render(renderer, skydome.scene); environmentMapPass.texture = null; @@ -25430,4499 +25602,4694 @@ RayPicking.Intersection = function (point, pointWorld, target, triangle, triangl this.distance = distance; }; -// Spherical Harmonic Helpers var vec3$15 = glmatrix.vec3; -var sh = {}; - -var targets$3 = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; +var vec2$1 = glmatrix.vec2; -function harmonics(normal, index){ - var x = normal[0]; - var y = normal[1]; - var z = normal[2]; +/** + * @constructor clay.geometry.Cone + * @extends clay.Geometry + * @param {Object} [opt] + * @param {number} [opt.topRadius] + * @param {number} [opt.bottomRadius] + * @param {number} [opt.height] + * @param {number} [opt.capSegments] + * @param {number} [opt.heightSegments] + */ +var Cone$1 = Geometry.extend( +/** @lends clay.geometry.Cone# */ +{ + dynamic: false, + /** + * @type {number} + */ + topRadius: 0, - if (index === 0) { - return 1.0; - } - else if (index === 1) { - return x; - } - else if (index === 2) { - return y; - } - else if (index === 3) { - return z; - } - else if (index === 4) { - return x * z; - } - else if (index === 5) { - return y * z; - } - else if (index === 6) { - return x * y; - } - else if (index === 7) { - return 3.0 * z * z - 1.0; - } - else { - return x * x - y * y; - } -} + /** + * @type {number} + */ + bottomRadius: 1, -var normalTransform = { - px: [2, 1, 0, -1, -1, 1], - nx: [2, 1, 0, 1, -1, -1], - py: [0, 2, 1, 1, -1, -1], - ny: [0, 2, 1, 1, 1, 1], - pz: [0, 1, 2, -1, -1, -1], - nz: [0, 1, 2, 1, -1, 1] -}; + /** + * @type {number} + */ + height: 2, -// Project on cpu. -function projectEnvironmentMapCPU(renderer, cubePixels, width, height) { - var coeff = new vendor.Float32Array(9 * 3); - var normal = vec3$15.create(); - var texel = vec3$15.create(); - var fetchNormal = vec3$15.create(); - for (var m = 0; m < 9; m++) { - var result = vec3$15.create(); - for (var k = 0; k < targets$3.length; k++) { - var pixels = cubePixels[targets$3[k]]; + /** + * @type {number} + */ + capSegments: 20, - var sideResult = vec3$15.create(); - var divider = 0; - var i = 0; - var transform = normalTransform[targets$3[k]]; - for (var y = 0; y < height; y++) { - for (var x = 0; x < width; x++) { + /** + * @type {number} + */ + heightSegments: 1 +}, function() { + this.build(); +}, +/** @lends clay.geometry.Cone.prototype */ +{ + /** + * Build cone geometry + */ + build: function() { + var positions = []; + var texcoords = []; + var faces = []; + positions.length = 0; + texcoords.length = 0; + faces.length = 0; + // Top cap + var capSegRadial = Math.PI * 2 / this.capSegments; - normal[0] = x / (width - 1.0) * 2.0 - 1.0; - // TODO Flip y? - normal[1] = y / (height - 1.0) * 2.0 - 1.0; - normal[2] = -1.0; - vec3$15.normalize(normal, normal); + var topCap = []; + var bottomCap = []; - fetchNormal[0] = normal[transform[0]] * transform[3]; - fetchNormal[1] = normal[transform[1]] * transform[4]; - fetchNormal[2] = normal[transform[2]] * transform[5]; + var r1 = this.topRadius; + var r2 = this.bottomRadius; + var y = this.height / 2; - texel[0] = pixels[i++] / 255; - texel[1] = pixels[i++] / 255; - texel[2] = pixels[i++] / 255; - // RGBM Decode - var scale = pixels[i++] / 255 * 51.5; - texel[0] *= scale; - texel[1] *= scale; - texel[2] *= scale; + var c1 = vec3$15.fromValues(0, y, 0); + var c2 = vec3$15.fromValues(0, -y, 0); + for (var i = 0; i < this.capSegments; i++) { + var theta = i * capSegRadial; + var x = r1 * Math.sin(theta); + var z = r1 * Math.cos(theta); + topCap.push(vec3$15.fromValues(x, y, z)); - vec3$15.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]); - // -normal.z equals cos(theta) of Lambertian - divider += -normal[2]; - } - } - vec3$15.scaleAndAdd(result, result, sideResult, 1 / divider); + x = r2 * Math.sin(theta); + z = r2 * Math.cos(theta); + bottomCap.push(vec3$15.fromValues(x, -y, z)); } - coeff[m * 3] = result[0] / 6.0; - coeff[m * 3 + 1] = result[1] / 6.0; - coeff[m * 3 + 2] = result[2] / 6.0; - } - return coeff; -} + // Build top cap + positions.push(c1); + // FIXME + texcoords.push(vec2$1.fromValues(0, 1)); + var n = this.capSegments; + for (var i = 0; i < n; i++) { + positions.push(topCap[i]); + // FIXME + texcoords.push(vec2$1.fromValues(i / n, 0)); + faces.push([0, i+1, (i+1) % n + 1]); + } -/** - * @param {clay.Renderer} renderer - * @param {clay.Texture} envMap - * @param {Object} [textureOpts] - * @param {Object} [textureOpts.lod] - * @param {boolean} [textureOpts.decodeRGBM] - */ -sh.projectEnvironmentMap = function (renderer, envMap, opts) { + // Build bottom cap + var offset = positions.length; + positions.push(c2); + texcoords.push(vec2$1.fromValues(0, 1)); + for (var i = 0; i < n; i++) { + positions.push(bottomCap[i]); + // FIXME + texcoords.push(vec2$1.fromValues(i / n, 0)); + faces.push([offset, offset+((i+1) % n + 1), offset+i+1]); + } - // TODO sRGB + // Build side + offset = positions.length; + var n2 = this.heightSegments; + for (var i = 0; i < n; i++) { + for (var j = 0; j < n2+1; j++) { + var v = j / n2; + positions.push(vec3$15.lerp(vec3$15.create(), topCap[i], bottomCap[i], v)); + texcoords.push(vec2$1.fromValues(i / n, v)); + } + } + for (var i = 0; i < n; i++) { + for (var j = 0; j < n2; j++) { + var i1 = i * (n2 + 1) + j; + var i2 = ((i + 1) % n) * (n2 + 1) + j; + var i3 = ((i + 1) % n) * (n2 + 1) + j + 1; + var i4 = i * (n2 + 1) + j + 1; + faces.push([offset+i2, offset+i1, offset+i4]); + faces.push([offset+i4, offset+i3, offset+i2]); + } + } - opts = opts || {}; - opts.lod = opts.lod || 0; + this.attributes.position.fromArray(positions); + this.attributes.texcoord0.fromArray(texcoords); - var skybox; - var dummyScene = new Scene(); - var size = 64; - if (envMap instanceof Texture2D) { - skybox = new Skydome({ - scene: dummyScene, - environmentMap: envMap - }); - } - else { - size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width; - skybox = new Skybox({ - scene: dummyScene, - environmentMap: envMap - }); - } - // Convert to rgbm - var width = Math.ceil(size / Math.pow(2, opts.lod)); - var height = Math.ceil(size / Math.pow(2, opts.lod)); - var rgbmTexture = new Texture2D({ - width: width, - height: height - }); - var framebuffer = new FrameBuffer(); - skybox.material.define('fragment', 'RGBM_ENCODE'); - if (opts.decodeRGBM) { - skybox.material.define('fragment', 'RGBM_DECODE'); - } - skybox.material.set('lod', opts.lod); - var envMapPass = new EnvironmentMapPass({ - texture: rgbmTexture - }); - var cubePixels = {}; - for (var i = 0; i < targets$3.length; i++) { - cubePixels[targets$3[i]] = new Uint8Array(width * height * 4); - var camera = envMapPass.getCamera(targets$3[i]); - camera.fov = 90; - framebuffer.attach(rgbmTexture); - framebuffer.bind(renderer); - renderer.render(dummyScene, camera); - renderer.gl.readPixels( - 0, 0, width, height, - Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets$3[i]] - ); - framebuffer.unbind(renderer); - } + this.initIndicesFromArray(faces); - skybox.dispose(renderer); - framebuffer.dispose(renderer); - rgbmTexture.dispose(renderer); + this.generateVertexNormals(); - return projectEnvironmentMapCPU(renderer, cubePixels, width, height); -}; + this.boundingBox = new BoundingBox(); + var r = Math.max(this.topRadius, this.bottomRadius); + this.boundingBox.min.set(-r, -this.height/2, -r); + this.boundingBox.max.set(r, this.height/2, r); + } +}); /** - * Helpers for creating a common 3d application. - * @namespace clay.application + * @constructor clay.geometry.Cylinder + * @extends clay.Geometry + * @param {Object} [opt] + * @param {number} [opt.radius] + * @param {number} [opt.height] + * @param {number} [opt.capSegments] + * @param {number} [opt.heightSegments] */ +var Cylinder$1 = Geometry.extend( +/** @lends clay.geometry.Cylinder# */ +{ + dynamic: false, + /** + * @type {number} + */ + radius: 1, - // TODO createCompositor - // TODO mobile. scroll events. - // TODO Dispose test. geoCache test. - // TODO fitModel, normal generation. - // TODO Skybox, Skydome. - // TODO Particle ? -var parseColor = colorUtil.parseToFloat; + /** + * @type {number} + */ + height: 2, -/** - * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike - */ -/** - * @typedef {string|Array.} Color - */ -/** - * @typedef {HTMLDomElement|string} DomQuery - */ + /** + * @type {number} + */ + capSegments: 50, -/** - * @constructor - * @alias clay.application.App3D - * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector` - * @param {Object} appNS - * @param {Function} appNS.init Initialization callback that will be called when initing app. - * You can return a promise in init to start the loop asynchronously when the promise is resolved. - * @param {Function} appNS.loop Loop callback that will be called each frame. - * @param {Function} appNS.beforeRender - * @param {Function} appNS.afterRender - * @param {number} [appNS.width] Container width. - * @param {number} [appNS.height] Container height. - * @param {number} [appNS.devicePixelRatio] - * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect - * @param {boolean} [appNS.graphic.shadow=false] If enable shadow - * @param {boolean} [appNS.graphic.linear=false] If use linear space - * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping. - * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex. - */ -function App3D(dom, appNS) { + /** + * @type {number} + */ + heightSegments: 1 +}, function() { + this.build(); +}, +/** @lends clay.geometry.Cylinder.prototype */ +{ + /** + * Build cylinder geometry + */ + build: function() { + var cone = new Cone$1({ + topRadius: this.radius, + bottomRadius: this.radius, + capSegments: this.capSegments, + heightSegments: this.heightSegments, + height: this.height + }); - appNS = appNS || {}; - appNS.graphic = appNS.graphic || {}; + this.attributes.position.value = cone.attributes.position.value; + this.attributes.normal.value = cone.attributes.normal.value; + this.attributes.texcoord0.value = cone.attributes.texcoord0.value; + this.indices = cone.indices; - if (typeof dom === 'string') { - dom = document.querySelector(dom); + this.boundingBox = cone.boundingBox; } +}); - if (!dom) { throw new Error('Invalid dom'); } +var gbufferEssl = "@export clay.deferred.gbuffer.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat;\nuniform vec2 uvOffset;\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#ifdef FIRST_PASS\nattribute vec3 normal : NORMAL;\n#endif\n@import clay.chunk.skinning_header\n#ifdef FIRST_PASS\nvarying vec3 v_Normal;\nattribute vec4 tangent : TANGENT;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nvarying vec3 v_WorldPosition;\n#endif\nvarying vec2 v_Texcoord;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef FIRST_PASS\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n bool hasTangent = dot(tangent, tangent) > 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"; - var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS'; - var rendererOpts = {}; - isDomCanvas && (rendererOpts.canvas = dom); - appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio); +var chunkEssl = "@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end"; - var gRenderer = new Renderer(rendererOpts); - var gWidth = appNS.width || dom.clientWidth; - var gHeight = appNS.height || dom.clientHeight; +Shader.import(gbufferEssl); +Shader.import(chunkEssl); - var gScene = new Scene(); - var gTimeline = new Timeline(); - var gShadowPass = appNS.graphic.shadow && new ShadowMapPass(); - var gRayPicking = appNS.event && new RayPicking({ - scene: gScene, - renderer: gRenderer - }); +function createFillCanvas(color) { + var canvas = document.createElement('canvas'); + canvas.width = canvas.height = 1; + var ctx = canvas.getContext('2d'); + ctx.fillStyle = color || '#000'; + ctx.fillRect(0, 0, 1, 1); - !isDomCanvas && dom.appendChild(gRenderer.canvas); + return canvas; +} - gRenderer.resize(gWidth, gHeight); +function attachTextureToSlot(renderer, program, symbol, texture, slot) { + var gl = renderer.gl; + program.setUniform(gl, '1i', symbol, slot); - var gFrameTime = 0; - var gElapsedTime = 0; + gl.activeTexture(gl.TEXTURE0 + slot); + // Maybe texture is not loaded yet; + if (texture.isRenderable()) { + texture.bind(renderer); + } + else { + // Bind texture to null + texture.unbind(renderer); + } +} - gTimeline.start(); +// TODO Use globalShader insteadof globalMaterial? +function getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) { - Object.defineProperties(this, { - /** - * Container dom element - * @name clay.application.App3D#container - * @type {HTMLDomElement} - */ - container: { get: function () { return dom; } }, - /** - * @name clay.application.App3D#renderer - * @type {clay.Renderer} - */ - renderer: { get: function () { return gRenderer; }}, - /** - * @name clay.application.App3D#scene - * @type {clay.Renderer} - */ - scene: { get: function () { return gScene; }}, - /** - * @name clay.application.App3D#timeline - * @type {clay.Renderer} - */ - timeline: { get: function () { return gTimeline; }}, - /** - * Time elapsed since last frame. Can be used in loop to calculate the movement. - * @name clay.application.App3D#frameTime - * @type {number} - */ - frameTime: { get: function () { return gFrameTime; }}, - /** - * Time elapsed since application created. - * @name clay.application.App3D#elapsedTime - * @type {number} - */ - elapsedTime: { get: function () { return gElapsedTime; }} - }); + var previousNormalMap; + var previousRougGlossMap; + var previousRenderable; - /** - * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given. - * @function - * @memberOf {clay.application.App3D} - * @param {number} [width] - * @param {number} [height] - */ - this.resize = function (width, height) { - gWidth = width || appNS.width || dom.clientWidth; - gHeight = height || dom.height || dom.clientHeight; - gRenderer.resize(gWidth, gHeight); - }; + return function (renderable, gBufferMat, prevMaterial) { + // Material not change + if (previousRenderable && previousRenderable.material === renderable.material) { + return; + } - /** - * Dispose the application - * @function - */ - this.dispose = function () { - this._disposed = true; + var standardMaterial = renderable.material; + var program = renderable.__program; - if (appNS.dispose) { - appNS.dispose(this); + var glossiness; + var roughGlossMap; + var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS'); + var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED'); + var roughGlossChannel; + if (useRoughnessWorkflow) { + glossiness = 1.0 - standardMaterial.get('roughness'); + roughGlossMap = standardMaterial.get('roughnessMap'); + roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL'); } - gTimeline.stop(); - gRenderer.disposeScene(gScene); - gShadowPass && gShadowPass.dispose(gRenderer); - - dom.innerHTML = ''; - ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) { - this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType)); - }); - }; + else { + glossiness = standardMaterial.get('glossiness'); + roughGlossMap = standardMaterial.get('glossinessMap'); + roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL'); + } + var useRoughGlossMap = !!roughGlossMap; - gRayPicking && this._initMouseEvents(gRayPicking); + var normalMap = standardMaterial.get('normalMap') || defaultNormalMap; + var uvRepeat = standardMaterial.get('uvRepeat'); + var uvOffset = standardMaterial.get('uvOffset'); - this._geoCache = new LRU$1(20); - this._texCache = new LRU$1(20); + roughGlossMap = roughGlossMap || defaultRoughnessMap; - // Do init the application. - var initPromise = Promise.resolve(appNS.init && appNS.init(this)); - // Use the inited camera. - gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); + if (prevMaterial !== gBufferMat) { + gBufferMat.set('glossiness', glossiness); + gBufferMat.set('normalMap', normalMap); + gBufferMat.set('roughGlossMap', roughGlossMap); + gBufferMat.set('useRoughGlossMap', +useRoughGlossMap); + gBufferMat.set('useRoughness', +useRoughnessWorkflow); + gBufferMat.set('doubleSided', +doubleSided); + gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0); + gBufferMat.set('uvRepeat', uvRepeat); + gBufferMat.set('uvOffset', uvOffset); + } + else { + program.setUniform( + gl, '1f', 'glossiness', glossiness + ); - var gTexturesList = {}; - var gGeometriesList = {}; + if (previousNormalMap !== normalMap) { + attachTextureToSlot(this, program, 'normalMap', normalMap, 0); + } + if (previousRougGlossMap !== roughGlossMap) { + attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1); + } + program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap); + program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow); + program.setUniform(gl, '1i', 'doubleSided', +doubleSided); + program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0); + if (uvRepeat != null) { + program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + } + if (uvOffset != null) { + program.setUniform(gl, '2f', 'uvOffset', uvOffset); + } + } - if (!appNS.loop) { - console.warn('Miss loop method.'); - } + previousNormalMap = normalMap; + previousRougGlossMap = roughGlossMap; - var self = this; - initPromise.then(function () { - appNS.loop && gTimeline.on('frame', function (frameTime) { - gFrameTime = frameTime; - gElapsedTime += frameTime; - appNS.loop(self); + previousRenderable = renderable; + }; +} - gScene.update(); - self._updateGraphicOptions(appNS.graphic, gScene.opaqueList); - self._updateGraphicOptions(appNS.graphic, gScene.transparentList); +function getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) { + var previousDiffuseMap; + var previousRenderable; + var previousMetalnessMap; - gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); - // Render shadow pass - gShadowPass && gShadowPass.render(gRenderer, gScene, null, true); + return function (renderable, gBufferMat, prevMaterial) { + // Material not change + if (previousRenderable && previousRenderable.material === renderable.material) { + return; + } - appNS.beforeRender && appNS.beforeRender(self); - self._doRender(gRenderer, gScene, true); - appNS.afterRender && appNS.afterRender(self); + var program = renderable.__program; + var standardMaterial = renderable.material; - // Mark all resources unused; - markUnused(gTexturesList); - markUnused(gGeometriesList); + var color = standardMaterial.get('color'); + var metalness = standardMaterial.get('metalness'); - // Collect resources used in this frame. - var newTexturesList = []; - var newGeometriesList = []; - collectResources(gScene, newTexturesList, newGeometriesList); + var diffuseMap = standardMaterial.get('diffuseMap'); + var metalnessMap = standardMaterial.get('metalnessMap'); - // Dispose those unsed resources. - checkAndDispose(gRenderer, gTexturesList); - checkAndDispose(gRenderer, gGeometriesList); + var uvRepeat = standardMaterial.get('uvRepeat'); + var uvOffset = standardMaterial.get('uvOffset'); - gTexturesList = newTexturesList; - gGeometriesList = newGeometriesList; - }); - }); -} + var useMetalnessMap = !!metalnessMap; -function isImageLikeElement(val) { - return val instanceof Image - || val instanceof HTMLCanvasElement - || val instanceof HTMLVideoElement; -} + diffuseMap = diffuseMap || defaultDiffuseMap; + metalnessMap = metalnessMap || defaultMetalnessMap; -function getKeyFromImageLike(val) { - typeof val === 'string' - ? val : (val.__key__ || (val.__key__ = util$1.genGUID())); -} + if (prevMaterial !== gBufferMat) { + gBufferMat.set('color', color); + gBufferMat.set('metalness', metalness); + gBufferMat.set('diffuseMap', diffuseMap); + gBufferMat.set('metalnessMap', metalnessMap); + gBufferMat.set('useMetalnessMap', +useMetalnessMap); + gBufferMat.set('uvRepeat', uvRepeat); + gBufferMat.set('uvOffset', uvOffset); -function makeHandlerName(eveType) { - return '_' + eveType + 'Handler'; -} + gBufferMat.set('linear', +standardMaterial.linear); + } + else { + program.setUniform(gl, '1f', 'metalness', metalness); -function packageEvent(eventType, pickResult, offsetX, offsetY) { - var event = util$1.clone(pickResult); - event.type = eventType; - event.offsetX = offsetX; - event.offsetY = offsetY; - return event; -} + program.setUniform(gl, '3f', 'color', color); + if (previousDiffuseMap !== diffuseMap) { + attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0); + } + if (previousMetalnessMap !== metalnessMap) { + attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1); + } + program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap); + program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + program.setUniform(gl, '2f', 'uvOffset', uvOffset); -function bubblingEvent(target, event) { - while (target && !event.cancelBubble) { - target.trigger(event.type, event); - target = target.getParent(); - } + program.setUniform(gl, '1i', 'linear', +standardMaterial.linear); + } + + previousDiffuseMap = diffuseMap; + previousMetalnessMap = metalnessMap; + + previousRenderable = renderable; + }; } -App3D.prototype._initMouseEvents = function (rayPicking) { - var dom = this.container; +/** + * GBuffer is provided for deferred rendering and SSAO, SSR pass. + * It will do two passes rendering to three target textures. See + * + {@link clay.deferred.GBuffer#getTargetTexture1} + * + {@link clay.deferred.GBuffer#getTargetTexture2} + * + {@link clay.deferred.GBuffer#getTargetTexture3} + * @constructor + * @alias clay.deferred.GBuffer + * @extends clay.core.Base + */ +var GBuffer = Base.extend(function () { - var oldTarget = null; - ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) { - dom.addEventListener(eveType, this[makeHandlerName(eveType)] = function (e) { - if (!rayPicking.camera) { // Not have camera yet. - return; - } + return { - var box = dom.getBoundingClientRect(); - var offsetX = e.clientX - box.left; - var offsetY = e.clientY - box.top; + enableTargetTexture1: true, - var pickResult = rayPicking.pick(offsetX, offsetY); + enableTargetTexture2: true, - if (pickResult) { - // Just ignore silent element. - if (pickResult.target.silent) { - return; - } + enableTargetTexture3: true, - if (eveType === 'mousemove') { - var targetChanged = pickResult.target !== oldTarget; - if (targetChanged) { - oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', { - target: oldTarget - }, offsetX, offsetY)); - } - bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY)); - if (targetChanged) { - bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY)); - } - } - else { - bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY)); - } - oldTarget = pickResult.target; - } - else if (oldTarget) { - bubblingEvent(oldTarget, packageEvent('mouseout', { - target: oldTarget - }, offsetX, offsetY)); - oldTarget = null; + renderTransparent: false, + + _renderList: [], + // - R: normal.x + // - G: normal.y + // - B: normal.z + // - A: glossiness + _gBufferTex1: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST, + // PENDING + type: Texture.HALF_FLOAT + }), + + // - R: depth + _gBufferTex2: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST, + // format: Texture.DEPTH_COMPONENT, + // type: Texture.UNSIGNED_INT + + format: Texture.DEPTH_STENCIL, + type: Texture.UNSIGNED_INT_24_8_WEBGL + }), + + // - R: albedo.r + // - G: albedo.g + // - B: albedo.b + // - A: metalness + _gBufferTex3: new Texture2D({ + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST + }), + + _defaultNormalMap: new Texture2D({ + image: createFillCanvas('#000') + }), + _defaultRoughnessMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + _defaultMetalnessMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + _defaultDiffuseMap: new Texture2D({ + image: createFillCanvas('#fff') + }), + + _frameBuffer: new FrameBuffer(), + + _gBufferMaterial1: new Material({ + shader: new Shader( + Shader.source('clay.deferred.gbuffer.vertex'), + Shader.source('clay.deferred.gbuffer1.fragment') + ), + vertexDefines: { + FIRST_PASS: null + }, + fragmentDefines: { + FIRST_PASS: null } - }); - }, this); -}; + }), + _gBufferMaterial2: new Material({ + shader: new Shader( + Shader.source('clay.deferred.gbuffer.vertex'), + Shader.source('clay.deferred.gbuffer2.fragment') + ) + }), -App3D.prototype._updateGraphicOptions = function (graphicOpts, list) { - var enableTonemapping = !!graphicOpts.tonemapping; - var isLinearSpace = !!graphicOpts.linear; + _debugPass: new Pass({ + fragment: Shader.source('clay.deferred.gbuffer.debug') + }) + }; +}, /** @lends clay.deferred.GBuffer# */{ - var prevMaterial; + /** + * Set G Buffer size. + * @param {number} width + * @param {number} height + */ + resize: function (width, height) { + if (this._gBufferTex1.width === width + && this._gBufferTex1.height === height + ) { + return; + } + this._gBufferTex1.width = width; + this._gBufferTex1.height = height; - for (var i = 0; i < list.length; i++) { - var mat = list[i].material; - if (mat === prevMaterial) { - continue; + this._gBufferTex2.width = width; + this._gBufferTex2.height = height; + + this._gBufferTex3.width = width; + this._gBufferTex3.height = height; + }, + + // TODO is dpr needed? + setViewport: function (x, y, width, height, dpr) { + var viewport; + if (typeof x === 'object') { + viewport = x; + } + else { + viewport = { + x: x, y: y, + width: width, height: height, + devicePixelRatio: dpr || 1 + }; } + this._frameBuffer.viewport = viewport; + }, - enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING'); - if (isLinearSpace) { - mat.define('fragment', 'SRGB_ENCODE'); - mat.define('fragment', 'SRGB_DECODE'); + getViewport: function () { + if (this._frameBuffer.viewport) { + return this._frameBuffer.viewport; } else { - mat.undefine('fragment', 'SRGB_ENCODE'); - mat.undefine('fragment', 'SRGB_DECODE'); + return { + x: 0, y: 0, + width: this._gBufferTex1.width, + height: this._gBufferTex1.height, + devicePixelRatio: 1 + }; } + }, - prevMaterial = mat; - } -}; + /** + * Update G Buffer + * @param {clay.Renderer} renderer + * @param {clay.Scene} scene + * @param {clay.camera.Perspective} camera + */ + update: function (renderer, scene, camera) { -App3D.prototype._doRender = function (renderer, scene) { - var camera = scene.getMainCamera(); - camera.aspect = renderer.getViewportAspect(); - renderer.render(scene); -}; + var gl = renderer.gl; + var frameBuffer = this._frameBuffer; + var viewport = frameBuffer.viewport; + var opaqueList = scene.opaqueList; + var transparentList = scene.transparentList; -function markUnused(resourceList) { - for (var i = 0; i < resourceList.length; i++) { - resourceList[i].__used__ = 0; - } -} + var offset = 0; + var renderList = this._renderList; + for (var i = 0; i < opaqueList.length; i++) { + if (!opaqueList[i].ignoreGBuffer) { + renderList[offset++] = opaqueList[i]; + } + } + if (this.renderTransparent) { + for (var i = 0; i < transparentList.length; i++) { + if (!transparentList[i].ignoreGBuffer) { + renderList[offset++] = transparentList[i]; + } + } + } + renderList.length = offset; -function checkAndDispose(renderer, resourceList) { - for (var i = 0; i < resourceList.length; i++) { - if (!resourceList[i].__used__) { - resourceList[i].dispose(renderer); + gl.clearColor(0, 0, 0, 0); + gl.depthMask(true); + gl.colorMask(true, true, true, true); + gl.disable(gl.BLEND); + + var enableTargetTexture1 = this.enableTargetTexture1; + var enableTargetTexture2 = this.enableTargetTexture2; + var enableTargetTexture3 = this.enableTargetTexture3; + if (!enableTargetTexture1 && !enableTargetTexture3) { + console.warn('Can\'t disable targetTexture1 targetTexture3 both'); + enableTargetTexture1 = true; } - } -} -function updateUsed(resource, list) { - resource.__used__ = resource.__used__ || 0; - resource.__used__++; - if (resource.__used__ === 1) { - // Don't push to the list twice. - list.push(resource); - } -} -function collectResources(scene, textureResourceList, geometryResourceList) { - function trackQueue(queue) { - var prevMaterial; - var prevGeometry; - for (var i = 0; i < queue.length; i++) { - var renderable = queue[i]; - var geometry = renderable.geometry; - var material = renderable.material; + if (enableTargetTexture2) { + frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT); + } - // TODO optimize!! - if (material !== prevMaterial) { - var textureUniforms = material.getTextureUniforms(); - for (var u = 0; u < textureUniforms.length; u++) { - var uniformName = textureUniforms[u]; - var val = material.uniforms[uniformName].value; - if (!val) { - continue; - } - if (val instanceof Texture) { - updateUsed(val, textureResourceList); - } - else if (val instanceof Array) { - for (var k = 0; k < val.length; k++) { - if (val[k] instanceof Texture) { - updateUsed(val[k], textureResourceList); - } - } - } - } + // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow + renderer.bindSceneRendering(scene); + if (enableTargetTexture1) { + // Pass 1 + frameBuffer.attach(this._gBufferTex1); + frameBuffer.bind(renderer); + + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); } - if (geometry !== prevGeometry) { - updateUsed(geometry, geometryResourceList); + gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); } + var gBufferMaterial1 = this._gBufferMaterial1; + var passConfig = { + getMaterial: function () { + return gBufferMaterial1; + }, + beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap), + sortCompare: renderer.opaqueSortCompare + }; + // FIXME Use MRT if possible + renderer.renderPass(renderList, camera, passConfig); - prevMaterial = material; - prevGeometry = geometry; } - } + if (enableTargetTexture3) { - trackQueue(scene.opaqueList); - trackQueue(scene.transparentList); + // Pass 2 + frameBuffer.attach(this._gBufferTex3); + frameBuffer.bind(renderer); - for (var k = 0; k < scene.lights.length; k++) { - // Track AmbientCubemap - if (scene.lights[k].cubemap) { - updateUsed(scene.lights[k].cubemap, textureResourceList); + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + } + gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); + } + + var gBufferMaterial2 = this._gBufferMaterial2; + var passConfig = { + getMaterial: function () { + return gBufferMaterial2; + }, + beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap), + sortCompare: renderer.opaqueSortCompare + }; + renderer.renderPass(renderList, camera, passConfig); } - } -} -/** - * Load a texture from image or string. - * @param {ImageLike} img - * @param {Object} [opts] Texture options. - * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} - * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} - * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} - * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} - * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} - * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} - * @param {number} [opts.exposure] Only be used when source is a HDR image. - * @param {boolean} [useCache] If use cache. - * @return {Promise} - * @example - * app.loadTexture('diffuseMap.jpg') - * .then(function (texture) { - * material.set('diffuseMap', texture); - * }); - */ -App3D.prototype.loadTexture = function (urlOrImg, opts, useCache) { - var self = this; - var key = getKeyFromImageLike(urlOrImg); - if (useCache) { - if (this._texCache.get(key)) { - return this._texCache.get(key); + + renderer.bindSceneRendering(null); + frameBuffer.unbind(renderer); + }, + + renderDebug: function (renderer, camera, type, viewport) { + var debugTypes = { + normal: 0, + depth: 1, + position: 2, + glossiness: 3, + metalness: 4, + albedo: 5 + }; + if (debugTypes[type] == null) { + console.warn('Unkown type "' + type + '"'); + // Default use normal + type = 'normal'; } - } - // TODO Promise ? - var promise = new Promise(function (resolve, reject) { - var texture = self.loadTextureSync(urlOrImg, opts); - if (!texture.isRenderable()) { - texture.success(function () { - if (self._disposed) { - return; - } - resolve(texture); - }); - texture.error(function () { - if (self._disposed) { - return; - } - reject(); - }); - } - else { - resolve(texture); - } - }); - if (useCache) { - this._texCache.put(key, promise); - } - return promise; -}; -/** - * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. - * @param {ImageLike} img - * @param {Object} [opts] Texture options. - * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} - * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} - * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} - * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} - * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} - * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} - * @param {number} [opts.exposure] Only be used when source is a HDR image. - * @return {Promise} - * @example - * var texture = app.loadTexture('diffuseMap.jpg', { - * anisotropic: 8, - * flipY: false - * }); - * material.set('diffuseMap', texture); - */ -App3D.prototype.loadTextureSync = function (urlOrImg, opts) { - var texture = new Texture2D(opts); - if (typeof urlOrImg === 'string') { - if (urlOrImg.match(/.hdr$|^data:application\/octet-stream/)) { - texture = textureUtil.loadTexture(urlOrImg, { - exposure: opts && opts.exposure, - fileType: 'hdr' - }, function () { - texture.dirty(); - texture.trigger('success'); - }); - } - else { - texture.load(urlOrImg); - } - } - else if (isImageLikeElement(urlOrImg)) { - texture.image = urlOrImg; - texture.dynamic = urlOrImg instanceof HTMLVideoElement; - } - return texture; -}; + renderer.saveClear(); + renderer.saveViewport(); + renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT; -/** - * Create a material. - * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms. - * Uniforms can be `color`, `alpha` `diffuseMap` etc. - * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow. - * @param {boolean} [transparent=false] If material is transparent. - * @return {clay.Material} - */ -App3D.prototype.createMaterial = function (matConfig) { - matConfig = matConfig || {}; - matConfig.shader = matConfig.shader || 'clay.standardMR'; - var shader = matConfig.shader instanceof Shader ? matConfig.shader : library.get(matConfig.shader); - var material = new Material({ - shader: shader - }); - function makeTextureSetter(key) { - return function (texture) { - material.setUniform(key, texture); - }; - } - for (var key in matConfig) { - if (material.uniforms[key]) { - var val = matConfig[key]; - if (material.uniforms[key].type === 't' || isImageLikeElement(val)) { - // Try to load a texture. - this.loadTexture(val).then(makeTextureSetter(key)); - } - else { - material.setUniform(key, val); - } + if (viewport) { + renderer.setViewport(viewport); } - } + var viewProjectionInv = new Matrix4(); + Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - if (matConfig.transparent) { - matConfig.depthMask = false; - matConfig.transparent = true; - } - return material; -}; + var debugPass = this._debugPass; + debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]); + debugPass.setUniform('gBufferTexture1', this._gBufferTex1); + debugPass.setUniform('gBufferTexture2', this._gBufferTex2); + debugPass.setUniform('gBufferTexture3', this._gBufferTex3); + debugPass.setUniform('debug', debugTypes[type]); + debugPass.setUniform('viewProjectionInv', viewProjectionInv.array); + debugPass.render(renderer); -/** - * Create a cube mesh and add it to the scene or the given parent node. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of cube. - * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a white cube. - * app.createCube() - */ -App3D.prototype.createCube = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv, subdiv]; - } + renderer.restoreViewport(); + renderer.restoreClear(); + }, - var geoKey = 'cube-' + subdiv.join('-'); - var cube = this._geoCache.get(geoKey); - if (!cube) { - cube = new Cube$1({ - widthSegments: subdiv[0], - heightSegments: subdiv[1], - depthSegments: subdiv[2] - }); - this._geoCache.put(geoKey, cube); - } - return this.createMesh(cube, material, parentNode); -}; + /** + * Get first target texture. + * Channel storage: + * + R: normal.x * 0.5 + 0.5 + * + G: normal.y * 0.5 + 0.5 + * + B: normal.z * 0.5 + 0.5 + * + A: glossiness + * @return {clay.Texture2D} + */ + getTargetTexture1: function () { + return this._gBufferTex1; + }, -/** - * Create a cube mesh that camera is inside the cube. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of cube. - * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a white cube inside. - * app.createCubeInside() - */ -App3D.prototype.createCubeInside = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv, subdiv]; - } - var geoKey = 'cubeInside-' + subdiv.join('-'); - var cube = this._geoCache.get(geoKey); - if (!cube) { - cube = new Cube$1({ - inside: true, - widthSegments: subdiv[0], - heightSegments: subdiv[1], - depthSegments: subdiv[2] - }); - this._geoCache.put(geoKey, cube); - } + /** + * Get second target texture. + * Channel storage: + * + R: depth + * @return {clay.Texture2D} + */ + getTargetTexture2: function () { + return this._gBufferTex2; + }, - return this.createMesh(cube, material, parentNode); -}; + /** + * Get third target texture. + * Channel storage: + * + R: albedo.r + * + G: albedo.g + * + B: albedo.b + * + A: metalness + * @return {clay.Texture2D} + */ + getTargetTexture3: function () { + return this._gBufferTex3; + }, -/** - * Create a sphere mesh and add it to the scene or the given parent node. - * @function - * @param {number} [subdivision=20] Subdivision of sphere. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a semi-transparent sphere. - * app.createSphere(20, { - * color: [0, 0, 1], - * transparent: true, - * alpha: 0.5 - * }) - */ -App3D.prototype.createSphere = function (subdivision, material, parentNode) { - if (subdivision == null) { - subdivision = 20; - } - var geoKey = 'sphere-' + subdivision; - var sphere = this._geoCache.get(geoKey); - if (!sphere) { - sphere = new Sphere$1({ - widthSegments: subdivision * 2, - heightSegments: subdivision - }); - this._geoCache.put(geoKey, sphere); - } - return this.createMesh(sphere, material, parentNode); -}; -/** - * Create a plane mesh and add it to the scene or the given parent node. - * @function - * @param {Array.|number} [subdivision=1] Subdivision of plane. - * Can be a number to represent both width and height dimensions. Or an array to represent them respectively. - * @param {Object|clay.Material} [material] - * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. - * @return {clay.Mesh} - * @example - * // Create a red color plane. - * app.createPlane(1, { - * color: [1, 0, 0] - * }) - */ -App3D.prototype.createPlane = function (subdiv, material, parentNode) { - if (subdiv == null) { - subdiv = 1; - } - if (typeof subdiv === 'number') { - subdiv = [subdiv, subdiv]; - } - var geoKey = 'plane-' + subdiv.join('-'); - var planeGeo = this._geoCache.get(geoKey); - if (!planeGeo) { - planeGeo = new Plane$3({ - widthSegments: subdiv[0], - heightSegments: subdiv[1] - }); - this._geoCache.put(geoKey, planeGeo); + /** + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { } - return this.createMesh(planeGeo, material, parentNode); -}; - -/** - * Create a general mesh with given geometry instance and material config. - * @param {*} geometry - */ -App3D.prototype.createMesh = function (geometry, mat, parentNode) { - var mesh = new Mesh({ - geometry: geometry, - material: mat instanceof Material ? mat : this.createMaterial(mat) - }); - parentNode = parentNode || this.scene; - parentNode.add(mesh); - return mesh; -}; +}); -/** - * Create a perspective or orthographic camera and add it to the scene. - * @param {Array.|clay.math.Vector3} position - * @param {Array.|clay.math.Vector3} target - * @param {string} [type="perspective"] Can be 'perspective' or 'orthographic'(in short 'ortho') - * @return {clay.camera.Perspective} - */ -App3D.prototype.createCamera = function (position, target, type) { - var CameraCtor; - if (type === 'ortho' || type === 'orthographic') { - CameraCtor = Orthographic$1; - } - else { - if (type && type !== 'perspective') { - console.error('Unkown camera type ' + type + '. Use default perspective camera'); - } - CameraCtor = Perspective$1; - } +var lightvolumeGlsl = "@export clay.deferred.light_volume.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_Position;\nvoid main()\n{\n gl_Position = worldViewProjection * vec4(position, 1.0);\n v_Position = position;\n}\n@end"; - var camera = new CameraCtor(); - if (position instanceof Vector3) { - camera.position.copy(position); - } - else if (position instanceof Array) { - camera.position.setArray(position); - } +var spotGlsl = "@export clay.deferred.spot_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\n@import clay.util.calculate_attenuation\nuniform vec3 lightPosition;\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform float umbraAngleCosine;\nuniform float penumbraAngleCosine;\nuniform float lightRange;\nuniform float falloffFactor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform mat4 lightMatrix;\nuniform float lightShadowMapSize;\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n float attenuation = lightAttenuation(dist, lightRange);\n float c = dot(-normalize(lightDirection), L);\n float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrix, position, lightShadowMapSize\n );\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; - if (target instanceof Array) { - target = new Vector3(target[0], target[1], target[2]); - } - if (target instanceof Vector3) { - camera.lookAt(target); - } +var directionalGlsl = "@export clay.deferred.directional_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform float lightShadowMapSize;\nuniform mat4 lightMatrices[SHADOW_CASCADE];\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = -normalize(lightDirection);\n vec3 V = normalize(eyePosition - position);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = 1.0;\n for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\n if (\n z >= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; - this.scene.add(camera); +var ambientGlsl = "@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"; - return camera; -}; +var ambientshGlsl = "@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"; -/** - * Create a directional light and add it to the scene. - * @param {Array.|clay.math.Vector3} dir A Vector3 or array to represent the direction. - * @param {Color} [color='#fff'] Color of directional light, default to be white. - * @param {number} [intensity] Intensity of directional light, default to be 1. - * - * @example - * app.createDirectionalLight([-1, -1, -1], '#fff', 2); - */ -App3D.prototype.createDirectionalLight = function (dir, color, intensity) { - var light = new DirectionalLight(); - if (dir instanceof Vector3) { - dir = dir.array; - } - light.position.setArray(dir).negate(); - light.lookAt(Vector3.ZERO); - if (typeof color === 'string') { - color = parseColor(color); - } - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); +var ambientcubemapGlsl = "@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"; - this.scene.add(light); - return light; -}; +var pointGlsl = "@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"; -/** - * Create a spot light and add it to the scene. - * @param {Array.|clay.math.Vector3} position Position of the spot light. - * @param {Array.|clay.math.Vector3} [target] Target position where spot light points to. - * @param {number} [range=20] Falloff range of spot light. Default to be 20. - * @param {Color} [color='#fff'] Color of spot light, default to be white. - * @param {number} [intensity=1] Intensity of spot light, default to be 1. - * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line. - * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line. - * - * @example - * app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900); - */ -App3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) { - var light = new SpotLight(); - light.position.setArray(position instanceof Vector3 ? position.array : position); +var sphereGlsl = "@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"; - if (target instanceof Array) { - target = new Vector3(target[0], target[1], target[2]); - } - if (target instanceof Vector3) { - light.lookAt(target); - } +var tubeGlsl = "@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"; - if (typeof color === 'string') { - color = parseColor(color); - } - range != null && (light.range = range); - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); - umbraAngle != null && (light.umbraAngle = umbraAngle); - penumbraAngle != null && (light.penumbraAngle = penumbraAngle); +// Light-pre pass deferred rendering +// http://www.realtimerendering.com/blog/deferred-lighting-approaches/ +// Light shaders +Shader.import(prezGlsl); +Shader.import(utilGlsl); +Shader.import(lightvolumeGlsl); - this.scene.add(light); +// Light shaders +Shader.import(spotGlsl); +Shader.import(directionalGlsl); +Shader.import(ambientGlsl); +Shader.import(ambientshGlsl); +Shader.import(ambientcubemapGlsl); +Shader.import(pointGlsl); +Shader.import(sphereGlsl); +Shader.import(tubeGlsl); - return light; -}; +Shader.import(prezGlsl); /** - * Create a point light. - * @param {Array.|clay.math.Vector3} position Position of point light.. - * @param {number} [range=100] Falloff range of point light. - * @param {Color} [color='#fff'] Color of point light. - * @param {number} [intensity=1] Intensity of point light. + * Deferred renderer + * @constructor + * @alias clay.deferred.Renderer + * @extends clay.core.Base */ -App3D.prototype.createPointLight = function (position, range, color, intensity) { - var light = new PointLight(); - light.position.setArray(position instanceof Vector3 ? position.array : position); +var DeferredRenderer = Base.extend(function () { - if (typeof color === 'string') { - color = parseColor(color); - } - range != null && (light.range = range); - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); + var fullQuadVertex = Shader.source('clay.compositor.vertex'); + var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex'); - this.scene.add(light); + var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light')); - return light; -}; + var lightAccumulateBlendFunc = function (gl) { + gl.blendEquation(gl.FUNC_ADD); + gl.blendFunc(gl.ONE, gl.ONE); + }; -/** - * Create a ambient light. - * @param {Color} [color='#fff'] Color of ambient light. - * @param {number} [intensity=1] Intensity of ambient light. - */ -App3D.prototype.createAmbientLight = function (color, intensity) { - var light = new AmbientLight(); + var createLightPassMat = function (shader) { + return new Material({ + shader: shader, + blend: lightAccumulateBlendFunc, + transparent: true, + depthMask: false + }); + }; - if (typeof color === 'string') { - color = parseColor(color); - } - color != null && (light.color = color); - intensity != null && (light.intensity = intensity); + var createVolumeShader = function (name) { + return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name)); + }; - this.scene.add(light); + // Rotate and positioning to fit the spot light + // Which the cusp of cone pointing to the positive z + // and positioned on the origin + var coneGeo = new Cone$1({ + capSegments: 10 + }); + var mat = new Matrix4(); + mat.rotateX(Math.PI / 2) + .translate(new Vector3(0, -1, 0)); - return light; -}; + coneGeo.applyTransform(mat); -/** - * Create an cubemap ambient light and an spherical harmonic ambient light - * for specular and diffuse lighting in PBR rendering - * @param {ImageLike} [envImage] Panorama environment image, HDR format is better. - * @param {number} [specularIntenstity=0.7] Intensity of specular light. - * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light. - * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR. - * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering. - */ -App3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) { - var self = this; - if (exposure == null) { - exposure = 1; - } - if (prefilteredCubemapSize == null) { - prefilteredCubemapSize = 32; - } + var cylinderGeo = new Cylinder$1({ + capSegments: 10 + }); + // Align with x axis + mat.identity().rotateZ(Math.PI / 2); + cylinderGeo.applyTransform(mat); - var scene = this.scene; + return /** @lends clay.deferred.Renderer# */ { - return this.loadTexture(envImage, { - exposure: exposure - }).then(function (envTexture) { - var specLight = new AmbientCubemapLight({ - intensity: specIntensity != null ? specIntensity : 0.7 - }); - specLight.cubemap = envTexture; - envTexture.flipY = false; - // TODO Cache prefilter ? - specLight.prefilter(self.renderer, 32); + /** + * Provide ShadowMapPass for shadow rendering. + * @type {clay.prePass.ShadowMap} + */ + shadowMapPass: null, + /** + * If enable auto resizing from given defualt renderer size. + * @type {boolean} + */ + autoResize: true, - var diffLight = new AmbientSHLight({ - intensity: diffIntensity != null ? diffIntensity : 0.7, - coefficients: sh.projectEnvironmentMap( - self.renderer, specLight.cubemap, { - lod: 1 - } - ) - }); - scene.add(specLight); - scene.add(diffLight); + _createLightPassMat: createLightPassMat, - return { - specular: specLight, - diffuse: diffLight, - // Original environment map - environmentMap: envTexture - }; - }); -}; + _gBuffer: new GBuffer(), -/** - * Load a [glTF](https://github.com/KhronosGroup/glTF) format model. - * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script, - * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application. - * @param {string} url - * @param {Object} opts - * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'. - * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded. - * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model. - * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z' - * @param {boolean} [opts.textureFlipY=false] - * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file. - * @return {Promise} - */ -App3D.prototype.loadModel = function (url, opts) { - if (typeof url !== 'string') { - throw new Error('Invalid URL.'); - } + _lightAccumFrameBuffer: new FrameBuffer({ + depthBuffer: false + }), - opts = opts || {}; - if (opts.autoPlayAnimation == null) { - opts.autoPlayAnimation = true; - } - var shader = opts.shader || 'clay.standard'; + _lightAccumTex: new Texture2D({ + // FIXME Device not support float texture + type: Texture.HALF_FLOAT, + minFilter: Texture.NEAREST, + magFilter: Texture.NEAREST + }), - var loaderOpts = { - rootNode: new Node(), - shader: shader, - textureRootPath: opts.textureRootPath, - crossOrigin: 'Anonymous', - textureFlipY: opts.textureFlipY - }; - if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') { - loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2); - } + _fullQuadPass: new Pass({ + blendWithPrevious: true + }), - var loader = new GLTFLoader(loaderOpts); + _directionalLightMat: createLightPassMat(directionalLightShader), - var scene = this.scene; - var timeline = this.timeline; - var self = this; + _ambientMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_light') + )), + _ambientSHMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light') + )), + _ambientCubemapMat: createLightPassMat(new Shader( + fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light') + )), - return new Promise(function (resolve, reject) { - function afterLoad(result) { - if (self._disposed) { - return; - } + _spotLightShader: createVolumeShader('spot_light'), + _pointLightShader: createVolumeShader('point_light'), - scene.add(result.rootNode); - if (opts.autoPlayAnimation) { - result.clips.forEach(function (clip) { - timeline.addClip(clip); - }); - } - resolve(result); - } - loader.success(function (result) { - if (self._disposed) { - return; - } + _sphereLightShader: createVolumeShader('sphere_light'), + _tubeLightShader: createVolumeShader('tube_light'), - if (!opts.waitTextureLoaded) { - afterLoad(result); - } - else { - Promise.all(result.textures.map(function (texture) { - if (texture.isRenderable()) { - return Promise.resolve(texture); - } - return new Promise(function (resolve) { - texture.success(resolve); - texture.error(resolve); - }); - })).then(function () { - afterLoad(result); - }).catch(function () { - afterLoad(result); - }); - } - }); - loader.error(function () { - reject(); - }); - loader.load(url); - }); -}; + _lightSphereGeo: new Sphere$1({ + widthSegments: 10, + heightSegements: 10 + }), + _lightConeGeo: coneGeo, -var application = { - App3D: App3D, + _lightCylinderGeo: cylinderGeo, + + _outputPass: new Pass({ + fragment: Shader.source('clay.compositor.output') + }) + }; +}, /** @lends clay.deferred.Renderer# */ { /** - * Create a 3D application that will manage the app initialization and loop. - * @name clay.application.create - * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector` - * @param {Object} appNS - * @param {Function} init Initialization callback that will be called when initing app. - * @param {Function} loop Loop callback that will be called each frame. - * @param {number} [width] Container width. - * @param {number} [height] Container height. - * @param {number} [devicePixelRatio] - * @return {clay.application.App3D} - * - * @example - * clay.application.create('#app', { - * init: function (app) { - * app.createCube(); - * var camera = app.createCamera(); - * camera.position.set(0, 0, 2); - * }, - * loop: function () { // noop } - * }) + * Do render + * @param {clay.Renderer} renderer + * @param {clay.Scene} scene + * @param {clay.Camera} camera + * @param {Object} [opts] + * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture + * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow. + * @param {boolean} [opts.notUpdateScene = true] If not update the scene. */ - create: function (dom, appNS) { - return new App3D(dom, appNS); - } -}; - -/** - * @constructor - * @alias clay.async.Task - * @mixes clay.core.mixin.notifier - */ -var Task = function() { - this._fullfilled = false; - this._rejected = false; -}; -/** - * Task successed - * @param {} data - */ -Task.prototype.resolve = function(data) { - this._fullfilled = true; - this._rejected = false; - this.trigger('success', data); -}; -/** - * Task failed - * @param {} err - */ -Task.prototype.reject = function(err) { - this._rejected = true; - this._fullfilled = false; - this.trigger('error', err); -}; -/** - * If task successed - * @return {boolean} - */ -Task.prototype.isFullfilled = function() { - return this._fullfilled; -}; -/** - * If task failed - * @return {boolean} - */ -Task.prototype.isRejected = function() { - return this._rejected; -}; -/** - * If task finished, either successed or failed - * @return {boolean} - */ -Task.prototype.isSettled = function() { - return this._fullfilled || this._rejected; -}; + render: function (renderer, scene, camera, opts) { -util$1.extend(Task.prototype, notifier); + opts = opts || {}; + opts.renderToTarget = opts.renderToTarget || false; + opts.notUpdateShadow = opts.notUpdateShadow || false; + opts.notUpdateScene = opts.notUpdateScene || false; -function makeRequestTask(url, responseType) { - var task = new Task(); - request.get({ - url: url, - responseType: responseType, - onload: function(res) { - task.resolve(res); - }, - onerror: function(error) { - task.reject(error); + if (!opts.notUpdateScene) { + scene.update(false, true); } - }); - return task; -} -/** - * Make a request task - * @param {string|object|object[]|string[]} url - * @param {string} [responseType] - * @example - * var task = Task.makeRequestTask('./a.json'); - * var task = Task.makeRequestTask({ - * url: 'b.bin', - * responseType: 'arraybuffer' - * }); - * var tasks = Task.makeRequestTask(['./a.json', './b.json']); - * var tasks = Task.makeRequestTask([ - * {url: 'a.json'}, - * {url: 'b.bin', responseType: 'arraybuffer'} - * ]); - * @return {clay.async.Task|clay.async.Task[]} - */ -Task.makeRequestTask = function(url, responseType) { - if (typeof url === 'string') { - return makeRequestTask(url, responseType); - } else if (url.url) { // Configure object - var obj = url; - return makeRequestTask(obj.url, obj.responseType); - } else if (Array.isArray(url)) { // Url list - var urlList = url; - var tasks = []; - urlList.forEach(function(obj) { - var url, responseType; - if (typeof obj === 'string') { - url = obj; - } else if (Object(obj) === obj) { - url = obj.url; - responseType = obj.responseType; - } - tasks.push(makeRequestTask(url, responseType)); - }); - return tasks; - } -}; -/** - * @return {clay.async.Task} - */ -Task.makeTask = function() { - return new Task(); -}; -util$1.extend(Task.prototype, notifier); + camera.update(true); -/** - * @constructor - * @alias clay.async.TaskGroup - * @extends clay.async.Task - */ -var TaskGroup = function () { + // PENDING For stereo rendering + var dpr = renderer.getDevicePixelRatio(); + if (this.autoResize + && (renderer.getWidth() * dpr !== this._lightAccumTex.width + || renderer.getHeight() * dpr !== this._lightAccumTex.height) + ) { + this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr); + } - Task.apply(this, arguments); + this._gBuffer.update(renderer, scene, camera); - this._tasks = []; + // Accumulate light buffer + this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow); - this._fulfilledNumber = 0; + if (!opts.renderToTarget) { + this._outputPass.setUniform('texture', this._lightAccumTex); - this._rejectedNumber = 0; -}; + this._outputPass.render(renderer); + // this._gBuffer.renderDebug(renderer, camera, 'normal'); + } + }, -var Ctor = function (){}; -Ctor.prototype = Task.prototype; -TaskGroup.prototype = new Ctor(); + /** + * @return {clay.Texture2D} + */ + getTargetTexture: function () { + return this._lightAccumTex; + }, -TaskGroup.prototype.constructor = TaskGroup; + /** + * @return {clay.FrameBuffer} + */ + getTargetFrameBuffer: function () { + return this._lightAccumFrameBuffer; + }, -/** - * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}. - * @param {Array.} tasks - * @chainable - * @example - * // Load texture list - * var list = ['a.jpg', 'b.jpg', 'c.jpg'] - * var textures = list.map(function (src) { - * var texture = new clay.Texture2D(); - * texture.load(src); - * return texture; - * }); - * var taskGroup = new clay.async.TaskGroup(); - * taskGroup.all(textures).success(function () { - * // Do some thing after all textures loaded - * }); - */ -TaskGroup.prototype.all = function (tasks) { - var count = 0; - var self = this; - var data = []; - this._tasks = tasks; - this._fulfilledNumber = 0; - this._rejectedNumber = 0; + /** + * @return {clay.deferred.GBuffer} + */ + getGBuffer: function () { + return this._gBuffer; + }, - util$1.each(tasks, function (task, idx) { - if (!task || !task.once) { - return; - } - count++; - task.once('success', function (res) { - count--; + // TODO is dpr needed? + setViewport: function (x, y, width, height, dpr) { + this._gBuffer.setViewport(x, y, width, height, dpr); + this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport(); + }, - self._fulfilledNumber++; - // TODO - // Some tasks like texture, loader are not inherited from task - // We need to set the states here - task._fulfilled = true; - task._rejected = false; + // getFullQuadLightPass: function () { + // return this._fullQuadPass; + // }, - data[idx] = res; - if (count === 0) { - self.resolve(data); - } - }); - task.once('error', function () { + /** + * Set renderer size. + * @param {number} width + * @param {number} height + */ + resize: function (width, height) { + this._lightAccumTex.width = width; + this._lightAccumTex.height = height; - self._rejectedNumber ++; + // PENDING viewport ? + this._gBuffer.resize(width, height); + }, - task._fulfilled = false; - task._rejected = true; + _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) { + var gl = renderer.gl; + var lightAccumTex = this._lightAccumTex; + var lightAccumFrameBuffer = this._lightAccumFrameBuffer; - self.reject(task); - }); - }); - if (count === 0) { - setTimeout(function () { - self.resolve(data); - }); - return this; - } - return this; -}; -/** - * Wait for all given tasks finished, either successed or failed - * @param {Array.} tasks - * @return {clay.async.TaskGroup} - */ -TaskGroup.prototype.allSettled = function (tasks) { - var count = 0; - var self = this; - var data = []; - if (tasks.length === 0) { - setTimeout(function () { - self.trigger('success', data); - }); - return this; - } - this._tasks = tasks; + var eyePosition = camera.getWorldPosition().array; - util$1.each(tasks, function (task, idx) { - if (!task || !task.once) { - return; + // Update volume meshes + for (var i = 0; i < scene.lights.length; i++) { + this._updateLightProxy(scene.lights[i]); } - count++; - task.once('success', function (res) { - count--; - self._fulfilledNumber++; + var shadowMapPass = this.shadowMapPass; + if (shadowMapPass && updateShadow) { + gl.clearColor(1, 1, 1, 1); + this._prepareLightShadow(renderer, scene, camera); + } - task._fulfilled = true; - task._rejected = false; + this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow); - data[idx] = res; - if (count === 0) { - self.resolve(data); - } - }); - task.once('error', function (err) { - count--; + lightAccumFrameBuffer.attach(lightAccumTex); + lightAccumFrameBuffer.bind(renderer); + var clearColor = renderer.clearColor; - self._rejectedNumber++; + var viewport = lightAccumFrameBuffer.viewport; + if (viewport) { + var dpr = viewport.devicePixelRatio; + // use scissor to make sure only clear the viewport + gl.enable(gl.SCISSOR_TEST); + gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + } + gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]); + gl.clear(gl.COLOR_BUFFER_BIT); + gl.enable(gl.BLEND); + if (viewport) { + gl.disable(gl.SCISSOR_TEST); + } - task._fulfilled = false; - task._rejected = true; + this.trigger('startlightaccumulate', renderer, scene, camera); - // TODO - data[idx] = null; - if (count === 0) { - self.resolve(data); - } - }); - }); - return this; -}; -/** - * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getFulfilledNumber = function (recursive) { - if (recursive) { - var nFulfilled = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nFulfilled += task.getFulfilledNumber(recursive); - } else if(task._fulfilled) { - nFulfilled += 1; - } - } - return nFulfilled; - } else { - return this._fulfilledNumber; - } -}; + var viewProjectionInv = new Matrix4(); + Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); -/** - * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getRejectedNumber = function (recursive) { - if (recursive) { - var nRejected = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nRejected += task.getRejectedNumber(recursive); - } else if(task._rejected) { - nRejected += 1; - } - } - return nRejected; - } else { - return this._rejectedNumber; - } -}; + var volumeMeshList = []; -/** - * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getSettledNumber = function (recursive) { + for (var i = 0; i < scene.lights.length; i++) { + var light = scene.lights[i]; + var uTpl = light.uniformTemplates; - if (recursive) { - var nSettled = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nSettled += task.getSettledNumber(recursive); - } else if(task._rejected || task._fulfilled) { - nSettled += 1; - } - } - return nSettled; - } else { - return this._fulfilledNumber + this._rejectedNumber; - } -}; + var volumeMesh = light.volumeMesh || light.__volumeMesh; -/** - * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup. - * @param {boolean} [recursive] - * @return {number} - */ -TaskGroup.prototype.getTaskNumber = function (recursive) { - if (recursive) { - var nTask = 0; - for (var i = 0; i < this._tasks.length; i++) { - var task = this._tasks[i]; - if (task instanceof TaskGroup) { - nTask += task.getTaskNumber(recursive); - } else { - nTask += 1; - } - } - return nTask; - } else { - return this._tasks.length; - } -}; + if (volumeMesh) { + var material = volumeMesh.material; + // Volume mesh will affect the scene bounding box when rendering + // if castShadow is true + volumeMesh.castShadow = false; -var CanvasMaterial = Base.extend({ + var unknownLightType = false; + switch (light.type) { + case 'POINT_LIGHT': + material.setUniform('lightColor', uTpl.pointLightColor.value(light)); + material.setUniform('lightRange', uTpl.pointLightRange.value(light)); + material.setUniform('lightPosition', uTpl.pointLightPosition.value(light)); + break; + case 'SPOT_LIGHT': + material.setUniform('lightPosition', uTpl.spotLightPosition.value(light)); + material.setUniform('lightColor', uTpl.spotLightColor.value(light)); + material.setUniform('lightRange', uTpl.spotLightRange.value(light)); + material.setUniform('lightDirection', uTpl.spotLightDirection.value(light)); + material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light)); + material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light)); + material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light)); + break; + case 'SPHERE_LIGHT': + material.setUniform('lightColor', uTpl.sphereLightColor.value(light)); + material.setUniform('lightRange', uTpl.sphereLightRange.value(light)); + material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light)); + material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light)); + break; + case 'TUBE_LIGHT': + material.setUniform('lightColor', uTpl.tubeLightColor.value(light)); + material.setUniform('lightRange', uTpl.tubeLightRange.value(light)); + material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light)); + material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light)); + break; + default: + unknownLightType = true; + } - color: [1, 1, 1, 1], + if (unknownLightType) { + continue; + } - opacity: 1, + material.setUniform('eyePosition', eyePosition); + material.setUniform('viewProjectionInv', viewProjectionInv.array); + material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); + material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); + material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - pointSize: 0, + volumeMeshList.push(volumeMesh); - pointShape: 'rectangle' -}); + } + else { + var pass = this._fullQuadPass; + var unknownLightType = false; + // Full quad light + switch (light.type) { + case 'AMBIENT_LIGHT': + pass.material = this._ambientMat; + pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light)); + break; + case 'AMBIENT_SH_LIGHT': + pass.material = this._ambientSHMat; + pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light)); + pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light)); + break; + case 'AMBIENT_CUBEMAP_LIGHT': + pass.material = this._ambientCubemapMat; + pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light)); + pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light)); + pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light)); + break; + case 'DIRECTIONAL_LIGHT': + var hasShadow = shadowMapPass && light.castShadow; + pass.material = this._directionalLightMat; + pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + if (hasShadow) { + pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade); + } + pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light)); + pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light)); + break; + default: + // Unkonw light type + unknownLightType = true; + } + if (unknownLightType) { + continue; + } -var mat4$8 = glmatrix.mat4; -var vec3$16 = glmatrix.vec3; -var vec4$2 = glmatrix.vec4; + var passMaterial = pass.material; + passMaterial.setUniform('eyePosition', eyePosition); + passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array); + passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); + passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); + passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); -var vec4Create = vec4$2.create; + // TODO + if (shadowMapPass && light.castShadow) { + passMaterial.setUniform('lightShadowMap', light.__shadowMap); + passMaterial.setUniform('lightMatrices', light.__lightMatrices); + passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear); + passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar); -var round = Math.round; + passMaterial.setUniform('lightShadowMapSize', light.shadowResolution); + } -var PRIMITIVE_TRIANGLE = 1; -var PRIMITIVE_LINE = 2; -var PRIMITIVE_POINT = 3; + pass.renderQuad(renderer); + } + } -function PrimitivePool(constructor) { - this.ctor = constructor; + this._renderVolumeMeshList(renderer, camera, volumeMeshList); - this._data = []; + this.trigger('lightaccumulate', renderer, scene, camera); - this._size = 0; -} + lightAccumFrameBuffer.unbind(renderer); -PrimitivePool.prototype = { - pick: function () { - var data = this._data; - var size = this._size; - var obj = data[size]; - if (! obj) { - // Constructor must have no parameters - obj = new this.ctor(); - data[size] = obj; - } - this._size++; - return obj; - }, + this.trigger('afterlightaccumulate', renderer, scene, camera); - reset: function () { - this._size = 0; }, - shrink: function () { - this._data.length = this._size; - }, + _prepareLightShadow: (function () { + var worldView = new Matrix4(); + return function (renderer, scene, camera) { + var shadowCasters; - clear: function () { - this._data = []; - this._size = 0; - } -}; + shadowCasters = this._shadowCasters || (this._shadowCasters = []); + var count = 0; + var list = scene.opaqueList; + for (var i = 0; i < list.length; i++) { + if (list[i].castShadow) { + shadowCasters[count++] = list[i]; + } + } + shadowCasters.length = count; -function Triangle() { - this.vertices = [vec4Create(), vec4Create(), vec4Create()]; - this.color = vec4Create(); + for (var i = 0; i < scene.lights.length; i++) { + var light = scene.lights[i]; + var volumeMesh = light.volumeMesh || light.__volumeMesh; + if (!light.castShadow) { + continue; + } - this.depth = 0; -} + switch (light.type) { + case 'POINT_LIGHT': + case 'SPOT_LIGHT': + // Frustum culling + Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); + if (renderer.isFrustumCulled( + volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array + )) { + continue; + } -Triangle.prototype.type = PRIMITIVE_TRIANGLE; + this._prepareSingleLightShadow( + renderer, scene, camera, light, shadowCasters, volumeMesh.material + ); + break; + case 'DIRECTIONAL_LIGHT': + this._prepareSingleLightShadow( + renderer, scene, camera, light, shadowCasters, null + ); + } + } + }; + })(), -function Point() { - // Here use an array to make it more convinient to proccessing in _setPrimitive method - this.vertices = [vec4Create()]; + _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) { + switch (light.type) { + case 'POINT_LIGHT': + var shadowMaps = []; + this.shadowMapPass.renderPointLightShadow( + renderer, scene, light, casters, shadowMaps + ); + material.setUniform('lightShadowMap', shadowMaps[0]); + material.setUniform('lightShadowMapSize', light.shadowResolution); + break; + case 'SPOT_LIGHT': + var shadowMaps = []; + var lightMatrices = []; + this.shadowMapPass.renderSpotLightShadow( + renderer, scene, light, casters, lightMatrices, shadowMaps + ); + material.setUniform('lightShadowMap', shadowMaps[0]); + material.setUniform('lightMatrix', lightMatrices[0]); + material.setUniform('lightShadowMapSize', light.shadowResolution); + break; + case 'DIRECTIONAL_LIGHT': + var shadowMaps = []; + var lightMatrices = []; + var cascadeClips = []; + this.shadowMapPass.renderDirectionalLightShadow( + renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps + ); + var cascadeClipsNear = cascadeClips.slice(); + var cascadeClipsFar = cascadeClips.slice(); + cascadeClipsNear.pop(); + cascadeClipsFar.shift(); - this.color = vec4Create(); + // Iterate from far to near + cascadeClipsNear.reverse(); + cascadeClipsFar.reverse(); + lightMatrices.reverse(); - this.depth = 0; -} + light.__cascadeClipsNear = cascadeClipsNear; + light.__cascadeClipsFar = cascadeClipsFar; + light.__shadowMap = shadowMaps[0]; + light.__lightMatrices = lightMatrices; + break; + } + }, -Point.prototype.type = PRIMITIVE_POINT; + // Update light volume mesh + // Light volume mesh is rendered in light accumulate pass instead of full quad. + // It will reduce pixels significantly when local light is relatively small. + // And we can use custom volume mesh to shape the light. + // + // See "Deferred Shading Optimizations" in GDC2011 + _updateLightProxy: function (light) { + var volumeMesh; + if (light.volumeMesh) { + volumeMesh = light.volumeMesh; + } + else { + switch (light.type) { + // Only local light (point and spot) needs volume mesh. + // Directional and ambient light renders in full quad + case 'POINT_LIGHT': + case 'SPHERE_LIGHT': + var shader = light.type === 'SPHERE_LIGHT' + ? this._sphereLightShader : this._pointLightShader; + // Volume mesh created automatically + if (!light.__volumeMesh) { + light.__volumeMesh = new Mesh({ + material: this._createLightPassMat(shader), + geometry: this._lightSphereGeo, + // Disable culling + // if light volume mesh intersect camera near plane + // We need mesh inside can still be rendered + culling: false + }); + } + volumeMesh = light.__volumeMesh; + var r = light.range + (light.radius || 0); + volumeMesh.scale.set(r, r, r); + break; + case 'SPOT_LIGHT': + light.__volumeMesh = light.__volumeMesh || new Mesh({ + material: this._createLightPassMat(this._spotLightShader), + geometry: this._lightConeGeo, + culling: false + }); + volumeMesh = light.__volumeMesh; + var aspect = Math.tan(light.penumbraAngle * Math.PI / 180); + var range = light.range; + volumeMesh.scale.set(aspect * range, aspect * range, range / 2); + break; + case 'TUBE_LIGHT': + light.__volumeMesh = light.__volumeMesh || new Mesh({ + material: this._createLightPassMat(this._tubeLightShader), + geometry: this._lightCylinderGeo, + culling: false + }); + volumeMesh = light.__volumeMesh; + var range = light.range; + volumeMesh.scale.set(light.length / 2 + range, range, range); + break; + } + } + if (volumeMesh) { + volumeMesh.update(); + // Apply light transform + Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform); + var hasShadow = this.shadowMapPass && light.castShadow; + volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + } + }, -function Line() { - this.vertices = [vec4Create(), vec4Create()]; - this.color = vec4Create(); + _renderVolumeMeshList: (function () { + var worldViewProjection = new Matrix4(); + var worldView = new Matrix4(); + var preZMaterial = new Material({ + shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment')) + }); + return function (renderer, camera, volumeMeshList) { + var gl = renderer.gl; - this.depth = 0; + gl.enable(gl.DEPTH_TEST); + gl.disable(gl.CULL_FACE); + gl.blendEquation(gl.FUNC_ADD); + gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE); + gl.depthFunc(gl.LEQUAL); - this.lineWidth = 1; -} + gl.clear(gl.DEPTH_BUFFER_BIT); -Line.prototype.type = PRIMITIVE_LINE; + var viewport = renderer.viewport; + var dpr = viewport.devicePixelRatio; + var viewportUniform = [ + viewport.x * dpr, viewport.y * dpr, + viewport.width * dpr, viewport.height * dpr + ]; -function depthSortFunc(x, y) { - // Sort from far to near, which in depth of projection space is from larger to smaller - return y.depth - x.depth; -} + var windowSizeUniform = [ + this._lightAccumTex.width, + this._lightAccumTex.height + ]; -function vec3ToColorStr(v3) { - return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')'; -} + for (var i = 0; i < volumeMeshList.length; i++) { + var volumeMesh = volumeMeshList[i]; -function vec4ToColorStr(v4) { - return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')'; -} + // Frustum culling + Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); + if (renderer.isFrustumCulled( + volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array + )) { + continue; + } -var CanvasRenderer = Base.extend({ + // Use prez to avoid one pixel rendered twice + gl.colorMask(false, false, false, false); + gl.depthMask(true); + // depthMask must be enabled before clear DEPTH_BUFFER + gl.clear(gl.DEPTH_BUFFER_BIT); - canvas: null, + Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView); - _width: 100, + var preZProgram = renderer.getProgram(volumeMesh, preZMaterial); + volumeMesh.__program = preZProgram; + renderer.validateProgram(preZProgram); + preZProgram.bind(renderer); - _height: 100, + var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION; + preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); + volumeMesh.render(renderer, preZMaterial, preZProgram); - devicePixelRatio: window.devicePixelRatio || 1.0, + // Render light + gl.colorMask(true, true, true, true); + gl.depthMask(false); + var program = renderer.getProgram(volumeMesh, volumeMesh.material); + volumeMesh.__program = program; + renderer.validateProgram(program); + program.bind(renderer); - color: [0.0, 0.0, 0.0, 0.0], + var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION; + // Set some common uniforms + program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); + program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform); + program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform); - clear: true, + volumeMesh.material.bind(renderer, program); + volumeMesh.render(renderer, volumeMesh.material, program); + } - ctx: null, + gl.depthFunc(gl.LESS); + }; + })(), - // Cached primitive list, including triangle, line, point - _primitives: [], + /** + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { + this._gBuffer.dispose(renderer); - // Triangle pool - _triangles: new PrimitivePool(Triangle), + this._lightAccumFrameBuffer.dispose(renderer); + this._lightAccumTex.dispose(renderer); - // Line pool - _lines: new PrimitivePool(Line), + this._lightConeGeo.dispose(renderer); + this._lightCylinderGeo.dispose(renderer); + this._lightSphereGeo.dispose(renderer); - // Point pool - _points: new PrimitivePool(Point) -}, function () { - if (! this.canvas) { - this.canvas = document.createElement('canvas'); - } - var canvas = this.canvas; + this._fullQuadPass.dispose(renderer); + this._outputPass.dispose(renderer); - try { - this.ctx = canvas.getContext('2d'); - var ctx = this.ctx; - if (!ctx) { - throw new Error(); - } - } - catch (e) { - throw 'Error creating WebGL Context ' + e; + this._directionalLightMat.dispose(renderer); + + this.shadowMapPass.dispose(renderer); } +}); - this.resize(); -}, { +// Spherical Harmonic Helpers +var vec3$16 = glmatrix.vec3; +var sh = {}; - resize: function (width, height) { - var dpr = this.devicePixelRatio; - var canvas = this.canvas; - if (width != null) { - canvas.style.width = width + 'px'; - canvas.style.height = height + 'px'; - canvas.width = width * dpr; - canvas.height = height * dpr; +var targets$3 = ['px', 'nx', 'py', 'ny', 'pz', 'nz']; - this._width = width; - this._height = height; - } - else { - this._width = canvas.width / dpr; - this._height = canvas.height / dpr; - } - }, +function harmonics(normal, index){ + var x = normal[0]; + var y = normal[1]; + var z = normal[2]; - getWidth: function () { - return this._width; - }, + if (index === 0) { + return 1.0; + } + else if (index === 1) { + return x; + } + else if (index === 2) { + return y; + } + else if (index === 3) { + return z; + } + else if (index === 4) { + return x * z; + } + else if (index === 5) { + return y * z; + } + else if (index === 6) { + return x * y; + } + else if (index === 7) { + return 3.0 * z * z - 1.0; + } + else { + return x * x - y * y; + } +} - getHeight: function () { - return this._height; - }, +var normalTransform = { + px: [2, 1, 0, -1, -1, 1], + nx: [2, 1, 0, 1, -1, -1], + py: [0, 2, 1, 1, -1, -1], + ny: [0, 2, 1, 1, 1, 1], + pz: [0, 1, 2, -1, -1, -1], + nz: [0, 1, 2, 1, -1, 1] +}; - getViewportAspect: function () { - return this._width / this._height; - }, +// Project on cpu. +function projectEnvironmentMapCPU(renderer, cubePixels, width, height) { + var coeff = new vendor.Float32Array(9 * 3); + var normal = vec3$16.create(); + var texel = vec3$16.create(); + var fetchNormal = vec3$16.create(); + for (var m = 0; m < 9; m++) { + var result = vec3$16.create(); + for (var k = 0; k < targets$3.length; k++) { + var pixels = cubePixels[targets$3[k]]; - render: function (scene, camera) { + var sideResult = vec3$16.create(); + var divider = 0; + var i = 0; + var transform = normalTransform[targets$3[k]]; + for (var y = 0; y < height; y++) { + for (var x = 0; x < width; x++) { - if (this.clear) { - var color = this.color; - var ctx = this.ctx; - var dpr = this.devicePixelRatio; - var w = this._width * dpr; - var h = this._height * dpr; - if (color && color[3] === 0) { - ctx.clearRect(0, 0, w, h); - } - else { - // Has transparency - if (color[3] < 1) { - ctx.clearRect(0, 0, w, h); + normal[0] = x / (width - 1.0) * 2.0 - 1.0; + // TODO Flip y? + normal[1] = y / (height - 1.0) * 2.0 - 1.0; + normal[2] = -1.0; + vec3$16.normalize(normal, normal); + + fetchNormal[0] = normal[transform[0]] * transform[3]; + fetchNormal[1] = normal[transform[1]] * transform[4]; + fetchNormal[2] = normal[transform[2]] * transform[5]; + + texel[0] = pixels[i++] / 255; + texel[1] = pixels[i++] / 255; + texel[2] = pixels[i++] / 255; + // RGBM Decode + var scale = pixels[i++] / 255 * 51.5; + texel[0] *= scale; + texel[1] *= scale; + texel[2] *= scale; + + vec3$16.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]); + // -normal.z equals cos(theta) of Lambertian + divider += -normal[2]; } - ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color); - ctx.fillRect(0, 0, w, h); } + vec3$16.scaleAndAdd(result, result, sideResult, 1 / divider); } - scene.update(); - camera.update(); + coeff[m * 3] = result[0] / 6.0; + coeff[m * 3 + 1] = result[1] / 6.0; + coeff[m * 3 + 2] = result[2] / 6.0; + } + return coeff; +} - var opaqueList = scene.opaqueList; - var transparentList = scene.transparentList; - var list = opaqueList.concat(transparentList); +/** + * @param {clay.Renderer} renderer + * @param {clay.Texture} envMap + * @param {Object} [textureOpts] + * @param {Object} [textureOpts.lod] + * @param {boolean} [textureOpts.decodeRGBM] + */ +sh.projectEnvironmentMap = function (renderer, envMap, opts) { - this.renderPass(list, camera); - }, + // TODO sRGB - renderPass: function (list, camera) { - var viewProj = mat4$8.create(); - mat4$8.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array); - var worldViewProjMat = mat4$8.create(); - var posViewSpace = vec3$16.create(); + opts = opts || {}; + opts.lod = opts.lod || 0; - var primitives = this._primitives; - var trianglesPool = this._triangles; - var linesPool = this._lines; - var pointsPool = this._points; + var skybox; + var dummyScene = new Scene(); + var size = 64; + if (envMap instanceof Texture2D) { + skybox = new Skydome({ + scene: dummyScene, + environmentMap: envMap + }); + } + else { + size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width; + skybox = new Skybox({ + scene: dummyScene, + environmentMap: envMap + }); + } + // Convert to rgbm + var width = Math.ceil(size / Math.pow(2, opts.lod)); + var height = Math.ceil(size / Math.pow(2, opts.lod)); + var rgbmTexture = new Texture2D({ + width: width, + height: height + }); + var framebuffer = new FrameBuffer(); + skybox.material.define('fragment', 'RGBM_ENCODE'); + if (opts.decodeRGBM) { + skybox.material.define('fragment', 'RGBM_DECODE'); + } + skybox.material.set('lod', opts.lod); + var envMapPass = new EnvironmentMapPass({ + texture: rgbmTexture + }); + var cubePixels = {}; + for (var i = 0; i < targets$3.length; i++) { + cubePixels[targets$3[i]] = new Uint8Array(width * height * 4); + var camera = envMapPass.getCamera(targets$3[i]); + camera.fov = 90; + framebuffer.attach(rgbmTexture); + framebuffer.bind(renderer); + renderer.render(dummyScene, camera); + renderer.gl.readPixels( + 0, 0, width, height, + Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets$3[i]] + ); + framebuffer.unbind(renderer); + } - trianglesPool.reset(); - linesPool.reset(); - pointsPool.reset(); + skybox.dispose(renderer); + framebuffer.dispose(renderer); + rgbmTexture.dispose(renderer); - var nPrimitive = 0; + return projectEnvironmentMapCPU(renderer, cubePixels, width, height); +}; - var indices = [0, 0, 0]; - var matColor = []; - for (var i = 0; i < list.length; i++) { - var renderable = list[i]; +/** + * Helpers for creating a common 3d application. + * @namespace clay.application + */ - mat4$8.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array); + // TODO createCompositor + // TODO Dispose test. geoCache test. + // TODO Tonemapping exposure + // TODO fitModel. + // TODO Particle ? +var parseColor = colorUtil.parseToFloat; - var geometry = renderable.geometry; - var material = renderable.material; - var attributes = geometry.attributes; +var EVE_NAMES = ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove', + 'touchstart', 'touchend', 'touchmove', + 'mousewheel', 'DOMMouseScroll' +]; - // alpha is default 1 - if (material.color.length == 3) { - vec3$16.copy(matColor, material.color); - matColor[3] = 1; - } - else { - vec4$2.copy(matColor, material.color); - } +/** + * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike + */ +/** + * @typedef {string|Array.} Color + */ +/** + * @typedef {HTMLDomElement|string} DomQuery + */ - var nVertex = geometry.vertexCount; - // Only support TRIANGLES, LINES, POINTS draw modes - switch (renderable.mode) { - case glenum.TRIANGLES: - if (geometry.isUseIndices()) { - var nFace = geometry.triangleCount; - for (var j = 0; j < nFace; j++) { - geometry.getFace(j, indices); +/** + * @constructor + * @alias clay.application.App3D + * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector` + * @param {Object} appNS + * @param {Function} appNS.init Initialization callback that will be called when initing app. + * You can return a promise in init to start the loop asynchronously when the promise is resolved. + * @param {Function} appNS.loop Loop callback that will be called each frame. + * @param {Function} appNS.beforeRender + * @param {Function} appNS.afterRender + * @param {number} [appNS.width] Container width. + * @param {number} [appNS.height] Container height. + * @param {number} [appNS.devicePixelRatio] + * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect + * @param {boolean} [appNS.graphic.shadow=false] If enable shadow + * @param {boolean} [appNS.graphic.linear=false] If use linear space + * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping. + * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex. + */ +function App3D(dom, appNS) { - var triangle = trianglesPool.pick(); - triangle.material = material; + appNS = appNS || {}; + appNS.graphic = appNS.graphic || {}; - var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + if (typeof dom === 'string') { + dom = document.querySelector(dom); + } - if (! clipped) { - primitives[nPrimitive++] = triangle; - } - } - } - else { - for (var j = 0; j < nVertex;) { - indices[0] = j++; - indices[1] = j++; - indices[2] = j++; + if (!dom) { throw new Error('Invalid dom'); } - var triangle = trianglesPool.pick(); - triangle.material = material; + var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS'; + var rendererOpts = {}; + isDomCanvas && (rendererOpts.canvas = dom); + appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio); - var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + var gRenderer = new Renderer(rendererOpts); + var gWidth = appNS.width || dom.clientWidth; + var gHeight = appNS.height || dom.clientHeight; - if (! clipped) { - primitives[nPrimitive++] = triangle; - } - } - } - break; - case glenum.LINES: - // LINES mode can't use face - for (var j = 0; j < nVertex;) { - indices[0] = j++; - indices[1] = j++; - var line = linesPool.pick(); - line.material = material; - line.lineWidth = renderable.lineWidth; + var gScene = new Scene(); + var gTimeline = new Timeline(); + var gShadowPass = appNS.graphic.shadow && new ShadowMapPass(); + var gRayPicking = appNS.event && new RayPicking({ + scene: gScene, + renderer: gRenderer + }); - var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor); + !isDomCanvas && dom.appendChild(gRenderer.canvas); - if (! clipped) { - primitives[nPrimitive++] = line; - } - } - break; - case glenum.POINTS: - for (var j = 0; j < nVertex; j++) { - indices[0] = j; - var point = pointsPool.pick(); - point.material = material; + gRenderer.resize(gWidth, gHeight); - var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor); + var gFrameTime = 0; + var gElapsedTime = 0; - if (! clipped) { - primitives[nPrimitive++] = point; - } - } - // POINTS mode can't use face - break; - } - } + gTimeline.start(); - trianglesPool.shrink(); - linesPool.shrink(); - pointsPool.shrink(); + Object.defineProperties(this, { + /** + * Container dom element + * @name clay.application.App3D#container + * @type {HTMLDomElement} + */ + container: { get: function () { return dom; } }, + /** + * @name clay.application.App3D#renderer + * @type {clay.Renderer} + */ + renderer: { get: function () { return gRenderer; }}, + /** + * @name clay.application.App3D#scene + * @type {clay.Renderer} + */ + scene: { get: function () { return gScene; }}, + /** + * @name clay.application.App3D#timeline + * @type {clay.Renderer} + */ + timeline: { get: function () { return gTimeline; }}, + /** + * Time elapsed since last frame. Can be used in loop to calculate the movement. + * @name clay.application.App3D#frameTime + * @type {number} + */ + frameTime: { get: function () { return gFrameTime; }}, + /** + * Time elapsed since application created. + * @name clay.application.App3D#elapsedTime + * @type {number} + */ + elapsedTime: { get: function () { return gElapsedTime; }} + }); - primitives.length = nPrimitive; + /** + * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given. + * @function + * @memberOf {clay.application.App3D} + * @param {number} [width] + * @param {number} [height] + */ + this.resize = function (width, height) { + gWidth = width || appNS.width || dom.clientWidth; + gHeight = height || dom.height || dom.clientHeight; + gRenderer.resize(gWidth, gHeight); + }; - primitives.sort(depthSortFunc); - this._drawPrimitives(primitives); - }, + /** + * Dispose the application + * @function + */ + this.dispose = function () { + this._disposed = true; - _setPrimitive: (function () { - var vertexColor = vec4Create(); - return function (primitive, indices, size, attributes, worldViewProjMat, matColor) { - var colorAttrib = attributes.color; - var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0; - var priColor = primitive.color; + if (appNS.dispose) { + appNS.dispose(this); + } + gTimeline.stop(); + gRenderer.disposeScene(gScene); + gShadowPass && gShadowPass.dispose(gRenderer); - primitive.depth = 0; - if (useVertexColor) { - vec4$2.set(priColor, 0, 0, 0, 0); - } + dom.innerHTML = ''; + EVE_NAMES.forEach(function (eveType) { + this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType)); + }); + }; - var clipped = true; + gRayPicking && this._initMouseEvents(gRayPicking); - var percent = 1 / size; - for (var i = 0; i < size; i++) { - var coord = primitive.vertices[i]; - attributes.position.get(indices[i], coord); - coord[3] = 1; - vec4$2.transformMat4(coord, coord, worldViewProjMat); - if (useVertexColor) { - colorAttrib.get(indices[i], vertexColor); - // Average vertex color - // Each primitive only call fill or stroke once - // So color must be the same - vec4$2.scaleAndAdd(priColor, priColor, vertexColor, percent); - } + this._geoCache = new LRU$1(20); + this._texCache = new LRU$1(20); - // Clipping - var x = coord[0]; - var y = coord[1]; - var z = coord[2]; - var w = coord[3]; + // Do init the application. + var initPromise = Promise.resolve(appNS.init && appNS.init(this)); + // Use the inited camera. + gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); - // TODO Point clipping - if (x > -w && x < w && y > -w && y < w && z > -w && z < w) { - clipped = false; - } + var gTexturesList = {}; + var gGeometriesList = {}; - var invW = 1 / w; - coord[0] = x * invW; - coord[1] = y * invW; - coord[2] = z * invW; - // Use primitive average depth; - primitive.depth += coord[2]; - } + if (!appNS.loop) { + console.warn('Miss loop method.'); + } - if (! clipped) { - primitive.depth /= size; + var self = this; + initPromise.then(function () { + appNS.loop && gTimeline.on('frame', function (frameTime) { + gFrameTime = frameTime; + gElapsedTime += frameTime; + appNS.loop(self); - if (useVertexColor) { - vec4$2.mul(priColor, priColor, matColor); - } - else { - vec4$2.copy(priColor, matColor); - } - } + gScene.update(); - return clipped; - } - })(), + self._updateGraphicOptions(appNS.graphic, gScene.opaqueList, false); + self._updateGraphicOptions(appNS.graphic, gScene.transparentList, false); + var skyboxList = []; + gScene.skybox && skyboxList.push(gScene.skybox); + gScene.skydome && skyboxList.push(gScene.skydome); + self._updateGraphicOptions(appNS.graphic, skyboxList, true); - _drawPrimitives: function (primitives) { - var ctx = this.ctx; - ctx.save(); + gRayPicking && (gRayPicking.camera = gScene.getMainCamera()); + // Render shadow pass + gShadowPass && gShadowPass.render(gRenderer, gScene, null, true); - var prevMaterial; + appNS.beforeRender && appNS.beforeRender(self); + self._doRender(gRenderer, gScene, true); + appNS.afterRender && appNS.afterRender(self); - var dpr = this.devicePixelRatio; - var width = this._width * dpr; - var height = this._height * dpr; - var halfWidth = width / 2; - var halfHeight = height / 2; + // Mark all resources unused; + markUnused(gTexturesList); + markUnused(gGeometriesList); - var prevLineWidth; - var prevStrokeColor; + // Collect resources used in this frame. + var newTexturesList = []; + var newGeometriesList = []; + collectResources(gScene, newTexturesList, newGeometriesList); - for (var i = 0; i < primitives.length; i++) { - var primitive = primitives[i]; - var vertices = primitive.vertices; + // Dispose those unsed resources. + checkAndDispose(gRenderer, gTexturesList); + checkAndDispose(gRenderer, gGeometriesList); - var primitiveType = primitive.type; - var material = primitive.material; - if (material !== prevMaterial) { - // Set material - ctx.globalAlpha = material.opacity; - prevMaterial = material; - } + gTexturesList = newTexturesList; + gGeometriesList = newGeometriesList; + }); + }); +} - var colorStr = vec4ToColorStr(primitive.color); - switch (primitiveType) { - case PRIMITIVE_TRIANGLE: - var v0 = vertices[0]; - var v1 = vertices[1]; - var v2 = vertices[2]; - ctx.fillStyle = colorStr; - ctx.beginPath(); - ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); - ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); - ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight); - ctx.closePath(); - ctx.fill(); - break; - case PRIMITIVE_LINE: - var v0 = vertices[0]; - var v1 = vertices[1]; - var lineWidth = primitive.lineWidth; - if (prevStrokeColor !== colorStr) { - prevStrokeColor = ctx.strokeStyle = colorStr; - } - if (lineWidth !== prevLineWidth) { - ctx.lineWidth = prevLineWidth = lineWidth; - } - ctx.beginPath(); - ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); - ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); - ctx.stroke(); - break; - case PRIMITIVE_POINT: - var pointSize = material.pointSize; - var pointShape = material.pointShape; - var halfSize = pointSize / 2; - if (pointSize > 0) { - var v0 = vertices[0]; - var cx = (v0[0] + 1) * halfWidth; - var cy = (-v0[1] + 1) * halfHeight; +function isImageLikeElement(val) { + return val instanceof Image + || val instanceof HTMLCanvasElement + || val instanceof HTMLVideoElement; +} - ctx.fillStyle = colorStr; - if (pointShape === 'rectangle') { - ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize); - } - else if (pointShape === 'circle') { - ctx.beginPath(); - ctx.arc(cx, cy, halfSize, 0, Math.PI * 2); - ctx.fill(); - } - } - break; - } - } +function getKeyFromImageLike(val) { + typeof val === 'string' + ? val : (val.__key__ || (val.__key__ = util$1.genGUID())); +} - ctx.restore(); - }, +function makeHandlerName(eveType) { + return '_' + eveType + 'Handler'; +} - dispose: function () { - this._triangles.clear(); - this._lines.clear(); - this._points.clear(); - this._primitives = []; +function packageEvent(eventType, pickResult, offsetX, offsetY, wheelDelta) { + var event = util$1.clone(pickResult); + event.type = eventType; + event.offsetX = offsetX; + event.offsetY = offsetY; + if (wheelDelta !== null) { + event.wheelDelta = wheelDelta; + } + return event; +} - this.ctx = null; - this.canvas = null; +function bubblingEvent(target, event) { + while (target && !event.cancelBubble) { + target.trigger(event.type, event); + target = target.getParent(); } -}); +} -// PENDING -// Use topological sort ? +App3D.prototype._initMouseEvents = function (rayPicking) { + var dom = this.container; -/** - * Node of graph based post processing. - * - * @constructor clay.compositor.Node - * @extends clay.core.Base - * - */ -var Node$1 = Base.extend(function () { - return /** @lends clay.compositor.Node# */ { - /** - * @type {string} - */ - name: '', + var oldTarget = null; + EVE_NAMES.forEach(function (_eveType) { + dom.addEventListener(_eveType, this[makeHandlerName(_eveType)] = function (e) { + if (!rayPicking.camera) { // Not have camera yet. + return; + } + e.preventDefault(); - /** - * Input links, will be updated by the graph - * @example: - * inputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - inputLinks: {}, + var box = dom.getBoundingClientRect(); + var offsetX, offsetY; + var eveType = _eveType; + + if (eveType.indexOf('touch') >= 0) { + var touch = eveType != 'touchend' + ? e.targetTouches[0] + : e.changedTouches[0]; + if (eveType === 'touchstart') { + eveType = 'mousedown'; + } + else if (eveType === 'touchend') { + eveType = 'mouseup'; + } + else if (eveType === 'touchmove') { + eveType = 'mousemove'; + } + offsetX = touch.clientX - box.left; + offsetY = touch.clientY - box.top; + } + else { + offsetX = e.clientX - box.left; + offsetY = e.clientY - box.top; + } - /** - * Output links, will be updated by the graph - * @example: - * outputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - outputLinks: {}, + var pickResult = rayPicking.pick(offsetX, offsetY); - // Save the output texture of previous frame - // Will be used when there exist a circular reference - _prevOutputTextures: {}, - _outputTextures: {}, + var delta; + if (eveType === 'DOMMouseScroll' || eveType === 'mousewheel') { + delta = (e.wheelDelta) ? e.wheelDelta / 120 : -(e.detail || 0) / 3; + } - // Example: { name: 2 } - _outputReferences: {}, + if (pickResult) { + // Just ignore silent element. + if (pickResult.target.silent) { + return; + } - _rendering: false, - // If rendered in this frame - _rendered: false, + if (eveType === 'mousemove') { + // PENDING touchdown should trigger mouseover event ? + var targetChanged = pickResult.target !== oldTarget; + if (targetChanged) { + oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', { + target: oldTarget + }, offsetX, offsetY)); + } + bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY)); + if (targetChanged) { + bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY)); + } + } + else { + bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY, delta)); + } + oldTarget = pickResult.target; + } + else if (oldTarget) { + bubblingEvent(oldTarget, packageEvent('mouseout', { + target: oldTarget + }, offsetX, offsetY)); + oldTarget = null; + } + }); + }, this); +}; - _compositor: null - }; -}, -/** @lends clay.compositor.Node.prototype */ -{ +App3D.prototype._updateGraphicOptions = function (graphicOpts, list, isSkybox) { + var enableTonemapping = !!graphicOpts.tonemapping; + var isLinearSpace = !!graphicOpts.linear; - // TODO Remove parameter function callback - updateParameter: function (outputName, renderer) { - var outputInfo = this.outputs[outputName]; - var parameters = outputInfo.parameters; - var parametersCopy = outputInfo._parametersCopy; - if (!parametersCopy) { - parametersCopy = outputInfo._parametersCopy = {}; + var prevMaterial; + + for (var i = 0; i < list.length; i++) { + var mat = list[i].material; + if (mat === prevMaterial) { + continue; } - if (parameters) { - for (var key in parameters) { - if (key !== 'width' && key !== 'height') { - parametersCopy[key] = parameters[key]; - } + + enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING'); + if (isLinearSpace) { + var decodeSRGB = true; + if (isSkybox && mat.get('environmentMap') && !mat.get('environmentMap').sRGB) { + decodeSRGB = false; } - } - var width, height; - if (parameters.width instanceof Function) { - width = parameters.width.call(this, renderer); - } - else { - width = parameters.width; - } - if (parameters.height instanceof Function) { - height = parameters.height.call(this, renderer); + decodeSRGB && mat.define('fragment', 'SRGB_DECODE'); + mat.define('fragment', 'SRGB_ENCODE'); } else { - height = parameters.height; - } - if ( - parametersCopy.width !== width - || parametersCopy.height !== height - ) { - if (this._outputTextures[outputName]) { - this._outputTextures[outputName].dispose(renderer.gl); - } + mat.undefine('fragment', 'SRGB_DECODE'); + mat.undefine('fragment', 'SRGB_ENCODE'); } - parametersCopy.width = width; - parametersCopy.height = height; - return parametersCopy; - }, + prevMaterial = mat; + } +}; - /** - * Set parameter - * @param {string} name - * @param {} value - */ - setParameter: function (name, value) {}, - /** - * Get parameter value - * @param {string} name - * @return {} - */ - getParameter: function (name) {}, - /** - * Set parameters - * @param {Object} obj - */ - setParameters: function (obj) { - for (var name in obj) { - this.setParameter(name, obj[name]); - } - }, +App3D.prototype._doRender = function (renderer, scene) { + var camera = scene.getMainCamera(); + camera.aspect = renderer.getViewportAspect(); + renderer.render(scene); +}; - render: function () {}, - getOutput: function (renderer /*optional*/, name) { - if (name == null) { - // Return the output texture without rendering - name = renderer; - return this._outputTextures[name]; - } - var outputInfo = this.outputs[name]; - if (!outputInfo) { - return ; - } +function markUnused(resourceList) { + for (var i = 0; i < resourceList.length; i++) { + resourceList[i].__used__ = 0; + } +} - // Already been rendered in this frame - if (this._rendered) { - // Force return texture in last frame - if (outputInfo.outputLastFrame) { - return this._prevOutputTextures[name]; - } - else { - return this._outputTextures[name]; - } - } - else if ( - // TODO - this._rendering // Solve Circular Reference - ) { - if (!this._prevOutputTextures[name]) { - // Create a blank texture at first pass - this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {}); - } - return this._prevOutputTextures[name]; +function checkAndDispose(renderer, resourceList) { + for (var i = 0; i < resourceList.length; i++) { + if (!resourceList[i].__used__) { + resourceList[i].dispose(renderer); } + } +} - this.render(renderer); - - return this._outputTextures[name]; - }, +function updateUsed(resource, list) { + resource.__used__ = resource.__used__ || 0; + resource.__used__++; + if (resource.__used__ === 1) { + // Don't push to the list twice. + list.push(resource); + } +} +function collectResources(scene, textureResourceList, geometryResourceList) { + function trackQueue(queue) { + var prevMaterial; + var prevGeometry; + for (var i = 0; i < queue.length; i++) { + var renderable = queue[i]; + var geometry = renderable.geometry; + var material = renderable.material; - removeReference: function (outputName) { - this._outputReferences[outputName]--; - if (this._outputReferences[outputName] === 0) { - var outputInfo = this.outputs[outputName]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[outputName]) { - this._compositor.releaseTexture(this._prevOutputTextures[outputName]); + // TODO optimize!! + if (material !== prevMaterial) { + var textureUniforms = material.getTextureUniforms(); + for (var u = 0; u < textureUniforms.length; u++) { + var uniformName = textureUniforms[u]; + var val = material.uniforms[uniformName].value; + if (!val) { + continue; + } + if (val instanceof Texture) { + updateUsed(val, textureResourceList); + } + else if (val instanceof Array) { + for (var k = 0; k < val.length; k++) { + if (val[k] instanceof Texture) { + updateUsed(val[k], textureResourceList); + } + } + } } - this._prevOutputTextures[outputName] = this._outputTextures[outputName]; } - else { - // Output of this node have alreay been used by all other nodes - // Put the texture back to the pool. - this._compositor.releaseTexture(this._outputTextures[outputName]); + if (geometry !== prevGeometry) { + updateUsed(geometry, geometryResourceList); } - } - }, - - link: function (inputPinName, fromNode, fromPinName) { - // The relationship from output pin to input pin is one-on-multiple - this.inputLinks[inputPinName] = { - node: fromNode, - pin: fromPinName - }; - if (!fromNode.outputLinks[fromPinName]) { - fromNode.outputLinks[fromPinName] = []; + prevMaterial = material; + prevGeometry = geometry; } - fromNode.outputLinks[fromPinName].push({ - node: this, - pin: inputPinName - }); - - // Enabled the pin texture in shader - this.pass.material.enableTexture(inputPinName); - }, + } - clear: function () { - this.inputLinks = {}; - this.outputLinks = {}; - }, + trackQueue(scene.opaqueList); + trackQueue(scene.transparentList); - updateReference: function (outputName) { - if (!this._rendering) { - this._rendering = true; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - link.node.updateReference(link.pin); - } - this._rendering = false; + for (var k = 0; k < scene.lights.length; k++) { + // Track AmbientCubemap + if (scene.lights[k].cubemap) { + updateUsed(scene.lights[k].cubemap, textureResourceList); } - if (outputName) { - this._outputReferences[outputName] ++; + } +} +/** + * Load a texture from image or string. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} + * @param {boolean} [opts.convertToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} + * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} + * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} + * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} + * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} + * @param {number} [opts.exposure] Only be used when source is a HDR image. + * @param {boolean} [useCache] If use cache. + * @return {Promise} + * @example + * app.loadTexture('diffuseMap.jpg') + * .then(function (texture) { + * material.set('diffuseMap', texture); + * }); + */ +App3D.prototype.loadTexture = function (urlOrImg, opts, useCache) { + var self = this; + var key = getKeyFromImageLike(urlOrImg); + if (useCache) { + if (this._texCache.get(key)) { + return this._texCache.get(key); } - }, - - beforeFrame: function () { - this._rendered = false; + } + // TODO Promise ? + var promise = new Promise(function (resolve, reject) { + var texture = self.loadTextureSync(urlOrImg, opts); + if (!texture.isRenderable()) { + texture.success(function () { + if (self._disposed) { + return; + } + resolve(texture); + }); + texture.error(function () { + if (self._disposed) { + return; + } + reject(); + }); + } + else { + resolve(texture); + } + }); + if (useCache) { + this._texCache.put(key, promise); + } + return promise; +}; - for (var name in this.outputLinks) { - this._outputReferences[name] = 0; +function nearestPowerOfTwo(val) { + return Math.pow(2, Math.round(Math.log(val) / Math.LN2)); +} +function convertTextureToPowerOfTwo(texture) { + if ((texture.wrapS === Texture.REPEAT || texture.wrapT === Texture.REPEAT) + && texture.image + ) { + // var canvas = document.createElement('canvas'); + var width = nearestPowerOfTwo(texture.width); + var height = nearestPowerOfTwo(texture.height); + if (width !== texture.width || height !== texture.height) { + var canvas = document.createElement('canvas'); + canvas.width = width; + canvas.height = height; + var ctx = canvas.getContext('2d'); + ctx.drawImage(texture.image, 0, 0, width, height); + canvas.srcImage = texture.image; + texture.image = canvas; + texture.dirty(); } - }, + } +} - afterFrame: function () { - // Put back all the textures to pool - for (var name in this.outputLinks) { - if (this._outputReferences[name] > 0) { - var outputInfo = this.outputs[name]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[name]) { - this._compositor.releaseTexture(this._prevOutputTextures[name]); - } - this._prevOutputTextures[name] = this._outputTextures[name]; - } - else { - this._compositor.releaseTexture(this._outputTextures[name]); - } +/** + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY} + * @param {boolean} [opts.convertToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic} + * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS} + * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT} + * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter} + * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter} + * @param {number} [opts.exposure] Only be used when source is a HDR image. + * @return {clay.Texture2D} + * @example + * var texture = app.loadTexture('diffuseMap.jpg', { + * anisotropic: 8, + * flipY: false + * }); + * material.set('diffuseMap', texture); + */ +App3D.prototype.loadTextureSync = function (urlOrImg, opts) { + var texture = new Texture2D(opts); + if (typeof urlOrImg === 'string') { + if (urlOrImg.match(/.hdr$|^data:application\/octet-stream/)) { + texture = textureUtil.loadTexture(urlOrImg, { + exposure: opts && opts.exposure, + fileType: 'hdr' + }, function () { + texture.dirty(); + texture.trigger('success'); + }); + for (var key in opts) { + texture[key] = opts[key]; + } + } + else { + texture.load(urlOrImg); + if (opts && opts.convertToPOT) { + texture.success(function () { + convertTextureToPowerOfTwo(texture); + }); } } } -}); + else if (isImageLikeElement(urlOrImg)) { + texture.image = urlOrImg; + texture.dynamic = urlOrImg instanceof HTMLVideoElement; + } + return texture; +}; /** - * @constructor clay.compositor.Graph - * @extends clay.core.Base - */ -var Graph = Base.extend(function () { - return /** @lends clay.compositor.Graph# */ { - /** - * @type {Array.} - */ - nodes: [] - }; -}, -/** @lends clay.compositor.Graph.prototype */ -{ - - /** - * Mark to update - */ - dirty: function () { - this._dirty = true; - }, - /** - * @param {clay.compositor.Node} node - */ - addNode: function (node) { - - if (this.nodes.indexOf(node) >= 0) { - return; + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=false] If flipY. See {@link clay.Texture.flipY} + * @return {Promise} + * @example + * app.loadTextureCube({ + * px: 'skybox/px.jpg', py: 'skybox/py.jpg', pz: 'skybox/pz.jpg', + * nx: 'skybox/nx.jpg', ny: 'skybox/ny.jpg', nz: 'skybox/nz.jpg' + * }).then(function (texture) { + * skybox.setEnvironmentMap(texture); + * }) + */ +App3D.prototype.loadTextureCube = function (imgList, opts) { + var textureCube = this.loadTextureCubeSync(imgList, opts); + return new Promise(function (resolve, reject) { + if (textureCube.isRenderable()) { + resolve(textureCube); } + else { + textureCube.success(function () { + resolve(textureCube); + }).error(function () { + reject(); + }); + } + }); +}; - this.nodes.push(node); +/** + * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded. + * @param {ImageLike} img + * @param {Object} [opts] Texture options. + * @param {boolean} [opts.flipY=false] If flipY. See {@link clay.Texture.flipY} + * @return {clay.TextureCube} + * @example + * var texture = app.loadTextureCubeSync({ + * px: 'skybox/px.jpg', py: 'skybox/py.jpg', pz: 'skybox/pz.jpg', + * nx: 'skybox/nx.jpg', ny: 'skybox/ny.jpg', nz: 'skybox/nz.jpg' + * }); + * skybox.setEnvironmentMap(texture); + */ +App3D.prototype.loadTextureCubeSync = function (imgList, opts) { + opts = opts || {}; + opts.flipY = opts.flipY || false; + var textureCube = new TextureCube(opts); + if (!imgList || !imgList.px || !imgList.nx || !imgList.py || !imgList.ny || !imgList.pz || !imgList.nz) { + throw new Error('Invalid cubemap format. Should be an object including px,nx,py,ny,pz,nz'); + } + if (typeof imgList.px === 'string') { + textureCube.load(imgList); + } + else { + textureCube.image = util$1.clone(imgList); + } + return textureCube; +}; - this._dirty = true; - }, - /** - * @param {clay.compositor.Node|string} node - */ - removeNode: function (node) { - if (typeof node === 'string') { - node = this.getNodeByName(node); - } - var idx = this.nodes.indexOf(node); - if (idx >= 0) { - this.nodes.splice(idx, 1); - this._dirty = true; - } - }, - /** - * @param {string} name - * @return {clay.compositor.Node} - */ - getNodeByName: function (name) { - for (var i = 0; i < this.nodes.length; i++) { - if (this.nodes[i].name === name) { - return this.nodes[i]; +/** + * Create a material. + * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms. + * Uniforms can be `color`, `alpha` `diffuseMap` etc. + * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow. + * @param {boolean} [transparent=false] If material is transparent. + * @param {boolean} [convertTextureToPOT=false] Force convert None Power of Two texture to Power of two so it can be tiled. + * @return {clay.Material} + */ +App3D.prototype.createMaterial = function (matConfig) { + matConfig = matConfig || {}; + matConfig.shader = matConfig.shader || 'clay.standardMR'; + var shader = matConfig.shader instanceof Shader ? matConfig.shader : library.get(matConfig.shader); + var material = new Material({ + shader: shader + }); + function makeTextureSetter(key) { + return function (texture) { + material.setUniform(key, texture); + }; + } + for (var key in matConfig) { + if (material.uniforms[key]) { + var val = matConfig[key]; + if ((material.uniforms[key].type === 't' || isImageLikeElement(val)) + && !(val instanceof Texture) + ) { + // Try to load a texture. + this.loadTexture(val, { + convertToPOT: matConfig.convertTextureToPOT + }).then(makeTextureSetter(key)); + } + else { + material.setUniform(key, val); } } - }, - /** - * Update links of graph - */ - update: function () { - for (var i = 0; i < this.nodes.length; i++) { - this.nodes[i].clear(); - } - // Traverse all the nodes and build the graph - for (var i = 0; i < this.nodes.length; i++) { - var node = this.nodes[i]; + } - if (!node.inputs) { - continue; - } - for (var inputName in node.inputs) { - if (!node.inputs[inputName]) { - continue; - } - if (node.pass && !node.pass.material.isUniformEnabled(inputName)) { - console.warn('Pin ' + node.name + '.' + inputName + ' not used.'); - continue; - } - var fromPinInfo = node.inputs[inputName]; + if (matConfig.transparent) { + matConfig.depthMask = false; + matConfig.transparent = true; + } + return material; +}; - var fromPin = this.findPin(fromPinInfo); - if (fromPin) { - node.link(inputName, fromPin.node, fromPin.pin); - } - else { - if (typeof fromPinInfo === 'string') { - console.warn('Node ' + fromPinInfo + ' not exist'); - } - else { - console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist'); - } - } - } - } - }, +/** + * Create a cube mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of cube. + * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a white cube. + * app.createCube() + */ +App3D.prototype.createCube = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; + } + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv, subdiv]; + } - findPin: function (input) { - var node; - // Try to take input as a directly a node - if (typeof input === 'string' || input instanceof Node$1) { - input = { - node: input - }; - } + var geoKey = 'cube-' + subdiv.join('-'); + var cube = this._geoCache.get(geoKey); + if (!cube) { + cube = new Cube$1({ + widthSegments: subdiv[0], + heightSegments: subdiv[1], + depthSegments: subdiv[2] + }); + cube.generateTangents(); + this._geoCache.put(geoKey, cube); + } + return this.createMesh(cube, material, parentNode); +}; - if (typeof input.node === 'string') { - for (var i = 0; i < this.nodes.length; i++) { - var tmp = this.nodes[i]; - if (tmp.name === input.node) { - node = tmp; - } - } - } - else { - node = input.node; - } - if (node) { - var inputPin = input.pin; - if (!inputPin) { - // Use first pin defaultly - if (node.outputs) { - inputPin = Object.keys(node.outputs)[0]; - } - } - if (node.outputs[inputPin]) { - return { - node: node, - pin: inputPin - }; - } - } +/** + * Create a cube mesh that camera is inside the cube. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of cube. + * Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a white cube inside. + * app.createCubeInside() + */ +App3D.prototype.createCubeInside = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; } -}); + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv, subdiv]; + } + var geoKey = 'cubeInside-' + subdiv.join('-'); + var cube = this._geoCache.get(geoKey); + if (!cube) { + cube = new Cube$1({ + inside: true, + widthSegments: subdiv[0], + heightSegments: subdiv[1], + depthSegments: subdiv[2] + }); + cube.generateTangents(); + this._geoCache.put(geoKey, cube); + } + + return this.createMesh(cube, material, parentNode); +}; /** - * Compositor provide graph based post processing - * - * @constructor clay.compositor.Compositor - * @extends clay.compositor.Graph - * + * Create a sphere mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {number} [subdivision=20] Subdivision of sphere. + * @return {clay.Mesh} + * @example + * // Create a semi-transparent sphere. + * app.createSphere({ + * color: [0, 0, 1], + * transparent: true, + * alpha: 0.5 + * }) */ -var Compositor = Graph.extend(function() { - return { - // Output node - _outputs: [], +App3D.prototype.createSphere = function (material, parentNode, subdivision) { + if (subdivision == null) { + subdivision = 20; + } + var geoKey = 'sphere-' + subdivision; + var sphere = this._geoCache.get(geoKey); + if (!sphere) { + sphere = new Sphere$1({ + widthSegments: subdivision * 2, + heightSegments: subdivision + }); + sphere.generateTangents(); + this._geoCache.put(geoKey, sphere); + } + return this.createMesh(sphere, material, parentNode); +}; - _texturePool: new TexturePool(), +/** + * Create a plane mesh and add it to the scene or the given parent node. + * @function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Array.|number} [subdivision=1] Subdivision of plane. + * Can be a number to represent both width and height dimensions. Or an array to represent them respectively. + * @return {clay.Mesh} + * @example + * // Create a red color plane. + * app.createPlane({ + * color: [1, 0, 0] + * }) + */ +App3D.prototype.createPlane = function (material, parentNode, subdiv) { + if (subdiv == null) { + subdiv = 1; + } + if (typeof subdiv === 'number') { + subdiv = [subdiv, subdiv]; + } + var geoKey = 'plane-' + subdiv.join('-'); + var planeGeo = this._geoCache.get(geoKey); + if (!planeGeo) { + planeGeo = new Plane$3({ + widthSegments: subdiv[0], + heightSegments: subdiv[1] + }); + planeGeo.generateTangents(); + this._geoCache.put(geoKey, planeGeo); + } + return this.createMesh(planeGeo, material, parentNode); +}; - _frameBuffer: new FrameBuffer({ - depthBuffer: false - }) - }; -}, -/** @lends clay.compositor.Compositor.prototype */ -{ - addNode: function(node) { - Graph.prototype.addNode.call(this, node); - node._compositor = this; - }, - /** - * @param {clay.Renderer} renderer - */ - render: function(renderer, frameBuffer) { - if (this._dirty) { - this.update(); - this._dirty = false; +/** + * Create mesh with parametric surface function + * @param {Object|clay.Material} [material] + * @param {clay.Node} [parentNode] Parent node to append. Default to be scene. + * @param {Object} generator + * @param {Function} generator.x + * @param {Function} generator.y + * @param {Function} generator.z + * @param {Array} [generator.u=[0, 1, 0.05]] + * @param {Array} [generator.v=[0, 1, 0.05]] + * @return {clay.Mesh} + */ +App3D.prototype.createParametricSurface = function (material, parentNode, generator) { + var geo = new ParametricSurface$1({ + generator: generator + }); + geo.generateTangents(); + return this.createMesh(geo, material, parentNode); +}; - this._outputs.length = 0; - for (var i = 0; i < this.nodes.length; i++) { - if (!this.nodes[i].outputs) { - this._outputs.push(this.nodes[i]); - } - } - } - for (var i = 0; i < this.nodes.length; i++) { - // Update the reference number of each output texture - this.nodes[i].beforeFrame(); - } +/** + * Create a general mesh with given geometry instance and material config. + * @param {clay.Geometry} geometry + * @return {clay.Mesh} + */ +App3D.prototype.createMesh = function (geometry, mat, parentNode) { + var mesh = new Mesh({ + geometry: geometry, + material: mat instanceof Material ? mat : this.createMaterial(mat) + }); + parentNode = parentNode || this.scene; + parentNode.add(mesh); + return mesh; +}; - for (var i = 0; i < this._outputs.length; i++) { - this._outputs[i].updateReference(); - } +/** + * Create an empty node + * @param {clay.Node} parentNode + * @return {clay.Node} + */ +App3D.prototype.createNode = function (parentNode) { + var node = new Node(); + parentNode = parentNode || this.scene; + parentNode.add(node); + return node; +}; - for (var i = 0; i < this._outputs.length; i++) { - this._outputs[i].render(renderer, frameBuffer); +/** + * Create a perspective or orthographic camera and add it to the scene. + * @param {Array.|clay.math.Vector3} position + * @param {Array.|clay.math.Vector3} target + * @param {string} [type="perspective"] Can be 'perspective' or 'orthographic'(in short 'ortho') + * @return {clay.camera.Perspective} + */ +App3D.prototype.createCamera = function (position, target, type) { + var CameraCtor; + if (type === 'ortho' || type === 'orthographic') { + CameraCtor = Orthographic$1; + } + else { + if (type && type !== 'perspective') { + console.error('Unkown camera type ' + type + '. Use default perspective camera'); } + CameraCtor = Perspective$1; + } - for (var i = 0; i < this.nodes.length; i++) { - // Clear up - this.nodes[i].afterFrame(); - } - }, + var camera = new CameraCtor(); + if (position instanceof Vector3) { + camera.position.copy(position); + } + else if (position instanceof Array) { + camera.position.setArray(position); + } - allocateTexture: function (parameters) { - return this._texturePool.get(parameters); - }, + if (target instanceof Array) { + target = new Vector3(target[0], target[1], target[2]); + } + if (target instanceof Vector3) { + camera.lookAt(target); + } - releaseTexture: function (parameters) { - this._texturePool.put(parameters); - }, + this.scene.add(camera); - getFrameBuffer: function () { - return this._frameBuffer; - }, + return camera; +}; - /** - * Dispose compositor - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { - this._texturePool.clear(renderer); +/** + * Create a directional light and add it to the scene. + * @param {Array.|clay.math.Vector3} dir A Vector3 or array to represent the direction. + * @param {Color} [color='#fff'] Color of directional light, default to be white. + * @param {number} [intensity] Intensity of directional light, default to be 1. + * + * @example + * app.createDirectionalLight([-1, -1, -1], '#fff', 2); + */ +App3D.prototype.createDirectionalLight = function (dir, color, intensity) { + var light = new DirectionalLight(); + if (dir instanceof Vector3) { + dir = dir.array; } -}); + light.position.setArray(dir).negate(); + light.lookAt(Vector3.ZERO); + if (typeof color === 'string') { + color = parseColor(color); + } + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); + + this.scene.add(light); + return light; +}; /** - * @constructor clay.compositor.SceneNode - * @extends clay.compositor.Node + * Create a spot light and add it to the scene. + * @param {Array.|clay.math.Vector3} position Position of the spot light. + * @param {Array.|clay.math.Vector3} [target] Target position where spot light points to. + * @param {number} [range=20] Falloff range of spot light. Default to be 20. + * @param {Color} [color='#fff'] Color of spot light, default to be white. + * @param {number} [intensity=1] Intensity of spot light, default to be 1. + * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line. + * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line. + * + * @example + * app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900); */ -var SceneNode$1 = Node$1.extend( -/** @lends clay.compositor.SceneNode# */ -{ - name: 'scene', - /** - * @type {clay.Scene} - */ - scene: null, - /** - * @type {clay.Camera} - */ - camera: null, - /** - * @type {boolean} - */ - autoUpdateScene: true, - /** - * @type {boolean} - */ - preZ: false +App3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) { + var light = new SpotLight(); + light.position.setArray(position instanceof Vector3 ? position.array : position); -}, function() { - this.frameBuffer = new FrameBuffer(); -}, { - render: function(renderer) { + if (target instanceof Array) { + target = new Vector3(target[0], target[1], target[2]); + } + if (target instanceof Vector3) { + light.lookAt(target); + } - this._rendering = true; - var _gl = renderer.gl; + if (typeof color === 'string') { + color = parseColor(color); + } + range != null && (light.range = range); + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); + umbraAngle != null && (light.umbraAngle = umbraAngle); + penumbraAngle != null && (light.penumbraAngle = penumbraAngle); - this.trigger('beforerender'); + this.scene.add(light); - var renderInfo; + return light; +}; - if (!this.outputs) { +/** + * Create a point light. + * @param {Array.|clay.math.Vector3} position Position of point light.. + * @param {number} [range=100] Falloff range of point light. + * @param {Color} [color='#fff'] Color of point light. + * @param {number} [intensity=1] Intensity of point light. + */ +App3D.prototype.createPointLight = function (position, range, color, intensity) { + var light = new PointLight(); + light.position.setArray(position instanceof Vector3 ? position.array : position); - renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); + if (typeof color === 'string') { + color = parseColor(color); + } + range != null && (light.range = range); + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); - } - else { + this.scene.add(light); - var frameBuffer = this.frameBuffer; - for (var name in this.outputs) { - var parameters = this.updateParameter(name, renderer); - var outputInfo = this.outputs[name]; - var texture = this._compositor.allocateTexture(parameters); - this._outputTextures[name] = texture; + return light; +}; - var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; - if (typeof(attachment) == 'string') { - attachment = _gl[attachment]; - } - frameBuffer.attach(texture, attachment); - } - frameBuffer.bind(renderer); +/** + * Create a ambient light. + * @param {Color} [color='#fff'] Color of ambient light. + * @param {number} [intensity=1] Intensity of ambient light. + */ +App3D.prototype.createAmbientLight = function (color, intensity) { + var light = new AmbientLight(); - // MRT Support in chrome - // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html - var ext = renderer.getGLExtension('EXT_draw_buffers'); - if (ext) { - var bufs = []; - for (var attachment in this.outputs) { - attachment = parseInt(attachment); - if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) { - bufs.push(attachment); - } - } - ext.drawBuffersEXT(bufs); - } + if (typeof color === 'string') { + color = parseColor(color); + } + color != null && (light.color = color); + intensity != null && (light.intensity = intensity); - // Always clear - // PENDING - renderer.saveClear(); - renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT; - renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); - renderer.restoreClear(); + this.scene.add(light); - frameBuffer.unbind(renderer); - } + return light; +}; - this.trigger('afterrender', renderInfo); +/** + * Create an cubemap ambient light and an spherical harmonic ambient light + * for specular and diffuse lighting in PBR rendering + * @param {ImageLike|TextureCube} [envImage] Panorama environment image, HDR format is better. Or a pre loaded texture cube + * @param {number} [specularIntenstity=0.7] Intensity of specular light. + * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light. + * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR. + * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering. + */ +App3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) { + var self = this; + if (exposure == null) { + exposure = 1; + } + if (prefilteredCubemapSize == null) { + prefilteredCubemapSize = 32; + } - this._rendering = false; - this._rendered = true; + var scene = this.scene; + + var loadPromise; + if (envImage instanceof TextureCube) { + loadPromise = envImage.isRenderable() + ? Promise.resolve(envImage) + : new Promise(function (resolve, reject) { + envImage.success(function () { + resolve(envImage); + }); + }); } -}); + else { + loadPromise = this.loadTexture(envImage, { + exposure: exposure + }); + } + + return loadPromise.then(function (envTexture) { + var specLight = new AmbientCubemapLight({ + intensity: specIntensity != null ? specIntensity : 0.7 + }); + specLight.cubemap = envTexture; + envTexture.flipY = false; + // TODO Cache prefilter ? + specLight.prefilter(self.renderer, 32); + + var diffLight = new AmbientSHLight({ + intensity: diffIntensity != null ? diffIntensity : 0.7, + coefficients: sh.projectEnvironmentMap( + self.renderer, specLight.cubemap, { + lod: 1 + } + ) + }); + scene.add(specLight); + scene.add(diffLight); + + return { + specular: specLight, + diffuse: diffLight, + // Original environment map + environmentMap: envTexture + }; + }); +}; /** - * @constructor clay.compositor.TextureNode - * @extends clay.compositor.Node + * Load a [glTF](https://github.com/KhronosGroup/glTF) format model. + * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script, + * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application. + * @param {string} url + * @param {Object} opts + * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'. + * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded. + * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model. + * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z' + * @param {boolean} [opts.textureFlipY=false] + * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file. + * @return {Promise} */ -var TextureNode$1 = Node$1.extend(function() { - return /** @lends clay.compositor.TextureNode# */ { - /** - * @type {clay.Texture2D} - */ - texture: null, +App3D.prototype.loadModel = function (url, opts) { + if (typeof url !== 'string') { + throw new Error('Invalid URL.'); + } - // Texture node must have output without parameters - outputs: { - color: {} - } + opts = opts || {}; + if (opts.autoPlayAnimation == null) { + opts.autoPlayAnimation = true; + } + var shader = opts.shader || 'clay.standard'; + + var loaderOpts = { + rootNode: new Node(), + shader: shader, + textureRootPath: opts.textureRootPath, + crossOrigin: 'Anonymous', + textureFlipY: opts.textureFlipY }; -}, function () { -}, { + if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') { + loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2); + } - getOutput: function (renderer, name) { - return this.texture; - }, + var loader = new GLTFLoader(loaderOpts); - // Do nothing - beforeFrame: function () {}, - afterFrame: function () {} -}); + var scene = this.scene; + var timeline = this.timeline; + var self = this; -// TODO Shader library -// TODO curlnoise demo wrong + return new Promise(function (resolve, reject) { + function afterLoad(result) { + if (self._disposed) { + return; + } -// PENDING -// Use topological sort ? + scene.add(result.rootNode); + if (opts.autoPlayAnimation) { + result.clips.forEach(function (clip) { + timeline.addClip(clip); + }); + } + resolve(result); + } + loader.success(function (result) { + if (self._disposed) { + return; + } -/** - * Filter node - * - * @constructor clay.compositor.FilterNode - * @extends clay.compositor.Node - * - * @example - var node = new clay.compositor.Node({ - name: 'fxaa', - shader: clay.Shader.source('clay.compositor.fxaa'), - inputs: { - texture: { - node: 'scene', - pin: 'color' + if (!opts.waitTextureLoaded) { + afterLoad(result); } - }, - // Multiple outputs is preserved for MRT support in WebGL2.0 - outputs: { - color: { - attachment: clay.FrameBuffer.COLOR_ATTACHMENT0 - parameters: { - format: clay.Texture.RGBA, - width: 512, - height: 512 - }, - // Node will keep the RTT rendered in last frame - keepLastFrame: true, - // Force the node output the RTT rendered in last frame - outputLastFrame: true + else { + Promise.all(result.textures.map(function (texture) { + if (texture.isRenderable()) { + return Promise.resolve(texture); + } + return new Promise(function (resolve) { + texture.success(resolve); + texture.error(resolve); + }); + })).then(function () { + afterLoad(result); + }).catch(function () { + afterLoad(result); + }); } - } + }); + loader.error(function () { + reject(); + }); + loader.load(url); }); - * - */ -var FilterNode$1 = Node$1.extend(function () { - return /** @lends clay.compositor.Node# */ { - /** - * @type {string} - */ - name: '', - - /** - * @type {Object} - */ - inputs: {}, - - /** - * @type {Object} - */ - outputs: null, +}; - /** - * @type {string} - */ - shader: '', - /** - * Input links, will be updated by the graph - * @example: - * inputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - inputLinks: {}, +var application = { + App3D: App3D, + /** + * Create a 3D application that will manage the app initialization and loop. + * @name clay.application.create + * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector` + * @param {Object} appNS + * @param {Function} init Initialization callback that will be called when initing app. + * @param {Function} loop Loop callback that will be called each frame. + * @param {number} [width] Container width. + * @param {number} [height] Container height. + * @param {number} [devicePixelRatio] + * @return {clay.application.App3D} + * + * @example + * clay.application.create('#app', { + * init: function (app) { + * app.createCube(); + * var camera = app.createCamera(); + * camera.position.set(0, 0, 2); + * }, + * loop: function () { // noop } + * }) + */ + create: function (dom, appNS) { + return new App3D(dom, appNS); + } +}; - /** - * Output links, will be updated by the graph - * @example: - * outputName: { - * node: someNode, - * pin: 'xxxx' - * } - * @type {Object} - */ - outputLinks: {}, +/** + * @constructor + * @alias clay.async.Task + * @mixes clay.core.mixin.notifier + */ +var Task = function() { + this._fullfilled = false; + this._rejected = false; +}; +/** + * Task successed + * @param {} data + */ +Task.prototype.resolve = function(data) { + this._fullfilled = true; + this._rejected = false; + this.trigger('success', data); +}; +/** + * Task failed + * @param {} err + */ +Task.prototype.reject = function(err) { + this._rejected = true; + this._fullfilled = false; + this.trigger('error', err); +}; +/** + * If task successed + * @return {boolean} + */ +Task.prototype.isFullfilled = function() { + return this._fullfilled; +}; +/** + * If task failed + * @return {boolean} + */ +Task.prototype.isRejected = function() { + return this._rejected; +}; +/** + * If task finished, either successed or failed + * @return {boolean} + */ +Task.prototype.isSettled = function() { + return this._fullfilled || this._rejected; +}; - /** - * @type {clay.compositor.Pass} - */ - pass: null, +util$1.extend(Task.prototype, notifier); - // Save the output texture of previous frame - // Will be used when there exist a circular reference - _prevOutputTextures: {}, - _outputTextures: {}, +function makeRequestTask(url, responseType) { + var task = new Task(); + request.get({ + url: url, + responseType: responseType, + onload: function(res) { + task.resolve(res); + }, + onerror: function(error) { + task.reject(error); + } + }); + return task; +} +/** + * Make a request task + * @param {string|object|object[]|string[]} url + * @param {string} [responseType] + * @example + * var task = Task.makeRequestTask('./a.json'); + * var task = Task.makeRequestTask({ + * url: 'b.bin', + * responseType: 'arraybuffer' + * }); + * var tasks = Task.makeRequestTask(['./a.json', './b.json']); + * var tasks = Task.makeRequestTask([ + * {url: 'a.json'}, + * {url: 'b.bin', responseType: 'arraybuffer'} + * ]); + * @return {clay.async.Task|clay.async.Task[]} + */ +Task.makeRequestTask = function(url, responseType) { + if (typeof url === 'string') { + return makeRequestTask(url, responseType); + } else if (url.url) { // Configure object + var obj = url; + return makeRequestTask(obj.url, obj.responseType); + } else if (Array.isArray(url)) { // Url list + var urlList = url; + var tasks = []; + urlList.forEach(function(obj) { + var url, responseType; + if (typeof obj === 'string') { + url = obj; + } else if (Object(obj) === obj) { + url = obj.url; + responseType = obj.responseType; + } + tasks.push(makeRequestTask(url, responseType)); + }); + return tasks; + } +}; +/** + * @return {clay.async.Task} + */ +Task.makeTask = function() { + return new Task(); +}; - // Example: { name: 2 } - _outputReferences: {}, +util$1.extend(Task.prototype, notifier); - _rendering: false, - // If rendered in this frame - _rendered: false, +/** + * @constructor + * @alias clay.async.TaskGroup + * @extends clay.async.Task + */ +var TaskGroup = function () { - _compositor: null - }; -}, function () { + Task.apply(this, arguments); - var pass = new Pass({ - fragment: this.shader - }); - this.pass = pass; -}, -/** @lends clay.compositor.Node.prototype */ -{ - /** - * @param {clay.Renderer} renderer - */ - render: function (renderer, frameBuffer) { - this.trigger('beforerender', renderer); + this._tasks = []; - this._rendering = true; + this._fulfilledNumber = 0; - var _gl = renderer.gl; + this._rejectedNumber = 0; +}; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - var inputTexture = link.node.getOutput(renderer, link.pin); - this.pass.setUniform(inputName, inputTexture); - } - // Output - if (!this.outputs) { - this.pass.outputs = null; +var Ctor = function (){}; +Ctor.prototype = Task.prototype; +TaskGroup.prototype = new Ctor(); - this._compositor.getFrameBuffer().unbind(renderer); +TaskGroup.prototype.constructor = TaskGroup; - this.pass.render(renderer, frameBuffer); +/** + * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}. + * @param {Array.} tasks + * @chainable + * @example + * // Load texture list + * var list = ['a.jpg', 'b.jpg', 'c.jpg'] + * var textures = list.map(function (src) { + * var texture = new clay.Texture2D(); + * texture.load(src); + * return texture; + * }); + * var taskGroup = new clay.async.TaskGroup(); + * taskGroup.all(textures).success(function () { + * // Do some thing after all textures loaded + * }); + */ +TaskGroup.prototype.all = function (tasks) { + var count = 0; + var self = this; + var data = []; + this._tasks = tasks; + this._fulfilledNumber = 0; + this._rejectedNumber = 0; + + util$1.each(tasks, function (task, idx) { + if (!task || !task.once) { + return; } - else { - this.pass.outputs = {}; + count++; + task.once('success', function (res) { + count--; - var attachedTextures = {}; - for (var name in this.outputs) { - var parameters = this.updateParameter(name, renderer); - if (isNaN(parameters.width)) { - this.updateParameter(name, renderer); - } - var outputInfo = this.outputs[name]; - var texture = this._compositor.allocateTexture(parameters); - this._outputTextures[name] = texture; - var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; - if (typeof(attachment) == 'string') { - attachment = _gl[attachment]; - } - attachedTextures[attachment] = texture; - } - this._compositor.getFrameBuffer().bind(renderer); + self._fulfilledNumber++; + // TODO + // Some tasks like texture, loader are not inherited from task + // We need to set the states here + task._fulfilled = true; + task._rejected = false; - for (var attachment in attachedTextures) { - // FIXME attachment changes in different nodes - this._compositor.getFrameBuffer().attach( - attachedTextures[attachment], attachment - ); + data[idx] = res; + if (count === 0) { + self.resolve(data); } + }); + task.once('error', function () { - this.pass.render(renderer); + self._rejectedNumber ++; - // Because the data of texture is changed over time, - // Here update the mipmaps of texture each time after rendered; - this._compositor.getFrameBuffer().updateMipmap(renderer.gl); - } + task._fulfilled = false; + task._rejected = true; - for (var inputName in this.inputLinks) { - var link = this.inputLinks[inputName]; - link.node.removeReference(link.pin); + self.reject(task); + }); + }); + if (count === 0) { + setTimeout(function () { + self.resolve(data); + }); + return this; + } + return this; +}; +/** + * Wait for all given tasks finished, either successed or failed + * @param {Array.} tasks + * @return {clay.async.TaskGroup} + */ +TaskGroup.prototype.allSettled = function (tasks) { + var count = 0; + var self = this; + var data = []; + if (tasks.length === 0) { + setTimeout(function () { + self.trigger('success', data); + }); + return this; + } + this._tasks = tasks; + + util$1.each(tasks, function (task, idx) { + if (!task || !task.once) { + return; } + count++; + task.once('success', function (res) { + count--; - this._rendering = false; - this._rendered = true; + self._fulfilledNumber++; - this.trigger('afterrender', renderer); - }, + task._fulfilled = true; + task._rejected = false; - // TODO Remove parameter function callback - updateParameter: function (outputName, renderer) { - var outputInfo = this.outputs[outputName]; - var parameters = outputInfo.parameters; - var parametersCopy = outputInfo._parametersCopy; - if (!parametersCopy) { - parametersCopy = outputInfo._parametersCopy = {}; - } - if (parameters) { - for (var key in parameters) { - if (key !== 'width' && key !== 'height') { - parametersCopy[key] = parameters[key]; - } - } - } - var width, height; - if (parameters.width instanceof Function) { - width = parameters.width.call(this, renderer); - } - else { - width = parameters.width; - } - if (parameters.height instanceof Function) { - height = parameters.height.call(this, renderer); - } - else { - height = parameters.height; - } - if ( - parametersCopy.width !== width - || parametersCopy.height !== height - ) { - if (this._outputTextures[outputName]) { - this._outputTextures[outputName].dispose(renderer); + data[idx] = res; + if (count === 0) { + self.resolve(data); } - } - parametersCopy.width = width; - parametersCopy.height = height; - - return parametersCopy; - }, + }); + task.once('error', function (err) { + count--; - /** - * Set parameter - * @param {string} name - * @param {} value - */ - setParameter: function (name, value) { - this.pass.setUniform(name, value); - }, - /** - * Get parameter value - * @param {string} name - * @return {} - */ - getParameter: function (name) { - return this.pass.getUniform(name); - }, - /** - * Set parameters - * @param {Object} obj - */ - setParameters: function (obj) { - for (var name in obj) { - this.setParameter(name, obj[name]); - } - }, - // /** - // * Set shader code - // * @param {string} shaderStr - // */ - // setShader: function (shaderStr) { - // var material = this.pass.material; - // material.shader.setFragment(shaderStr); - // material.attachShader(material.shader, true); - // }, - /** - * Proxy of pass.material.define('fragment', xxx); - * @param {string} symbol - * @param {number} [val] - */ - define: function (symbol, val) { - this.pass.material.define('fragment', symbol, val); - }, + self._rejectedNumber++; - /** - * Proxy of pass.material.undefine('fragment', xxx) - * @param {string} symbol - */ - undefine: function (symbol) { - this.pass.material.undefine('fragment', symbol); - }, + task._fulfilled = false; + task._rejected = true; - removeReference: function (outputName) { - this._outputReferences[outputName]--; - if (this._outputReferences[outputName] === 0) { - var outputInfo = this.outputs[outputName]; - if (outputInfo.keepLastFrame) { - if (this._prevOutputTextures[outputName]) { - this._compositor.releaseTexture(this._prevOutputTextures[outputName]); - } - this._prevOutputTextures[outputName] = this._outputTextures[outputName]; + // TODO + data[idx] = null; + if (count === 0) { + self.resolve(data); } - else { - // Output of this node have alreay been used by all other nodes - // Put the texture back to the pool. - this._compositor.releaseTexture(this._outputTextures[outputName]); + }); + }); + return this; +}; +/** + * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getFulfilledNumber = function (recursive) { + if (recursive) { + var nFulfilled = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nFulfilled += task.getFulfilledNumber(recursive); + } else if(task._fulfilled) { + nFulfilled += 1; } } - }, - - clear: function () { - Node$1.prototype.clear.call(this); - - // Default disable all texture - this.pass.material.disableTexturesAll(); + return nFulfilled; + } else { + return this._fulfilledNumber; } -}); - -var shaderSourceReg = /^#source\((.*?)\)/; +}; /** - * @param {Object} json - * @param {Object} [opts] - * @return {clay.compositor.Compositor} + * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} */ -function createCompositor(json, opts) { - var compositor = new Compositor(); - opts = opts || {}; - - var lib = { - textures: {}, - parameters: {} - }; - var afterLoad = function(shaderLib, textureLib) { - for (var i = 0; i < json.nodes.length; i++) { - var nodeInfo = json.nodes[i]; - var node = createNode(nodeInfo, lib, opts); - if (node) { - compositor.addNode(node); +TaskGroup.prototype.getRejectedNumber = function (recursive) { + if (recursive) { + var nRejected = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nRejected += task.getRejectedNumber(recursive); + } else if(task._rejected) { + nRejected += 1; } } - }; - - for (var name in json.parameters) { - var paramInfo = json.parameters[name]; - lib.parameters[name] = convertParameter(paramInfo); + return nRejected; + } else { + return this._rejectedNumber; } - // TODO load texture asynchronous - loadTextures(json, lib, opts, function(textureLib) { - lib.textures = textureLib; - afterLoad(); - }); - - return compositor; -} - -function createNode(nodeInfo, lib, opts) { - var type = nodeInfo.type || 'filter'; - var shaderSource; - var inputs; - var outputs; +}; - if (type === 'filter') { - var shaderExp = nodeInfo.shader.trim(); - var res = shaderSourceReg.exec(shaderExp); - if (res) { - shaderSource = Shader.source(res[1].trim()); - } - else if (shaderExp.charAt(0) === '#') { - shaderSource = lib.shaders[shaderExp.substr(1)]; - } - if (!shaderSource) { - shaderSource = shaderExp; - } - if (!shaderSource) { - return; - } - } +/** + * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getSettledNumber = function (recursive) { - if (nodeInfo.inputs) { - inputs = {}; - for (var name in nodeInfo.inputs) { - if (typeof nodeInfo.inputs[name] === 'string') { - inputs[name] = nodeInfo.inputs[name]; - } - else { - inputs[name] = { - node: nodeInfo.inputs[name].node, - pin: nodeInfo.inputs[name].pin - }; + if (recursive) { + var nSettled = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nSettled += task.getSettledNumber(recursive); + } else if(task._rejected || task._fulfilled) { + nSettled += 1; } } + return nSettled; + } else { + return this._fulfilledNumber + this._rejectedNumber; } - if (nodeInfo.outputs) { - outputs = {}; - for (var name in nodeInfo.outputs) { - var outputInfo = nodeInfo.outputs[name]; - outputs[name] = {}; - if (outputInfo.attachment != null) { - outputs[name].attachment = outputInfo.attachment; - } - if (outputInfo.keepLastFrame != null) { - outputs[name].keepLastFrame = outputInfo.keepLastFrame; - } - if (outputInfo.outputLastFrame != null) { - outputs[name].outputLastFrame = outputInfo.outputLastFrame; - } - if (outputInfo.parameters) { - outputs[name].parameters = convertParameter(outputInfo.parameters); +}; + +/** + * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup. + * @param {boolean} [recursive] + * @return {number} + */ +TaskGroup.prototype.getTaskNumber = function (recursive) { + if (recursive) { + var nTask = 0; + for (var i = 0; i < this._tasks.length; i++) { + var task = this._tasks[i]; + if (task instanceof TaskGroup) { + nTask += task.getTaskNumber(recursive); + } else { + nTask += 1; } } + return nTask; + } else { + return this._tasks.length; } - var node; - if (type === 'scene') { - node = new SceneNode$1({ - name: nodeInfo.name, - scene: opts.scene, - camera: opts.camera, - outputs: outputs - }); - } - else if (type === 'texture') { - node = new TextureNode$1({ - name: nodeInfo.name, - outputs: outputs - }); - } - // Default is filter - else { - node = new FilterNode$1({ - name: nodeInfo.name, - shader: shaderSource, - inputs: inputs, - outputs: outputs - }); - } - if (node) { - if (nodeInfo.parameters) { - for (var name in nodeInfo.parameters) { - var val = nodeInfo.parameters[name]; - if (typeof(val) === 'string') { - val = val.trim(); - if (val.charAt(0) === '#') { - val = lib.textures[val.substr(1)]; - } - else { - node.on( - 'beforerender', createSizeSetHandler( - name, tryConvertExpr(val) - ) - ); - } - } - node.setParameter(name, val); - } - } - if (nodeInfo.defines && node.pass) { - for (var name in nodeInfo.defines) { - var val = nodeInfo.defines[name]; - node.pass.material.define('fragment', name, val); - } +}; + +var CanvasMaterial = Base.extend({ + + color: [1, 1, 1, 1], + + opacity: 1, + + pointSize: 0, + + pointShape: 'rectangle' +}); + +var mat4$8 = glmatrix.mat4; +var vec3$17 = glmatrix.vec3; +var vec4$2 = glmatrix.vec4; + +var vec4Create = vec4$2.create; + +var round = Math.round; + +var PRIMITIVE_TRIANGLE = 1; +var PRIMITIVE_LINE = 2; +var PRIMITIVE_POINT = 3; + +function PrimitivePool(constructor) { + this.ctor = constructor; + + this._data = []; + + this._size = 0; +} + +PrimitivePool.prototype = { + pick: function () { + var data = this._data; + var size = this._size; + var obj = data[size]; + if (! obj) { + // Constructor must have no parameters + obj = new this.ctor(); + data[size] = obj; } - } - return node; -} + this._size++; + return obj; + }, -function convertParameter(paramInfo) { - var param = {}; - if (!paramInfo) { - return param; - } - ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap'] - .forEach(function(name) { - var val = paramInfo[name]; - if (val != null) { - // Convert string to enum - if (typeof val === 'string') { - val = Texture[val]; - } - param[name] = val; - } - }); - ['width', 'height'] - .forEach(function(name) { - if (paramInfo[name] != null) { - var val = paramInfo[name]; - if (typeof val === 'string') { - val = val.trim(); - param[name] = createSizeParser( - name, tryConvertExpr(val) - ); - } - else { - param[name] = val; - } - } - }); - if (paramInfo.useMipmap != null) { - param.useMipmap = paramInfo.useMipmap; + reset: function () { + this._size = 0; + }, + + shrink: function () { + this._data.length = this._size; + }, + + clear: function () { + this._data = []; + this._size = 0; } - return param; +}; + +function Triangle() { + this.vertices = [vec4Create(), vec4Create(), vec4Create()]; + this.color = vec4Create(); + + this.depth = 0; } -function loadTextures(json, lib, opts, callback) { - if (!json.textures) { - callback({}); - return; - } - var textures = {}; - var loading = 0; +Triangle.prototype.type = PRIMITIVE_TRIANGLE; - var cbd = false; - var textureRootPath = opts.textureRootPath; - util$1.each(json.textures, function(textureInfo, name) { - var texture; - var path = textureInfo.path; - var parameters = convertParameter(textureInfo.parameters); - if (Array.isArray(path) && path.length === 6) { - if (textureRootPath) { - path = path.map(function(item) { - return util$1.relative2absolute(item, textureRootPath); - }); - } - texture = new TextureCube(parameters); - } - else if(typeof path === 'string') { - if (textureRootPath) { - path = util$1.relative2absolute(path, textureRootPath); - } - texture = new Texture2D(parameters); - } - else { - return; - } +function Point() { + // Here use an array to make it more convinient to proccessing in _setPrimitive method + this.vertices = [vec4Create()]; - texture.load(path); - loading++; - texture.once('success', function() { - textures[name] = texture; - loading--; - if (loading === 0) { - callback(textures); - cbd = true; - } - }); - }); + this.color = vec4Create(); - if (loading === 0 && !cbd) { - callback(textures); - } + this.depth = 0; } -function createSizeSetHandler(name, exprFunc) { - return function (renderer) { - // PENDING viewport size or window size - var dpr = renderer.getDevicePixelRatio(); - // PENDING If multiply dpr ? - var width = renderer.getWidth(); - var height = renderer.getHeight(); - var result = exprFunc(width, height, dpr); - this.setParameter(name, result); - }; +Point.prototype.type = PRIMITIVE_POINT; + +function Line() { + this.vertices = [vec4Create(), vec4Create()]; + this.color = vec4Create(); + + this.depth = 0; + + this.lineWidth = 1; } -function createSizeParser(name, exprFunc) { - return function (renderer) { - var dpr = renderer.getDevicePixelRatio(); - var width = renderer.getWidth(); - var height = renderer.getHeight(); - return exprFunc(width, height, dpr); - }; +Line.prototype.type = PRIMITIVE_LINE; + +function depthSortFunc(x, y) { + // Sort from far to near, which in depth of projection space is from larger to smaller + return y.depth - x.depth; } -function tryConvertExpr(string) { - // PENDING - var exprRes = /^expr\((.*)\)$/.exec(string); - if (exprRes) { - try { - var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]); - // Try run t - func(1, 1); +function vec3ToColorStr(v3) { + return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')'; +} - return func; - } - catch (e) { - throw new Error('Invalid expression.'); - } - } +function vec4ToColorStr(v4) { + return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')'; } -var gbufferEssl = "@export clay.deferred.gbuffer.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat;\nuniform vec2 uvOffset;\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#ifdef FIRST_PASS\nattribute vec3 normal : NORMAL;\n#endif\n@import clay.chunk.skinning_header\n#ifdef FIRST_PASS\nvarying vec3 v_Normal;\nattribute vec4 tangent : TANGENT;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nvarying vec3 v_WorldPosition;\n#endif\nvarying vec2 v_Texcoord;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef FIRST_PASS\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n bool hasTangent = dot(tangent, tangent) > 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"; +var CanvasRenderer = Base.extend({ -var chunkEssl = "@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end"; + canvas: null, -Shader.import(gbufferEssl); -Shader.import(chunkEssl); + _width: 100, -function createFillCanvas(color) { - var canvas = document.createElement('canvas'); - canvas.width = canvas.height = 1; - var ctx = canvas.getContext('2d'); - ctx.fillStyle = color || '#000'; - ctx.fillRect(0, 0, 1, 1); + _height: 100, - return canvas; -} + devicePixelRatio: window.devicePixelRatio || 1.0, -function attachTextureToSlot(renderer, program, symbol, texture, slot) { - var gl = renderer.gl; - program.setUniform(gl, '1i', symbol, slot); + color: [0.0, 0.0, 0.0, 0.0], - gl.activeTexture(gl.TEXTURE0 + slot); - // Maybe texture is not loaded yet; - if (texture.isRenderable()) { - texture.bind(renderer); - } - else { - // Bind texture to null - texture.unbind(renderer); - } -} + clear: true, -// TODO Use globalShader insteadof globalMaterial? -function getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) { + ctx: null, - var previousNormalMap; - var previousRougGlossMap; - var previousRenderable; + // Cached primitive list, including triangle, line, point + _primitives: [], - return function (renderable, gBufferMat, prevMaterial) { - // Material not change - if (previousRenderable && previousRenderable.material === renderable.material) { - return; + // Triangle pool + _triangles: new PrimitivePool(Triangle), + + // Line pool + _lines: new PrimitivePool(Line), + + // Point pool + _points: new PrimitivePool(Point) +}, function () { + if (! this.canvas) { + this.canvas = document.createElement('canvas'); + } + var canvas = this.canvas; + + try { + this.ctx = canvas.getContext('2d'); + var ctx = this.ctx; + if (!ctx) { + throw new Error(); } + } + catch (e) { + throw 'Error creating WebGL Context ' + e; + } - var standardMaterial = renderable.material; - var program = renderable.__program; + this.resize(); +}, { - var glossiness; - var roughGlossMap; - var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS'); - var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED'); - var roughGlossChannel; - if (useRoughnessWorkflow) { - glossiness = 1.0 - standardMaterial.get('roughness'); - roughGlossMap = standardMaterial.get('roughnessMap'); - roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL'); + resize: function (width, height) { + var dpr = this.devicePixelRatio; + var canvas = this.canvas; + if (width != null) { + canvas.style.width = width + 'px'; + canvas.style.height = height + 'px'; + canvas.width = width * dpr; + canvas.height = height * dpr; + + this._width = width; + this._height = height; } else { - glossiness = standardMaterial.get('glossiness'); - roughGlossMap = standardMaterial.get('glossinessMap'); - roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL'); + this._width = canvas.width / dpr; + this._height = canvas.height / dpr; } - var useRoughGlossMap = !!roughGlossMap; + }, - var normalMap = standardMaterial.get('normalMap') || defaultNormalMap; - var uvRepeat = standardMaterial.get('uvRepeat'); - var uvOffset = standardMaterial.get('uvOffset'); + getWidth: function () { + return this._width; + }, - roughGlossMap = roughGlossMap || defaultRoughnessMap; + getHeight: function () { + return this._height; + }, - if (prevMaterial !== gBufferMat) { - gBufferMat.set('glossiness', glossiness); - gBufferMat.set('normalMap', normalMap); - gBufferMat.set('roughGlossMap', roughGlossMap); - gBufferMat.set('useRoughGlossMap', +useRoughGlossMap); - gBufferMat.set('useRoughness', +useRoughnessWorkflow); - gBufferMat.set('doubleSided', +doubleSided); - gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0); - gBufferMat.set('uvRepeat', uvRepeat); - gBufferMat.set('uvOffset', uvOffset); - } - else { - program.setUniform( - gl, '1f', 'glossiness', glossiness - ); + getViewportAspect: function () { + return this._width / this._height; + }, - if (previousNormalMap !== normalMap) { - attachTextureToSlot(this, program, 'normalMap', normalMap, 0); + render: function (scene, camera) { + + if (this.clear) { + var color = this.color; + var ctx = this.ctx; + var dpr = this.devicePixelRatio; + var w = this._width * dpr; + var h = this._height * dpr; + if (color && color[3] === 0) { + ctx.clearRect(0, 0, w, h); } - if (previousRougGlossMap !== roughGlossMap) { - attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1); + else { + // Has transparency + if (color[3] < 1) { + ctx.clearRect(0, 0, w, h); + } + ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color); + ctx.fillRect(0, 0, w, h); } - program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap); - program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow); - program.setUniform(gl, '1i', 'doubleSided', +doubleSided); - program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0); - if (uvRepeat != null) { - program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); + } + + scene.update(); + camera.update(); + + var opaqueList = scene.opaqueList; + var transparentList = scene.transparentList; + var list = opaqueList.concat(transparentList); + + this.renderPass(list, camera); + }, + + renderPass: function (list, camera) { + var viewProj = mat4$8.create(); + mat4$8.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array); + var worldViewProjMat = mat4$8.create(); + var posViewSpace = vec3$17.create(); + + var primitives = this._primitives; + var trianglesPool = this._triangles; + var linesPool = this._lines; + var pointsPool = this._points; + + trianglesPool.reset(); + linesPool.reset(); + pointsPool.reset(); + + var nPrimitive = 0; + + var indices = [0, 0, 0]; + var matColor = []; + for (var i = 0; i < list.length; i++) { + var renderable = list[i]; + + mat4$8.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array); + + var geometry = renderable.geometry; + var material = renderable.material; + var attributes = geometry.attributes; + + // alpha is default 1 + if (material.color.length == 3) { + vec3$17.copy(matColor, material.color); + matColor[3] = 1; } - if (uvOffset != null) { - program.setUniform(gl, '2f', 'uvOffset', uvOffset); + else { + vec4$2.copy(matColor, material.color); } - } - previousNormalMap = normalMap; - previousRougGlossMap = roughGlossMap; + var nVertex = geometry.vertexCount; + // Only support TRIANGLES, LINES, POINTS draw modes + switch (renderable.mode) { + case glenum.TRIANGLES: + if (geometry.isUseIndices()) { + var nFace = geometry.triangleCount; + for (var j = 0; j < nFace; j++) { + geometry.getFace(j, indices); - previousRenderable = renderable; - }; -} + var triangle = trianglesPool.pick(); + triangle.material = material; -function getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) { - var previousDiffuseMap; - var previousRenderable; - var previousMetalnessMap; + var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); - return function (renderable, gBufferMat, prevMaterial) { - // Material not change - if (previousRenderable && previousRenderable.material === renderable.material) { - return; + if (! clipped) { + primitives[nPrimitive++] = triangle; + } + } + } + else { + for (var j = 0; j < nVertex;) { + indices[0] = j++; + indices[1] = j++; + indices[2] = j++; + + var triangle = trianglesPool.pick(); + triangle.material = material; + + var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = triangle; + } + } + } + break; + case glenum.LINES: + // LINES mode can't use face + for (var j = 0; j < nVertex;) { + indices[0] = j++; + indices[1] = j++; + var line = linesPool.pick(); + line.material = material; + line.lineWidth = renderable.lineWidth; + + var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = line; + } + } + break; + case glenum.POINTS: + for (var j = 0; j < nVertex; j++) { + indices[0] = j; + var point = pointsPool.pick(); + point.material = material; + + var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor); + + if (! clipped) { + primitives[nPrimitive++] = point; + } + } + // POINTS mode can't use face + break; + } } - var program = renderable.__program; - var standardMaterial = renderable.material; + trianglesPool.shrink(); + linesPool.shrink(); + pointsPool.shrink(); - var color = standardMaterial.get('color'); - var metalness = standardMaterial.get('metalness'); + primitives.length = nPrimitive; - var diffuseMap = standardMaterial.get('diffuseMap'); - var metalnessMap = standardMaterial.get('metalnessMap'); + primitives.sort(depthSortFunc); + this._drawPrimitives(primitives); + }, - var uvRepeat = standardMaterial.get('uvRepeat'); - var uvOffset = standardMaterial.get('uvOffset'); + _setPrimitive: (function () { + var vertexColor = vec4Create(); + return function (primitive, indices, size, attributes, worldViewProjMat, matColor) { + var colorAttrib = attributes.color; + var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0; + var priColor = primitive.color; - var useMetalnessMap = !!metalnessMap; + primitive.depth = 0; + if (useVertexColor) { + vec4$2.set(priColor, 0, 0, 0, 0); + } - diffuseMap = diffuseMap || defaultDiffuseMap; - metalnessMap = metalnessMap || defaultMetalnessMap; + var clipped = true; - if (prevMaterial !== gBufferMat) { - gBufferMat.set('color', color); - gBufferMat.set('metalness', metalness); - gBufferMat.set('diffuseMap', diffuseMap); - gBufferMat.set('metalnessMap', metalnessMap); - gBufferMat.set('useMetalnessMap', +useMetalnessMap); - gBufferMat.set('uvRepeat', uvRepeat); - gBufferMat.set('uvOffset', uvOffset); + var percent = 1 / size; + for (var i = 0; i < size; i++) { + var coord = primitive.vertices[i]; + attributes.position.get(indices[i], coord); + coord[3] = 1; + vec4$2.transformMat4(coord, coord, worldViewProjMat); + if (useVertexColor) { + colorAttrib.get(indices[i], vertexColor); + // Average vertex color + // Each primitive only call fill or stroke once + // So color must be the same + vec4$2.scaleAndAdd(priColor, priColor, vertexColor, percent); + } - gBufferMat.set('linear', +standardMaterial.linear); - } - else { - program.setUniform(gl, '1f', 'metalness', metalness); + // Clipping + var x = coord[0]; + var y = coord[1]; + var z = coord[2]; + var w = coord[3]; - program.setUniform(gl, '3f', 'color', color); - if (previousDiffuseMap !== diffuseMap) { - attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0); + // TODO Point clipping + if (x > -w && x < w && y > -w && y < w && z > -w && z < w) { + clipped = false; + } + + var invW = 1 / w; + coord[0] = x * invW; + coord[1] = y * invW; + coord[2] = z * invW; + // Use primitive average depth; + primitive.depth += coord[2]; } - if (previousMetalnessMap !== metalnessMap) { - attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1); + + if (! clipped) { + primitive.depth /= size; + + if (useVertexColor) { + vec4$2.mul(priColor, priColor, matColor); + } + else { + vec4$2.copy(priColor, matColor); + } } - program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap); - program.setUniform(gl, '2f', 'uvRepeat', uvRepeat); - program.setUniform(gl, '2f', 'uvOffset', uvOffset); - program.setUniform(gl, '1i', 'linear', +standardMaterial.linear); + return clipped; } + })(), - previousDiffuseMap = diffuseMap; - previousMetalnessMap = metalnessMap; + _drawPrimitives: function (primitives) { + var ctx = this.ctx; + ctx.save(); - previousRenderable = renderable; - }; -} + var prevMaterial; -/** - * GBuffer is provided for deferred rendering and SSAO, SSR pass. - * It will do two passes rendering to three target textures. See - * + {@link clay.deferred.GBuffer#getTargetTexture1} - * + {@link clay.deferred.GBuffer#getTargetTexture2} - * + {@link clay.deferred.GBuffer#getTargetTexture3} - * @constructor - * @alias clay.deferred.GBuffer - * @extends clay.core.Base - */ -var GBuffer = Base.extend(function () { + var dpr = this.devicePixelRatio; + var width = this._width * dpr; + var height = this._height * dpr; + var halfWidth = width / 2; + var halfHeight = height / 2; - return { + var prevLineWidth; + var prevStrokeColor; - enableTargetTexture1: true, + for (var i = 0; i < primitives.length; i++) { + var primitive = primitives[i]; + var vertices = primitive.vertices; - enableTargetTexture2: true, + var primitiveType = primitive.type; + var material = primitive.material; + if (material !== prevMaterial) { + // Set material + ctx.globalAlpha = material.opacity; + prevMaterial = material; + } - enableTargetTexture3: true, + var colorStr = vec4ToColorStr(primitive.color); + switch (primitiveType) { + case PRIMITIVE_TRIANGLE: + var v0 = vertices[0]; + var v1 = vertices[1]; + var v2 = vertices[2]; + ctx.fillStyle = colorStr; + ctx.beginPath(); + ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); + ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); + ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight); + ctx.closePath(); + ctx.fill(); + break; + case PRIMITIVE_LINE: + var v0 = vertices[0]; + var v1 = vertices[1]; + var lineWidth = primitive.lineWidth; + if (prevStrokeColor !== colorStr) { + prevStrokeColor = ctx.strokeStyle = colorStr; + } + if (lineWidth !== prevLineWidth) { + ctx.lineWidth = prevLineWidth = lineWidth; + } + ctx.beginPath(); + ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight); + ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight); + ctx.stroke(); + break; + case PRIMITIVE_POINT: + var pointSize = material.pointSize; + var pointShape = material.pointShape; + var halfSize = pointSize / 2; + if (pointSize > 0) { + var v0 = vertices[0]; + var cx = (v0[0] + 1) * halfWidth; + var cy = (-v0[1] + 1) * halfHeight; - renderTransparent: false, + ctx.fillStyle = colorStr; + if (pointShape === 'rectangle') { + ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize); + } + else if (pointShape === 'circle') { + ctx.beginPath(); + ctx.arc(cx, cy, halfSize, 0, Math.PI * 2); + ctx.fill(); + } + } + break; + } + } - _renderList: [], - // - R: normal.x - // - G: normal.y - // - B: normal.z - // - A: glossiness - _gBufferTex1: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST, - // PENDING - type: Texture.HALF_FLOAT - }), + ctx.restore(); + }, - // - R: depth - _gBufferTex2: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST, - // format: Texture.DEPTH_COMPONENT, - // type: Texture.UNSIGNED_INT + dispose: function () { + this._triangles.clear(); + this._lines.clear(); + this._points.clear(); + this._primitives = []; - format: Texture.DEPTH_STENCIL, - type: Texture.UNSIGNED_INT_24_8_WEBGL - }), + this.ctx = null; + this.canvas = null; + } +}); - // - R: albedo.r - // - G: albedo.g - // - B: albedo.b - // - A: metalness - _gBufferTex3: new Texture2D({ - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST - }), +// PENDING +// Use topological sort ? - _defaultNormalMap: new Texture2D({ - image: createFillCanvas('#000') - }), - _defaultRoughnessMap: new Texture2D({ - image: createFillCanvas('#fff') - }), - _defaultMetalnessMap: new Texture2D({ - image: createFillCanvas('#fff') - }), - _defaultDiffuseMap: new Texture2D({ - image: createFillCanvas('#fff') - }), +/** + * Node of graph based post processing. + * + * @constructor clay.compositor.Node + * @extends clay.core.Base + * + */ +var Node$1 = Base.extend(function () { + return /** @lends clay.compositor.Node# */ { + /** + * @type {string} + */ + name: '', - _frameBuffer: new FrameBuffer(), + /** + * Input links, will be updated by the graph + * @example: + * inputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + inputLinks: {}, - _gBufferMaterial1: new Material({ - shader: new Shader( - Shader.source('clay.deferred.gbuffer.vertex'), - Shader.source('clay.deferred.gbuffer1.fragment') - ), - vertexDefines: { - FIRST_PASS: null - }, - fragmentDefines: { - FIRST_PASS: null - } - }), - _gBufferMaterial2: new Material({ - shader: new Shader( - Shader.source('clay.deferred.gbuffer.vertex'), - Shader.source('clay.deferred.gbuffer2.fragment') - ) - }), + /** + * Output links, will be updated by the graph + * @example: + * outputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + outputLinks: {}, - _debugPass: new Pass({ - fragment: Shader.source('clay.deferred.gbuffer.debug') - }) - }; -}, /** @lends clay.deferred.GBuffer# */{ + // Save the output texture of previous frame + // Will be used when there exist a circular reference + _prevOutputTextures: {}, + _outputTextures: {}, - /** - * Set G Buffer size. - * @param {number} width - * @param {number} height - */ - resize: function (width, height) { - if (this._gBufferTex1.width === width - && this._gBufferTex1.height === height - ) { - return; - } - this._gBufferTex1.width = width; - this._gBufferTex1.height = height; + // Example: { name: 2 } + _outputReferences: {}, - this._gBufferTex2.width = width; - this._gBufferTex2.height = height; + _rendering: false, + // If rendered in this frame + _rendered: false, - this._gBufferTex3.width = width; - this._gBufferTex3.height = height; - }, + _compositor: null + }; +}, +/** @lends clay.compositor.Node.prototype */ +{ - // TODO is dpr needed? - setViewport: function (x, y, width, height, dpr) { - var viewport; - if (typeof x === 'object') { - viewport = x; + // TODO Remove parameter function callback + updateParameter: function (outputName, renderer) { + var outputInfo = this.outputs[outputName]; + var parameters = outputInfo.parameters; + var parametersCopy = outputInfo._parametersCopy; + if (!parametersCopy) { + parametersCopy = outputInfo._parametersCopy = {}; + } + if (parameters) { + for (var key in parameters) { + if (key !== 'width' && key !== 'height') { + parametersCopy[key] = parameters[key]; + } + } + } + var width, height; + if (parameters.width instanceof Function) { + width = parameters.width.call(this, renderer); } else { - viewport = { - x: x, y: y, - width: width, height: height, - devicePixelRatio: dpr || 1 - }; + width = parameters.width; } - this._frameBuffer.viewport = viewport; - }, - - getViewport: function () { - if (this._frameBuffer.viewport) { - return this._frameBuffer.viewport; + if (parameters.height instanceof Function) { + height = parameters.height.call(this, renderer); } else { - return { - x: 0, y: 0, - width: this._gBufferTex1.width, - height: this._gBufferTex1.height, - devicePixelRatio: 1 - }; + height = parameters.height; + } + if ( + parametersCopy.width !== width + || parametersCopy.height !== height + ) { + if (this._outputTextures[outputName]) { + this._outputTextures[outputName].dispose(renderer.gl); + } } + parametersCopy.width = width; + parametersCopy.height = height; + + return parametersCopy; }, /** - * Update G Buffer - * @param {clay.Renderer} renderer - * @param {clay.Scene} scene - * @param {clay.camera.Perspective} camera + * Set parameter + * @param {string} name + * @param {} value */ - update: function (renderer, scene, camera) { + setParameter: function (name, value) {}, + /** + * Get parameter value + * @param {string} name + * @return {} + */ + getParameter: function (name) {}, + /** + * Set parameters + * @param {Object} obj + */ + setParameters: function (obj) { + for (var name in obj) { + this.setParameter(name, obj[name]); + } + }, - var gl = renderer.gl; + render: function () {}, - var frameBuffer = this._frameBuffer; - var viewport = frameBuffer.viewport; - var opaqueList = scene.opaqueList; - var transparentList = scene.transparentList; + getOutput: function (renderer /*optional*/, name) { + if (name == null) { + // Return the output texture without rendering + name = renderer; + return this._outputTextures[name]; + } + var outputInfo = this.outputs[name]; + if (!outputInfo) { + return ; + } - var offset = 0; - var renderList = this._renderList; - for (var i = 0; i < opaqueList.length; i++) { - if (!opaqueList[i].ignoreGBuffer) { - renderList[offset++] = opaqueList[i]; + // Already been rendered in this frame + if (this._rendered) { + // Force return texture in last frame + if (outputInfo.outputLastFrame) { + return this._prevOutputTextures[name]; } - } - if (this.renderTransparent) { - for (var i = 0; i < transparentList.length; i++) { - if (!transparentList[i].ignoreGBuffer) { - renderList[offset++] = transparentList[i]; - } + else { + return this._outputTextures[name]; } } - renderList.length = offset; - - gl.clearColor(0, 0, 0, 0); - gl.depthMask(true); - gl.colorMask(true, true, true, true); - gl.disable(gl.BLEND); - - var enableTargetTexture1 = this.enableTargetTexture1; - var enableTargetTexture2 = this.enableTargetTexture2; - var enableTargetTexture3 = this.enableTargetTexture3; - if (!enableTargetTexture1 && !enableTargetTexture3) { - console.warn('Can\'t disable targetTexture1 targetTexture3 both'); - enableTargetTexture1 = true; + else if ( + // TODO + this._rendering // Solve Circular Reference + ) { + if (!this._prevOutputTextures[name]) { + // Create a blank texture at first pass + this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {}); + } + return this._prevOutputTextures[name]; } - if (enableTargetTexture2) { - frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT); - } + this.render(renderer); - // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow - renderer.bindSceneRendering(scene); - if (enableTargetTexture1) { - // Pass 1 - frameBuffer.attach(this._gBufferTex1); - frameBuffer.bind(renderer); + return this._outputTextures[name]; + }, - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); + removeReference: function (outputName) { + this._outputReferences[outputName]--; + if (this._outputReferences[outputName] === 0) { + var outputInfo = this.outputs[outputName]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[outputName]) { + this._compositor.releaseTexture(this._prevOutputTextures[outputName]); + } + this._prevOutputTextures[outputName] = this._outputTextures[outputName]; } - gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); + else { + // Output of this node have alreay been used by all other nodes + // Put the texture back to the pool. + this._compositor.releaseTexture(this._outputTextures[outputName]); } - var gBufferMaterial1 = this._gBufferMaterial1; - var passConfig = { - getMaterial: function () { - return gBufferMaterial1; - }, - beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap), - sortCompare: renderer.opaqueSortCompare - }; - // FIXME Use MRT if possible - renderer.renderPass(renderList, camera, passConfig); + } + }, + link: function (inputPinName, fromNode, fromPinName) { + + // The relationship from output pin to input pin is one-on-multiple + this.inputLinks[inputPinName] = { + node: fromNode, + pin: fromPinName + }; + if (!fromNode.outputLinks[fromPinName]) { + fromNode.outputLinks[fromPinName] = []; } - if (enableTargetTexture3) { + fromNode.outputLinks[fromPinName].push({ + node: this, + pin: inputPinName + }); - // Pass 2 - frameBuffer.attach(this._gBufferTex3); - frameBuffer.bind(renderer); + // Enabled the pin texture in shader + this.pass.material.enableTexture(inputPinName); + }, - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); - } - gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); - } + clear: function () { + this.inputLinks = {}; + this.outputLinks = {}; + }, - var gBufferMaterial2 = this._gBufferMaterial2; - var passConfig = { - getMaterial: function () { - return gBufferMaterial2; - }, - beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap), - sortCompare: renderer.opaqueSortCompare - }; - renderer.renderPass(renderList, camera, passConfig); + updateReference: function (outputName) { + if (!this._rendering) { + this._rendering = true; + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + link.node.updateReference(link.pin); + } + this._rendering = false; + } + if (outputName) { + this._outputReferences[outputName] ++; } + }, - renderer.bindSceneRendering(null); - frameBuffer.unbind(renderer); + beforeFrame: function () { + this._rendered = false; + + for (var name in this.outputLinks) { + this._outputReferences[name] = 0; + } }, - renderDebug: function (renderer, camera, type, viewport) { - var debugTypes = { - normal: 0, - depth: 1, - position: 2, - glossiness: 3, - metalness: 4, - albedo: 5 - }; - if (debugTypes[type] == null) { - console.warn('Unkown type "' + type + '"'); - // Default use normal - type = 'normal'; + afterFrame: function () { + // Put back all the textures to pool + for (var name in this.outputLinks) { + if (this._outputReferences[name] > 0) { + var outputInfo = this.outputs[name]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[name]) { + this._compositor.releaseTexture(this._prevOutputTextures[name]); + } + this._prevOutputTextures[name] = this._outputTextures[name]; + } + else { + this._compositor.releaseTexture(this._outputTextures[name]); + } + } } + } +}); - renderer.saveClear(); - renderer.saveViewport(); - renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT; +/** + * @constructor clay.compositor.Graph + * @extends clay.core.Base + */ +var Graph = Base.extend(function () { + return /** @lends clay.compositor.Graph# */ { + /** + * @type {Array.} + */ + nodes: [] + }; +}, +/** @lends clay.compositor.Graph.prototype */ +{ - if (viewport) { - renderer.setViewport(viewport); + /** + * Mark to update + */ + dirty: function () { + this._dirty = true; + }, + /** + * @param {clay.compositor.Node} node + */ + addNode: function (node) { + + if (this.nodes.indexOf(node) >= 0) { + return; } - var viewProjectionInv = new Matrix4(); - Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - var debugPass = this._debugPass; - debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]); - debugPass.setUniform('gBufferTexture1', this._gBufferTex1); - debugPass.setUniform('gBufferTexture2', this._gBufferTex2); - debugPass.setUniform('gBufferTexture3', this._gBufferTex3); - debugPass.setUniform('debug', debugTypes[type]); - debugPass.setUniform('viewProjectionInv', viewProjectionInv.array); - debugPass.render(renderer); + this.nodes.push(node); - renderer.restoreViewport(); - renderer.restoreClear(); + this._dirty = true; }, - /** - * Get first target texture. - * Channel storage: - * + R: normal.x * 0.5 + 0.5 - * + G: normal.y * 0.5 + 0.5 - * + B: normal.z * 0.5 + 0.5 - * + A: glossiness - * @return {clay.Texture2D} + * @param {clay.compositor.Node|string} node */ - getTargetTexture1: function () { - return this._gBufferTex1; + removeNode: function (node) { + if (typeof node === 'string') { + node = this.getNodeByName(node); + } + var idx = this.nodes.indexOf(node); + if (idx >= 0) { + this.nodes.splice(idx, 1); + this._dirty = true; + } }, - /** - * Get second target texture. - * Channel storage: - * + R: depth - * @return {clay.Texture2D} + * @param {string} name + * @return {clay.compositor.Node} */ - getTargetTexture2: function () { - return this._gBufferTex2; + getNodeByName: function (name) { + for (var i = 0; i < this.nodes.length; i++) { + if (this.nodes[i].name === name) { + return this.nodes[i]; + } + } }, - /** - * Get third target texture. - * Channel storage: - * + R: albedo.r - * + G: albedo.g - * + B: albedo.b - * + A: metalness - * @return {clay.Texture2D} + * Update links of graph */ - getTargetTexture3: function () { - return this._gBufferTex3; + update: function () { + for (var i = 0; i < this.nodes.length; i++) { + this.nodes[i].clear(); + } + // Traverse all the nodes and build the graph + for (var i = 0; i < this.nodes.length; i++) { + var node = this.nodes[i]; + + if (!node.inputs) { + continue; + } + for (var inputName in node.inputs) { + if (!node.inputs[inputName]) { + continue; + } + if (node.pass && !node.pass.material.isUniformEnabled(inputName)) { + console.warn('Pin ' + node.name + '.' + inputName + ' not used.'); + continue; + } + var fromPinInfo = node.inputs[inputName]; + + var fromPin = this.findPin(fromPinInfo); + if (fromPin) { + node.link(inputName, fromPin.node, fromPin.pin); + } + else { + if (typeof fromPinInfo === 'string') { + console.warn('Node ' + fromPinInfo + ' not exist'); + } + else { + console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist'); + } + } + } + } }, + findPin: function (input) { + var node; + // Try to take input as a directly a node + if (typeof input === 'string' || input instanceof Node$1) { + input = { + node: input + }; + } - /** - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { + if (typeof input.node === 'string') { + for (var i = 0; i < this.nodes.length; i++) { + var tmp = this.nodes[i]; + if (tmp.name === input.node) { + node = tmp; + } + } + } + else { + node = input.node; + } + if (node) { + var inputPin = input.pin; + if (!inputPin) { + // Use first pin defaultly + if (node.outputs) { + inputPin = Object.keys(node.outputs)[0]; + } + } + if (node.outputs[inputPin]) { + return { + node: node, + pin: inputPin + }; + } + } } }); -var vec3$17 = glmatrix.vec3; -var vec2$1 = glmatrix.vec2; - /** - * @constructor clay.geometry.Cone - * @extends clay.Geometry - * @param {Object} [opt] - * @param {number} [opt.topRadius] - * @param {number} [opt.bottomRadius] - * @param {number} [opt.height] - * @param {number} [opt.capSegments] - * @param {number} [opt.heightSegments] + * Compositor provide graph based post processing + * + * @constructor clay.compositor.Compositor + * @extends clay.compositor.Graph + * */ -var Cone$1 = Geometry.extend( -/** @lends clay.geometry.Cone# */ -{ - dynamic: false, - /** - * @type {number} - */ - topRadius: 0, - - /** - * @type {number} - */ - bottomRadius: 1, - - /** - * @type {number} - */ - height: 2, +var Compositor = Graph.extend(function() { + return { + // Output node + _outputs: [], - /** - * @type {number} - */ - capSegments: 20, + _texturePool: new TexturePool(), - /** - * @type {number} - */ - heightSegments: 1 -}, function() { - this.build(); + _frameBuffer: new FrameBuffer({ + depthBuffer: false + }) + }; }, -/** @lends clay.geometry.Cone.prototype */ +/** @lends clay.compositor.Compositor.prototype */ { + addNode: function(node) { + Graph.prototype.addNode.call(this, node); + node._compositor = this; + }, /** - * Build cone geometry + * @param {clay.Renderer} renderer */ - build: function() { - var positions = []; - var texcoords = []; - var faces = []; - positions.length = 0; - texcoords.length = 0; - faces.length = 0; - // Top cap - var capSegRadial = Math.PI * 2 / this.capSegments; - - var topCap = []; - var bottomCap = []; - - var r1 = this.topRadius; - var r2 = this.bottomRadius; - var y = this.height / 2; - - var c1 = vec3$17.fromValues(0, y, 0); - var c2 = vec3$17.fromValues(0, -y, 0); - for (var i = 0; i < this.capSegments; i++) { - var theta = i * capSegRadial; - var x = r1 * Math.sin(theta); - var z = r1 * Math.cos(theta); - topCap.push(vec3$17.fromValues(x, y, z)); + render: function(renderer, frameBuffer) { + if (this._dirty) { + this.update(); + this._dirty = false; - x = r2 * Math.sin(theta); - z = r2 * Math.cos(theta); - bottomCap.push(vec3$17.fromValues(x, -y, z)); + this._outputs.length = 0; + for (var i = 0; i < this.nodes.length; i++) { + if (!this.nodes[i].outputs) { + this._outputs.push(this.nodes[i]); + } + } } - // Build top cap - positions.push(c1); - // FIXME - texcoords.push(vec2$1.fromValues(0, 1)); - var n = this.capSegments; - for (var i = 0; i < n; i++) { - positions.push(topCap[i]); - // FIXME - texcoords.push(vec2$1.fromValues(i / n, 0)); - faces.push([0, i+1, (i+1) % n + 1]); + for (var i = 0; i < this.nodes.length; i++) { + // Update the reference number of each output texture + this.nodes[i].beforeFrame(); } - // Build bottom cap - var offset = positions.length; - positions.push(c2); - texcoords.push(vec2$1.fromValues(0, 1)); - for (var i = 0; i < n; i++) { - positions.push(bottomCap[i]); - // FIXME - texcoords.push(vec2$1.fromValues(i / n, 0)); - faces.push([offset, offset+((i+1) % n + 1), offset+i+1]); + for (var i = 0; i < this._outputs.length; i++) { + this._outputs[i].updateReference(); } - // Build side - offset = positions.length; - var n2 = this.heightSegments; - for (var i = 0; i < n; i++) { - for (var j = 0; j < n2+1; j++) { - var v = j / n2; - positions.push(vec3$17.lerp(vec3$17.create(), topCap[i], bottomCap[i], v)); - texcoords.push(vec2$1.fromValues(i / n, v)); - } + for (var i = 0; i < this._outputs.length; i++) { + this._outputs[i].render(renderer, frameBuffer); } - for (var i = 0; i < n; i++) { - for (var j = 0; j < n2; j++) { - var i1 = i * (n2 + 1) + j; - var i2 = ((i + 1) % n) * (n2 + 1) + j; - var i3 = ((i + 1) % n) * (n2 + 1) + j + 1; - var i4 = i * (n2 + 1) + j + 1; - faces.push([offset+i2, offset+i1, offset+i4]); - faces.push([offset+i4, offset+i3, offset+i2]); - } + + for (var i = 0; i < this.nodes.length; i++) { + // Clear up + this.nodes[i].afterFrame(); } + }, - this.attributes.position.fromArray(positions); - this.attributes.texcoord0.fromArray(texcoords); + allocateTexture: function (parameters) { + return this._texturePool.get(parameters); + }, - this.initIndicesFromArray(faces); + releaseTexture: function (parameters) { + this._texturePool.put(parameters); + }, - this.generateVertexNormals(); + getFrameBuffer: function () { + return this._frameBuffer; + }, - this.boundingBox = new BoundingBox(); - var r = Math.max(this.topRadius, this.bottomRadius); - this.boundingBox.min.set(-r, -this.height/2, -r); - this.boundingBox.max.set(r, this.height/2, r); + /** + * Dispose compositor + * @param {clay.Renderer} renderer + */ + dispose: function (renderer) { + this._texturePool.clear(renderer); } }); /** - * @constructor clay.geometry.Cylinder - * @extends clay.Geometry - * @param {Object} [opt] - * @param {number} [opt.radius] - * @param {number} [opt.height] - * @param {number} [opt.capSegments] - * @param {number} [opt.heightSegments] + * @constructor clay.compositor.SceneNode + * @extends clay.compositor.Node */ -var Cylinder$1 = Geometry.extend( -/** @lends clay.geometry.Cylinder# */ +var SceneNode$1 = Node$1.extend( +/** @lends clay.compositor.SceneNode# */ { - dynamic: false, - /** - * @type {number} - */ - radius: 1, - + name: 'scene', /** - * @type {number} + * @type {clay.Scene} */ - height: 2, - + scene: null, /** - * @type {number} + * @type {clay.Camera} */ - capSegments: 50, - + camera: null, /** - * @type {number} + * @type {boolean} */ - heightSegments: 1 -}, function() { - this.build(); -}, -/** @lends clay.geometry.Cylinder.prototype */ -{ + autoUpdateScene: true, /** - * Build cylinder geometry + * @type {boolean} */ - build: function() { - var cone = new Cone$1({ - topRadius: this.radius, - bottomRadius: this.radius, - capSegments: this.capSegments, - heightSegments: this.heightSegments, - height: this.height - }); + preZ: false - this.attributes.position.value = cone.attributes.position.value; - this.attributes.normal.value = cone.attributes.normal.value; - this.attributes.texcoord0.value = cone.attributes.texcoord0.value; - this.indices = cone.indices; +}, function() { + this.frameBuffer = new FrameBuffer(); +}, { + render: function(renderer) { - this.boundingBox = cone.boundingBox; - } -}); + this._rendering = true; + var _gl = renderer.gl; -var lightvolumeGlsl = "@export clay.deferred.light_volume.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nattribute vec3 position : POSITION;\nvarying vec3 v_Position;\nvoid main()\n{\n gl_Position = worldViewProjection * vec4(position, 1.0);\n v_Position = position;\n}\n@end"; + this.trigger('beforerender'); -var spotGlsl = "@export clay.deferred.spot_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\n@import clay.util.calculate_attenuation\nuniform vec3 lightPosition;\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform float umbraAngleCosine;\nuniform float penumbraAngleCosine;\nuniform float lightRange;\nuniform float falloffFactor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform mat4 lightMatrix;\nuniform float lightShadowMapSize;\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n float attenuation = lightAttenuation(dist, lightRange);\n float c = dot(-normalize(lightDirection), L);\n float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrix, position, lightShadowMapSize\n );\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; + var renderInfo; -var directionalGlsl = "@export clay.deferred.directional_light\n@import clay.deferred.chunk.light_head\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform sampler2D lightShadowMap;\nuniform float lightShadowMapSize;\nuniform mat4 lightMatrices[SHADOW_CASCADE];\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\n#endif\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = -normalize(lightDirection);\n vec3 V = normalize(eyePosition - position);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n gl_FragColor.rgb = lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = 1.0;\n for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\n if (\n z >= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"; + if (!this.outputs) { -var ambientGlsl = "@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"; + renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); -var ambientshGlsl = "@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"; + } + else { -var ambientcubemapGlsl = "@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"; + var frameBuffer = this.frameBuffer; + for (var name in this.outputs) { + var parameters = this.updateParameter(name, renderer); + var outputInfo = this.outputs[name]; + var texture = this._compositor.allocateTexture(parameters); + this._outputTextures[name] = texture; -var pointGlsl = "@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"; + var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; + if (typeof(attachment) == 'string') { + attachment = _gl[attachment]; + } + frameBuffer.attach(texture, attachment); + } + frameBuffer.bind(renderer); -var sphereGlsl = "@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"; + // MRT Support in chrome + // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html + var ext = renderer.getGLExtension('EXT_draw_buffers'); + if (ext) { + var bufs = []; + for (var attachment in this.outputs) { + attachment = parseInt(attachment); + if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) { + bufs.push(attachment); + } + } + ext.drawBuffersEXT(bufs); + } -var tubeGlsl = "@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"; + // Always clear + // PENDING + renderer.saveClear(); + renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT; + renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ); + renderer.restoreClear(); -// Light-pre pass deferred rendering -// http://www.realtimerendering.com/blog/deferred-lighting-approaches/ -// Light shaders -Shader.import(prezGlsl); -Shader.import(utilGlsl); -Shader.import(lightvolumeGlsl); + frameBuffer.unbind(renderer); + } -// Light shaders -Shader.import(spotGlsl); -Shader.import(directionalGlsl); -Shader.import(ambientGlsl); -Shader.import(ambientshGlsl); -Shader.import(ambientcubemapGlsl); -Shader.import(pointGlsl); -Shader.import(sphereGlsl); -Shader.import(tubeGlsl); + this.trigger('afterrender', renderInfo); -Shader.import(prezGlsl); + this._rendering = false; + this._rendered = true; + } +}); /** - * Deferred renderer - * @constructor - * @alias clay.deferred.Renderer - * @extends clay.core.Base + * @constructor clay.compositor.TextureNode + * @extends clay.compositor.Node */ -var DeferredRenderer = Base.extend(function () { - - var fullQuadVertex = Shader.source('clay.compositor.vertex'); - var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex'); - - var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light')); - - var lightAccumulateBlendFunc = function (gl) { - gl.blendEquation(gl.FUNC_ADD); - gl.blendFunc(gl.ONE, gl.ONE); - }; - - var createLightPassMat = function (shader) { - return new Material({ - shader: shader, - blend: lightAccumulateBlendFunc, - transparent: true, - depthMask: false - }); - }; +var TextureNode$1 = Node$1.extend(function() { + return /** @lends clay.compositor.TextureNode# */ { + /** + * @type {clay.Texture2D} + */ + texture: null, - var createVolumeShader = function (name) { - return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name)); + // Texture node must have output without parameters + outputs: { + color: {} + } }; +}, function () { +}, { - // Rotate and positioning to fit the spot light - // Which the cusp of cone pointing to the positive z - // and positioned on the origin - var coneGeo = new Cone$1({ - capSegments: 10 - }); - var mat = new Matrix4(); - mat.rotateX(Math.PI / 2) - .translate(new Vector3(0, -1, 0)); + getOutput: function (renderer, name) { + return this.texture; + }, - coneGeo.applyTransform(mat); + // Do nothing + beforeFrame: function () {}, + afterFrame: function () {} +}); - var cylinderGeo = new Cylinder$1({ - capSegments: 10 - }); - // Align with x axis - mat.identity().rotateZ(Math.PI / 2); - cylinderGeo.applyTransform(mat); +// TODO Shader library +// TODO curlnoise demo wrong - return /** @lends clay.deferred.Renderer# */ { +// PENDING +// Use topological sort ? +/** + * Filter node + * + * @constructor clay.compositor.FilterNode + * @extends clay.compositor.Node + * + * @example + var node = new clay.compositor.Node({ + name: 'fxaa', + shader: clay.Shader.source('clay.compositor.fxaa'), + inputs: { + texture: { + node: 'scene', + pin: 'color' + } + }, + // Multiple outputs is preserved for MRT support in WebGL2.0 + outputs: { + color: { + attachment: clay.FrameBuffer.COLOR_ATTACHMENT0 + parameters: { + format: clay.Texture.RGBA, + width: 512, + height: 512 + }, + // Node will keep the RTT rendered in last frame + keepLastFrame: true, + // Force the node output the RTT rendered in last frame + outputLastFrame: true + } + } + }); + * + */ +var FilterNode$1 = Node$1.extend(function () { + return /** @lends clay.compositor.Node# */ { /** - * Provide ShadowMapPass for shadow rendering. - * @type {clay.prePass.ShadowMap} + * @type {string} */ - shadowMapPass: null, + name: '', + /** - * If enable auto resizing from given defualt renderer size. - * @type {boolean} + * @type {Object} */ - autoResize: true, + inputs: {}, - _createLightPassMat: createLightPassMat, + /** + * @type {Object} + */ + outputs: null, - _gBuffer: new GBuffer(), + /** + * @type {string} + */ + shader: '', - _lightAccumFrameBuffer: new FrameBuffer({ - depthBuffer: false - }), + /** + * Input links, will be updated by the graph + * @example: + * inputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + inputLinks: {}, - _lightAccumTex: new Texture2D({ - // FIXME Device not support float texture - type: Texture.HALF_FLOAT, - minFilter: Texture.NEAREST, - magFilter: Texture.NEAREST - }), + /** + * Output links, will be updated by the graph + * @example: + * outputName: { + * node: someNode, + * pin: 'xxxx' + * } + * @type {Object} + */ + outputLinks: {}, - _fullQuadPass: new Pass({ - blendWithPrevious: true - }), + /** + * @type {clay.compositor.Pass} + */ + pass: null, - _directionalLightMat: createLightPassMat(directionalLightShader), + // Save the output texture of previous frame + // Will be used when there exist a circular reference + _prevOutputTextures: {}, + _outputTextures: {}, - _ambientMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_light') - )), - _ambientSHMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light') - )), - _ambientCubemapMat: createLightPassMat(new Shader( - fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light') - )), + // Example: { name: 2 } + _outputReferences: {}, - _spotLightShader: createVolumeShader('spot_light'), - _pointLightShader: createVolumeShader('point_light'), + _rendering: false, + // If rendered in this frame + _rendered: false, - _sphereLightShader: createVolumeShader('sphere_light'), - _tubeLightShader: createVolumeShader('tube_light'), + _compositor: null + }; +}, function () { - _lightSphereGeo: new Sphere$1({ - widthSegments: 10, - heightSegements: 10 - }), + var pass = new Pass({ + fragment: this.shader + }); + this.pass = pass; +}, +/** @lends clay.compositor.Node.prototype */ +{ + /** + * @param {clay.Renderer} renderer + */ + render: function (renderer, frameBuffer) { + this.trigger('beforerender', renderer); - _lightConeGeo: coneGeo, + this._rendering = true; - _lightCylinderGeo: cylinderGeo, + var _gl = renderer.gl; - _outputPass: new Pass({ - fragment: Shader.source('clay.compositor.output') - }) - }; -}, /** @lends clay.deferred.Renderer# */ { - /** - * Do render - * @param {clay.Renderer} renderer - * @param {clay.Scene} scene - * @param {clay.Camera} camera - * @param {Object} [opts] - * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture - * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow. - * @param {boolean} [opts.notUpdateScene = true] If not update the scene. - */ - render: function (renderer, scene, camera, opts) { + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + var inputTexture = link.node.getOutput(renderer, link.pin); + this.pass.setUniform(inputName, inputTexture); + } + // Output + if (!this.outputs) { + this.pass.outputs = null; - opts = opts || {}; - opts.renderToTarget = opts.renderToTarget || false; - opts.notUpdateShadow = opts.notUpdateShadow || false; - opts.notUpdateScene = opts.notUpdateScene || false; + this._compositor.getFrameBuffer().unbind(renderer); - if (!opts.notUpdateScene) { - scene.update(false, true); + this.pass.render(renderer, frameBuffer); } + else { + this.pass.outputs = {}; - camera.update(true); + var attachedTextures = {}; + for (var name in this.outputs) { + var parameters = this.updateParameter(name, renderer); + if (isNaN(parameters.width)) { + this.updateParameter(name, renderer); + } + var outputInfo = this.outputs[name]; + var texture = this._compositor.allocateTexture(parameters); + this._outputTextures[name] = texture; + var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0; + if (typeof(attachment) == 'string') { + attachment = _gl[attachment]; + } + attachedTextures[attachment] = texture; + } + this._compositor.getFrameBuffer().bind(renderer); - // PENDING For stereo rendering - var dpr = renderer.getDevicePixelRatio(); - if (this.autoResize - && (renderer.getWidth() * dpr !== this._lightAccumTex.width - || renderer.getHeight() * dpr !== this._lightAccumTex.height) - ) { - this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr); + for (var attachment in attachedTextures) { + // FIXME attachment changes in different nodes + this._compositor.getFrameBuffer().attach( + attachedTextures[attachment], attachment + ); + } + + this.pass.render(renderer); + + // Because the data of texture is changed over time, + // Here update the mipmaps of texture each time after rendered; + this._compositor.getFrameBuffer().updateMipmap(renderer.gl); } - this._gBuffer.update(renderer, scene, camera); + for (var inputName in this.inputLinks) { + var link = this.inputLinks[inputName]; + link.node.removeReference(link.pin); + } - // Accumulate light buffer - this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow); + this._rendering = false; + this._rendered = true; - if (!opts.renderToTarget) { - this._outputPass.setUniform('texture', this._lightAccumTex); + this.trigger('afterrender', renderer); + }, - this._outputPass.render(renderer); - // this._gBuffer.renderDebug(renderer, camera, 'normal'); + // TODO Remove parameter function callback + updateParameter: function (outputName, renderer) { + var outputInfo = this.outputs[outputName]; + var parameters = outputInfo.parameters; + var parametersCopy = outputInfo._parametersCopy; + if (!parametersCopy) { + parametersCopy = outputInfo._parametersCopy = {}; + } + if (parameters) { + for (var key in parameters) { + if (key !== 'width' && key !== 'height') { + parametersCopy[key] = parameters[key]; + } + } + } + var width, height; + if (parameters.width instanceof Function) { + width = parameters.width.call(this, renderer); + } + else { + width = parameters.width; + } + if (parameters.height instanceof Function) { + height = parameters.height.call(this, renderer); + } + else { + height = parameters.height; + } + if ( + parametersCopy.width !== width + || parametersCopy.height !== height + ) { + if (this._outputTextures[outputName]) { + this._outputTextures[outputName].dispose(renderer); + } } + parametersCopy.width = width; + parametersCopy.height = height; + + return parametersCopy; }, /** - * @return {clay.Texture2D} + * Set parameter + * @param {string} name + * @param {} value */ - getTargetTexture: function () { - return this._lightAccumTex; + setParameter: function (name, value) { + this.pass.setUniform(name, value); }, - /** - * @return {clay.FrameBuffer} + * Get parameter value + * @param {string} name + * @return {} */ - getTargetFrameBuffer: function () { - return this._lightAccumFrameBuffer; + getParameter: function (name) { + return this.pass.getUniform(name); }, - /** - * @return {clay.deferred.GBuffer} + * Set parameters + * @param {Object} obj */ - getGBuffer: function () { - return this._gBuffer; - }, - - // TODO is dpr needed? - setViewport: function (x, y, width, height, dpr) { - this._gBuffer.setViewport(x, y, width, height, dpr); - this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport(); + setParameters: function (obj) { + for (var name in obj) { + this.setParameter(name, obj[name]); + } }, - - // getFullQuadLightPass: function () { - // return this._fullQuadPass; + // /** + // * Set shader code + // * @param {string} shaderStr + // */ + // setShader: function (shaderStr) { + // var material = this.pass.material; + // material.shader.setFragment(shaderStr); + // material.attachShader(material.shader, true); // }, - /** - * Set renderer size. - * @param {number} width - * @param {number} height + * Proxy of pass.material.define('fragment', xxx); + * @param {string} symbol + * @param {number} [val] */ - resize: function (width, height) { - this._lightAccumTex.width = width; - this._lightAccumTex.height = height; - - // PENDING viewport ? - this._gBuffer.resize(width, height); + define: function (symbol, val) { + this.pass.material.define('fragment', symbol, val); }, - _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) { - var gl = renderer.gl; - var lightAccumTex = this._lightAccumTex; - var lightAccumFrameBuffer = this._lightAccumFrameBuffer; - - var eyePosition = camera.getWorldPosition().array; - - // Update volume meshes - for (var i = 0; i < scene.lights.length; i++) { - this._updateLightProxy(scene.lights[i]); - } - - var shadowMapPass = this.shadowMapPass; - if (shadowMapPass && updateShadow) { - gl.clearColor(1, 1, 1, 1); - this._prepareLightShadow(renderer, scene, camera); - } - - this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow); - - lightAccumFrameBuffer.attach(lightAccumTex); - lightAccumFrameBuffer.bind(renderer); - var clearColor = renderer.clearColor; - - var viewport = lightAccumFrameBuffer.viewport; - if (viewport) { - var dpr = viewport.devicePixelRatio; - // use scissor to make sure only clear the viewport - gl.enable(gl.SCISSOR_TEST); - gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr); - } - gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]); - gl.clear(gl.COLOR_BUFFER_BIT); - gl.enable(gl.BLEND); - if (viewport) { - gl.disable(gl.SCISSOR_TEST); - } - - this.trigger('startlightaccumulate', renderer, scene, camera); - - var viewProjectionInv = new Matrix4(); - Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix); - - var volumeMeshList = []; - - for (var i = 0; i < scene.lights.length; i++) { - var light = scene.lights[i]; - var uTpl = light.uniformTemplates; - - var volumeMesh = light.volumeMesh || light.__volumeMesh; - - if (volumeMesh) { - var material = volumeMesh.material; - // Volume mesh will affect the scene bounding box when rendering - // if castShadow is true - volumeMesh.castShadow = false; - - var unknownLightType = false; - switch (light.type) { - case 'POINT_LIGHT': - material.setUniform('lightColor', uTpl.pointLightColor.value(light)); - material.setUniform('lightRange', uTpl.pointLightRange.value(light)); - material.setUniform('lightPosition', uTpl.pointLightPosition.value(light)); - break; - case 'SPOT_LIGHT': - material.setUniform('lightPosition', uTpl.spotLightPosition.value(light)); - material.setUniform('lightColor', uTpl.spotLightColor.value(light)); - material.setUniform('lightRange', uTpl.spotLightRange.value(light)); - material.setUniform('lightDirection', uTpl.spotLightDirection.value(light)); - material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light)); - material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light)); - material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light)); - break; - case 'SPHERE_LIGHT': - material.setUniform('lightColor', uTpl.sphereLightColor.value(light)); - material.setUniform('lightRange', uTpl.sphereLightRange.value(light)); - material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light)); - material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light)); - break; - case 'TUBE_LIGHT': - material.setUniform('lightColor', uTpl.tubeLightColor.value(light)); - material.setUniform('lightRange', uTpl.tubeLightRange.value(light)); - material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light)); - material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light)); - break; - default: - unknownLightType = true; - } - - if (unknownLightType) { - continue; - } - - material.setUniform('eyePosition', eyePosition); - material.setUniform('viewProjectionInv', viewProjectionInv.array); - material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); - material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); - material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - - volumeMeshList.push(volumeMesh); - - } - else { - var pass = this._fullQuadPass; - var unknownLightType = false; - // Full quad light - switch (light.type) { - case 'AMBIENT_LIGHT': - pass.material = this._ambientMat; - pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light)); - break; - case 'AMBIENT_SH_LIGHT': - pass.material = this._ambientSHMat; - pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light)); - pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light)); - break; - case 'AMBIENT_CUBEMAP_LIGHT': - pass.material = this._ambientCubemapMat; - pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light)); - pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light)); - pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light)); - break; - case 'DIRECTIONAL_LIGHT': - var hasShadow = shadowMapPass && light.castShadow; - pass.material = this._directionalLightMat; - pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); - if (hasShadow) { - pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade); - } - pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light)); - pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light)); - break; - default: - // Unkonw light type - unknownLightType = true; - } - if (unknownLightType) { - continue; - } - - var passMaterial = pass.material; - passMaterial.setUniform('eyePosition', eyePosition); - passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array); - passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1()); - passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2()); - passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3()); - - // TODO - if (shadowMapPass && light.castShadow) { - passMaterial.setUniform('lightShadowMap', light.__shadowMap); - passMaterial.setUniform('lightMatrices', light.__lightMatrices); - passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear); - passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar); + /** + * Proxy of pass.material.undefine('fragment', xxx) + * @param {string} symbol + */ + undefine: function (symbol) { + this.pass.material.undefine('fragment', symbol); + }, - passMaterial.setUniform('lightShadowMapSize', light.shadowResolution); + removeReference: function (outputName) { + this._outputReferences[outputName]--; + if (this._outputReferences[outputName] === 0) { + var outputInfo = this.outputs[outputName]; + if (outputInfo.keepLastFrame) { + if (this._prevOutputTextures[outputName]) { + this._compositor.releaseTexture(this._prevOutputTextures[outputName]); } - - pass.renderQuad(renderer); + this._prevOutputTextures[outputName] = this._outputTextures[outputName]; + } + else { + // Output of this node have alreay been used by all other nodes + // Put the texture back to the pool. + this._compositor.releaseTexture(this._outputTextures[outputName]); } } - - this._renderVolumeMeshList(renderer, camera, volumeMeshList); - - this.trigger('lightaccumulate', renderer, scene, camera); - - lightAccumFrameBuffer.unbind(renderer); - - this.trigger('afterlightaccumulate', renderer, scene, camera); - }, - _prepareLightShadow: (function () { - var worldView = new Matrix4(); - return function (renderer, scene, camera) { - var shadowCasters; + clear: function () { + Node$1.prototype.clear.call(this); - shadowCasters = this._shadowCasters || (this._shadowCasters = []); - var count = 0; - var list = scene.opaqueList; - for (var i = 0; i < list.length; i++) { - if (list[i].castShadow) { - shadowCasters[count++] = list[i]; - } - } - shadowCasters.length = count; + // Default disable all texture + this.pass.material.disableTexturesAll(); + } +}); - for (var i = 0; i < scene.lights.length; i++) { - var light = scene.lights[i]; - var volumeMesh = light.volumeMesh || light.__volumeMesh; - if (!light.castShadow) { - continue; - } +var shaderSourceReg = /^#source\((.*?)\)/; - switch (light.type) { - case 'POINT_LIGHT': - case 'SPOT_LIGHT': - // Frustum culling - Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); - if (renderer.isFrustumCulled( - volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array - )) { - continue; - } +/** + * @name clay.compositor.createCompositor + * @function + * @param {Object} json + * @param {Object} [opts] + * @return {clay.compositor.Compositor} + */ +function createCompositor(json, opts) { + var compositor = new Compositor(); + opts = opts || {}; - this._prepareSingleLightShadow( - renderer, scene, camera, light, shadowCasters, volumeMesh.material - ); - break; - case 'DIRECTIONAL_LIGHT': - this._prepareSingleLightShadow( - renderer, scene, camera, light, shadowCasters, null - ); - } + var lib = { + textures: {}, + parameters: {} + }; + var afterLoad = function(shaderLib, textureLib) { + for (var i = 0; i < json.nodes.length; i++) { + var nodeInfo = json.nodes[i]; + var node = createNode(nodeInfo, lib, opts); + if (node) { + compositor.addNode(node); } - }; - })(), + } + }; - _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) { - switch (light.type) { - case 'POINT_LIGHT': - var shadowMaps = []; - this.shadowMapPass.renderPointLightShadow( - renderer, scene, light, casters, shadowMaps - ); - material.setUniform('lightShadowMap', shadowMaps[0]); - material.setUniform('lightShadowMapSize', light.shadowResolution); - break; - case 'SPOT_LIGHT': - var shadowMaps = []; - var lightMatrices = []; - this.shadowMapPass.renderSpotLightShadow( - renderer, scene, light, casters, lightMatrices, shadowMaps - ); - material.setUniform('lightShadowMap', shadowMaps[0]); - material.setUniform('lightMatrix', lightMatrices[0]); - material.setUniform('lightShadowMapSize', light.shadowResolution); - break; - case 'DIRECTIONAL_LIGHT': - var shadowMaps = []; - var lightMatrices = []; - var cascadeClips = []; - this.shadowMapPass.renderDirectionalLightShadow( - renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps - ); - var cascadeClipsNear = cascadeClips.slice(); - var cascadeClipsFar = cascadeClips.slice(); - cascadeClipsNear.pop(); - cascadeClipsFar.shift(); + for (var name in json.parameters) { + var paramInfo = json.parameters[name]; + lib.parameters[name] = convertParameter(paramInfo); + } + // TODO load texture asynchronous + loadTextures(json, lib, opts, function(textureLib) { + lib.textures = textureLib; + afterLoad(); + }); - // Iterate from far to near - cascadeClipsNear.reverse(); - cascadeClipsFar.reverse(); - lightMatrices.reverse(); + return compositor; +} - light.__cascadeClipsNear = cascadeClipsNear; - light.__cascadeClipsFar = cascadeClipsFar; - light.__shadowMap = shadowMaps[0]; - light.__lightMatrices = lightMatrices; - break; +function createNode(nodeInfo, lib, opts) { + var type = nodeInfo.type || 'filter'; + var shaderSource; + var inputs; + var outputs; + + if (type === 'filter') { + var shaderExp = nodeInfo.shader.trim(); + var res = shaderSourceReg.exec(shaderExp); + if (res) { + shaderSource = Shader.source(res[1].trim()); } - }, + else if (shaderExp.charAt(0) === '#') { + shaderSource = lib.shaders[shaderExp.substr(1)]; + } + if (!shaderSource) { + shaderSource = shaderExp; + } + if (!shaderSource) { + return; + } + } - // Update light volume mesh - // Light volume mesh is rendered in light accumulate pass instead of full quad. - // It will reduce pixels significantly when local light is relatively small. - // And we can use custom volume mesh to shape the light. - // - // See "Deferred Shading Optimizations" in GDC2011 - _updateLightProxy: function (light) { - var volumeMesh; - if (light.volumeMesh) { - volumeMesh = light.volumeMesh; + if (nodeInfo.inputs) { + inputs = {}; + for (var name in nodeInfo.inputs) { + if (typeof nodeInfo.inputs[name] === 'string') { + inputs[name] = nodeInfo.inputs[name]; + } + else { + inputs[name] = { + node: nodeInfo.inputs[name].node, + pin: nodeInfo.inputs[name].pin + }; + } } - else { - switch (light.type) { - // Only local light (point and spot) needs volume mesh. - // Directional and ambient light renders in full quad - case 'POINT_LIGHT': - case 'SPHERE_LIGHT': - var shader = light.type === 'SPHERE_LIGHT' - ? this._sphereLightShader : this._pointLightShader; - // Volume mesh created automatically - if (!light.__volumeMesh) { - light.__volumeMesh = new Mesh({ - material: this._createLightPassMat(shader), - geometry: this._lightSphereGeo, - // Disable culling - // if light volume mesh intersect camera near plane - // We need mesh inside can still be rendered - culling: false - }); + } + if (nodeInfo.outputs) { + outputs = {}; + for (var name in nodeInfo.outputs) { + var outputInfo = nodeInfo.outputs[name]; + outputs[name] = {}; + if (outputInfo.attachment != null) { + outputs[name].attachment = outputInfo.attachment; + } + if (outputInfo.keepLastFrame != null) { + outputs[name].keepLastFrame = outputInfo.keepLastFrame; + } + if (outputInfo.outputLastFrame != null) { + outputs[name].outputLastFrame = outputInfo.outputLastFrame; + } + if (outputInfo.parameters) { + outputs[name].parameters = convertParameter(outputInfo.parameters); + } + } + } + var node; + if (type === 'scene') { + node = new SceneNode$1({ + name: nodeInfo.name, + scene: opts.scene, + camera: opts.camera, + outputs: outputs + }); + } + else if (type === 'texture') { + node = new TextureNode$1({ + name: nodeInfo.name, + outputs: outputs + }); + } + // Default is filter + else { + node = new FilterNode$1({ + name: nodeInfo.name, + shader: shaderSource, + inputs: inputs, + outputs: outputs + }); + } + if (node) { + if (nodeInfo.parameters) { + for (var name in nodeInfo.parameters) { + var val = nodeInfo.parameters[name]; + if (typeof(val) === 'string') { + val = val.trim(); + if (val.charAt(0) === '#') { + val = lib.textures[val.substr(1)]; } - volumeMesh = light.__volumeMesh; - var r = light.range + (light.radius || 0); - volumeMesh.scale.set(r, r, r); - break; - case 'SPOT_LIGHT': - light.__volumeMesh = light.__volumeMesh || new Mesh({ - material: this._createLightPassMat(this._spotLightShader), - geometry: this._lightConeGeo, - culling: false - }); - volumeMesh = light.__volumeMesh; - var aspect = Math.tan(light.penumbraAngle * Math.PI / 180); - var range = light.range; - volumeMesh.scale.set(aspect * range, aspect * range, range / 2); - break; - case 'TUBE_LIGHT': - light.__volumeMesh = light.__volumeMesh || new Mesh({ - material: this._createLightPassMat(this._tubeLightShader), - geometry: this._lightCylinderGeo, - culling: false - }); - volumeMesh = light.__volumeMesh; - var range = light.range; - volumeMesh.scale.set(light.length / 2 + range, range, range); - break; + else { + node.on( + 'beforerender', createSizeSetHandler( + name, tryConvertExpr(val) + ) + ); + } + } + node.setParameter(name, val); } } - if (volumeMesh) { - volumeMesh.update(); - // Apply light transform - Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform); - var hasShadow = this.shadowMapPass && light.castShadow; - volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED'); + if (nodeInfo.defines && node.pass) { + for (var name in nodeInfo.defines) { + var val = nodeInfo.defines[name]; + node.pass.material.define('fragment', name, val); + } } - }, + } + return node; +} - _renderVolumeMeshList: (function () { - var worldViewProjection = new Matrix4(); - var worldView = new Matrix4(); - var preZMaterial = new Material({ - shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment')) +function convertParameter(paramInfo) { + var param = {}; + if (!paramInfo) { + return param; + } + ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap'] + .forEach(function(name) { + var val = paramInfo[name]; + if (val != null) { + // Convert string to enum + if (typeof val === 'string') { + val = Texture[val]; + } + param[name] = val; + } }); - return function (renderer, camera, volumeMeshList) { - var gl = renderer.gl; - - gl.enable(gl.DEPTH_TEST); - gl.disable(gl.CULL_FACE); - gl.blendEquation(gl.FUNC_ADD); - gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE); - gl.depthFunc(gl.LEQUAL); - - gl.clear(gl.DEPTH_BUFFER_BIT); - - var viewport = renderer.viewport; - var dpr = viewport.devicePixelRatio; - var viewportUniform = [ - viewport.x * dpr, viewport.y * dpr, - viewport.width * dpr, viewport.height * dpr - ]; - - var windowSizeUniform = [ - this._lightAccumTex.width, - this._lightAccumTex.height - ]; - - for (var i = 0; i < volumeMeshList.length; i++) { - var volumeMesh = volumeMeshList[i]; - - // Frustum culling - Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform); - if (renderer.isFrustumCulled( - volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array - )) { - continue; + ['width', 'height'] + .forEach(function(name) { + if (paramInfo[name] != null) { + var val = paramInfo[name]; + if (typeof val === 'string') { + val = val.trim(); + param[name] = createSizeParser( + name, tryConvertExpr(val) + ); } + else { + param[name] = val; + } + } + }); + if (paramInfo.useMipmap != null) { + param.useMipmap = paramInfo.useMipmap; + } + return param; +} - // Use prez to avoid one pixel rendered twice - gl.colorMask(false, false, false, false); - gl.depthMask(true); - // depthMask must be enabled before clear DEPTH_BUFFER - gl.clear(gl.DEPTH_BUFFER_BIT); - - Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView); - - var preZProgram = renderer.getProgram(volumeMesh, preZMaterial); - volumeMesh.__program = preZProgram; - renderer.validateProgram(preZProgram); - preZProgram.bind(renderer); - - var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION; - preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); - volumeMesh.render(renderer, preZMaterial, preZProgram); - - // Render light - gl.colorMask(true, true, true, true); - gl.depthMask(false); - var program = renderer.getProgram(volumeMesh, volumeMesh.material); - volumeMesh.__program = program; - renderer.validateProgram(program); - program.bind(renderer); - - var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION; - // Set some common uniforms - program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array); - program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform); - program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform); +function loadTextures(json, lib, opts, callback) { + if (!json.textures) { + callback({}); + return; + } + var textures = {}; + var loading = 0; - volumeMesh.material.bind(renderer, program); - volumeMesh.render(renderer, volumeMesh.material, program); + var cbd = false; + var textureRootPath = opts.textureRootPath; + util$1.each(json.textures, function(textureInfo, name) { + var texture; + var path = textureInfo.path; + var parameters = convertParameter(textureInfo.parameters); + if (Array.isArray(path) && path.length === 6) { + if (textureRootPath) { + path = path.map(function(item) { + return util$1.relative2absolute(item, textureRootPath); + }); } + texture = new TextureCube(parameters); + } + else if(typeof path === 'string') { + if (textureRootPath) { + path = util$1.relative2absolute(path, textureRootPath); + } + texture = new Texture2D(parameters); + } + else { + return; + } - gl.depthFunc(gl.LESS); - }; - })(), - - /** - * @param {clay.Renderer} renderer - */ - dispose: function (renderer) { - this._gBuffer.dispose(renderer); + texture.load(path); + loading++; + texture.once('success', function() { + textures[name] = texture; + loading--; + if (loading === 0) { + callback(textures); + cbd = true; + } + }); + }); - this._lightAccumFrameBuffer.dispose(renderer); - this._lightAccumTex.dispose(renderer); + if (loading === 0 && !cbd) { + callback(textures); + } +} - this._lightConeGeo.dispose(renderer); - this._lightCylinderGeo.dispose(renderer); - this._lightSphereGeo.dispose(renderer); +function createSizeSetHandler(name, exprFunc) { + return function (renderer) { + // PENDING viewport size or window size + var dpr = renderer.getDevicePixelRatio(); + // PENDING If multiply dpr ? + var width = renderer.getWidth(); + var height = renderer.getHeight(); + var result = exprFunc(width, height, dpr); + this.setParameter(name, result); + }; +} - this._fullQuadPass.dispose(renderer); - this._outputPass.dispose(renderer); +function createSizeParser(name, exprFunc) { + return function (renderer) { + var dpr = renderer.getDevicePixelRatio(); + var width = renderer.getWidth(); + var height = renderer.getHeight(); + return exprFunc(width, height, dpr); + }; +} - this._directionalLightMat.dispose(renderer); +function tryConvertExpr(string) { + // PENDING + var exprRes = /^expr\((.*)\)$/.exec(string); + if (exprRes) { + try { + var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]); + // Try run t + func(1, 1); - this.shadowMapPass.dispose(renderer); + return func; + } + catch (e) { + throw new Error('Invalid expression.'); + } } -}); +} /** * @constructor clay.light.Sphere @@ -34281,7 +34648,7 @@ function copyIfNecessary(arr, shallow) { /** * @name clay.version */ -var version = '1.0.0-rc.1'; +var version = '1.0.0'; var outputEssl$1 = "@export clay.vr.disorter.output.vertex\nattribute vec2 texcoord: TEXCOORD_0;\nattribute vec3 position: POSITION;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n v_Texcoord = texcoord;\n gl_Position = vec4(position.xy, 0.5, 1.0);\n}\n@end\n@export clay.vr.disorter.output.fragment\nuniform sampler2D texture;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n gl_FragColor = texture2D(texture, v_Texcoord);\n}\n@end"; @@ -34655,6 +35022,7 @@ var geometry = { Cone : Cone$1, Cube : Cube$1, Cylinder : Cylinder$1, + ParametricSurface : ParametricSurface$1, Plane : Plane$3, Sphere : Sphere$1 }; @@ -34782,4 +35150,3 @@ exports.vr = vr; Object.defineProperty(exports, '__esModule', { value: true }); }))); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"claygl.js","sources":["../src/animation/easing.js","../src/animation/Clip.js","../src/animation/Animator.js","../src/animation/Blend1DClip.js","../src/util/delaunay.js","../src/dep/glmatrix.js","../src/math/Vector2.js","../src/animation/Blend2DClip.js","../src/animation/TransformTrack.js","../src/animation/SamplerTrack.js","../src/core/mixin/extend.js","../src/core/mixin/notifier.js","../src/core/util.js","../src/core/Base.js","../src/animation/Timeline.js","../src/animation/TrackClip.js","../src/core/GLInfo.js","../src/core/glenum.js","../src/core/vendor.js","../src/math/Vector3.js","../src/math/BoundingBox.js","../src/math/Matrix4.js","../src/core/Cache.js","../src/Texture.js","../src/core/LinkedList.js","../src/core/LRU.js","../src/core/color.js","../src/Material.js","../src/gpu/GLProgram.js","../src/gpu/ProgramManager.js","../src/Shader.js","../src/shader/source/header/calcAmbientSHLight.glsl.js","../src/shader/source/header/light.js","../src/shader/source/prez.glsl.js","../src/Renderer.js","../src/math/Quaternion.js","../src/Node.js","../src/Light.js","../src/math/Plane.js","../src/math/Frustum.js","../src/math/Ray.js","../src/Camera.js","../src/Scene.js","../src/Geometry.js","../src/geometry/Plane.js","../src/geometry/Cube.js","../src/geometry/Sphere.js","../src/math/util.js","../src/Texture2D.js","../src/shader/library.js","../src/Renderable.js","../src/Mesh.js","../src/camera/Perspective.js","../src/camera/Orthographic.js","../src/core/request.js","../src/shader/source/standard.glsl.js","../src/StandardMaterial.js","../src/Joint.js","../src/Skeleton.js","../src/shader/source/util.glsl.js","../src/shader/source/basic.glsl.js","../src/shader/source/lambert.glsl.js","../src/shader/source/wireframe.glsl.js","../src/shader/source/skybox.glsl.js","../src/shader/source/compositor/coloradjust.glsl.js","../src/shader/source/compositor/blur.glsl.js","../src/shader/source/compositor/lum.glsl.js","../src/shader/source/compositor/lut.glsl.js","../src/shader/source/compositor/vignette.glsl.js","../src/shader/source/compositor/output.glsl.js","../src/shader/source/compositor/bright.glsl.js","../src/shader/source/compositor/downsample.glsl.js","../src/shader/source/compositor/upsample.glsl.js","../src/shader/source/compositor/hdr.glsl.js","../src/shader/source/compositor/dof.glsl.js","../src/shader/source/compositor/lensflare.glsl.js","../src/shader/source/compositor/blend.glsl.js","../src/shader/source/compositor/fxaa.glsl.js","../src/shader/source/compositor/fxaa3.glsl.js","../src/shader/builtin.js","../src/loader/GLTF.js","../src/light/Directional.js","../src/light/Point.js","../src/light/Spot.js","../src/light/Ambient.js","../src/TextureCube.js","../src/FrameBuffer.js","../src/shader/source/compositor/vertex.glsl.js","../src/compositor/Pass.js","../src/plugin/Skybox.js","../src/prePass/EnvironmentMap.js","../src/plugin/Skydome.js","../src/util/dds.js","../src/util/hdr.js","../src/util/texture.js","../src/util/shader/integrateBRDF.glsl.js","../src/util/shader/prefilter.glsl.js","../src/util/cubemap.js","../src/light/AmbientCubemap.js","../src/light/AmbientSH.js","../src/compositor/TexturePool.js","../src/shader/source/shadowmap.glsl.js","../src/prePass/ShadowMap.js","../src/picking/RayPicking.js","../src/util/sh.js","../src/application.js","../src/async/Task.js","../src/async/TaskGroup.js","../src/canvas/Material.js","../src/canvas/Renderer.js","../src/compositor/Node.js","../src/compositor/Graph.js","../src/compositor/Compositor.js","../src/compositor/SceneNode.js","../src/compositor/TextureNode.js","../src/compositor/FilterNode.js","../src/compositor/createCompositor.js","../src/shader/source/deferred/gbuffer.glsl.js","../src/shader/source/deferred/chunk.glsl.js","../src/deferred/GBuffer.js","../src/geometry/Cone.js","../src/geometry/Cylinder.js","../src/shader/source/deferred/lightvolume.glsl.js","../src/shader/source/deferred/spot.glsl.js","../src/shader/source/deferred/directional.glsl.js","../src/shader/source/deferred/ambient.glsl.js","../src/shader/source/deferred/ambientsh.glsl.js","../src/shader/source/deferred/ambientcubemap.glsl.js","../src/shader/source/deferred/point.glsl.js","../src/shader/source/deferred/sphere.glsl.js","../src/shader/source/deferred/tube.glsl.js","../src/deferred/Renderer.js","../src/light/Sphere.js","../src/light/Tube.js","../src/loader/FX.js","../src/math/Matrix2.js","../src/math/Matrix2d.js","../src/math/Matrix3.js","../src/math/Value.js","../src/math/Vector4.js","../src/particle/Particle.js","../src/particle/Emitter.js","../src/particle/Field.js","../src/particle/ForceField.js","../src/particle/particle.glsl.js","../src/particle/ParticleRenderable.js","../src/picking/color.glsl.js","../src/picking/PixelPicking.js","../src/plugin/FreeControl.js","../src/plugin/GestureMgr.js","../src/plugin/InfinitePlane.js","../src/plugin/OrbitControl.js","../src/StaticGeometry.js","../src/util/mesh.js","../src/util/transferable.js","../src/version.js","../src/vr/output.glsl.js","../src/vr/CardboardDistorter.js","../src/vr/StereoCamera.js","../src/claygl.js"],"sourcesContent":["// 缓动函数来自 https://github.com/sole/tween.js/blob/master/src/Tween.js\n\n/**\n * @namespace clay.animation.easing\n */\nvar easing = {\n    /**\n     * @alias clay.animation.easing.linear\n     * @param {number} k\n     * @return {number}\n     */\n    linear: function(k) {\n        return k;\n    },\n    /**\n     * @alias clay.animation.easing.quadraticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticIn: function(k) {\n        return k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quadraticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticOut: function(k) {\n        return k * (2 - k);\n    },\n    /**\n     * @alias clay.animation.easing.quadraticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quadraticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k;\n        }\n        return - 0.5 * (--k * (k - 2) - 1);\n    },\n    /**\n     * @alias clay.animation.easing.cubicIn\n     * @param {number} k\n     * @return {number}\n     */\n    cubicIn: function(k) {\n        return k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.cubicOut\n     * @param {number} k\n     * @return {number}\n     */\n    cubicOut: function(k) {\n        return --k * k * k + 1;\n    },\n    /**\n     * @alias clay.animation.easing.cubicInOut\n     * @param {number} k\n     * @return {number}\n     */\n    cubicInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k;\n        }\n        return 0.5 * ((k -= 2) * k * k + 2);\n    },\n    /**\n     * @alias clay.animation.easing.quarticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quarticIn: function(k) {\n        return k * k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quarticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quarticOut: function(k) {\n        return 1 - (--k * k * k * k);\n    },\n    /**\n     * @alias clay.animation.easing.quarticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quarticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k * k;\n        }\n        return - 0.5 * ((k -= 2) * k * k * k - 2);\n    },\n    /**\n     * @alias clay.animation.easing.quinticIn\n     * @param {number} k\n     * @return {number}\n     */\n    quinticIn: function(k) {\n        return k * k * k * k * k;\n    },\n    /**\n     * @alias clay.animation.easing.quinticOut\n     * @param {number} k\n     * @return {number}\n     */\n    quinticOut: function(k) {\n        return --k * k * k * k * k + 1;\n    },\n    /**\n     * @alias clay.animation.easing.quinticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    quinticInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return 0.5 * k * k * k * k * k;\n        }\n        return 0.5 * ((k -= 2) * k * k * k * k + 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalIn\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalIn: function(k) {\n        return 1 - Math.cos(k * Math.PI / 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalOut\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalOut: function(k) {\n        return Math.sin(k * Math.PI / 2);\n    },\n    /**\n     * @alias clay.animation.easing.sinusoidalInOut\n     * @param {number} k\n     * @return {number}\n     */\n    sinusoidalInOut: function(k) {\n        return 0.5 * (1 - Math.cos(Math.PI * k));\n    },\n    /**\n     * @alias clay.animation.easing.exponentialIn\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialIn: function(k) {\n        return k === 0 ? 0 : Math.pow(1024, k - 1);\n    },\n    /**\n     * @alias clay.animation.easing.exponentialOut\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialOut: function(k) {\n        return k === 1 ? 1 : 1 - Math.pow(2, - 10 * k);\n    },\n    /**\n     * @alias clay.animation.easing.exponentialInOut\n     * @param {number} k\n     * @return {number}\n     */\n    exponentialInOut: function(k) {\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if ((k *= 2) < 1) {\n            return 0.5 * Math.pow(1024, k - 1);\n        }\n        return 0.5 * (- Math.pow(2, - 10 * (k - 1)) + 2);\n    },\n    /**\n     * @alias clay.animation.easing.circularIn\n     * @param {number} k\n     * @return {number}\n     */\n    circularIn: function(k) {\n        return 1 - Math.sqrt(1 - k * k);\n    },\n    /**\n     * @alias clay.animation.easing.circularOut\n     * @param {number} k\n     * @return {number}\n     */\n    circularOut: function(k) {\n        return Math.sqrt(1 - (--k * k));\n    },\n    /**\n     * @alias clay.animation.easing.circularInOut\n     * @param {number} k\n     * @return {number}\n     */\n    circularInOut: function(k) {\n        if ((k *= 2) < 1) {\n            return - 0.5 * (Math.sqrt(1 - k * k) - 1);\n        }\n        return 0.5 * (Math.sqrt(1 - (k -= 2) * k) + 1);\n    },\n    /**\n     * @alias clay.animation.easing.elasticIn\n     * @param {number} k\n     * @return {number}\n     */\n    elasticIn: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        return - (a * Math.pow(2, 10 * (k -= 1)) *\n                    Math.sin((k - s) * (2 * Math.PI) / p));\n    },\n    /**\n     * @alias clay.animation.easing.elasticOut\n     * @param {number} k\n     * @return {number}\n     */\n    elasticOut: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }\n        else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        return (a * Math.pow(2, - 10 * k) *\n                Math.sin((k - s) * (2 * Math.PI) / p) + 1);\n    },\n    /**\n     * @alias clay.animation.easing.elasticInOut\n     * @param {number} k\n     * @return {number}\n     */\n    elasticInOut: function(k) {\n        var s, a = 0.1, p = 0.4;\n        if (k === 0) {\n            return 0;\n        }\n        if (k === 1) {\n            return 1;\n        }\n        if (!a || a < 1) {\n            a = 1; s = p / 4;\n        }\n        else{\n            s = p * Math.asin(1 / a) / (2 * Math.PI);\n        }\n        if ((k *= 2) < 1) {\n            return - 0.5 * (a * Math.pow(2, 10 * (k -= 1))\n                * Math.sin((k - s) * (2 * Math.PI) / p));\n        }\n        return a * Math.pow(2, -10 * (k -= 1))\n                * Math.sin((k - s) * (2 * Math.PI) / p) * 0.5 + 1;\n\n    },\n    /**\n     * @alias clay.animation.easing.backIn\n     * @param {number} k\n     * @return {number}\n     */\n    backIn: function(k) {\n        var s = 1.70158;\n        return k * k * ((s + 1) * k - s);\n    },\n    /**\n     * @alias clay.animation.easing.backOut\n     * @param {number} k\n     * @return {number}\n     */\n    backOut: function(k) {\n        var s = 1.70158;\n        return --k * k * ((s + 1) * k + s) + 1;\n    },\n    /**\n     * @alias clay.animation.easing.backInOut\n     * @param {number} k\n     * @return {number}\n     */\n    backInOut: function(k) {\n        var s = 1.70158 * 1.525;\n        if ((k *= 2) < 1) {\n            return 0.5 * (k * k * ((s + 1) * k - s));\n        }\n        return 0.5 * ((k -= 2) * k * ((s + 1) * k + s) + 2);\n    },\n    /**\n     * @alias clay.animation.easing.bounceIn\n     * @param {number} k\n     * @return {number}\n     */\n    bounceIn: function(k) {\n        return 1 - easing.bounceOut(1 - k);\n    },\n    /**\n     * @alias clay.animation.easing.bounceOut\n     * @param {number} k\n     * @return {number}\n     */\n    bounceOut: function(k) {\n        if (k < (1 / 2.75)) {\n            return 7.5625 * k * k;\n        }\n        else if (k < (2 / 2.75)) {\n            return 7.5625 * (k -= (1.5 / 2.75)) * k + 0.75;\n        } else if (k < (2.5 / 2.75)) {\n            return 7.5625 * (k -= (2.25 / 2.75)) * k + 0.9375;\n        } else {\n            return 7.5625 * (k -= (2.625 / 2.75)) * k + 0.984375;\n        }\n    },\n    /**\n     * @alias clay.animation.easing.bounceInOut\n     * @param {number} k\n     * @return {number}\n     */\n    bounceInOut: function(k) {\n        if (k < 0.5) {\n            return easing.bounceIn(k * 2) * 0.5;\n        }\n        return easing.bounceOut(k * 2 - 1) * 0.5 + 0.5;\n    }\n};\n\nexport default easing;\n","import Easing from './easing';\n\nfunction noop () {}\n/**\n * @constructor\n * @alias clay.animation.Clip\n * @param {Object} [opts]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRate]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n */\nvar Clip = function (opts) {\n\n    opts = opts || {};\n\n    /**\n     * @type {string}\n     */\n    this.name = opts.name || '';\n\n    /**\n     * @type {Object}\n     */\n    this.target = opts.target;\n\n    /**\n     * @type {number}\n     */\n    this.life = opts.life || 1000;\n\n    /**\n     * @type {number}\n     */\n    this.delay = opts.delay || 0;\n\n    /**\n     * @type {number}\n     */\n    this.gap = opts.gap || 0;\n\n    /**\n     * @type {number}\n     */\n    this.playbackRate = opts.playbackRate || 1;\n\n\n    this._initialized = false;\n\n    this._elapsedTime = 0;\n\n    this._loop = opts.loop == null ? false : opts.loop;\n    this.setLoop(this._loop);\n\n    if (opts.easing != null) {\n        this.setEasing(opts.easing);\n    }\n\n    /**\n     * @type {Function}\n     */\n    this.onframe = opts.onframe || noop;\n\n    /**\n     * @type {Function}\n     */\n    this.onfinish = opts.onfinish || noop;\n\n    /**\n     * @type {Function}\n     */\n    this.onrestart = opts.onrestart || noop;\n\n    this._paused = false;\n};\n\nClip.prototype = {\n\n    gap: 0,\n\n    life: 0,\n\n    delay: 0,\n\n    /**\n     * @param {number|boolean} loop\n     */\n    setLoop: function (loop) {\n        this._loop = loop;\n        if (loop) {\n            if (typeof(loop) == 'number') {\n                this._loopRemained = loop;\n            }\n            else {\n                this._loopRemained = 1e8;\n            }\n        }\n    },\n\n    /**\n     * @param {string|Function} easing\n     */\n    setEasing: function (easing) {\n        if (typeof(easing) === 'string') {\n            easing = Easing[easing];\n        }\n        this.easing = easing;\n    },\n\n    /**\n     * @param  {number} time\n     * @return {string}\n     */\n    step: function (time, deltaTime, silent) {\n        if (!this._initialized) {\n            this._startTime = time + this.delay;\n            this._initialized = true;\n        }\n        if (this._currentTime != null) {\n            deltaTime = time - this._currentTime;\n        }\n        this._currentTime = time;\n\n        if (this._paused) {\n            return 'paused';\n        }\n\n        if (time < this._startTime) {\n            return;\n        }\n\n        // PENDIGN Sync ?\n        this._elapse(time, deltaTime);\n\n        var percent = Math.min(this._elapsedTime / this.life, 1);\n\n        if (percent < 0) {\n            return;\n        }\n\n        var schedule;\n        if (this.easing) {\n            schedule = this.easing(percent);\n        }\n        else {\n            schedule = percent;\n        }\n\n        if (!silent) {\n            this.fire('frame', schedule);\n        }\n\n        if (percent === 1) {\n            if (this._loop && this._loopRemained > 0) {\n                this._restartInLoop(time);\n                this._loopRemained--;\n                return 'restart';\n            }\n            else {\n                // Mark this clip to be deleted\n                // In the animation.update\n                this._needsRemove = true;\n\n                return 'finish';\n            }\n        }\n        else {\n            return null;\n        }\n    },\n\n    /**\n     * @param  {number} time\n     * @return {string}\n     */\n    setTime: function (time) {\n        return this.step(time + this._startTime);\n    },\n\n    restart: function (time) {\n        // If user leave the page for a while, when he gets back\n        // All clips may be expired and all start from the beginning value(position)\n        // It is clearly wrong, so we use remainder to add a offset\n\n        var remainder = 0;\n        // Remainder ignored if restart is invoked manually\n        if (time) {\n            this._elapse(time);\n            remainder = this._elapsedTime % this.life;\n        }\n        time = time || Date.now();\n\n        this._startTime = time - remainder + this.delay;\n        this._elapsedTime = 0;\n\n        this._needsRemove = false;\n        this._paused = false;\n    },\n\n    getElapsedTime: function () {\n        return this._elapsedTime;\n    },\n\n    _restartInLoop: function (time) {\n        this._startTime = time + this.gap;\n        this._elapsedTime = 0;\n    },\n\n    _elapse: function (time, deltaTime) {\n        this._elapsedTime += deltaTime * this.playbackRate;\n    },\n\n    fire: function (eventType, arg) {\n        var eventName = 'on' + eventType;\n        if (this[eventName]) {\n            this[eventName](this.target, arg);\n        }\n    },\n\n    clone: function () {\n        var clip = new this.constructor();\n        clip.name = this.name;\n        clip._loop = this._loop;\n        clip._loopRemained = this._loopRemained;\n\n        clip.life = this.life;\n        clip.gap = this.gap;\n        clip.delay = this.delay;\n\n        return clip;\n    },\n    /**\n     * Pause the clip.\n     */\n    pause: function () {\n        this._paused = true;\n    },\n\n    /**\n     * Resume the clip.\n     */\n    resume: function () {\n        this._paused = false;\n    }\n};\nClip.prototype.constructor = Clip;\n\nexport default Clip;\n","/**\n * @module echarts/animation/Animator\n */\nimport Clip from './Clip';\n\nvar arraySlice = Array.prototype.slice;\n\nfunction defaultGetter(target, key) {\n    return target[key];\n}\nfunction defaultSetter(target, key, value) {\n    target[key] = value;\n}\n\nfunction interpolateNumber(p0, p1, percent) {\n    return (p1 - p0) * percent + p0;\n}\n\nfunction interpolateArray(p0, p1, percent, out, arrDim) {\n    var len = p0.length;\n    if (arrDim == 1) {\n        for (var i = 0; i < len; i++) {\n            out[i] = interpolateNumber(p0[i], p1[i], percent);\n        }\n    } else {\n        var len2 = p0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                out[i][j] = interpolateNumber(\n                    p0[i][j], p1[i][j], percent\n                );\n            }\n        }\n    }\n}\n\nfunction isArrayLike(data) {\n    if (typeof(data) == 'undefined') {\n        return false;\n    } else if (typeof(data) == 'string') {\n        return false;\n    } else {\n        return typeof(data.length) == 'number';\n    }\n}\n\nfunction cloneValue(value) {\n    if (isArrayLike(value)) {\n        var len = value.length;\n        if (isArrayLike(value[0])) {\n            var ret = [];\n            for (var i = 0; i < len; i++) {\n                ret.push(arraySlice.call(value[i]));\n            }\n            return ret;\n        } else {\n            return arraySlice.call(value);\n        }\n    } else {\n        return value;\n    }\n}\n\nfunction catmullRomInterpolateArray(\n    p0, p1, p2, p3, t, t2, t3, out, arrDim\n) {\n    var len = p0.length;\n    if (arrDim == 1) {\n        for (var i = 0; i < len; i++) {\n            out[i] = catmullRomInterpolate(\n                p0[i], p1[i], p2[i], p3[i], t, t2, t3\n            );\n        }\n    } else {\n        var len2 = p0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                out[i][j] = catmullRomInterpolate(\n                    p0[i][j], p1[i][j], p2[i][j], p3[i][j],\n                    t, t2, t3\n                );\n            }\n        }\n    }\n}\n\nfunction catmullRomInterpolate(p0, p1, p2, p3, t, t2, t3) {\n    var v0 = (p2 - p0) * 0.5;\n    var v1 = (p3 - p1) * 0.5;\n    return (2 * (p1 - p2) + v0 + v1) * t3\n            + (- 3 * (p1 - p2) - 2 * v0 - v1) * t2\n            + v0 * t + p1;\n}\n\n// arr0 is source array, arr1 is target array.\n// Do some preprocess to avoid error happened when interpolating from arr0 to arr1\nfunction fillArr(arr0, arr1, arrDim) {\n    var arr0Len = arr0.length;\n    var arr1Len = arr1.length;\n    if (arr0Len !== arr1Len) {\n        // FIXME Not work for TypedArray\n        var isPreviousLarger = arr0Len > arr1Len;\n        if (isPreviousLarger) {\n            // Cut the previous\n            arr0.length = arr1Len;\n        }\n        else {\n            // Fill the previous\n            for (var i = arr0Len; i < arr1Len; i++) {\n                arr0.push(\n                    arrDim === 1 ? arr1[i] : arraySlice.call(arr1[i])\n                );\n            }\n        }\n    }\n    // Handling NaN value\n    var len2 = arr0[0] && arr0[0].length;\n    for (var i = 0; i < arr0.length; i++) {\n        if (arrDim === 1) {\n            if (isNaN(arr0[i])) {\n                arr0[i] = arr1[i];\n            }\n        }\n        else {\n            for (var j = 0; j < len2; j++) {\n                if (isNaN(arr0[i][j])) {\n                    arr0[i][j] = arr1[i][j];\n                }\n            }\n        }\n    }\n}\n\nfunction isArraySame(arr0, arr1, arrDim) {\n    if (arr0 === arr1) {\n        return true;\n    }\n    var len = arr0.length;\n    if (len !== arr1.length) {\n        return false;\n    }\n    if (arrDim === 1) {\n        for (var i = 0; i < len; i++) {\n            if (arr0[i] !== arr1[i]) {\n                return false;\n            }\n        }\n    }\n    else {\n        var len2 = arr0[0].length;\n        for (var i = 0; i < len; i++) {\n            for (var j = 0; j < len2; j++) {\n                if (arr0[i][j] !== arr1[i][j]) {\n                    return false;\n                }\n            }\n        }\n    }\n    return true;\n}\n\nfunction createTrackClip(animator, easing, oneTrackDone, keyframes, propName, interpolater) {\n    var getter = animator._getter;\n    var setter = animator._setter;\n    var useSpline = easing === 'spline';\n\n    var trackLen = keyframes.length;\n    if (!trackLen) {\n        return;\n    }\n    // Guess data type\n    var firstVal = keyframes[0].value;\n    var isValueArray = isArrayLike(firstVal);\n\n    // For vertices morphing\n    var arrDim = (\n            isValueArray\n            && isArrayLike(firstVal[0])\n        )\n        ? 2 : 1;\n    // Sort keyframe as ascending\n    keyframes.sort(function(a, b) {\n        return a.time - b.time;\n    });\n\n    var trackMaxTime = keyframes[trackLen - 1].time;\n    // Percents of each keyframe\n    var kfPercents = [];\n    // Value of each keyframe\n    var kfValues = [];\n\n    var prevValue = keyframes[0].value;\n    var isAllValueEqual = true;\n    for (var i = 0; i < trackLen; i++) {\n        kfPercents.push(keyframes[i].time / trackMaxTime);\n\n        // Assume value is a color when it is a string\n        var value = keyframes[i].value;\n\n        // Check if value is equal, deep check if value is array\n        if (!((isValueArray && isArraySame(value, prevValue, arrDim))\n            || (!isValueArray && value === prevValue))) {\n            isAllValueEqual = false;\n        }\n        prevValue = value;\n\n        kfValues.push(value);\n    }\n    if (isAllValueEqual) {\n        return;\n    }\n\n    var lastValue = kfValues[trackLen - 1];\n    // Polyfill array and NaN value\n    for (var i = 0; i < trackLen - 1; i++) {\n        if (isValueArray) {\n            fillArr(kfValues[i], lastValue, arrDim);\n        }\n        else {\n            if (isNaN(kfValues[i]) && !isNaN(lastValue)) {\n                kfValues[i] = lastValue;\n            }\n        }\n    }\n    isValueArray && fillArr(getter(animator._target, propName), lastValue, arrDim);\n\n    // Cache the key of last frame to speed up when\n    // animation playback is sequency\n    var cacheKey = 0;\n    var cachePercent = 0;\n    var start;\n    var i, w;\n    var p0, p1, p2, p3;\n\n    var onframe = function(target, percent) {\n        // Find the range keyframes\n        // kf1-----kf2---------current--------kf3\n        // find kf2(i) and kf3(i+1) and do interpolation\n        if (percent < cachePercent) {\n            // Start from next key\n            start = Math.min(cacheKey + 1, trackLen - 1);\n            for (i = start; i >= 0; i--) {\n                if (kfPercents[i] <= percent) {\n                    break;\n                }\n            }\n            i = Math.min(i, trackLen-2);\n        } else {\n            for (i = cacheKey; i < trackLen; i++) {\n                if (kfPercents[i] > percent) {\n                    break;\n                }\n            }\n            i = Math.min(i-1, trackLen-2);\n        }\n        cacheKey = i;\n        cachePercent = percent;\n\n        var range = (kfPercents[i+1] - kfPercents[i]);\n        if (range === 0) {\n            return;\n        } else {\n            w = (percent - kfPercents[i]) / range;\n        }\n        if (useSpline) {\n            p1 = kfValues[i];\n            p0 = kfValues[i === 0 ? i : i - 1];\n            p2 = kfValues[i > trackLen - 2 ? trackLen - 1 : i + 1];\n            p3 = kfValues[i > trackLen - 3 ? trackLen - 1 : i + 2];\n            if (interpolater) {\n                setter(\n                    target,\n                    propName,\n                    interpolater(\n                        getter(target, propName),\n                        p0, p1, p2, p3, w\n                    )\n                );\n            } else if (isValueArray) {\n                catmullRomInterpolateArray(\n                    p0, p1, p2, p3, w, w*w, w*w*w,\n                    getter(target, propName),\n                    arrDim\n                );\n            } else {\n                setter(\n                    target,\n                    propName,\n                    catmullRomInterpolate(p0, p1, p2, p3, w, w*w, w*w*w)\n                );\n            }\n        } else {\n            if (interpolater) {\n                setter(\n                    target,\n                    propName,\n                    interpolater(\n                        getter(target, propName),\n                        kfValues[i],\n                        kfValues[i + 1],\n                        w\n                    )\n                );\n            }\n            else if (isValueArray) {\n                interpolateArray(\n                    kfValues[i], kfValues[i+1], w,\n                    getter(target, propName),\n                    arrDim\n                );\n            } else {\n                setter(\n                    target,\n                    propName,\n                    interpolateNumber(kfValues[i], kfValues[i+1], w)\n                );\n            }\n        }\n    };\n\n    var clip = new Clip({\n        target: animator._target,\n        life: trackMaxTime,\n        loop: animator._loop,\n        delay: animator._delay,\n        onframe: onframe,\n        onfinish: oneTrackDone\n    });\n\n    if (easing && easing !== 'spline') {\n        clip.setEasing(easing);\n    }\n\n    return clip;\n}\n\n/**\n * @description Animator object can only be created by Animation.prototype.animate method.\n * After created, we can use {@link clay.animation.Animator#when} to add all keyframes and {@link clay.animation.Animator#start} it.\n * Clips will be automatically created and added to the animation instance which created this deferred object.\n *\n * @constructor clay.animation.Animator\n *\n * @param {Object} target\n * @param {boolean} loop\n * @param {Function} getter\n * @param {Function} setter\n * @param {Function} interpolater\n */\nfunction Animator(target, loop, getter, setter, interpolater) {\n    this._tracks = {};\n    this._target = target;\n\n    this._loop = loop || false;\n\n    this._getter = getter || defaultGetter;\n    this._setter = setter || defaultSetter;\n\n    this._interpolater = interpolater || null;\n\n    this._delay = 0;\n\n    this._doneList = [];\n\n    this._onframeList = [];\n\n    this._clipList = [];\n}\n\nAnimator.prototype = {\n\n    constructor: Animator,\n\n    /**\n     * @param  {number} time Keyframe time using millisecond\n     * @param  {Object} props A key-value object. Value can be number, 1d and 2d array\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    when: function (time, props) {\n        for (var propName in props) {\n            if (!this._tracks[propName]) {\n                this._tracks[propName] = [];\n                // If time is 0\n                //  Then props is given initialize value\n                // Else\n                //  Initialize value from current prop value\n                if (time !== 0) {\n                    this._tracks[propName].push({\n                        time: 0,\n                        value: cloneValue(\n                            this._getter(this._target, propName)\n                        )\n                    });\n                }\n            }\n            this._tracks[propName].push({\n                time: parseInt(time),\n                value: props[propName]\n            });\n        }\n        return this;\n    },\n    /**\n     * callback when running animation\n     * @param  {Function} callback callback have two args, animating target and current percent\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    during: function (callback) {\n        this._onframeList.push(callback);\n        return this;\n    },\n\n    _doneCallback: function () {\n        // Clear all tracks\n        this._tracks = {};\n        // Clear all clips\n        this._clipList.length = 0;\n\n        var doneList = this._doneList;\n        var len = doneList.length;\n        for (var i = 0; i < len; i++) {\n            doneList[i].call(this);\n        }\n    },\n    /**\n     * Start the animation\n     * @param  {string|Function} easing\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    start: function (easing) {\n\n        var self = this;\n        var clipCount = 0;\n\n        var oneTrackDone = function() {\n            clipCount--;\n            if (clipCount === 0) {\n                self._doneCallback();\n            }\n        };\n\n        var lastClip;\n        for (var propName in this._tracks) {\n            var clip = createTrackClip(\n                this, easing, oneTrackDone,\n                this._tracks[propName], propName, self._interpolater\n            );\n            if (clip) {\n                this._clipList.push(clip);\n                clipCount++;\n\n                // If start after added to animation\n                if (this.animation) {\n                    this.animation.addClip(clip);\n                }\n\n                lastClip = clip;\n            }\n        }\n\n        // Add during callback on the last clip\n        if (lastClip) {\n            var oldOnFrame = lastClip.onframe;\n            lastClip.onframe = function (target, percent) {\n                oldOnFrame(target, percent);\n\n                for (var i = 0; i < self._onframeList.length; i++) {\n                    self._onframeList[i](target, percent);\n                }\n            };\n        }\n\n        if (!clipCount) {\n            this._doneCallback();\n        }\n        return this;\n    },\n\n    /**\n     * Stop the animation\n     * @memberOf clay.animation.Animator.prototype\n     */\n    stop: function () {\n        for (var i = 0; i < this._clipList.length; i++) {\n            var clip = this._clipList[i];\n            this.animation.removeClip(clip);\n        }\n        this._clipList = [];\n    },\n    /**\n     * Delay given milliseconds\n     * @param  {number} time\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    delay: function (time){\n        this._delay = time;\n        return this;\n    },\n    /**\n     * Callback after animation finished\n     * @param {Function} func\n     * @return {clay.animation.Animator}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    done: function (func) {\n        if (func) {\n            this._doneList.push(func);\n        }\n        return this;\n    },\n    /**\n     * Get all clips created in start method.\n     * @return {clay.animation.Clip[]}\n     * @memberOf clay.animation.Animator.prototype\n     */\n    getClips: function () {\n        return this._clipList;\n    }\n};\n\nexport default Animator;\n","// 1D Blend clip of blend tree\n// http://docs.unity3d.com/Documentation/Manual/1DBlending.html\n\nimport Clip from './Clip';\n\nvar clipSortFunc = function (a, b) {\n    return a.position < b.position;\n};\n\n/**\n * @typedef {Object} clay.animation.Blend1DClip.IClipInput\n * @property {number} position\n * @property {clay.animation.Clip} clip\n * @property {number} offset\n */\n\n/**\n * 1d blending node in animation blend tree.\n * output clip must have blend1D and copy method\n * @constructor\n * @alias clay.animation.Blend1DClip\n * @extends clay.animation.Clip\n *\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {object[]} [opts.inputs]\n * @param {number} [opts.position]\n * @param {clay.animation.Clip} [opts.output]\n */\nvar Blend1DClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n    /**\n     * Output clip must have blend1D and copy method\n     * @type {clay.animation.Clip}\n     */\n    this.output = opts.output || null;\n    /**\n     * @type {clay.animation.Blend1DClip.IClipInput[]}\n     */\n    this.inputs = opts.inputs || [];\n    /**\n     * @type {number}\n     */\n    this.position = 0;\n\n    this._cacheKey = 0;\n    this._cachePosition = -Infinity;\n\n    this.inputs.sort(clipSortFunc);\n};\n\nBlend1DClip.prototype = new Clip();\nBlend1DClip.prototype.constructor = Blend1DClip;\n\n/**\n * @param {number} position\n * @param {clay.animation.Clip} inputClip\n * @param {number} [offset]\n * @return {clay.animation.Blend1DClip.IClipInput}\n */\nBlend1DClip.prototype.addInput = function (position, inputClip, offset) {\n    var obj = {\n        position: position,\n        clip: inputClip,\n        offset: offset || 0\n    };\n    this.life = Math.max(inputClip.life, this.life);\n\n    if (!this.inputs.length) {\n        this.inputs.push(obj);\n        return obj;\n    }\n    var len = this.inputs.length;\n    if (this.inputs[0].position > position) {\n        this.inputs.unshift(obj);\n    } else if (this.inputs[len - 1].position <= position) {\n        this.inputs.push(obj);\n    } else {\n        var key = this._findKey(position);\n        this.inputs.splice(key, obj);\n    }\n\n    return obj;\n};\n\nBlend1DClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n    return ret;\n};\n\nBlend1DClip.prototype.setTime = function (time) {\n    var position = this.position;\n    var inputs = this.inputs;\n    var len = inputs.length;\n    var min = inputs[0].position;\n    var max = inputs[len-1].position;\n\n    if (position <= min || position >= max) {\n        var in0 = position <= min ? inputs[0] : inputs[len-1];\n        var clip = in0.clip;\n        var offset = in0.offset;\n        clip.setTime((time + offset) % clip.life);\n        // Input clip is a blend clip\n        // PENDING\n        if (clip.output instanceof Clip) {\n            this.output.copy(clip.output);\n        } else {\n            this.output.copy(clip);\n        }\n    } else {\n        var key = this._findKey(position);\n        var in1 = inputs[key];\n        var in2 = inputs[key + 1];\n        var clip1 = in1.clip;\n        var clip2 = in2.clip;\n        // Set time on input clips\n        clip1.setTime((time + in1.offset) % clip1.life);\n        clip2.setTime((time + in2.offset) % clip2.life);\n\n        var w = (this.position - in1.position) / (in2.position - in1.position);\n\n        var c1 = clip1.output instanceof Clip ? clip1.output : clip1;\n        var c2 = clip2.output instanceof Clip ? clip2.output : clip2;\n        this.output.blend1D(c1, c2, w);\n    }\n};\n\n/**\n * Clone a new Blend1D clip\n * @param {boolean} cloneInputs True if clone the input clips\n * @return {clay.animation.Blend1DClip}\n */\nBlend1DClip.prototype.clone = function (cloneInputs) {\n    var clip = Clip.prototype.clone.call(this);\n    clip.output = this.output.clone();\n    for (var i = 0; i < this.inputs.length; i++) {\n        var inputClip = cloneInputs ? this.inputs[i].clip.clone(true) : this.inputs[i].clip;\n        clip.addInput(this.inputs[i].position, inputClip, this.inputs[i].offset);\n    }\n    return clip;\n};\n\n// Find the key where position in range [inputs[key].position, inputs[key+1].position)\nBlend1DClip.prototype._findKey = function (position) {\n    var key = -1;\n    var inputs = this.inputs;\n    var len = inputs.length;\n    if (this._cachePosition < position) {\n        for (var i = this._cacheKey; i < len-1; i++) {\n            if (position >= inputs[i].position && position < inputs[i+1].position) {\n                key = i;\n            }\n        }\n    } else {\n        var s = Math.min(len-2, this._cacheKey);\n        for (var i = s; i >= 0; i--) {\n            if (position >= inputs[i].position && position < inputs[i+1].position) {\n                key = i;\n            }\n        }\n    }\n    if (key >= 0) {\n        this._cacheKey = key;\n        this._cachePosition = position;\n    }\n\n    return key;\n};\n\nexport default Blend1DClip;","// Delaunay Triangulation\n// Modified from https://github.com/ironwallaby/delaunay\nvar EPSILON = 1.0 / 1048576.0;\n\nfunction supertriangle(vertices) {\n    var xmin = Number.POSITIVE_INFINITY;\n    var ymin = Number.POSITIVE_INFINITY;\n    var xmax = Number.NEGATIVE_INFINITY;\n    var ymax = Number.NEGATIVE_INFINITY;\n    var i, dx, dy, dmax, xmid, ymid;\n\n    for (i = vertices.length; i--; ) {\n        if (vertices[i][0] < xmin) { xmin = vertices[i][0]; }\n        if (vertices[i][0] > xmax) { xmax = vertices[i][0]; }\n        if (vertices[i][1] < ymin) { ymin = vertices[i][1]; }\n        if (vertices[i][1] > ymax) { ymax = vertices[i][1]; }\n    }\n\n    dx = xmax - xmin;\n    dy = ymax - ymin;\n    dmax = Math.max(dx, dy);\n    xmid = xmin + dx * 0.5;\n    ymid = ymin + dy * 0.5;\n\n    return [\n        [xmid - 20 * dmax, ymid -      dmax],\n        [xmid            , ymid + 20 * dmax],\n        [xmid + 20 * dmax, ymid -      dmax]\n    ];\n}\n\nfunction circumcircle(vertices, i, j, k) {\n    var x1 = vertices[i][0],\n            y1 = vertices[i][1],\n            x2 = vertices[j][0],\n            y2 = vertices[j][1],\n            x3 = vertices[k][0],\n            y3 = vertices[k][1],\n            fabsy1y2 = Math.abs(y1 - y2),\n            fabsy2y3 = Math.abs(y2 - y3),\n            xc, yc, m1, m2, mx1, mx2, my1, my2, dx, dy;\n\n    /* Check for coincident points */\n    if (fabsy1y2 < EPSILON && fabsy2y3 < EPSILON) {\n        throw new Error('Eek! Coincident points!');\n    }\n\n    if (fabsy1y2 < EPSILON) {\n        m2  = -((x3 - x2) / (y3 - y2));\n        mx2 = (x2 + x3) / 2.0;\n        my2 = (y2 + y3) / 2.0;\n        xc  = (x2 + x1) / 2.0;\n        yc  = m2 * (xc - mx2) + my2;\n    }\n\n    else if (fabsy2y3 < EPSILON) {\n        m1  = -((x2 - x1) / (y2 - y1));\n        mx1 = (x1 + x2) / 2.0;\n        my1 = (y1 + y2) / 2.0;\n        xc  = (x3 + x2) / 2.0;\n        yc  = m1 * (xc - mx1) + my1;\n    }\n\n    else {\n        m1  = -((x2 - x1) / (y2 - y1));\n        m2  = -((x3 - x2) / (y3 - y2));\n        mx1 = (x1 + x2) / 2.0;\n        mx2 = (x2 + x3) / 2.0;\n        my1 = (y1 + y2) / 2.0;\n        my2 = (y2 + y3) / 2.0;\n        xc  = (m1 * mx1 - m2 * mx2 + my2 - my1) / (m1 - m2);\n        yc  = (fabsy1y2 > fabsy2y3) ?\n            m1 * (xc - mx1) + my1 :\n            m2 * (xc - mx2) + my2;\n    }\n\n    dx = x2 - xc;\n    dy = y2 - yc;\n    return {i: i, j: j, k: k, x: xc, y: yc, r: dx * dx + dy * dy};\n}\n\nfunction dedup(edges) {\n    var i, j, a, b, m, n;\n\n    for (j = edges.length; j; ) {\n        b = edges[--j];\n        a = edges[--j];\n\n        for (i = j; i; ) {\n            n = edges[--i];\n            m = edges[--i];\n\n            if ((a === m && b === n) || (a === n && b === m)) {\n                edges.splice(j, 2);\n                edges.splice(i, 2);\n                break;\n            }\n        }\n    }\n}\n\nvar delaunay = {\n    triangulate: function(vertices, key) {\n        var n = vertices.length;\n        var i, j, indices, st, open, closed, edges, dx, dy, a, b, c;\n\n        /* Bail if there aren't enough vertices to form any triangles. */\n        if (n < 3) {\n            return [];\n        }\n\n        /* Slice out the actual vertices from the passed objects. (Duplicate the\n            * array even if we don't, though, since we need to make a supertriangle\n            * later on!) */\n        vertices = vertices.slice(0);\n\n        if (key) {\n            for (i = n; i--; ) {\n                vertices[i] = vertices[i][key];\n            }\n        }\n\n        /* Make an array of indices into the vertex array, sorted by the\n            * vertices' x-position. Force stable sorting by comparing indices if\n            * the x-positions are equal. */\n        indices = new Array(n);\n\n        for (i = n; i--; ) {\n            indices[i] = i;\n        }\n\n        indices.sort(function(i, j) {\n            var diff = vertices[j][0] - vertices[i][0];\n            return diff !== 0 ? diff : i - j;\n        });\n\n        /* Next, find the vertices of the supertriangle (which contains all other\n            * triangles), and append them onto the end of a (copy of) the vertex\n            * array. */\n        st = supertriangle(vertices);\n        vertices.push(st[0], st[1], st[2]);\n\n        /* Initialize the open list (containing the supertriangle and nothing\n            * else) and the closed list (which is empty since we havn't processed\n            * any triangles yet). */\n        open   = [circumcircle(vertices, n + 0, n + 1, n + 2)];\n        closed = [];\n        edges  = [];\n\n        /* Incrementally add each vertex to the mesh. */\n        for (i = indices.length; i--; edges.length = 0) {\n            c = indices[i];\n\n            /* For each open triangle, check to see if the current point is\n                * inside it's circumcircle. If it is, remove the triangle and add\n                * it's edges to an edge list. */\n            for (j = open.length; j--; ) {\n                /* If this point is to the right of this triangle's circumcircle,\n                    * then this triangle should never get checked again. Remove it\n                    * from the open list, add it to the closed list, and skip. */\n                dx = vertices[c][0] - open[j].x;\n                if (dx > 0.0 && dx * dx > open[j].r) {\n                    closed.push(open[j]);\n                    open.splice(j, 1);\n                    continue;\n                }\n\n                /* If we're outside the circumcircle, skip this triangle. */\n                dy = vertices[c][1] - open[j].y;\n                if (dx * dx + dy * dy - open[j].r > EPSILON) {\n                    continue;\n                }\n\n                /* Remove the triangle and add it's edges to the edge list. */\n                edges.push(\n                    open[j].i, open[j].j,\n                    open[j].j, open[j].k,\n                    open[j].k, open[j].i\n                );\n                open.splice(j, 1);\n            }\n\n            /* Remove any doubled edges. */\n            dedup(edges);\n\n            /* Add a new triangle for each edge. */\n            for (j = edges.length; j; ) {\n                b = edges[--j];\n                a = edges[--j];\n                open.push(circumcircle(vertices, a, b, c));\n            }\n        }\n\n        /* Copy any remaining open triangles to the closed list, and then\n            * remove any triangles that share a vertex with the supertriangle,\n            * building a list of triplets that represent triangles. */\n        for (i = open.length; i--; ) {\n            closed.push(open[i]);\n        }\n        open.length = 0;\n\n        for (i = closed.length; i--; ) {\n            if (closed[i].i < n && closed[i].j < n && closed[i].k < n) {\n                open.push(closed[i].i, closed[i].j, closed[i].k);\n            }\n        }\n\n        /* Yay, we're done! */\n        return open;\n    },\n    contains: function(tri, p) {\n        /* Bounding box test first, for quick rejections. */\n        if ((p[0] < tri[0][0] && p[0] < tri[1][0] && p[0] < tri[2][0]) ||\n                (p[0] > tri[0][0] && p[0] > tri[1][0] && p[0] > tri[2][0]) ||\n                (p[1] < tri[0][1] && p[1] < tri[1][1] && p[1] < tri[2][1]) ||\n                (p[1] > tri[0][1] && p[1] > tri[1][1] && p[1] > tri[2][1])) {\n            return null;\n        }\n\n        var a = tri[1][0] - tri[0][0];\n        var b = tri[2][0] - tri[0][0];\n        var c = tri[1][1] - tri[0][1];\n        var d = tri[2][1] - tri[0][1];\n        var i = a * d - b * c;\n\n        /* Degenerate tri. */\n        if (i === 0.0) {\n            return null;\n        }\n\n        var u = (d * (p[0] - tri[0][0]) - b * (p[1] - tri[0][1])) / i,\n                v = (a * (p[1] - tri[0][1]) - c * (p[0] - tri[0][0])) / i;\n\n        /* If we're outside the tri, fail. */\n        if (u < 0.0 || v < 0.0 || (u + v) > 1.0) {\n            return null;\n        }\n\n        return [u, v];\n    }\n};\n\nexport default delaunay;\n","/**\n * @fileoverview gl-matrix - High performance matrix and vector operations\n * @author Brandon Jones\n * @author Colin MacKenzie IV\n * @version 2.2.2\n */\n\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\n(function(_global) {\n  \"use strict\";\n\n  var shim = {};\n  if (typeof(exports) === 'undefined') {\n    if(typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n      shim.exports = {};\n      define(function() {\n        return shim.exports;\n      });\n    } else {\n      // gl-matrix lives in a browser, define its namespaces in global\n      shim.exports = typeof(window) !== 'undefined' ? window : _global;\n    }\n  }\n  else {\n    // gl-matrix lives in commonjs, define its namespaces in exports\n    shim.exports = exports;\n  }\n\n  (function(exports) {\n    /* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n\nif(!GLMAT_EPSILON) {\n    var GLMAT_EPSILON = 0.000001;\n}\n\nif(!GLMAT_ARRAY_TYPE) {\n    var GLMAT_ARRAY_TYPE = (typeof Float32Array !== 'undefined') ? Float32Array : Array;\n}\n\nif(!GLMAT_RANDOM) {\n    var GLMAT_RANDOM = Math.random;\n}\n\n/**\n * @class Common utilities\n * @name glMatrix\n */\nvar glMatrix = {};\n\n/**\n * Sets the type of array used when creating new vectors and matrices\n *\n * @param {Type} type Array type, such as Float32Array or Array\n */\nglMatrix.setMatrixArrayType = function(type) {\n    GLMAT_ARRAY_TYPE = type;\n}\n\nif(typeof(exports) !== 'undefined') {\n    exports.glMatrix = glMatrix;\n}\n\nvar degree = Math.PI / 180;\n\n/**\n* Convert Degree To Radian\n*\n* @param {Number} Angle in Degrees\n*/\nglMatrix.toRadian = function(a){\n     return a * degree;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2 Dimensional Vector\n * @name vec2\n */\n\nvar vec2 = {};\n\n/**\n * Creates a new, empty vec2\n *\n * @returns {vec2} a new 2D vector\n */\nvec2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = 0;\n    out[1] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with values from an existing vector\n *\n * @param {vec2} a vector to clone\n * @returns {vec2} a new 2D vector\n */\nvec2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Creates a new vec2 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} a new 2D vector\n */\nvec2.fromValues = function(x, y) {\n    var out = new GLMAT_ARRAY_TYPE(2);\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Copy the values from one vec2 to another\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the source vector\n * @returns {vec2} out\n */\nvec2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    return out;\n};\n\n/**\n * Set the components of a vec2 to the given values\n *\n * @param {vec2} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @returns {vec2} out\n */\nvec2.set = function(out, x, y) {\n    out[0] = x;\n    out[1] = y;\n    return out;\n};\n\n/**\n * Adds two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.subtract}\n * @function\n */\nvec2.sub = vec2.subtract;\n\n/**\n * Multiplies two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.multiply}\n * @function\n */\nvec2.mul = vec2.multiply;\n\n/**\n * Divides two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    return out;\n};\n\n/**\n * Alias for {@link vec2.divide}\n * @function\n */\nvec2.div = vec2.divide;\n\n/**\n * Returns the minimum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec2} out\n */\nvec2.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    return out;\n};\n\n/**\n * Scales a vec2 by a scalar number\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec2} out\n */\nvec2.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    return out;\n};\n\n/**\n * Adds two vec2's after scaling the second operand by a scalar value\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec2} out\n */\nvec2.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} distance between a and b\n */\nvec2.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.distance}\n * @function\n */\nvec2.dist = vec2.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec2.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredDistance}\n * @function\n */\nvec2.sqrDist = vec2.squaredDistance;\n\n/**\n * Calculates the length of a vec2\n *\n * @param {vec2} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec2.length = function (a) {\n    var x = a[0],\n        y = a[1];\n    return Math.sqrt(x*x + y*y);\n};\n\n/**\n * Alias for {@link vec2.length}\n * @function\n */\nvec2.len = vec2.length;\n\n/**\n * Calculates the squared length of a vec2\n *\n * @param {vec2} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec2.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1];\n    return x*x + y*y;\n};\n\n/**\n * Alias for {@link vec2.squaredLength}\n * @function\n */\nvec2.sqrLen = vec2.squaredLength;\n\n/**\n * Negates the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to negate\n * @returns {vec2} out\n */\nvec2.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to invert\n * @returns {vec2} out\n */\nvec2.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  return out;\n};\n\n/**\n * Normalize a vec2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a vector to normalize\n * @returns {vec2} out\n */\nvec2.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1];\n    var len = x*x + y*y;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec2's\n *\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec2.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1];\n};\n\n/**\n * Computes the cross product of two vec2's\n * Note that the cross product must by definition produce a 3D vector\n *\n * @param {vec3} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @returns {vec3} out\n */\nvec2.cross = function(out, a, b) {\n    var z = a[0] * b[1] - a[1] * b[0];\n    out[0] = out[1] = 0;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec2's\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the first operand\n * @param {vec2} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec2} out\n */\nvec2.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec2} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec2} out\n */\nvec2.random = function (out, scale) {\n    scale = scale || 1.0;\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    out[0] = Math.cos(r) * scale;\n    out[1] = Math.sin(r) * scale;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y;\n    out[1] = m[1] * x + m[3] * y;\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat2d\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat2d} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat2d = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[2] * y + m[4];\n    out[1] = m[1] * x + m[3] * y + m[5];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat3\n * 3rd vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat3} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat3 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[3] * y + m[6];\n    out[1] = m[1] * x + m[4] * y + m[7];\n    return out;\n};\n\n/**\n * Transforms the vec2 with a mat4\n * 3rd vector component is implicitly '0'\n * 4th vector component is implicitly '1'\n *\n * @param {vec2} out the receiving vector\n * @param {vec2} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec2} out\n */\nvec2.transformMat4 = function(out, a, m) {\n    var x = a[0],\n        y = a[1];\n    out[0] = m[0] * x + m[4] * y + m[12];\n    out[1] = m[1] * x + m[5] * y + m[13];\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec2s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec2. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec2s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec2.forEach = (function() {\n    var vec = vec2.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 2;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec2} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec2.str = function (a) {\n    return 'vec2(' + a[0] + ', ' + a[1] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec2 = vec2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3 Dimensional Vector\n * @name vec3\n */\n\nvar vec3 = {};\n\n/**\n * Creates a new, empty vec3\n *\n * @returns {vec3} a new 3D vector\n */\nvec3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with values from an existing vector\n *\n * @param {vec3} a vector to clone\n * @returns {vec3} a new 3D vector\n */\nvec3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Creates a new vec3 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} a new 3D vector\n */\nvec3.fromValues = function(x, y, z) {\n    var out = new GLMAT_ARRAY_TYPE(3);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Copy the values from one vec3 to another\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the source vector\n * @returns {vec3} out\n */\nvec3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    return out;\n};\n\n/**\n * Set the components of a vec3 to the given values\n *\n * @param {vec3} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @returns {vec3} out\n */\nvec3.set = function(out, x, y, z) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    return out;\n};\n\n/**\n * Adds two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.subtract}\n * @function\n */\nvec3.sub = vec3.subtract;\n\n/**\n * Multiplies two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.multiply}\n * @function\n */\nvec3.mul = vec3.multiply;\n\n/**\n * Divides two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    return out;\n};\n\n/**\n * Alias for {@link vec3.divide}\n * @function\n */\nvec3.div = vec3.divide;\n\n/**\n * Returns the minimum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    return out;\n};\n\n/**\n * Scales a vec3 by a scalar number\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec3} out\n */\nvec3.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    return out;\n};\n\n/**\n * Adds two vec3's after scaling the second operand by a scalar value\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec3} out\n */\nvec3.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} distance between a and b\n */\nvec3.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.distance}\n * @function\n */\nvec3.dist = vec3.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec3.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredDistance}\n * @function\n */\nvec3.sqrDist = vec3.squaredDistance;\n\n/**\n * Calculates the length of a vec3\n *\n * @param {vec3} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec3.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return Math.sqrt(x*x + y*y + z*z);\n};\n\n/**\n * Alias for {@link vec3.length}\n * @function\n */\nvec3.len = vec3.length;\n\n/**\n * Calculates the squared length of a vec3\n *\n * @param {vec3} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec3.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    return x*x + y*y + z*z;\n};\n\n/**\n * Alias for {@link vec3.squaredLength}\n * @function\n */\nvec3.sqrLen = vec3.squaredLength;\n\n/**\n * Negates the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to negate\n * @returns {vec3} out\n */\nvec3.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to invert\n * @returns {vec3} out\n */\nvec3.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  return out;\n};\n\n/**\n * Normalize a vec3\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a vector to normalize\n * @returns {vec3} out\n */\nvec3.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2];\n    var len = x*x + y*y + z*z;\n    if (len > 0) {\n        //TODO: evaluate use of glm_invsqrt here?\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec3's\n *\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec3.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n};\n\n/**\n * Computes the cross product of two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @returns {vec3} out\n */\nvec3.cross = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2],\n        bx = b[0], by = b[1], bz = b[2];\n\n    out[0] = ay * bz - az * by;\n    out[1] = az * bx - ax * bz;\n    out[2] = ax * by - ay * bx;\n    return out;\n};\n\n/**\n * Performs a linear interpolation between two vec3's\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the first operand\n * @param {vec3} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec3} out\n */\nvec3.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec3} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec3} out\n */\nvec3.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    var r = GLMAT_RANDOM() * 2.0 * Math.PI;\n    var z = (GLMAT_RANDOM() * 2.0) - 1.0;\n    var zScale = Math.sqrt(1.0-z*z) * scale;\n\n    out[0] = Math.cos(r) * zScale;\n    out[1] = Math.sin(r) * zScale;\n    out[2] = z * scale;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat4.\n * 4th vector component is implicitly '1'\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2],\n        w = m[3] * x + m[7] * y + m[11] * z + m[15];\n    w = w || 1.0;\n    out[0] = (m[0] * x + m[4] * y + m[8] * z + m[12]) / w;\n    out[1] = (m[1] * x + m[5] * y + m[9] * z + m[13]) / w;\n    out[2] = (m[2] * x + m[6] * y + m[10] * z + m[14]) / w;\n    return out;\n};\n\n/**\n * Transforms the vec3 with a mat3.\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {mat4} m the 3x3 matrix to transform with\n * @returns {vec3} out\n */\nvec3.transformMat3 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2];\n    out[0] = x * m[0] + y * m[3] + z * m[6];\n    out[1] = x * m[1] + y * m[4] + z * m[7];\n    out[2] = x * m[2] + y * m[5] + z * m[8];\n    return out;\n};\n\n/**\n * Transforms the vec3 with a quat\n *\n * @param {vec3} out the receiving vector\n * @param {vec3} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec3} out\n */\nvec3.transformQuat = function(out, a, q) {\n    // benchmarks: http://jsperf.com/quaternion-transform-vec3-implementations\n\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the x-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateX = function(out, a, b, c){\n   var p = [], r=[];\n      //Translate point to the origin\n      p[0] = a[0] - b[0];\n      p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n      //perform rotation\n      r[0] = p[0];\n      r[1] = p[1]*Math.cos(c) - p[2]*Math.sin(c);\n      r[2] = p[1]*Math.sin(c) + p[2]*Math.cos(c);\n\n      //translate to correct position\n      out[0] = r[0] + b[0];\n      out[1] = r[1] + b[1];\n      out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the y-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateY = function(out, a, b, c){\n    var p = [], r=[];\n    //Translate point to the origin\n    p[0] = a[0] - b[0];\n    p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n    //perform rotation\n    r[0] = p[2]*Math.sin(c) + p[0]*Math.cos(c);\n    r[1] = p[1];\n    r[2] = p[2]*Math.cos(c) - p[0]*Math.sin(c);\n\n    //translate to correct position\n    out[0] = r[0] + b[0];\n    out[1] = r[1] + b[1];\n    out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Rotate a 3D vector around the z-axis\n * @param {vec3} out The receiving vec3\n * @param {vec3} a The vec3 point to rotate\n * @param {vec3} b The origin of the rotation\n * @param {Number} c The angle of rotation\n * @returns {vec3} out\n */\nvec3.rotateZ = function(out, a, b, c){\n    var p = [], r=[];\n    //Translate point to the origin\n    p[0] = a[0] - b[0];\n    p[1] = a[1] - b[1];\n    p[2] = a[2] - b[2];\n\n    //perform rotation\n    r[0] = p[0]*Math.cos(c) - p[1]*Math.sin(c);\n    r[1] = p[0]*Math.sin(c) + p[1]*Math.cos(c);\n    r[2] = p[2];\n\n    //translate to correct position\n    out[0] = r[0] + b[0];\n    out[1] = r[1] + b[1];\n    out[2] = r[2] + b[2];\n\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec3s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec3. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec3s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec3.forEach = (function() {\n    var vec = vec3.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 3;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Get the angle between two 3D vectors\n * @param {vec3} a The first operand\n * @param {vec3} b The second operand\n * @returns {Number} The angle in radians\n */\nvec3.angle = function(a, b) {\n\n    var tempA = vec3.fromValues(a[0], a[1], a[2]);\n    var tempB = vec3.fromValues(b[0], b[1], b[2]);\n\n    vec3.normalize(tempA, tempA);\n    vec3.normalize(tempB, tempB);\n\n    var cosine = vec3.dot(tempA, tempB);\n\n    if(cosine > 1.0){\n        return 0;\n    } else {\n        return Math.acos(cosine);\n    }\n};\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec3} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec3.str = function (a) {\n    return 'vec3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec3 = vec3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4 Dimensional Vector\n * @name vec4\n */\n\nvar vec4 = {};\n\n/**\n * Creates a new, empty vec4\n *\n * @returns {vec4} a new 4D vector\n */\nvec4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with values from an existing vector\n *\n * @param {vec4} a vector to clone\n * @returns {vec4} a new 4D vector\n */\nvec4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Creates a new vec4 initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} a new 4D vector\n */\nvec4.fromValues = function(x, y, z, w) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Copy the values from one vec4 to another\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the source vector\n * @returns {vec4} out\n */\nvec4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set the components of a vec4 to the given values\n *\n * @param {vec4} out the receiving vector\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {vec4} out\n */\nvec4.set = function(out, x, y, z, w) {\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = w;\n    return out;\n};\n\n/**\n * Adds two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.add = function(out, a, b) {\n    out[0] = a[0] + b[0];\n    out[1] = a[1] + b[1];\n    out[2] = a[2] + b[2];\n    out[3] = a[3] + b[3];\n    return out;\n};\n\n/**\n * Subtracts vector b from vector a\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.subtract = function(out, a, b) {\n    out[0] = a[0] - b[0];\n    out[1] = a[1] - b[1];\n    out[2] = a[2] - b[2];\n    out[3] = a[3] - b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.subtract}\n * @function\n */\nvec4.sub = vec4.subtract;\n\n/**\n * Multiplies two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.multiply = function(out, a, b) {\n    out[0] = a[0] * b[0];\n    out[1] = a[1] * b[1];\n    out[2] = a[2] * b[2];\n    out[3] = a[3] * b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.multiply}\n * @function\n */\nvec4.mul = vec4.multiply;\n\n/**\n * Divides two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.divide = function(out, a, b) {\n    out[0] = a[0] / b[0];\n    out[1] = a[1] / b[1];\n    out[2] = a[2] / b[2];\n    out[3] = a[3] / b[3];\n    return out;\n};\n\n/**\n * Alias for {@link vec4.divide}\n * @function\n */\nvec4.div = vec4.divide;\n\n/**\n * Returns the minimum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.min = function(out, a, b) {\n    out[0] = Math.min(a[0], b[0]);\n    out[1] = Math.min(a[1], b[1]);\n    out[2] = Math.min(a[2], b[2]);\n    out[3] = Math.min(a[3], b[3]);\n    return out;\n};\n\n/**\n * Returns the maximum of two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {vec4} out\n */\nvec4.max = function(out, a, b) {\n    out[0] = Math.max(a[0], b[0]);\n    out[1] = Math.max(a[1], b[1]);\n    out[2] = Math.max(a[2], b[2]);\n    out[3] = Math.max(a[3], b[3]);\n    return out;\n};\n\n/**\n * Scales a vec4 by a scalar number\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {vec4} out\n */\nvec4.scale = function(out, a, b) {\n    out[0] = a[0] * b;\n    out[1] = a[1] * b;\n    out[2] = a[2] * b;\n    out[3] = a[3] * b;\n    return out;\n};\n\n/**\n * Adds two vec4's after scaling the second operand by a scalar value\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} scale the amount to scale b by before adding\n * @returns {vec4} out\n */\nvec4.scaleAndAdd = function(out, a, b, scale) {\n    out[0] = a[0] + (b[0] * scale);\n    out[1] = a[1] + (b[1] * scale);\n    out[2] = a[2] + (b[2] * scale);\n    out[3] = a[3] + (b[3] * scale);\n    return out;\n};\n\n/**\n * Calculates the euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} distance between a and b\n */\nvec4.distance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.distance}\n * @function\n */\nvec4.dist = vec4.distance;\n\n/**\n * Calculates the squared euclidian distance between two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} squared distance between a and b\n */\nvec4.squaredDistance = function(a, b) {\n    var x = b[0] - a[0],\n        y = b[1] - a[1],\n        z = b[2] - a[2],\n        w = b[3] - a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredDistance}\n * @function\n */\nvec4.sqrDist = vec4.squaredDistance;\n\n/**\n * Calculates the length of a vec4\n *\n * @param {vec4} a vector to calculate length of\n * @returns {Number} length of a\n */\nvec4.length = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return Math.sqrt(x*x + y*y + z*z + w*w);\n};\n\n/**\n * Alias for {@link vec4.length}\n * @function\n */\nvec4.len = vec4.length;\n\n/**\n * Calculates the squared length of a vec4\n *\n * @param {vec4} a vector to calculate squared length of\n * @returns {Number} squared length of a\n */\nvec4.squaredLength = function (a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    return x*x + y*y + z*z + w*w;\n};\n\n/**\n * Alias for {@link vec4.squaredLength}\n * @function\n */\nvec4.sqrLen = vec4.squaredLength;\n\n/**\n * Negates the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to negate\n * @returns {vec4} out\n */\nvec4.negate = function(out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = -a[3];\n    return out;\n};\n\n/**\n * Returns the inverse of the components of a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to invert\n * @returns {vec4} out\n */\nvec4.inverse = function(out, a) {\n  out[0] = 1.0 / a[0];\n  out[1] = 1.0 / a[1];\n  out[2] = 1.0 / a[2];\n  out[3] = 1.0 / a[3];\n  return out;\n};\n\n/**\n * Normalize a vec4\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a vector to normalize\n * @returns {vec4} out\n */\nvec4.normalize = function(out, a) {\n    var x = a[0],\n        y = a[1],\n        z = a[2],\n        w = a[3];\n    var len = x*x + y*y + z*z + w*w;\n    if (len > 0) {\n        len = 1 / Math.sqrt(len);\n        out[0] = a[0] * len;\n        out[1] = a[1] * len;\n        out[2] = a[2] * len;\n        out[3] = a[3] * len;\n    }\n    return out;\n};\n\n/**\n * Calculates the dot product of two vec4's\n *\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @returns {Number} dot product of a and b\n */\nvec4.dot = function (a, b) {\n    return a[0] * b[0] + a[1] * b[1] + a[2] * b[2] + a[3] * b[3];\n};\n\n/**\n * Performs a linear interpolation between two vec4's\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the first operand\n * @param {vec4} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {vec4} out\n */\nvec4.lerp = function (out, a, b, t) {\n    var ax = a[0],\n        ay = a[1],\n        az = a[2],\n        aw = a[3];\n    out[0] = ax + t * (b[0] - ax);\n    out[1] = ay + t * (b[1] - ay);\n    out[2] = az + t * (b[2] - az);\n    out[3] = aw + t * (b[3] - aw);\n    return out;\n};\n\n/**\n * Generates a random vector with the given scale\n *\n * @param {vec4} out the receiving vector\n * @param {Number} [scale] Length of the resulting vector. If ommitted, a unit vector will be returned\n * @returns {vec4} out\n */\nvec4.random = function (out, scale) {\n    scale = scale || 1.0;\n\n    //TODO: This is a pretty awful way of doing this. Find something better.\n    out[0] = GLMAT_RANDOM();\n    out[1] = GLMAT_RANDOM();\n    out[2] = GLMAT_RANDOM();\n    out[3] = GLMAT_RANDOM();\n    vec4.normalize(out, out);\n    vec4.scale(out, out, scale);\n    return out;\n};\n\n/**\n * Transforms the vec4 with a mat4.\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {mat4} m matrix to transform with\n * @returns {vec4} out\n */\nvec4.transformMat4 = function(out, a, m) {\n    var x = a[0], y = a[1], z = a[2], w = a[3];\n    out[0] = m[0] * x + m[4] * y + m[8] * z + m[12] * w;\n    out[1] = m[1] * x + m[5] * y + m[9] * z + m[13] * w;\n    out[2] = m[2] * x + m[6] * y + m[10] * z + m[14] * w;\n    out[3] = m[3] * x + m[7] * y + m[11] * z + m[15] * w;\n    return out;\n};\n\n/**\n * Transforms the vec4 with a quat\n *\n * @param {vec4} out the receiving vector\n * @param {vec4} a the vector to transform\n * @param {quat} q quaternion to transform with\n * @returns {vec4} out\n */\nvec4.transformQuat = function(out, a, q) {\n    var x = a[0], y = a[1], z = a[2],\n        qx = q[0], qy = q[1], qz = q[2], qw = q[3],\n\n        // calculate quat * vec\n        ix = qw * x + qy * z - qz * y,\n        iy = qw * y + qz * x - qx * z,\n        iz = qw * z + qx * y - qy * x,\n        iw = -qx * x - qy * y - qz * z;\n\n    // calculate result * inverse quat\n    out[0] = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n    out[1] = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n    out[2] = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n    return out;\n};\n\n/**\n * Perform some operation over an array of vec4s.\n *\n * @param {Array} a the array of vectors to iterate over\n * @param {Number} stride Number of elements between the start of each vec4. If 0 assumes tightly packed\n * @param {Number} offset Number of elements to skip at the beginning of the array\n * @param {Number} count Number of vec4s to iterate over. If 0 iterates over entire array\n * @param {Function} fn Function to call for each vector in the array\n * @param {Object} [arg] additional argument to pass to fn\n * @returns {Array} a\n * @function\n */\nvec4.forEach = (function() {\n    var vec = vec4.create();\n\n    return function(a, stride, offset, count, fn, arg) {\n        var i, l;\n        if(!stride) {\n            stride = 4;\n        }\n\n        if(!offset) {\n            offset = 0;\n        }\n\n        if(count) {\n            l = Math.min((count * stride) + offset, a.length);\n        } else {\n            l = a.length;\n        }\n\n        for(i = offset; i < l; i += stride) {\n            vec[0] = a[i]; vec[1] = a[i+1]; vec[2] = a[i+2]; vec[3] = a[i+3];\n            fn(vec, vec, arg);\n            a[i] = vec[0]; a[i+1] = vec[1]; a[i+2] = vec[2]; a[i+3] = vec[3];\n        }\n\n        return a;\n    };\n})();\n\n/**\n * Returns a string representation of a vector\n *\n * @param {vec4} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nvec4.str = function (a) {\n    return 'vec4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.vec4 = vec4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x2 Matrix\n * @name mat2\n */\n\nvar mat2 = {};\n\n/**\n * Creates a new identity mat2\n *\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat2 initialized with values from an existing matrix\n *\n * @param {mat2} a matrix to clone\n * @returns {mat2} a new 2x2 matrix\n */\nmat2.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Copy the values from one mat2 to another\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Set a mat2 to the identity matrix\n *\n * @param {mat2} out the receiving matrix\n * @returns {mat2} out\n */\nmat2.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a1 = a[1];\n        out[1] = a[2];\n        out[2] = a1;\n    } else {\n        out[0] = a[0];\n        out[1] = a[2];\n        out[2] = a[1];\n        out[3] = a[3];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n\n        // Calculate the determinant\n        det = a0 * a3 - a2 * a1;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] =  a3 * det;\n    out[1] = -a1 * det;\n    out[2] = -a2 * det;\n    out[3] =  a0 * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the source matrix\n * @returns {mat2} out\n */\nmat2.adjoint = function(out, a) {\n    // Caching this value is nessecary if out == a\n    var a0 = a[0];\n    out[0] =  a[3];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] =  a0;\n\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2\n *\n * @param {mat2} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2.determinant = function (a) {\n    return a[0] * a[3] - a[2] * a[1];\n};\n\n/**\n * Multiplies two mat2's\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the first operand\n * @param {mat2} b the second operand\n * @returns {mat2} out\n */\nmat2.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3];\n    var b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    return out;\n};\n\n/**\n * Alias for {@link mat2.multiply}\n * @function\n */\nmat2.mul = mat2.multiply;\n\n/**\n * Rotates a mat2 by the given angle\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2} out\n */\nmat2.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    return out;\n};\n\n/**\n * Scales the mat2 by the dimensions in the given vec2\n *\n * @param {mat2} out the receiving matrix\n * @param {mat2} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2} out\n **/\nmat2.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2\n *\n * @param {mat2} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2.str = function (a) {\n    return 'mat2(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2\n *\n * @param {mat2} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2)))\n};\n\n/**\n * Returns L, D and U matrices (Lower triangular, Diagonal and Upper triangular) by factorizing the input matrix\n * @param {mat2} L the lower triangular matrix\n * @param {mat2} D the diagonal matrix\n * @param {mat2} U the upper triangular matrix\n * @param {mat2} a the input matrix to factorize\n */\n\nmat2.LDU = function (L, D, U, a) {\n    L[2] = a[2]/a[0];\n    U[0] = a[0];\n    U[1] = a[1];\n    U[3] = a[3] - L[2] * U[1];\n    return [L, D, U];\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2 = mat2;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 2x3 Matrix\n * @name mat2d\n *\n * @description\n * A mat2d contains six elements defined as:\n * <pre>\n * [a, c, tx,\n *  b, d, ty]\n * </pre>\n * This is a short form for the 3x3 matrix:\n * <pre>\n * [a, c, tx,\n *  b, d, ty,\n *  0, 0, 1]\n * </pre>\n * The last row is ignored so the array is shorter and operations are faster.\n */\n\nvar mat2d = {};\n\n/**\n * Creates a new identity mat2d\n *\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Creates a new mat2d initialized with values from an existing matrix\n *\n * @param {mat2d} a matrix to clone\n * @returns {mat2d} a new 2x3 matrix\n */\nmat2d.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(6);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Copy the values from one mat2d to another\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    return out;\n};\n\n/**\n * Set a mat2d to the identity matrix\n *\n * @param {mat2d} out the receiving matrix\n * @returns {mat2d} out\n */\nmat2d.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    out[4] = 0;\n    out[5] = 0;\n    return out;\n};\n\n/**\n * Inverts a mat2d\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the source matrix\n * @returns {mat2d} out\n */\nmat2d.invert = function(out, a) {\n    var aa = a[0], ab = a[1], ac = a[2], ad = a[3],\n        atx = a[4], aty = a[5];\n\n    var det = aa * ad - ab * ac;\n    if(!det){\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = ad * det;\n    out[1] = -ab * det;\n    out[2] = -ac * det;\n    out[3] = aa * det;\n    out[4] = (ac * aty - ad * atx) * det;\n    out[5] = (ab * atx - aa * aty) * det;\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat2d\n *\n * @param {mat2d} a the source matrix\n * @returns {Number} determinant of a\n */\nmat2d.determinant = function (a) {\n    return a[0] * a[3] - a[1] * a[2];\n};\n\n/**\n * Multiplies two mat2d's\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the first operand\n * @param {mat2d} b the second operand\n * @returns {mat2d} out\n */\nmat2d.multiply = function (out, a, b) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        b0 = b[0], b1 = b[1], b2 = b[2], b3 = b[3], b4 = b[4], b5 = b[5];\n    out[0] = a0 * b0 + a2 * b1;\n    out[1] = a1 * b0 + a3 * b1;\n    out[2] = a0 * b2 + a2 * b3;\n    out[3] = a1 * b2 + a3 * b3;\n    out[4] = a0 * b4 + a2 * b5 + a4;\n    out[5] = a1 * b4 + a3 * b5 + a5;\n    return out;\n};\n\n/**\n * Alias for {@link mat2d.multiply}\n * @function\n */\nmat2d.mul = mat2d.multiply;\n\n\n/**\n * Rotates a mat2d by the given angle\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat2d} out\n */\nmat2d.rotate = function (out, a, rad) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n    out[0] = a0 *  c + a2 * s;\n    out[1] = a1 *  c + a3 * s;\n    out[2] = a0 * -s + a2 * c;\n    out[3] = a1 * -s + a3 * c;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Scales the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat2d} out\n **/\nmat2d.scale = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0 * v0;\n    out[1] = a1 * v0;\n    out[2] = a2 * v1;\n    out[3] = a3 * v1;\n    out[4] = a4;\n    out[5] = a5;\n    return out;\n};\n\n/**\n * Translates the mat2d by the dimensions in the given vec2\n *\n * @param {mat2d} out the receiving matrix\n * @param {mat2d} a the matrix to translate\n * @param {vec2} v the vec2 to translate the matrix by\n * @returns {mat2d} out\n **/\nmat2d.translate = function(out, a, v) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3], a4 = a[4], a5 = a[5],\n        v0 = v[0], v1 = v[1];\n    out[0] = a0;\n    out[1] = a1;\n    out[2] = a2;\n    out[3] = a3;\n    out[4] = a0 * v0 + a2 * v1 + a4;\n    out[5] = a1 * v0 + a3 * v1 + a5;\n    return out;\n};\n\n/**\n * Returns a string representation of a mat2d\n *\n * @param {mat2d} a matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat2d.str = function (a) {\n    return 'mat2d(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' +\n                    a[3] + ', ' + a[4] + ', ' + a[5] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat2d\n *\n * @param {mat2d} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat2d.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + 1))\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat2d = mat2d;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 3x3 Matrix\n * @name mat3\n */\n\nvar mat3 = {};\n\n/**\n * Creates a new identity mat3\n *\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Copies the upper-left 3x3 values into the given mat3.\n *\n * @param {mat3} out the receiving 3x3 matrix\n * @param {mat4} a   the source 4x4 matrix\n * @returns {mat3} out\n */\nmat3.fromMat4 = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[4];\n    out[4] = a[5];\n    out[5] = a[6];\n    out[6] = a[8];\n    out[7] = a[9];\n    out[8] = a[10];\n    return out;\n};\n\n/**\n * Creates a new mat3 initialized with values from an existing matrix\n *\n * @param {mat3} a matrix to clone\n * @returns {mat3} a new 3x3 matrix\n */\nmat3.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(9);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copy the values from one mat3 to another\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Set a mat3 to the identity matrix\n *\n * @param {mat3} out the receiving matrix\n * @returns {mat3} out\n */\nmat3.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 1;\n    out[5] = 0;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a12 = a[5];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a01;\n        out[5] = a[7];\n        out[6] = a02;\n        out[7] = a12;\n    } else {\n        out[0] = a[0];\n        out[1] = a[3];\n        out[2] = a[6];\n        out[3] = a[1];\n        out[4] = a[4];\n        out[5] = a[7];\n        out[6] = a[2];\n        out[7] = a[5];\n        out[8] = a[8];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b01 = a22 * a11 - a12 * a21,\n        b11 = -a22 * a10 + a12 * a20,\n        b21 = a21 * a10 - a11 * a20,\n\n        // Calculate the determinant\n        det = a00 * b01 + a01 * b11 + a02 * b21;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = b01 * det;\n    out[1] = (-a22 * a01 + a02 * a21) * det;\n    out[2] = (a12 * a01 - a02 * a11) * det;\n    out[3] = b11 * det;\n    out[4] = (a22 * a00 - a02 * a20) * det;\n    out[5] = (-a12 * a00 + a02 * a10) * det;\n    out[6] = b21 * det;\n    out[7] = (-a21 * a00 + a01 * a20) * det;\n    out[8] = (a11 * a00 - a01 * a10) * det;\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the source matrix\n * @returns {mat3} out\n */\nmat3.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    out[0] = (a11 * a22 - a12 * a21);\n    out[1] = (a02 * a21 - a01 * a22);\n    out[2] = (a01 * a12 - a02 * a11);\n    out[3] = (a12 * a20 - a10 * a22);\n    out[4] = (a00 * a22 - a02 * a20);\n    out[5] = (a02 * a10 - a00 * a12);\n    out[6] = (a10 * a21 - a11 * a20);\n    out[7] = (a01 * a20 - a00 * a21);\n    out[8] = (a00 * a11 - a01 * a10);\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat3\n *\n * @param {mat3} a the source matrix\n * @returns {Number} determinant of a\n */\nmat3.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8];\n\n    return a00 * (a22 * a11 - a12 * a21) + a01 * (-a22 * a10 + a12 * a20) + a02 * (a21 * a10 - a11 * a20);\n};\n\n/**\n * Multiplies two mat3's\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the first operand\n * @param {mat3} b the second operand\n * @returns {mat3} out\n */\nmat3.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        b00 = b[0], b01 = b[1], b02 = b[2],\n        b10 = b[3], b11 = b[4], b12 = b[5],\n        b20 = b[6], b21 = b[7], b22 = b[8];\n\n    out[0] = b00 * a00 + b01 * a10 + b02 * a20;\n    out[1] = b00 * a01 + b01 * a11 + b02 * a21;\n    out[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n    out[3] = b10 * a00 + b11 * a10 + b12 * a20;\n    out[4] = b10 * a01 + b11 * a11 + b12 * a21;\n    out[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n    out[6] = b20 * a00 + b21 * a10 + b22 * a20;\n    out[7] = b20 * a01 + b21 * a11 + b22 * a21;\n    out[8] = b20 * a02 + b21 * a12 + b22 * a22;\n    return out;\n};\n\n/**\n * Alias for {@link mat3.multiply}\n * @function\n */\nmat3.mul = mat3.multiply;\n\n/**\n * Translate a mat3 by the given vector\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to translate\n * @param {vec2} v vector to translate by\n * @returns {mat3} out\n */\nmat3.translate = function(out, a, v) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n        x = v[0], y = v[1];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n\n    out[3] = a10;\n    out[4] = a11;\n    out[5] = a12;\n\n    out[6] = x * a00 + y * a10 + a20;\n    out[7] = x * a01 + y * a11 + a21;\n    out[8] = x * a02 + y * a12 + a22;\n    return out;\n};\n\n/**\n * Rotates a mat3 by the given angle\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat3} out\n */\nmat3.rotate = function (out, a, rad) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[3], a11 = a[4], a12 = a[5],\n        a20 = a[6], a21 = a[7], a22 = a[8],\n\n        s = Math.sin(rad),\n        c = Math.cos(rad);\n\n    out[0] = c * a00 + s * a10;\n    out[1] = c * a01 + s * a11;\n    out[2] = c * a02 + s * a12;\n\n    out[3] = c * a10 - s * a00;\n    out[4] = c * a11 - s * a01;\n    out[5] = c * a12 - s * a02;\n\n    out[6] = a20;\n    out[7] = a21;\n    out[8] = a22;\n    return out;\n};\n\n/**\n * Scales the mat3 by the dimensions in the given vec2\n *\n * @param {mat3} out the receiving matrix\n * @param {mat3} a the matrix to rotate\n * @param {vec2} v the vec2 to scale the matrix by\n * @returns {mat3} out\n **/\nmat3.scale = function(out, a, v) {\n    var x = v[0], y = v[1];\n\n    out[0] = x * a[0];\n    out[1] = x * a[1];\n    out[2] = x * a[2];\n\n    out[3] = y * a[3];\n    out[4] = y * a[4];\n    out[5] = y * a[5];\n\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    return out;\n};\n\n/**\n * Copies the values from a mat2d into a mat3\n *\n * @param {mat3} out the receiving matrix\n * @param {mat2d} a the matrix to copy\n * @returns {mat3} out\n **/\nmat3.fromMat2d = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = 0;\n\n    out[3] = a[2];\n    out[4] = a[3];\n    out[5] = 0;\n\n    out[6] = a[4];\n    out[7] = a[5];\n    out[8] = 1;\n    return out;\n};\n\n/**\n* Calculates a 3x3 matrix from the given quaternion\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {quat} q Quaternion to create matrix from\n*\n* @returns {mat3} out\n*/\nmat3.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[3] = yx - wz;\n    out[6] = zx + wy;\n\n    out[1] = yx + wz;\n    out[4] = 1 - xx - zz;\n    out[7] = zy - wx;\n\n    out[2] = zx - wy;\n    out[5] = zy + wx;\n    out[8] = 1 - xx - yy;\n\n    return out;\n};\n\n/**\n* Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n*\n* @param {mat3} out mat3 receiving operation result\n* @param {mat4} a Mat4 to derive the normal matrix from\n*\n* @returns {mat3} out\n*/\nmat3.normalFromMat4 = function (out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[2] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n\n    out[3] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[4] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[5] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n\n    out[6] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[7] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[8] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat3\n *\n * @param {mat3} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat3.str = function (a) {\n    return 'mat3(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' +\n                    a[3] + ', ' + a[4] + ', ' + a[5] + ', ' +\n                    a[6] + ', ' + a[7] + ', ' + a[8] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat3\n *\n * @param {mat3} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat3.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2)))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat3 = mat3;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class 4x4 Matrix\n * @name mat4\n */\n\nvar mat4 = {};\n\n/**\n * Creates a new identity mat4\n *\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Creates a new mat4 initialized with values from an existing matrix\n *\n * @param {mat4} a matrix to clone\n * @returns {mat4} a new 4x4 matrix\n */\nmat4.clone = function(a) {\n    var out = new GLMAT_ARRAY_TYPE(16);\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Copy the values from one mat4 to another\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.copy = function(out, a) {\n    out[0] = a[0];\n    out[1] = a[1];\n    out[2] = a[2];\n    out[3] = a[3];\n    out[4] = a[4];\n    out[5] = a[5];\n    out[6] = a[6];\n    out[7] = a[7];\n    out[8] = a[8];\n    out[9] = a[9];\n    out[10] = a[10];\n    out[11] = a[11];\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Set a mat4 to the identity matrix\n *\n * @param {mat4} out the receiving matrix\n * @returns {mat4} out\n */\nmat4.identity = function(out) {\n    out[0] = 1;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = 1;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 1;\n    out[11] = 0;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Transpose the values of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.transpose = function(out, a) {\n    // If we are transposing ourselves we can skip a few steps but have to cache some values\n    if (out === a) {\n        var a01 = a[1], a02 = a[2], a03 = a[3],\n            a12 = a[6], a13 = a[7],\n            a23 = a[11];\n\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a01;\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a02;\n        out[9] = a12;\n        out[11] = a[14];\n        out[12] = a03;\n        out[13] = a13;\n        out[14] = a23;\n    } else {\n        out[0] = a[0];\n        out[1] = a[4];\n        out[2] = a[8];\n        out[3] = a[12];\n        out[4] = a[1];\n        out[5] = a[5];\n        out[6] = a[9];\n        out[7] = a[13];\n        out[8] = a[2];\n        out[9] = a[6];\n        out[10] = a[10];\n        out[11] = a[14];\n        out[12] = a[3];\n        out[13] = a[7];\n        out[14] = a[11];\n        out[15] = a[15];\n    }\n\n    return out;\n};\n\n/**\n * Inverts a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.invert = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32,\n\n        // Calculate the determinant\n        det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n\n    if (!det) {\n        return null;\n    }\n    det = 1.0 / det;\n\n    out[0] = (a11 * b11 - a12 * b10 + a13 * b09) * det;\n    out[1] = (a02 * b10 - a01 * b11 - a03 * b09) * det;\n    out[2] = (a31 * b05 - a32 * b04 + a33 * b03) * det;\n    out[3] = (a22 * b04 - a21 * b05 - a23 * b03) * det;\n    out[4] = (a12 * b08 - a10 * b11 - a13 * b07) * det;\n    out[5] = (a00 * b11 - a02 * b08 + a03 * b07) * det;\n    out[6] = (a32 * b02 - a30 * b05 - a33 * b01) * det;\n    out[7] = (a20 * b05 - a22 * b02 + a23 * b01) * det;\n    out[8] = (a10 * b10 - a11 * b08 + a13 * b06) * det;\n    out[9] = (a01 * b08 - a00 * b10 - a03 * b06) * det;\n    out[10] = (a30 * b04 - a31 * b02 + a33 * b00) * det;\n    out[11] = (a21 * b02 - a20 * b04 - a23 * b00) * det;\n    out[12] = (a11 * b07 - a10 * b09 - a12 * b06) * det;\n    out[13] = (a00 * b09 - a01 * b07 + a02 * b06) * det;\n    out[14] = (a31 * b01 - a30 * b03 - a32 * b00) * det;\n    out[15] = (a20 * b03 - a21 * b01 + a22 * b00) * det;\n\n    return out;\n};\n\n/**\n * Calculates the adjugate of a mat4\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the source matrix\n * @returns {mat4} out\n */\nmat4.adjoint = function(out, a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    out[0]  =  (a11 * (a22 * a33 - a23 * a32) - a21 * (a12 * a33 - a13 * a32) + a31 * (a12 * a23 - a13 * a22));\n    out[1]  = -(a01 * (a22 * a33 - a23 * a32) - a21 * (a02 * a33 - a03 * a32) + a31 * (a02 * a23 - a03 * a22));\n    out[2]  =  (a01 * (a12 * a33 - a13 * a32) - a11 * (a02 * a33 - a03 * a32) + a31 * (a02 * a13 - a03 * a12));\n    out[3]  = -(a01 * (a12 * a23 - a13 * a22) - a11 * (a02 * a23 - a03 * a22) + a21 * (a02 * a13 - a03 * a12));\n    out[4]  = -(a10 * (a22 * a33 - a23 * a32) - a20 * (a12 * a33 - a13 * a32) + a30 * (a12 * a23 - a13 * a22));\n    out[5]  =  (a00 * (a22 * a33 - a23 * a32) - a20 * (a02 * a33 - a03 * a32) + a30 * (a02 * a23 - a03 * a22));\n    out[6]  = -(a00 * (a12 * a33 - a13 * a32) - a10 * (a02 * a33 - a03 * a32) + a30 * (a02 * a13 - a03 * a12));\n    out[7]  =  (a00 * (a12 * a23 - a13 * a22) - a10 * (a02 * a23 - a03 * a22) + a20 * (a02 * a13 - a03 * a12));\n    out[8]  =  (a10 * (a21 * a33 - a23 * a31) - a20 * (a11 * a33 - a13 * a31) + a30 * (a11 * a23 - a13 * a21));\n    out[9]  = -(a00 * (a21 * a33 - a23 * a31) - a20 * (a01 * a33 - a03 * a31) + a30 * (a01 * a23 - a03 * a21));\n    out[10] =  (a00 * (a11 * a33 - a13 * a31) - a10 * (a01 * a33 - a03 * a31) + a30 * (a01 * a13 - a03 * a11));\n    out[11] = -(a00 * (a11 * a23 - a13 * a21) - a10 * (a01 * a23 - a03 * a21) + a20 * (a01 * a13 - a03 * a11));\n    out[12] = -(a10 * (a21 * a32 - a22 * a31) - a20 * (a11 * a32 - a12 * a31) + a30 * (a11 * a22 - a12 * a21));\n    out[13] =  (a00 * (a21 * a32 - a22 * a31) - a20 * (a01 * a32 - a02 * a31) + a30 * (a01 * a22 - a02 * a21));\n    out[14] = -(a00 * (a11 * a32 - a12 * a31) - a10 * (a01 * a32 - a02 * a31) + a30 * (a01 * a12 - a02 * a11));\n    out[15] =  (a00 * (a11 * a22 - a12 * a21) - a10 * (a01 * a22 - a02 * a21) + a20 * (a01 * a12 - a02 * a11));\n    return out;\n};\n\n/**\n * Calculates the determinant of a mat4\n *\n * @param {mat4} a the source matrix\n * @returns {Number} determinant of a\n */\nmat4.determinant = function (a) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15],\n\n        b00 = a00 * a11 - a01 * a10,\n        b01 = a00 * a12 - a02 * a10,\n        b02 = a00 * a13 - a03 * a10,\n        b03 = a01 * a12 - a02 * a11,\n        b04 = a01 * a13 - a03 * a11,\n        b05 = a02 * a13 - a03 * a12,\n        b06 = a20 * a31 - a21 * a30,\n        b07 = a20 * a32 - a22 * a30,\n        b08 = a20 * a33 - a23 * a30,\n        b09 = a21 * a32 - a22 * a31,\n        b10 = a21 * a33 - a23 * a31,\n        b11 = a22 * a33 - a23 * a32;\n\n    // Calculate the determinant\n    return b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\n};\n\n/**\n * Multiplies two mat4's\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiply = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2], a03 = a[3],\n        a10 = a[4], a11 = a[5], a12 = a[6], a13 = a[7],\n        a20 = a[8], a21 = a[9], a22 = a[10], a23 = a[11],\n        a30 = a[12], a31 = a[13], a32 = a[14], a33 = a[15];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2], b3 = b[3];\n    out[0] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[1] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[2] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[3] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6]; b3 = b[7];\n    out[4] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[5] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[6] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[7] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10]; b3 = b[11];\n    out[8] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[9] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[10] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[11] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14]; b3 = b[15];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + b3*a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + b3*a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + b3*a32;\n    out[15] = b0*a03 + b1*a13 + b2*a23 + b3*a33;\n    return out;\n};\n\n/**\n * Multiplies two affine mat4's\n * Add by https://github.com/pissang\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the first operand\n * @param {mat4} b the second operand\n * @returns {mat4} out\n */\nmat4.multiplyAffine = function (out, a, b) {\n    var a00 = a[0], a01 = a[1], a02 = a[2],\n        a10 = a[4], a11 = a[5], a12 = a[6],\n        a20 = a[8], a21 = a[9], a22 = a[10],\n        a30 = a[12], a31 = a[13], a32 = a[14];\n\n    // Cache only the current line of the second matrix\n    var b0  = b[0], b1 = b[1], b2 = b[2];\n    out[0] = b0*a00 + b1*a10 + b2*a20;\n    out[1] = b0*a01 + b1*a11 + b2*a21;\n    out[2] = b0*a02 + b1*a12 + b2*a22;\n    // out[3] = 0;\n\n    b0 = b[4]; b1 = b[5]; b2 = b[6];\n    out[4] = b0*a00 + b1*a10 + b2*a20;\n    out[5] = b0*a01 + b1*a11 + b2*a21;\n    out[6] = b0*a02 + b1*a12 + b2*a22;\n    // out[7] = 0;\n\n    b0 = b[8]; b1 = b[9]; b2 = b[10];\n    out[8] = b0*a00 + b1*a10 + b2*a20;\n    out[9] = b0*a01 + b1*a11 + b2*a21;\n    out[10] = b0*a02 + b1*a12 + b2*a22;\n    // out[11] = 0;\n\n    b0 = b[12]; b1 = b[13]; b2 = b[14];\n    out[12] = b0*a00 + b1*a10 + b2*a20 + a30;\n    out[13] = b0*a01 + b1*a11 + b2*a21 + a31;\n    out[14] = b0*a02 + b1*a12 + b2*a22 + a32;\n    // out[15] = 1;\n    return out;\n};\n\n/**\n * Alias for {@link mat4.multiply}\n * @function\n */\nmat4.mul = mat4.multiply;\n\n/**\n * Alias for {@link mat4.multiplyAffine}\n * @function\n */\nmat4.mulAffine = mat4.multiplyAffine;\n/**\n * Translate a mat4 by the given vector\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to translate\n * @param {vec3} v vector to translate by\n * @returns {mat4} out\n */\nmat4.translate = function (out, a, v) {\n    var x = v[0], y = v[1], z = v[2],\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23;\n\n    if (a === out) {\n        out[12] = a[0] * x + a[4] * y + a[8] * z + a[12];\n        out[13] = a[1] * x + a[5] * y + a[9] * z + a[13];\n        out[14] = a[2] * x + a[6] * y + a[10] * z + a[14];\n        out[15] = a[3] * x + a[7] * y + a[11] * z + a[15];\n    } else {\n        a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n        a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n        a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n        out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a03;\n        out[4] = a10; out[5] = a11; out[6] = a12; out[7] = a13;\n        out[8] = a20; out[9] = a21; out[10] = a22; out[11] = a23;\n\n        out[12] = a00 * x + a10 * y + a20 * z + a[12];\n        out[13] = a01 * x + a11 * y + a21 * z + a[13];\n        out[14] = a02 * x + a12 * y + a22 * z + a[14];\n        out[15] = a03 * x + a13 * y + a23 * z + a[15];\n    }\n\n    return out;\n};\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to scale\n * @param {vec3} v the vec3 to scale the matrix by\n * @returns {mat4} out\n **/\nmat4.scale = function(out, a, v) {\n    var x = v[0], y = v[1], z = v[2];\n\n    out[0] = a[0] * x;\n    out[1] = a[1] * x;\n    out[2] = a[2] * x;\n    out[3] = a[3] * x;\n    out[4] = a[4] * y;\n    out[5] = a[5] * y;\n    out[6] = a[6] * y;\n    out[7] = a[7] * y;\n    out[8] = a[8] * z;\n    out[9] = a[9] * z;\n    out[10] = a[10] * z;\n    out[11] = a[11] * z;\n    out[12] = a[12];\n    out[13] = a[13];\n    out[14] = a[14];\n    out[15] = a[15];\n    return out;\n};\n\n/**\n * Rotates a mat4 by the given angle\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @param {vec3} axis the axis to rotate around\n * @returns {mat4} out\n */\nmat4.rotate = function (out, a, rad, axis) {\n    var x = axis[0], y = axis[1], z = axis[2],\n        len = Math.sqrt(x * x + y * y + z * z),\n        s, c, t,\n        a00, a01, a02, a03,\n        a10, a11, a12, a13,\n        a20, a21, a22, a23,\n        b00, b01, b02,\n        b10, b11, b12,\n        b20, b21, b22;\n\n    if (Math.abs(len) < GLMAT_EPSILON) { return null; }\n\n    len = 1 / len;\n    x *= len;\n    y *= len;\n    z *= len;\n\n    s = Math.sin(rad);\n    c = Math.cos(rad);\n    t = 1 - c;\n\n    a00 = a[0]; a01 = a[1]; a02 = a[2]; a03 = a[3];\n    a10 = a[4]; a11 = a[5]; a12 = a[6]; a13 = a[7];\n    a20 = a[8]; a21 = a[9]; a22 = a[10]; a23 = a[11];\n\n    // Construct the elements of the rotation matrix\n    b00 = x * x * t + c; b01 = y * x * t + z * s; b02 = z * x * t - y * s;\n    b10 = x * y * t - z * s; b11 = y * y * t + c; b12 = z * y * t + x * s;\n    b20 = x * z * t + y * s; b21 = y * z * t - x * s; b22 = z * z * t + c;\n\n    // Perform rotation-specific matrix multiplication\n    out[0] = a00 * b00 + a10 * b01 + a20 * b02;\n    out[1] = a01 * b00 + a11 * b01 + a21 * b02;\n    out[2] = a02 * b00 + a12 * b01 + a22 * b02;\n    out[3] = a03 * b00 + a13 * b01 + a23 * b02;\n    out[4] = a00 * b10 + a10 * b11 + a20 * b12;\n    out[5] = a01 * b10 + a11 * b11 + a21 * b12;\n    out[6] = a02 * b10 + a12 * b11 + a22 * b12;\n    out[7] = a03 * b10 + a13 * b11 + a23 * b12;\n    out[8] = a00 * b20 + a10 * b21 + a20 * b22;\n    out[9] = a01 * b20 + a11 * b21 + a21 * b22;\n    out[10] = a02 * b20 + a12 * b21 + a22 * b22;\n    out[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the X axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateX = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[0]  = a[0];\n        out[1]  = a[1];\n        out[2]  = a[2];\n        out[3]  = a[3];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[4] = a10 * c + a20 * s;\n    out[5] = a11 * c + a21 * s;\n    out[6] = a12 * c + a22 * s;\n    out[7] = a13 * c + a23 * s;\n    out[8] = a20 * c - a10 * s;\n    out[9] = a21 * c - a11 * s;\n    out[10] = a22 * c - a12 * s;\n    out[11] = a23 * c - a13 * s;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Y axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateY = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a20 = a[8],\n        a21 = a[9],\n        a22 = a[10],\n        a23 = a[11];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged rows\n        out[4]  = a[4];\n        out[5]  = a[5];\n        out[6]  = a[6];\n        out[7]  = a[7];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c - a20 * s;\n    out[1] = a01 * c - a21 * s;\n    out[2] = a02 * c - a22 * s;\n    out[3] = a03 * c - a23 * s;\n    out[8] = a00 * s + a20 * c;\n    out[9] = a01 * s + a21 * c;\n    out[10] = a02 * s + a22 * c;\n    out[11] = a03 * s + a23 * c;\n    return out;\n};\n\n/**\n * Rotates a matrix by the given angle around the Z axis\n *\n * @param {mat4} out the receiving matrix\n * @param {mat4} a the matrix to rotate\n * @param {Number} rad the angle to rotate the matrix by\n * @returns {mat4} out\n */\nmat4.rotateZ = function (out, a, rad) {\n    var s = Math.sin(rad),\n        c = Math.cos(rad),\n        a00 = a[0],\n        a01 = a[1],\n        a02 = a[2],\n        a03 = a[3],\n        a10 = a[4],\n        a11 = a[5],\n        a12 = a[6],\n        a13 = a[7];\n\n    if (a !== out) { // If the source and destination differ, copy the unchanged last row\n        out[8]  = a[8];\n        out[9]  = a[9];\n        out[10] = a[10];\n        out[11] = a[11];\n        out[12] = a[12];\n        out[13] = a[13];\n        out[14] = a[14];\n        out[15] = a[15];\n    }\n\n    // Perform axis-specific matrix multiplication\n    out[0] = a00 * c + a10 * s;\n    out[1] = a01 * c + a11 * s;\n    out[2] = a02 * c + a12 * s;\n    out[3] = a03 * c + a13 * s;\n    out[4] = a10 * c - a00 * s;\n    out[5] = a11 * c - a01 * s;\n    out[6] = a12 * c - a02 * s;\n    out[7] = a13 * c - a03 * s;\n    return out;\n};\n\n/**\n * Creates a matrix from a quaternion rotation and vector translation\n * This is equivalent to (but much faster than):\n *\n *     mat4.identity(dest);\n *     mat4.translate(dest, vec);\n *     var quatMat = mat4.create();\n *     quat4.toMat4(quat, quatMat);\n *     mat4.multiply(dest, quatMat);\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @param {vec3} v Translation vector\n * @returns {mat4} out\n */\nmat4.fromRotationTranslation = function (out, q, v) {\n    // Quaternion math\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        xy = x * y2,\n        xz = x * z2,\n        yy = y * y2,\n        yz = y * z2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - (yy + zz);\n    out[1] = xy + wz;\n    out[2] = xz - wy;\n    out[3] = 0;\n    out[4] = xy - wz;\n    out[5] = 1 - (xx + zz);\n    out[6] = yz + wx;\n    out[7] = 0;\n    out[8] = xz + wy;\n    out[9] = yz - wx;\n    out[10] = 1 - (xx + yy);\n    out[11] = 0;\n    out[12] = v[0];\n    out[13] = v[1];\n    out[14] = v[2];\n    out[15] = 1;\n\n    return out;\n};\n\nmat4.fromQuat = function (out, q) {\n    var x = q[0], y = q[1], z = q[2], w = q[3],\n        x2 = x + x,\n        y2 = y + y,\n        z2 = z + z,\n\n        xx = x * x2,\n        yx = y * x2,\n        yy = y * y2,\n        zx = z * x2,\n        zy = z * y2,\n        zz = z * z2,\n        wx = w * x2,\n        wy = w * y2,\n        wz = w * z2;\n\n    out[0] = 1 - yy - zz;\n    out[1] = yx + wz;\n    out[2] = zx - wy;\n    out[3] = 0;\n\n    out[4] = yx - wz;\n    out[5] = 1 - xx - zz;\n    out[6] = zy + wx;\n    out[7] = 0;\n\n    out[8] = zx + wy;\n    out[9] = zy - wx;\n    out[10] = 1 - xx - yy;\n    out[11] = 0;\n\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = 0;\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Generates a frustum matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {Number} left Left bound of the frustum\n * @param {Number} right Right bound of the frustum\n * @param {Number} bottom Bottom bound of the frustum\n * @param {Number} top Top bound of the frustum\n * @param {Number} near Near bound of the frustum\n * @param {Number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.frustum = function (out, left, right, bottom, top, near, far) {\n    var rl = 1 / (right - left),\n        tb = 1 / (top - bottom),\n        nf = 1 / (near - far);\n    out[0] = (near * 2) * rl;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = (near * 2) * tb;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = (right + left) * rl;\n    out[9] = (top + bottom) * tb;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (far * near * 2) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a perspective projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} fovy Vertical field of view in radians\n * @param {number} aspect Aspect ratio. typically viewport width/height\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.perspective = function (out, fovy, aspect, near, far) {\n    var f = 1.0 / Math.tan(fovy / 2),\n        nf = 1 / (near - far);\n    out[0] = f / aspect;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = f;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = (far + near) * nf;\n    out[11] = -1;\n    out[12] = 0;\n    out[13] = 0;\n    out[14] = (2 * far * near) * nf;\n    out[15] = 0;\n    return out;\n};\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @returns {mat4} out\n */\nmat4.ortho = function (out, left, right, bottom, top, near, far) {\n    var lr = 1 / (left - right),\n        bt = 1 / (bottom - top),\n        nf = 1 / (near - far);\n    out[0] = -2 * lr;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 0;\n    out[4] = 0;\n    out[5] = -2 * bt;\n    out[6] = 0;\n    out[7] = 0;\n    out[8] = 0;\n    out[9] = 0;\n    out[10] = 2 * nf;\n    out[11] = 0;\n    out[12] = (left + right) * lr;\n    out[13] = (top + bottom) * bt;\n    out[14] = (far + near) * nf;\n    out[15] = 1;\n    return out;\n};\n\n/**\n * Generates a look-at matrix with the given eye position, focal point, and up axis\n *\n * @param {mat4} out mat4 frustum matrix will be written into\n * @param {vec3} eye Position of the viewer\n * @param {vec3} center Point the viewer is looking at\n * @param {vec3} up vec3 pointing up\n * @returns {mat4} out\n */\nmat4.lookAt = function (out, eye, center, up) {\n    var x0, x1, x2, y0, y1, y2, z0, z1, z2, len,\n        eyex = eye[0],\n        eyey = eye[1],\n        eyez = eye[2],\n        upx = up[0],\n        upy = up[1],\n        upz = up[2],\n        centerx = center[0],\n        centery = center[1],\n        centerz = center[2];\n\n    if (Math.abs(eyex - centerx) < GLMAT_EPSILON &&\n        Math.abs(eyey - centery) < GLMAT_EPSILON &&\n        Math.abs(eyez - centerz) < GLMAT_EPSILON) {\n        return mat4.identity(out);\n    }\n\n    z0 = eyex - centerx;\n    z1 = eyey - centery;\n    z2 = eyez - centerz;\n\n    len = 1 / Math.sqrt(z0 * z0 + z1 * z1 + z2 * z2);\n    z0 *= len;\n    z1 *= len;\n    z2 *= len;\n\n    x0 = upy * z2 - upz * z1;\n    x1 = upz * z0 - upx * z2;\n    x2 = upx * z1 - upy * z0;\n    len = Math.sqrt(x0 * x0 + x1 * x1 + x2 * x2);\n    if (!len) {\n        x0 = 0;\n        x1 = 0;\n        x2 = 0;\n    } else {\n        len = 1 / len;\n        x0 *= len;\n        x1 *= len;\n        x2 *= len;\n    }\n\n    y0 = z1 * x2 - z2 * x1;\n    y1 = z2 * x0 - z0 * x2;\n    y2 = z0 * x1 - z1 * x0;\n\n    len = Math.sqrt(y0 * y0 + y1 * y1 + y2 * y2);\n    if (!len) {\n        y0 = 0;\n        y1 = 0;\n        y2 = 0;\n    } else {\n        len = 1 / len;\n        y0 *= len;\n        y1 *= len;\n        y2 *= len;\n    }\n\n    out[0] = x0;\n    out[1] = y0;\n    out[2] = z0;\n    out[3] = 0;\n    out[4] = x1;\n    out[5] = y1;\n    out[6] = z1;\n    out[7] = 0;\n    out[8] = x2;\n    out[9] = y2;\n    out[10] = z2;\n    out[11] = 0;\n    out[12] = -(x0 * eyex + x1 * eyey + x2 * eyez);\n    out[13] = -(y0 * eyex + y1 * eyey + y2 * eyez);\n    out[14] = -(z0 * eyex + z1 * eyey + z2 * eyez);\n    out[15] = 1;\n\n    return out;\n};\n\n/**\n * Returns a string representation of a mat4\n *\n * @param {mat4} mat matrix to represent as a string\n * @returns {String} string representation of the matrix\n */\nmat4.str = function (a) {\n    return 'mat4(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ', ' +\n                    a[4] + ', ' + a[5] + ', ' + a[6] + ', ' + a[7] + ', ' +\n                    a[8] + ', ' + a[9] + ', ' + a[10] + ', ' + a[11] + ', ' +\n                    a[12] + ', ' + a[13] + ', ' + a[14] + ', ' + a[15] + ')';\n};\n\n/**\n * Returns Frobenius norm of a mat4\n *\n * @param {mat4} a the matrix to calculate Frobenius norm of\n * @returns {Number} Frobenius norm\n */\nmat4.frob = function (a) {\n    return(Math.sqrt(Math.pow(a[0], 2) + Math.pow(a[1], 2) + Math.pow(a[2], 2) + Math.pow(a[3], 2) + Math.pow(a[4], 2) + Math.pow(a[5], 2) + Math.pow(a[6], 2) + Math.pow(a[7], 2) + Math.pow(a[8], 2) + Math.pow(a[9], 2) + Math.pow(a[10], 2) + Math.pow(a[11], 2) + Math.pow(a[12], 2) + Math.pow(a[13], 2) + Math.pow(a[14], 2) + Math.pow(a[15], 2) ))\n};\n\n\nif(typeof(exports) !== 'undefined') {\n    exports.mat4 = mat4;\n}\n;\n/* Copyright (c) 2013, Brandon Jones, Colin MacKenzie IV. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification,\nare permitted provided that the following conditions are met:\n\n  * Redistributions of source code must retain the above copyright notice, this\n    list of conditions and the following disclaimer.\n  * Redistributions in binary form must reproduce the above copyright notice,\n    this list of conditions and the following disclaimer in the documentation\n    and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\nANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\nLOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\nANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\nSOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */\n\n/**\n * @class Quaternion\n * @name quat\n */\n\nvar quat = {};\n\n/**\n * Creates a new identity quat\n *\n * @returns {quat} a new quaternion\n */\nquat.create = function() {\n    var out = new GLMAT_ARRAY_TYPE(4);\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quaternion to represent the shortest rotation from one\n * vector to another.\n *\n * Both vectors are assumed to be unit length.\n *\n * @param {quat} out the receiving quaternion.\n * @param {vec3} a the initial vector\n * @param {vec3} b the destination vector\n * @returns {quat} out\n */\nquat.rotationTo = (function() {\n    var tmpvec3 = vec3.create();\n    var xUnitVec3 = vec3.fromValues(1,0,0);\n    var yUnitVec3 = vec3.fromValues(0,1,0);\n\n    return function(out, a, b) {\n        var dot = vec3.dot(a, b);\n        if (dot < -0.999999) {\n            vec3.cross(tmpvec3, xUnitVec3, a);\n            if (vec3.length(tmpvec3) < 0.000001)\n                vec3.cross(tmpvec3, yUnitVec3, a);\n            vec3.normalize(tmpvec3, tmpvec3);\n            quat.setAxisAngle(out, tmpvec3, Math.PI);\n            return out;\n        } else if (dot > 0.999999) {\n            out[0] = 0;\n            out[1] = 0;\n            out[2] = 0;\n            out[3] = 1;\n            return out;\n        } else {\n            vec3.cross(tmpvec3, a, b);\n            out[0] = tmpvec3[0];\n            out[1] = tmpvec3[1];\n            out[2] = tmpvec3[2];\n            out[3] = 1 + dot;\n            return quat.normalize(out, out);\n        }\n    };\n})();\n\n/**\n * Sets the specified quaternion with values corresponding to the given\n * axes. Each axis is a vec3 and is expected to be unit length and\n * perpendicular to all other specified axes.\n *\n * @param {vec3} view  the vector representing the viewing direction\n * @param {vec3} right the vector representing the local \"right\" direction\n * @param {vec3} up    the vector representing the local \"up\" direction\n * @returns {quat} out\n */\nquat.setAxes = (function() {\n    var matr = mat3.create();\n\n    return function(out, view, right, up) {\n        matr[0] = right[0];\n        matr[3] = right[1];\n        matr[6] = right[2];\n\n        matr[1] = up[0];\n        matr[4] = up[1];\n        matr[7] = up[2];\n\n        matr[2] = -view[0];\n        matr[5] = -view[1];\n        matr[8] = -view[2];\n\n        return quat.normalize(out, quat.fromMat3(out, matr));\n    };\n})();\n\n/**\n * Creates a new quat initialized with values from an existing quaternion\n *\n * @param {quat} a quaternion to clone\n * @returns {quat} a new quaternion\n * @function\n */\nquat.clone = vec4.clone;\n\n/**\n * Creates a new quat initialized with the given values\n *\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} a new quaternion\n * @function\n */\nquat.fromValues = vec4.fromValues;\n\n/**\n * Copy the values from one quat to another\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the source quaternion\n * @returns {quat} out\n * @function\n */\nquat.copy = vec4.copy;\n\n/**\n * Set the components of a quat to the given values\n *\n * @param {quat} out the receiving quaternion\n * @param {Number} x X component\n * @param {Number} y Y component\n * @param {Number} z Z component\n * @param {Number} w W component\n * @returns {quat} out\n * @function\n */\nquat.set = vec4.set;\n\n/**\n * Set a quat to the identity quaternion\n *\n * @param {quat} out the receiving quaternion\n * @returns {quat} out\n */\nquat.identity = function(out) {\n    out[0] = 0;\n    out[1] = 0;\n    out[2] = 0;\n    out[3] = 1;\n    return out;\n};\n\n/**\n * Sets a quat from the given angle and rotation axis,\n * then returns it.\n *\n * @param {quat} out the receiving quaternion\n * @param {vec3} axis the axis around which to rotate\n * @param {Number} rad the angle in radians\n * @returns {quat} out\n **/\nquat.setAxisAngle = function(out, axis, rad) {\n    rad = rad * 0.5;\n    var s = Math.sin(rad);\n    out[0] = s * axis[0];\n    out[1] = s * axis[1];\n    out[2] = s * axis[2];\n    out[3] = Math.cos(rad);\n    return out;\n};\n\n/**\n * Adds two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n * @function\n */\nquat.add = vec4.add;\n\n/**\n * Multiplies two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {quat} out\n */\nquat.multiply = function(out, a, b) {\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    out[0] = ax * bw + aw * bx + ay * bz - az * by;\n    out[1] = ay * bw + aw * by + az * bx - ax * bz;\n    out[2] = az * bw + aw * bz + ax * by - ay * bx;\n    out[3] = aw * bw - ax * bx - ay * by - az * bz;\n    return out;\n};\n\n/**\n * Alias for {@link quat.multiply}\n * @function\n */\nquat.mul = quat.multiply;\n\n/**\n * Scales a quat by a scalar number\n *\n * @param {quat} out the receiving vector\n * @param {quat} a the vector to scale\n * @param {Number} b amount to scale the vector by\n * @returns {quat} out\n * @function\n */\nquat.scale = vec4.scale;\n\n/**\n * Rotates a quaternion by the given angle about the X axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateX = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + aw * bx;\n    out[1] = ay * bw + az * bx;\n    out[2] = az * bw - ay * bx;\n    out[3] = aw * bw - ax * bx;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Y axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateY = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        by = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw - az * by;\n    out[1] = ay * bw + aw * by;\n    out[2] = az * bw + ax * by;\n    out[3] = aw * bw - ay * by;\n    return out;\n};\n\n/**\n * Rotates a quaternion by the given angle about the Z axis\n *\n * @param {quat} out quat receiving operation result\n * @param {quat} a quat to rotate\n * @param {number} rad angle (in radians) to rotate\n * @returns {quat} out\n */\nquat.rotateZ = function (out, a, rad) {\n    rad *= 0.5;\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bz = Math.sin(rad), bw = Math.cos(rad);\n\n    out[0] = ax * bw + ay * bz;\n    out[1] = ay * bw - ax * bz;\n    out[2] = az * bw + aw * bz;\n    out[3] = aw * bw - az * bz;\n    return out;\n};\n\n/**\n * Calculates the W component of a quat from the X, Y, and Z components.\n * Assumes that quaternion is 1 unit in length.\n * Any existing W component will be ignored.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate W component of\n * @returns {quat} out\n */\nquat.calculateW = function (out, a) {\n    var x = a[0], y = a[1], z = a[2];\n\n    out[0] = x;\n    out[1] = y;\n    out[2] = z;\n    out[3] = Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z));\n    return out;\n};\n\n/**\n * Calculates the dot product of two quat's\n *\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @returns {Number} dot product of a and b\n * @function\n */\nquat.dot = vec4.dot;\n\n/**\n * Performs a linear interpolation between two quat's\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n * @function\n */\nquat.lerp = vec4.lerp;\n\n/**\n * Performs a spherical linear interpolation between two quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a the first operand\n * @param {quat} b the second operand\n * @param {Number} t interpolation amount between the two inputs\n * @returns {quat} out\n */\nquat.slerp = function (out, a, b, t) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0], ay = a[1], az = a[2], aw = a[3],\n        bx = b[0], by = b[1], bz = b[2], bw = b[3];\n\n    var        omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if ( cosom < 0.0 ) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ( (1.0 - cosom) > 0.000001 ) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    } else {\n        // \"from\" and \"to\" quaternions are very close\n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n\n    return out;\n};\n\n/**\n * Calculates the inverse of a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate inverse of\n * @returns {quat} out\n */\nquat.invert = function(out, a) {\n    var a0 = a[0], a1 = a[1], a2 = a[2], a3 = a[3],\n        dot = a0*a0 + a1*a1 + a2*a2 + a3*a3,\n        invDot = dot ? 1.0/dot : 0;\n\n    // TODO: Would be faster to return [0,0,0,0] immediately if dot == 0\n\n    out[0] = -a0*invDot;\n    out[1] = -a1*invDot;\n    out[2] = -a2*invDot;\n    out[3] = a3*invDot;\n    return out;\n};\n\n/**\n * Calculates the conjugate of a quat\n * If the quaternion is normalized, this function is faster than quat.inverse and produces the same result.\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quat to calculate conjugate of\n * @returns {quat} out\n */\nquat.conjugate = function (out, a) {\n    out[0] = -a[0];\n    out[1] = -a[1];\n    out[2] = -a[2];\n    out[3] = a[3];\n    return out;\n};\n\n/**\n * Calculates the length of a quat\n *\n * @param {quat} a vector to calculate length of\n * @returns {Number} length of a\n * @function\n */\nquat.length = vec4.length;\n\n/**\n * Alias for {@link quat.length}\n * @function\n */\nquat.len = quat.length;\n\n/**\n * Calculates the squared length of a quat\n *\n * @param {quat} a vector to calculate squared length of\n * @returns {Number} squared length of a\n * @function\n */\nquat.squaredLength = vec4.squaredLength;\n\n/**\n * Alias for {@link quat.squaredLength}\n * @function\n */\nquat.sqrLen = quat.squaredLength;\n\n/**\n * Normalize a quat\n *\n * @param {quat} out the receiving quaternion\n * @param {quat} a quaternion to normalize\n * @returns {quat} out\n * @function\n */\nquat.normalize = vec4.normalize;\n\n/**\n * Creates a quaternion from the given 3x3 rotation matrix.\n *\n * NOTE: The resultant quaternion is not normalized, so you should be sure\n * to renormalize the quaternion yourself where necessary.\n *\n * @param {quat} out the receiving quaternion\n * @param {mat3} m rotation matrix\n * @returns {quat} out\n * @function\n */\nquat.fromMat3 = function(out, m) {\n    // Algorithm in Ken Shoemake's article in 1987 SIGGRAPH course notes\n    // article \"Quaternion Calculus and Fast Animation\".\n    var fTrace = m[0] + m[4] + m[8];\n    var fRoot;\n\n    if ( fTrace > 0.0 ) {\n        // |w| > 1/2, may as well choose w > 1/2\n        fRoot = Math.sqrt(fTrace + 1.0);  // 2w\n        out[3] = 0.5 * fRoot;\n        fRoot = 0.5/fRoot;  // 1/(4w)\n        out[0] = (m[5]-m[7])*fRoot;\n        out[1] = (m[6]-m[2])*fRoot;\n        out[2] = (m[1]-m[3])*fRoot;\n    } else {\n        // |w| <= 1/2\n        var i = 0;\n        if ( m[4] > m[0] )\n          i = 1;\n        if ( m[8] > m[i*3+i] )\n          i = 2;\n        var j = (i+1)%3;\n        var k = (i+2)%3;\n\n        fRoot = Math.sqrt(m[i*3+i]-m[j*3+j]-m[k*3+k] + 1.0);\n        out[i] = 0.5 * fRoot;\n        fRoot = 0.5 / fRoot;\n        out[3] = (m[j*3+k] - m[k*3+j]) * fRoot;\n        out[j] = (m[j*3+i] + m[i*3+j]) * fRoot;\n        out[k] = (m[k*3+i] + m[i*3+k]) * fRoot;\n    }\n\n    return out;\n};\n\n/**\n * Returns a string representation of a quatenion\n *\n * @param {quat} vec vector to represent as a string\n * @returns {String} string representation of the vector\n */\nquat.str = function (a) {\n    return 'quat(' + a[0] + ', ' + a[1] + ', ' + a[2] + ', ' + a[3] + ')';\n};\n\nif(typeof(exports) !== 'undefined') {\n    exports.quat = quat;\n}\n;\n\n\n\n\n\n\n\n\n\n\n\n\n\n  })(shim.exports);\n})(this);","import glMatrix from '../dep/glmatrix';\nvar vec2 = glMatrix.vec2;\n\n/**\n * @constructor\n * @alias clay.math.Vector2\n * @param {number} x\n * @param {number} y\n */\nvar Vector2 = function(x, y) {\n\n    x = x || 0;\n    y = y || 0;\n\n    /**\n     * Storage of Vector2, read and write of x, y will change the values in array\n     * All methods also operate on the array instead of x, y components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector2#\n     */\n    this.array = vec2.fromValues(x, y);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector2#\n     */\n    this._dirty = true;\n};\n\nVector2.prototype = {\n\n    constructor: Vector2,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    add: function(b) {\n        vec2.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x and y components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @return {clay.math.Vector2}\n     */\n    set: function(x, y) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x and y components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector2}\n     */\n    setArray: function(arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector2\n     * @return {clay.math.Vector2}\n     */\n    clone: function() {\n        return new Vector2(this.x, this.y);\n    },\n\n    /**\n     * Copy x, y from b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    copy: function(b) {\n        vec2.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Cross product of self and b, written to a Vector3 out\n     * @param  {clay.math.Vector3} out\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    cross: function(out, b) {\n        vec2.cross(out.array, this.array, b.array);\n        out._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    dist: function(b) {\n        return vec2.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    distance: function(b) {\n        return vec2.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    div: function(b) {\n        vec2.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    divide: function(b) {\n        vec2.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    dot: function(b) {\n        return vec2.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function() {\n        return vec2.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function() {\n        return vec2.length(this.array);\n    },\n\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector2} a\n     * @param  {clay.math.Vector2} b\n     * @param  {number}  t\n     * @return {clay.math.Vector2}\n     */\n    lerp: function(a, b, t) {\n        vec2.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    min: function(b) {\n        vec2.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    max: function(b) {\n        vec2.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    mul: function(b) {\n        vec2.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    multiply: function(b) {\n        vec2.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector2}\n     */\n    negate: function() {\n        vec2.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector2}\n     */\n    normalize: function() {\n        vec2.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector2}\n     */\n    random: function(scale) {\n        vec2.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector2}\n     */\n    scale: function(s) {\n        vec2.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector2} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector2}\n     */\n    scaleAndAdd: function(b, s) {\n        vec2.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    sqrDist: function(b) {\n        return vec2.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector2} b\n     * @return {number}\n     */\n    squaredDistance: function(b) {\n        return vec2.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function() {\n        return vec2.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function() {\n        return vec2.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    sub: function(b) {\n        vec2.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector2} b\n     * @return {clay.math.Vector2}\n     */\n    subtract: function(b) {\n        vec2.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix2 m\n     * @param  {clay.math.Matrix2} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat2: function(m) {\n        vec2.transformMat2(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix2d m\n     * @param  {clay.math.Matrix2d} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat2d: function(m) {\n        vec2.transformMat2d(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix3 m\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat3: function(m) {\n        vec2.transformMat3(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector2}\n     */\n    transformMat4: function(m) {\n        vec2.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n// Getter and Setter\nif (Object.defineProperty) {\n\n    var proto = Vector2.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector2\n     * @instance\n     */\n    Object.defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector2\n     * @instance\n     */\n    Object.defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.add = function(out, a, b) {\n    vec2.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {number}  x\n * @param  {number}  y\n * @return {clay.math.Vector2}\n */\nVector2.set = function(out, x, y) {\n    vec2.set(out.array, x, y);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.copy = function(out, b) {\n    vec2.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.cross = function(out, a, b) {\n    vec2.cross(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.dist = function(a, b) {\n    return vec2.distance(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.distance = Vector2.dist;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.div = function(out, a, b) {\n    vec2.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.divide = Vector2.div;\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.dot = function(a, b) {\n    return vec2.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.len = function(b) {\n    return vec2.length(b.array);\n};\n\n// Vector2.length = Vector2.len;\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @param  {number}  t\n * @return {clay.math.Vector2}\n */\nVector2.lerp = function(out, a, b, t) {\n    vec2.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.min = function(out, a, b) {\n    vec2.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.max = function(out, a, b) {\n    vec2.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.mul = function(out, a, b) {\n    vec2.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.multiply = Vector2.mul;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @return {clay.math.Vector2}\n */\nVector2.negate = function(out, a) {\n    vec2.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @return {clay.math.Vector2}\n */\nVector2.normalize = function(out, a) {\n    vec2.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.random = function(out, scale) {\n    vec2.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.scale = function(out, a, scale) {\n    vec2.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @param  {number}  scale\n * @return {clay.math.Vector2}\n */\nVector2.scaleAndAdd = function(out, a, b, scale) {\n    vec2.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.sqrDist = function(a, b) {\n    return vec2.sqrDist(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {number}\n */\nVector2.squaredDistance = Vector2.sqrDist;\n\n/**\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.sqrLen = function(a) {\n    return vec2.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector2} a\n * @return {number}\n */\nVector2.squaredLength = Vector2.sqrLen;\n\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.sub = function(out, a, b) {\n    vec2.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Vector2} b\n * @return {clay.math.Vector2}\n */\nVector2.subtract = Vector2.sub;\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Matrix2} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat2 = function(out, a, m) {\n    vec2.transformMat2(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2}  out\n * @param  {clay.math.Vector2}  a\n * @param  {clay.math.Matrix2d} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat2d = function(out, a, m) {\n    vec2.transformMat2d(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {Matrix3} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat3 = function(out, a, m) {\n    vec2.transformMat3(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector2} out\n * @param  {clay.math.Vector2} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector2}\n */\nVector2.transformMat4 = function(out, a, m) {\n    vec2.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Vector2;\n","// 2D Blend clip of blend tree\n// http://docs.unity3d.com/Documentation/Manual/2DBlending.html\nimport Clip from './Clip';\nimport delaunay from '../util/delaunay';\nimport Vector2 from '../math/Vector2';\n\n/**\n * @typedef {Object} clay.animation.Blend2DClip.IClipInput\n * @property {clay.math.Vector2} position\n * @property {clay.animation.Clip} clip\n * @property {number} offset\n */\n\n/**\n * 2d blending node in animation blend tree.\n * output clip must have blend2D method\n * @constructor\n * @alias clay.animation.Blend2DClip\n * @extends clay.animation.Clip\n *\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {object[]} [opts.inputs]\n * @param {clay.math.Vector2} [opts.position]\n * @param {clay.animation.Clip} [opts.output]\n */\nvar Blend2DClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n    /**\n     * Output clip must have blend2D method\n     * @type {clay.animation.Clip}\n     */\n    this.output = opts.output || null;\n    /**\n     * @type {clay.animation.Blend2DClip.IClipInput[]}\n     */\n    this.inputs = opts.inputs || [];\n    /**\n     * @type {clay.math.Vector2}\n     */\n    this.position = new Vector2();\n\n    this._cacheTriangle = null;\n\n    this._triangles = [];\n\n    this._updateTriangles();\n};\n\nBlend2DClip.prototype = new Clip();\nBlend2DClip.prototype.constructor = Blend2DClip;\n/**\n * @param {clay.math.Vector2} position\n * @param {clay.animation.Clip} inputClip\n * @param {number} [offset]\n * @return {clay.animation.Blend2DClip.IClipInput}\n */\nBlend2DClip.prototype.addInput = function (position, inputClip, offset) {\n    var obj = {\n        position : position,\n        clip : inputClip,\n        offset : offset || 0\n    };\n    this.inputs.push(obj);\n    this.life = Math.max(inputClip.life, this.life);\n    // TODO Change to incrementally adding\n    this._updateTriangles();\n\n    return obj;\n};\n\n// Delaunay triangulate\nBlend2DClip.prototype._updateTriangles = function () {\n    var inputs = this.inputs.map(function (a) {\n        return a.position;\n    });\n    this._triangles = delaunay.triangulate(inputs, 'array');\n};\n\nBlend2DClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n    return ret;\n};\n\nBlend2DClip.prototype.setTime = function (time) {\n    var res = this._findTriangle(this.position);\n    if (!res) {\n        return;\n    }\n    // In Barycentric\n    var a = res[1]; // Percent of clip2\n    var b = res[2]; // Percent of clip3\n\n    var tri = res[0];\n\n    var in1 = this.inputs[tri.indices[0]];\n    var in2 = this.inputs[tri.indices[1]];\n    var in3 = this.inputs[tri.indices[2]];\n    var clip1 = in1.clip;\n    var clip2 = in2.clip;\n    var clip3 = in3.clip;\n\n    clip1.setTime((time + in1.offset) % clip1.life);\n    clip2.setTime((time + in2.offset) % clip2.life);\n    clip3.setTime((time + in3.offset) % clip3.life);\n\n    var c1 = clip1.output instanceof Clip ? clip1.output : clip1;\n    var c2 = clip2.output instanceof Clip ? clip2.output : clip2;\n    var c3 = clip3.output instanceof Clip ? clip3.output : clip3;\n\n    this.output.blend2D(c1, c2, c3, a, b);\n};\n\n/**\n * Clone a new Blend2D clip\n * @param {boolean} cloneInputs True if clone the input clips\n * @return {clay.animation.Blend2DClip}\n */\nBlend2DClip.prototype.clone = function (cloneInputs) {\n    var clip = Clip.prototype.clone.call(this);\n    clip.output = this.output.clone();\n    for (var i = 0; i < this.inputs.length; i++) {\n        var inputClip = cloneInputs ? this.inputs[i].clip.clone(true) : this.inputs[i].clip;\n        clip.addInput(this.inputs[i].position, inputClip, this.inputs[i].offset);\n    }\n    return clip;\n};\n\nBlend2DClip.prototype._findTriangle = function (position) {\n    if (this._cacheTriangle) {\n        var res = delaunay.contains(this._cacheTriangle.vertices, position.array);\n        if (res) {\n            return [this._cacheTriangle, res[0], res[1]];\n        }\n    }\n    for (var i = 0; i < this._triangles.length; i++) {\n        var tri = this._triangles[i];\n        var res = delaunay.contains(tri.vertices, this.position.array);\n        if (res) {\n            this._cacheTriangle = tri;\n            return [tri, res[0], res[1]];\n        }\n    }\n};\n\nexport default Blend2DClip;","import Clip from './Clip';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\nfunction keyframeSort(a, b) {\n    return a.time - b.time;\n}\n\nvar TransformTrack = function (opts) {\n\n    this.name = opts.name || '';\n    //[{\n    //  time: //ms\n    //  position:  // optional\n    //  rotation:  // optional\n    //  scale:     // optional\n    //}]\n    this.keyFrames = [];\n    if (opts.keyFrames) {\n        this.addKeyFrames(opts.keyFrames);\n    }\n\n    this.position = vec3.create();\n\n    this.rotation = quat.create();\n\n    this.scale = vec3.fromValues(1, 1, 1);\n\n    this._cacheKey = 0;\n    this._cacheTime = 0;\n};\n\nTransformTrack.prototype = Object.create(Clip.prototype);\n\nTransformTrack.prototype.constructor = TransformTrack;\n\nTransformTrack.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time, dTime, true);\n\n    if (ret !== 'finish') {\n        this.setTime(this.getElapsedTime());\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n\n    return ret;\n};\n\nTransformTrack.prototype.setTime = function (time) {\n    this._interpolateField(time, 'position');\n    this._interpolateField(time, 'rotation');\n    this._interpolateField(time, 'scale');\n};\n\nTransformTrack.prototype.getMaxTime = function () {\n    var kf = this.keyFrames[this.keyFrames.length - 1];\n    return kf ? kf.time : 0;\n};\n\nTransformTrack.prototype.addKeyFrame = function (kf) {\n    for (var i = 0; i < this.keyFrames.length - 1; i++) {\n        var prevFrame = this.keyFrames[i];\n        var nextFrame = this.keyFrames[i + 1];\n        if (prevFrame.time <= kf.time && nextFrame.time >= kf.time) {\n            this.keyFrames.splice(i, 0, kf);\n            return i;\n        }\n    }\n\n    this.life = kf.time;\n    this.keyFrames.push(kf);\n};\n\nTransformTrack.prototype.addKeyFrames = function (kfs) {\n    for (var i = 0; i < kfs.length; i++) {\n        this.keyFrames.push(kfs[i]);\n    }\n\n    this.keyFrames.sort(keyframeSort);\n\n    this.life = this.keyFrames[this.keyFrames.length - 1].time;\n};\n\nTransformTrack.prototype._interpolateField = function (time, fieldName) {\n    var kfs = this.keyFrames;\n    var len = kfs.length;\n    var start;\n    var end;\n\n    if (!kfs.length) {\n        return;\n    }\n    if (time < kfs[0].time || time > kfs[kfs.length-1].time) {\n        return;\n    }\n    if (time < this._cacheTime) {\n        var s = this._cacheKey >= len-1 ? len-1 : this._cacheKey+1;\n        for (var i = s; i >= 0; i--) {\n            if (kfs[i].time <= time && kfs[i][fieldName]) {\n                start = kfs[i];\n                this._cacheKey = i;\n                this._cacheTime = time;\n            } else if (kfs[i][fieldName]) {\n                end = kfs[i];\n                break;\n            }\n        }\n    } else {\n        for (var i = this._cacheKey; i < len; i++) {\n            if (kfs[i].time <= time && kfs[i][fieldName]) {\n                start = kfs[i];\n                this._cacheKey = i;\n                this._cacheTime = time;\n            } else if (kfs[i][fieldName]) {\n                end = kfs[i];\n                break;\n            }\n        }\n    }\n\n    if (start && end) {\n        var percent = (time - start.time) / (end.time - start.time);\n        percent = Math.max(Math.min(percent, 1), 0);\n        if (fieldName === 'rotation') {\n            quat.slerp(this[fieldName], start[fieldName], end[fieldName], percent);\n        } else {\n            vec3.lerp(this[fieldName], start[fieldName], end[fieldName], percent);\n        }\n    } else {\n        this._cacheKey = 0;\n        this._cacheTime = 0;\n    }\n};\n\nTransformTrack.prototype.blend1D = function (t1, t2, w) {\n    vec3.lerp(this.position, t1.position, t2.position, w);\n    vec3.lerp(this.scale, t1.scale, t2.scale, w);\n    quat.slerp(this.rotation, t1.rotation, t2.rotation, w);\n};\n\nTransformTrack.prototype.blend2D = (function () {\n    var q1 = quat.create();\n    var q2 = quat.create();\n    return function (t1, t2, t3, f, g) {\n        var a = 1 - f - g;\n\n        this.position[0] = t1.position[0] * a + t2.position[0] * f + t3.position[0] * g;\n        this.position[1] = t1.position[1] * a + t2.position[1] * f + t3.position[1] * g;\n        this.position[2] = t1.position[2] * a + t2.position[2] * f + t3.position[2] * g;\n\n        this.scale[0] = t1.scale[0] * a + t2.scale[0] * f + t3.scale[0] * g;\n        this.scale[1] = t1.scale[1] * a + t2.scale[1] * f + t3.scale[1] * g;\n        this.scale[2] = t1.scale[2] * a + t2.scale[2] * f + t3.scale[2] * g;\n\n        // http://msdn.microsoft.com/en-us/library/windows/desktop/bb205403(v=vs.85).aspx\n        // http://msdn.microsoft.com/en-us/library/windows/desktop/microsoft.directx_sdk.quaternion.xmquaternionbarycentric(v=vs.85).aspx\n        var s = f + g;\n        if (s === 0) {\n            quat.copy(this.rotation, t1.rotation);\n        } else {\n            quat.slerp(q1, t1.rotation, t2.rotation, s);\n            quat.slerp(q2, t1.rotation, c3.rotation, s);\n            quat.slerp(this.rotation, q1, q2, g / s);\n        }\n    };\n})();\n\nTransformTrack.prototype.additiveBlend = function (t1, t2) {\n    vec3.add(this.position, t1.position, t2.position);\n    vec3.add(this.scale, t1.scale, t2.scale);\n    quat.multiply(this.rotation, t2.rotation, t1.rotation);\n};\n\nTransformTrack.prototype.subtractiveBlend = function (t1, t2) {\n    vec3.sub(this.position, t1.position, t2.position);\n    vec3.sub(this.scale, t1.scale, t2.scale);\n    quat.invert(this.rotation, t2.rotation);\n    quat.multiply(this.rotation, this.rotation, t1.rotation);\n};\n\nTransformTrack.prototype.getSubClip = function (startTime, endTime) {\n    // TODO\n    console.warn('TODO');\n};\n\nTransformTrack.prototype.clone = function () {\n    var track = TransformTrack.prototype.clone.call(this);\n    track.keyFrames = this.keyFrames;\n\n    vec3.copy(track.position, this.position);\n    quat.copy(track.rotation, this.rotation);\n    vec3.copy(track.scale, this.scale);\n\n    return track;\n};\n\n\nexport default TransformTrack;\n","// Sampler clip is especially for the animation sampler in glTF\n// Use Typed Array can reduce a lot of heap memory\n//\n// TODO Sync target transform\n\nimport TransformTrack from './TransformTrack';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\n// lerp function with offset in large array\nfunction vec3lerp(out, a, b, t, oa, ob) {\n    var ax = a[oa];\n    var ay = a[oa + 1];\n    var az = a[oa + 2];\n    out[0] = ax + t * (b[ob] - ax);\n    out[1] = ay + t * (b[ob + 1] - ay);\n    out[2] = az + t * (b[ob + 2] - az);\n\n    return out;\n}\n\nfunction quatSlerp(out, a, b, t, oa, ob) {\n    // benchmarks:\n    //    http://jsperf.com/quaternion-slerp-implementations\n\n    var ax = a[0 + oa], ay = a[1 + oa], az = a[2 + oa], aw = a[3 + oa],\n        bx = b[0 + ob], by = b[1 + ob], bz = b[2 + ob], bw = b[3 + ob];\n\n    var omega, cosom, sinom, scale0, scale1;\n\n    // calc cosine\n    cosom = ax * bx + ay * by + az * bz + aw * bw;\n    // adjust signs (if necessary)\n    if (cosom < 0.0) {\n        cosom = -cosom;\n        bx = - bx;\n        by = - by;\n        bz = - bz;\n        bw = - bw;\n    }\n    // calculate coefficients\n    if ((1.0 - cosom) > 0.000001) {\n        // standard case (slerp)\n        omega  = Math.acos(cosom);\n        sinom  = Math.sin(omega);\n        scale0 = Math.sin((1.0 - t) * omega) / sinom;\n        scale1 = Math.sin(t * omega) / sinom;\n    }\n    else {\n        // 'from' and 'to' quaternions are very close\n        //  ... so we can do a linear interpolation\n        scale0 = 1.0 - t;\n        scale1 = t;\n    }\n    // calculate final values\n    out[0] = scale0 * ax + scale1 * bx;\n    out[1] = scale0 * ay + scale1 * by;\n    out[2] = scale0 * az + scale1 * bz;\n    out[3] = scale0 * aw + scale1 * bw;\n\n    return out;\n}\n\n/**\n * SamplerTrack manages `position`, `rotation`, `scale` tracks in animation of single scene node.\n * @constructor\n * @alias clay.animation.SamplerTrack\n * @param {Object} [opts]\n * @param {string} [opts.name] Track name\n * @param {clay.Node} [opts.target] Target node's transform will updated automatically\n */\nvar SamplerTrack = function (opts) {\n    opts = opts || {};\n\n    this.name = opts.name || '';\n    /**\n     * @param {clay.Node}\n     */\n    this.target = opts.target || null;\n    /**\n     * @type {Float32Array}\n     */\n    this.position = vec3.create();\n    /**\n     * Rotation is represented by a quaternion\n     * @type {Float32Array}\n     */\n    this.rotation = quat.create();\n    /**\n     * @type {Float32Array}\n     */\n    this.scale = vec3.fromValues(1, 1, 1);\n\n    this.channels = {\n        time: null,\n        position: null,\n        rotation: null,\n        scale: null\n    };\n\n    this._cacheKey = 0;\n    this._cacheTime = 0;\n};\n\nSamplerTrack.prototype.setTime = function (time) {\n    if (!this.channels.time) {\n        return;\n    }\n    var channels = this.channels;\n    var len = channels.time.length;\n    var key = -1;\n    // Only one frame\n    if (len === 1) {\n        if (channels.rotation) {\n            quat.copy(this.rotation, channels.rotation);\n        }\n        if (channels.position) {\n            vec3.copy(this.position, channels.position);\n        }\n        if (channels.scale) {\n            vec3.copy(this.scale, channels.scale);\n        }\n        return;\n    }\n    // Clamp\n    else if (time <= channels.time[0]) {\n        time = channels.time[0];\n        key = 0;\n    }\n    else if (time >= channels.time[len - 1]) {\n        time = channels.time[len - 1];\n        key = len - 2;\n    }\n    else {\n        if (time < this._cacheTime) {\n            var s = Math.min(len - 1, this._cacheKey + 1);\n            for (var i = s; i >= 0; i--) {\n                if (channels.time[i - 1] <= time && channels.time[i] > time) {\n                    key = i - 1;\n                    break;\n                }\n            }\n        }\n        else {\n            for (var i = this._cacheKey; i < len - 1; i++) {\n                if (channels.time[i] <= time && channels.time[i + 1] > time) {\n                    key = i;\n                    break;\n                }\n            }\n        }\n    }\n    if (key > -1) {\n        this._cacheKey = key;\n        this._cacheTime = time;\n        var start = key;\n        var end = key + 1;\n        var startTime = channels.time[start];\n        var endTime = channels.time[end];\n        var range = endTime - startTime;\n        var percent = range === 0 ? 0 : (time - startTime) / range;\n\n        if (channels.rotation) {\n            quatSlerp(this.rotation, channels.rotation, channels.rotation, percent, start * 4, end * 4);\n        }\n        if (channels.position) {\n            vec3lerp(this.position, channels.position, channels.position, percent, start * 3, end * 3);\n        }\n        if (channels.scale) {\n            vec3lerp(this.scale, channels.scale, channels.scale, percent, start * 3, end * 3);\n        }\n    }\n    // Loop handling\n    if (key == len - 2) {\n        this._cacheKey = 0;\n        this._cacheTime = 0;\n    }\n\n    this.updateTarget();\n};\n\n/**\n * Update transform of target node manually\n */\nSamplerTrack.prototype.updateTarget = function () {\n    var channels = this.channels;\n    if (this.target) {\n        // Only update target prop if have data.\n        if (channels.position) {\n            this.target.position.setArray(this.position);\n        }\n        if (channels.rotation) {\n            this.target.rotation.setArray(this.rotation);\n        }\n        if (channels.scale) {\n            this.target.scale.setArray(this.scale);\n        }\n    }\n};\n\n/**\n * @return {number}\n */\nSamplerTrack.prototype.getMaxTime = function () {\n    return this.channels.time[this.channels.time.length - 1];\n};\n\n/**\n * @param {number} startTime\n * @param {number} endTime\n * @return {clay.animation.SamplerTrack}\n */\nSamplerTrack.prototype.getSubTrack = function (startTime, endTime) {\n\n    var subClip = new SamplerTrack({\n        name: this.name\n    });\n    var minTime = this.channels.time[0];\n    startTime = Math.min(Math.max(startTime, minTime), this.life);\n    endTime = Math.min(Math.max(endTime, minTime), this.life);\n\n    var rangeStart = this._findRange(startTime);\n    var rangeEnd = this._findRange(endTime);\n\n    var count = rangeEnd[0] - rangeStart[0] + 1;\n    if (rangeStart[1] === 0 && rangeEnd[1] === 0) {\n        count -= 1;\n    }\n    if (this.channels.rotation) {\n        subClip.channels.rotation = new Float32Array(count * 4);\n    }\n    if (this.channels.position) {\n        subClip.channels.position = new Float32Array(count * 3);\n    }\n    if (this.channels.scale) {\n        subClip.channels.scale = new Float32Array(count * 3);\n    }\n    if (this.channels.time) {\n        subClip.channels.time = new Float32Array(count);\n    }\n    // Clip at the start\n    this.setTime(startTime);\n    for (var i = 0; i < 3; i++) {\n        subClip.channels.rotation[i] = this.rotation[i];\n        subClip.channels.position[i] = this.position[i];\n        subClip.channels.scale[i] = this.scale[i];\n    }\n    subClip.channels.time[0] = 0;\n    subClip.channels.rotation[3] = this.rotation[3];\n\n    for (var i = 1; i < count-1; i++) {\n        var i2;\n        for (var j = 0; j < 3; j++) {\n            i2 = rangeStart[0] + i;\n            subClip.channels.rotation[i * 4 + j] = this.channels.rotation[i2 * 4 + j];\n            subClip.channels.position[i * 3 + j] = this.channels.position[i2 * 3 + j];\n            subClip.channels.scale[i * 3 + j] = this.channels.scale[i2 * 3 + j];\n        }\n        subClip.channels.time[i] = this.channels.time[i2] - startTime;\n        subClip.channels.rotation[i * 4 + 3] = this.channels.rotation[i2 * 4 + 3];\n    }\n    // Clip at the end\n    this.setTime(endTime);\n    for (var i = 0; i < 3; i++) {\n        subClip.channels.rotation[(count - 1) * 4 + i] = this.rotation[i];\n        subClip.channels.position[(count - 1) * 3 + i] = this.position[i];\n        subClip.channels.scale[(count - 1) * 3 + i] = this.scale[i];\n    }\n    subClip.channels.time[(count - 1)] = endTime - startTime;\n    subClip.channels.rotation[(count - 1) * 4 + 3] = this.rotation[3];\n\n    // TODO set back ?\n    subClip.life = endTime - startTime;\n    return subClip;\n};\n\nSamplerTrack.prototype._findRange = function (time) {\n    var channels = this.channels;\n    var len = channels.time.length;\n    var start = -1;\n    for (var i = 0; i < len - 1; i++) {\n        if (channels.time[i] <= time && channels.time[i+1] > time) {\n            start = i;\n        }\n    }\n    var percent = 0;\n    if (start >= 0) {\n        var startTime = channels.time[start];\n        var endTime = channels.time[start+1];\n        var percent = (time-startTime) / (endTime-startTime);\n    }\n    // Percent [0, 1)\n    return [start, percent];\n};\n\n/**\n * 1D blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n * @param  {number} w\n */\nSamplerTrack.prototype.blend1D = TransformTrack.prototype.blend1D;\n/**\n * 2D blending between three clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c3\n * @param  {number} f\n * @param  {number} g\n */\nSamplerTrack.prototype.blend2D = TransformTrack.prototype.blend2D;\n/**\n * Additive blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n */\nSamplerTrack.prototype.additiveBlend = TransformTrack.prototype.additiveBlend;\n/**\n * Subtractive blending between two clips\n * @function\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c1\n * @param  {clay.animation.SamplerTrack|clay.animation.TransformTrack} c2\n */\nSamplerTrack.prototype.subtractiveBlend = TransformTrack.prototype.subtractiveBlend;\n\n/**\n * Clone a new SamplerTrack\n * @return {clay.animation.SamplerTrack}\n */\nSamplerTrack.prototype.clone = function () {\n    var track = SamplerTrack.prototype.clone.call(this);\n    track.channels = {\n        time: this.channels.time || null,\n        position: this.channels.position || null,\n        rotation: this.channels.rotation || null,\n        scale: this.channels.scale || null\n    };\n    vec3.copy(track.position, this.position);\n    quat.copy(track.rotation, this.rotation);\n    vec3.copy(track.scale, this.scale);\n\n    track.target = this.target;\n    track.updateTarget();\n\n    return track;\n\n};\n\nexport default SamplerTrack;\n","/**\n * Extend a sub class from base class\n * @param {object|Function} makeDefaultOpt default option of this sub class, method of the sub can use this.xxx to access this option\n * @param {Function} [initialize] Initialize after the sub class is instantiated\n * @param {Object} [proto] Prototype methods/properties of the sub class\n * @memberOf clay.core.mixin.extend\n * @return {Function}\n */\nfunction derive(makeDefaultOpt, initialize/*optional*/, proto/*optional*/) {\n\n    if (typeof initialize == 'object') {\n        proto = initialize;\n        initialize = null;\n    }\n\n    var _super = this;\n\n    var propList;\n    if (!(makeDefaultOpt instanceof Function)) {\n        // Optimize the property iterate if it have been fixed\n        propList = [];\n        for (var propName in makeDefaultOpt) {\n            if (makeDefaultOpt.hasOwnProperty(propName)) {\n                propList.push(propName);\n            }\n        }\n    }\n\n    var sub = function(options) {\n\n        // call super constructor\n        _super.apply(this, arguments);\n\n        if (makeDefaultOpt instanceof Function) {\n            // Invoke makeDefaultOpt each time if it is a function, So we can make sure each\n            // property in the object will not be shared by mutiple instances\n            extend(this, makeDefaultOpt.call(this, options));\n        }\n        else {\n            extendWithPropList(this, makeDefaultOpt, propList);\n        }\n\n        if (this.constructor === sub) {\n            // Initialize function will be called in the order of inherit\n            var initializers = sub.__initializers__;\n            for (var i = 0; i < initializers.length; i++) {\n                initializers[i].apply(this, arguments);\n            }\n        }\n    };\n    // save super constructor\n    sub.__super__ = _super;\n    // Initialize function will be called after all the super constructor is called\n    if (!_super.__initializers__) {\n        sub.__initializers__ = [];\n    } else {\n        sub.__initializers__ = _super.__initializers__.slice();\n    }\n    if (initialize) {\n        sub.__initializers__.push(initialize);\n    }\n\n    var Ctor = function() {};\n    Ctor.prototype = _super.prototype;\n    sub.prototype = new Ctor();\n    sub.prototype.constructor = sub;\n    extend(sub.prototype, proto);\n\n    // extend the derive method as a static method;\n    sub.extend = _super.extend;\n\n    // DEPCRATED\n    sub.derive = _super.extend;\n\n    return sub;\n}\n\nfunction extend(target, source) {\n    if (!source) {\n        return;\n    }\n    for (var name in source) {\n        if (source.hasOwnProperty(name)) {\n            target[name] = source[name];\n        }\n    }\n}\n\nfunction extendWithPropList(target, source, propList) {\n    for (var i = 0; i < propList.length; i++) {\n        var propName = propList[i];\n        target[propName] = source[propName];\n    }\n}\n\n/**\n * @alias clay.core.mixin.extend\n * @mixin\n */\nexport default {\n\n    extend: derive,\n\n    // DEPCRATED\n    derive: derive\n};\n","function Handler(action, context) {\n    this.action = action;\n    this.context = context;\n}\n/**\n * @mixin\n * @alias clay.core.mixin.notifier\n */\nvar notifier = {\n    /**\n     * Trigger event\n     * @param  {string} name\n     */\n    trigger: function(name) {\n        if (!this.hasOwnProperty('__handlers__')) {\n            return;\n        }\n        if (!this.__handlers__.hasOwnProperty(name)) {\n            return;\n        }\n\n        var hdls = this.__handlers__[name];\n        var l = hdls.length, i = -1, args = arguments;\n        // Optimize advise from backbone\n        switch (args.length) {\n            case 1:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context);\n                }\n                return;\n            case 2:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1]);\n                }\n                return;\n            case 3:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2]);\n                }\n                return;\n            case 4:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2], args[3]);\n                }\n                return;\n            case 5:\n                while (++i < l) {\n                    hdls[i].action.call(hdls[i].context, args[1], args[2], args[3], args[4]);\n                }\n                return;\n            default:\n                while (++i < l) {\n                    hdls[i].action.apply(hdls[i].context, Array.prototype.slice.call(args, 1));\n                }\n                return;\n        }\n    },\n    /**\n     * Register event handler\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    on: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        var handlers = this.__handlers__ || (this.__handlers__={});\n        if (!handlers[name]) {\n            handlers[name] = [];\n        }\n        else {\n            if (this.has(name, action)) {\n                return;\n            }\n        }\n        var handler = new Handler(action, context || this);\n        handlers[name].push(handler);\n\n        return this;\n    },\n\n    /**\n     * Register event, event will only be triggered once and then removed\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    once: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        var self = this;\n        function wrapper() {\n            self.off(name, wrapper);\n            action.apply(this, arguments);\n        }\n        return this.on(name, wrapper, context);\n    },\n\n    /**\n     * Alias of once('before' + name)\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    before: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        name = 'before' + name;\n        return this.on(name, action, context);\n    },\n\n    /**\n     * Alias of once('after' + name)\n     * @param  {string} name\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    after: function(name, action, context) {\n        if (!name || !action) {\n            return;\n        }\n        name = 'after' + name;\n        return this.on(name, action, context);\n    },\n\n    /**\n     * Alias of on('success')\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    success: function(action, context) {\n        return this.once('success', action, context);\n    },\n\n    /**\n     * Alias of on('error')\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    error: function(action, context) {\n        return this.once('error', action, context);\n    },\n\n    /**\n     * Remove event listener\n     * @param  {Function} action\n     * @param  {Object} [context]\n     * @chainable\n     */\n    off: function(name, action) {\n\n        var handlers = this.__handlers__ || (this.__handlers__={});\n\n        if (!action) {\n            handlers[name] = [];\n            return;\n        }\n        if (handlers[name]) {\n            var hdls = handlers[name];\n            var retains = [];\n            for (var i = 0; i < hdls.length; i++) {\n                if (action && hdls[i].action !== action) {\n                    retains.push(hdls[i]);\n                }\n            }\n            handlers[name] = retains;\n        }\n\n        return this;\n    },\n\n    /**\n     * If registered the event handler\n     * @param  {string}  name\n     * @param  {Function}  action\n     * @return {boolean}\n     */\n    has: function(name, action) {\n        var handlers = this.__handlers__;\n\n        if (! handlers ||\n            ! handlers[name]) {\n            return false;\n        }\n        var hdls = handlers[name];\n        for (var i = 0; i < hdls.length; i++) {\n            if (hdls[i].action === action) {\n                return true;\n            }\n        }\n    }\n};\n\nexport default notifier;","var guid = 0;\n\nvar ArrayProto = Array.prototype;\nvar nativeForEach = ArrayProto.forEach;\n\n/**\n * Util functions\n * @namespace clay.core.util\n */\nvar util = {\n\n    /**\n     * Generate GUID\n     * @return {number}\n     * @memberOf clay.core.util\n     */\n    genGUID: function () {\n        return ++guid;\n    },\n    /**\n     * Relative path to absolute path\n     * @param  {string} path\n     * @param  {string} basePath\n     * @return {string}\n     * @memberOf clay.core.util\n     */\n    relative2absolute: function (path, basePath) {\n        if (!basePath || path.match(/^\\//)) {\n            return path;\n        }\n        var pathParts = path.split('/');\n        var basePathParts = basePath.split('/');\n\n        var item = pathParts[0];\n        while(item === '.' || item === '..') {\n            if (item === '..') {\n                basePathParts.pop();\n            }\n            pathParts.shift();\n            item = pathParts[0];\n        }\n        return basePathParts.join('/') + '/' + pathParts.join('/');\n    },\n\n    /**\n     * Extend target with source\n     * @param  {Object} target\n     * @param  {Object} source\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    extend: function (target, source) {\n        if (source) {\n            for (var name in source) {\n                if (source.hasOwnProperty(name)) {\n                    target[name] = source[name];\n                }\n            }\n        }\n        return target;\n    },\n\n    /**\n     * Extend properties to target if not exist.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    defaults: function (target, source) {\n        if (source) {\n            for (var propName in source) {\n                if (target[propName] === undefined) {\n                    target[propName] = source[propName];\n                }\n            }\n        }\n        return target;\n    },\n    /**\n     * Extend properties with a given property list to avoid for..in.. iteration.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @param  {Array.<string>} propList\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    extendWithPropList: function (target, source, propList) {\n        if (source) {\n            for (var i = 0; i < propList.length; i++) {\n                var propName = propList[i];\n                target[propName] = source[propName];\n            }\n        }\n        return target;\n    },\n    /**\n     * Extend properties to target if not exist. With a given property list avoid for..in.. iteration.\n     * @param  {Object} target\n     * @param  {Object} source\n     * @param  {Array.<string>} propList\n     * @return {Object}\n     * @memberOf clay.core.util\n     */\n    defaultsWithPropList: function (target, source, propList) {\n        if (source) {\n            for (var i = 0; i < propList.length; i++) {\n                var propName = propList[i];\n                if (target[propName] == null) {\n                    target[propName] = source[propName];\n                }\n            }\n        }\n        return target;\n    },\n    /**\n     * @param  {Object|Array} obj\n     * @param  {Function} iterator\n     * @param  {Object} [context]\n     * @memberOf clay.core.util\n     */\n    each: function (obj, iterator, context) {\n        if (!(obj && iterator)) {\n            return;\n        }\n        if (obj.forEach && obj.forEach === nativeForEach) {\n            obj.forEach(iterator, context);\n        }\n        else if (obj.length === + obj.length) {\n            for (var i = 0, len = obj.length; i < len; i++) {\n                iterator.call(context, obj[i], i, obj);\n            }\n        }\n        else {\n            for (var key in obj) {\n                if (obj.hasOwnProperty(key)) {\n                    iterator.call(context, obj[key], key, obj);\n                }\n            }\n        }\n    },\n\n    /**\n     * Is object\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isObject: function (obj) {\n        return obj === Object(obj);\n    },\n\n    /**\n     * Is array ?\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isArray: function (obj) {\n        return Array.isArray(obj);\n    },\n\n    /**\n     * Is array like, which have a length property\n     * @param  {}  obj\n     * @return {boolean}\n     * @memberOf clay.core.util\n     */\n    isArrayLike: function (obj) {\n        if (!obj) {\n            return false;\n        }\n        else {\n            return obj.length === + obj.length;\n        }\n    },\n\n    /**\n     * @param  {} obj\n     * @return {}\n     * @memberOf clay.core.util\n     */\n    clone: function (obj) {\n        if (!util.isObject(obj)) {\n            return obj;\n        }\n        else if (util.isArray(obj)) {\n            return obj.slice();\n        }\n        else if (util.isArrayLike(obj)) { // is typed array\n            var ret = new obj.constructor(obj.length);\n            for (var i = 0; i < obj.length; i++) {\n                ret[i] = obj[i];\n            }\n            return ret;\n        }\n        else {\n            return util.extend({}, obj);\n        }\n    }\n};\n\nexport default util;\n","import extendMixin from './mixin/extend';\nimport notifierMixin from './mixin/notifier';\nimport util from './util';\n\n/**\n * Base class of all objects\n * @constructor\n * @alias clay.core.Base\n * @mixes clay.core.mixin.notifier\n */\nvar Base = function () {\n    /**\n     * @type {number}\n     */\n    this.__uid__ = util.genGUID();\n};\n\nBase.__initializers__ = [\n    function (opts) {\n        util.extend(this, opts);\n    }\n];\n\nutil.extend(Base, extendMixin);\nutil.extend(Base.prototype, notifierMixin);\n\nexport default Base;\n","import Base from '../core/Base';\nimport Animator from './Animator';\n\nvar requestAnimationFrame = window.requestAnimationFrame\n                            || window.msRequestAnimationFrame\n                            || window.mozRequestAnimationFrame\n                            || window.webkitRequestAnimationFrame\n                            || function (func){ setTimeout(func, 16); };\n\n/**\n * Animation is global timeline that schedule all clips. each frame animation will set the time of clips to current and update the states of clips\n * @constructor clay.animation.Animation\n * @extends clay.core.Base\n *\n * @example\n * var animation = new clay.animation.Animation();\n * var node = new clay.Node();\n * animation.animate(node.position)\n *     .when(1000, {\n *         x: 500,\n *         y: 500\n *     })\n *     .when(2000, {\n *         x: 100,\n *         y: 100\n *     })\n *     .when(3000, {\n *         z: 10\n *     })\n *     .start('spline');\n */\nvar Timeline = Base.extend(function () {\n    return /** @lends clay.animation.Timeline# */{\n        /**\n         * stage is an object with render method, each frame if there exists any animating clips, stage.render will be called\n         * @type {Object}\n         */\n        stage: null,\n\n        _clips: [],\n\n        _running: false,\n\n        _time: 0,\n\n        _paused: false,\n\n        _pausedTime: 0\n    };\n},\n/** @lends clay.animation.Timeline.prototype */\n{\n\n    /**\n     * Add animator\n     * @param {clay.animate.Animator} animator\n     */\n    addAnimator: function (animator) {\n        animator.animation = this;\n        var clips = animator.getClips();\n        for (var i = 0; i < clips.length; i++) {\n            this.addClip(clips[i]);\n        }\n    },\n\n    /**\n     * @param {clay.animation.Clip} clip\n     */\n    addClip: function (clip) {\n        if (this._clips.indexOf(clip) < 0) {\n            this._clips.push(clip);\n        }\n    },\n\n    /**\n     * @param  {clay.animation.Clip} clip\n     */\n    removeClip: function (clip) {\n        var idx = this._clips.indexOf(clip);\n        if (idx >= 0) {\n            this._clips.splice(idx, 1);\n        }\n    },\n\n    /**\n     * Remove animator\n     * @param {clay.animate.Animator} animator\n     */\n    removeAnimator: function (animator) {\n        var clips = animator.getClips();\n        for (var i = 0; i < clips.length; i++) {\n            this.removeClip(clips[i]);\n        }\n        animator.animation = null;\n    },\n\n    _update: function () {\n\n        var time = Date.now() - this._pausedTime;\n        var delta = time - this._time;\n        var clips = this._clips;\n        var len = clips.length;\n\n        var deferredEvents = [];\n        var deferredClips = [];\n        for (var i = 0; i < len; i++) {\n            var clip = clips[i];\n            var e = clip.step(time, delta, false);\n            // Throw out the events need to be called after\n            // stage.render, like finish\n            if (e) {\n                deferredEvents.push(e);\n                deferredClips.push(clip);\n            }\n        }\n\n        // Remove the finished clip\n        for (var i = 0; i < len;) {\n            if (clips[i]._needsRemove) {\n                clips[i] = clips[len-1];\n                clips.pop();\n                len--;\n            } else {\n                i++;\n            }\n        }\n\n        len = deferredEvents.length;\n        for (var i = 0; i < len; i++) {\n            deferredClips[i].fire(deferredEvents[i]);\n        }\n\n        this._time = time;\n\n        this.trigger('frame', delta);\n\n        if (this.stage && this.stage.render) {\n            this.stage.render();\n        }\n    },\n    /**\n     * Start running animation\n     */\n    start: function () {\n        var self = this;\n\n        this._running = true;\n        this._time = Date.now();\n\n        this._pausedTime = 0;\n\n        function step() {\n            if (self._running) {\n\n                requestAnimationFrame(step);\n\n                if (!self._paused) {\n                    self._update();\n                }\n            }\n        }\n\n        requestAnimationFrame(step);\n\n    },\n    /**\n     * Stop running animation\n     */\n    stop: function () {\n        this._running = false;\n    },\n\n    /**\n     * Pause\n     */\n    pause: function () {\n        if (!this._paused) {\n            this._pauseStart = Date.now();\n            this._paused = true;\n        }\n    },\n\n    /**\n     * Resume\n     */\n    resume: function () {\n        if (this._paused) {\n            this._pausedTime += Date.now() - this._pauseStart;\n            this._paused = false;\n        }\n    },\n\n    /**\n     * Remove all clips\n     */\n    removeClipsAll: function () {\n        this._clips = [];\n    },\n    /**\n     * Create a animator\n     * @param  {Object} target\n     * @param  {Object} [options]\n     * @param  {boolean} [options.loop]\n     * @param  {Function} [options.getter]\n     * @param  {Function} [options.setter]\n     * @param  {Function} [options.interpolater]\n     * @return {clay.animation.Animator}\n     */\n    animate: function (target, options) {\n        options = options || {};\n        var animator = new Animator(\n            target,\n            options.loop,\n            options.getter,\n            options.setter,\n            options.interpolater\n        );\n        animator.animation = this;\n        return animator;\n    }\n});\n\nexport default Timeline;\n","import Clip from './Clip';\n\nimport glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\n\n/**\n *\n * Animation clip that manage a collection of {@link clay.animation.SamplerTrack}\n * @constructor\n * @alias clay.animation.TrackClip\n *\n * @extends clay.animation.Clip\n * @param {Object} [opts]\n * @param {string} [opts.name]\n * @param {Object} [opts.target]\n * @param {number} [opts.life]\n * @param {number} [opts.delay]\n * @param {number} [opts.gap]\n * @param {number} [opts.playbackRatio]\n * @param {boolean|number} [opts.loop] If loop is a number, it indicate the loop count of animation\n * @param {string|Function} [opts.easing]\n * @param {Function} [opts.onframe]\n * @param {Function} [opts.onfinish]\n * @param {Function} [opts.onrestart]\n * @param {Array.<clay.animation.SamplerTrack>} [opts.tracks]\n */\nvar TrackClip = function (opts) {\n\n    opts = opts || {};\n\n    Clip.call(this, opts);\n\n    /**\n     *\n     * @type {clay.animation.SamplerTrack[]}\n     */\n    this.tracks = opts.tracks || [];\n};\n\nTrackClip.prototype = Object.create(Clip.prototype);\n\nTrackClip.prototype.constructor = TrackClip;\n\nTrackClip.prototype.step = function (time, dTime, silent) {\n\n    var ret = Clip.prototype.step.call(this, time, dTime, true);\n\n    if (ret !== 'finish') {\n        var time = this.getElapsedTime();\n        // TODO life may be changed.\n        if (this._range) {\n            time = this._range[0] + time;\n        }\n        this.setTime(time);\n    }\n\n    // PENDING Schedule\n    if (!silent && ret !== 'paused') {\n        this.fire('frame');\n    }\n\n    return ret;\n};\n\n/**\n * @param {Array.<number>} range\n */\nTrackClip.prototype.setRange = function (range) {\n    this.calcLifeFromTracks();\n    this._range = range;\n    if (range) {\n        range[1] = Math.min(range[1], this.life);\n        range[0] = Math.min(range[0], this.life);\n        this.life = (range[1] - range[0]);\n    }\n};\n\nTrackClip.prototype.setTime = function (time) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        this.tracks[i].setTime(time);\n    }\n};\n\nTrackClip.prototype.calcLifeFromTracks = function () {\n    this.life = 0;\n    for (var i = 0; i < this.tracks.length; i++) {\n        this.life = Math.max(this.life, this.tracks[i].getMaxTime());\n    }\n};\n\n/**\n * @param {clay.animation.SamplerTrack} jointClip\n */\nTrackClip.prototype.addTrack = function (track) {\n    this.tracks.push(track);\n};\n\n/**\n * @param {clay.animation.SamplerTrack} jointClip\n */\nTrackClip.prototype.removeTarck = function (track) {\n    var idx = this.tracks.indexOf(track);\n    if (idx >= 0) {\n        this.tracks.splice(idx, 1);\n    }\n};\n\n/**\n * @param {number} startTime\n * @param {number} endTime\n * @param {boolean} isLoop\n * @return {clay.animation.TrackClip}\n */\nTrackClip.prototype.getSubClip = function (startTime, endTime, isLoop) {\n    var subClip = new TrackClip({\n        name: this.name\n    });\n\n    for (var i = 0; i < this.tracks.length; i++) {\n        var subTrack = this.tracks[i].getSubTrack(startTime, endTime);\n        subClip.addTrack(subTrack);\n    }\n\n    if (isLoop !== undefined) {\n        subClip.setLoop(isLoop);\n    }\n\n    subClip.life = endTime - startTime;\n\n    return subClip;\n};\n\n/**\n * 1d blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n * @param  {number} w\n */\nTrackClip.prototype.blend1D = function (clip1, clip2, w) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.blend1D(c1, c2, w);\n    }\n};\n\n/**\n * Additive blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n */\nTrackClip.prototype.additiveBlend = function (clip1, clip2) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.additiveBlend(c1, c2);\n    }\n};\n\n/**\n * Subtractive blending from two skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n */\nTrackClip.prototype.subtractiveBlend = function (clip1, clip2) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.subtractiveBlend(c1, c2);\n    }\n};\n\n/**\n * 2D blending from three skinning clips\n * @param  {clay.animation.TrackClip} clip1\n * @param  {clay.animation.TrackClip} clip2\n * @param  {clay.animation.TrackClip} clip3\n * @param  {number} f\n * @param  {number} g\n */\nTrackClip.prototype.blend2D = function (clip1, clip2, clip3, f, g) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var c1 = clip1.tracks[i];\n        var c2 = clip2.tracks[i];\n        var c3 = clip3.tracks[i];\n        var tClip = this.tracks[i];\n\n        tClip.blend2D(c1, c2, c3, f, g);\n    }\n};\n\n/**\n * Copy SRT of all joints clips from another TrackClip\n * @param  {clay.animation.TrackClip} clip\n */\nTrackClip.prototype.copy = function (clip) {\n    for (var i = 0; i < this.tracks.length; i++) {\n        var sTrack = clip.tracks[i];\n        var tTrack = this.tracks[i];\n\n        vec3.copy(tTrack.position, sTrack.position);\n        vec3.copy(tTrack.scale, sTrack.scale);\n        quat.copy(tTrack.rotation, sTrack.rotation);\n    }\n};\n\nTrackClip.prototype.clone = function () {\n    var clip = Clip.prototype.clone.call(this);\n    for (var i = 0; i < this.tracks.length; i++) {\n        clip.addTrack(this.tracks[i].clone());\n    }\n    clip.life = this.life;\n    return clip;\n};\n\nexport default TrackClip;\n","var EXTENSION_LIST = [\n    'OES_texture_float',\n    'OES_texture_half_float',\n    'OES_texture_float_linear',\n    'OES_texture_half_float_linear',\n    'OES_standard_derivatives',\n    'OES_vertex_array_object',\n    'OES_element_index_uint',\n    'WEBGL_compressed_texture_s3tc',\n    'WEBGL_depth_texture',\n    'EXT_texture_filter_anisotropic',\n    'EXT_shader_texture_lod',\n    'WEBGL_draw_buffers',\n    'EXT_frag_depth',\n    'EXT_sRGB'\n];\n\nvar PARAMETER_NAMES = [\n    'MAX_TEXTURE_SIZE',\n    'MAX_CUBE_MAP_TEXTURE_SIZE'\n];\n\nfunction GLInfo(_gl) {\n    var extensions = {};\n    var parameters = {};\n\n    // Get webgl extension\n    for (var i = 0; i < EXTENSION_LIST.length; i++) {\n        var extName = EXTENSION_LIST[i];\n        createExtension(extName);\n    }\n    // Get parameters\n    for (var i = 0; i < PARAMETER_NAMES.length; i++) {\n        var name = PARAMETER_NAMES[i];\n        parameters[name] = _gl.getParameter(_gl[name]);\n    }\n\n    this.getExtension = function (name) {\n        if (!(name in extensions)) {\n            createExtension(name);\n        }\n        return extensions[name];\n    };\n\n    this.getParameter = function (name) {\n        return parameters[name];\n    };\n\n    function createExtension(name) {\n        var ext = _gl.getExtension(name);\n        if (!ext) {\n            ext = _gl.getExtension('MOZ_' + name);\n        }\n        if (!ext) {\n            ext = _gl.getExtension('WEBKIT_' + name);\n        }\n        extensions[name] = ext;\n    }\n}\n\nexport default GLInfo;\n","/**\n * @namespace clay.core.glenum\n * @see http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.14\n */\nexport default {\n    /* ClearBufferMask */\n    DEPTH_BUFFER_BIT               : 0x00000100,\n    STENCIL_BUFFER_BIT             : 0x00000400,\n    COLOR_BUFFER_BIT               : 0x00004000,\n\n    /* BeginMode */\n    POINTS                         : 0x0000,\n    LINES                          : 0x0001,\n    LINE_LOOP                      : 0x0002,\n    LINE_STRIP                     : 0x0003,\n    TRIANGLES                      : 0x0004,\n    TRIANGLE_STRIP                 : 0x0005,\n    TRIANGLE_FAN                   : 0x0006,\n\n    /* AlphaFunction (not supported in ES20) */\n    /*      NEVER */\n    /*      LESS */\n    /*      EQUAL */\n    /*      LEQUAL */\n    /*      GREATER */\n    /*      NOTEQUAL */\n    /*      GEQUAL */\n    /*      ALWAYS */\n\n    /* BlendingFactorDest */\n    ZERO                           : 0,\n    ONE                            : 1,\n    SRC_COLOR                      : 0x0300,\n    ONE_MINUS_SRC_COLOR            : 0x0301,\n    SRC_ALPHA                      : 0x0302,\n    ONE_MINUS_SRC_ALPHA            : 0x0303,\n    DST_ALPHA                      : 0x0304,\n    ONE_MINUS_DST_ALPHA            : 0x0305,\n\n    /* BlendingFactorSrc */\n    /*      ZERO */\n    /*      ONE */\n    DST_COLOR                      : 0x0306,\n    ONE_MINUS_DST_COLOR            : 0x0307,\n    SRC_ALPHA_SATURATE             : 0x0308,\n    /*      SRC_ALPHA */\n    /*      ONE_MINUS_SRC_ALPHA */\n    /*      DST_ALPHA */\n    /*      ONE_MINUS_DST_ALPHA */\n\n    /* BlendEquationSeparate */\n    FUNC_ADD                       : 0x8006,\n    BLEND_EQUATION                 : 0x8009,\n    BLEND_EQUATION_RGB             : 0x8009, /* same as BLEND_EQUATION */\n    BLEND_EQUATION_ALPHA           : 0x883D,\n\n    /* BlendSubtract */\n    FUNC_SUBTRACT                  : 0x800A,\n    FUNC_REVERSE_SUBTRACT          : 0x800B,\n\n    /* Separate Blend Functions */\n    BLEND_DST_RGB                  : 0x80C8,\n    BLEND_SRC_RGB                  : 0x80C9,\n    BLEND_DST_ALPHA                : 0x80CA,\n    BLEND_SRC_ALPHA                : 0x80CB,\n    CONSTANT_COLOR                 : 0x8001,\n    ONE_MINUS_CONSTANT_COLOR       : 0x8002,\n    CONSTANT_ALPHA                 : 0x8003,\n    ONE_MINUS_CONSTANT_ALPHA       : 0x8004,\n    BLEND_COLOR                    : 0x8005,\n\n    /* Buffer Objects */\n    ARRAY_BUFFER                   : 0x8892,\n    ELEMENT_ARRAY_BUFFER           : 0x8893,\n    ARRAY_BUFFER_BINDING           : 0x8894,\n    ELEMENT_ARRAY_BUFFER_BINDING   : 0x8895,\n\n    STREAM_DRAW                    : 0x88E0,\n    STATIC_DRAW                    : 0x88E4,\n    DYNAMIC_DRAW                   : 0x88E8,\n\n    BUFFER_SIZE                    : 0x8764,\n    BUFFER_USAGE                   : 0x8765,\n\n    CURRENT_VERTEX_ATTRIB          : 0x8626,\n\n    /* CullFaceMode */\n    FRONT                          : 0x0404,\n    BACK                           : 0x0405,\n    FRONT_AND_BACK                 : 0x0408,\n\n    /* DepthFunction */\n    /*      NEVER */\n    /*      LESS */\n    /*      EQUAL */\n    /*      LEQUAL */\n    /*      GREATER */\n    /*      NOTEQUAL */\n    /*      GEQUAL */\n    /*      ALWAYS */\n\n    /* EnableCap */\n    /* TEXTURE_2D */\n    CULL_FACE                      : 0x0B44,\n    BLEND                          : 0x0BE2,\n    DITHER                         : 0x0BD0,\n    STENCIL_TEST                   : 0x0B90,\n    DEPTH_TEST                     : 0x0B71,\n    SCISSOR_TEST                   : 0x0C11,\n    POLYGON_OFFSET_FILL            : 0x8037,\n    SAMPLE_ALPHA_TO_COVERAGE       : 0x809E,\n    SAMPLE_COVERAGE                : 0x80A0,\n\n    /* ErrorCode */\n    NO_ERROR                       : 0,\n    INVALID_ENUM                   : 0x0500,\n    INVALID_VALUE                  : 0x0501,\n    INVALID_OPERATION              : 0x0502,\n    OUT_OF_MEMORY                  : 0x0505,\n\n    /* FrontFaceDirection */\n    CW                             : 0x0900,\n    CCW                            : 0x0901,\n\n    /* GetPName */\n    LINE_WIDTH                     : 0x0B21,\n    ALIASED_POINT_SIZE_RANGE       : 0x846D,\n    ALIASED_LINE_WIDTH_RANGE       : 0x846E,\n    CULL_FACE_MODE                 : 0x0B45,\n    FRONT_FACE                     : 0x0B46,\n    DEPTH_RANGE                    : 0x0B70,\n    DEPTH_WRITEMASK                : 0x0B72,\n    DEPTH_CLEAR_VALUE              : 0x0B73,\n    DEPTH_FUNC                     : 0x0B74,\n    STENCIL_CLEAR_VALUE            : 0x0B91,\n    STENCIL_FUNC                   : 0x0B92,\n    STENCIL_FAIL                   : 0x0B94,\n    STENCIL_PASS_DEPTH_FAIL        : 0x0B95,\n    STENCIL_PASS_DEPTH_PASS        : 0x0B96,\n    STENCIL_REF                    : 0x0B97,\n    STENCIL_VALUE_MASK             : 0x0B93,\n    STENCIL_WRITEMASK              : 0x0B98,\n    STENCIL_BACK_FUNC              : 0x8800,\n    STENCIL_BACK_FAIL              : 0x8801,\n    STENCIL_BACK_PASS_DEPTH_FAIL   : 0x8802,\n    STENCIL_BACK_PASS_DEPTH_PASS   : 0x8803,\n    STENCIL_BACK_REF               : 0x8CA3,\n    STENCIL_BACK_VALUE_MASK        : 0x8CA4,\n    STENCIL_BACK_WRITEMASK         : 0x8CA5,\n    VIEWPORT                       : 0x0BA2,\n    SCISSOR_BOX                    : 0x0C10,\n    /*      SCISSOR_TEST */\n    COLOR_CLEAR_VALUE              : 0x0C22,\n    COLOR_WRITEMASK                : 0x0C23,\n    UNPACK_ALIGNMENT               : 0x0CF5,\n    PACK_ALIGNMENT                 : 0x0D05,\n    MAX_TEXTURE_SIZE               : 0x0D33,\n    MAX_VIEWPORT_DIMS              : 0x0D3A,\n    SUBPIXEL_BITS                  : 0x0D50,\n    RED_BITS                       : 0x0D52,\n    GREEN_BITS                     : 0x0D53,\n    BLUE_BITS                      : 0x0D54,\n    ALPHA_BITS                     : 0x0D55,\n    DEPTH_BITS                     : 0x0D56,\n    STENCIL_BITS                   : 0x0D57,\n    POLYGON_OFFSET_UNITS           : 0x2A00,\n    /*      POLYGON_OFFSET_FILL */\n    POLYGON_OFFSET_FACTOR          : 0x8038,\n    TEXTURE_BINDING_2D             : 0x8069,\n    SAMPLE_BUFFERS                 : 0x80A8,\n    SAMPLES                        : 0x80A9,\n    SAMPLE_COVERAGE_VALUE          : 0x80AA,\n    SAMPLE_COVERAGE_INVERT         : 0x80AB,\n\n    /* GetTextureParameter */\n    /*      TEXTURE_MAG_FILTER */\n    /*      TEXTURE_MIN_FILTER */\n    /*      TEXTURE_WRAP_S */\n    /*      TEXTURE_WRAP_T */\n\n    COMPRESSED_TEXTURE_FORMATS     : 0x86A3,\n\n    /* HintMode */\n    DONT_CARE                      : 0x1100,\n    FASTEST                        : 0x1101,\n    NICEST                         : 0x1102,\n\n    /* HintTarget */\n    GENERATE_MIPMAP_HINT            : 0x8192,\n\n    /* DataType */\n    BYTE                           : 0x1400,\n    UNSIGNED_BYTE                  : 0x1401,\n    SHORT                          : 0x1402,\n    UNSIGNED_SHORT                 : 0x1403,\n    INT                            : 0x1404,\n    UNSIGNED_INT                   : 0x1405,\n    FLOAT                          : 0x1406,\n\n    /* PixelFormat */\n    DEPTH_COMPONENT                : 0x1902,\n    ALPHA                          : 0x1906,\n    RGB                            : 0x1907,\n    RGBA                           : 0x1908,\n    LUMINANCE                      : 0x1909,\n    LUMINANCE_ALPHA                : 0x190A,\n\n    /* PixelType */\n    /*      UNSIGNED_BYTE */\n    UNSIGNED_SHORT_4_4_4_4         : 0x8033,\n    UNSIGNED_SHORT_5_5_5_1         : 0x8034,\n    UNSIGNED_SHORT_5_6_5           : 0x8363,\n\n    /* Shaders */\n    FRAGMENT_SHADER                  : 0x8B30,\n    VERTEX_SHADER                    : 0x8B31,\n    MAX_VERTEX_ATTRIBS               : 0x8869,\n    MAX_VERTEX_UNIFORM_VECTORS       : 0x8DFB,\n    MAX_VARYING_VECTORS              : 0x8DFC,\n    MAX_COMBINED_TEXTURE_IMAGE_UNITS : 0x8B4D,\n    MAX_VERTEX_TEXTURE_IMAGE_UNITS   : 0x8B4C,\n    MAX_TEXTURE_IMAGE_UNITS          : 0x8872,\n    MAX_FRAGMENT_UNIFORM_VECTORS     : 0x8DFD,\n    SHADER_TYPE                      : 0x8B4F,\n    DELETE_STATUS                    : 0x8B80,\n    LINK_STATUS                      : 0x8B82,\n    VALIDATE_STATUS                  : 0x8B83,\n    ATTACHED_SHADERS                 : 0x8B85,\n    ACTIVE_UNIFORMS                  : 0x8B86,\n    ACTIVE_ATTRIBUTES                : 0x8B89,\n    SHADING_LANGUAGE_VERSION         : 0x8B8C,\n    CURRENT_PROGRAM                  : 0x8B8D,\n\n    /* StencilFunction */\n    NEVER                          : 0x0200,\n    LESS                           : 0x0201,\n    EQUAL                          : 0x0202,\n    LEQUAL                         : 0x0203,\n    GREATER                        : 0x0204,\n    NOTEQUAL                       : 0x0205,\n    GEQUAL                         : 0x0206,\n    ALWAYS                         : 0x0207,\n\n    /* StencilOp */\n    /*      ZERO */\n    KEEP                           : 0x1E00,\n    REPLACE                        : 0x1E01,\n    INCR                           : 0x1E02,\n    DECR                           : 0x1E03,\n    INVERT                         : 0x150A,\n    INCR_WRAP                      : 0x8507,\n    DECR_WRAP                      : 0x8508,\n\n    /* StringName */\n    VENDOR                         : 0x1F00,\n    RENDERER                       : 0x1F01,\n    VERSION                        : 0x1F02,\n\n    /* TextureMagFilter */\n    NEAREST                        : 0x2600,\n    LINEAR                         : 0x2601,\n\n    /* TextureMinFilter */\n    /*      NEAREST */\n    /*      LINEAR */\n    NEAREST_MIPMAP_NEAREST         : 0x2700,\n    LINEAR_MIPMAP_NEAREST          : 0x2701,\n    NEAREST_MIPMAP_LINEAR          : 0x2702,\n    LINEAR_MIPMAP_LINEAR           : 0x2703,\n\n    /* TextureParameterName */\n    TEXTURE_MAG_FILTER             : 0x2800,\n    TEXTURE_MIN_FILTER             : 0x2801,\n    TEXTURE_WRAP_S                 : 0x2802,\n    TEXTURE_WRAP_T                 : 0x2803,\n\n    /* TextureTarget */\n    TEXTURE_2D                     : 0x0DE1,\n    TEXTURE                        : 0x1702,\n\n    TEXTURE_CUBE_MAP               : 0x8513,\n    TEXTURE_BINDING_CUBE_MAP       : 0x8514,\n    TEXTURE_CUBE_MAP_POSITIVE_X    : 0x8515,\n    TEXTURE_CUBE_MAP_NEGATIVE_X    : 0x8516,\n    TEXTURE_CUBE_MAP_POSITIVE_Y    : 0x8517,\n    TEXTURE_CUBE_MAP_NEGATIVE_Y    : 0x8518,\n    TEXTURE_CUBE_MAP_POSITIVE_Z    : 0x8519,\n    TEXTURE_CUBE_MAP_NEGATIVE_Z    : 0x851A,\n    MAX_CUBE_MAP_TEXTURE_SIZE      : 0x851C,\n\n    /* TextureUnit */\n    TEXTURE0                       : 0x84C0,\n    TEXTURE1                       : 0x84C1,\n    TEXTURE2                       : 0x84C2,\n    TEXTURE3                       : 0x84C3,\n    TEXTURE4                       : 0x84C4,\n    TEXTURE5                       : 0x84C5,\n    TEXTURE6                       : 0x84C6,\n    TEXTURE7                       : 0x84C7,\n    TEXTURE8                       : 0x84C8,\n    TEXTURE9                       : 0x84C9,\n    TEXTURE10                      : 0x84CA,\n    TEXTURE11                      : 0x84CB,\n    TEXTURE12                      : 0x84CC,\n    TEXTURE13                      : 0x84CD,\n    TEXTURE14                      : 0x84CE,\n    TEXTURE15                      : 0x84CF,\n    TEXTURE16                      : 0x84D0,\n    TEXTURE17                      : 0x84D1,\n    TEXTURE18                      : 0x84D2,\n    TEXTURE19                      : 0x84D3,\n    TEXTURE20                      : 0x84D4,\n    TEXTURE21                      : 0x84D5,\n    TEXTURE22                      : 0x84D6,\n    TEXTURE23                      : 0x84D7,\n    TEXTURE24                      : 0x84D8,\n    TEXTURE25                      : 0x84D9,\n    TEXTURE26                      : 0x84DA,\n    TEXTURE27                      : 0x84DB,\n    TEXTURE28                      : 0x84DC,\n    TEXTURE29                      : 0x84DD,\n    TEXTURE30                      : 0x84DE,\n    TEXTURE31                      : 0x84DF,\n    ACTIVE_TEXTURE                 : 0x84E0,\n\n    /* TextureWrapMode */\n    REPEAT                         : 0x2901,\n    CLAMP_TO_EDGE                  : 0x812F,\n    MIRRORED_REPEAT                : 0x8370,\n\n    /* Uniform Types */\n    FLOAT_VEC2                     : 0x8B50,\n    FLOAT_VEC3                     : 0x8B51,\n    FLOAT_VEC4                     : 0x8B52,\n    INT_VEC2                       : 0x8B53,\n    INT_VEC3                       : 0x8B54,\n    INT_VEC4                       : 0x8B55,\n    BOOL                           : 0x8B56,\n    BOOL_VEC2                      : 0x8B57,\n    BOOL_VEC3                      : 0x8B58,\n    BOOL_VEC4                      : 0x8B59,\n    FLOAT_MAT2                     : 0x8B5A,\n    FLOAT_MAT3                     : 0x8B5B,\n    FLOAT_MAT4                     : 0x8B5C,\n    SAMPLER_2D                     : 0x8B5E,\n    SAMPLER_CUBE                   : 0x8B60,\n\n    /* Vertex Arrays */\n    VERTEX_ATTRIB_ARRAY_ENABLED        : 0x8622,\n    VERTEX_ATTRIB_ARRAY_SIZE           : 0x8623,\n    VERTEX_ATTRIB_ARRAY_STRIDE         : 0x8624,\n    VERTEX_ATTRIB_ARRAY_TYPE           : 0x8625,\n    VERTEX_ATTRIB_ARRAY_NORMALIZED     : 0x886A,\n    VERTEX_ATTRIB_ARRAY_POINTER        : 0x8645,\n    VERTEX_ATTRIB_ARRAY_BUFFER_BINDING : 0x889F,\n\n    /* Shader Source */\n    COMPILE_STATUS                 : 0x8B81,\n\n    /* Shader Precision-Specified Types */\n    LOW_FLOAT                      : 0x8DF0,\n    MEDIUM_FLOAT                   : 0x8DF1,\n    HIGH_FLOAT                     : 0x8DF2,\n    LOW_INT                        : 0x8DF3,\n    MEDIUM_INT                     : 0x8DF4,\n    HIGH_INT                       : 0x8DF5,\n\n    /* Framebuffer Object. */\n    FRAMEBUFFER                    : 0x8D40,\n    RENDERBUFFER                   : 0x8D41,\n\n    RGBA4                          : 0x8056,\n    RGB5_A1                        : 0x8057,\n    RGB565                         : 0x8D62,\n    DEPTH_COMPONENT16              : 0x81A5,\n    STENCIL_INDEX                  : 0x1901,\n    STENCIL_INDEX8                 : 0x8D48,\n    DEPTH_STENCIL                  : 0x84F9,\n\n    RENDERBUFFER_WIDTH             : 0x8D42,\n    RENDERBUFFER_HEIGHT            : 0x8D43,\n    RENDERBUFFER_INTERNAL_FORMAT   : 0x8D44,\n    RENDERBUFFER_RED_SIZE          : 0x8D50,\n    RENDERBUFFER_GREEN_SIZE        : 0x8D51,\n    RENDERBUFFER_BLUE_SIZE         : 0x8D52,\n    RENDERBUFFER_ALPHA_SIZE        : 0x8D53,\n    RENDERBUFFER_DEPTH_SIZE        : 0x8D54,\n    RENDERBUFFER_STENCIL_SIZE      : 0x8D55,\n\n    FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE           : 0x8CD0,\n    FRAMEBUFFER_ATTACHMENT_OBJECT_NAME           : 0x8CD1,\n    FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL         : 0x8CD2,\n    FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE : 0x8CD3,\n\n    COLOR_ATTACHMENT0              : 0x8CE0,\n    DEPTH_ATTACHMENT               : 0x8D00,\n    STENCIL_ATTACHMENT             : 0x8D20,\n    DEPTH_STENCIL_ATTACHMENT       : 0x821A,\n\n    NONE                           : 0,\n\n    FRAMEBUFFER_COMPLETE                      : 0x8CD5,\n    FRAMEBUFFER_INCOMPLETE_ATTACHMENT         : 0x8CD6,\n    FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT : 0x8CD7,\n    FRAMEBUFFER_INCOMPLETE_DIMENSIONS         : 0x8CD9,\n    FRAMEBUFFER_UNSUPPORTED                   : 0x8CDD,\n\n    FRAMEBUFFER_BINDING            : 0x8CA6,\n    RENDERBUFFER_BINDING           : 0x8CA7,\n    MAX_RENDERBUFFER_SIZE          : 0x84E8,\n\n    INVALID_FRAMEBUFFER_OPERATION  : 0x0506,\n\n    /* WebGL-specific enums */\n    UNPACK_FLIP_Y_WEBGL            : 0x9240,\n    UNPACK_PREMULTIPLY_ALPHA_WEBGL : 0x9241,\n    CONTEXT_LOST_WEBGL             : 0x9242,\n    UNPACK_COLORSPACE_CONVERSION_WEBGL : 0x9243,\n    BROWSER_DEFAULT_WEBGL          : 0x9244,\n};\n","var supportWebGL = true;\ntry {\n    var canvas = document.createElement('canvas');\n    var gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl');\n    if (!gl) {\n        throw new Error();\n    }\n} catch (e) {\n    supportWebGL = false;\n}\n\nvar vendor = {};\n\n/**\n * If support WebGL\n * @return {boolean}\n */\nvendor.supportWebGL = function () {\n    return supportWebGL;\n};\n\n\nvendor.Int8Array = typeof Int8Array == 'undefined' ? Array : Int8Array;\n\nvendor.Uint8Array = typeof Uint8Array == 'undefined' ? Array : Uint8Array;\n\nvendor.Uint16Array = typeof Uint16Array == 'undefined' ? Array : Uint16Array;\n\nvendor.Uint32Array = typeof Uint32Array == 'undefined' ? Array : Uint32Array;\n\nvendor.Int16Array = typeof Int16Array == 'undefined' ? Array : Int16Array;\n\nvendor.Float32Array = typeof Float32Array == 'undefined' ? Array : Float32Array;\n\nvendor.Float64Array = typeof Float64Array == 'undefined' ? Array : Float64Array;\n\nexport default vendor;\n","import glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\n/**\n * @constructor\n * @alias clay.math.Vector3\n * @param {number} x\n * @param {number} y\n * @param {number} z\n */\nvar Vector3 = function(x, y, z) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n\n    /**\n     * Storage of Vector3, read and write of x, y, z will change the values in array\n     * All methods also operate on the array instead of x, y, z components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector3#\n     */\n    this.array = vec3.fromValues(x, y, z);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector3#\n     */\n    this._dirty = true;\n};\n\nVector3.prototype = {\n\n    constructor : Vector3,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    add: function (b) {\n        vec3.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @return {clay.math.Vector3}\n     */\n    set: function (x, y, z) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector3}\n     */\n    setArray: function (arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector3\n     * @return {clay.math.Vector3}\n     */\n    clone: function () {\n        return new Vector3(this.x, this.y, this.z);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    copy: function (b) {\n        vec3.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Cross product of self and b, written to a Vector3 out\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    cross: function (a, b) {\n        vec3.cross(this.array, a.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    dist: function (b) {\n        return vec3.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    distance: function (b) {\n        return vec3.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    div: function (b) {\n        vec3.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    divide: function (b) {\n        vec3.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    dot: function (b) {\n        return vec3.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function () {\n        return vec3.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function () {\n        return vec3.length(this.array);\n    },\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @param  {number}  t\n     * @return {clay.math.Vector3}\n     */\n    lerp: function (a, b, t) {\n        vec3.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    min: function (b) {\n        vec3.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    max: function (b) {\n        vec3.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    mul: function (b) {\n        vec3.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    multiply: function (b) {\n        vec3.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector3}\n     */\n    negate: function () {\n        vec3.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector3}\n     */\n    normalize: function () {\n        vec3.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y, z components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector3}\n     */\n    random: function (scale) {\n        vec3.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector3}\n     */\n    scale: function (s) {\n        vec3.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector3} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector3}\n     */\n    scaleAndAdd: function (b, s) {\n        vec3.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    sqrDist: function (b) {\n        return vec3.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector3} b\n     * @return {number}\n     */\n    squaredDistance: function (b) {\n        return vec3.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function () {\n        return vec3.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function () {\n        return vec3.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    sub: function (b) {\n        vec3.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Vector3}\n     */\n    subtract: function (b) {\n        vec3.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix3 m\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Vector3}\n     */\n    transformMat3: function (m) {\n        vec3.transformMat3(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector3}\n     */\n    transformMat4: function (m) {\n        vec3.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Transform self with a Quaternion q\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Vector3}\n     */\n    transformQuat: function (q) {\n        vec3.transformQuat(this.array, this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Trasnform self into projection space with m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector3}\n     */\n    applyProjection: function (m) {\n        var v = this.array;\n        m = m.array;\n\n        // Perspective projection\n        if (m[15] === 0) {\n            var w = -1 / v[2];\n            v[0] = m[0] * v[0] * w;\n            v[1] = m[5] * v[1] * w;\n            v[2] = (m[10] * v[2] + m[14]) * w;\n        }\n        else {\n            v[0] = m[0] * v[0] + m[12];\n            v[1] = m[5] * v[1] + m[13];\n            v[2] = m[10] * v[2] + m[14];\n        }\n        this._dirty = true;\n\n        return this;\n    },\n\n    eulerFromQuat: function(q, order) {\n        Vector3.eulerFromQuat(this, q, order);\n    },\n\n    eulerFromMat3: function (m, order) {\n        Vector3.eulerFromMat3(this, m, order);\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Vector3.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Vector3\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.add = function(out, a, b) {\n    vec3.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {number}  x\n * @param  {number}  y\n * @param  {number}  z\n * @return {clay.math.Vector3}\n */\nVector3.set = function(out, x, y, z) {\n    vec3.set(out.array, x, y, z);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.copy = function(out, b) {\n    vec3.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.cross = function(out, a, b) {\n    vec3.cross(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.dist = function(a, b) {\n    return vec3.distance(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.distance = Vector3.dist;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.div = function(out, a, b) {\n    vec3.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.divide = Vector3.div;\n\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.dot = function(a, b) {\n    return vec3.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.len = function(b) {\n    return vec3.length(b.array);\n};\n\n// Vector3.length = Vector3.len;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @param  {number}  t\n * @return {clay.math.Vector3}\n */\nVector3.lerp = function(out, a, b, t) {\n    vec3.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.min = function(out, a, b) {\n    vec3.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.max = function(out, a, b) {\n    vec3.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.mul = function(out, a, b) {\n    vec3.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.multiply = Vector3.mul;\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @return {clay.math.Vector3}\n */\nVector3.negate = function(out, a) {\n    vec3.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @return {clay.math.Vector3}\n */\nVector3.normalize = function(out, a) {\n    vec3.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.random = function(out, scale) {\n    vec3.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.scale = function(out, a, scale) {\n    vec3.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @param  {number}  scale\n * @return {clay.math.Vector3}\n */\nVector3.scaleAndAdd = function(out, a, b, scale) {\n    vec3.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.sqrDist = function(a, b) {\n    return vec3.sqrDist(a.array, b.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {number}\n */\nVector3.squaredDistance = Vector3.sqrDist;\n/**\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.sqrLen = function(a) {\n    return vec3.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector3} a\n * @return {number}\n */\nVector3.squaredLength = Vector3.sqrLen;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.sub = function(out, a, b) {\n    vec3.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Vector3} b\n * @return {clay.math.Vector3}\n */\nVector3.subtract = Vector3.sub;\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {Matrix3} m\n * @return {clay.math.Vector3}\n */\nVector3.transformMat3 = function(out, a, m) {\n    vec3.transformMat3(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector3}\n */\nVector3.transformMat4 = function(out, a, m) {\n    vec3.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {clay.math.Vector3} out\n * @param  {clay.math.Vector3} a\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Vector3}\n */\nVector3.transformQuat = function(out, a, q) {\n    vec3.transformQuat(out.array, a.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\nfunction clamp(val, min, max) {\n    return val < min ? min : (val > max ? max : val);\n}\nvar atan2 = Math.atan2;\nvar asin = Math.asin;\nvar abs = Math.abs;\n/**\n * Convert quaternion to euler angle\n * Quaternion must be normalized\n * From three.js\n */\nVector3.eulerFromQuat = function (out, q, order) {\n    out._dirty = true;\n    q = q.array;\n\n    var target = out.array;\n    var x = q[0], y = q[1], z = q[2], w = q[3];\n    var x2 = x * x;\n    var y2 = y * y;\n    var z2 = z * z;\n    var w2 = w * w;\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    switch (order) {\n        case 'XYZ':\n            target[0] = atan2(2 * (x * w - y * z), (w2 - x2 - y2 + z2));\n            target[1] = asin(clamp(2 * (x * z + y * w), - 1, 1));\n            target[2] = atan2(2 * (z * w - x * y), (w2 + x2 - y2 - z2));\n            break;\n        case 'YXZ':\n            target[0] = asin(clamp(2 * (x * w - y * z), - 1, 1));\n            target[1] = atan2(2 * (x * z + y * w), (w2 - x2 - y2 + z2));\n            target[2] = atan2(2 * (x * y + z * w), (w2 - x2 + y2 - z2));\n            break;\n        case 'ZXY':\n            target[0] = asin(clamp(2 * (x * w + y * z), - 1, 1));\n            target[1] = atan2(2 * (y * w - z * x), (w2 - x2 - y2 + z2));\n            target[2] = atan2(2 * (z * w - x * y), (w2 - x2 + y2 - z2));\n            break;\n        case 'ZYX':\n            target[0] = atan2(2 * (x * w + z * y), (w2 - x2 - y2 + z2));\n            target[1] = asin(clamp(2 * (y * w - x * z), - 1, 1));\n            target[2] = atan2(2 * (x * y + z * w), (w2 + x2 - y2 - z2));\n            break;\n        case 'YZX':\n            target[0] = atan2(2 * (x * w - z * y), (w2 - x2 + y2 - z2));\n            target[1] = atan2(2 * (y * w - x * z), (w2 + x2 - y2 - z2));\n            target[2] = asin(clamp(2 * (x * y + z * w), - 1, 1));\n            break;\n        case 'XZY':\n            target[0] = atan2(2 * (x * w + y * z), (w2 - x2 + y2 - z2));\n            target[1] = atan2(2 * (x * z + y * w), (w2 + x2 - y2 - z2));\n            target[2] = asin(clamp(2 * (z * w - x * y), - 1, 1));\n            break;\n        default:\n            console.warn('Unkown order: ' + order);\n    }\n    return out;\n};\n\n/**\n * Convert rotation matrix to euler angle\n * from three.js\n */\nVector3.eulerFromMat3 = function (out, m, order) {\n    // assumes the upper 3x3 of m is a pure rotation matrix (i.e, unscaled)\n    var te = m.array;\n    var m11 = te[0], m12 = te[3], m13 = te[6];\n    var m21 = te[1], m22 = te[4], m23 = te[7];\n    var m31 = te[2], m32 = te[5], m33 = te[8];\n    var target = out.array;\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    switch (order) {\n        case 'XYZ':\n            target[1] = asin(clamp(m13, -1, 1));\n            if (abs(m13) < 0.99999) {\n                target[0] = atan2(-m23, m33);\n                target[2] = atan2(-m12, m11);\n            }\n            else {\n                target[0] = atan2(m32, m22);\n                target[2] = 0;\n            }\n            break;\n        case 'YXZ':\n            target[0] = asin(-clamp(m23, -1, 1));\n            if (abs(m23) < 0.99999) {\n                target[1] = atan2(m13, m33);\n                target[2] = atan2(m21, m22);\n            }\n            else {\n                target[1] = atan2(-m31, m11);\n                target[2] = 0;\n            }\n            break;\n        case 'ZXY':\n            target[0] = asin(clamp(m32, -1, 1));\n            if (abs(m32) < 0.99999) {\n                target[1] = atan2(-m31, m33);\n                target[2] = atan2(-m12, m22);\n            }\n            else {\n                target[1] = 0;\n                target[2] = atan2(m21, m11);\n            }\n            break;\n        case 'ZYX':\n            target[1] = asin(-clamp(m31, -1, 1));\n            if (abs(m31) < 0.99999) {\n                target[0] = atan2(m32, m33);\n                target[2] = atan2(m21, m11);\n            }\n            else {\n                target[0] = 0;\n                target[2] = atan2(-m12, m22);\n            }\n            break;\n        case 'YZX':\n            target[2] = asin(clamp(m21, -1, 1));\n            if (abs(m21) < 0.99999) {\n                target[0] = atan2(-m23, m22);\n                target[1] = atan2(-m31, m11);\n            }\n            else {\n                target[0] = 0;\n                target[1] = atan2(m13, m33);\n            }\n            break;\n        case 'XZY':\n            target[2] = asin(-clamp(m12, -1, 1));\n            if (abs(m12) < 0.99999) {\n                target[0] = atan2(m32, m22);\n                target[1] = atan2(m13, m11);\n            }\n            else {\n                target[0] = atan2(-m23, m33);\n                target[1] = 0;\n            }\n            break;\n        default:\n            console.warn('Unkown order: ' + order);\n    }\n    out._dirty = true;\n\n    return out;\n};\n\n// TODO return new.\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_X = new Vector3(1, 0, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_X = new Vector3(-1, 0, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_Y = new Vector3(0, 1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_Y = new Vector3(0, -1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.POSITIVE_Z = new Vector3(0, 0, 1);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.NEGATIVE_Z = new Vector3(0, 0, -1);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.UP = new Vector3(0, 1, 0);\n/**\n * @type {clay.math.Vector3}\n */\nVector3.ZERO = new Vector3(0, 0, 0);\n\nexport default Vector3;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar vec3Copy = vec3.copy;\nvar vec3Set = vec3.set;\n\n/**\n * Axis aligned bounding box\n * @constructor\n * @alias clay.math.BoundingBox\n * @param {clay.math.Vector3} [min]\n * @param {clay.math.Vector3} [max]\n */\nvar BoundingBox = function (min, max) {\n\n    /**\n     * Minimum coords of bounding box\n     * @type {clay.math.Vector3}\n     */\n    this.min = min || new Vector3(Infinity, Infinity, Infinity);\n\n    /**\n     * Maximum coords of bounding box\n     * @type {clay.math.Vector3}\n     */\n    this.max = max || new Vector3(-Infinity, -Infinity, -Infinity);\n};\n\nBoundingBox.prototype = {\n\n    constructor: BoundingBox,\n    /**\n     * Update min and max coords from a vertices array\n     * @param  {array} vertices\n     */\n    updateFromVertices: function (vertices) {\n        if (vertices.length > 0) {\n            var min = this.min;\n            var max = this.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            vec3Copy(minArr, vertices[0]);\n            vec3Copy(maxArr, vertices[0]);\n            for (var i = 1; i < vertices.length; i++) {\n                var vertex = vertices[i];\n\n                if (vertex[0] < minArr[0]) { minArr[0] = vertex[0]; }\n                if (vertex[1] < minArr[1]) { minArr[1] = vertex[1]; }\n                if (vertex[2] < minArr[2]) { minArr[2] = vertex[2]; }\n\n                if (vertex[0] > maxArr[0]) { maxArr[0] = vertex[0]; }\n                if (vertex[1] > maxArr[1]) { maxArr[1] = vertex[1]; }\n                if (vertex[2] > maxArr[2]) { maxArr[2] = vertex[2]; }\n            }\n            min._dirty = true;\n            max._dirty = true;\n        }\n    },\n\n    /**\n     * Union operation with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    union: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3.min(min.array, min.array, bbox.min.array);\n        vec3.max(max.array, max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * Intersection operation with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    intersection: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3.max(min.array, min.array, bbox.min.array);\n        vec3.min(max.array, max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * If intersect with another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     * @return {boolean}\n     */\n    intersectBoundingBox: function (bbox) {\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _min2 = bbox.min.array;\n        var _max2 = bbox.max.array;\n\n        return ! (_min[0] > _max2[0] || _min[1] > _max2[1] || _min[2] > _max2[2]\n            || _max[0] < _min2[0] || _max[1] < _min2[1] || _max[2] < _min2[2]);\n    },\n\n    /**\n     * If contain another bounding box entirely\n     * @param  {clay.math.BoundingBox} bbox\n     * @return {boolean}\n     */\n    containBoundingBox: function (bbox) {\n\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _min2 = bbox.min.array;\n        var _max2 = bbox.max.array;\n\n        return _min[0] <= _min2[0] && _min[1] <= _min2[1] && _min[2] <= _min2[2]\n            && _max[0] >= _max2[0] && _max[1] >= _max2[1] && _max[2] >= _max2[2];\n    },\n\n    /**\n     * If contain point entirely\n     * @param  {clay.math.Vector3} point\n     * @return {boolean}\n     */\n    containPoint: function (p) {\n        var _min = this.min.array;\n        var _max = this.max.array;\n\n        var _p = p.array;\n\n        return _min[0] <= _p[0] && _min[1] <= _p[1] && _min[2] <= _p[2]\n            && _max[0] >= _p[0] && _max[1] >= _p[1] && _max[2] >= _p[2];\n    },\n\n    /**\n     * If bounding box is finite\n     */\n    isFinite: function () {\n        var _min = this.min.array;\n        var _max = this.max.array;\n        return isFinite(_min[0]) && isFinite(_min[1]) && isFinite(_min[2])\n            && isFinite(_max[0]) && isFinite(_max[1]) && isFinite(_max[2]);\n    },\n\n    /**\n     * Apply an affine transform matrix to the bounding box\n     * @param  {clay.math.Matrix4} matrix\n     */\n    applyTransform: (function () {\n        // http://dev.theomader.com/transform-bounding-boxes/\n        var xa = vec3.create();\n        var xb = vec3.create();\n        var ya = vec3.create();\n        var yb = vec3.create();\n        var za = vec3.create();\n        var zb = vec3.create();\n\n        return function (matrix) {\n            var min = this.min.array;\n            var max = this.max.array;\n\n            var m = matrix.array;\n\n            xa[0] = m[0] * min[0]; xa[1] = m[1] * min[0]; xa[2] = m[2] * min[0];\n            xb[0] = m[0] * max[0]; xb[1] = m[1] * max[0]; xb[2] = m[2] * max[0];\n\n            ya[0] = m[4] * min[1]; ya[1] = m[5] * min[1]; ya[2] = m[6] * min[1];\n            yb[0] = m[4] * max[1]; yb[1] = m[5] * max[1]; yb[2] = m[6] * max[1];\n\n            za[0] = m[8] * min[2]; za[1] = m[9] * min[2]; za[2] = m[10] * min[2];\n            zb[0] = m[8] * max[2]; zb[1] = m[9] * max[2]; zb[2] = m[10] * max[2];\n\n            min[0] = Math.min(xa[0], xb[0]) + Math.min(ya[0], yb[0]) + Math.min(za[0], zb[0]) + m[12];\n            min[1] = Math.min(xa[1], xb[1]) + Math.min(ya[1], yb[1]) + Math.min(za[1], zb[1]) + m[13];\n            min[2] = Math.min(xa[2], xb[2]) + Math.min(ya[2], yb[2]) + Math.min(za[2], zb[2]) + m[14];\n\n            max[0] = Math.max(xa[0], xb[0]) + Math.max(ya[0], yb[0]) + Math.max(za[0], zb[0]) + m[12];\n            max[1] = Math.max(xa[1], xb[1]) + Math.max(ya[1], yb[1]) + Math.max(za[1], zb[1]) + m[13];\n            max[2] = Math.max(xa[2], xb[2]) + Math.max(ya[2], yb[2]) + Math.max(za[2], zb[2]) + m[14];\n\n            this.min._dirty = true;\n            this.max._dirty = true;\n\n            return this;\n        };\n    })(),\n\n    /**\n     * Apply a projection matrix to the bounding box\n     * @param  {clay.math.Matrix4} matrix\n     */\n    applyProjection: function (matrix) {\n        var min = this.min.array;\n        var max = this.max.array;\n\n        var m = matrix.array;\n        // min in min z\n        var v10 = min[0];\n        var v11 = min[1];\n        var v12 = min[2];\n        // max in min z\n        var v20 = max[0];\n        var v21 = max[1];\n        var v22 = min[2];\n        // max in max z\n        var v30 = max[0];\n        var v31 = max[1];\n        var v32 = max[2];\n\n        if (m[15] === 1) {  // Orthographic projection\n            min[0] = m[0] * v10 + m[12];\n            min[1] = m[5] * v11 + m[13];\n            max[2] = m[10] * v12 + m[14];\n\n            max[0] = m[0] * v30 + m[12];\n            max[1] = m[5] * v31 + m[13];\n            min[2] = m[10] * v32 + m[14];\n        }\n        else {\n            var w = -1 / v12;\n            min[0] = m[0] * v10 * w;\n            min[1] = m[5] * v11 * w;\n            max[2] = (m[10] * v12 + m[14]) * w;\n\n            w = -1 / v22;\n            max[0] = m[0] * v20 * w;\n            max[1] = m[5] * v21 * w;\n\n            w = -1 / v32;\n            min[2] = (m[10] * v32 + m[14]) * w;\n        }\n        this.min._dirty = true;\n        this.max._dirty = true;\n\n        return this;\n    },\n\n    updateVertices: function () {\n        var vertices = this.vertices;\n        if (!vertices) {\n            // Cube vertices\n            var vertices = [];\n            for (var i = 0; i < 8; i++) {\n                vertices[i] = vec3.fromValues(0, 0, 0);\n            }\n\n            /**\n             * Eight coords of bounding box\n             * @type {Float32Array[]}\n             */\n            this.vertices = vertices;\n        }\n        var min = this.min.array;\n        var max = this.max.array;\n        //--- min z\n        // min x\n        vec3Set(vertices[0], min[0], min[1], min[2]);\n        vec3Set(vertices[1], min[0], max[1], min[2]);\n        // max x\n        vec3Set(vertices[2], max[0], min[1], min[2]);\n        vec3Set(vertices[3], max[0], max[1], min[2]);\n\n        //-- max z\n        vec3Set(vertices[4], min[0], min[1], max[2]);\n        vec3Set(vertices[5], min[0], max[1], max[2]);\n        vec3Set(vertices[6], max[0], min[1], max[2]);\n        vec3Set(vertices[7], max[0], max[1], max[2]);\n\n        return this;\n    },\n    /**\n     * Copy values from another bounding box\n     * @param  {clay.math.BoundingBox} bbox\n     */\n    copy: function (bbox) {\n        var min = this.min;\n        var max = this.max;\n        vec3Copy(min.array, bbox.min.array);\n        vec3Copy(max.array, bbox.max.array);\n        min._dirty = true;\n        max._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new bounding box\n     * @return {clay.math.BoundingBox}\n     */\n    clone: function () {\n        var boundingBox = new BoundingBox();\n        boundingBox.copy(this);\n        return boundingBox;\n    }\n};\n\nexport default BoundingBox;\n","import glMatrix from '../dep/glmatrix';\nimport Vector3 from './Vector3';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar mat3 = glMatrix.mat3;\nvar quat = glMatrix.quat;\n\n/**\n * @constructor\n * @alias clay.math.Matrix4\n */\nvar Matrix4 = function() {\n\n    this._axisX = new Vector3();\n    this._axisY = new Vector3();\n    this._axisZ = new Vector3();\n\n    /**\n     * Storage of Matrix4\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix4#\n     */\n    this.array = mat4.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix4#\n     */\n    this._dirty = true;\n};\n\nMatrix4.prototype = {\n\n    constructor: Matrix4,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix4}\n     */\n    adjoint: function() {\n        mat4.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Matrix4\n     * @return {clay.math.Matrix4}\n     */\n    clone: function() {\n        return (new Matrix4()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    copy: function(a) {\n        mat4.copy(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat4.determinant(this.array);\n    },\n\n    /**\n     * Set upper 3x3 part from quaternion\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Matrix4}\n     */\n    fromQuat: function(q) {\n        mat4.fromQuat(this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from a quaternion rotation and a vector translation\n     * @param  {clay.math.Quaternion} q\n     * @param  {clay.math.Vector3} v\n     * @return {clay.math.Matrix4}\n     */\n    fromRotationTranslation: function(q, v) {\n        mat4.fromRotationTranslation(this.array, q.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from Matrix2d, it is used when converting a 2d shape to 3d space.\n     * In 3d space it is equivalent to ranslate on xy plane and rotate about z axis\n     * @param  {clay.math.Matrix2d} m2d\n     * @return {clay.math.Matrix4}\n     */\n    fromMat2d: function(m2d) {\n        Matrix4.fromMat2d(this, m2d);\n        return this;\n    },\n\n    /**\n     * Set from frustum bounds\n     * @param  {number} left\n     * @param  {number} right\n     * @param  {number} bottom\n     * @param  {number} top\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    frustum: function (left, right, bottom, top, near, far) {\n        mat4.frustum(this.array, left, right, bottom, top, near, far);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix4}\n     */\n    identity: function() {\n        mat4.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix4}\n     */\n    invert: function() {\n        mat4.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set as a matrix with the given eye position, focal point, and up axis\n     * @param  {clay.math.Vector3} eye\n     * @param  {clay.math.Vector3} center\n     * @param  {clay.math.Vector3} up\n     * @return {clay.math.Matrix4}\n     */\n    lookAt: function(eye, center, up) {\n        mat4.lookAt(this.array, eye.array, center.array, up.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    mul: function(b) {\n        mat4.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix4} a\n     * @return {clay.math.Matrix4}\n     */\n    mulLeft: function(a) {\n        mat4.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix4} b\n     * @return {clay.math.Matrix4}\n     */\n    multiply: function(b) {\n        mat4.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    multiplyLeft: function(a) {\n        mat4.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set as a orthographic projection matrix\n     * @param  {number} left\n     * @param  {number} right\n     * @param  {number} bottom\n     * @param  {number} top\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    ortho: function(left, right, bottom, top, near, far) {\n        mat4.ortho(this.array, left, right, bottom, top, near, far);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Set as a perspective projection matrix\n     * @param  {number} fovy\n     * @param  {number} aspect\n     * @param  {number} near\n     * @param  {number} far\n     * @return {clay.math.Matrix4}\n     */\n    perspective: function(fovy, aspect, near, far) {\n        mat4.perspective(this.array, fovy, aspect, near, far);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by rad about axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param  {number}   rad\n     * @param  {clay.math.Vector3} axis\n     * @return {clay.math.Matrix4}\n     */\n    rotate: function(rad, axis) {\n        mat4.rotate(this.array, this.array, rad, axis.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about X axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateX: function(rad) {\n        mat4.rotateX(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Y axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateY: function(rad) {\n        mat4.rotateY(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Z axis.\n     * Equal to right-multiply a rotaion matrix\n     * @param {number} rad\n     * @return {clay.math.Matrix4}\n     */\n    rotateZ: function(rad) {\n        mat4.rotateZ(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * Equal to right-multiply a scale matrix\n     * @param  {clay.math.Vector3}  s\n     * @return {clay.math.Matrix4}\n     */\n    scale: function(v) {\n        mat4.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v.\n     * Equal to right-multiply a translate matrix\n     * @param  {clay.math.Vector3}  v\n     * @return {clay.math.Matrix4}\n     */\n    translate: function(v) {\n        mat4.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function() {\n        mat4.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Decompose a matrix to SRT\n     * @param {clay.math.Vector3} [scale]\n     * @param {clay.math.Quaternion} rotation\n     * @param {clay.math.Vector} position\n     * @see http://msdn.microsoft.com/en-us/library/microsoft.xna.framework.matrix.decompose.aspx\n     */\n    decomposeMatrix: (function() {\n\n        var x = vec3.create();\n        var y = vec3.create();\n        var z = vec3.create();\n\n        var m3 = mat3.create();\n\n        return function(scale, rotation, position) {\n\n            var el = this.array;\n            vec3.set(x, el[0], el[1], el[2]);\n            vec3.set(y, el[4], el[5], el[6]);\n            vec3.set(z, el[8], el[9], el[10]);\n\n            var sx = vec3.length(x);\n            var sy = vec3.length(y);\n            var sz = vec3.length(z);\n\n            // if determine is negative, we need to invert one scale\n            var det = this.determinant();\n            if (det < 0) {\n                sx = -sx;\n            }\n\n            if (scale) {\n                scale.set(sx, sy, sz);\n            }\n\n            position.set(el[12], el[13], el[14]);\n\n            mat3.fromMat4(m3, el);\n            // Not like mat4, mat3 in glmatrix seems to be row-based\n            // Seems fixed in gl-matrix 2.2.2\n            // https://github.com/toji/gl-matrix/issues/114\n            // mat3.transpose(m3, m3);\n\n            m3[0] /= sx;\n            m3[1] /= sx;\n            m3[2] /= sx;\n\n            m3[3] /= sy;\n            m3[4] /= sy;\n            m3[5] /= sy;\n\n            m3[6] /= sz;\n            m3[7] /= sz;\n            m3[8] /= sz;\n\n            quat.fromMat3(rotation.array, m3);\n            quat.normalize(rotation.array, rotation.array);\n\n            rotation._dirty = true;\n            position._dirty = true;\n        };\n    })(),\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n\nif (defineProperty) {\n    var proto = Matrix4.prototype;\n    /**\n     * Z Axis of local transform\n     * @name z\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            var el = this.array;\n            this._axisZ.set(el[8], el[9], el[10]);\n            return this._axisZ;\n        },\n        set: function (v) {\n            // TODO Here has a problem\n            // If only set an item of vector will not work\n            var el = this.array;\n            v = v.array;\n            el[8] = v[0];\n            el[9] = v[1];\n            el[10] = v[2];\n\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * Y Axis of local transform\n     * @name y\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            var el = this.array;\n            this._axisY.set(el[4], el[5], el[6]);\n            return this._axisY;\n        },\n        set: function (v) {\n            var el = this.array;\n            v = v.array;\n            el[4] = v[0];\n            el[5] = v[1];\n            el[6] = v[2];\n\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * X Axis of local transform\n     * @name x\n     * @type {clay.math.Vector3}\n     * @memberOf clay.math.Matrix4\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            var el = this.array;\n            this._axisX.set(el[0], el[1], el[2]);\n            return this._axisX;\n        },\n        set: function (v) {\n            var el = this.array;\n            v = v.array;\n            el[0] = v[0];\n            el[1] = v[1];\n            el[2] = v[2];\n\n            this._dirty = true;\n        }\n    })\n}\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.adjoint = function(out, a) {\n    mat4.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.copy = function(out, a) {\n    mat4.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} a\n * @return {number}\n */\nMatrix4.determinant = function(a) {\n    return mat4.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @return {clay.math.Matrix4}\n */\nMatrix4.identity = function(out) {\n    mat4.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {number}  left\n * @param  {number}  right\n * @param  {number}  bottom\n * @param  {number}  top\n * @param  {number}  near\n * @param  {number}  far\n * @return {clay.math.Matrix4}\n */\nMatrix4.ortho = function(out, left, right, bottom, top, near, far) {\n    mat4.ortho(out.array, left, right, bottom, top, near, far);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {number}  fovy\n * @param  {number}  aspect\n * @param  {number}  near\n * @param  {number}  far\n * @return {clay.math.Matrix4}\n */\nMatrix4.perspective = function(out, fovy, aspect, near, far) {\n    mat4.perspective(out.array, fovy, aspect, near, far);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Vector3} eye\n * @param  {clay.math.Vector3} center\n * @param  {clay.math.Vector3} up\n * @return {clay.math.Matrix4}\n */\nMatrix4.lookAt = function(out, eye, center, up) {\n    mat4.lookAt(out.array, eye.array, center.array, up.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.invert = function(out, a) {\n    mat4.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Matrix4} b\n * @return {clay.math.Matrix4}\n */\nMatrix4.mul = function(out, a, b) {\n    mat4.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Matrix4} b\n * @return {clay.math.Matrix4}\n */\nMatrix4.multiply = Matrix4.mul;\n\n/**\n * @param  {clay.math.Matrix4}    out\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromQuat = function(out, q) {\n    mat4.fromQuat(out.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4}    out\n * @param  {clay.math.Quaternion} q\n * @param  {clay.math.Vector3}    v\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromRotationTranslation = function(out, q, v) {\n    mat4.fromRotationTranslation(out.array, q.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} m4\n * @param  {clay.math.Matrix2d} m2d\n * @return {clay.math.Matrix4}\n */\nMatrix4.fromMat2d = function(m4, m2d) {\n    m4._dirty = true;\n    var m2d = m2d.array;\n    var m4 = m4.array;\n\n    m4[0] = m2d[0];\n    m4[4] = m2d[2];\n    m4[12] = m2d[4];\n\n    m4[1] = m2d[1];\n    m4[5] = m2d[3];\n    m4[13] = m2d[5];\n\n    return m4;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @param  {clay.math.Vector3} axis\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotate = function(out, a, rad, axis) {\n    mat4.rotate(out.array, a.array, rad, axis.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateX = function(out, a, rad) {\n    mat4.rotateX(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateY = function(out, a, rad) {\n    mat4.rotateY(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {number}  rad\n * @return {clay.math.Matrix4}\n */\nMatrix4.rotateZ = function(out, a, rad) {\n    mat4.rotateZ(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Vector3} v\n * @return {clay.math.Matrix4}\n */\nMatrix4.scale = function(out, a, v) {\n    mat4.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix4}\n */\nMatrix4.transpose = function(out, a) {\n    mat4.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix4} out\n * @param  {clay.math.Matrix4} a\n * @param  {clay.math.Vector3} v\n * @return {clay.math.Matrix4}\n */\nMatrix4.translate = function(out, a, v) {\n    mat4.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix4;\n","var DIRTY_PREFIX = '__dt__';\n\nvar Cache = function () {\n\n    this._contextId = 0;\n\n    this._caches = [];\n\n    this._context = {};\n};\n\nCache.prototype = {\n\n    use: function (contextId, documentSchema) {\n        var caches = this._caches;\n        if (!caches[contextId]) {\n            caches[contextId] = {};\n\n            if (documentSchema) {\n                caches[contextId] = documentSchema();\n            }\n        }\n        this._contextId = contextId;\n\n        this._context = caches[contextId];\n    },\n\n    put: function (key, value) {\n        this._context[key] = value;\n    },\n\n    get: function (key) {\n        return this._context[key];\n    },\n\n    dirty: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        this.put(key, true);\n    },\n\n    dirtyAll: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var caches = this._caches;\n        for (var i = 0; i < caches.length; i++) {\n            if (caches[i]) {\n                caches[i][key] = true;\n            }\n        }\n    },\n\n    fresh: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        this.put(key, false);\n    },\n\n    freshAll: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var caches = this._caches;\n        for (var i = 0; i < caches.length; i++) {\n            if (caches[i]) {\n                caches[i][key] = false;\n            }\n        }\n    },\n\n    isDirty: function (field) {\n        field = field || '';\n        var key = DIRTY_PREFIX + field;\n        var context = this._context;\n        return  !context.hasOwnProperty(key)\n            || context[key] === true;\n    },\n\n    deleteContext: function (contextId) {\n        delete this._caches[contextId];\n        this._context = {};\n    },\n\n    delete: function (key) {\n        delete this._context[key];\n    },\n\n    clearAll: function () {\n        this._caches = {};\n    },\n\n    getContext: function () {\n        return this._context;\n    },\n\n    eachContext : function (cb, context) {\n        var keys = Object.keys(this._caches);\n        keys.forEach(function (key) {\n            cb && cb.call(context, key);\n        });\n    },\n\n    miss: function (key) {\n        return ! this._context.hasOwnProperty(key);\n    }\n};\n\nCache.prototype.constructor = Cache;\n\nexport default Cache;\n","/**\n * Base class for all textures like compressed texture, texture2d, texturecube\n * TODO mapping\n */\nimport Base from './core/Base';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\n\n/**\n * @constructor\n * @alias clay.Texture\n * @extends clay.core.Base\n */\nvar Texture = Base.extend(\n/** @lends clay.Texture# */\n{\n    /**\n     * Texture width, readonly when the texture source is image\n     * @type {number}\n     */\n    width: 512,\n    /**\n     * Texture height, readonly when the texture source is image\n     * @type {number}\n     */\n    height: 512,\n    /**\n     * Texel data type.\n     * Possible values:\n     *  + {@link clay.Texture.UNSIGNED_BYTE}\n     *  + {@link clay.Texture.HALF_FLOAT}\n     *  + {@link clay.Texture.FLOAT}\n     *  + {@link clay.Texture.UNSIGNED_INT_24_8_WEBGL}\n     *  + {@link clay.Texture.UNSIGNED_INT}\n     * @type {number}\n     */\n    type: glenum.UNSIGNED_BYTE,\n    /**\n     * Format of texel data\n     * Possible values:\n     *  + {@link clay.Texture.RGBA}\n     *  + {@link clay.Texture.DEPTH_COMPONENT}\n     *  + {@link clay.Texture.DEPTH_STENCIL}\n     * @type {number}\n     */\n    format: glenum.RGBA,\n    /**\n     * Texture wrap. Default to be REPEAT.\n     * Possible values:\n     *  + {@link clay.Texture.CLAMP_TO_EDGE}\n     *  + {@link clay.Texture.REPEAT}\n     *  + {@link clay.Texture.MIRRORED_REPEAT}\n     * @type {number}\n     */\n    wrapS: glenum.REPEAT,\n    /**\n     * Texture wrap. Default to be REPEAT.\n     * Possible values:\n     *  + {@link clay.Texture.CLAMP_TO_EDGE}\n     *  + {@link clay.Texture.REPEAT}\n     *  + {@link clay.Texture.MIRRORED_REPEAT}\n     * @type {number}\n     */\n    wrapT: glenum.REPEAT,\n    /**\n     * Possible values:\n     *  + {@link clay.Texture.NEAREST}\n     *  + {@link clay.Texture.LINEAR}\n     *  + {@link clay.Texture.NEAREST_MIPMAP_NEAREST}\n     *  + {@link clay.Texture.LINEAR_MIPMAP_NEAREST}\n     *  + {@link clay.Texture.NEAREST_MIPMAP_LINEAR}\n     *  + {@link clay.Texture.LINEAR_MIPMAP_LINEAR}\n     * @type {number}\n     */\n    minFilter: glenum.LINEAR_MIPMAP_LINEAR,\n    /**\n     * Possible values:\n     *  + {@link clay.Texture.NEAREST}\n     *  + {@link clay.Texture.LINEAR}\n     * @type {number}\n     */\n    magFilter: glenum.LINEAR,\n    /**\n     * If enable mimap.\n     * @type {boolean}\n     */\n    useMipmap: true,\n\n    /**\n     * Anisotropic filtering, enabled if value is larger than 1\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/EXT_texture_filter_anisotropic\n     * @type {number}\n     */\n    anisotropic: 1,\n    // pixelStorei parameters, not available when texture is used as render target\n    // http://www.khronos.org/opengles/sdk/docs/man/xhtml/glPixelStorei.xml\n    /**\n     * If flip in y axis for given image source\n     * @type {boolean}\n     * @default true\n     */\n    flipY: true,\n    /**\n     * @type {number}\n     * @default 4\n     */\n    unpackAlignment: 4,\n    /**\n     * @type {boolean}\n     * @default false\n     */\n    premultiplyAlpha: false,\n\n    /**\n     * Dynamic option for texture like video\n     * @type {boolean}\n     */\n    dynamic: false,\n\n    NPOT: false\n}, function () {\n    this._cache = new Cache();\n},\n/** @lends clay.Texture.prototype */\n{\n\n    getWebGLTexture: function (renderer) {\n        var _gl = renderer.gl;\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n\n        if (cache.miss('webgl_texture')) {\n            // In a new gl context, create new texture and set dirty true\n            cache.put('webgl_texture', _gl.createTexture());\n        }\n        if (this.dynamic) {\n            this.update(renderer);\n        }\n        else if (cache.isDirty()) {\n            this.update(renderer);\n            cache.fresh();\n        }\n\n        return cache.get('webgl_texture');\n    },\n\n    bind: function () {},\n    unbind: function () {},\n\n    /**\n     * Mark texture is dirty and update in the next frame\n     */\n    dirty: function () {\n        if (this._cache) {\n            this._cache.dirtyAll();\n        }\n    },\n\n    update: function (renderer) {},\n\n    // Update the common parameters of texture\n    updateCommon: function (renderer) {\n        var _gl = renderer.gl;\n        _gl.pixelStorei(_gl.UNPACK_FLIP_Y_WEBGL, this.flipY);\n        _gl.pixelStorei(_gl.UNPACK_PREMULTIPLY_ALPHA_WEBGL, this.premultiplyAlpha);\n        _gl.pixelStorei(_gl.UNPACK_ALIGNMENT, this.unpackAlignment);\n\n        // Use of none-power of two texture\n        // http://www.khronos.org/webgl/wiki/WebGL_and_OpenGL_Differences\n        if (this.format === glenum.DEPTH_COMPONENT) {\n            this.useMipmap = false;\n        }\n\n        var sRGBExt = renderer.getGLExtension('EXT_sRGB');\n        // Fallback\n        if (this.format === Texture.SRGB && !sRGBExt) {\n            this.format = Texture.RGB;\n        }\n        if (this.format === Texture.SRGB_ALPHA && !sRGBExt) {\n            this.format = Texture.RGBA;\n        }\n\n        this.NPOT = !this.isPowerOfTwo();\n    },\n\n    getAvailableWrapS: function () {\n        if (this.NPOT) {\n            return glenum.CLAMP_TO_EDGE;\n        }\n        return this.wrapS;\n    },\n    getAvailableWrapT: function () {\n        if (this.NPOT) {\n            return glenum.CLAMP_TO_EDGE;\n        }\n        return this.wrapT;\n    },\n    getAvailableMinFilter: function () {\n        var minFilter = this.minFilter;\n        if (this.NPOT || !this.useMipmap) {\n            if (minFilter == glenum.NEAREST_MIPMAP_NEAREST ||\n                minFilter == glenum.NEAREST_MIPMAP_LINEAR\n            ) {\n                return glenum.NEAREST;\n            }\n            else if (minFilter == glenum.LINEAR_MIPMAP_LINEAR ||\n                minFilter == glenum.LINEAR_MIPMAP_NEAREST\n            ) {\n                return glenum.LINEAR;\n            }\n            else {\n                return minFilter;\n            }\n        }\n        else {\n            return minFilter;\n        }\n    },\n    getAvailableMagFilter: function () {\n        return this.magFilter;\n    },\n\n    nextHighestPowerOfTwo: function (x) {\n        --x;\n        for (var i = 1; i < 32; i <<= 1) {\n            x = x | x >> i;\n        }\n        return x + 1;\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n\n        var webglTexture = cache.get('webgl_texture');\n        if (webglTexture){\n            renderer.gl.deleteTexture(webglTexture);\n        }\n        cache.deleteContext(renderer.__uid__);\n\n    },\n    /**\n     * Test if image of texture is valid and loaded.\n     * @return {boolean}\n     */\n    isRenderable: function () {},\n\n    /**\n     * Test if texture size is power of two\n     * @return {boolean}\n     */\n    isPowerOfTwo: function () {}\n});\n\nObject.defineProperty(Texture.prototype, 'width', {\n    get: function () {\n        return this._width;\n    },\n    set: function (value) {\n        this._width = value;\n    }\n});\nObject.defineProperty(Texture.prototype, 'height', {\n    get: function () {\n        return this._height;\n    },\n    set: function (value) {\n        this._height = value;\n    }\n});\n\n/* DataType */\n\n/**\n * @type {number}\n */\nTexture.BYTE = glenum.BYTE;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_BYTE = glenum.UNSIGNED_BYTE;\n/**\n * @type {number}\n */\nTexture.SHORT = glenum.SHORT;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_SHORT = glenum.UNSIGNED_SHORT;\n/**\n * @type {number}\n */\nTexture.INT = glenum.INT;\n/**\n * @type {number}\n */\nTexture.UNSIGNED_INT = glenum.UNSIGNED_INT;\n/**\n * @type {number}\n */\nTexture.FLOAT = glenum.FLOAT;\n/**\n * @type {number}\n */\nTexture.HALF_FLOAT = 0x8D61;\n\n/**\n * UNSIGNED_INT_24_8_WEBGL for WEBGL_depth_texture extension\n * @type {number}\n */\nTexture.UNSIGNED_INT_24_8_WEBGL = 34042;\n\n/* PixelFormat */\n/**\n * @type {number}\n */\nTexture.DEPTH_COMPONENT = glenum.DEPTH_COMPONENT;\n/**\n * @type {number}\n */\nTexture.DEPTH_STENCIL = glenum.DEPTH_STENCIL;\n/**\n * @type {number}\n */\nTexture.ALPHA = glenum.ALPHA;\n/**\n * @type {number}\n */\nTexture.RGB = glenum.RGB;\n/**\n * @type {number}\n */\nTexture.RGBA = glenum.RGBA;\n/**\n * @type {number}\n */\nTexture.LUMINANCE = glenum.LUMINANCE;\n/**\n * @type {number}\n */\nTexture.LUMINANCE_ALPHA = glenum.LUMINANCE_ALPHA;\n\n/**\n * @see https://www.khronos.org/registry/webgl/extensions/EXT_sRGB/\n * @type {number}\n */\nTexture.SRGB = 0x8C40;\n/**\n * @see https://www.khronos.org/registry/webgl/extensions/EXT_sRGB/\n * @type {number}\n */\nTexture.SRGB_ALPHA = 0x8C42;\n\n/* Compressed Texture */\nTexture.COMPRESSED_RGB_S3TC_DXT1_EXT = 0x83F0;\nTexture.COMPRESSED_RGBA_S3TC_DXT1_EXT = 0x83F1;\nTexture.COMPRESSED_RGBA_S3TC_DXT3_EXT = 0x83F2;\nTexture.COMPRESSED_RGBA_S3TC_DXT5_EXT = 0x83F3;\n\n/* TextureMagFilter */\n/**\n * @type {number}\n */\nTexture.NEAREST = glenum.NEAREST;\n/**\n * @type {number}\n */\nTexture.LINEAR = glenum.LINEAR;\n\n/* TextureMinFilter */\n/**\n * @type {number}\n */\nTexture.NEAREST_MIPMAP_NEAREST = glenum.NEAREST_MIPMAP_NEAREST;\n/**\n * @type {number}\n */\nTexture.LINEAR_MIPMAP_NEAREST = glenum.LINEAR_MIPMAP_NEAREST;\n/**\n * @type {number}\n */\nTexture.NEAREST_MIPMAP_LINEAR = glenum.NEAREST_MIPMAP_LINEAR;\n/**\n * @type {number}\n */\nTexture.LINEAR_MIPMAP_LINEAR = glenum.LINEAR_MIPMAP_LINEAR;\n\n/* TextureWrapMode */\n/**\n * @type {number}\n */\nTexture.REPEAT = glenum.REPEAT;\n/**\n * @type {number}\n */\nTexture.CLAMP_TO_EDGE = glenum.CLAMP_TO_EDGE;\n/**\n * @type {number}\n */\nTexture.MIRRORED_REPEAT = glenum.MIRRORED_REPEAT;\n\n\nexport default Texture;\n","/**\n * Simple double linked list. Compared with array, it has O(1) remove operation.\n * @constructor\n * @alias clay.core.LinkedList\n */\nvar LinkedList = function () {\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.head = null;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.tail = null;\n\n    this._length = 0;\n};\n\n/**\n * Insert a new value at the tail\n * @param  {} val\n * @return {clay.core.LinkedList.Entry}\n */\nLinkedList.prototype.insert = function (val) {\n    var entry = new LinkedList.Entry(val);\n    this.insertEntry(entry);\n    return entry;\n};\n\n/**\n * Insert a new value at idx\n * @param {number} idx\n * @param  {} val\n * @return {clay.core.LinkedList.Entry}\n */\nLinkedList.prototype.insertAt = function (idx, val) {\n    if (idx < 0) {\n        return;\n    }\n    var next = this.head;\n    var cursor = 0;\n    while (next && cursor != idx) {\n        next = next.next;\n        cursor++;\n    }\n    if (next) {\n        var entry = new LinkedList.Entry(val);\n        var prev = next.prev;\n        if (!prev) { //next is head\n            this.head = entry;\n        }\n        else {\n            prev.next = entry;\n            entry.prev = prev;\n        }\n        entry.next = next;\n        next.prev = entry;\n    }\n    else {\n        this.insert(val);\n    }\n};\n\nLinkedList.prototype.insertBeforeEntry = function (val, next) {\n    var entry = new LinkedList.Entry(val);\n    var prev = next.prev;\n    if (!prev) { //next is head\n        this.head = entry;\n    }\n    else {\n        prev.next = entry;\n        entry.prev = prev;\n    }\n    entry.next = next;\n    next.prev = entry;\n\n    this._length++;\n};\n\n/**\n * Insert an entry at the tail\n * @param  {clay.core.LinkedList.Entry} entry\n */\nLinkedList.prototype.insertEntry = function (entry) {\n    if (!this.head) {\n        this.head = this.tail = entry;\n    }\n    else {\n        this.tail.next = entry;\n        entry.prev = this.tail;\n        this.tail = entry;\n    }\n    this._length++;\n};\n\n/**\n * Remove entry.\n * @param  {clay.core.LinkedList.Entry} entry\n */\nLinkedList.prototype.remove = function (entry) {\n    var prev = entry.prev;\n    var next = entry.next;\n    if (prev) {\n        prev.next = next;\n    }\n    else {\n        // Is head\n        this.head = next;\n    }\n    if (next) {\n        next.prev = prev;\n    }\n    else {\n        // Is tail\n        this.tail = prev;\n    }\n    entry.next = entry.prev = null;\n    this._length--;\n};\n\n/**\n * Remove entry at index.\n * @param  {number} idx\n * @return {}\n */\nLinkedList.prototype.removeAt = function (idx) {\n    if (idx < 0) {\n        return;\n    }\n    var curr = this.head;\n    var cursor = 0;\n    while (curr && cursor != idx) {\n        curr = curr.next;\n        cursor++;\n    }\n    if (curr) {\n        this.remove(curr);\n        return curr.value;\n    }\n};\n/**\n * Get head value\n * @return {}\n */\nLinkedList.prototype.getHead = function () {\n    if (this.head) {\n        return this.head.value;\n    }\n};\n/**\n * Get tail value\n * @return {}\n */\nLinkedList.prototype.getTail = function () {\n    if (this.tail) {\n        return this.tail.value;\n    }\n};\n/**\n * Get value at idx\n * @param {number} idx\n * @return {}\n */\nLinkedList.prototype.getAt = function (idx) {\n    if (idx < 0) {\n        return;\n    }\n    var curr = this.head;\n    var cursor = 0;\n    while (curr && cursor != idx) {\n        curr = curr.next;\n        cursor++;\n    }\n    return curr.value;\n};\n\n/**\n * @param  {} value\n * @return {number}\n */\nLinkedList.prototype.indexOf = function (value) {\n    var curr = this.head;\n    var cursor = 0;\n    while (curr) {\n        if (curr.value === value) {\n            return cursor;\n        }\n        curr = curr.next;\n        cursor++;\n    }\n};\n\n/**\n * @return {number}\n */\nLinkedList.prototype.length = function () {\n    return this._length;\n};\n\n/**\n * If list is empty\n */\nLinkedList.prototype.isEmpty = function () {\n    return this._length === 0;\n};\n\n/**\n * @param  {Function} cb\n * @param  {} context\n */\nLinkedList.prototype.forEach = function (cb, context) {\n    var curr = this.head;\n    var idx = 0;\n    var haveContext = typeof(context) != 'undefined';\n    while (curr) {\n        if (haveContext) {\n            cb.call(context, curr.value, idx);\n        }\n        else {\n            cb(curr.value, idx);\n        }\n        curr = curr.next;\n        idx++;\n    }\n};\n\n/**\n * Clear the list\n */\nLinkedList.prototype.clear = function () {\n    this.tail = this.head = null;\n    this._length = 0;\n};\n\n/**\n * @constructor\n * @param {} val\n */\nLinkedList.Entry = function (val) {\n    /**\n     * @type {}\n     */\n    this.value = val;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.next = null;\n\n    /**\n     * @type {clay.core.LinkedList.Entry}\n     */\n    this.prev = null;\n};\n\nexport default LinkedList;\n","import LinkedList from './LinkedList';\n\n/**\n * LRU Cache\n * @constructor\n * @alias clay.core.LRU\n */\nvar LRU = function(maxSize) {\n\n    this._list = new LinkedList();\n\n    this._map = {};\n\n    this._maxSize = maxSize || 10;\n};\n\n/**\n * Set cache max size\n * @param {number} size\n */\nLRU.prototype.setMaxSize = function(size) {\n    this._maxSize = size;\n};\n\n/**\n * @param  {string} key\n * @param  {} value\n */\nLRU.prototype.put = function(key, value) {\n    if (typeof(this._map[key]) == 'undefined') {\n        var len = this._list.length();\n        if (len >= this._maxSize && len > 0) {\n            // Remove the least recently used\n            var leastUsedEntry = this._list.head;\n            this._list.remove(leastUsedEntry);\n            delete this._map[leastUsedEntry.key];\n        }\n\n        var entry = this._list.insert(value);\n        entry.key = key;\n        this._map[key] = entry;\n    }\n};\n\n/**\n * @param  {string} key\n * @return {}\n */\nLRU.prototype.get = function(key) {\n    var entry = this._map[key];\n    if (typeof(entry) != 'undefined') {\n        // Put the latest used entry in the tail\n        if (entry !== this._list.tail) {\n            this._list.remove(entry);\n            this._list.insertEntry(entry);\n        }\n\n        return entry.value;\n    }\n};\n\n/**\n * @param {string} key\n */\nLRU.prototype.remove = function(key) {\n    var entry = this._map[key];\n    if (typeof(entry) != 'undefined') {\n        delete this._map[key];\n        this._list.remove(entry);\n    }\n};\n\n/**\n * Clear the cache\n */\nLRU.prototype.clear = function() {\n    this._list.clear();\n    this._map = {};\n};\n\nexport default LRU;\n","import LRU from '../core/LRU';\n\nvar colorUtil = {};\n\nvar kCSSColorTable = {\n    'transparent': [0,0,0,0], 'aliceblue': [240,248,255,1],\n    'antiquewhite': [250,235,215,1], 'aqua': [0,255,255,1],\n    'aquamarine': [127,255,212,1], 'azure': [240,255,255,1],\n    'beige': [245,245,220,1], 'bisque': [255,228,196,1],\n    'black': [0,0,0,1], 'blanchedalmond': [255,235,205,1],\n    'blue': [0,0,255,1], 'blueviolet': [138,43,226,1],\n    'brown': [165,42,42,1], 'burlywood': [222,184,135,1],\n    'cadetblue': [95,158,160,1], 'chartreuse': [127,255,0,1],\n    'chocolate': [210,105,30,1], 'coral': [255,127,80,1],\n    'cornflowerblue': [100,149,237,1], 'cornsilk': [255,248,220,1],\n    'crimson': [220,20,60,1], 'cyan': [0,255,255,1],\n    'darkblue': [0,0,139,1], 'darkcyan': [0,139,139,1],\n    'darkgoldenrod': [184,134,11,1], 'darkgray': [169,169,169,1],\n    'darkgreen': [0,100,0,1], 'darkgrey': [169,169,169,1],\n    'darkkhaki': [189,183,107,1], 'darkmagenta': [139,0,139,1],\n    'darkolivegreen': [85,107,47,1], 'darkorange': [255,140,0,1],\n    'darkorchid': [153,50,204,1], 'darkred': [139,0,0,1],\n    'darksalmon': [233,150,122,1], 'darkseagreen': [143,188,143,1],\n    'darkslateblue': [72,61,139,1], 'darkslategray': [47,79,79,1],\n    'darkslategrey': [47,79,79,1], 'darkturquoise': [0,206,209,1],\n    'darkviolet': [148,0,211,1], 'deeppink': [255,20,147,1],\n    'deepskyblue': [0,191,255,1], 'dimgray': [105,105,105,1],\n    'dimgrey': [105,105,105,1], 'dodgerblue': [30,144,255,1],\n    'firebrick': [178,34,34,1], 'floralwhite': [255,250,240,1],\n    'forestgreen': [34,139,34,1], 'fuchsia': [255,0,255,1],\n    'gainsboro': [220,220,220,1], 'ghostwhite': [248,248,255,1],\n    'gold': [255,215,0,1], 'goldenrod': [218,165,32,1],\n    'gray': [128,128,128,1], 'green': [0,128,0,1],\n    'greenyellow': [173,255,47,1], 'grey': [128,128,128,1],\n    'honeydew': [240,255,240,1], 'hotpink': [255,105,180,1],\n    'indianred': [205,92,92,1], 'indigo': [75,0,130,1],\n    'ivory': [255,255,240,1], 'khaki': [240,230,140,1],\n    'lavender': [230,230,250,1], 'lavenderblush': [255,240,245,1],\n    'lawngreen': [124,252,0,1], 'lemonchiffon': [255,250,205,1],\n    'lightblue': [173,216,230,1], 'lightcoral': [240,128,128,1],\n    'lightcyan': [224,255,255,1], 'lightgoldenrodyellow': [250,250,210,1],\n    'lightgray': [211,211,211,1], 'lightgreen': [144,238,144,1],\n    'lightgrey': [211,211,211,1], 'lightpink': [255,182,193,1],\n    'lightsalmon': [255,160,122,1], 'lightseagreen': [32,178,170,1],\n    'lightskyblue': [135,206,250,1], 'lightslategray': [119,136,153,1],\n    'lightslategrey': [119,136,153,1], 'lightsteelblue': [176,196,222,1],\n    'lightyellow': [255,255,224,1], 'lime': [0,255,0,1],\n    'limegreen': [50,205,50,1], 'linen': [250,240,230,1],\n    'magenta': [255,0,255,1], 'maroon': [128,0,0,1],\n    'mediumaquamarine': [102,205,170,1], 'mediumblue': [0,0,205,1],\n    'mediumorchid': [186,85,211,1], 'mediumpurple': [147,112,219,1],\n    'mediumseagreen': [60,179,113,1], 'mediumslateblue': [123,104,238,1],\n    'mediumspringgreen': [0,250,154,1], 'mediumturquoise': [72,209,204,1],\n    'mediumvioletred': [199,21,133,1], 'midnightblue': [25,25,112,1],\n    'mintcream': [245,255,250,1], 'mistyrose': [255,228,225,1],\n    'moccasin': [255,228,181,1], 'navajowhite': [255,222,173,1],\n    'navy': [0,0,128,1], 'oldlace': [253,245,230,1],\n    'olive': [128,128,0,1], 'olivedrab': [107,142,35,1],\n    'orange': [255,165,0,1], 'orangered': [255,69,0,1],\n    'orchid': [218,112,214,1], 'palegoldenrod': [238,232,170,1],\n    'palegreen': [152,251,152,1], 'paleturquoise': [175,238,238,1],\n    'palevioletred': [219,112,147,1], 'papayawhip': [255,239,213,1],\n    'peachpuff': [255,218,185,1], 'peru': [205,133,63,1],\n    'pink': [255,192,203,1], 'plum': [221,160,221,1],\n    'powderblue': [176,224,230,1], 'purple': [128,0,128,1],\n    'red': [255,0,0,1], 'rosybrown': [188,143,143,1],\n    'royalblue': [65,105,225,1], 'saddlebrown': [139,69,19,1],\n    'salmon': [250,128,114,1], 'sandybrown': [244,164,96,1],\n    'seagreen': [46,139,87,1], 'seashell': [255,245,238,1],\n    'sienna': [160,82,45,1], 'silver': [192,192,192,1],\n    'skyblue': [135,206,235,1], 'slateblue': [106,90,205,1],\n    'slategray': [112,128,144,1], 'slategrey': [112,128,144,1],\n    'snow': [255,250,250,1], 'springgreen': [0,255,127,1],\n    'steelblue': [70,130,180,1], 'tan': [210,180,140,1],\n    'teal': [0,128,128,1], 'thistle': [216,191,216,1],\n    'tomato': [255,99,71,1], 'turquoise': [64,224,208,1],\n    'violet': [238,130,238,1], 'wheat': [245,222,179,1],\n    'white': [255,255,255,1], 'whitesmoke': [245,245,245,1],\n    'yellow': [255,255,0,1], 'yellowgreen': [154,205,50,1]\n};\n\nfunction clampCssByte(i) {  // Clamp to integer 0 .. 255.\n    i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n    return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clampCssAngle(i) {  // Clamp to integer 0 .. 360.\n    i = Math.round(i);  // Seems to be what Chrome does (vs truncation).\n    return i < 0 ? 0 : i > 360 ? 360 : i;\n}\n\nfunction clampCssFloat(f) {  // Clamp to float 0.0 .. 1.0.\n    return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parseCssInt(str) {  // int or percentage.\n    if (str.length && str.charAt(str.length - 1) === '%') {\n        return clampCssByte(parseFloat(str) / 100 * 255);\n    }\n    return clampCssByte(parseInt(str, 10));\n}\n\nfunction parseCssFloat(str) {  // float or percentage.\n    if (str.length && str.charAt(str.length - 1) === '%') {\n        return clampCssFloat(parseFloat(str) / 100);\n    }\n    return clampCssFloat(parseFloat(str));\n}\n\nfunction cssHueToRgb(m1, m2, h) {\n    if (h < 0) {\n        h += 1;\n    }\n    else if (h > 1) {\n        h -= 1;\n    }\n\n    if (h * 6 < 1) {\n        return m1 + (m2 - m1) * h * 6;\n    }\n    if (h * 2 < 1) {\n        return m2;\n    }\n    if (h * 3 < 2) {\n        return m1 + (m2 - m1) * (2/3 - h) * 6;\n    }\n    return m1;\n}\n\nfunction lerpNumber(a, b, p) {\n    return a + (b - a) * p;\n}\n\nfunction setRgba(out, r, g, b, a) {\n    out[0] = r; out[1] = g; out[2] = b; out[3] = a;\n    return out;\n}\nfunction copyRgba(out, a) {\n    out[0] = a[0]; out[1] = a[1]; out[2] = a[2]; out[3] = a[3];\n    return out;\n}\n\nvar colorCache = new LRU(20);\nvar lastRemovedArr = null;\n\nfunction putToCache(colorStr, rgbaArr) {\n    // Reuse removed array\n    if (lastRemovedArr) {\n        copyRgba(lastRemovedArr, rgbaArr);\n    }\n    lastRemovedArr = colorCache.put(colorStr, lastRemovedArr || (rgbaArr.slice()));\n}\n\n/**\n * @param {string} colorStr\n * @param {Array.<number>} out\n * @return {Array.<number>}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.parse = function (colorStr, rgbaArr) {\n    if (!colorStr) {\n        return;\n    }\n    rgbaArr = rgbaArr || [];\n\n    var cached = colorCache.get(colorStr);\n    if (cached) {\n        return copyRgba(rgbaArr, cached);\n    }\n\n    // colorStr may be not string\n    colorStr = colorStr + '';\n    // Remove all whitespace, not compliant, but should just be more accepting.\n    var str = colorStr.replace(/ /g, '').toLowerCase();\n\n    // Color keywords (and transparent) lookup.\n    if (str in kCSSColorTable) {\n        copyRgba(rgbaArr, kCSSColorTable[str]);\n        putToCache(colorStr, rgbaArr);\n        return rgbaArr;\n    }\n\n    // #abc and #abc123 syntax.\n    if (str.charAt(0) === '#') {\n        if (str.length === 4) {\n            var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n            if (!(iv >= 0 && iv <= 0xfff)) {\n                setRgba(rgbaArr, 0, 0, 0, 1);\n                return;  // Covers NaN.\n            }\n            setRgba(rgbaArr,\n                ((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n                (iv & 0xf0) | ((iv & 0xf0) >> 4),\n                (iv & 0xf) | ((iv & 0xf) << 4),\n                1\n            );\n            putToCache(colorStr, rgbaArr);\n            return rgbaArr;\n        }\n        else if (str.length === 7) {\n            var iv = parseInt(str.substr(1), 16);  // TODO(deanm): Stricter parsing.\n            if (!(iv >= 0 && iv <= 0xffffff)) {\n                setRgba(rgbaArr, 0, 0, 0, 1);\n                return;  // Covers NaN.\n            }\n            setRgba(rgbaArr,\n                (iv & 0xff0000) >> 16,\n                (iv & 0xff00) >> 8,\n                iv & 0xff,\n                1\n            );\n            putToCache(colorStr, rgbaArr);\n            return rgbaArr;\n        }\n\n        return;\n    }\n    var op = str.indexOf('('), ep = str.indexOf(')');\n    if (op !== -1 && ep + 1 === str.length) {\n        var fname = str.substr(0, op);\n        var params = str.substr(op + 1, ep - (op + 1)).split(',');\n        var alpha = 1;  // To allow case fallthrough.\n        switch (fname) {\n            case 'rgba':\n                if (params.length !== 4) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                alpha = parseCssFloat(params.pop()); // jshint ignore:line\n            // Fall through.\n            case 'rgb':\n                if (params.length !== 3) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                setRgba(rgbaArr,\n                    parseCssInt(params[0]),\n                    parseCssInt(params[1]),\n                    parseCssInt(params[2]),\n                    alpha\n                );\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            case 'hsla':\n                if (params.length !== 4) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                params[3] = parseCssFloat(params[3]);\n                hsla2rgba(params, rgbaArr);\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            case 'hsl':\n                if (params.length !== 3) {\n                    setRgba(rgbaArr, 0, 0, 0, 1);\n                    return;\n                }\n                hsla2rgba(params, rgbaArr);\n                putToCache(colorStr, rgbaArr);\n                return rgbaArr;\n            default:\n                return;\n        }\n    }\n\n    setRgba(rgbaArr, 0, 0, 0, 1);\n    return;\n};\n\ncolorUtil.parseToFloat = function (colorStr, rgbaArr) {\n    rgbaArr = colorUtil.parse(colorStr, rgbaArr);\n    if (!rgbaArr) {\n        return;\n    }\n    rgbaArr[0] /= 255;\n    rgbaArr[1] /= 255;\n    rgbaArr[2] /= 255;\n    return rgbaArr;\n}\n\n/**\n * @param {Array.<number>} hsla\n * @param {Array.<number>} rgba\n * @return {Array.<number>} rgba\n */\nfunction hsla2rgba(hsla, rgba) {\n    var h = (((parseFloat(hsla[0]) % 360) + 360) % 360) / 360;  // 0 .. 1\n    // NOTE(deanm): According to the CSS spec s/l should only be\n    // percentages, but we don't bother and let float or percentage.\n    var s = parseCssFloat(hsla[1]);\n    var l = parseCssFloat(hsla[2]);\n    var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n    var m1 = l * 2 - m2;\n\n    rgba = rgba || [];\n    setRgba(rgba,\n        clampCssByte(cssHueToRgb(m1, m2, h + 1 / 3) * 255),\n        clampCssByte(cssHueToRgb(m1, m2, h) * 255),\n        clampCssByte(cssHueToRgb(m1, m2, h - 1 / 3) * 255),\n        1\n    );\n\n    if (hsla.length === 4) {\n        rgba[3] = hsla[3];\n    }\n\n    return rgba;\n}\n\n/**\n * @param {Array.<number>} rgba\n * @return {Array.<number>} hsla\n */\nfunction rgba2hsla(rgba) {\n    if (!rgba) {\n        return;\n    }\n\n    // RGB from 0 to 255\n    var R = rgba[0] / 255;\n    var G = rgba[1] / 255;\n    var B = rgba[2] / 255;\n\n    var vMin = Math.min(R, G, B); // Min. value of RGB\n    var vMax = Math.max(R, G, B); // Max. value of RGB\n    var delta = vMax - vMin; // Delta RGB value\n\n    var L = (vMax + vMin) / 2;\n    var H;\n    var S;\n    // HSL results from 0 to 1\n    if (delta === 0) {\n        H = 0;\n        S = 0;\n    }\n    else {\n        if (L < 0.5) {\n            S = delta / (vMax + vMin);\n        }\n        else {\n            S = delta / (2 - vMax - vMin);\n        }\n\n        var deltaR = (((vMax - R) / 6) + (delta / 2)) / delta;\n        var deltaG = (((vMax - G) / 6) + (delta / 2)) / delta;\n        var deltaB = (((vMax - B) / 6) + (delta / 2)) / delta;\n\n        if (R === vMax) {\n            H = deltaB - deltaG;\n        }\n        else if (G === vMax) {\n            H = (1 / 3) + deltaR - deltaB;\n        }\n        else if (B === vMax) {\n            H = (2 / 3) + deltaG - deltaR;\n        }\n\n        if (H < 0) {\n            H += 1;\n        }\n\n        if (H > 1) {\n            H -= 1;\n        }\n    }\n\n    var hsla = [H * 360, S, L];\n\n    if (rgba[3] != null) {\n        hsla.push(rgba[3]);\n    }\n\n    return hsla;\n}\n\n/**\n * @param {string} color\n * @param {number} level\n * @return {string}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.lift = function (color, level) {\n    var colorArr = colorUtil.parse(color);\n    if (colorArr) {\n        for (var i = 0; i < 3; i++) {\n            if (level < 0) {\n                colorArr[i] = colorArr[i] * (1 - level) | 0;\n            }\n            else {\n                colorArr[i] = ((255 - colorArr[i]) * level + colorArr[i]) | 0;\n            }\n        }\n        return colorUtil.stringify(colorArr, colorArr.length === 4 ? 'rgba' : 'rgb');\n    }\n}\n\n/**\n * @param {string} color\n * @return {string}\n * @memberOf module:zrender/util/color\n */\ncolorUtil.toHex = function (color) {\n    var colorArr = colorUtil.parse(color);\n    if (colorArr) {\n        return ((1 << 24) + (colorArr[0] << 16) + (colorArr[1] << 8) + (+colorArr[2])).toString(16).slice(1);\n    }\n}\n\n/**\n * Map value to color. Faster than lerp methods because color is represented by rgba array.\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<Array.<number>>} colors List of rgba color array\n * @param {Array.<number>} [out] Mapped gba color array\n * @return {Array.<number>} will be null/undefined if input illegal.\n */\ncolorUtil.fastLerp = function (normalizedValue, colors, out) {\n    if (!(colors && colors.length)\n        || !(normalizedValue >= 0 && normalizedValue <= 1)\n    ) {\n        return;\n    }\n\n    out = out || [];\n\n    var value = normalizedValue * (colors.length - 1);\n    var leftIndex = Math.floor(value);\n    var rightIndex = Math.ceil(value);\n    var leftColor = colors[leftIndex];\n    var rightColor = colors[rightIndex];\n    var dv = value - leftIndex;\n    out[0] = clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv));\n    out[1] = clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv));\n    out[2] = clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv));\n    out[3] = clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv));\n\n    return out;\n}\n\n/**\n * @deprecated\n */\ncolorUtil.fastMapToColor = colorUtil.fastLerp;\n\n/**\n * @param {number} normalizedValue A float between 0 and 1.\n * @param {Array.<string>} colors Color list.\n * @param {boolean=} fullOutput Default false.\n * @return {(string|Object)} Result color. If fullOutput,\n *                           return {color: ..., leftIndex: ..., rightIndex: ..., value: ...},\n * @memberOf module:zrender/util/color\n */\ncolorUtil.lerp = function (normalizedValue, colors, fullOutput) {\n    if (!(colors && colors.length)\n        || !(normalizedValue >= 0 && normalizedValue <= 1)\n    ) {\n        return;\n    }\n\n    var value = normalizedValue * (colors.length - 1);\n    var leftIndex = Math.floor(value);\n    var rightIndex = Math.ceil(value);\n    var leftColor = colorUtil.parse(colors[leftIndex]);\n    var rightColor = colorUtil.parse(colors[rightIndex]);\n    var dv = value - leftIndex;\n\n    var color = colorUtil.stringify(\n        [\n            clampCssByte(lerpNumber(leftColor[0], rightColor[0], dv)),\n            clampCssByte(lerpNumber(leftColor[1], rightColor[1], dv)),\n            clampCssByte(lerpNumber(leftColor[2], rightColor[2], dv)),\n            clampCssFloat(lerpNumber(leftColor[3], rightColor[3], dv))\n        ],\n        'rgba'\n    );\n\n    return fullOutput\n        ? {\n            color: color,\n            leftIndex: leftIndex,\n            rightIndex: rightIndex,\n            value: value\n        }\n        : color;\n}\n\n/**\n * @deprecated\n */\ncolorUtil.mapToColor = colorUtil.lerp;\n\n/**\n * @param {string} color\n * @param {number=} h 0 ~ 360, ignore when null.\n * @param {number=} s 0 ~ 1, ignore when null.\n * @param {number=} l 0 ~ 1, ignore when null.\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\ncolorUtil.modifyHSL = function (color, h, s, l) {\n    color = colorUtil.parse(color);\n\n    if (color) {\n        color = rgba2hsla(color);\n        h != null && (color[0] = clampCssAngle(h));\n        s != null && (color[1] = parseCssFloat(s));\n        l != null && (color[2] = parseCssFloat(l));\n\n        return colorUtil.stringify(hsla2rgba(color), 'rgba');\n    }\n}\n\n/**\n * @param {string} color\n * @param {number=} alpha 0 ~ 1\n * @return {string} Color string in rgba format.\n * @memberOf module:zrender/util/color\n */\ncolorUtil.modifyAlpha = function (color, alpha) {\n    color = colorUtil.parse(color);\n\n    if (color && alpha != null) {\n        color[3] = clampCssFloat(alpha);\n        return colorUtil.stringify(color, 'rgba');\n    }\n}\n\n/**\n * @param {Array.<number>} arrColor like [12,33,44,0.4]\n * @param {string} type 'rgba', 'hsva', ...\n * @return {string} Result color. (If input illegal, return undefined).\n */\ncolorUtil.stringify = function (arrColor, type) {\n    if (!arrColor || !arrColor.length) {\n        return;\n    }\n    var colorStr = arrColor[0] + ',' + arrColor[1] + ',' + arrColor[2];\n    if (type === 'rgba' || type === 'hsva' || type === 'hsla') {\n        colorStr += ',' + arrColor[3];\n    }\n    return type + '(' + colorStr + ')';\n};\n\n\n\nexport default colorUtil;","import Base from './core/Base';\nimport Texture from './Texture';\nimport util from './core/util';\nimport colorUtil from './core/color';\nvar parseColor = colorUtil.parseToFloat;\n\nvar programKeyCache = {};\n\nfunction getDefineCode(defines, lightsNumbers, enabledTextures) {\n    var defineKeys = Object.keys(defines);\n    defineKeys.sort();\n    var defineStr = [];\n    // Custom Defines\n    for (var i = 0; i < defineKeys.length; i++) {\n        var key = defineKeys[i];\n        var value = defines[key];\n        if (value === null) {\n            defineStr.push(key);\n        }\n        else{\n            defineStr.push(key + ' ' + value.toString());\n        }\n    }\n    return defineStr.join('\\n');\n}\n\nfunction getProgramKey(vertexDefines, fragmentDefines, enabledTextures) {\n    enabledTextures.sort();\n    var defineStr = [];\n    for (var i = 0; i < enabledTextures.length; i++) {\n        var symbol = enabledTextures[i];\n        defineStr.push(symbol);\n    }\n    var key = getDefineCode(vertexDefines) + '\\n'\n        + getDefineCode(fragmentDefines) + '\\n'\n        + defineStr.join('\\n');\n\n    if (programKeyCache[key]) {\n        return programKeyCache[key];\n    }\n\n    var id = util.genGUID();\n    programKeyCache[key] = id;\n    return id;\n}\n\n/**\n * @constructor clay.Material\n * @extends clay.core.Base\n */\nvar Material = Base.extend(function () {\n    return /** @lends clay.Material# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * @type {Object}\n         */\n        // uniforms: null,\n\n        /**\n         * @type {clay.Shader}\n         */\n        // shader: null,\n\n        /**\n         * @type {boolean}\n         */\n        depthTest: true,\n\n        /**\n         * @type {boolean}\n         */\n        depthMask: true,\n\n        /**\n         * @type {boolean}\n         */\n        transparent: false,\n        /**\n         * Blend func is a callback function when the material\n         * have custom blending\n         * The gl context will be the only argument passed in tho the\n         * blend function\n         * Detail of blend function in WebGL:\n         * http://www.khronos.org/registry/gles/specs/2.0/es_full_spec_2.0.25.pdf\n         *\n         * Example :\n         * function(_gl) {\n         *  _gl.blendEquation(_gl.FUNC_ADD);\n         *  _gl.blendFunc(_gl.SRC_ALPHA, _gl.ONE_MINUS_SRC_ALPHA);\n         * }\n         */\n        blend: null,\n\n        /**\n         * If update texture status automatically.\n         */\n        autoUpdateTextureStatus: true,\n\n        uniforms: {},\n        vertexDefines: {},\n        fragmentDefines: {},\n        _textureStatus: {},\n\n        // shadowTransparentMap : null\n\n        // PENDING enable the uniform that only used in shader.\n        _enabledUniforms: null,\n    };\n}, function () {\n    if (!this.name) {\n        this.name = 'MATERIAL_' + this.__uid__;\n    }\n\n    if (this.shader) {\n        // Keep status, mainly preset uniforms, vertexDefines and fragmentDefines\n        this.attachShader(this.shader, true);\n    }\n},\n/** @lends clay.Material.prototype */\n{\n    precision: 'highp',\n\n    bind: function(renderer, program, prevMaterial, prevProgram) {\n        var _gl = renderer.gl;\n        // PENDING Same texture in different material take different slot?\n\n        // May use shader of other material if shader code are same\n\n        // var sameProgram = prevProgram === program;\n\n        var currentTextureSlot = program.currentTextureSlot();\n\n        for (var u = 0; u < this._enabledUniforms.length; u++) {\n            var symbol = this._enabledUniforms[u];\n            var uniformValue = this.uniforms[symbol].value;\n            if (uniformValue instanceof Texture) {\n                // Reset slot\n                uniformValue.__slot = -1;\n            }\n            else if (Array.isArray(uniformValue)) {\n                for (var i = 0; i < uniformValue.length; i++) {\n                    if (uniformValue[i] instanceof Texture) {\n                        uniformValue[i].__slot = -1;\n                    }\n                }\n            }\n        }\n        // Set uniforms\n        for (var u = 0; u < this._enabledUniforms.length; u++) {\n            var symbol = this._enabledUniforms[u];\n            var uniform = this.uniforms[symbol];\n            var uniformValue = uniform.value;\n            // PENDING\n            // When binding two materials with the same shader\n            // Many uniforms will be be set twice even if they have the same value\n            // So add a evaluation to see if the uniform is really needed to be set\n            // if (prevMaterial && sameShader) {\n            //     if (prevMaterial.uniforms[symbol].value === uniformValue) {\n            //         continue;\n            //     }\n            // }\n\n            if (uniformValue === null) {\n                // FIXME Assume material with same shader have same order uniforms\n                // Or if different material use same textures,\n                // the slot will be different and still skipped because optimization\n                if (uniform.type === 't') {\n                    var slot = program.currentTextureSlot();\n                    var res = program.setUniform(_gl, '1i', symbol, slot);\n                    if (res) { // Texture is enabled\n                        // Still occupy the slot to make sure same texture in different materials have same slot.\n                        program.takeCurrentTextureSlot(renderer, null);\n                    }\n                }\n                continue;\n            }\n            else if (uniformValue instanceof Texture) {\n                if (uniformValue.__slot < 0) {\n                    var slot = program.currentTextureSlot();\n                    var res = program.setUniform(_gl, '1i', symbol, slot);\n                    if (!res) { // Texture uniform is not enabled\n                        continue;\n                    }\n                    program.takeCurrentTextureSlot(renderer, uniformValue);\n                    uniformValue.__slot = slot;\n                }\n                // Multiple uniform use same texture..\n                else {\n                    program.setUniform(_gl, '1i', symbol, uniformValue.__slot);\n                }\n            }\n            else if (Array.isArray(uniformValue)) {\n                if (uniformValue.length === 0) {\n                    continue;\n                }\n                // Texture Array\n                var exampleValue = uniformValue[0];\n\n                if (exampleValue instanceof Texture) {\n                    if (!program.hasUniform(symbol)) {\n                        continue;\n                    }\n\n                    var arr = [];\n                    for (var i = 0; i < uniformValue.length; i++) {\n                        var texture = uniformValue[i];\n\n                        if (texture.__slot < 0) {\n                            var slot = program.currentTextureSlot();\n                            arr.push(slot);\n                            program.takeCurrentTextureSlot(renderer, texture);\n                            texture.__slot = slot;\n                        }\n                        else {\n                            arr.push(texture.__slot);\n                        }\n                    }\n\n                    program.setUniform(_gl, '1iv', symbol, arr);\n                }\n                else {\n                    program.setUniform(_gl, uniform.type, symbol, uniformValue);\n                }\n            }\n            else{\n                program.setUniform(_gl, uniform.type, symbol, uniformValue);\n            }\n        }\n        // Texture slot maybe used out of material.\n        program.resetTextureSlot(currentTextureSlot);\n    },\n\n    /**\n     * Set material uniform\n     * @example\n     *  mat.setUniform('color', [1, 1, 1, 1]);\n     * @param {string} symbol\n     * @param {number|array|clay.Texture|ArrayBufferView} value\n     */\n    setUniform: function (symbol, value) {\n        if (value === undefined) {\n            console.warn('Uniform value \"' + symbol + '\" is undefined');\n        }\n        var uniform = this.uniforms[symbol];\n        if (uniform) {\n\n            if (typeof value === 'string') {\n                // Try to parse as a color. Invalid color string will return null.\n                value = parseColor(value) || value;\n            }\n\n            uniform.value = value;\n\n            if (this.autoUpdateTextureStatus && uniform.type === 't') {\n                if (value) {\n                    this.enableTexture(symbol);\n                }\n                else {\n                    this.disableTexture(symbol);\n                }\n            }\n        }\n    },\n\n    /**\n     * @param {Object} obj\n     */\n    setUniforms: function(obj) {\n        for (var key in obj) {\n            var val = obj[key];\n            this.setUniform(key, val);\n        }\n    },\n\n    // /**\n    //  * Enable a uniform\n    //  * It only have effect on the uniform exists in shader.\n    //  * @param  {string} symbol\n    //  */\n    // enableUniform: function (symbol) {\n    //     if (this.uniforms[symbol] && !this.isUniformEnabled(symbol)) {\n    //         this._enabledUniforms.push(symbol);\n    //     }\n    // },\n\n    // /**\n    //  * Disable a uniform\n    //  * It will not affect the uniform state in the shader. Because the shader uniforms is parsed from shader code with naive regex. When using micro to disable some uniforms in the shader. It will still try to set these uniforms in each rendering pass. We can disable these uniforms manually if we need this bit performance improvement. Mostly we can simply ignore it.\n    //  * @param  {string} symbol\n    //  */\n    // disableUniform: function (symbol) {\n    //     var idx = this._enabledUniforms.indexOf(symbol);\n    //     if (idx >= 0) {\n    //         this._enabledUniforms.splice(idx, 1);\n    //     }\n    // },\n\n    /**\n     * @param  {string}  symbol\n     * @return {boolean}\n     */\n    isUniformEnabled: function (symbol) {\n        return this._enabledUniforms.indexOf(symbol) >= 0;\n    },\n\n    getEnabledUniforms: function () {\n        return this._enabledUniforms;\n    },\n    getTextureUniforms: function () {\n        return this._textureUniforms;\n    },\n\n    /**\n     * Alias of setUniform and setUniforms\n     * @param {object|string} symbol\n     * @param {number|array|clay.Texture|ArrayBufferView} [value]\n     */\n    set: function (symbol, value) {\n        if (typeof(symbol) === 'object') {\n            for (var key in symbol) {\n                var val = symbol[key];\n                this.setUniform(key, val);\n            }\n        }\n        else {\n            this.setUniform(symbol, value);\n        }\n    },\n    /**\n     * Get uniform value\n     * @param  {string} symbol\n     * @return {number|array|clay.Texture|ArrayBufferView}\n     */\n    get: function (symbol) {\n        var uniform = this.uniforms[symbol];\n        if (uniform) {\n            return uniform.value;\n        }\n    },\n    /**\n     * Attach a shader instance\n     * @param  {clay.Shader} shader\n     * @param  {boolean} keepStatus If try to keep uniform and texture\n     */\n    attachShader: function(shader, keepStatus) {\n        var originalUniforms = this.uniforms;\n\n        // Ignore if uniform can use in shader.\n        this.uniforms = shader.createUniforms();\n        this.shader = shader;\n\n        var uniforms = this.uniforms;\n        this._enabledUniforms = Object.keys(uniforms);\n        // Make sure uniforms are set in same order to avoid texture slot wrong\n        this._enabledUniforms.sort();\n        this._textureUniforms = this._enabledUniforms.filter(function (uniformName) {\n            var type = this.uniforms[uniformName].type;\n            return type === 't' || type === 'tv';\n        }, this);\n\n        var originalVertexDefines = this.vertexDefines;\n        var originalFragmentDefines = this.fragmentDefines;\n\n        this.vertexDefines = util.clone(shader.vertexDefines);\n        this.fragmentDefines = util.clone(shader.fragmentDefines);\n\n        if (keepStatus) {\n            for (var symbol in originalUniforms) {\n                if (uniforms[symbol]) {\n                    uniforms[symbol].value = originalUniforms[symbol].value;\n                }\n            }\n\n            util.defaults(this.vertexDefines, originalVertexDefines);\n            util.defaults(this.fragmentDefines, originalFragmentDefines);\n        }\n\n        var textureStatus = {};\n        for (var key in shader.textures) {\n            textureStatus[key] = {\n                shaderType: shader.textures[key].shaderType,\n                type: shader.textures[key].type,\n                enabled: (keepStatus && this._textureStatus[key]) ? this._textureStatus[key].enabled : false\n            };\n        }\n\n        this._textureStatus = textureStatus;\n\n        this._programKey = '';\n    },\n\n    /**\n     * Clone a new material and keep uniforms, shader will not be cloned\n     * @return {clay.Material}\n     */\n    clone: function () {\n        var material = new this.constructor({\n            name: this.name,\n            shader: this.shader\n        });\n        for (var symbol in this.uniforms) {\n            material.uniforms[symbol].value = this.uniforms[symbol].value;\n        }\n        material.depthTest = this.depthTest;\n        material.depthMask = this.depthMask;\n        material.transparent = this.transparent;\n        material.blend = this.blend;\n\n        material.vertexDefines = util.clone(this.vertexDefines);\n        material.fragmentDefines = util.clone(this.fragmentDefines);\n        material.enableTexture(this.getEnabledTextures());\n        material.precision = this.precision;\n\n        return material;\n    },\n\n    /**\n     * Add a #define macro in shader code\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     * @param  {number} [val]\n     */\n    define: function (shaderType, symbol, val) {\n        var vertexDefines = this.vertexDefines;\n        var fragmentDefines = this.fragmentDefines;\n        if (shaderType !== 'vertex' && shaderType !== 'fragment' && shaderType !== 'both'\n            && arguments.length < 3\n        ) {\n            // shaderType default to be 'both'\n            val = symbol;\n            symbol = shaderType;\n            shaderType = 'both';\n        }\n        val = val != null ? val : null;\n        if (shaderType === 'vertex' || shaderType === 'both') {\n            if (vertexDefines[symbol] !== val) {\n                vertexDefines[symbol] = val;\n                // Mark as dirty\n                this._programKey = '';\n            }\n        }\n        if (shaderType === 'fragment' || shaderType === 'both') {\n            if (fragmentDefines[symbol] !== val) {\n                fragmentDefines[symbol] = val;\n                if (shaderType !== 'both') {\n                    this._programKey = '';\n                }\n            }\n        }\n    },\n\n    /**\n     * Remove a #define macro in shader code\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    undefine: function (shaderType, symbol) {\n        if (shaderType !== 'vertex' && shaderType !== 'fragment' && shaderType !== 'both'\n            && arguments.length < 2\n        ) {\n            // shaderType default to be 'both'\n            symbol = shaderType;\n            shaderType = 'both';\n        }\n        if (shaderType === 'vertex' || shaderType === 'both') {\n            if (this.isDefined('vertex', symbol)) {\n                delete this.vertexDefines[symbol];\n                // Mark as dirty\n                this._programKey = '';\n            }\n        }\n        if (shaderType === 'fragment' || shaderType === 'both') {\n            if (this.isDefined('fragment', symbol)) {\n                delete this.fragmentDefines[symbol];\n                if (shaderType !== 'both') {\n                    this._programKey = '';\n                }\n            }\n        }\n    },\n\n    /**\n     * If macro is defined in shader.\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    isDefined: function (shaderType, symbol) {\n        // PENDING hasOwnProperty ?\n        switch (shaderType) {\n            case 'vertex':\n                return this.vertexDefines[symbol] !== undefined;\n            case 'fragment':\n                return this.fragmentDefines[symbol] !== undefined;\n        }\n    },\n    /**\n     * Get macro value defined in shader.\n     * @param  {string} shaderType Can be vertex, fragment or both\n     * @param  {string} symbol\n     */\n    getDefine: function (shaderType, symbol) {\n        switch(shaderType) {\n            case 'vertex':\n                return this.vertexDefines[symbol];\n            case 'fragment':\n                return this.fragmentDefines[symbol];\n        }\n    },\n    /**\n     * Enable a texture, actually it will add a #define macro in the shader code\n     * For example, if texture symbol is diffuseMap, it will add a line `#define DIFFUSEMAP_ENABLED` in the shader code\n     * @param  {string} symbol\n     */\n    enableTexture: function (symbol) {\n        if (Array.isArray(symbol)) {\n            for (var i = 0; i < symbol.length; i++) {\n                this.enableTexture(symbol[i]);\n            }\n            return;\n        }\n\n        var status = this._textureStatus[symbol];\n        if (status) {\n            var isEnabled = status.enabled;\n            if (!isEnabled) {\n                status.enabled = true;\n                this._programKey = '';\n            }\n        }\n    },\n    /**\n     * Enable all textures used in the shader\n     */\n    enableTexturesAll: function () {\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            textureStatus[symbol].enabled = true;\n        }\n\n        this._programKey = '';\n    },\n    /**\n     * Disable a texture, it remove a #define macro in the shader\n     * @param  {string} symbol\n     */\n    disableTexture: function (symbol) {\n        if (Array.isArray(symbol)) {\n            for (var i = 0; i < symbol.length; i++) {\n                this.disableTexture(symbol[i]);\n            }\n            return;\n        }\n\n        var status = this._textureStatus[symbol];\n        if (status) {\n            var isDisabled = ! status.enabled;\n            if (!isDisabled) {\n                status.enabled = false;\n                this._programKey = '';\n            }\n        }\n    },\n    /**\n     * Disable all textures used in the shader\n     */\n    disableTexturesAll: function () {\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            textureStatus[symbol].enabled = false;\n        }\n\n        this._programKey = '';\n    },\n    /**\n     * If texture of given type is enabled.\n     * @param  {string}  symbol\n     * @return {boolean}\n     */\n    isTextureEnabled: function (symbol) {\n        var textureStatus = this._textureStatus;\n        return !!textureStatus[symbol]\n            && textureStatus[symbol].enabled;\n    },\n\n    /**\n     * Get all enabled textures\n     * @return {string[]}\n     */\n    getEnabledTextures: function () {\n        var enabledTextures = [];\n        var textureStatus = this._textureStatus;\n        for (var symbol in textureStatus) {\n            if (textureStatus[symbol].enabled) {\n                enabledTextures.push(symbol);\n            }\n        }\n        return enabledTextures;\n    },\n\n    /**\n     * Mark defines are updated.\n     */\n    dirtyDefines: function () {\n        this._programKey = '';\n    }\n});\n\nif (Object.defineProperty) {\n    Object.defineProperty(Material.prototype, 'shader', {\n        get: function () {\n            return this._shader || null;\n        },\n\n        set: function (val) {\n            // TODO\n            // console.warn('You need to use attachShader to set the shader.');\n            this._shader = val;\n        }\n    });\n\n    Object.defineProperty(Material.prototype, 'programKey', {\n        get: function () {\n            if (!this._programKey) {\n                this._programKey = getProgramKey(\n                    this.vertexDefines, this.fragmentDefines, this.getEnabledTextures()\n                );\n            }\n            return this._programKey;\n        }\n    });\n}\n\nexport default Material;\n","import vendor from '../core/vendor';\nimport Base from '../core/Base';\n\nvar SHADER_STATE_TO_ENABLE = 1;\nvar SHADER_STATE_KEEP_ENABLE = 2;\nvar SHADER_STATE_PENDING = 3;\n\n// Enable attribute operation is global to all programs\n// Here saved the list of all enabled attribute index\n// http://www.mjbshaw.com/2013/03/webgl-fixing-invalidoperation.html\nvar enabledAttributeList = {};\n\n// some util functions\nfunction addLineNumbers(string) {\n    var chunks = string.split('\\n');\n    for (var i = 0, il = chunks.length; i < il; i ++) {\n        // Chrome reports shader errors on lines\n        // starting counting from 1\n        chunks[i] = (i + 1) + ': ' + chunks[i];\n    }\n    return chunks.join('\\n');\n}\n\n// Return true or error msg if error happened\nfunction checkShaderErrorMsg(_gl, shader, shaderString) {\n    if (!_gl.getShaderParameter(shader, _gl.COMPILE_STATUS)) {\n        return [_gl.getShaderInfoLog(shader), addLineNumbers(shaderString)].join('\\n');\n    }\n}\n\nvar GLProgram = Base.extend({\n\n    uniformSemantics: {},\n    attributes: {}\n\n}, function () {\n    this._locations = {};\n\n    this._textureSlot = 0;\n\n    this._program = null;\n}, {\n\n    bind: function (renderer) {\n        this._textureSlot = 0;\n        renderer.gl.useProgram(this._program);\n    },\n\n    hasUniform: function (symbol) {\n        var location = this._locations[symbol];\n        return location !== null && location !== undefined;\n    },\n\n    useTextureSlot: function (renderer, texture, slot) {\n        if (texture) {\n            renderer.gl.activeTexture(renderer.gl.TEXTURE0 + slot);\n            // Maybe texture is not loaded yet;\n            if (texture.isRenderable()) {\n                texture.bind(renderer);\n            }\n            else {\n                // Bind texture to null\n                texture.unbind(renderer);\n            }\n        }\n    },\n\n    currentTextureSlot: function () {\n        return this._textureSlot;\n    },\n\n    resetTextureSlot: function (slot) {\n        this._textureSlot = slot || 0;\n    },\n\n    takeCurrentTextureSlot: function (renderer, texture) {\n        var textureSlot = this._textureSlot;\n\n        this.useTextureSlot(renderer, texture, textureSlot);\n\n        this._textureSlot++;\n\n        return textureSlot;\n    },\n\n    setUniform: function (_gl, type, symbol, value) {\n        var locationMap = this._locations;\n        var location = locationMap[symbol];\n        // Uniform is not existed in the shader\n        if (location === null || location === undefined) {\n            return false;\n        }\n        switch (type) {\n            case 'm4':\n                // The matrix must be created by glmatrix and can pass it directly.\n                _gl.uniformMatrix4fv(location, false, value);\n                break;\n            case '2i':\n                _gl.uniform2i(location, value[0], value[1]);\n                break;\n            case '2f':\n                _gl.uniform2f(location, value[0], value[1]);\n                break;\n            case '3i':\n                _gl.uniform3i(location, value[0], value[1], value[2]);\n                break;\n            case '3f':\n                _gl.uniform3f(location, value[0], value[1], value[2]);\n                break;\n            case '4i':\n                _gl.uniform4i(location, value[0], value[1], value[2], value[3]);\n                break;\n            case '4f':\n                _gl.uniform4f(location, value[0], value[1], value[2], value[3]);\n                break;\n            case '1i':\n                _gl.uniform1i(location, value);\n                break;\n            case '1f':\n                _gl.uniform1f(location, value);\n                break;\n            case '1fv':\n                _gl.uniform1fv(location, value);\n                break;\n            case '1iv':\n                _gl.uniform1iv(location, value);\n                break;\n            case '2iv':\n                _gl.uniform2iv(location, value);\n                break;\n            case '2fv':\n                _gl.uniform2fv(location, value);\n                break;\n            case '3iv':\n                _gl.uniform3iv(location, value);\n                break;\n            case '3fv':\n                _gl.uniform3fv(location, value);\n                break;\n            case '4iv':\n                _gl.uniform4iv(location, value);\n                break;\n            case '4fv':\n                _gl.uniform4fv(location, value);\n                break;\n            case 'm2':\n            case 'm2v':\n                _gl.uniformMatrix2fv(location, false, value);\n                break;\n            case 'm3':\n            case 'm3v':\n                _gl.uniformMatrix3fv(location, false, value);\n                break;\n            case 'm4v':\n                // Raw value\n                if (Array.isArray(value)) {\n                    var array = new vendor.Float32Array(value.length * 16);\n                    var cursor = 0;\n                    for (var i = 0; i < value.length; i++) {\n                        var item = value[i];\n                        for (var j = 0; j < 16; j++) {\n                            array[cursor++] = item[j];\n                        }\n                    }\n                    _gl.uniformMatrix4fv(location, false, array);\n                }\n                else if (value instanceof vendor.Float32Array) {   // ArrayBufferView\n                    _gl.uniformMatrix4fv(location, false, value);\n                }\n                break;\n        }\n        return true;\n    },\n\n    setUniformOfSemantic: function (_gl, semantic, val) {\n        var semanticInfo = this.uniformSemantics[semantic];\n        if (semanticInfo) {\n            return this.setUniform(_gl, semanticInfo.type, semanticInfo.symbol, val);\n        }\n        return false;\n    },\n\n    // Used for creating VAO\n    // Enable the attributes passed in and disable the rest\n    // Example Usage:\n    // enableAttributes(renderer, [\"position\", \"texcoords\"])\n    enableAttributes: function (renderer, attribList, vao) {\n        var _gl = renderer.gl;\n        var program = this._program;\n\n        var locationMap = this._locations;\n\n        var enabledAttributeListInContext;\n        if (vao) {\n            enabledAttributeListInContext = vao.__enabledAttributeList;\n        }\n        else {\n            enabledAttributeListInContext = enabledAttributeList[renderer.__uid__];\n        }\n        if (!enabledAttributeListInContext) {\n            // In vertex array object context\n            // PENDING Each vao object needs to enable attributes again?\n            if (vao) {\n                enabledAttributeListInContext\n                    = vao.__enabledAttributeList\n                    = [];\n            }\n            else {\n                enabledAttributeListInContext\n                    = enabledAttributeList[renderer.__uid__]\n                    = [];\n            }\n        }\n        var locationList = [];\n        for (var i = 0; i < attribList.length; i++) {\n            var symbol = attribList[i];\n            if (!this.attributes[symbol]) {\n                locationList[i] = -1;\n                continue;\n            }\n            var location = locationMap[symbol];\n            if (location == null) {\n                location = _gl.getAttribLocation(program, symbol);\n                // Attrib location is a number from 0 to ...\n                if (location === -1) {\n                    locationList[i] = -1;\n                    continue;\n                }\n                locationMap[symbol] = location;\n            }\n            locationList[i] = location;\n\n            if (!enabledAttributeListInContext[location]) {\n                enabledAttributeListInContext[location] = SHADER_STATE_TO_ENABLE;\n            }\n            else {\n                enabledAttributeListInContext[location] = SHADER_STATE_KEEP_ENABLE;\n            }\n        }\n\n        for (var i = 0; i < enabledAttributeListInContext.length; i++) {\n            switch(enabledAttributeListInContext[i]){\n                case SHADER_STATE_TO_ENABLE:\n                    _gl.enableVertexAttribArray(i);\n                    enabledAttributeListInContext[i] = SHADER_STATE_PENDING;\n                    break;\n                case SHADER_STATE_KEEP_ENABLE:\n                    enabledAttributeListInContext[i] = SHADER_STATE_PENDING;\n                    break;\n                // Expired\n                case SHADER_STATE_PENDING:\n                    _gl.disableVertexAttribArray(i);\n                    enabledAttributeListInContext[i] = 0;\n                    break;\n            }\n        }\n\n        return locationList;\n    },\n\n    buildProgram: function (_gl, shader, vertexShaderCode, fragmentShaderCode) {\n        var vertexShader = _gl.createShader(_gl.VERTEX_SHADER);\n        var program = _gl.createProgram();\n\n        _gl.shaderSource(vertexShader, vertexShaderCode);\n        _gl.compileShader(vertexShader);\n\n        var fragmentShader = _gl.createShader(_gl.FRAGMENT_SHADER);\n        _gl.shaderSource(fragmentShader, fragmentShaderCode);\n        _gl.compileShader(fragmentShader);\n\n        var msg = checkShaderErrorMsg(_gl, vertexShader, vertexShaderCode);\n        if (msg) {\n            return msg;\n        }\n        msg = checkShaderErrorMsg(_gl, fragmentShader, fragmentShaderCode);\n        if (msg) {\n            return msg;\n        }\n\n        _gl.attachShader(program, vertexShader);\n        _gl.attachShader(program, fragmentShader);\n        // Force the position bind to location 0;\n        if (shader.attributeSemantics['POSITION']) {\n            _gl.bindAttribLocation(program, 0, shader.attributeSemantics['POSITION'].symbol);\n        }\n        else {\n            // Else choose an attribute and bind to location 0;\n            var keys = Object.keys(this.attributes);\n            _gl.bindAttribLocation(program, 0, keys[0]);\n        }\n\n        _gl.linkProgram(program);\n\n        if (!_gl.getProgramParameter(program, _gl.LINK_STATUS)) {\n            return 'Could not link program\\n' + 'VALIDATE_STATUS: ' + _gl.getProgramParameter(program, _gl.VALIDATE_STATUS) + ', gl error [' + _gl.getError() + ']';\n        }\n\n        // Cache uniform locations\n        for (var i = 0; i < shader.uniforms.length; i++) {\n            var uniformSymbol = shader.uniforms[i];\n            this._locations[uniformSymbol] = _gl.getUniformLocation(program, uniformSymbol);\n        }\n\n        _gl.deleteShader(vertexShader);\n        _gl.deleteShader(fragmentShader);\n\n        this._program = program;\n\n        // Save code.\n        this.vertexCode = vertexShaderCode;\n        this.fragmentCode = fragmentShaderCode;\n    }\n});\n\nexport default GLProgram;","import GLProgram from './GLProgram';\n\nvar loopRegex = /for\\s*?\\(int\\s*?_idx_\\s*\\=\\s*([\\w-]+)\\;\\s*_idx_\\s*<\\s*([\\w-]+);\\s*_idx_\\s*\\+\\+\\s*\\)\\s*\\{\\{([\\s\\S]+?)(?=\\}\\})\\}\\}/g;\n\nfunction unrollLoop(shaderStr, defines, lightsNumbers) {\n    // Loop unroll from three.js, https://github.com/mrdoob/three.js/blob/master/src/renderers/webgl/WebGLProgram.js#L175\n    // In some case like shadowMap in loop use 'i' to index value much slower.\n\n    // Loop use _idx_ and increased with _idx_++ will be unrolled\n    // Use {{ }} to match the pair so the if statement will not be affected\n    // Write like following\n    // for (int _idx_ = 0; _idx_ < 4; _idx_++) {{\n    //     vec3 color = texture2D(textures[_idx_], uv).rgb;\n    // }}\n    function replace(match, start, end, snippet) {\n        var unroll = '';\n        // Try to treat as define\n        if (isNaN(start)) {\n            if (start in defines) {\n                start = defines[start];\n            }\n            else {\n                start = lightNumberDefines[start];\n            }\n        }\n        if (isNaN(end)) {\n            if (end in defines) {\n                end = defines[end];\n            }\n            else {\n                end = lightNumberDefines[end];\n            }\n        }\n        // TODO Error checking\n\n        for (var idx = parseInt(start); idx < parseInt(end); idx++) {\n            // PENDING Add scope?\n            unroll += '{'\n                + snippet\n                    .replace(/float\\s*\\(\\s*_idx_\\s*\\)/g, idx.toFixed(1))\n                    .replace(/_idx_/g, idx)\n            + '}';\n        }\n\n        return unroll;\n    }\n\n    var lightNumberDefines = {};\n    for (var lightType in lightsNumbers) {\n        lightNumberDefines[lightType + '_COUNT'] = lightsNumbers[lightType];\n    }\n    return shaderStr.replace(loopRegex, replace);\n}\n\nfunction getDefineCode(defines, lightsNumbers, enabledTextures) {\n    var defineStr = [];\n    if (lightsNumbers) {\n        for (var lightType in lightsNumbers) {\n            var count = lightsNumbers[lightType];\n            if (count > 0) {\n                defineStr.push('#define ' + lightType.toUpperCase() + '_COUNT ' + count);\n            }\n        }\n    }\n    if (enabledTextures) {\n        for (var i = 0; i < enabledTextures.length; i++) {\n            var symbol = enabledTextures[i];\n            defineStr.push('#define ' + symbol.toUpperCase() + '_ENABLED');\n        }\n    }\n    // Custom Defines\n    for (var symbol in defines) {\n        var value = defines[symbol];\n        if (value === null) {\n            defineStr.push('#define ' + symbol);\n        }\n        else{\n            defineStr.push('#define ' + symbol + ' ' + value.toString());\n        }\n    }\n    return defineStr.join('\\n');\n}\n\nfunction getExtensionCode(exts) {\n    // Extension declaration must before all non-preprocessor codes\n    // TODO vertex ? extension enum ?\n    var extensionStr = [];\n    for (var i = 0; i < exts.length; i++) {\n        extensionStr.push('#extension GL_' + exts[i] + ' : enable');\n    }\n    return extensionStr.join('\\n');\n}\n\nfunction getPrecisionCode(precision) {\n    return ['precision', precision, 'float'].join(' ') + ';\\n'\n        + ['precision', precision, 'int'].join(' ') + ';\\n'\n        // depth texture may have precision problem on iOS device.\n        + ['precision', precision, 'sampler2D'].join(' ') + ';\\n';\n}\n\nfunction ProgramManager(renderer) {\n    this._renderer = renderer;\n    this._cache = {};\n}\n\nProgramManager.prototype.getProgram = function (renderable, material, scene) {\n    var cache = this._cache;\n\n    var key = 's' + material.shader.shaderID + 'm' + material.programKey;\n    if (scene) {\n        key += 'se' + scene.getProgramKey(renderable.lightGroup);\n    }\n    if (renderable.isSkinnedMesh()) {\n        key += ',' + renderable.joints.length;\n    }\n    var program = cache[key];\n\n    if (program) {\n        return program;\n    }\n\n    var lightsNumbers = scene ? scene.getLightsNumbers(renderable.lightGroup) : {};\n    var renderer = this._renderer;\n    var _gl = renderer.gl;\n    var enabledTextures = material.getEnabledTextures();\n    var skinDefineCode = '';\n    if (renderable.isSkinnedMesh()) {\n        // TODO Add skinning code?\n        skinDefineCode = '\\n' + getDefineCode({\n            SKINNING: null,\n            JOINT_COUNT: renderable.joints.length\n        }) + '\\n';\n    }\n    // TODO Optimize key generation\n    // VERTEX\n    var vertexDefineStr = skinDefineCode + getDefineCode(material.vertexDefines, lightsNumbers, enabledTextures);\n    // FRAGMENT\n    var fragmentDefineStr = skinDefineCode + getDefineCode(material.fragmentDefines, lightsNumbers, enabledTextures);\n\n    var vertexCode = vertexDefineStr + '\\n' + material.shader.vertex;\n    var fragmentCode = getExtensionCode([\n            // TODO Not hard coded\n            'OES_standard_derivatives',\n            'EXT_shader_texture_lod'\n        ]) + '\\n'\n            + getPrecisionCode(material.precision) + '\\n'\n            + fragmentDefineStr + '\\n' + material.shader.fragment;\n\n    var finalVertexCode = unrollLoop(vertexCode, material.vertexDefines, lightsNumbers);\n    var finalFragmentCode = unrollLoop(fragmentCode, material.fragmentDefines, lightsNumbers);\n\n    var program = new GLProgram();\n    program.uniformSemantics = material.shader.uniformSemantics;\n    program.attributes = material.shader.attributes;\n    var errorMsg = program.buildProgram(_gl, material.shader, finalVertexCode, finalFragmentCode);\n    program.__error = errorMsg;\n\n    cache[key] = program;\n\n    return program;\n};\n\nexport default ProgramManager;","/**\n * Mainly do the parse and compile of shader string\n * Support shader code chunk import and export\n * Support shader semantics\n * http://www.nvidia.com/object/using_sas.html\n * https://github.com/KhronosGroup/collada2json/issues/45\n *\n * TODO: Use etpl or other string template engine\n */\nimport util from './core/util';\nimport vendor from './core/vendor';\nimport glMatrix from './dep/glmatrix';\nvar mat2 = glMatrix.mat2;\nvar mat3 = glMatrix.mat3;\nvar mat4 = glMatrix.mat4;\n\nvar uniformRegex = /uniform\\s+(bool|float|int|vec2|vec3|vec4|ivec2|ivec3|ivec4|mat2|mat3|mat4|sampler2D|samplerCube)\\s+([\\w\\,]+)?(\\[.*?\\])?\\s*(:\\s*([\\S\\s]+?))?;/g;\nvar attributeRegex = /attribute\\s+(float|int|vec2|vec3|vec4)\\s+(\\w*)\\s*(:\\s*(\\w+))?;/g;\nvar defineRegex = /#define\\s+(\\w+)?(\\s+[\\w-.]+)?\\s*;?\\s*\\n/g;\n\nvar uniformTypeMap = {\n    'bool': '1i',\n    'int': '1i',\n    'sampler2D': 't',\n    'samplerCube': 't',\n    'float': '1f',\n    'vec2': '2f',\n    'vec3': '3f',\n    'vec4': '4f',\n    'ivec2': '2i',\n    'ivec3': '3i',\n    'ivec4': '4i',\n    'mat2': 'm2',\n    'mat3': 'm3',\n    'mat4': 'm4'\n};\n\nvar uniformValueConstructor = {\n    'bool': function () {return true;},\n    'int': function () {return 0;},\n    'float': function () {return 0;},\n    'sampler2D': function () {return null;},\n    'samplerCube': function () {return null;},\n\n    'vec2': function () {return [0, 0];},\n    'vec3': function () {return [0, 0, 0];},\n    'vec4': function () {return [0, 0, 0, 0];},\n\n    'ivec2': function () {return [0, 0];},\n    'ivec3': function () {return [0, 0, 0];},\n    'ivec4': function () {return [0, 0, 0, 0];},\n\n    'mat2': function () {return mat2.create();},\n    'mat3': function () {return mat3.create();},\n    'mat4': function () {return mat4.create();},\n\n    'array': function () {return [];}\n};\n\nvar attributeSemantics = [\n    'POSITION',\n    'NORMAL',\n    'BINORMAL',\n    'TANGENT',\n    'TEXCOORD',\n    'TEXCOORD_0',\n    'TEXCOORD_1',\n    'COLOR',\n    // Skinning\n    // https://github.com/KhronosGroup/glTF/blob/master/specification/README.md#semantics\n    'JOINT',\n    'WEIGHT'\n];\nvar uniformSemantics = [\n    'SKIN_MATRIX',\n    // Information about viewport\n    'VIEWPORT_SIZE',\n    'VIEWPORT',\n    'DEVICEPIXELRATIO',\n    // Window size for window relative coordinate\n    // https://www.opengl.org/sdk/docs/man/html/gl_FragCoord.xhtml\n    'WINDOW_SIZE',\n    // Infomation about camera\n    'NEAR',\n    'FAR',\n    // Time\n    'TIME'\n];\nvar matrixSemantics = [\n    'WORLD',\n    'VIEW',\n    'PROJECTION',\n    'WORLDVIEW',\n    'VIEWPROJECTION',\n    'WORLDVIEWPROJECTION',\n    'WORLDINVERSE',\n    'VIEWINVERSE',\n    'PROJECTIONINVERSE',\n    'WORLDVIEWINVERSE',\n    'VIEWPROJECTIONINVERSE',\n    'WORLDVIEWPROJECTIONINVERSE',\n    'WORLDTRANSPOSE',\n    'VIEWTRANSPOSE',\n    'PROJECTIONTRANSPOSE',\n    'WORLDVIEWTRANSPOSE',\n    'VIEWPROJECTIONTRANSPOSE',\n    'WORLDVIEWPROJECTIONTRANSPOSE',\n    'WORLDINVERSETRANSPOSE',\n    'VIEWINVERSETRANSPOSE',\n    'PROJECTIONINVERSETRANSPOSE',\n    'WORLDVIEWINVERSETRANSPOSE',\n    'VIEWPROJECTIONINVERSETRANSPOSE',\n    'WORLDVIEWPROJECTIONINVERSETRANSPOSE'\n];\n\n\nvar shaderIDCache = {};\nvar shaderCodeCache = {};\n\nfunction getShaderID(vertex, fragment) {\n    var key = 'vertex:' + vertex + 'fragment:' + fragment;\n    if (shaderIDCache[key]) {\n        return shaderIDCache[key];\n    }\n    var id = util.genGUID();\n    shaderIDCache[key] = id;\n\n    shaderCodeCache[id] = {\n        vertex: vertex,\n        fragment: fragment\n    };\n\n    return id;\n}\n\n/**\n * @constructor\n * @extends clay.core.Base\n * @alias clay.Shader\n * @example\n * // Create a phong shader\n * var shader = new clay.Shader(\n *      clay.Shader.source('clay.standard.vertex'),\n *      clay.Shader.source('clay.standard.fragment')\n * );\n */\nfunction Shader(vertex, fragment) {\n    // First argument can be { vertex, fragment }\n    if (typeof vertex === 'object') {\n        fragment = vertex.fragment;\n        vertex = vertex.vertex;\n    }\n\n    this._shaderID = getShaderID(vertex, fragment);\n\n    this._vertexCode = Shader.parseImport(vertex);\n    this._fragmentCode = Shader.parseImport(fragment);\n\n    /**\n     * @readOnly\n     */\n    this.attributeSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.matrixSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.uniformSemantics = {};\n    /**\n     * @readOnly\n     */\n    this.matrixSemanticKeys = [];\n    /**\n     * @readOnly\n     */\n    this.uniformTemplates = {};\n    /**\n     * @readOnly\n     */\n    this.attributes = {};\n    /**\n     * @readOnly\n     */\n    this.textures = {};\n    /**\n     * @readOnly\n     */\n    this.vertexDefines = {};\n    /**\n     * @readOnly\n     */\n    this.fragmentDefines = {};\n\n    this._parseAttributes();\n    this._parseUniforms();\n    this._parseDefines();\n}\n\nShader.prototype = {\n\n    constructor: Shader,\n\n    // Create a new uniform instance for material\n    createUniforms: function () {\n        var uniforms = {};\n\n        for (var symbol in this.uniformTemplates){\n            var uniformTpl = this.uniformTemplates[symbol];\n            uniforms[symbol] = {\n                type: uniformTpl.type,\n                value: uniformTpl.value()\n            };\n        }\n\n        return uniforms;\n    },\n\n    _parseImport: function () {\n        this._vertexCode = Shader.parseImport(this.vertex);\n        this._fragmentCode = Shader.parseImport(this.fragment);\n    },\n\n    _parseUniforms: function () {\n        var uniforms = {};\n        var self = this;\n        var shaderType = 'vertex';\n        this._uniformList = [];\n\n        this._vertexCode = this._vertexCode.replace(uniformRegex, _uniformParser);\n        shaderType = 'fragment';\n        this._fragmentCode = this._fragmentCode.replace(uniformRegex, _uniformParser);\n\n        self.matrixSemanticKeys = Object.keys(this.matrixSemantics);\n\n        function _uniformParser(str, type, symbol, isArray, semanticWrapper, semantic) {\n            if (type && symbol) {\n                var uniformType = uniformTypeMap[type];\n                var isConfigurable = true;\n                var defaultValueFunc;\n                if (uniformType) {\n                    self._uniformList.push(symbol);\n                    if (type === 'sampler2D' || type === 'samplerCube') {\n                        // Texture is default disabled\n                        self.textures[symbol] = {\n                            shaderType: shaderType,\n                            type: type\n                        };\n                    }\n                    if (isArray) {\n                        uniformType += 'v';\n                    }\n                    if (semantic) {\n                        // This case is only for SKIN_MATRIX\n                        // TODO\n                        if (attributeSemantics.indexOf(semantic) >= 0) {\n                            self.attributeSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType\n                            };\n                            isConfigurable = false;\n                        }\n                        else if (matrixSemantics.indexOf(semantic) >= 0) {\n                            var isTranspose = false;\n                            var semanticNoTranspose = semantic;\n                            if (semantic.match(/TRANSPOSE$/)) {\n                                isTranspose = true;\n                                semanticNoTranspose = semantic.slice(0, -9);\n                            }\n                            self.matrixSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType,\n                                isTranspose: isTranspose,\n                                semanticNoTranspose: semanticNoTranspose\n                            };\n                            isConfigurable = false;\n                        }\n                        else if (uniformSemantics.indexOf(semantic) >= 0) {\n                            self.uniformSemantics[semantic] = {\n                                symbol: symbol,\n                                type: uniformType\n                            };\n                            isConfigurable = false;\n                        }\n                        else {\n                            // The uniform is not configurable, which means it will not appear\n                            // in the material uniform properties\n                            if (semantic === 'unconfigurable') {\n                                isConfigurable = false;\n                            }\n                            else {\n                                // Uniform have a defalut value, like\n                                // uniform vec3 color: [1, 1, 1];\n                                defaultValueFunc = self._parseDefaultValue(type, semantic);\n                                if (!defaultValueFunc) {\n                                    throw new Error('Unkown semantic \"' + semantic + '\"');\n                                }\n                                else {\n                                    semantic = '';\n                                }\n                            }\n                        }\n                    }\n\n                    if (isConfigurable) {\n                        uniforms[symbol] = {\n                            type: uniformType,\n                            value: isArray ? uniformValueConstructor['array'] : (defaultValueFunc || uniformValueConstructor[type]),\n                            semantic: semantic || null\n                        };\n                    }\n                }\n                return ['uniform', type, symbol, isArray].join(' ') + ';\\n';\n            }\n        }\n\n        this.uniformTemplates = uniforms;\n    },\n\n    _parseDefaultValue: function (type, str) {\n        var arrayRegex = /\\[\\s*(.*)\\s*\\]/;\n        if (type === 'vec2' || type === 'vec3' || type === 'vec4') {\n            var arrayStr = arrayRegex.exec(str)[1];\n            if (arrayStr) {\n                var arr = arrayStr.split(/\\s*,\\s*/);\n                return function () {\n                    return new vendor.Float32Array(arr);\n                };\n            }\n            else {\n                // Invalid value\n                return;\n            }\n        }\n        else if (type === 'bool') {\n            return function () {\n                return str.toLowerCase() === 'true' ? true : false;\n            };\n        }\n        else if (type === 'float') {\n            return function () {\n                return parseFloat(str);\n            };\n        }\n        else if (type === 'int') {\n            return function () {\n                return parseInt(str);\n            };\n        }\n    },\n\n    _parseAttributes: function () {\n        var attributes = {};\n        var self = this;\n        this._vertexCode = this._vertexCode.replace(attributeRegex, _attributeParser);\n\n        function _attributeParser(str, type, symbol, semanticWrapper, semantic) {\n            if (type && symbol) {\n                var size = 1;\n                switch (type) {\n                    case 'vec4':\n                        size = 4;\n                        break;\n                    case 'vec3':\n                        size = 3;\n                        break;\n                    case 'vec2':\n                        size = 2;\n                        break;\n                    case 'float':\n                        size = 1;\n                        break;\n                }\n\n                attributes[symbol] = {\n                    // Can only be float\n                    type: 'float',\n                    size: size,\n                    semantic: semantic || null\n                };\n\n                if (semantic) {\n                    if (attributeSemantics.indexOf(semantic) < 0) {\n                        throw new Error('Unkown semantic \"' + semantic + '\"');\n                    }\n                    else {\n                        self.attributeSemantics[semantic] = {\n                            symbol: symbol,\n                            type: type\n                        };\n                    }\n                }\n            }\n\n            return ['attribute', type, symbol].join(' ') + ';\\n';\n        }\n\n        this.attributes = attributes;\n    },\n\n    _parseDefines: function () {\n        var self = this;\n        var shaderType = 'vertex';\n        this._vertexCode = this._vertexCode.replace(defineRegex, _defineParser);\n        shaderType = 'fragment';\n        this._fragmentCode = this._fragmentCode.replace(defineRegex, _defineParser);\n\n        function _defineParser(str, symbol, value) {\n            var defines = shaderType === 'vertex' ? self.vertexDefines : self.fragmentDefines;\n            if (!defines[symbol]) { // Haven't been defined by user\n                if (value == 'false') {\n                    defines[symbol] = false;\n                }\n                else if (value == 'true') {\n                    defines[symbol] = true;\n                }\n                else {\n                    defines[symbol] = value\n                        // If can parse to float\n                        ? (isNaN(parseFloat(value)) ? value.trim() : parseFloat(value))\n                        : null;\n                }\n            }\n            return '';\n        }\n    },\n\n    /**\n     * Clone a new shader\n     * @return {clay.Shader}\n     */\n    clone: function () {\n        var code = shaderCodeCache[this._shaderID];\n        var shader = new Shader(code.vertex, code.fragment);\n        return shader;\n    }\n};\n\nif (Object.defineProperty) {\n    Object.defineProperty(Shader.prototype, 'shaderID', {\n        get: function () {\n            return this._shaderID;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'vertex', {\n        get: function () {\n            return this._vertexCode;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'fragment', {\n        get: function () {\n            return this._fragmentCode;\n        }\n    });\n    Object.defineProperty(Shader.prototype, 'uniforms', {\n        get: function () {\n            return this._uniformList;\n        }\n    });\n}\n\nvar importRegex = /(@import)\\s*([0-9a-zA-Z_\\-\\.]*)/g;\nShader.parseImport = function (shaderStr) {\n    shaderStr = shaderStr.replace(importRegex, function (str, importSymbol, importName) {\n        var str = Shader.source(importName);\n        if (str) {\n            // Recursively parse\n            return Shader.parseImport(str);\n        }\n        else {\n            console.error('Shader chunk \"' + importName + '\" not existed in library');\n            return '';\n        }\n    });\n    return shaderStr;\n};\n\nvar exportRegex = /(@export)\\s*([0-9a-zA-Z_\\-\\.]*)\\s*\\n([\\s\\S]*?)@end/g;\n\n/**\n * Import shader source\n * @param  {string} shaderStr\n * @memberOf clay.Shader\n */\nShader['import'] = function (shaderStr) {\n    shaderStr.replace(exportRegex, function (str, exportSymbol, exportName, code) {\n        var code = code.replace(/(^[\\s\\t\\xa0\\u3000]+)|([\\u3000\\xa0\\s\\t]+\\x24)/g, '');\n        if (code) {\n            var parts = exportName.split('.');\n            var obj = Shader.codes;\n            var i = 0;\n            var key;\n            while (i < parts.length - 1) {\n                key = parts[i++];\n                if (!obj[key]) {\n                    obj[key] = {};\n                }\n                obj = obj[key];\n            }\n            key = parts[i];\n            obj[key] = code;\n        }\n        return code;\n    });\n};\n\n/**\n * Library to store all the loaded shader codes\n * @type {Object}\n * @readOnly\n * @memberOf clay.Shader\n */\nShader.codes = {};\n\n/**\n * Get shader source\n * @param  {string} name\n * @return {string}\n */\nShader.source = function (name) {\n    var parts = name.split('.');\n    var obj = Shader.codes;\n    var i = 0;\n    while (obj && i < parts.length) {\n        var key = parts[i++];\n        obj = obj[key];\n    }\n    if (typeof obj !== 'string') {\n        // FIXME Use default instead\n        console.error('Shader \"' + name + '\" not existed in library');\n        return '';\n    }\n    return obj;\n};\n\nexport default Shader;\n","export default \"vec3 calcAmbientSHLight(int idx, vec3 N) {\\n    int offset = 9 * idx;\\n    return ambientSHLightCoefficients[0]\\n        + ambientSHLightCoefficients[1] * N.x\\n        + ambientSHLightCoefficients[2] * N.y\\n        + ambientSHLightCoefficients[3] * N.z\\n        + ambientSHLightCoefficients[4] * N.x * N.z\\n        + ambientSHLightCoefficients[5] * N.z * N.y\\n        + ambientSHLightCoefficients[6] * N.y * N.x\\n        + ambientSHLightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\\n        + ambientSHLightCoefficients[8] * (N.x * N.x - N.y * N.y);\\n}\";\n","import calcAmbientSHLightEssl from './calcAmbientSHLight.glsl.js';\n\nvar uniformVec3Prefix = 'uniform vec3 ';\nvar uniformFloatPrefix = 'uniform float ';\nvar exportHeaderPrefix = '@export clay.header.';\nvar exportEnd = '@end';\nvar unconfigurable = ':unconfigurable;';\nexport default [\n    exportHeaderPrefix + 'directional_light',\n    uniformVec3Prefix + 'directionalLightDirection[DIRECTIONAL_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'directionalLightColor[DIRECTIONAL_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_light',\n    uniformVec3Prefix + 'ambientLightColor[AMBIENT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_sh_light',\n    uniformVec3Prefix + 'ambientSHLightColor[AMBIENT_SH_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'ambientSHLightCoefficients[AMBIENT_SH_LIGHT_COUNT * 9]' + unconfigurable,\n    calcAmbientSHLightEssl,\n    exportEnd,\n\n    exportHeaderPrefix + 'ambient_cubemap_light',\n    uniformVec3Prefix + 'ambientCubemapLightColor[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    'uniform samplerCube ambientCubemapLightCubemap[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    'uniform sampler2D ambientCubemapLightBRDFLookup[AMBIENT_CUBEMAP_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'point_light',\n    uniformVec3Prefix + 'pointLightPosition[POINT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'pointLightRange[POINT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'pointLightColor[POINT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd,\n\n    exportHeaderPrefix + 'spot_light',\n    uniformVec3Prefix + 'spotLightPosition[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'spotLightDirection[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightRange[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightUmbraAngleCosine[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightPenumbraAngleCosine[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformFloatPrefix + 'spotLightFalloffFactor[SPOT_LIGHT_COUNT]' + unconfigurable,\n    uniformVec3Prefix + 'spotLightColor[SPOT_LIGHT_COUNT]' + unconfigurable,\n    exportEnd\n].join('\\n');\n","export default \"@export clay.prez.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n}\\n@end\\n@export clay.prez.fragment\\nvoid main()\\n{\\n    gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);\\n}\\n@end\";\n","// TODO Resources like shader, texture, geometry reference management\n// Trace and find out which shader, texture, geometry can be destroyed\nimport Base from './core/Base';\nimport GLInfo from './core/GLInfo';\nimport glenum from './core/glenum';\nimport vendor from './core/vendor';\nimport BoundingBox from './math/BoundingBox';\nimport Matrix4 from './math/Matrix4';\nimport Material from './Material';\nimport Vector2 from './math/Vector2';\nimport ProgramManager from './gpu/ProgramManager';\n\n// Light header\nimport Shader from './Shader';\n\nimport lightShader from './shader/source/header/light';\nimport prezEssl from './shader/source/prez.glsl.js';\nShader['import'](lightShader);\nShader['import'](prezEssl);\n\nimport glMatrix from './dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\nvar mat4Create = mat4.create;\n\nvar errorShader = {};\n\nfunction defaultGetMaterial(renderable) {\n    return renderable.material;\n}\n\nfunction noop() {}\n\n/**\n * @constructor clay.Renderer\n */\nvar Renderer = Base.extend(function () {\n    return /** @lends clay.Renderer# */ {\n\n        /**\n         * @type {HTMLCanvasElement}\n         * @readonly\n         */\n        canvas: null,\n\n        /**\n         * Canvas width, set by resize method\n         * @type {number}\n         * @private\n         */\n        _width: 100,\n\n        /**\n         * Canvas width, set by resize method\n         * @type {number}\n         * @private\n         */\n        _height: 100,\n\n        /**\n         * Device pixel ratio, set by setDevicePixelRatio method\n         * Specially for high defination display\n         * @see http://www.khronos.org/webgl/wiki/HandlingHighDPI\n         * @type {number}\n         * @private\n         */\n        devicePixelRatio: window.devicePixelRatio || 1.0,\n\n        /**\n         * Clear color\n         * @type {number[]}\n         */\n        clearColor: [0.0, 0.0, 0.0, 0.0],\n\n        /**\n         * Default:\n         *     _gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT | _gl.STENCIL_BUFFER_BIT\n         * @type {number}\n         */\n        clearBit: 17664,\n\n        // Settings when getting context\n        // http://www.khronos.org/registry/webgl/specs/latest/#2.4\n\n        /**\n         * If enable alpha, default true\n         * @type {boolean}\n         */\n        alpha: true,\n        /**\n         * If enable depth buffer, default true\n         * @type {boolean}\n         */\n        depth: true,\n        /**\n         * If enable stencil buffer, default false\n         * @type {boolean}\n         */\n        stencil: false,\n        /**\n         * If enable antialias, default true\n         * @type {boolean}\n         */\n        antialias: true,\n        /**\n         * If enable premultiplied alpha, default true\n         * @type {boolean}\n         */\n        premultipliedAlpha: true,\n        /**\n         * If preserve drawing buffer, default false\n         * @type {boolean}\n         */\n        preserveDrawingBuffer: false,\n        /**\n         * If throw context error, usually turned on in debug mode\n         * @type {boolean}\n         */\n        throwError: true,\n        /**\n         * WebGL Context created from given canvas\n         * @type {WebGLRenderingContext}\n         */\n        gl: null,\n        /**\n         * Renderer viewport, read-only, can be set by setViewport method\n         * @type {Object}\n         */\n        viewport: {},\n\n        // Set by FrameBuffer#bind\n        __currentFrameBuffer: null,\n\n        _viewportStack: [],\n        _clearStack: [],\n\n        _sceneRendering: null\n    };\n}, function () {\n\n    if (!this.canvas) {\n        this.canvas = document.createElement('canvas');\n    }\n    var canvas = this.canvas;\n    try {\n        var opts = {\n            alpha: this.alpha,\n            depth: this.depth,\n            stencil: this.stencil,\n            antialias: this.antialias,\n            premultipliedAlpha: this.premultipliedAlpha,\n            preserveDrawingBuffer: this.preserveDrawingBuffer\n        };\n\n        this.gl = canvas.getContext('webgl', opts)\n            || canvas.getContext('experimental-webgl', opts);\n\n        if (!this.gl) {\n            throw new Error();\n        }\n\n        this._glinfo = new GLInfo(this.gl);\n\n        if (this.gl.targetRenderer) {\n            console.error('Already created a renderer');\n        }\n        this.gl.targetRenderer = this;\n\n        this.resize();\n    }\n    catch (e) {\n        throw 'Error creating WebGL Context ' + e;\n    }\n\n    // Init managers\n    this._programMgr = new ProgramManager(this);\n},\n/** @lends clay.Renderer.prototype. **/\n{\n    /**\n     * Resize the canvas\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function(width, height) {\n        var canvas = this.canvas;\n        // http://www.khronos.org/webgl/wiki/HandlingHighDPI\n        // set the display size of the canvas.\n        var dpr = this.devicePixelRatio;\n        if (width != null) {\n            canvas.style.width = width + 'px';\n            canvas.style.height = height + 'px';\n            // set the size of the drawingBuffer\n            canvas.width = width * dpr;\n            canvas.height = height * dpr;\n\n            this._width = width;\n            this._height = height;\n        }\n        else {\n            this._width = canvas.width / dpr;\n            this._height = canvas.height / dpr;\n        }\n\n        this.setViewport(0, 0, this._width, this._height);\n    },\n\n    /**\n     * Get renderer width\n     * @return {number}\n     */\n    getWidth: function () {\n        return this._width;\n    },\n\n    /**\n     * Get renderer height\n     * @return {number}\n     */\n    getHeight: function () {\n        return this._height;\n    },\n\n    /**\n     * Get viewport aspect,\n     * @return {number}\n     */\n    getViewportAspect: function () {\n        var viewport = this.viewport;\n        return viewport.width / viewport.height;\n    },\n\n    /**\n     * Set devicePixelRatio\n     * @param {number} devicePixelRatio\n     */\n    setDevicePixelRatio: function(devicePixelRatio) {\n        this.devicePixelRatio = devicePixelRatio;\n        this.resize(this._width, this._height);\n    },\n\n    /**\n     * Get devicePixelRatio\n     * @param {number} devicePixelRatio\n     */\n    getDevicePixelRatio: function () {\n        return this.devicePixelRatio;\n    },\n\n    /**\n     * Get WebGL extension\n     * @param {string} name\n     * @return {object}\n     */\n    getGLExtension: function (name) {\n        return this._glinfo.getExtension(name);\n    },\n\n    /**\n     * Get WebGL parameter\n     * @param {string} name\n     * @return {*}\n     */\n    getGLParameter: function (name) {\n        return this._glinfo.getParameter(name);\n    },\n\n    /**\n     * Set rendering viewport\n     * @param {number|Object} x\n     * @param {number} [y]\n     * @param {number} [width]\n     * @param {number} [height]\n     * @param {number} [devicePixelRatio]\n     *        Defaultly use the renderere devicePixelRatio\n     *        It needs to be 1 when setViewport is called by frameBuffer\n     *\n     * @example\n     *  setViewport(0,0,width,height,1)\n     *  setViewport({\n     *      x: 0,\n     *      y: 0,\n     *      width: width,\n     *      height: height,\n     *      devicePixelRatio: 1\n     *  })\n     */\n    setViewport: function (x, y, width, height, dpr) {\n\n        if (typeof x === 'object') {\n            var obj = x;\n\n            x = obj.x;\n            y = obj.y;\n            width = obj.width;\n            height = obj.height;\n            dpr = obj.devicePixelRatio;\n        }\n        dpr = dpr || this.devicePixelRatio;\n\n        this.gl.viewport(\n            x * dpr, y * dpr, width * dpr, height * dpr\n        );\n        // Use a fresh new object, not write property.\n        this.viewport = {\n            x: x,\n            y: y,\n            width: width,\n            height: height,\n            devicePixelRatio: dpr\n        };\n    },\n\n    /**\n     * Push current viewport into a stack\n     */\n    saveViewport: function () {\n        this._viewportStack.push(this.viewport);\n    },\n\n    /**\n     * Pop viewport from stack, restore in the renderer\n     */\n    restoreViewport: function () {\n        if (this._viewportStack.length > 0) {\n            this.setViewport(this._viewportStack.pop());\n        }\n    },\n\n    /**\n     * Push current clear into a stack\n     */\n    saveClear: function () {\n        this._clearStack.push({\n            clearBit: this.clearBit,\n            clearColor: this.clearColor\n        });\n    },\n\n    /**\n     * Pop clear from stack, restore in the renderer\n     */\n    restoreClear: function () {\n        if (this._clearStack.length > 0) {\n            var opt = this._clearStack.pop();\n            this.clearColor = opt.clearColor;\n            this.clearBit = opt.clearBit;\n        }\n    },\n\n    bindSceneRendering: function (scene) {\n        this._sceneRendering = scene;\n    },\n\n    /**\n     * Render the scene in camera to the screen or binded offline framebuffer\n     * @param  {clay.Scene}       scene\n     * @param  {clay.Camera}      camera\n     * @param  {boolean}     [notUpdateScene] If not call the scene.update methods in the rendering, default true\n     * @param  {boolean}     [preZ]           If use preZ optimization, default false\n     * @return {IRenderInfo}\n     */\n    render: function(scene, camera, notUpdateScene, preZ) {\n        var _gl = this.gl;\n\n        var clearColor = this.clearColor;\n\n        if (this.clearBit) {\n\n            // Must set depth and color mask true before clear\n            _gl.colorMask(true, true, true, true);\n            _gl.depthMask(true);\n            var viewport = this.viewport;\n            var needsScissor = false;\n            var viewportDpr = viewport.devicePixelRatio;\n            if (viewport.width !== this._width || viewport.height !== this._height\n                || (viewportDpr && viewportDpr !== this.devicePixelRatio)\n                || viewport.x || viewport.y\n            ) {\n                needsScissor = true;\n                // http://stackoverflow.com/questions/11544608/how-to-clear-a-rectangle-area-in-webgl\n                // Only clear the viewport\n                _gl.enable(_gl.SCISSOR_TEST);\n                _gl.scissor(viewport.x * viewportDpr, viewport.y * viewportDpr, viewport.width * viewportDpr, viewport.height * viewportDpr);\n            }\n            _gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n            _gl.clear(this.clearBit);\n            if (needsScissor) {\n                _gl.disable(_gl.SCISSOR_TEST);\n            }\n        }\n\n        // If the scene have been updated in the prepass like shadow map\n        // There is no need to update it again\n        if (!notUpdateScene) {\n            scene.update(false);\n        }\n        camera = camera || scene.getMainCamera();\n        if (!camera) {\n            console.error('Can\\'t find camera in the scene.');\n            return;\n        }\n        // Update if camera not mounted on the scene\n        if (!camera.getScene()) {\n            camera.update(true);\n        }\n\n        this._sceneRendering = scene;\n\n        // Reset the scene bounding box;\n        scene.viewBoundingBoxLastFrame.min.set(Infinity, Infinity, Infinity);\n        scene.viewBoundingBoxLastFrame.max.set(-Infinity, -Infinity, -Infinity);\n\n        var opaqueList = this.cullRenderList(scene.opaqueList, scene, camera);\n        var transparentList = this.cullRenderList(scene.transparentList, scene, camera);\n        var sceneMaterial = scene.material;\n\n        scene.trigger('beforerender', this, scene, camera);\n\n        // Render pre z\n        if (preZ) {\n            this.renderPreZ(opaqueList, scene, camera);\n            _gl.depthFunc(_gl.LEQUAL);\n        }\n        else {\n            _gl.depthFunc(_gl.LESS);\n        }\n\n        // Update the depth of transparent list.\n        var worldViewMat = mat4Create();\n        var posViewSpace = vec3.create();\n        for (var i = 0; i < transparentList.length; i++) {\n            var renderable = transparentList[i];\n            mat4.multiplyAffine(worldViewMat, camera.viewMatrix.array, renderable.worldTransform.array);\n            vec3.transformMat4(posViewSpace, renderable.position.array, worldViewMat);\n            renderable.__depth = posViewSpace[2];\n        }\n\n        // Render opaque list\n        scene.trigger('beforerender:opaque', this, opaqueList);\n        var opaqueRenderInfo = this.renderPass(opaqueList, camera, {\n            getMaterial: function (renderable) {\n                return sceneMaterial || renderable.material;\n            },\n            sortCompare: this.opaqueSortCompare\n        });\n\n        scene.trigger('afterrender:opaque', this, opaqueList, opaqueRenderInfo);\n        scene.trigger('beforerender:transparent', this, transparentList);\n\n        var transparentRenderInfo = this.renderPass(transparentList, camera, {\n            getMaterial: function (renderable) {\n                return sceneMaterial || renderable.material;\n            },\n            sortCompare: this.transparentSortCompare\n        });\n\n        scene.trigger('afterrender:transparent', this, transparentList, transparentRenderInfo);\n        var renderInfo = {};\n        for (var name in opaqueRenderInfo) {\n            renderInfo[name] = opaqueRenderInfo[name] + transparentRenderInfo[name];\n        }\n\n        scene.trigger('afterrender', this, scene, camera, renderInfo);\n\n        // Cleanup\n        this._sceneRendering = null;\n        return renderInfo;\n    },\n\n    getProgram: function (renderable, renderMaterial, scene) {\n        renderMaterial = renderMaterial || renderable.material;\n        return this._programMgr.getProgram(renderable, renderMaterial, scene);\n    },\n\n    validateProgram: function (program) {\n        if (program.__error) {\n            var errorMsg = program.__error;\n            if (errorShader[program.__uid__]) {\n                return;\n            }\n            errorShader[program.__uid__] = true;\n\n            if (this.throwError) {\n                throw new Error(errorMsg);\n            }\n            else {\n                this.trigger('error', errorMsg);\n            }\n        }\n\n    },\n\n    updatePrograms: function (list, scene, passConfig) {\n        var getMaterial = (passConfig && passConfig.getMaterial) || defaultGetMaterial;\n        scene = scene || null;\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n            var renderMaterial = getMaterial.call(this, renderable);\n            if (i > 0) {\n                var prevRenderable = list[i - 1];\n                var prevJointsLen = prevRenderable.joints ? prevRenderable.joints.length : 0;\n                var jointsLen = renderable.joints.length ? renderable.joints.length : 0;\n                // Keep program not change if joints, material, lightGroup are same of two renderables.\n                if (jointsLen === prevJointsLen\n                    && renderable.material === prevRenderable.material\n                    && renderable.lightGroup === prevRenderable.lightGroup\n                ) {\n                    renderable.__program = prevRenderable.__program;\n                    continue;\n                }\n            }\n\n            var program = this._programMgr.getProgram(renderable, renderMaterial, scene);\n\n            this.validateProgram(program);\n\n            renderable.__program = program;\n        }\n    },\n\n    /**\n     * Do frustum culling on render list\n     */\n    cullRenderList: function (list, scene, camera) {\n        var culledRenderList = [];\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n\n            var worldM = renderable.isSkinnedMesh() ? matrices.IDENTITY : renderable.worldTransform.array;\n            var geometry = renderable.geometry;\n\n            mat4.multiplyAffine(matrices.WORLDVIEW, camera.viewMatrix.array , worldM);\n            if (geometry.boundingBox) {\n                if (this.isFrustumCulled(\n                    renderable, scene, camera, matrices.WORLDVIEW, camera.projectionMatrix.array\n                )) {\n                    continue;\n                }\n            }\n\n            culledRenderList.push(renderable);\n        }\n\n        return culledRenderList;\n    },\n\n    /**\n     * Render a single renderable list in camera in sequence\n     * @param {clay.Renderable[]} list List of all renderables.\n     * @param {clay.Camera} camera\n     * @param {Object} [passConfig]\n     * @param {Function} [passConfig.getMaterial] Get renderable material.\n     * @param {Function} [passConfig.beforeRender] Before render each renderable.\n     * @param {Function} [passConfig.afterRender] After render each renderable\n     * @param {Function} [passConfig.ifRender] If render the renderable.\n     * @param {Function} [passConfig.sortCompare] Sort compare function.\n     * @return {IRenderInfo}\n     */\n    renderPass: function(list, camera, passConfig) {\n        var renderInfo = {\n            triangleCount: 0,\n            vertexCount: 0,\n            drawCallCount: 0,\n            meshCount: list.length,\n            renderedMeshCount: 0\n        };\n        passConfig = passConfig || {};\n        passConfig.getMaterial = passConfig.getMaterial || defaultGetMaterial;\n        passConfig.beforeRender = passConfig.beforeRender || noop;\n        passConfig.afterRender = passConfig.afterRender || noop;\n\n        this.updatePrograms(list, this._sceneRendering, passConfig);\n        if (passConfig.sortCompare) {\n            list.sort(passConfig.sortCompare);\n        }\n\n        // Some common builtin uniforms\n        var viewport = this.viewport;\n        var vDpr = viewport.devicePixelRatio;\n        var viewportUniform = [\n            viewport.x * vDpr, viewport.y * vDpr,\n            viewport.width * vDpr, viewport.height * vDpr\n        ];\n        var windowDpr = this.devicePixelRatio;\n        var windowSizeUniform = this.__currentFrameBuffer\n            ? [this.__currentFrameBuffer.getTextureWidth(), this.__currentFrameBuffer.getTextureHeight()]\n            : [this._width * windowDpr, this._height * windowDpr];\n        // DEPRECATED\n        var viewportSizeUniform = [\n            viewportUniform[2], viewportUniform[3]\n        ];\n        var time = Date.now();\n\n        // Calculate view and projection matrix\n        mat4.copy(matrices.VIEW, camera.viewMatrix.array);\n        mat4.copy(matrices.PROJECTION, camera.projectionMatrix.array);\n        mat4.multiply(matrices.VIEWPROJECTION, camera.projectionMatrix.array, matrices.VIEW);\n        mat4.copy(matrices.VIEWINVERSE, camera.worldTransform.array);\n        mat4.invert(matrices.PROJECTIONINVERSE, matrices.PROJECTION);\n        mat4.invert(matrices.VIEWPROJECTIONINVERSE, matrices.VIEWPROJECTION);\n\n        var _gl = this.gl;\n        var scene = this._sceneRendering;\n\n        var prevMaterial;\n        var prevProgram;\n\n        // Status\n        var depthTest, depthMask;\n        var culling, cullFace, frontFace;\n        var transparent;\n\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n            if (passConfig.ifRender && !passConfig.ifRender(renderable)) {\n                continue;\n            }\n\n            // Skinned mesh will transformed to joint space. Ignore the mesh transform\n            var worldM = renderable.isSkinnedMesh() ? matrices.IDENTITY : renderable.worldTransform.array;\n\n            var material = passConfig.getMaterial.call(this, renderable);\n\n            var program = renderable.__program;\n            var shader = material.shader;\n\n            mat4.copy(matrices.WORLD, worldM);\n            mat4.multiply(matrices.WORLDVIEWPROJECTION, matrices.VIEWPROJECTION , worldM);\n            if (shader.matrixSemantics.WORLDINVERSE ||\n                shader.matrixSemantics.WORLDINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDINVERSE, worldM);\n            }\n            if (shader.matrixSemantics.WORLDVIEWINVERSE ||\n                shader.matrixSemantics.WORLDVIEWINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDVIEWINVERSE, matrices.WORLDVIEW);\n            }\n            if (shader.matrixSemantics.WORLDVIEWPROJECTIONINVERSE ||\n                shader.matrixSemantics.WORLDVIEWPROJECTIONINVERSETRANSPOSE) {\n                mat4.invert(matrices.WORLDVIEWPROJECTIONINVERSE, matrices.WORLDVIEWPROJECTION);\n            }\n\n            // Before render hook\n            renderable.beforeRender(this);\n            passConfig.beforeRender.call(this, renderable, material, prevMaterial);\n\n            var programChanged = program !== prevProgram;\n            if (programChanged) {\n                // Set lights number\n                program.bind(this);\n                // Set some common uniforms\n                program.setUniformOfSemantic(_gl, 'VIEWPORT', viewportUniform);\n                program.setUniformOfSemantic(_gl, 'WINDOW_SIZE', windowSizeUniform);\n                program.setUniformOfSemantic(_gl, 'NEAR', camera.near);\n                program.setUniformOfSemantic(_gl, 'FAR', camera.far);\n                program.setUniformOfSemantic(_gl, 'DEVICEPIXELRATIO', vDpr);\n                program.setUniformOfSemantic(_gl, 'TIME', time);\n                // DEPRECATED\n                program.setUniformOfSemantic(_gl, 'VIEWPORT_SIZE', viewportSizeUniform);\n\n                // Set lights uniforms\n                // TODO needs optimized\n                if (scene) {\n                    scene.setLightUniforms(program, renderable.lightGroup, this);\n                }\n            }\n            else {\n                program = prevProgram;\n            }\n\n            // Program changes also needs reset the materials.\n            if (prevMaterial !== material || programChanged) {\n                if (material.depthTest !== depthTest) {\n                    material.depthTest\n                        ? _gl.enable(_gl.DEPTH_TEST)\n                        : _gl.disable(_gl.DEPTH_TEST);\n                    depthTest = material.depthTest;\n                }\n                if (material.depthMask !== depthMask) {\n                    _gl.depthMask(material.depthMask);\n                    depthMask = material.depthMask;\n                }\n                if (material.transparent !== transparent) {\n                    material.transparent\n                        ? _gl.enable(_gl.BLEND)\n                        : _gl.disable(_gl.BLEND);\n                    transparent = material.transparent;\n                }\n                // TODO cache blending\n                if (material.transparent) {\n                    if (material.blend) {\n                        material.blend(_gl);\n                    }\n                    else {\n                        // Default blend function\n                        _gl.blendEquationSeparate(_gl.FUNC_ADD, _gl.FUNC_ADD);\n                        _gl.blendFuncSeparate(_gl.SRC_ALPHA, _gl.ONE_MINUS_SRC_ALPHA, _gl.ONE, _gl.ONE_MINUS_SRC_ALPHA);\n                    }\n                }\n\n                material.bind(this, program, prevMaterial, prevProgram);\n                prevMaterial = material;\n            }\n\n            var matrixSemanticKeys = shader.matrixSemanticKeys;\n            for (var k = 0; k < matrixSemanticKeys.length; k++) {\n                var semantic = matrixSemanticKeys[k];\n                var semanticInfo = shader.matrixSemantics[semantic];\n                var matrix = matrices[semantic];\n                if (semanticInfo.isTranspose) {\n                    var matrixNoTranspose = matrices[semanticInfo.semanticNoTranspose];\n                    mat4.transpose(matrix, matrixNoTranspose);\n                }\n                program.setUniform(_gl, semanticInfo.type, semanticInfo.symbol, matrix);\n            }\n\n            if (renderable.cullFace !== cullFace) {\n                cullFace = renderable.cullFace;\n                _gl.cullFace(cullFace);\n            }\n            if (renderable.frontFace !== frontFace) {\n                frontFace = renderable.frontFace;\n                _gl.frontFace(frontFace);\n            }\n            if (renderable.culling !== culling) {\n                culling = renderable.culling;\n                culling ? _gl.enable(_gl.CULL_FACE) : _gl.disable(_gl.CULL_FACE);\n            }\n\n            var objectRenderInfo = renderable.render(this, material, program);\n\n            if (objectRenderInfo) {\n                renderInfo.triangleCount += objectRenderInfo.triangleCount;\n                renderInfo.vertexCount += objectRenderInfo.vertexCount;\n                renderInfo.drawCallCount += objectRenderInfo.drawCallCount;\n                renderInfo.renderedMeshCount ++;\n            }\n\n            // After render hook\n            passConfig.afterRender.call(this, renderable, objectRenderInfo);\n            renderable.afterRender(this, objectRenderInfo);\n\n            prevProgram = program;\n        }\n\n        // Remove programs incase it's not updated in the other passes.\n        for (var i = 0; i < list.length; i++) {\n            list[i].__program = null;\n        }\n\n        return renderInfo;\n    },\n\n    renderPreZ: function (list, scene, camera) {\n        var _gl = this.gl;\n        var preZPassMaterial = this._prezMaterial || new Material({\n            shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'))\n        });\n        this._prezMaterial = preZPassMaterial;\n\n        _gl.colorMask(false, false, false, false);\n        _gl.depthMask(true);\n\n        // Status\n        this.renderPass(list, camera, {\n            ifRender: function (renderable) {\n                return !renderable.ignorePreZ;\n            },\n            getMaterial: function () {\n                return preZPassMaterial;\n            },\n            sort: this.opaqueSortCompare\n        });\n\n        _gl.colorMask(true, true, true, true);\n        _gl.depthMask(true);\n    },\n\n    /**\n     * If an scene object is culled by camera frustum\n     *\n     * Object can be a renderable or a light\n     *\n     * @param {clay.Node} Scene object\n     * @param {clay.Camera} camera\n     * @param {Array.<number>} worldViewMat represented with array\n     * @param {Array.<number>} projectionMat represented with array\n     */\n    isFrustumCulled: (function () {\n        // Frustum culling\n        // http://www.cse.chalmers.se/~uffe/vfc_bbox.pdf\n        var cullingBoundingBox = new BoundingBox();\n        var cullingMatrix = new Matrix4();\n        return function (object, scene, camera, worldViewMat, projectionMat) {\n            // Bounding box can be a property of object(like light) or renderable.geometry\n            var geoBBox = object.boundingBox || object.geometry.boundingBox;\n            cullingMatrix.array = worldViewMat;\n            cullingBoundingBox.copy(geoBBox);\n            cullingBoundingBox.applyTransform(cullingMatrix);\n\n            // Passingly update the scene bounding box\n            // FIXME exclude very large mesh like ground plane or terrain ?\n            // FIXME Only rendererable which cast shadow ?\n\n            // FIXME boundingBox becomes much larger after transformd.\n            if (scene && object.isRenderable() && object.castShadow) {\n                scene.viewBoundingBoxLastFrame.union(cullingBoundingBox);\n            }\n            // Ignore frustum culling if object is skinned mesh.\n            if (object.frustumCulling && !object.isSkinnedMesh())  {\n                if (!cullingBoundingBox.intersectBoundingBox(camera.frustum.boundingBox)) {\n                    return true;\n                }\n\n                cullingMatrix.array = projectionMat;\n                if (\n                    cullingBoundingBox.max.array[2] > 0 &&\n                    cullingBoundingBox.min.array[2] < 0\n                ) {\n                    // Clip in the near plane\n                    cullingBoundingBox.max.array[2] = -1e-20;\n                }\n\n                cullingBoundingBox.applyProjection(cullingMatrix);\n\n                var min = cullingBoundingBox.min.array;\n                var max = cullingBoundingBox.max.array;\n\n                if (\n                    max[0] < -1 || min[0] > 1\n                    || max[1] < -1 || min[1] > 1\n                    || max[2] < -1 || min[2] > 1\n                ) {\n                    return true;\n                }\n            }\n\n            return false;\n        };\n    })(),\n\n    /**\n     * Dispose given scene, including all geometris, textures and shaders in the scene\n     * @param {clay.Scene} scene\n     */\n    disposeScene: function(scene) {\n        this.disposeNode(scene, true, true);\n        scene.dispose();\n    },\n\n    /**\n     * Dispose given node, including all geometries, textures and shaders attached on it or its descendant\n     * @param {clay.Node} node\n     * @param {boolean} [disposeGeometry=false] If dispose the geometries used in the descendant mesh\n     * @param {boolean} [disposeTexture=false] If dispose the textures used in the descendant mesh\n     */\n    disposeNode: function(root, disposeGeometry, disposeTexture) {\n        // Dettached from parent\n        if (root.getParent()) {\n            root.getParent().remove(root);\n        }\n        root.traverse(function(node) {\n            if (node.geometry && disposeGeometry) {\n                node.geometry.dispose(this);\n            }\n            // Particle system and AmbientCubemap light need to dispose\n            if (node.dispose) {\n                node.dispose(this);\n            }\n        }, this);\n    },\n\n    /**\n     * Dispose given geometry\n     * @param {clay.Geometry} geometry\n     */\n    disposeGeometry: function(geometry) {\n        geometry.dispose(this);\n    },\n\n    /**\n     * Dispose given texture\n     * @param {clay.Texture} texture\n     */\n    disposeTexture: function(texture) {\n        texture.dispose(this);\n    },\n\n    /**\n     * Dispose given frame buffer\n     * @param {clay.FrameBuffer} frameBuffer\n     */\n    disposeFrameBuffer: function(frameBuffer) {\n        frameBuffer.dispose(this);\n    },\n\n    /**\n     * Dispose renderer\n     */\n    dispose: function () {},\n\n    /**\n     * Convert screen coords to normalized device coordinates(NDC)\n     * Screen coords can get from mouse event, it is positioned relative to canvas element\n     * NDC can be used in ray casting with Camera.prototype.castRay methods\n     *\n     * @param  {number}       x\n     * @param  {number}       y\n     * @param  {clay.math.Vector2} [out]\n     * @return {clay.math.Vector2}\n     */\n    screenToNDC: function(x, y, out) {\n        if (!out) {\n            out = new Vector2();\n        }\n        // Invert y;\n        y = this._height - y;\n\n        var viewport = this.viewport;\n        var arr = out.array;\n        arr[0] = (x - viewport.x) / viewport.width;\n        arr[0] = arr[0] * 2 - 1;\n        arr[1] = (y - viewport.y) / viewport.height;\n        arr[1] = arr[1] * 2 - 1;\n\n        return out;\n    }\n});\n\n/**\n * Opaque renderables compare function\n * @param  {clay.Renderable} x\n * @param  {clay.Renderable} y\n * @return {boolean}\n * @static\n */\nRenderer.opaqueSortCompare = Renderer.prototype.opaqueSortCompare = function(x, y) {\n    // Priority renderOrder -> program -> material -> geometry\n    if (x.renderOrder === y.renderOrder) {\n        if (x.__program === y.__program) {\n            if (x.material === y.material) {\n                return x.geometry.__uid__ - y.geometry.__uid__;\n            }\n            return x.material.__uid__ - y.material.__uid__;\n        }\n        if (x.__program  && y.__program) {\n            return x.__program.__uid__ - y.__program.__uid__;\n        }\n        return 0;\n    }\n    return x.renderOrder - y.renderOrder;\n};\n\n/**\n * Transparent renderables compare function\n * @param  {clay.Renderable} a\n * @param  {clay.Renderable} b\n * @return {boolean}\n * @static\n */\nRenderer.transparentSortCompare = Renderer.prototype.transparentSortCompare = function(x, y) {\n    // Priority renderOrder -> depth -> program -> material -> geometry\n\n    if (x.renderOrder === y.renderOrder) {\n        if (x.__depth === y.__depth) {\n            if (x.__program === y.__program) {\n                if (x.material === y.material) {\n                    return x.geometry.__uid__ - y.geometry.__uid__;\n                }\n                return x.material.__uid__ - y.material.__uid__;\n            }\n            if (x.__program  && y.__program) {\n                return x.__program.__uid__ - y.__program.__uid__;\n            }\n            return 0;\n        }\n        // Depth is negative\n        // So farther object has smaller depth value\n        return x.__depth - y.__depth;\n    }\n    return x.renderOrder - y.renderOrder;\n};\n\n// Temporary variables\nvar matrices = {\n    IDENTITY: mat4Create(),\n\n    WORLD: mat4Create(),\n    VIEW: mat4Create(),\n    PROJECTION: mat4Create(),\n    WORLDVIEW: mat4Create(),\n    VIEWPROJECTION: mat4Create(),\n    WORLDVIEWPROJECTION: mat4Create(),\n\n    WORLDINVERSE: mat4Create(),\n    VIEWINVERSE: mat4Create(),\n    PROJECTIONINVERSE: mat4Create(),\n    WORLDVIEWINVERSE: mat4Create(),\n    VIEWPROJECTIONINVERSE: mat4Create(),\n    WORLDVIEWPROJECTIONINVERSE: mat4Create(),\n\n    WORLDTRANSPOSE: mat4Create(),\n    VIEWTRANSPOSE: mat4Create(),\n    PROJECTIONTRANSPOSE: mat4Create(),\n    WORLDVIEWTRANSPOSE: mat4Create(),\n    VIEWPROJECTIONTRANSPOSE: mat4Create(),\n    WORLDVIEWPROJECTIONTRANSPOSE: mat4Create(),\n    WORLDINVERSETRANSPOSE: mat4Create(),\n    VIEWINVERSETRANSPOSE: mat4Create(),\n    PROJECTIONINVERSETRANSPOSE: mat4Create(),\n    WORLDVIEWINVERSETRANSPOSE: mat4Create(),\n    VIEWPROJECTIONINVERSETRANSPOSE: mat4Create(),\n    WORLDVIEWPROJECTIONINVERSETRANSPOSE: mat4Create()\n};\n\n/**\n * @name clay.Renderer.COLOR_BUFFER_BIT\n * @type {number}\n */\nRenderer.COLOR_BUFFER_BIT = glenum.COLOR_BUFFER_BIT;\n/**\n * @name clay.Renderer.DEPTH_BUFFER_BIT\n * @type {number}\n */\nRenderer.DEPTH_BUFFER_BIT = glenum.DEPTH_BUFFER_BIT;\n/**\n * @name clay.Renderer.STENCIL_BUFFER_BIT\n * @type {number}\n */\nRenderer.STENCIL_BUFFER_BIT = glenum.STENCIL_BUFFER_BIT;\n\nexport default Renderer;\n","import glMatrix from '../dep/glmatrix';\nvar quat = glMatrix.quat;\n\n/**\n * @constructor\n * @alias clay.math.Quaternion\n * @param {number} x\n * @param {number} y\n * @param {number} z\n * @param {number} w\n */\nvar Quaternion = function (x, y, z, w) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n    w = w === undefined ? 1 : w;\n\n    /**\n     * Storage of Quaternion, read and write of x, y, z, w will change the values in array\n     * All methods also operate on the array instead of x, y, z, w components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Quaternion#\n     */\n    this.array = quat.fromValues(x, y, z, w);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Quaternion#\n     */\n    this._dirty = true;\n};\n\nQuaternion.prototype = {\n\n    constructor: Quaternion,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    add: function (b) {\n        quat.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate the w component from x, y, z component\n     * @return {clay.math.Quaternion}\n     */\n    calculateW: function () {\n        quat.calculateW(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @param  {number}  w\n     * @return {clay.math.Quaternion}\n     */\n    set: function (x, y, z, w) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this.array[3] = w;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y, z and w components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Quaternion}\n     */\n    setArray: function (arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n        this.array[3] = arr[3];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Quaternion\n     * @return {clay.math.Quaternion}\n     */\n    clone: function () {\n        return new Quaternion(this.x, this.y, this.z, this.w);\n    },\n\n    /**\n     * Calculates the conjugate of self If the quaternion is normalized,\n     * this function is faster than invert and produces the same result.\n     *\n     * @return {clay.math.Quaternion}\n     */\n    conjugate: function () {\n        quat.conjugate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    copy: function (b) {\n        quat.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Quaternion} b\n     * @return {number}\n     */\n    dot: function (b) {\n        return quat.dot(this.array, b.array);\n    },\n\n    /**\n     * Set from the given 3x3 rotation matrix\n     * @param  {clay.math.Matrix3} m\n     * @return {clay.math.Quaternion}\n     */\n    fromMat3: function (m) {\n        quat.fromMat3(this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set from the given 4x4 rotation matrix\n     * The 4th column and 4th row will be droped\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Quaternion}\n     */\n    fromMat4: (function () {\n        var mat3 = glMatrix.mat3;\n        var m3 = mat3.create();\n        return function (m) {\n            mat3.fromMat4(m3, m.array);\n            // TODO Not like mat4, mat3 in glmatrix seems to be row-based\n            mat3.transpose(m3, m3);\n            quat.fromMat3(this.array, m3);\n            this._dirty = true;\n            return this;\n        };\n    })(),\n\n    /**\n     * Set to identity quaternion\n     * @return {clay.math.Quaternion}\n     */\n    identity: function () {\n        quat.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Invert self\n     * @return {clay.math.Quaternion}\n     */\n    invert: function () {\n        quat.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function () {\n        return quat.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function () {\n        return quat.length(this.array);\n    },\n\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Quaternion} a\n     * @param  {clay.math.Quaternion} b\n     * @param  {number}  t\n     * @return {clay.math.Quaternion}\n     */\n    lerp: function (a, b, t) {\n        quat.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    mul: function (b) {\n        quat.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Quaternion} a\n     * @return {clay.math.Quaternion}\n     */\n    mulLeft: function (a) {\n        quat.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Quaternion} b\n     * @return {clay.math.Quaternion}\n     */\n    multiply: function (b) {\n        quat.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply a and self\n     * Quaternion mutiply is not commutative, so the result of mutiplyLeft is different with multiply.\n     * @param  {clay.math.Quaternion} a\n     * @return {clay.math.Quaternion}\n     */\n    multiplyLeft: function (a) {\n        quat.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Quaternion}\n     */\n    normalize: function () {\n        quat.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about X axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateX: function (rad) {\n        quat.rotateX(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Y axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateY: function (rad) {\n        quat.rotateY(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian about Z axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    rotateZ: function (rad) {\n        quat.rotateZ(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Sets self to represent the shortest rotation from Vector3 a to Vector3 b.\n     * a and b needs to be normalized\n     * @param  {clay.math.Vector3} a\n     * @param  {clay.math.Vector3} b\n     * @return {clay.math.Quaternion}\n     */\n    rotationTo: function (a, b) {\n        quat.rotationTo(this.array, a.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Sets self with values corresponding to the given axes\n     * @param {clay.math.Vector3} view\n     * @param {clay.math.Vector3} right\n     * @param {clay.math.Vector3} up\n     * @return {clay.math.Quaternion}\n     */\n    setAxes: function (view, right, up) {\n        quat.setAxes(this.array, view.array, right.array, up.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Sets self with a rotation axis and rotation angle\n     * @param {clay.math.Vector3} axis\n     * @param {number} rad\n     * @return {clay.math.Quaternion}\n     */\n    setAxisAngle: function (axis, rad) {\n        quat.setAxisAngle(this.array, axis.array, rad);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Perform spherical linear interpolation between a and b\n     * @param  {clay.math.Quaternion} a\n     * @param  {clay.math.Quaternion} b\n     * @param  {number} t\n     * @return {clay.math.Quaternion}\n     */\n    slerp: function (a, b, t) {\n        quat.slerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function () {\n        return quat.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function () {\n        return quat.squaredLength(this.array);\n    },\n\n    /**\n     * Set from euler\n     * @param {clay.math.Vector3} v\n     * @param {String} order\n     */\n    fromEuler: function (v, order) {\n        return Quaternion.fromEuler(this, v, order);\n    },\n\n    toString: function () {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Quaternion.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name w\n     * @type {number}\n     * @memberOf clay.math.Quaternion\n     * @instance\n     */\n    defineProperty(proto, 'w', {\n        get: function () {\n            return this.array[3];\n        },\n        set: function (value) {\n            this.array[3] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.add = function (out, a, b) {\n    quat.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {number}     x\n * @param  {number}     y\n * @param  {number}     z\n * @param  {number}     w\n * @return {clay.math.Quaternion}\n */\nQuaternion.set = function (out, x, y, z, w) {\n    quat.set(out.array, x, y, z, w);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.copy = function (out, b) {\n    quat.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.calculateW = function (out, a) {\n    quat.calculateW(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.conjugate = function (out, a) {\n    quat.conjugate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @return {clay.math.Quaternion}\n */\nQuaternion.identity = function (out) {\n    quat.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.invert = function (out, a) {\n    quat.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {number}\n */\nQuaternion.dot = function (a, b) {\n    return quat.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.len = function (a) {\n    return quat.length(a.array);\n};\n\n// Quaternion.length = Quaternion.len;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @param  {number}     t\n * @return {clay.math.Quaternion}\n */\nQuaternion.lerp = function (out, a, b, t) {\n    quat.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @param  {number}     t\n * @return {clay.math.Quaternion}\n */\nQuaternion.slerp = function (out, a, b, t) {\n    quat.slerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.mul = function (out, a, b) {\n    quat.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {clay.math.Quaternion} b\n * @return {clay.math.Quaternion}\n */\nQuaternion.multiply = Quaternion.mul;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateX = function (out, a, rad) {\n    quat.rotateX(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateY = function (out, a, rad) {\n    quat.rotateY(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotateZ = function (out, a, rad) {\n    quat.rotateZ(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    axis\n * @param  {number}     rad\n * @return {clay.math.Quaternion}\n */\nQuaternion.setAxisAngle = function (out, axis, rad) {\n    quat.setAxisAngle(out.array, axis.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Quaternion}\n */\nQuaternion.normalize = function (out, a) {\n    quat.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.sqrLen = function (a) {\n    return quat.sqrLen(a.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Quaternion} a\n * @return {number}\n */\nQuaternion.squaredLength = Quaternion.sqrLen;\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Matrix3}    m\n * @return {clay.math.Quaternion}\n */\nQuaternion.fromMat3 = function (out, m) {\n    quat.fromMat3(out.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    view\n * @param  {clay.math.Vector3}    right\n * @param  {clay.math.Vector3}    up\n * @return {clay.math.Quaternion}\n */\nQuaternion.setAxes = function (out, view, right, up) {\n    quat.setAxes(out.array, view.array, right.array, up.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Quaternion} out\n * @param  {clay.math.Vector3}    a\n * @param  {clay.math.Vector3}    b\n * @return {clay.math.Quaternion}\n */\nQuaternion.rotationTo = function (out, a, b) {\n    quat.rotationTo(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * Set quaternion from euler\n * @param {clay.math.Quaternion} out\n * @param {clay.math.Vector3} v\n * @param {String} order\n */\nQuaternion.fromEuler = function (out, v, order) {\n\n    out._dirty = true;\n\n    v = v.array;\n    var target = out.array;\n    var c1 = Math.cos(v[0] / 2);\n    var c2 = Math.cos(v[1] / 2);\n    var c3 = Math.cos(v[2] / 2);\n    var s1 = Math.sin(v[0] / 2);\n    var s2 = Math.sin(v[1] / 2);\n    var s3 = Math.sin(v[2] / 2);\n\n    var order = (order || 'XYZ').toUpperCase();\n\n    // http://www.mathworks.com/matlabcentral/fileexchange/\n    //  20696-function-to-convert-between-dcm-euler-angles-quaternions-and-euler-vectors/\n    //  content/SpinCalc.m\n\n    switch (order) {\n        case 'XYZ':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'YXZ':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n        case 'ZXY':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'ZYX':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n        case 'YZX':\n            target[0] = s1 * c2 * c3 + c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 + s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 - s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 - s1 * s2 * s3;\n            break;\n        case 'XZY':\n            target[0] = s1 * c2 * c3 - c1 * s2 * s3;\n            target[1] = c1 * s2 * c3 - s1 * c2 * s3;\n            target[2] = c1 * c2 * s3 + s1 * s2 * c3;\n            target[3] = c1 * c2 * c3 + s1 * s2 * s3;\n            break;\n    }\n};\n\nexport default Quaternion;\n","import Base from './core/Base';\nimport Vector3 from './math/Vector3';\nimport Quaternion from './math/Quaternion';\nimport Matrix4 from './math/Matrix4';\nimport glMatrix from './dep/glmatrix';\nimport BoundingBox from './math/BoundingBox';\nvar mat4 = glMatrix.mat4;\n\nvar nameId = 0;\n\n/**\n * @constructor clay.Node\n * @extends clay.core.Base\n */\nvar Node = Base.extend(\n/** @lends clay.Node# */\n{\n    /**\n     * Scene node name\n     * @type {string}\n     */\n    name: '',\n\n    /**\n     * Position relative to its parent node. aka translation.\n     * @type {clay.math.Vector3}\n     */\n    position: null,\n\n    /**\n     * Rotation relative to its parent node. Represented by a quaternion\n     * @type {clay.math.Quaternion}\n     */\n    rotation: null,\n\n    /**\n     * Scale relative to its parent node\n     * @type {clay.math.Vector3}\n     */\n    scale: null,\n\n    /**\n     * Affine transform matrix relative to its root scene.\n     * @type {clay.math.Matrix4}\n     */\n    worldTransform: null,\n\n    /**\n     * Affine transform matrix relative to its parent node.\n     * Composited with position, rotation and scale.\n     * @type {clay.math.Matrix4}\n     */\n    localTransform: null,\n\n    /**\n     * If the local transform is update from SRT(scale, rotation, translation, which is position here) each frame\n     * @type {boolean}\n     */\n    autoUpdateLocalTransform: true,\n\n    /**\n     * Parent of current scene node\n     * @type {?clay.Node}\n     * @private\n     */\n    _parent: null,\n    /**\n     * The root scene mounted. Null if it is a isolated node\n     * @type {?clay.Scene}\n     * @private\n     */\n    _scene: null,\n    /**\n     * @type {boolean}\n     * @private\n     */\n    _needsUpdateWorldTransform: true,\n    /**\n     * @type {boolean}\n     * @private\n     */\n    _inIterating: false,\n\n    // Depth for transparent list sorting\n    __depth: 0\n\n}, function () {\n\n    if (!this.name) {\n        this.name = (this.type || 'NODE') + '_' + (nameId++);\n    }\n\n    if (!this.position) {\n        this.position = new Vector3();\n    }\n    if (!this.rotation) {\n        this.rotation = new Quaternion();\n    }\n    if (!this.scale) {\n        this.scale = new Vector3(1, 1, 1);\n    }\n\n    this.worldTransform = new Matrix4();\n    this.localTransform = new Matrix4();\n\n    this._children = [];\n\n},\n/**@lends clay.Node.prototype. */\n{\n\n    /**\n     * @type {?clay.math.Vector3}\n     * @instance\n     */\n    target: null,\n    /**\n     * If node and its chilren invisible\n     * @type {boolean}\n     * @instance\n     */\n    invisible: false,\n\n    /**\n     * If Node is a skinned mesh\n     * @return {boolean}\n     */\n    isSkinnedMesh: function () {\n        return false;\n    },\n    /**\n     * Return true if it is a renderable scene node, like Mesh and ParticleSystem\n     * @return {boolean}\n     */\n    isRenderable: function () {\n        return false;\n    },\n\n    /**\n     * Set the name of the scene node\n     * @param {string} name\n     */\n    setName: function (name) {\n        var scene = this._scene;\n        if (scene) {\n            var nodeRepository = scene._nodeRepository;\n            delete nodeRepository[this.name];\n            nodeRepository[name] = this;\n        }\n        this.name = name;\n    },\n\n    /**\n     * Add a child node\n     * @param {clay.Node} node\n     */\n    add: function (node) {\n        if (this._inIterating) {\n            console.warn('Add operation can cause unpredictable error when in iterating');\n        }\n        var originalParent = node._parent;\n        if (originalParent === this) {\n            return;\n        }\n        if (originalParent) {\n            originalParent.remove(node);\n        }\n        node._parent = this;\n        this._children.push(node);\n\n        var scene = this._scene;\n        if (scene && scene !== node.scene) {\n            node.traverse(this._addSelfToScene, this);\n        }\n        // Mark children needs update transform\n        // In case child are remove and added again after parent moved\n        node._needsUpdateWorldTransform = true;\n    },\n\n    /**\n     * Remove the given child scene node\n     * @param {clay.Node} node\n     */\n    remove: function (node) {\n        if (this._inIterating) {\n            console.warn('Remove operation can cause unpredictable error when in iterating');\n        }\n        var children = this._children;\n        var idx = children.indexOf(node);\n        if (idx < 0) {\n            return;\n        }\n\n        children.splice(idx, 1);\n        node._parent = null;\n\n        if (this._scene) {\n            node.traverse(this._removeSelfFromScene, this);\n        }\n    },\n\n    /**\n     * Remove all children\n     */\n    removeAll: function () {\n        var children = this._children;\n\n        for (var idx = 0; idx < children.length; idx++) {\n            children[idx]._parent = null;\n\n            if (this._scene) {\n                children[idx].traverse(this._removeSelfFromScene, this);\n            }\n        }\n\n        this._children = [];\n    },\n\n    /**\n     * Get the scene mounted\n     * @return {clay.Scene}\n     */\n    getScene: function () {\n        return this._scene;\n    },\n\n    /**\n     * Get parent node\n     * @return {clay.Scene}\n     */\n    getParent: function () {\n        return this._parent;\n    },\n\n    _removeSelfFromScene: function (descendant) {\n        descendant._scene.removeFromScene(descendant);\n        descendant._scene = null;\n    },\n\n    _addSelfToScene: function (descendant) {\n        this._scene.addToScene(descendant);\n        descendant._scene = this._scene;\n    },\n\n    /**\n     * Return true if it is ancestor of the given scene node\n     * @param {clay.Node} node\n     */\n    isAncestor: function (node) {\n        var parent = node._parent;\n        while(parent) {\n            if (parent === this) {\n                return true;\n            }\n            parent = parent._parent;\n        }\n        return false;\n    },\n\n    /**\n     * Get a new created array of all children nodes\n     * @return {clay.Node[]}\n     */\n    children: function () {\n        return this._children.slice();\n    },\n\n    /**\n     * Get child scene node at given index.\n     * @param {number} idx\n     * @return {clay.Node}\n     */\n    childAt: function (idx) {\n        return this._children[idx];\n    },\n\n    /**\n     * Get first child with the given name\n     * @param {string} name\n     * @return {clay.Node}\n     */\n    getChildByName: function (name) {\n        var children = this._children;\n        for (var i = 0; i < children.length; i++) {\n            if (children[i].name === name) {\n                return children[i];\n            }\n        }\n    },\n\n    /**\n     * Get first descendant have the given name\n     * @param {string} name\n     * @return {clay.Node}\n     */\n    getDescendantByName: function (name) {\n        var children = this._children;\n        for (var i = 0; i < children.length; i++) {\n            var child = children[i];\n            if (child.name === name) {\n                return child;\n            } else {\n                var res = child.getDescendantByName(name);\n                if (res) {\n                    return res;\n                }\n            }\n        }\n    },\n\n    /**\n     * Query descendant node by path\n     * @param {string} path\n     * @return {clay.Node}\n     * @example\n     *  node.queryNode('root/parent/child');\n     */\n    queryNode: function (path) {\n        if (!path) {\n            return;\n        }\n        // TODO Name have slash ?\n        var pathArr = path.split('/');\n        var current = this;\n        for (var i = 0; i < pathArr.length; i++) {\n            var name = pathArr[i];\n            // Skip empty\n            if (!name) {\n                continue;\n            }\n            var found = false;\n            var children = current._children;\n            for (var j = 0; j < children.length; j++) {\n                var child = children[j];\n                if (child.name === name) {\n                    current = child;\n                    found = true;\n                    break;\n                }\n            }\n            // Early return if not found\n            if (!found) {\n                return;\n            }\n        }\n\n        return current;\n    },\n\n    /**\n     * Get query path, relative to rootNode(default is scene)\n     * @param {clay.Node} [rootNode]\n     * @return {string}\n     */\n    getPath: function (rootNode) {\n        if (!this._parent) {\n            return '/';\n        }\n\n        var current = this._parent;\n        var path = this.name;\n        while (current._parent) {\n            path = current.name + '/' + path;\n            if (current._parent == rootNode) {\n                break;\n            }\n            current = current._parent;\n        }\n        if (!current._parent && rootNode) {\n            return null;\n        }\n        return path;\n    },\n\n    /**\n     * Depth first traverse all its descendant scene nodes and\n     * @param {Function} callback\n     * @param {Node} [context]\n     * @param {Function} [filter]\n     */\n    traverse: function (callback, context, filter) {\n\n        this._inIterating = true;\n\n        if (!filter || filter.call(context, this)) {\n            callback.call(context, this);\n        }\n        var _children = this._children;\n        for(var i = 0, len = _children.length; i < len; i++) {\n            _children[i].traverse(callback, context, filter);\n        }\n\n        this._inIterating = false;\n    },\n\n    eachChild: function (callback, context, ctor) {\n        this._inIterating = true;\n\n        var _children = this._children;\n        var noCtor = ctor == null;\n        for(var i = 0, len = _children.length; i < len; i++) {\n            var child = _children[i];\n            if (noCtor || child.constructor === ctor) {\n                callback.call(context, child, i);\n            }\n        }\n\n        this._inIterating = false;\n    },\n\n    /**\n     * Set the local transform and decompose to SRT\n     * @param {clay.math.Matrix4} matrix\n     */\n    setLocalTransform: function (matrix) {\n        mat4.copy(this.localTransform.array, matrix.array);\n        this.decomposeLocalTransform();\n    },\n\n    /**\n     * Decompose the local transform to SRT\n     */\n    decomposeLocalTransform: function (keepScale) {\n        var scale = !keepScale ? this.scale: null;\n        this.localTransform.decomposeMatrix(scale, this.rotation, this.position);\n    },\n\n    /**\n     * Set the world transform and decompose to SRT\n     * @param {clay.math.Matrix4} matrix\n     */\n    setWorldTransform: function (matrix) {\n        mat4.copy(this.worldTransform.array, matrix.array);\n        this.decomposeWorldTransform();\n    },\n\n    /**\n     * Decompose the world transform to SRT\n     * @function\n     */\n    decomposeWorldTransform: (function () {\n\n        var tmp = mat4.create();\n\n        return function (keepScale) {\n            var localTransform = this.localTransform;\n            var worldTransform = this.worldTransform;\n            // Assume world transform is updated\n            if (this._parent) {\n                mat4.invert(tmp, this._parent.worldTransform.array);\n                mat4.multiply(localTransform.array, tmp, worldTransform.array);\n            } else {\n                mat4.copy(localTransform.array, worldTransform.array);\n            }\n            var scale = !keepScale ? this.scale: null;\n            localTransform.decomposeMatrix(scale, this.rotation, this.position);\n        };\n    })(),\n\n    transformNeedsUpdate: function () {\n        return this.position._dirty\n            || this.rotation._dirty\n            || this.scale._dirty;\n    },\n\n    /**\n     * Update local transform from SRT\n     * Notice that local transform will not be updated if _dirty mark of position, rotation, scale is all false\n     */\n    updateLocalTransform: function () {\n        var position = this.position;\n        var rotation = this.rotation;\n        var scale = this.scale;\n\n        if (this.transformNeedsUpdate()) {\n            var m = this.localTransform.array;\n\n            // Transform order, scale->rotation->position\n            mat4.fromRotationTranslation(m, rotation.array, position.array);\n\n            mat4.scale(m, m, scale.array);\n\n            rotation._dirty = false;\n            scale._dirty = false;\n            position._dirty = false;\n\n            this._needsUpdateWorldTransform = true;\n        }\n    },\n\n    /**\n     * Update world transform, assume its parent world transform have been updated\n     * @private\n     */\n    _updateWorldTransformTopDown: function () {\n        var localTransform = this.localTransform.array;\n        var worldTransform = this.worldTransform.array;\n        if (this._parent) {\n            mat4.multiplyAffine(\n                worldTransform,\n                this._parent.worldTransform.array,\n                localTransform\n            );\n        }\n        else {\n            mat4.copy(worldTransform, localTransform);\n        }\n    },\n\n    /**\n     * Update world transform before whole scene is updated.\n     */\n    updateWorldTransform: function () {\n        // Find the root node which transform needs update;\n        var rootNodeIsDirty = this;\n        while (rootNodeIsDirty && rootNodeIsDirty.getParent()\n            && rootNodeIsDirty.getParent().transformNeedsUpdate()\n        ) {\n            rootNodeIsDirty = rootNodeIsDirty.getParent();\n        }2\n        rootNodeIsDirty.update();\n    },\n\n    /**\n     * Update local transform and world transform recursively\n     * @param {boolean} forceUpdateWorld\n     */\n    update: function (forceUpdateWorld) {\n        if (this.autoUpdateLocalTransform) {\n            this.updateLocalTransform();\n        }\n        else {\n            // Transform is manually setted\n            forceUpdateWorld = true;\n        }\n\n        if (forceUpdateWorld || this._needsUpdateWorldTransform) {\n            this._updateWorldTransformTopDown();\n            forceUpdateWorld = true;\n            this._needsUpdateWorldTransform = false;\n        }\n\n        var children = this._children;\n        for(var i = 0, len = children.length; i < len; i++) {\n            children[i].update(forceUpdateWorld);\n        }\n    },\n\n    /**\n     * Get bounding box of node\n     * @param  {Function} [filter]\n     * @param  {clay.math.BoundingBox} [out]\n     * @return {clay.math.BoundingBox}\n     */\n    // TODO Skinning\n    getBoundingBox: (function () {\n        function defaultFilter (el) {\n            return !el.invisible && el.geometry;\n        }\n        var tmpBBox = new BoundingBox();\n        var tmpMat4 = new Matrix4();\n        var invWorldTransform = new Matrix4();\n        return function (filter, out) {\n            out = out || new BoundingBox();\n            filter = filter || defaultFilter;\n\n            if (this._parent) {\n                Matrix4.invert(invWorldTransform, this._parent.worldTransform);\n            }\n            else {\n                Matrix4.identity(invWorldTransform);\n            }\n\n            this.traverse(function (mesh) {\n                if (mesh.geometry && mesh.geometry.boundingBox) {\n                    tmpBBox.copy(mesh.geometry.boundingBox);\n                    Matrix4.multiply(tmpMat4, invWorldTransform, mesh.worldTransform);\n                    tmpBBox.applyTransform(tmpMat4);\n                    out.union(tmpBBox);\n                }\n            }, this, defaultFilter);\n\n            return out;\n        };\n    })(),\n\n    /**\n     * Get world position, extracted from world transform\n     * @param  {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    getWorldPosition: function (out) {\n        // PENDING\n        if (this.transformNeedsUpdate()) {\n            this.updateWorldTransform();\n        }\n        var m = this.worldTransform.array;\n        if (out) {\n            var arr = out.array;\n            arr[0] = m[12];\n            arr[1] = m[13];\n            arr[2] = m[14];\n            return out;\n        }\n        else {\n            return new Vector3(m[12], m[13], m[14]);\n        }\n    },\n\n    /**\n     * Clone a new node\n     * @return {Node}\n     */\n    clone: function () {\n        var node = new this.constructor();\n        var children = this._children;\n\n        node.setName(this.name);\n        node.position.copy(this.position);\n        node.rotation.copy(this.rotation);\n        node.scale.copy(this.scale);\n\n        for (var i = 0; i < children.length; i++) {\n            node.add(children[i].clone());\n        }\n        return node;\n    },\n\n    /**\n     * Rotate the node around a axis by angle degrees, axis passes through point\n     * @param {clay.math.Vector3} point Center point\n     * @param {clay.math.Vector3} axis  Center axis\n     * @param {number}       angle Rotation angle\n     * @see http://docs.unity3d.com/Documentation/ScriptReference/Transform.RotateAround.html\n     * @function\n     */\n    rotateAround: (function () {\n        var v = new Vector3();\n        var RTMatrix = new Matrix4();\n\n        // TODO improve performance\n        return function (point, axis, angle) {\n\n            v.copy(this.position).subtract(point);\n\n            var localTransform = this.localTransform;\n            localTransform.identity();\n            // parent node\n            localTransform.translate(point);\n            localTransform.rotate(angle, axis);\n\n            RTMatrix.fromRotationTranslation(this.rotation, v);\n            localTransform.multiply(RTMatrix);\n            localTransform.scale(this.scale);\n\n            this.decomposeLocalTransform();\n            this._needsUpdateWorldTransform = true;\n        };\n    })(),\n\n    /**\n     * @param {clay.math.Vector3} target\n     * @param {clay.math.Vector3} [up]\n     * @see http://www.opengl.org/sdk/docs/man2/xhtml/gluLookAt.xml\n     * @function\n     */\n    lookAt: (function () {\n        var m = new Matrix4();\n        return function (target, up) {\n            m.lookAt(this.position, target, up || this.localTransform.y).invert();\n            this.setLocalTransform(m);\n\n            this.target = target;\n        };\n    })()\n});\n\nexport default Node;\n","import Node from './Node';\n\n/**\n * @constructor clay.Light\n * @extends clay.Node\n */\nvar Light = Node.extend(function(){\n    return /** @lends clay.Light# */ {\n        /**\n         * Light RGB color\n         * @type {number[]}\n         */\n        color: [1, 1, 1],\n\n        /**\n         * Light intensity\n         * @type {number}\n         */\n        intensity: 1.0,\n\n        // Config for shadow map\n        /**\n         * If light cast shadow\n         * @type {boolean}\n         */\n        castShadow: true,\n\n        /**\n         * Shadow map size\n         * @type {number}\n         */\n        shadowResolution: 512,\n\n        /**\n         * Light group, shader with same `lightGroup` will be affected\n         *\n         * Only useful in forward rendering\n         * @type {number}\n         */\n        group: 0\n    };\n},\n/** @lends clay.Light.prototype. */\n{\n    /**\n     * Light type\n     * @type {string}\n     * @memberOf clay.Light#\n     */\n    type: '',\n\n    /**\n     * @return {clay.Light}\n     * @memberOf clay.Light.prototype\n     */\n    clone: function() {\n        var light = Node.prototype.clone.call(this);\n        light.color = Array.prototype.slice.call(this.color);\n        light.intensity = this.intensity;\n        light.castShadow = this.castShadow;\n        light.shadowResolution = this.shadowResolution;\n\n        return light;\n    }\n});\n\nexport default Light;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor\n * @alias clay.math.Plane\n * @param {clay.math.Vector3} [normal]\n * @param {number} [distance]\n */\nvar Plane = function(normal, distance) {\n    /**\n     * Normal of the plane\n     * @type {clay.math.Vector3}\n     */\n    this.normal = normal || new Vector3(0, 1, 0);\n\n    /**\n     * Constant of the plane equation, used as distance to the origin\n     * @type {number}\n     */\n    this.distance = distance || 0;\n};\n\nPlane.prototype = {\n\n    constructor: Plane,\n\n    /**\n     * Distance from a given point to the plane\n     * @param  {clay.math.Vector3} point\n     * @return {number}\n     */\n    distanceToPoint: function(point) {\n        return vec3.dot(point.array, this.normal.array) - this.distance;\n    },\n\n    /**\n     * Calculate the projection point on the plane\n     * @param  {clay.math.Vector3} point\n     * @param  {clay.math.Vector3} out\n     * @return {clay.math.Vector3}\n     */\n    projectPoint: function(point, out) {\n        if (!out) {\n            out = new Vector3();\n        }\n        var d = this.distanceToPoint(point);\n        vec3.scaleAndAdd(out.array, point.array, this.normal.array, -d);\n        out._dirty = true;\n        return out;\n    },\n\n    /**\n     * Normalize the plane's normal and calculate the distance\n     */\n    normalize: function() {\n        var invLen = 1 / vec3.len(this.normal.array);\n        vec3.scale(this.normal.array, invLen);\n        this.distance *= invLen;\n    },\n\n    /**\n     * If the plane intersect a frustum\n     * @param  {clay.math.Frustum} Frustum\n     * @return {boolean}\n     */\n    intersectFrustum: function(frustum) {\n        // Check if all coords of frustum is on plane all under plane\n        var coords = frustum.vertices;\n        var normal = this.normal.array;\n        var onPlane = vec3.dot(coords[0].array, normal) > this.distance;\n        for (var i = 1; i < 8; i++) {\n            if ((vec3.dot(coords[i].array, normal) > this.distance) != onPlane) {\n                return true;\n            }\n        }\n    },\n\n    /**\n     * Calculate the intersection point between plane and a given line\n     * @function\n     * @param {clay.math.Vector3} start start point of line\n     * @param {clay.math.Vector3} end end point of line\n     * @param {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    intersectLine: (function() {\n        var rd = vec3.create();\n        return function(start, end, out) {\n            var d0 = this.distanceToPoint(start);\n            var d1 = this.distanceToPoint(end);\n            if ((d0 > 0 && d1 > 0) || (d0 < 0 && d1 < 0)) {\n                return null;\n            }\n            // Ray intersection\n            var pn = this.normal.array;\n            var d = this.distance;\n            var ro = start.array;\n            // direction\n            vec3.sub(rd, end.array, start.array);\n            vec3.normalize(rd, rd);\n\n            var divider = vec3.dot(pn, rd);\n            // ray is parallel to the plane\n            if (divider === 0) {\n                return null;\n            }\n            if (!out) {\n                out = new Vector3();\n            }\n            var t = (vec3.dot(pn, ro) - d) / divider;\n            vec3.scaleAndAdd(out.array, ro, rd, -t);\n            out._dirty = true;\n            return out;\n        };\n    })(),\n\n    /**\n     * Apply an affine transform matrix to plane\n     * @function\n     * @return {clay.math.Matrix4}\n     */\n    applyTransform: (function() {\n        var inverseTranspose = mat4.create();\n        var normalv4 = vec4.create();\n        var pointv4 = vec4.create();\n        pointv4[3] = 1;\n        return function(m4) {\n            m4 = m4.array;\n            // Transform point on plane\n            vec3.scale(pointv4, this.normal.array, this.distance);\n            vec4.transformMat4(pointv4, pointv4, m4);\n            this.distance = vec3.dot(pointv4, this.normal.array);\n            // Transform plane normal\n            mat4.invert(inverseTranspose, m4);\n            mat4.transpose(inverseTranspose, inverseTranspose);\n            normalv4[3] = 0;\n            vec3.copy(normalv4, this.normal.array);\n            vec4.transformMat4(normalv4, normalv4, inverseTranspose);\n            vec3.copy(this.normal.array, normalv4);\n        };\n    })(),\n\n    /**\n     * Copy from another plane\n     * @param  {clay.math.Vector3} plane\n     */\n    copy: function(plane) {\n        vec3.copy(this.normal.array, plane.normal.array);\n        this.normal._dirty = true;\n        this.distance = plane.distance;\n    },\n\n    /**\n     * Clone a new plane\n     * @return {clay.math.Plane}\n     */\n    clone: function() {\n        var plane = new Plane();\n        plane.copy(this);\n        return plane;\n    }\n};\n\nexport default Plane;\n","import Vector3 from './Vector3';\nimport BoundingBox from './BoundingBox';\nimport Plane from './Plane';\n\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar vec3Set = vec3.set;\nvar vec3Copy = vec3.copy;\nvar vec3TranformMat4 = vec3.transformMat4;\nvar mathMin = Math.min;\nvar mathMax = Math.max;\n/**\n * @constructor\n * @alias clay.math.Frustum\n */\nvar Frustum = function() {\n\n    /**\n     * Eight planes to enclose the frustum\n     * @type {clay.math.Plane[]}\n     */\n    this.planes = [];\n\n    for (var i = 0; i < 6; i++) {\n        this.planes.push(new Plane());\n    }\n\n    /**\n     * Bounding box of frustum\n     * @type {clay.math.BoundingBox}\n     */\n    this.boundingBox = new BoundingBox();\n\n    /**\n     * Eight vertices of frustum\n     * @type {Float32Array[]}\n     */\n    this.vertices = [];\n    for (var i = 0; i < 8; i++) {\n        this.vertices[i] = vec3.fromValues(0, 0, 0);\n    }\n};\n\nFrustum.prototype = {\n\n    // http://web.archive.org/web/20120531231005/http://crazyjoke.free.fr/doc/3D/plane%20extraction.pdf\n    /**\n     * Set frustum from a projection matrix\n     * @param {clay.math.Matrix4} projectionMatrix\n     */\n    setFromProjection: function(projectionMatrix) {\n\n        var planes = this.planes;\n        var m = projectionMatrix.array;\n        var m0 = m[0], m1 = m[1], m2 = m[2], m3 = m[3];\n        var m4 = m[4], m5 = m[5], m6 = m[6], m7 = m[7];\n        var m8 = m[8], m9 = m[9], m10 = m[10], m11 = m[11];\n        var m12 = m[12], m13 = m[13], m14 = m[14], m15 = m[15];\n\n        // Update planes\n        vec3Set(planes[0].normal.array, m3 - m0, m7 - m4, m11 - m8);\n        planes[0].distance = -(m15 - m12);\n        planes[0].normalize();\n\n        vec3Set(planes[1].normal.array, m3 + m0, m7 + m4, m11 + m8);\n        planes[1].distance = -(m15 + m12);\n        planes[1].normalize();\n\n        vec3Set(planes[2].normal.array, m3 + m1, m7 + m5, m11 + m9);\n        planes[2].distance = -(m15 + m13);\n        planes[2].normalize();\n\n        vec3Set(planes[3].normal.array, m3 - m1, m7 - m5, m11 - m9);\n        planes[3].distance = -(m15 - m13);\n        planes[3].normalize();\n\n        vec3Set(planes[4].normal.array, m3 - m2, m7 - m6, m11 - m10);\n        planes[4].distance = -(m15 - m14);\n        planes[4].normalize();\n\n        vec3Set(planes[5].normal.array, m3 + m2, m7 + m6, m11 + m10);\n        planes[5].distance = -(m15 + m14);\n        planes[5].normalize();\n\n        // Perspective projection\n        var boundingBox = this.boundingBox;\n        if (m15 === 0)  {\n            var aspect = m5 / m0;\n            var zNear = -m14 / (m10 - 1);\n            var zFar = -m14 / (m10 + 1);\n            var farY = -zFar / m5;\n            var nearY = -zNear / m5;\n            // Update bounding box\n            boundingBox.min.set(-farY * aspect, -farY, zFar);\n            boundingBox.max.set(farY * aspect, farY, zNear);\n            // update vertices\n            var vertices = this.vertices;\n            //--- min z\n            // min x\n            vec3Set(vertices[0], -farY * aspect, -farY, zFar);\n            vec3Set(vertices[1], -farY * aspect, farY, zFar);\n            // max x\n            vec3Set(vertices[2], farY * aspect, -farY, zFar);\n            vec3Set(vertices[3], farY * aspect, farY, zFar);\n            //-- max z\n            vec3Set(vertices[4], -nearY * aspect, -nearY, zNear);\n            vec3Set(vertices[5], -nearY * aspect, nearY, zNear);\n            vec3Set(vertices[6], nearY * aspect, -nearY, zNear);\n            vec3Set(vertices[7], nearY * aspect, nearY, zNear);\n        }\n        else { // Orthographic projection\n            var left = (-1 - m12) / m0;\n            var right = (1 - m12) / m0;\n            var top = (1 - m13) / m5;\n            var bottom = (-1 - m13) / m5;\n            var near = (-1 - m14) / m10;\n            var far = (1 - m14) / m10;\n\n\n            boundingBox.min.set(Math.min(left, right), Math.min(bottom, top), Math.min(far, near));\n            boundingBox.max.set(Math.max(right, left), Math.max(top, bottom), Math.max(near, far));\n\n            var min = boundingBox.min.array;\n            var max = boundingBox.max.array;\n            var vertices = this.vertices;\n            //--- min z\n            // min x\n            vec3Set(vertices[0], min[0], min[1], min[2]);\n            vec3Set(vertices[1], min[0], max[1], min[2]);\n            // max x\n            vec3Set(vertices[2], max[0], min[1], min[2]);\n            vec3Set(vertices[3], max[0], max[1], min[2]);\n            //-- max z\n            vec3Set(vertices[4], min[0], min[1], max[2]);\n            vec3Set(vertices[5], min[0], max[1], max[2]);\n            vec3Set(vertices[6], max[0], min[1], max[2]);\n            vec3Set(vertices[7], max[0], max[1], max[2]);\n        }\n    },\n\n    /**\n     * Apply a affine transform matrix and set to the given bounding box\n     * @function\n     * @param {clay.math.BoundingBox}\n     * @param {clay.math.Matrix4}\n     * @return {clay.math.BoundingBox}\n     */\n    getTransformedBoundingBox: (function() {\n\n        var tmpVec3 = vec3.create();\n\n        return function(bbox, matrix) {\n            var vertices = this.vertices;\n\n            var m4 = matrix.array;\n            var min = bbox.min;\n            var max = bbox.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            var v = vertices[0];\n            vec3TranformMat4(tmpVec3, v, m4);\n            vec3Copy(minArr, tmpVec3);\n            vec3Copy(maxArr, tmpVec3);\n\n            for (var i = 1; i < 8; i++) {\n                v = vertices[i];\n                vec3TranformMat4(tmpVec3, v, m4);\n\n                minArr[0] = mathMin(tmpVec3[0], minArr[0]);\n                minArr[1] = mathMin(tmpVec3[1], minArr[1]);\n                minArr[2] = mathMin(tmpVec3[2], minArr[2]);\n\n                maxArr[0] = mathMax(tmpVec3[0], maxArr[0]);\n                maxArr[1] = mathMax(tmpVec3[1], maxArr[1]);\n                maxArr[2] = mathMax(tmpVec3[2], maxArr[2]);\n            }\n\n            min._dirty = true;\n            max._dirty = true;\n\n            return bbox;\n        };\n    }) ()\n};\nexport default Frustum;\n","import Vector3 from './Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\nvar EPSILON = 1e-5;\n\n/**\n * @constructor\n * @alias clay.math.Ray\n * @param {clay.math.Vector3} [origin]\n * @param {clay.math.Vector3} [direction]\n */\nvar Ray = function (origin, direction) {\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.origin = origin || new Vector3();\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.direction = direction || new Vector3();\n};\n\nRay.prototype = {\n\n    constructor: Ray,\n\n    // http://www.siggraph.org/education/materials/HyperGraph/raytrace/rayplane_intersection.htm\n    /**\n     * Calculate intersection point between ray and a give plane\n     * @param  {clay.math.Plane} plane\n     * @param  {clay.math.Vector3} [out]\n     * @return {clay.math.Vector3}\n     */\n    intersectPlane: function (plane, out) {\n        var pn = plane.normal.array;\n        var d = plane.distance;\n        var ro = this.origin.array;\n        var rd = this.direction.array;\n\n        var divider = vec3.dot(pn, rd);\n        // ray is parallel to the plane\n        if (divider === 0) {\n            return null;\n        }\n        if (!out) {\n            out = new Vector3();\n        }\n        var t = (vec3.dot(pn, ro) - d) / divider;\n        vec3.scaleAndAdd(out.array, ro, rd, -t);\n        out._dirty = true;\n        return out;\n    },\n\n    /**\n     * Mirror the ray against plane\n     * @param  {clay.math.Plane} plane\n     */\n    mirrorAgainstPlane: function (plane) {\n        // Distance to plane\n        var d = vec3.dot(plane.normal.array, this.direction.array);\n        vec3.scaleAndAdd(this.direction.array, this.direction.array, plane.normal.array, -d * 2);\n        this.direction._dirty = true;\n    },\n\n    distanceToPoint: (function () {\n        var v = vec3.create();\n        return function (point) {\n            vec3.sub(v, point, this.origin.array);\n            // Distance from projection point to origin\n            var b = vec3.dot(v, this.direction.array);\n            if (b < 0) {\n                return vec3.distance(this.origin.array, point);\n            }\n            // Squared distance from center to origin\n            var c2 = vec3.lenSquared(v);\n            // Squared distance from center to projection point\n            return Math.sqrt(c2 - b * b);\n        };\n    })(),\n\n    /**\n     * Calculate intersection point between ray and sphere\n     * @param  {clay.math.Vector3} center\n     * @param  {number} radius\n     * @param  {clay.math.Vector3} out\n     * @return {clay.math.Vector3}\n     */\n    intersectSphere: (function () {\n        var v = vec3.create();\n        return function (center, radius, out) {\n            var origin = this.origin.array;\n            var direction = this.direction.array;\n            center = center.array;\n            vec3.sub(v, center, origin);\n            // Distance from projection point to origin\n            var b = vec3.dot(v, direction);\n            // Squared distance from center to origin\n            var c2 = vec3.squaredLength(v);\n            // Squared distance from center to projection point\n            var d2 = c2 - b * b;\n\n            var r2 = radius * radius;\n            // No intersection\n            if (d2 > r2) {\n                return;\n            }\n\n            var a = Math.sqrt(r2 - d2);\n            // First intersect point\n            var t0 = b - a;\n            // Second intersect point\n            var t1 = b + a;\n\n            if (!out) {\n                out = new Vector3();\n            }\n            if (t0 < 0) {\n                if (t1 < 0) {\n                    return null;\n                }\n                else {\n                    vec3.scaleAndAdd(out.array, origin, direction, t1);\n                    return out;\n                }\n            }\n            else {\n                vec3.scaleAndAdd(out.array, origin, direction, t0);\n                return out;\n            }\n        };\n    })(),\n\n    // http://www.scratchapixel.com/lessons/3d-basic-lessons/lesson-7-intersecting-simple-shapes/ray-box-intersection/\n    /**\n     * Calculate intersection point between ray and bounding box\n     * @param {clay.math.BoundingBox} bbox\n     * @param {clay.math.Vector3}\n     * @return {clay.math.Vector3}\n     */\n    intersectBoundingBox: function (bbox, out) {\n        var dir = this.direction.array;\n        var origin = this.origin.array;\n        var min = bbox.min.array;\n        var max = bbox.max.array;\n\n        var invdirx = 1 / dir[0];\n        var invdiry = 1 / dir[1];\n        var invdirz = 1 / dir[2];\n\n        var tmin, tmax, tymin, tymax, tzmin, tzmax;\n        if (invdirx >= 0) {\n            tmin = (min[0] - origin[0]) * invdirx;\n            tmax = (max[0] - origin[0]) * invdirx;\n        }\n        else {\n            tmax = (min[0] - origin[0]) * invdirx;\n            tmin = (max[0] - origin[0]) * invdirx;\n        }\n        if (invdiry >= 0) {\n            tymin = (min[1] - origin[1]) * invdiry;\n            tymax = (max[1] - origin[1]) * invdiry;\n        }\n        else {\n            tymax = (min[1] - origin[1]) * invdiry;\n            tymin = (max[1] - origin[1]) * invdiry;\n        }\n\n        if ((tmin > tymax) || (tymin > tmax)) {\n            return null;\n        }\n\n        if (tymin > tmin || tmin !== tmin) {\n            tmin = tymin;\n        }\n        if (tymax < tmax || tmax !== tmax) {\n            tmax = tymax;\n        }\n\n        if (invdirz >= 0) {\n            tzmin = (min[2] - origin[2]) * invdirz;\n            tzmax = (max[2] - origin[2]) * invdirz;\n        }\n        else {\n            tzmax = (min[2] - origin[2]) * invdirz;\n            tzmin = (max[2] - origin[2]) * invdirz;\n        }\n\n        if ((tmin > tzmax) || (tzmin > tmax)) {\n            return null;\n        }\n\n        if (tzmin > tmin || tmin !== tmin) {\n            tmin = tzmin;\n        }\n        if (tzmax < tmax || tmax !== tmax) {\n            tmax = tzmax;\n        }\n        if (tmax < 0) {\n            return null;\n        }\n\n        var t = tmin >= 0 ? tmin : tmax;\n\n        if (!out) {\n            out = new Vector3();\n        }\n        vec3.scaleAndAdd(out.array, origin, dir, t);\n        return out;\n    },\n\n    // http://en.wikipedia.org/wiki/M%C3%B6ller%E2%80%93Trumbore_intersection_algorithm\n    /**\n     * Calculate intersection point between ray and three triangle vertices\n     * @param {clay.math.Vector3} a\n     * @param {clay.math.Vector3} b\n     * @param {clay.math.Vector3} c\n     * @param {boolean}           singleSided, CW triangle will be ignored\n     * @param {clay.math.Vector3} [out]\n     * @param {clay.math.Vector3} [barycenteric] barycentric coords\n     * @return {clay.math.Vector3}\n     */\n    intersectTriangle: (function () {\n\n        var eBA = vec3.create();\n        var eCA = vec3.create();\n        var AO = vec3.create();\n        var vCross = vec3.create();\n\n        return function (a, b, c, singleSided, out, barycenteric) {\n            var dir = this.direction.array;\n            var origin = this.origin.array;\n            a = a.array;\n            b = b.array;\n            c = c.array;\n\n            vec3.sub(eBA, b, a);\n            vec3.sub(eCA, c, a);\n\n            vec3.cross(vCross, eCA, dir);\n\n            var det = vec3.dot(eBA, vCross);\n\n            if (singleSided) {\n                if (det > -EPSILON) {\n                    return null;\n                }\n            }\n            else {\n                if (det > -EPSILON && det < EPSILON) {\n                    return null;\n                }\n            }\n\n            vec3.sub(AO, origin, a);\n            var u = vec3.dot(vCross, AO) / det;\n            if (u < 0 || u > 1) {\n                return null;\n            }\n\n            vec3.cross(vCross, eBA, AO);\n            var v = vec3.dot(dir, vCross) / det;\n\n            if (v < 0 || v > 1 || (u + v > 1)) {\n                return null;\n            }\n\n            vec3.cross(vCross, eBA, eCA);\n            var t = -vec3.dot(AO, vCross) / det;\n\n            if (t < 0) {\n                return null;\n            }\n\n            if (!out) {\n                out = new Vector3();\n            }\n            if (barycenteric) {\n                Vector3.set(barycenteric, (1 - u - v), u, v);\n            }\n            vec3.scaleAndAdd(out.array, origin, dir, t);\n\n            return out;\n        };\n    })(),\n\n    /**\n     * Apply an affine transform matrix to the ray\n     * @return {clay.math.Matrix4} matrix\n     */\n    applyTransform: function (matrix) {\n        Vector3.add(this.direction, this.direction, this.origin);\n        Vector3.transformMat4(this.origin, this.origin, matrix);\n        Vector3.transformMat4(this.direction, this.direction, matrix);\n\n        Vector3.sub(this.direction, this.direction, this.origin);\n        Vector3.normalize(this.direction, this.direction);\n    },\n\n    /**\n     * Copy values from another ray\n     * @param {clay.math.Ray} ray\n     */\n    copy: function (ray) {\n        Vector3.copy(this.origin, ray.origin);\n        Vector3.copy(this.direction, ray.direction);\n    },\n\n    /**\n     * Clone a new ray\n     * @return {clay.math.Ray}\n     */\n    clone: function () {\n        var ray = new Ray();\n        ray.copy(this);\n        return ray;\n    }\n};\n\nexport default Ray;\n","import Node from './Node';\nimport Matrix4 from './math/Matrix4';\nimport Frustum from './math/Frustum';\nimport Ray from './math/Ray';\n\nimport glMatrix from './dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor clay.Camera\n * @extends clay.Node\n */\nvar Camera = Node.extend(function () {\n    return /** @lends clay.Camera# */ {\n        /**\n         * Camera projection matrix\n         * @type {clay.math.Matrix4}\n         */\n        projectionMatrix: new Matrix4(),\n\n        /**\n         * Inverse of camera projection matrix\n         * @type {clay.math.Matrix4}\n         */\n        invProjectionMatrix: new Matrix4(),\n\n        /**\n         * View matrix, equal to inverse of camera's world matrix\n         * @type {clay.math.Matrix4}\n         */\n        viewMatrix: new Matrix4(),\n\n        /**\n         * Camera frustum in view space\n         * @type {clay.math.Frustum}\n         */\n        frustum: new Frustum()\n    };\n}, function () {\n    this.update(true);\n},\n/** @lends clay.Camera.prototype */\n{\n\n    update: function (force) {\n        Node.prototype.update.call(this, force);\n        Matrix4.invert(this.viewMatrix, this.worldTransform);\n\n        this.updateProjectionMatrix();\n        Matrix4.invert(this.invProjectionMatrix, this.projectionMatrix);\n\n        this.frustum.setFromProjection(this.projectionMatrix);\n    },\n\n    /**\n     * Set camera view matrix\n     */\n    setViewMatrix: function (viewMatrix) {\n        Matrix4.copy(this.viewMatrix, viewMatrix);\n        Matrix4.invert(this.worldTransform, viewMatrix);\n        this.decomposeWorldTransform();\n    },\n\n    /**\n     * Decompose camera projection matrix\n     */\n    decomposeProjectionMatrix: function () {},\n\n    /**\n     * Set camera projection matrix\n     * @param {clay.math.Matrix4} projectionMatrix\n     */\n    setProjectionMatrix: function (projectionMatrix) {\n        Matrix4.copy(this.projectionMatrix, projectionMatrix);\n        Matrix4.invert(this.invProjectionMatrix, projectionMatrix);\n        this.decomposeProjectionMatrix();\n    },\n    /**\n     * Update projection matrix, called after update\n     */\n    updateProjectionMatrix: function () {},\n\n    /**\n     * Cast a picking ray from camera near plane to far plane\n     * @function\n     * @param {clay.math.Vector2} ndc\n     * @param {clay.math.Ray} [out]\n     * @return {clay.math.Ray}\n     */\n    castRay: (function () {\n        var v4 = vec4.create();\n        return function (ndc, out) {\n            var ray = out !== undefined ? out : new Ray();\n            var x = ndc.array[0];\n            var y = ndc.array[1];\n            vec4.set(v4, x, y, -1, 1);\n            vec4.transformMat4(v4, v4, this.invProjectionMatrix.array);\n            vec4.transformMat4(v4, v4, this.worldTransform.array);\n            vec3.scale(ray.origin.array, v4, 1 / v4[3]);\n\n            vec4.set(v4, x, y, 1, 1);\n            vec4.transformMat4(v4, v4, this.invProjectionMatrix.array);\n            vec4.transformMat4(v4, v4, this.worldTransform.array);\n            vec3.scale(v4, v4, 1 / v4[3]);\n            vec3.sub(ray.direction.array, v4, ray.origin.array);\n\n            vec3.normalize(ray.direction.array, ray.direction.array);\n            ray.direction._dirty = true;\n            ray.origin._dirty = true;\n\n            return ray;\n        };\n    })()\n\n    /**\n     * @function\n     * @name clone\n     * @return {clay.Camera}\n     * @memberOf clay.Camera.prototype\n     */\n});\n\nexport default Camera;\n","import Node from './Node';\nimport Light from './Light';\nimport Camera from './Camera';\nimport BoundingBox from './math/BoundingBox';\nimport util from './core/util';\n\nvar programKeyCache = {};\n\nfunction getProgramKey(lightNumbers) {\n    var defineStr = [];\n    var lightTypes = Object.keys(lightNumbers);\n    lightTypes.sort();\n    for (var i = 0; i < lightTypes.length; i++) {\n        var lightType = lightNumbers[i];\n        defineStr.push(lightType + ' ' + lightNumbers[lightType]);\n    }\n    var key = defineStr.join('\\n');\n\n    if (programKeyCache[key]) {\n        return programKeyCache[key];\n    }\n\n    var id = util.genGUID();\n    programKeyCache[key] = id;\n    return id;\n}\n\n/**\n * @constructor clay.Scene\n * @extends clay.Node\n */\nvar Scene = Node.extend(function () {\n    return /** @lends clay.Scene# */ {\n        /**\n         * Global material of scene\n         * @type {clay.Material}\n         */\n        material: null,\n\n        /**\n         * @type {boolean}\n         */\n        autoUpdate: true,\n\n        /**\n         * Opaque renderable list, it will be updated automatically\n         * @type {clay.Renderable[]}\n         * @readonly\n         */\n        opaqueList: [],\n\n        /**\n         * Opaque renderable list, it will be updated automatically\n         * @type {clay.Renderable[]}\n         * @readonly\n         */\n        transparentList: [],\n\n        lights: [],\n\n\n        /**\n         * Scene bounding box in view space.\n         * Used when camera needs to adujst the near and far plane automatically\n         * so that the view frustum contains the visible objects as tightly as possible.\n         * Notice:\n         *  It is updated after rendering (in the step of frustum culling passingly). So may be not so accurate, but saves a lot of calculation\n         *\n         * @type {clay.math.BoundingBox}\n         */\n        viewBoundingBoxLastFrame: new BoundingBox(),\n\n        // Uniforms for shadow map.\n        shadowUniforms: {},\n\n        _cameraList: [],\n\n        // Properties to save the light information in the scene\n        // Will be set in the render function\n        _lightUniforms: {},\n\n        _previousLightNumber: {},\n\n        _lightNumber: {\n            // groupId: {\n                // POINT_LIGHT: 0,\n                // DIRECTIONAL_LIGHT: 0,\n                // SPOT_LIGHT: 0,\n                // AMBIENT_LIGHT: 0,\n                // AMBIENT_SH_LIGHT: 0\n            // }\n        },\n\n        _lightProgramKeys: {},\n\n        _opaqueObjectCount: 0,\n        _transparentObjectCount: 0,\n\n        _nodeRepository: {},\n\n    };\n}, function () {\n    this._scene = this;\n},\n/** @lends clay.Scene.prototype. */\n{\n    /**\n     * Add node to scene\n     * @param {Node} node\n     */\n    addToScene: function (node) {\n        if (node instanceof Camera) {\n            if (this._cameraList.length > 0) {\n                console.warn('Found multiple camera in one scene. Use the fist one.');\n            }\n            this._cameraList.push(node);\n        }\n        if (node.name) {\n            this._nodeRepository[node.name] = node;\n        }\n    },\n\n    /**\n     * Remove node from scene\n     * @param {Node} node\n     */\n    removeFromScene: function (node) {\n        if (node instanceof Camera) {\n            var idx = this._cameraList.indexOf(node);\n            if (idx >= 0) {\n                this._cameraList.splice(idx, 1);\n            }\n        }\n        if (node.name) {\n            delete this._nodeRepository[node.name];\n        }\n    },\n\n    /**\n     * Get node by name\n     * @param  {string} name\n     * @return {Node}\n     * @DEPRECATED\n     */\n    getNode: function (name) {\n        return this._nodeRepository[name];\n    },\n\n    /**\n     * Clone a new scene node recursively, including material, skeleton.\n     * Shader and geometry instances will not been cloned\n     * @param  {clay.Node} node\n     * @return {clay.Node}\n     */\n    cloneNode: function (node) {\n        var newNode = node.clone();\n        var materialsMap = {};\n\n        var cloneSkeleton = function (current, currentNew) {\n            if (current.skeleton) {\n                currentNew.skeleton = current.skeleton.clone(node, newNode);\n                currentNew.joints = current.joints.slice();\n            }\n            if (current.material) {\n                materialsMap[current.material.__uid__] = {\n                    oldMat: current.material\n                };\n            }\n            for (var i = 0; i < current._children.length; i++) {\n                cloneSkeleton(current._children[i], currentNew._children[i]);\n            }\n        };\n\n        cloneSkeleton(node, newNode);\n\n        for (var guid in materialsMap) {\n            materialsMap[guid].newMat = materialsMap[guid].oldMat.clone();\n        }\n\n        // Replace material\n        newNode.traverse(function (current) {\n            if (current.material) {\n                current.material = materialsMap[current.material.__uid__].newMat;\n            }\n        });\n\n        return newNode;\n    },\n\n\n    /**\n     * Scene update\n     * @param  {boolean} force\n     * @param  {boolean} notUpdateLights\n     *         Useful in deferred pipeline\n     */\n    update: function (force, notUpdateLights) {\n        if (!(this.autoUpdate || force)) {\n            return;\n        }\n        Node.prototype.update.call(this, force);\n\n        var lights = this.lights;\n        var sceneMaterialTransparent = this.material && this.material.transparent;\n\n        this._opaqueObjectCount = 0;\n        this._transparentObjectCount = 0;\n\n        lights.length = 0;\n\n        this._updateRenderList(this, sceneMaterialTransparent);\n\n        this.opaqueList.length = this._opaqueObjectCount;\n        this.transparentList.length = this._transparentObjectCount;\n\n        // reset\n        if (!notUpdateLights) {\n            this._previousLightNumber = this._lightNumber;\n\n            var lightNumber = {};\n            for (var i = 0; i < lights.length; i++) {\n                var light = lights[i];\n                var group = light.group;\n                if (!lightNumber[group]) {\n                    lightNumber[group] = {};\n                }\n                // User can use any type of light\n                lightNumber[group][light.type] = lightNumber[group][light.type] || 0;\n                lightNumber[group][light.type]++;\n            }\n            this._lightNumber = lightNumber;\n\n            for (var groupId in lightNumber) {\n                this._lightProgramKeys[groupId] = getProgramKey(lightNumber[groupId]);\n            }\n\n            this._updateLightUniforms();\n        }\n    },\n\n    getMainCamera: function () {\n        return this._cameraList[0];\n    },\n\n    // Traverse the scene and add the renderable\n    // object to the render list\n    _updateRenderList: function (parent, sceneMaterialTransparent) {\n        if (parent.invisible) {\n            return;\n        }\n\n        for (var i = 0; i < parent._children.length; i++) {\n            var child = parent._children[i];\n\n            if (child instanceof Light) {\n                this.lights.push(child);\n            }\n            else if (child.isRenderable()) {\n                if (child.material.transparent || sceneMaterialTransparent) {\n                    this.transparentList[this._transparentObjectCount++] = child;\n                }\n                else {\n                    this.opaqueList[this._opaqueObjectCount++] = child;\n                }\n            }\n            if (child._children.length > 0) {\n                this._updateRenderList(child);\n            }\n        }\n    },\n\n    _updateLightUniforms: function () {\n        var lights = this.lights;\n        // Put the light cast shadow before the light not cast shadow\n        lights.sort(lightSortFunc);\n\n        var lightUniforms = this._lightUniforms;\n        for (var group in lightUniforms) {\n            for (var symbol in lightUniforms[group]) {\n                lightUniforms[group][symbol].value.length = 0;\n            }\n        }\n        for (var i = 0; i < lights.length; i++) {\n\n            var light = lights[i];\n            var group = light.group;\n\n            for (var symbol in light.uniformTemplates) {\n                var uniformTpl = light.uniformTemplates[symbol];\n                var value = uniformTpl.value(light);\n                if (value == null) {\n                    continue;\n                }\n                if (!lightUniforms[group]) {\n                    lightUniforms[group] = {};\n                }\n                if (!lightUniforms[group][symbol]) {\n                    lightUniforms[group][symbol] = {\n                        type: '',\n                        value: []\n                    };\n                }\n                var lu = lightUniforms[group][symbol];\n                lu.type = uniformTpl.type + 'v';\n                switch (uniformTpl.type) {\n                    case '1i':\n                    case '1f':\n                    case 't':\n                        lu.value.push(value);\n                        break;\n                    case '2f':\n                    case '3f':\n                    case '4f':\n                        for (var j = 0; j < value.length; j++) {\n                            lu.value.push(value[j]);\n                        }\n                        break;\n                    default:\n                        console.error('Unkown light uniform type ' + uniformTpl.type);\n                }\n            }\n        }\n    },\n\n    getLightGroups: function () {\n        var lightGroups = [];\n        for (var groupId in this._lightNumber) {\n            lightGroups.push(groupId);\n        }\n        return lightGroups;\n    },\n\n    getNumberChangedLightGroups: function () {\n        var lightGroups = [];\n        for (var groupId in this._lightNumber) {\n            if (this.isLightNumberChanged(groupId)) {\n                lightGroups.push(groupId);\n            }\n        }\n        return lightGroups;\n    },\n\n    /**\n     * Determine if light group is different with since last frame\n     * Used to determine whether to update shader and scene's uniforms in Renderer.render\n     * @param {Shader} shader\n     * @returns {Boolean}\n     */\n    isLightNumberChanged: function (lightGroup) {\n        var prevLightNumber = this._previousLightNumber;\n        var currentLightNumber = this._lightNumber;\n        // PENDING Performance\n        for (var type in currentLightNumber[lightGroup]) {\n            if (!prevLightNumber[lightGroup]) {\n                return true;\n            }\n            if (currentLightNumber[lightGroup][type] !== prevLightNumber[lightGroup][type]) {\n                return true;\n            }\n        }\n        for (var type in prevLightNumber[lightGroup]) {\n            if (!currentLightNumber[lightGroup]) {\n                return true;\n            }\n            if (currentLightNumber[lightGroup][type] !== prevLightNumber[lightGroup][type]) {\n                return true;\n            }\n        }\n        return false;\n    },\n\n    /**\n     * Set shader's light group with scene's\n     * @param {Shader} shader\n     */\n    getLightsNumbers: function (lightGroup) {\n        return this._lightNumber[lightGroup];\n    },\n\n    getProgramKey: function (lightGroup) {\n        return this._lightProgramKeys[lightGroup];\n    },\n\n    setLightUniforms: (function () {\n        function setUniforms(uniforms, program, renderer) {\n            for (var symbol in uniforms) {\n                var lu = uniforms[symbol];\n                if (lu.type === 'tv') {\n                    if (!program.hasUniform(symbol)) {\n                        continue;\n                    }\n                    var texSlots = [];\n                    for (var i = 0; i < lu.value.length; i++) {\n                        var texture = lu.value[i];\n                        var slot = program.takeCurrentTextureSlot(renderer, texture);\n                        texSlots.push(slot);\n                    }\n                    program.setUniform(renderer.gl, '1iv', symbol, texSlots);\n                }\n                else {\n                    program.setUniform(renderer.gl, lu.type, symbol, lu.value);\n                }\n            }\n        }\n\n        return function (program, lightGroup, renderer) {\n            setUniforms(this._lightUniforms[lightGroup], program, renderer);\n            // Set shadows\n            setUniforms(this.shadowUniforms, program, renderer);\n        };\n    })(),\n\n    /**\n     * Dispose self, clear all the scene objects\n     * But resources of gl like texuture, shader will not be disposed.\n     * Mostly you should use disposeScene method in Renderer to do dispose.\n     */\n    dispose: function () {\n        this.material = null;\n        this.opaqueList = [];\n        this.transparentList = [];\n\n        this.lights = [];\n\n        this._lightUniforms = {};\n\n        this._lightNumber = {};\n        this._nodeRepository = {};\n    }\n});\n\nfunction lightSortFunc(a, b) {\n    if (b.castShadow && !a.castShadow) {\n        return true;\n    }\n}\n\nexport default Scene;\n","import Base from './core/Base';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\nimport vendor from './core/vendor';\nimport glMatrix from './dep/glmatrix';\nimport BoundingBox from './math/BoundingBox';\n\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\n\nvar vec3Create = vec3.create;\nvar vec3Add = vec3.add;\nvar vec3Set = vec3.set;\n\nfunction getArrayCtorByType (type) {\n    return ({\n        'byte': vendor.Int8Array,\n        'ubyte': vendor.Uint8Array,\n        'short': vendor.Int16Array,\n        'ushort': vendor.Uint16Array\n    })[type] || vendor.Float32Array;\n}\n\nfunction makeAttrKey(attrName) {\n    return 'attr_' + attrName;\n}\n/**\n * Geometry attribute\n * @alias clay.Geometry.Attribute\n * @constructor\n */\nfunction Attribute(name, type, size, semantic) {\n    /**\n     * Attribute name\n     * @type {string}\n     */\n    this.name = name;\n    /**\n     * Attribute type\n     * Possible values:\n     *  + `'byte'`\n     *  + `'ubyte'`\n     *  + `'short'`\n     *  + `'ushort'`\n     *  + `'float'` Most commonly used.\n     * @type {string}\n     */\n    this.type = type;\n    /**\n     * Size of attribute component. 1 - 4.\n     * @type {number}\n     */\n    this.size = size;\n    /**\n     * Semantic of this attribute.\n     * Possible values:\n     *  + `'POSITION'`\n     *  + `'NORMAL'`\n     *  + `'BINORMAL'`\n     *  + `'TANGENT'`\n     *  + `'TEXCOORD'`\n     *  + `'TEXCOORD_0'`\n     *  + `'TEXCOORD_1'`\n     *  + `'COLOR'`\n     *  + `'JOINT'`\n     *  + `'WEIGHT'`\n     *\n     * In shader, attribute with same semantic will be automatically mapped. For example:\n     * ```glsl\n     * attribute vec3 pos: POSITION\n     * ```\n     * will use the attribute value with semantic POSITION in geometry, no matter what name it used.\n     * @type {string}\n     */\n    this.semantic = semantic || '';\n\n    /**\n     * Value of the attribute.\n     * @type {TypedArray}\n     */\n    this.value = null;\n\n    // Init getter setter\n    switch (size) {\n        case 1:\n            this.get = function (idx) {\n                return this.value[idx];\n            };\n            this.set = function (idx, value) {\n                this.value[idx] = value;\n            };\n            // Copy from source to target\n            this.copy = function (target, source) {\n                this.value[target] = this.value[target];\n            };\n            break;\n        case 2:\n            this.get = function (idx, out) {\n                var arr = this.value;\n                out[0] = arr[idx * 2];\n                out[1] = arr[idx * 2 + 1];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var arr = this.value;\n                arr[idx * 2] = val[0];\n                arr[idx * 2 + 1] = val[1];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 2;\n                target *= 2;\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n            };\n            break;\n        case 3:\n            this.get = function (idx, out) {\n                var idx3 = idx * 3;\n                var arr = this.value;\n                out[0] = arr[idx3];\n                out[1] = arr[idx3 + 1];\n                out[2] = arr[idx3 + 2];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var idx3 = idx * 3;\n                var arr = this.value;\n                arr[idx3] = val[0];\n                arr[idx3 + 1] = val[1];\n                arr[idx3 + 2] = val[2];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 3;\n                target *= 3;\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n                arr[target + 2] = arr[source + 2];\n            };\n            break;\n        case 4:\n            this.get = function (idx, out) {\n                var arr = this.value;\n                var idx4 = idx * 4;\n                out[0] = arr[idx4];\n                out[1] = arr[idx4 + 1];\n                out[2] = arr[idx4 + 2];\n                out[3] = arr[idx4 + 3];\n                return out;\n            };\n            this.set = function (idx, val) {\n                var arr = this.value;\n                var idx4 = idx * 4;\n                arr[idx4] = val[0];\n                arr[idx4 + 1] = val[1];\n                arr[idx4 + 2] = val[2];\n                arr[idx4 + 3] = val[3];\n            };\n            this.copy = function (target, source) {\n                var arr = this.value;\n                source *= 4;\n                target *= 4;\n                // copyWithin is extremely slow\n                arr[target] = arr[source];\n                arr[target + 1] = arr[source + 1];\n                arr[target + 2] = arr[source + 2];\n                arr[target + 3] = arr[source + 3];\n            };\n    }\n}\n\n/**\n * Set item value at give index. Second parameter val is number if size is 1\n * @function\n * @name clay.Geometry.Attribute#set\n * @param {number} idx\n * @param {number[]|number} val\n * @example\n * geometry.getAttribute('position').set(0, [1, 1, 1]);\n */\n\n/**\n * Get item value at give index. Second parameter out is no need if size is 1\n * @function\n * @name clay.Geometry.Attribute#set\n * @param {number} idx\n * @param {number[]} [out]\n * @example\n * geometry.getAttribute('position').get(0, out);\n */\n\n/**\n * Initialize attribute with given vertex count\n * @param {number} nVertex\n */\nAttribute.prototype.init = function (nVertex) {\n    if (!this.value || this.value.length != nVertex * this.size) {\n        var ArrayConstructor = getArrayCtorByType(this.type);\n        this.value = new ArrayConstructor(nVertex * this.size);\n    }\n};\n\n/**\n * Initialize attribute with given array. Which can be 1 dimensional or 2 dimensional\n * @param {Array} array\n * @example\n *  geometry.getAttribute('position').fromArray(\n *      [-1, 0, 0, 1, 0, 0, 0, 1, 0]\n *  );\n *  geometry.getAttribute('position').fromArray(\n *      [ [-1, 0, 0], [1, 0, 0], [0, 1, 0] ]\n *  );\n */\nAttribute.prototype.fromArray = function (array) {\n    var ArrayConstructor = getArrayCtorByType(this.type);\n    var value;\n    // Convert 2d array to flat\n    if (array[0] && (array[0].length)) {\n        var n = 0;\n        var size = this.size;\n        value = new ArrayConstructor(array.length * size);\n        for (var i = 0; i < array.length; i++) {\n            for (var j = 0; j < size; j++) {\n                value[n++] = array[i][j];\n            }\n        }\n    }\n    else {\n        value = new ArrayConstructor(array);\n    }\n    this.value = value;\n};\n\nAttribute.prototype.clone = function(copyValue) {\n    var ret = new Attribute(this.name, this.type, this.size, this.semantic);\n    // FIXME\n    if (copyValue) {\n        console.warn('todo');\n    }\n    return ret;\n};\n\nfunction AttributeBuffer(name, type, buffer, size, semantic) {\n    this.name = name;\n    this.type = type;\n    this.buffer = buffer;\n    this.size = size;\n    this.semantic = semantic;\n\n    // To be set in mesh\n    // symbol in the shader\n    this.symbol = '';\n\n    // Needs remove flag\n    this.needsRemove = false;\n}\n\nfunction IndicesBuffer(buffer) {\n    this.buffer = buffer;\n    this.count = 0;\n}\n\n/**\n * @constructor clay.Geometry\n * @extends clay.core.Base\n */\nvar Geometry = Base.extend(function () {\n    return /** @lends clay.Geometry# */ {\n        /**\n         * Attributes of geometry. Including:\n         *  + `position`\n         *  + `texcoord0`\n         *  + `texcoord1`\n         *  + `normal`\n         *  + `tangent`\n         *  + `color`\n         *  + `weight`\n         *  + `joint`\n         *  + `barycentric`\n         * @type {Object}\n         */\n        attributes: {\n            position: new Attribute('position', 'float', 3, 'POSITION'),\n            texcoord0: new Attribute('texcoord0', 'float', 2, 'TEXCOORD_0'),\n            texcoord1: new Attribute('texcoord1', 'float', 2, 'TEXCOORD_1'),\n            normal: new Attribute('normal', 'float', 3, 'NORMAL'),\n            tangent: new Attribute('tangent', 'float', 4, 'TANGENT'),\n            color: new Attribute('color', 'float', 4, 'COLOR'),\n            // Skinning attributes\n            // Each vertex can be bind to 4 bones, because the\n            // sum of weights is 1, so the weights is stored in vec3 and the last\n            // can be calculated by 1-w.x-w.y-w.z\n            weight: new Attribute('weight', 'float', 3, 'WEIGHT'),\n            joint: new Attribute('joint', 'float', 4, 'JOINT'),\n            // For wireframe display\n            // http://codeflow.org/entries/2012/aug/02/easy-wireframe-display-with-barycentric-coordinates/\n            barycentric: new Attribute('barycentric', 'float', 3, null),\n        },\n        /**\n         * Calculated bounding box of geometry.\n         * @type {clay.math.BoundingBox}\n         */\n        boundingBox: null,\n\n        /**\n         * Indices of geometry.\n         * @type {Uint16Array|Uint32Array}\n         */\n        indices: null,\n\n        /**\n         * Is vertices data dynamically updated.\n         * Attributes value can't be changed after first render if dyanmic is false.\n         * @type {boolean}\n         */\n        dynamic: true,\n\n        _enabledAttributes: null\n    };\n}, function() {\n    // Use cache\n    this._cache = new Cache();\n\n    this._attributeList = Object.keys(this.attributes);\n},\n/** @lends clay.Geometry.prototype */\n{\n    /**\n     * Main attribute will be used to count vertex number\n     * @type {string}\n     */\n    mainAttribute: 'position',\n    /**\n     * User defined picking algorithm instead of default\n     * triangle ray intersection\n     * x, y are NDC.\n     * ```typescript\n     * (x, y, renderer, camera, renderable, out) => boolean\n     * ```\n     * @type {?Function}\n     */\n    pick: null,\n\n    /**\n     * User defined ray picking algorithm instead of default\n     * triangle ray intersection\n     * ```typescript\n     * (ray: clay.math.Ray, renderable: clay.Renderable, out: Array) => boolean\n     * ```\n     * @type {?Function}\n     */\n    pickByRay: null,\n\n    /**\n     * Update boundingBox of Geometry\n     */\n    updateBoundingBox: function () {\n        var bbox = this.boundingBox;\n        if (!bbox) {\n            bbox = this.boundingBox = new BoundingBox();\n        }\n        var posArr = this.attributes.position.value;\n        if (posArr && posArr.length) {\n            var min = bbox.min;\n            var max = bbox.max;\n            var minArr = min.array;\n            var maxArr = max.array;\n            vec3.set(minArr, posArr[0], posArr[1], posArr[2]);\n            vec3.set(maxArr, posArr[0], posArr[1], posArr[2]);\n            for (var i = 3; i < posArr.length;) {\n                var x = posArr[i++];\n                var y = posArr[i++];\n                var z = posArr[i++];\n                if (x < minArr[0]) { minArr[0] = x; }\n                if (y < minArr[1]) { minArr[1] = y; }\n                if (z < minArr[2]) { minArr[2] = z; }\n\n                if (x > maxArr[0]) { maxArr[0] = x; }\n                if (y > maxArr[1]) { maxArr[1] = y; }\n                if (z > maxArr[2]) { maxArr[2] = z; }\n            }\n            min._dirty = true;\n            max._dirty = true;\n        }\n    },\n    /**\n     * Mark attributes and indices in geometry needs to update.\n     */\n    dirty: function () {\n        var enabledAttributes = this.getEnabledAttributes();\n        for (var i = 0; i < enabledAttributes.length; i++) {\n            this.dirtyAttribute(enabledAttributes[i]);\n        }\n        this.dirtyIndices();\n        this._enabledAttributes = null;\n\n        this._cache.dirty('any');\n    },\n    /**\n     * Mark the indices needs to update.\n     */\n    dirtyIndices: function () {\n        this._cache.dirtyAll('indices');\n    },\n    /**\n     * Mark the attributes needs to update.\n     * @param {string} [attrName]\n     */\n    dirtyAttribute: function (attrName) {\n        this._cache.dirtyAll(makeAttrKey(attrName));\n        this._cache.dirtyAll('attributes');\n    },\n    /**\n     * Get indices of triangle at given index.\n     * @param {number} idx\n     * @param {Array.<number>} out\n     * @return {Array.<number>}\n     */\n    getTriangleIndices: function (idx, out) {\n        if (idx < this.triangleCount && idx >= 0) {\n            if (!out) {\n                out = vec3Create();\n            }\n            var indices = this.indices;\n            out[0] = indices[idx * 3];\n            out[1] = indices[idx * 3 + 1];\n            out[2] = indices[idx * 3 + 2];\n            return out;\n        }\n    },\n\n    /**\n     * Set indices of triangle at given index.\n     * @param {number} idx\n     * @param {Array.<number>} arr\n     */\n    setTriangleIndices: function (idx, arr) {\n        var indices = this.indices;\n        indices[idx * 3] = arr[0];\n        indices[idx * 3 + 1] = arr[1];\n        indices[idx * 3 + 2] = arr[2];\n    },\n\n    isUseIndices: function () {\n        return !!this.indices;\n    },\n\n    /**\n     * Initialize indices from an array.\n     * @param {Array} array\n     */\n    initIndicesFromArray: function (array) {\n        var value;\n        var ArrayConstructor = this.vertexCount > 0xffff\n            ? vendor.Uint32Array : vendor.Uint16Array;\n        // Convert 2d array to flat\n        if (array[0] && (array[0].length)) {\n            var n = 0;\n            var size = 3;\n\n            value = new ArrayConstructor(array.length * size);\n            for (var i = 0; i < array.length; i++) {\n                for (var j = 0; j < size; j++) {\n                    value[n++] = array[i][j];\n                }\n            }\n        }\n        else {\n            value = new ArrayConstructor(array);\n        }\n\n        this.indices = value;\n    },\n    /**\n     * Create a new attribute\n     * @param {string} name\n     * @param {string} type\n     * @param {number} size\n     * @param {string} [semantic]\n     */\n    createAttribute: function (name, type, size, semantic) {\n        var attrib = new Attribute(name, type, size, semantic);\n        if (this.attributes[name]) {\n            this.removeAttribute(name);\n        }\n        this.attributes[name] = attrib;\n        this._attributeList.push(name);\n        return attrib;\n    },\n    /**\n     * Remove attribute\n     * @param {string} name\n     */\n    removeAttribute: function (name) {\n        var attributeList = this._attributeList;\n        var idx = attributeList.indexOf(name);\n        if (idx >= 0) {\n            attributeList.splice(idx, 1);\n            delete this.attributes[name];\n            return true;\n        }\n        return false;\n    },\n\n    /**\n     * Get attribute\n     * @param {string} name\n     * @return {clay.Geometry.Attribute}\n     */\n    getAttribute: function (name) {\n        return this.attributes[name];\n    },\n\n    /**\n     * Get enabled attributes name list\n     * Attribute which has the same vertex number with position is treated as a enabled attribute\n     * @return {string[]}\n     */\n    getEnabledAttributes: function () {\n        var enabledAttributes = this._enabledAttributes;\n        var attributeList = this._attributeList;\n        // Cache\n        if (enabledAttributes) {\n            return enabledAttributes;\n        }\n\n        var result = [];\n        var nVertex = this.vertexCount;\n\n        for (var i = 0; i < attributeList.length; i++) {\n            var name = attributeList[i];\n            var attrib = this.attributes[name];\n            if (attrib.value) {\n                if (attrib.value.length === nVertex * attrib.size) {\n                    result.push(name);\n                }\n            }\n        }\n\n        this._enabledAttributes = result;\n\n        return result;\n    },\n\n    getBufferChunks: function (renderer) {\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n        var isAttributesDirty = cache.isDirty('attributes');\n        var isIndicesDirty = cache.isDirty('indices');\n        if (isAttributesDirty || isIndicesDirty) {\n            this._updateBuffer(renderer.gl, isAttributesDirty, isIndicesDirty);\n            var enabledAttributes = this.getEnabledAttributes();\n            for (var i = 0; i < enabledAttributes.length; i++) {\n                cache.fresh(makeAttrKey(enabledAttributes[i]));\n            }\n            cache.fresh('attributes');\n            cache.fresh('indices');\n        }\n        cache.fresh('any');\n        return cache.get('chunks');\n    },\n\n    _updateBuffer: function (_gl, isAttributesDirty, isIndicesDirty) {\n        var cache = this._cache;\n        var chunks = cache.get('chunks');\n        var firstUpdate = false;\n        if (!chunks) {\n            chunks = [];\n            // Intialize\n            chunks[0] = {\n                attributeBuffers: [],\n                indicesBuffer: null\n            };\n            cache.put('chunks', chunks);\n            firstUpdate = true;\n        }\n\n        var chunk = chunks[0];\n        var attributeBuffers = chunk.attributeBuffers;\n        var indicesBuffer = chunk.indicesBuffer;\n\n        if (isAttributesDirty || firstUpdate) {\n            var attributeList = this.getEnabledAttributes();\n\n            var attributeBufferMap = {};\n            if (!firstUpdate) {\n                for (var i = 0; i < attributeBuffers.length; i++) {\n                    attributeBufferMap[attributeBuffers[i].name] = attributeBuffers[i];\n                }\n            }\n            // FIXME If some attributes removed\n            for (var k = 0; k < attributeList.length; k++) {\n                var name = attributeList[k];\n                var attribute = this.attributes[name];\n\n                var bufferInfo;\n\n                if (!firstUpdate) {\n                    bufferInfo = attributeBufferMap[name];\n                }\n                var buffer;\n                if (bufferInfo) {\n                    buffer = bufferInfo.buffer;\n                }\n                else {\n                    buffer = _gl.createBuffer();\n                }\n                if (cache.isDirty(makeAttrKey(name))) {\n                    // Only update when they are dirty.\n                    // TODO: Use BufferSubData?\n                    _gl.bindBuffer(_gl.ARRAY_BUFFER, buffer);\n                    _gl.bufferData(_gl.ARRAY_BUFFER, attribute.value, this.dynamic ? glenum.DYNAMIC_DRAW : glenum.STATIC_DRAW);\n                }\n\n                attributeBuffers[k] = new AttributeBuffer(name, attribute.type, buffer, attribute.size, attribute.semantic);\n            }\n            // Remove unused attributes buffers.\n            // PENDING\n            for (var i = k; i < attributeBuffers.length; i++) {\n                _gl.deleteBuffer(attributeBuffers[i].buffer);\n            }\n            attributeBuffers.length = k;\n\n        }\n\n        if (this.isUseIndices() && (isIndicesDirty || firstUpdate)) {\n            if (!indicesBuffer) {\n                indicesBuffer = new IndicesBuffer(_gl.createBuffer());\n                chunk.indicesBuffer = indicesBuffer;\n            }\n            indicesBuffer.count = this.indices.length;\n            _gl.bindBuffer(_gl.ELEMENT_ARRAY_BUFFER, indicesBuffer.buffer);\n            _gl.bufferData(_gl.ELEMENT_ARRAY_BUFFER, this.indices, this.dynamic ? glenum.DYNAMIC_DRAW : glenum.STATIC_DRAW);\n        }\n    },\n\n    /**\n     * Generate normals per vertex.\n     */\n    generateVertexNormals: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        var indices = this.indices;\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n\n        if (!normals || normals.length !== positions.length) {\n            normals = attributes.normal.value = new vendor.Float32Array(positions.length);\n        }\n        else {\n            // Reset\n            for (var i = 0; i < normals.length; i++) {\n                normals[i] = 0;\n            }\n        }\n\n        var p1 = vec3Create();\n        var p2 = vec3Create();\n        var p3 = vec3Create();\n\n        var v21 = vec3Create();\n        var v32 = vec3Create();\n\n        var n = vec3Create();\n\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var f = 0; f < len;) {\n            if (indices) {\n                i1 = indices[f++];\n                i2 = indices[f++];\n                i3 = indices[f++];\n            }\n            else {\n                i1 = f++;\n                i2 = f++;\n                i3 = f++;\n            }\n\n            vec3Set(p1, positions[i1*3], positions[i1*3+1], positions[i1*3+2]);\n            vec3Set(p2, positions[i2*3], positions[i2*3+1], positions[i2*3+2]);\n            vec3Set(p3, positions[i3*3], positions[i3*3+1], positions[i3*3+2]);\n\n            vec3.sub(v21, p1, p2);\n            vec3.sub(v32, p2, p3);\n            vec3.cross(n, v21, v32);\n            // Already be weighted by the triangle area\n            for (var i = 0; i < 3; i++) {\n                normals[i1*3+i] = normals[i1*3+i] + n[i];\n                normals[i2*3+i] = normals[i2*3+i] + n[i];\n                normals[i3*3+i] = normals[i3*3+i] + n[i];\n            }\n        }\n\n        for (var i = 0; i < normals.length;) {\n            vec3Set(n, normals[i], normals[i+1], normals[i+2]);\n            vec3.normalize(n, n);\n            normals[i++] = n[0];\n            normals[i++] = n[1];\n            normals[i++] = n[2];\n        }\n        this.dirty();\n    },\n\n    /**\n     * Generate normals per face.\n     */\n    generateFaceNormals: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        if (!this.isUniqueVertex()) {\n            this.generateUniqueVertex();\n        }\n\n        var indices = this.indices;\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n\n        var p1 = vec3Create();\n        var p2 = vec3Create();\n        var p3 = vec3Create();\n\n        var v21 = vec3Create();\n        var v32 = vec3Create();\n        var n = vec3Create();\n\n        if (!normals) {\n            normals = attributes.normal.value = new Float32Array(positions.length);\n        }\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var f = 0; f < len;) {\n            if (indices) {\n                i1 = indices[f++];\n                i2 = indices[f++];\n                i3 = indices[f++];\n            }\n            else {\n                i1 = f++;\n                i2 = f++;\n                i3 = f++;\n            }\n\n            vec3Set(p1, positions[i1*3], positions[i1*3+1], positions[i1*3+2]);\n            vec3Set(p2, positions[i2*3], positions[i2*3+1], positions[i2*3+2]);\n            vec3Set(p3, positions[i3*3], positions[i3*3+1], positions[i3*3+2]);\n\n            vec3.sub(v21, p1, p2);\n            vec3.sub(v32, p2, p3);\n            vec3.cross(n, v21, v32);\n\n            vec3.normalize(n, n);\n\n            for (var i = 0; i < 3; i++) {\n                normals[i1*3 + i] = n[i];\n                normals[i2*3 + i] = n[i];\n                normals[i3*3 + i] = n[i];\n            }\n        }\n        this.dirty();\n    },\n\n    /**\n     * Generate tangents attributes.\n     */\n    generateTangents: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        var nVertex = this.vertexCount;\n        var attributes = this.attributes;\n        if (!attributes.tangent.value) {\n            attributes.tangent.value = new Float32Array(nVertex * 4);\n        }\n        var texcoords = attributes.texcoord0.value;\n        var positions = attributes.position.value;\n        var tangents = attributes.tangent.value;\n        var normals = attributes.normal.value;\n\n        if (!texcoords) {\n            console.warn('Geometry without texcoords can\\'t generate tangents.');\n            return;\n        }\n\n        var tan1 = [];\n        var tan2 = [];\n        for (var i = 0; i < nVertex; i++) {\n            tan1[i] = [0.0, 0.0, 0.0];\n            tan2[i] = [0.0, 0.0, 0.0];\n        }\n\n        var sdir = [0.0, 0.0, 0.0];\n        var tdir = [0.0, 0.0, 0.0];\n        var indices = this.indices;\n\n        var len = indices ? indices.length : this.vertexCount;\n        var i1, i2, i3;\n        for (var i = 0; i < len;) {\n            if (indices) {\n                i1 = indices[i++];\n                i2 = indices[i++];\n                i3 = indices[i++];\n            }\n            else {\n                i1 = i++;\n                i2 = i++;\n                i3 = i++;\n            }\n\n            var st1s = texcoords[i1 * 2],\n                st2s = texcoords[i2 * 2],\n                st3s = texcoords[i3 * 2],\n                st1t = texcoords[i1 * 2 + 1],\n                st2t = texcoords[i2 * 2 + 1],\n                st3t = texcoords[i3 * 2 + 1],\n\n                p1x = positions[i1 * 3],\n                p2x = positions[i2 * 3],\n                p3x = positions[i3 * 3],\n                p1y = positions[i1 * 3 + 1],\n                p2y = positions[i2 * 3 + 1],\n                p3y = positions[i3 * 3 + 1],\n                p1z = positions[i1 * 3 + 2],\n                p2z = positions[i2 * 3 + 2],\n                p3z = positions[i3 * 3 + 2];\n\n            var x1 = p2x - p1x,\n                x2 = p3x - p1x,\n                y1 = p2y - p1y,\n                y2 = p3y - p1y,\n                z1 = p2z - p1z,\n                z2 = p3z - p1z;\n\n            var s1 = st2s - st1s,\n                s2 = st3s - st1s,\n                t1 = st2t - st1t,\n                t2 = st3t - st1t;\n\n            var r = 1.0 / (s1 * t2 - t1 * s2);\n            sdir[0] = (t2 * x1 - t1 * x2) * r;\n            sdir[1] = (t2 * y1 - t1 * y2) * r;\n            sdir[2] = (t2 * z1 - t1 * z2) * r;\n\n            tdir[0] = (s1 * x2 - s2 * x1) * r;\n            tdir[1] = (s1 * y2 - s2 * y1) * r;\n            tdir[2] = (s1 * z2 - s2 * z1) * r;\n\n            vec3Add(tan1[i1], tan1[i1], sdir);\n            vec3Add(tan1[i2], tan1[i2], sdir);\n            vec3Add(tan1[i3], tan1[i3], sdir);\n            vec3Add(tan2[i1], tan2[i1], tdir);\n            vec3Add(tan2[i2], tan2[i2], tdir);\n            vec3Add(tan2[i3], tan2[i3], tdir);\n        }\n        var tmp = vec3Create();\n        var nCrossT = vec3Create();\n        var n = vec3Create();\n        for (var i = 0; i < nVertex; i++) {\n            n[0] = normals[i * 3];\n            n[1] = normals[i * 3 + 1];\n            n[2] = normals[i * 3 + 2];\n            var t = tan1[i];\n\n            // Gram-Schmidt orthogonalize\n            vec3.scale(tmp, n, vec3.dot(n, t));\n            vec3.sub(tmp, t, tmp);\n            vec3.normalize(tmp, tmp);\n            // Calculate handedness.\n            vec3.cross(nCrossT, n, t);\n            tangents[i * 4] = tmp[0];\n            tangents[i * 4 + 1] = tmp[1];\n            tangents[i * 4 + 2] = tmp[2];\n            // PENDING can config ?\n            tangents[i * 4 + 3] = vec3.dot(nCrossT, tan2[i]) < 0.0 ? -1.0 : 1.0;\n        }\n        this.dirty();\n    },\n\n    /**\n     * If vertices are not shared by different indices.\n     */\n    isUniqueVertex: function () {\n        if (this.isUseIndices()) {\n            return this.vertexCount === this.indices.length;\n        }\n        else {\n            return true;\n        }\n    },\n    /**\n     * Create a unique vertex for each index.\n     */\n    generateUniqueVertex: function () {\n        if (!this.vertexCount || !this.indices) {\n            return;\n        }\n\n        if (this.indices.length > 0xffff) {\n            this.indices = new vendor.Uint32Array(this.indices);\n        }\n\n        var attributes = this.attributes;\n        var indices = this.indices;\n\n        var attributeNameList = this.getEnabledAttributes();\n\n        var oldAttrValues = {};\n        for (var a = 0; a < attributeNameList.length; a++) {\n            var name = attributeNameList[a];\n            oldAttrValues[name] = attributes[name].value;\n            attributes[name].init(this.indices.length);\n        }\n\n        var cursor = 0;\n        for (var i = 0; i < indices.length; i++) {\n            var ii = indices[i];\n            for (var a = 0; a < attributeNameList.length; a++) {\n                var name = attributeNameList[a];\n                var array = attributes[name].value;\n                var size = attributes[name].size;\n\n                for (var k = 0; k < size; k++) {\n                    array[cursor * size + k] = oldAttrValues[name][ii * size + k];\n                }\n            }\n            indices[i] = cursor;\n            cursor++;\n        }\n\n        this.dirty();\n    },\n\n    /**\n     * Generate barycentric coordinates for wireframe draw.\n     */\n    generateBarycentric: function () {\n        if (!this.vertexCount) {\n            return;\n        }\n\n        if (!this.isUniqueVertex()) {\n            this.generateUniqueVertex();\n        }\n\n        var attributes = this.attributes;\n        var array = attributes.barycentric.value;\n        var indices = this.indices;\n        // Already existed;\n        if (array && array.length === indices.length * 3) {\n            return;\n        }\n        array = attributes.barycentric.value = new Float32Array(indices.length * 3);\n\n        for (var i = 0; i < (indices ? indices.length : this.vertexCount / 3);) {\n            for (var j = 0; j < 3; j++) {\n                var ii = indices ? indices[i++] : (i * 3 + j);\n                array[ii * 3 + j] = 1;\n            }\n        }\n        this.dirty();\n    },\n\n    /**\n     * Apply transform to geometry attributes.\n     * @param {clay.math.Matrix4} matrix\n     */\n    applyTransform: function (matrix) {\n\n        var attributes = this.attributes;\n        var positions = attributes.position.value;\n        var normals = attributes.normal.value;\n        var tangents = attributes.tangent.value;\n\n        matrix = matrix.array;\n        // Normal Matrix\n        var inverseTransposeMatrix = mat4.create();\n        mat4.invert(inverseTransposeMatrix, matrix);\n        mat4.transpose(inverseTransposeMatrix, inverseTransposeMatrix);\n\n        var vec3TransformMat4 = vec3.transformMat4;\n        var vec3ForEach = vec3.forEach;\n        vec3ForEach(positions, 3, 0, null, vec3TransformMat4, matrix);\n        if (normals) {\n            vec3ForEach(normals, 3, 0, null, vec3TransformMat4, inverseTransposeMatrix);\n        }\n        if (tangents) {\n            vec3ForEach(tangents, 4, 0, null, vec3TransformMat4, inverseTransposeMatrix);\n        }\n\n        if (this.boundingBox) {\n            this.updateBoundingBox();\n        }\n    },\n    /**\n     * Dispose geometry data in GL context.\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n        var chunks = cache.get('chunks');\n        if (chunks) {\n            for (var c = 0; c < chunks.length; c++) {\n                var chunk = chunks[c];\n\n                for (var k = 0; k < chunk.attributeBuffers.length; k++) {\n                    var attribs = chunk.attributeBuffers[k];\n                    renderer.gl.deleteBuffer(attribs.buffer);\n                }\n\n                if (chunk.indicesBuffer) {\n                    renderer.gl.deleteBuffer(chunk.indicesBuffer.buffer);\n                }\n            }\n        }\n        cache.deleteContext(renderer.__uid__);\n    }\n\n});\n\nif (Object.defineProperty) {\n    /**\n     * @name clay.Geometry#vertexCount\n     * @type {number}\n     * @readOnly\n     */\n    Object.defineProperty(Geometry.prototype, 'vertexCount', {\n\n        enumerable: false,\n\n        get: function () {\n            var mainAttribute = this.attributes[this.mainAttribute];\n            if (!mainAttribute || !mainAttribute.value) {\n                return 0;\n            }\n            return mainAttribute.value.length / mainAttribute.size;\n        }\n    });\n    /**\n     * @name clay.Geometry#triangleCount\n     * @type {number}\n     * @readOnly\n     */\n    Object.defineProperty(Geometry.prototype, 'triangleCount', {\n\n        enumerable: false,\n\n        get: function () {\n            var indices = this.indices;\n            if (!indices) {\n                return 0;\n            }\n            else {\n                return indices.length / 3;\n            }\n        }\n    });\n}\n\nGeometry.STATIC_DRAW = glenum.STATIC_DRAW;\nGeometry.DYNAMIC_DRAW = glenum.DYNAMIC_DRAW;\nGeometry.STREAM_DRAW = glenum.STREAM_DRAW;\n\nGeometry.AttributeBuffer = AttributeBuffer;\nGeometry.IndicesBuffer = IndicesBuffer;\n\nGeometry.Attribute = Attribute;\n\nexport default Geometry;\n","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\n\n/**\n * @constructor clay.geometry.Plane\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.widthSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Plane = Geometry.extend(\n/** @lends clay.geometry.Plane# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 1,\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Plane.prototype */\n{\n    /**\n     * Build plane geometry\n     */\n    build: function() {\n        var heightSegments = this.heightSegments;\n        var widthSegments = this.widthSegments;\n        var attributes = this.attributes;\n        var positions = [];\n        var texcoords = [];\n        var normals = [];\n        var faces = [];\n\n        for (var y = 0; y <= heightSegments; y++) {\n            var t = y / heightSegments;\n            for (var x = 0; x <= widthSegments; x++) {\n                var s = x / widthSegments;\n\n                positions.push([2 * s - 1, 2 * t - 1, 0]);\n                if (texcoords) {\n                    texcoords.push([s, t]);\n                }\n                if (normals) {\n                    normals.push([0, 0, 1]);\n                }\n                if (x < widthSegments && y < heightSegments) {\n                    var i = x + y * (widthSegments + 1);\n                    faces.push([i, i + 1, i + widthSegments + 1]);\n                    faces.push([i + widthSegments + 1, i + 1, i + widthSegments + 2]);\n                }\n            }\n        }\n\n        attributes.position.fromArray(positions);\n        attributes.texcoord0.fromArray(texcoords);\n        attributes.normal.fromArray(normals);\n\n        this.initIndicesFromArray(faces);\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.min.set(-1, -1, 0);\n        this.boundingBox.max.set(1, 1, 0);\n    }\n});\n\nexport default Plane;\n","import Geometry from '../Geometry';\nimport Plane from './Plane';\nimport Matrix4 from '../math/Matrix4';\nimport Vector3 from '../math/Vector3';\nimport BoundingBox from '../math/BoundingBox';\nimport vendor from '../core/vendor';\n\nvar planeMatrix = new Matrix4();\n\n/**\n * @constructor clay.geometry.Cube\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.widthSegments]\n * @param {number} [opt.heightSegments]\n * @param {number} [opt.depthSegments]\n * @param {boolean} [opt.inside]\n */\nvar Cube = Geometry.extend(\n/**@lends clay.geometry.Cube# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 1,\n    /**\n     * @type {number}\n     */\n    heightSegments: 1,\n    /**\n     * @type {number}\n     */\n    depthSegments: 1,\n    /**\n     * @type {boolean}\n     */\n    inside: false\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cube.prototype */\n{\n    /**\n     * Build cube geometry\n     */\n    build: function() {\n\n        var planes = {\n            'px': createPlane('px', this.depthSegments, this.heightSegments),\n            'nx': createPlane('nx', this.depthSegments, this.heightSegments),\n            'py': createPlane('py', this.widthSegments, this.depthSegments),\n            'ny': createPlane('ny', this.widthSegments, this.depthSegments),\n            'pz': createPlane('pz', this.widthSegments, this.heightSegments),\n            'nz': createPlane('nz', this.widthSegments, this.heightSegments),\n        };\n\n        var attrList = ['position', 'texcoord0', 'normal'];\n        var vertexNumber = 0;\n        var faceNumber = 0;\n        for (var pos in planes) {\n            vertexNumber += planes[pos].vertexCount;\n            faceNumber += planes[pos].indices.length;\n        }\n        for (var k = 0; k < attrList.length; k++) {\n            this.attributes[attrList[k]].init(vertexNumber);\n        }\n        this.indices = new vendor.Uint16Array(faceNumber);\n        var faceOffset = 0;\n        var vertexOffset = 0;\n        for (var pos in planes) {\n            var plane = planes[pos];\n            for (var k = 0; k < attrList.length; k++) {\n                var attrName = attrList[k];\n                var attrArray = plane.attributes[attrName].value;\n                var attrSize = plane.attributes[attrName].size;\n                var isNormal = attrName === 'normal';\n                for (var i = 0; i < attrArray.length; i++) {\n                    var value = attrArray[i];\n                    if (this.inside && isNormal) {\n                        value = -value;\n                    }\n                    this.attributes[attrName].value[i + attrSize * vertexOffset] = value;\n                }\n            }\n            var len = plane.indices.length;\n            for (var i = 0; i < plane.indices.length; i++) {\n                this.indices[i + faceOffset] = vertexOffset + plane.indices[this.inside ? (len - i - 1) : i];\n            }\n            faceOffset += plane.indices.length;\n            vertexOffset += plane.vertexCount;\n        }\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.max.set(1, 1, 1);\n        this.boundingBox.min.set(-1, -1, -1);\n    }\n});\n\nfunction createPlane(pos, widthSegments, heightSegments) {\n\n    planeMatrix.identity();\n\n    var plane = new Plane({\n        widthSegments: widthSegments,\n        heightSegments: heightSegments\n    });\n\n    switch(pos) {\n        case 'px':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_X);\n            Matrix4.rotateY(planeMatrix, planeMatrix, Math.PI / 2);\n            break;\n        case 'nx':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_X);\n            Matrix4.rotateY(planeMatrix, planeMatrix, -Math.PI / 2);\n            break;\n        case 'py':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_Y);\n            Matrix4.rotateX(planeMatrix, planeMatrix, -Math.PI / 2);\n            break;\n        case 'ny':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_Y);\n            Matrix4.rotateX(planeMatrix, planeMatrix, Math.PI / 2);\n            break;\n        case 'pz':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.POSITIVE_Z);\n            break;\n        case 'nz':\n            Matrix4.translate(planeMatrix, planeMatrix, Vector3.NEGATIVE_Z);\n            Matrix4.rotateY(planeMatrix, planeMatrix, Math.PI);\n            break;\n    }\n    plane.applyTransform(planeMatrix);\n    return plane;\n}\n\nexport default Cube;\n","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\n\n/**\n * @constructor clay.geometry.Sphere\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [widthSegments]\n * @param {number} [heightSegments]\n * @param {number} [phiStart]\n * @param {number} [phiLength]\n * @param {number} [thetaStart]\n * @param {number} [thetaLength]\n * @param {number} [radius]\n */\nvar Sphere = Geometry.extend(\n/** @lends clay.geometry.Sphere# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    widthSegments: 40,\n    /**\n     * @type {number}\n     */\n    heightSegments: 20,\n\n    /**\n     * @type {number}\n     */\n    phiStart: 0,\n    /**\n     * @type {number}\n     */\n    phiLength: Math.PI * 2,\n\n    /**\n     * @type {number}\n     */\n    thetaStart: 0,\n    /**\n     * @type {number}\n     */\n    thetaLength: Math.PI,\n\n    /**\n     * @type {number}\n     */\n    radius: 1\n\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Sphere.prototype */\n{\n    /**\n     * Build sphere geometry\n     */\n    build: function() {\n        var heightSegments = this.heightSegments;\n        var widthSegments = this.widthSegments;\n\n        var positionAttr = this.attributes.position;\n        var texcoordAttr = this.attributes.texcoord0;\n        var normalAttr = this.attributes.normal;\n\n        var vertexCount = (widthSegments + 1) * (heightSegments + 1);\n        positionAttr.init(vertexCount);\n        texcoordAttr.init(vertexCount);\n        normalAttr.init(vertexCount);\n\n        var IndicesCtor = vertexCount > 0xffff ? Uint32Array : Uint16Array;\n        var indices = this.indices = new IndicesCtor(widthSegments * heightSegments * 6);\n\n        var x, y, z,\n            u, v,\n            i, j;\n\n        var radius = this.radius;\n        var phiStart = this.phiStart;\n        var phiLength = this.phiLength;\n        var thetaStart = this.thetaStart;\n        var thetaLength = this.thetaLength;\n        var radius = this.radius;\n\n        var pos = [];\n        var uv = [];\n        var offset = 0;\n        var divider = 1 / radius;\n        for (j = 0; j <= heightSegments; j ++) {\n            for (i = 0; i <= widthSegments; i ++) {\n                u = i / widthSegments;\n                v = j / heightSegments;\n\n                // X axis is inverted so texture can be mapped from left to right\n                x = -radius * Math.cos(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n                y = radius * Math.cos(thetaStart + v * thetaLength);\n                z = radius * Math.sin(phiStart + u * phiLength) * Math.sin(thetaStart + v * thetaLength);\n\n                pos[0] = x; pos[1] = y; pos[2] = z;\n                uv[0] = u; uv[1] = v;\n                positionAttr.set(offset, pos);\n                texcoordAttr.set(offset, uv);\n                pos[0] *= divider;\n                pos[1] *= divider;\n                pos[2] *= divider;\n                normalAttr.set(offset, pos);\n                offset++;\n            }\n        }\n\n        var i1, i2, i3, i4;\n\n        var len = widthSegments + 1;\n\n        var n = 0;\n        for (j = 0; j < heightSegments; j ++) {\n            for (i = 0; i < widthSegments; i ++) {\n                i2 = j * len + i;\n                i1 = (j * len + i + 1);\n                i4 = (j + 1) * len + i + 1;\n                i3 = (j + 1) * len + i;\n\n                indices[n++] = i1;\n                indices[n++] = i2;\n                indices[n++] = i4;\n\n                indices[n++] = i2;\n                indices[n++] = i3;\n                indices[n++] = i4;\n            }\n        }\n\n        this.boundingBox = new BoundingBox();\n        this.boundingBox.max.set(radius, radius, radius);\n        this.boundingBox.min.set(-radius, -radius, -radius);\n    }\n});\n\nexport default Sphere;\n","var mathUtil = {};\n\nmathUtil.isPowerOfTwo = function (value) {\n    return (value & (value - 1)) === 0;\n};\n\nmathUtil.nextPowerOfTwo = function (value) {\n    value --;\n    value |= value >> 1;\n    value |= value >> 2;\n    value |= value >> 4;\n    value |= value >> 8;\n    value |= value >> 16;\n    value ++;\n\n    return value;\n};\n\nmathUtil.nearestPowerOfTwo = function (value) {\n    return Math.pow( 2, Math.round( Math.log( value ) / Math.LN2 ) );\n};\n\nexport default mathUtil;\n","import Texture from './Texture';\nimport glenum from './core/glenum';\nimport mathUtil from './math/util';\nvar isPowerOfTwo = mathUtil.isPowerOfTwo;\n\n/**\n * @constructor clay.Texture2D\n * @extends clay.Texture\n *\n * @example\n *     ...\n *     var mat = new clay.Material({\n *         shader: clay.shader.library.get('clay.phong', 'diffuseMap')\n *     });\n *     var diffuseMap = new clay.Texture2D();\n *     diffuseMap.load('assets/textures/diffuse.jpg');\n *     mat.set('diffuseMap', diffuseMap);\n *     ...\n *     diffuseMap.success(function () {\n *         // Wait for the diffuse texture loaded\n *         animation.on('frame', function (frameTime) {\n *             renderer.render(scene, camera);\n *         });\n *     });\n */\nvar Texture2D = Texture.extend(function () {\n    return /** @lends clay.Texture2D# */ {\n        /**\n         * @type {?HTMLImageElement|HTMLCanvasElemnet}\n         */\n        image: null,\n        /**\n         * Pixels data. Will be ignored if image is set.\n         * @type {?Uint8Array|Float32Array}\n         */\n        pixels: null,\n        /**\n         * @type {Array.<Object>}\n         * @example\n         *     [{\n         *         image: mipmap0,\n         *         pixels: null\n         *     }, {\n         *         image: mipmap1,\n         *         pixels: null\n         *     }, ....]\n         */\n        mipmaps: []\n    };\n}, {\n    update: function (renderer) {\n\n        var _gl = renderer.gl;\n        _gl.bindTexture(_gl.TEXTURE_2D, this._cache.get('webgl_texture'));\n\n        this.updateCommon(renderer);\n\n        var glFormat = this.format;\n        var glType = this.type;\n\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS());\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT());\n\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter());\n        _gl.texParameteri(_gl.TEXTURE_2D, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter());\n\n        var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic');\n        if (anisotropicExt && this.anisotropic > 1) {\n            _gl.texParameterf(_gl.TEXTURE_2D, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic);\n        }\n\n        // Fallback to float type if browser don't have half float extension\n        if (glType === 36193) {\n            var halfFloatExt = renderer.getGLExtension('OES_texture_half_float');\n            if (!halfFloatExt) {\n                glType = glenum.FLOAT;\n            }\n        }\n\n        if (this.mipmaps.length) {\n            var width = this.width;\n            var height = this.height;\n            for (var i = 0; i < this.mipmaps.length; i++) {\n                var mipmap = this.mipmaps[i];\n                this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType);\n                width /= 2;\n                height /= 2;\n            }\n        }\n        else {\n            this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType);\n\n            if (this.useMipmap && !this.NPOT) {\n                _gl.generateMipmap(_gl.TEXTURE_2D);\n            }\n        }\n\n        _gl.bindTexture(_gl.TEXTURE_2D, null);\n    },\n\n    _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) {\n        if (data.image) {\n            _gl.texImage2D(_gl.TEXTURE_2D, level, glFormat, glFormat, glType, data.image);\n        }\n        else {\n            // Can be used as a blank texture when writing render to texture(RTT)\n            if (\n                glFormat <= Texture.COMPRESSED_RGBA_S3TC_DXT5_EXT\n                && glFormat >= Texture.COMPRESSED_RGB_S3TC_DXT1_EXT\n            ) {\n                _gl.compressedTexImage2D(_gl.TEXTURE_2D, level, glFormat, width, height, 0, data.pixels);\n            }\n            else {\n                // Is a render target if pixels is null\n                _gl.texImage2D(_gl.TEXTURE_2D, level, glFormat, width, height, 0, glFormat, glType, data.pixels);\n            }\n        }\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @memberOf clay.Texture2D.prototype\n     */\n    generateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        if (this.useMipmap && !this.NPOT) {\n            _gl.bindTexture(_gl.TEXTURE_2D, this._cache.get('webgl_texture'));\n            _gl.generateMipmap(_gl.TEXTURE_2D);\n        }\n    },\n\n    isPowerOfTwo: function () {\n        var width;\n        var height;\n        if (this.image) {\n            width = this.image.width;\n            height = this.image.height;\n        }\n        else {\n            width = this.width;\n            height = this.height;\n        }\n        return isPowerOfTwo(width) && isPowerOfTwo(height);\n    },\n\n    isRenderable: function () {\n        if (this.image) {\n            return this.image.nodeName === 'CANVAS'\n                || this.image.nodeName === 'VIDEO'\n                || this.image.complete;\n        }\n        else {\n            return !!(this.width && this.height);\n        }\n    },\n\n    bind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_2D, this.getWebGLTexture(renderer));\n    },\n\n    unbind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_2D, null);\n    },\n\n    load: function (src, crossOrigin) {\n        var image = new Image();\n        if (crossOrigin) {\n            image.crossOrigin = crossOrigin;\n        }\n        var self = this;\n        image.onload = function () {\n            self.dirty();\n            self.trigger('success', self);\n            image.onload = null;\n        };\n        image.onerror = function () {\n            self.trigger('error', self);\n            image.onerror = null;\n        };\n\n        image.src = src;\n        this.image = image;\n\n        return this;\n    }\n});\n\nObject.defineProperty(Texture2D.prototype, 'width', {\n    get: function () {\n        if (this.image) {\n            return this.image.width;\n        }\n        return this._width;\n    },\n    set: function (value) {\n        if (this.image) {\n            console.warn('Texture from image can\\'t set width');\n        }\n        else {\n            if (this._width !== value) {\n                this.dirty();\n            }\n            this._width = value;\n        }\n    }\n});\nObject.defineProperty(Texture2D.prototype, 'height', {\n    get: function () {\n        if (this.image) {\n            return this.image.height;\n        }\n        return this._height;\n    },\n    set: function (value) {\n        if (this.image) {\n            console.warn('Texture from image can\\'t set height');\n        }\n        else {\n            if (this._height !== value) {\n                this.dirty();\n            }\n            this._height = value;\n        }\n    }\n});\n\nexport default Texture2D;\n","import Shader from '../Shader';\n\nvar _library = {};\n\nfunction ShaderLibrary () {\n    this._pool = {};\n}\n\nShaderLibrary.prototype.get = function(name) {\n    var key = name;\n\n    if (this._pool[key]) {\n        return this._pool[key];\n    }\n    else {\n        var source = _library[name];\n        if (!source) {\n            console.error('Shader \"' + name + '\"' + ' is not in the library');\n            return;\n        }\n        var shader = new Shader(source.vertex, source.fragment);\n        this._pool[key] = shader;\n        return shader;\n    }\n};\n\nShaderLibrary.prototype.clear = function() {\n    this._pool = {};\n};\n\nfunction template(name, vertex, fragment) {\n    _library[name] = {\n        vertex: vertex,\n        fragment: fragment\n    };\n}\n\nvar defaultLibrary = new ShaderLibrary();\n\n/**\n * ### Builin shaders\n * + clay.standard\n * + clay.basic\n * + clay.lambert\n * + clay.wireframe\n *\n * @namespace clay.shader.library\n */\nexport default {\n    /**\n     * Create a new shader library.\n     */\n    createLibrary: function () {\n        return new ShaderLibrary();\n    },\n    /**\n     * Get shader from default library.\n     * @param {string} name\n     * @return {clay.Shader}\n     * @memberOf clay.shader.library\n     * @example\n     *     clay.shader.library.get('clay.standard')\n     */\n    get: function () {\n        return defaultLibrary.get.apply(defaultLibrary, arguments);\n    },\n    /**\n     * @memberOf clay.shader.library\n     * @param  {string} name\n     * @param  {string} vertex - Vertex shader code\n     * @param  {string} fragment - Fragment shader code\n     */\n    template: template,\n    clear: function () {\n        return defaultLibrary.clear();\n    }\n};\n","import Node from './Node';\nimport glenum from './core/glenum';\n\n// Cache\nvar prevDrawID = 0;\nvar prevDrawIndicesBuffer = null;\nvar prevDrawIsUseIndices = true;\n\nvar currentDrawID;\n\nvar RenderInfo = function() {\n    this.triangleCount = 0;\n    this.vertexCount = 0;\n    this.drawCallCount = 0;\n};\n\nfunction VertexArrayObject(\n    availableAttributes,\n    availableAttributeSymbols,\n    indicesBuffer\n) {\n    this.availableAttributes = availableAttributes;\n    this.availableAttributeSymbols = availableAttributeSymbols;\n    this.indicesBuffer = indicesBuffer;\n\n    this.vao = null;\n}\n/**\n * @constructor\n * @alias clay.Renderable\n * @extends clay.Node\n */\nvar Renderable = Node.extend(\n/** @lends clay.Renderable# */\n{\n    /**\n     * @type {clay.Material}\n     */\n    material: null,\n\n    /**\n     * @type {clay.Geometry}\n     */\n    geometry: null,\n\n    /**\n     * @type {number}\n     */\n    mode: glenum.TRIANGLES,\n\n    _drawCache: null,\n\n    _renderInfo: null\n}, function() {\n    this._drawCache = {};\n    this._renderInfo = new RenderInfo();\n},\n/** @lends clay.Renderable.prototype */\n{\n\n    __program: null,\n\n    /**\n     * Group of received light.\n     */\n    lightGroup: 0,\n    /**\n     * Render order, Nodes with smaller value renders before nodes with larger values.\n     * @type {Number}\n     */\n    renderOrder: 0,\n    /**\n     * Used when mode is LINES, LINE_STRIP or LINE_LOOP\n     * @type {number}\n     */\n    lineWidth: 1,\n\n    /**\n     * If enable culling\n     * @type {boolean}\n     */\n    culling: true,\n    /**\n     * Specify which side of polygon will be culled.\n     * Possible values:\n     *  + {@link clay.Renderable.BACK}\n     *  + {@link clay.Renderable.FRONT}\n     *  + {@link clay.Renderable.FRONT_AND_BACK}\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/cullFace\n     * @type {number}\n     */\n    cullFace: glenum.BACK,\n    /**\n     * Specify which side is front face.\n     * Possible values:\n     *  + {@link clay.Renderable.CW}\n     *  + {@link clay.Renderable.CCW}\n     * @see https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/frontFace\n     * @type {number}\n     */\n    frontFace: glenum.CCW,\n\n    /**\n     * If enable software frustum culling\n     * @type {boolean}\n     */\n    frustumCulling: true,\n    /**\n     * @type {boolean}\n     */\n    receiveShadow: true,\n    /**\n     * @type {boolean}\n     */\n    castShadow: true,\n    /**\n     * @type {boolean}\n     */\n    ignorePicking: false,\n    /**\n     * @type {boolean}\n     */\n    ignorePreZ: false,\n\n    /**\n     * @type {boolean}\n     */\n    ignoreGBuffer: false,\n\n    /**\n     * @return {boolean}\n     */\n    isRenderable: function() {\n        // TODO Shader ?\n        return this.geometry && this.material && this.material.shader && !this.invisible\n            && this.geometry.vertexCount > 0;\n    },\n\n    /**\n     * Before render hook\n     * @type {Function}\n     */\n    beforeRender: function (_gl) {},\n\n    /**\n     * Before render hook\n     * @type {Function}\n     */\n    afterRender: function (_gl, renderStat) {},\n\n    getBoundingBox: function (filter, out) {\n        out = Node.prototype.getBoundingBox.call(this, filter, out);\n        if (this.geometry && this.geometry.boundingBox) {\n            out.union(this.geometry.boundingBox);\n        }\n\n        return out;\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Material} [material]\n     * @return {Object}\n     */\n    render: function (renderer, material, program) {\n        var _gl = renderer.gl;\n        material = material || this.material;\n        // May use shader of other material if shader code are same\n        var shader = material.shader;\n        var geometry = this.geometry;\n\n        var glDrawMode = this.mode;\n\n        var nVertex = geometry.vertexCount;\n        var isUseIndices = geometry.isUseIndices();\n\n        var uintExt = renderer.getGLExtension('OES_element_index_uint');\n        var useUintExt = uintExt && nVertex > 0xffff;\n        var indicesType = useUintExt ? _gl.UNSIGNED_INT : _gl.UNSIGNED_SHORT;\n\n        var vaoExt = renderer.getGLExtension('OES_vertex_array_object');\n        // var vaoExt = null;\n\n        var isStatic = !geometry.dynamic;\n\n        var renderInfo = this._renderInfo;\n        renderInfo.vertexCount = nVertex;\n        renderInfo.triangleCount = 0;\n        renderInfo.drawCallCount = 0;\n        // Draw each chunk\n        var drawHashChanged = false;\n        // Hash with shader id in case previous material has less attributes than next material\n        currentDrawID = renderer.__uid__ + '-' + geometry.__uid__ + '-' + program.__uid__;\n\n        if (currentDrawID !== prevDrawID) {\n            drawHashChanged = true;\n        }\n        else {\n            // The cache will be invalid in the following cases\n            // 1. VAO is enabled and is binded to null after render\n            // 2. Geometry needs update\n            if (\n                // TODO Optimize\n                (vaoExt && isStatic)\n                // PENDING\n                || geometry._cache.isDirty('any')\n            ) {\n                drawHashChanged = true;\n            }\n        }\n        prevDrawID = currentDrawID;\n\n        if (!drawHashChanged) {\n            // Direct draw\n            if (prevDrawIsUseIndices) {\n                _gl.drawElements(glDrawMode, prevDrawIndicesBuffer.count, indicesType, 0);\n                renderInfo.triangleCount = prevDrawIndicesBuffer.count / 3;\n            }\n            else {\n                // FIXME Use vertex number in buffer\n                // vertexCount may get the wrong value when geometry forget to mark dirty after update\n                _gl.drawArrays(glDrawMode, 0, nVertex);\n            }\n            renderInfo.drawCallCount = 1;\n        }\n        else {\n            // Use the cache of static geometry\n            var vaoList = this._drawCache[currentDrawID];\n            if (!vaoList) {\n                var chunks = geometry.getBufferChunks(renderer);\n                if (!chunks) {  // Empty mesh\n                    return;\n                }\n                vaoList = [];\n                for (var c = 0; c < chunks.length; c++) {\n                    var chunk = chunks[c];\n                    var attributeBuffers = chunk.attributeBuffers;\n                    var indicesBuffer = chunk.indicesBuffer;\n\n                    var availableAttributes = [];\n                    var availableAttributeSymbols = [];\n                    for (var a = 0; a < attributeBuffers.length; a++) {\n                        var attributeBufferInfo = attributeBuffers[a];\n                        var name = attributeBufferInfo.name;\n                        var semantic = attributeBufferInfo.semantic;\n                        var symbol;\n                        if (semantic) {\n                            var semanticInfo = shader.attributeSemantics[semantic];\n                            symbol = semanticInfo && semanticInfo.symbol;\n                        }\n                        else {\n                            symbol = name;\n                        }\n                        if (symbol && program.attributes[symbol]) {\n                            availableAttributes.push(attributeBufferInfo);\n                            availableAttributeSymbols.push(symbol);\n                        }\n                    }\n\n                    var vao = new VertexArrayObject(\n                        availableAttributes,\n                        availableAttributeSymbols,\n                        indicesBuffer\n                    );\n                    vaoList.push(vao);\n                }\n                if (isStatic) {\n                    this._drawCache[currentDrawID] = vaoList;\n                }\n            }\n\n            for (var i = 0; i < vaoList.length; i++) {\n                var vao = vaoList[i];\n                var needsBindAttributes = true;\n\n                // Create vertex object array cost a lot\n                // So we don't use it on the dynamic object\n                if (vaoExt && isStatic) {\n                    // Use vertex array object\n                    // http://blog.tojicode.com/2012/10/oesvertexarrayobject-extension.html\n                    if (vao.vao == null) {\n                        vao.vao = vaoExt.createVertexArrayOES();\n                    }\n                    else {\n                        needsBindAttributes = false;\n                    }\n                    vaoExt.bindVertexArrayOES(vao.vao);\n                }\n\n                var availableAttributes = vao.availableAttributes;\n                var indicesBuffer = vao.indicesBuffer;\n\n                if (needsBindAttributes) {\n                    var locationList = program.enableAttributes(renderer, vao.availableAttributeSymbols, (vaoExt && isStatic && vao.vao));\n                    // Setting attributes;\n                    for (var a = 0; a < availableAttributes.length; a++) {\n                        var location = locationList[a];\n                        if (location === -1) {\n                            continue;\n                        }\n                        var attributeBufferInfo = availableAttributes[a];\n                        var buffer = attributeBufferInfo.buffer;\n                        var size = attributeBufferInfo.size;\n                        var glType;\n                        switch (attributeBufferInfo.type) {\n                            case 'float':\n                                glType = _gl.FLOAT;\n                                break;\n                            case 'byte':\n                                glType = _gl.BYTE;\n                                break;\n                            case 'ubyte':\n                                glType = _gl.UNSIGNED_BYTE;\n                                break;\n                            case 'short':\n                                glType = _gl.SHORT;\n                                break;\n                            case 'ushort':\n                                glType = _gl.UNSIGNED_SHORT;\n                                break;\n                            default:\n                                glType = _gl.FLOAT;\n                                break;\n                        }\n\n                        _gl.bindBuffer(_gl.ARRAY_BUFFER, buffer);\n                        _gl.vertexAttribPointer(location, size, glType, false, 0, 0);\n                    }\n                }\n                if (\n                    glDrawMode == glenum.LINES ||\n                    glDrawMode == glenum.LINE_STRIP ||\n                    glDrawMode == glenum.LINE_LOOP\n                ) {\n                    _gl.lineWidth(this.lineWidth);\n                }\n\n                prevDrawIndicesBuffer = indicesBuffer;\n                prevDrawIsUseIndices = geometry.isUseIndices();\n                // Do drawing\n                if (prevDrawIsUseIndices) {\n                    if (needsBindAttributes) {\n                        _gl.bindBuffer(_gl.ELEMENT_ARRAY_BUFFER, indicesBuffer.buffer);\n                    }\n                    _gl.drawElements(glDrawMode, indicesBuffer.count, indicesType, 0);\n                    renderInfo.triangleCount += indicesBuffer.count / 3;\n                } else {\n                    _gl.drawArrays(glDrawMode, 0, nVertex);\n                }\n\n                if (vaoExt && isStatic) {\n                    vaoExt.bindVertexArrayOES(null);\n                }\n\n                renderInfo.drawCallCount++;\n            }\n        }\n\n        return renderInfo;\n    },\n\n    /**\n     * Clone a new renderable\n     * @function\n     * @return {clay.Renderable}\n     */\n    clone: (function() {\n        var properties = [\n            'castShadow', 'receiveShadow',\n            'mode', 'culling', 'cullFace', 'frontFace',\n            'frustumCulling',\n            'renderOrder', 'lineWidth',\n            'ignorePicking', 'ignorePreZ', 'ignoreGBuffer'\n        ];\n        return function() {\n            var renderable = Node.prototype.clone.call(this);\n\n            renderable.geometry = this.geometry;\n            renderable.material = this.material;\n\n            for (var i = 0; i < properties.length; i++) {\n                var name = properties[i];\n                // Try not to overwrite the prototype property\n                if (renderable[name] !== this[name]) {\n                    renderable[name] = this[name];\n                }\n            }\n\n            return renderable;\n        };\n    })()\n});\n\n/**\n * @type {number}\n */\nRenderable.POINTS = glenum.POINTS;\n/**\n * @type {number}\n */\nRenderable.LINES = glenum.LINES;\n/**\n * @type {number}\n */\nRenderable.LINE_LOOP = glenum.LINE_LOOP;\n/**\n * @type {number}\n */\nRenderable.LINE_STRIP = glenum.LINE_STRIP;\n/**\n * @type {number}\n */\nRenderable.TRIANGLES = glenum.TRIANGLES;\n/**\n * @type {number}\n */\nRenderable.TRIANGLE_STRIP = glenum.TRIANGLE_STRIP;\n/**\n * @type {number}\n */\nRenderable.TRIANGLE_FAN = glenum.TRIANGLE_FAN;\n/**\n * @type {number}\n */\nRenderable.BACK = glenum.BACK;\n/**\n * @type {number}\n */\nRenderable.FRONT = glenum.FRONT;\n/**\n * @type {number}\n */\nRenderable.FRONT_AND_BACK = glenum.FRONT_AND_BACK;\n/**\n * @type {number}\n */\nRenderable.CW = glenum.CW;\n/**\n * @type {number}\n */\nRenderable.CCW = glenum.CCW;\n\nRenderable.RenderInfo = RenderInfo;\n\nexport default Renderable;\n","import Renderable from './Renderable';\nimport glenum from './core/glenum';\nimport Texture2D from './Texture2D';\n\n/**\n * @constructor clay.Mesh\n * @extends clay.Renderable\n */\nvar Mesh = Renderable.extend(\n/** @lends clay.Mesh# */\n{\n    /**\n     * Used when it is a skinned mesh\n     * @type {clay.Skeleton}\n     */\n    skeleton: null,\n    /**\n     * Joints indices Meshes can share the one skeleton instance and each mesh can use one part of joints. Joints indices indicate the index of joint in the skeleton instance\n     * @type {number[]}\n     */\n    joints: null,\n\n    /**\n     * If store the skin matrices in vertex texture\n     * @type {bool}\n     */\n    useSkinMatricesTexture: false\n\n}, function () {\n    if (!this.joints) {\n        this.joints = [];\n    }\n}, {\n\n    isSkinnedMesh: function () {\n        return !!(this.skeleton && this.joints && this.joints.length > 0);\n    },\n\n    render: function (renderer, shader, program) {\n        var _gl = renderer.gl;\n        // Set pose matrices of skinned mesh\n        if (this.skeleton) {\n            // TODO Multiple mesh share same skeleton\n            this.skeleton.update();\n\n            var skinMatricesArray = this.skeleton.getSubSkinMatrices(this.__uid__, this.joints);\n\n            // if (this.useSkinMatricesTexture) {\n            //     var size;\n            //     var numJoints = this.joints.length;\n            //     if (numJoints > 256) {\n            //         size = 64;\n            //     }\n            //     else if (numJoints > 64) {\n            //         size = 32;\n            //     }\n            //     else if (numJoints > 16) {\n            //         size = 16;\n            //     }\n            //     else {\n            //         size = 8;\n            //     }\n\n            //     var texture = this.getSkinMatricesTexture();\n            //     texture.width = size;\n            //     texture.height = size;\n\n            //     if (!texture.pixels || texture.pixels.length !== size * size * 4) {\n            //         texture.pixels = new Float32Array(size * size * 4);\n            //     }\n            //     texture.pixels.set(skinMatricesArray);\n            //     texture.dirty();\n\n            //     shader.setUniform(_gl, '1f', 'skinMatricesTextureSize', size);\n            // }\n            // else {\n            program.setUniformOfSemantic(_gl, 'SKIN_MATRIX', skinMatricesArray);\n            // }\n        }\n\n        return Renderable.prototype.render.call(this, renderer, shader, program);\n    },\n\n    getSkinMatricesTexture: function () {\n        this._skinMatricesTexture = this._skinMatricesTexture || new Texture2D({\n            type: glenum.FLOAT,\n            minFilter: glenum.NEAREST,\n            magFilter: glenum.NEAREST,\n            useMipmap: false,\n            flipY: false\n        });\n\n        return this._skinMatricesTexture;\n    }\n});\n\n// Enums\nMesh.POINTS = glenum.POINTS;\nMesh.LINES = glenum.LINES;\nMesh.LINE_LOOP = glenum.LINE_LOOP;\nMesh.LINE_STRIP = glenum.LINE_STRIP;\nMesh.TRIANGLES = glenum.TRIANGLES;\nMesh.TRIANGLE_STRIP = glenum.TRIANGLE_STRIP;\nMesh.TRIANGLE_FAN = glenum.TRIANGLE_FAN;\n\nMesh.BACK = glenum.BACK;\nMesh.FRONT = glenum.FRONT;\nMesh.FRONT_AND_BACK = glenum.FRONT_AND_BACK;\nMesh.CW = glenum.CW;\nMesh.CCW = glenum.CCW;\n\nexport default Mesh;\n","import Camera from '../Camera';\n\n/**\n * @constructor clay.camera.Perspective\n * @extends clay.Camera\n */\nvar Perspective = Camera.extend(\n/** @lends clay.camera.Perspective# */\n{\n    /**\n     * Vertical field of view in radians\n     * @type {number}\n     */\n    fov: 50,\n    /**\n     * Aspect ratio, typically viewport width / height\n     * @type {number}\n     */\n    aspect: 1,\n    /**\n     * Near bound of the frustum\n     * @type {number}\n     */\n    near: 0.1,\n    /**\n     * Far bound of the frustum\n     * @type {number}\n     */\n    far: 2000\n},\n/** @lends clay.camera.Perspective.prototype */\n{\n\n    updateProjectionMatrix: function() {\n        var rad = this.fov / 180 * Math.PI;\n        this.projectionMatrix.perspective(rad, this.aspect, this.near, this.far);\n    },\n    decomposeProjectionMatrix: function () {\n        var m = this.projectionMatrix.array;\n        var rad = Math.atan(1 / m[5]) * 2;\n        this.fov = rad / Math.PI * 180;\n        this.aspect = m[5] / m[0];\n        this.near = m[14] / (m[10] - 1);\n        this.far = m[14] / (m[10] + 1);\n    },\n    /**\n     * @return {clay.camera.Perspective}\n     */\n    clone: function() {\n        var camera = Camera.prototype.clone.call(this);\n        camera.fov = this.fov;\n        camera.aspect = this.aspect;\n        camera.near = this.near;\n        camera.far = this.far;\n\n        return camera;\n    }\n});\n\nexport default Perspective;\n","import Camera from '../Camera';\n/**\n * @constructor clay.camera.Orthographic\n * @extends clay.Camera\n */\nvar Orthographic = Camera.extend(\n/** @lends clay.camera.Orthographic# */\n{\n    /**\n     * @type {number}\n     */\n    left: -1,\n    /**\n     * @type {number}\n     */\n    right: 1,\n    /**\n     * @type {number}\n     */\n    near: -1,\n    /**\n     * @type {number}\n     */\n    far: 1,\n    /**\n     * @type {number}\n     */\n    top: 1,\n    /**\n     * @type {number}\n     */\n    bottom: -1\n},\n/** @lends clay.camera.Orthographic.prototype */\n{\n\n    updateProjectionMatrix: function() {\n        this.projectionMatrix.ortho(this.left, this.right, this.bottom, this.top, this.near, this.far);\n    },\n\n    decomposeProjectionMatrix: function () {\n        var m = this.projectionMatrix.array;\n        this.left = (-1 - m[12]) / m[0];\n        this.right = (1 - m[12]) / m[0];\n        this.top = (1 - m[13]) / m[5];\n        this.bottom = (-1 - m[13]) / m[5];\n        this.near = -(-1 - m[14]) / m[10];\n        this.far = -(1 - m[14]) / m[10];\n    },\n    /**\n     * @return {clay.camera.Orthographic}\n     */\n    clone: function() {\n        var camera = Camera.prototype.clone.call(this);\n        camera.left = this.left;\n        camera.right = this.right;\n        camera.near = this.near;\n        camera.far = this.far;\n        camera.top = this.top;\n        camera.bottom = this.bottom;\n\n        return camera;\n    }\n});\n\nexport default Orthographic;\n","function get(options) {\n\n    var xhr = new XMLHttpRequest();\n\n    xhr.open('get', options.url);\n    // With response type set browser can get and put binary data\n    // https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/Sending_and_Receiving_Binary_Data\n    // Default is text, and it can be set\n    // arraybuffer, blob, document, json, text\n    xhr.responseType = options.responseType || 'text';\n\n    if (options.onprogress) {\n        //https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/Using_XMLHttpRequest\n        xhr.onprogress = function(e) {\n            if (e.lengthComputable) {\n                var percent = e.loaded / e.total;\n                options.onprogress(percent, e.loaded, e.total);\n            }\n            else {\n                options.onprogress(null);\n            }\n        };\n    }\n    xhr.onload = function(e) {\n        if (xhr.status >= 400) {\n            options.onerror && options.onerror();\n        }\n        else {\n            options.onload && options.onload(xhr.response);\n        }\n    };\n    if (options.onerror) {\n        xhr.onerror = options.onerror;\n    }\n    xhr.send(null);\n}\n\nexport default {\n    get : get\n};\n","export default \"\\n@export clay.standard.vertex\\n#define SHADER_NAME standard\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\n#if defined(AOMAP_ENABLED)\\nattribute vec2 texcoord2 : TEXCOORD_1;\\n#endif\\nattribute vec3 normal : NORMAL;\\nattribute vec4 tangent : TANGENT;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nvarying vec3 v_Barycentric;\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\n#endif\\n#if defined(AOMAP_ENABLED)\\nvarying vec2 v_Texcoord2;\\n#endif\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n    vec3 skinnedNormal = normal;\\n    vec3 skinnedTangent = tangent.xyz;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n    skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n    v_Barycentric = barycentric;\\n    v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\n    v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\\n    v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\\n#endif\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n#if defined(AOMAP_ENABLED)\\n    v_Texcoord2 = texcoord2;\\n#endif\\n}\\n@end\\n@export clay.standard.fragment\\n#define PI 3.14159265358979\\n#define GLOSSINESS_CHANNEL 0\\n#define ROUGHNESS_CHANNEL 0\\n#define METALNESS_CHANNEL 1\\nuniform mat4 viewInverse : VIEWINVERSE;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\n#endif\\n#ifdef NORMALMAP_ENABLED\\nuniform sampler2D normalMap;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\nuniform sampler2D diffuseMap;\\n#endif\\n#ifdef SPECULARMAP_ENABLED\\nuniform sampler2D specularMap;\\n#endif\\n#ifdef USE_ROUGHNESS\\nuniform float roughness : 0.5;\\n    #ifdef ROUGHNESSMAP_ENABLED\\nuniform sampler2D roughnessMap;\\n    #endif\\n#else\\nuniform float glossiness: 0.5;\\n    #ifdef GLOSSINESSMAP_ENABLED\\nuniform sampler2D glossinessMap;\\n    #endif\\n#endif\\n#ifdef METALNESSMAP_ENABLED\\nuniform sampler2D metalnessMap;\\n#endif\\n#ifdef ENVIRONMENTMAP_ENABLED\\nuniform samplerCube environmentMap;\\n    #ifdef PARALLAX_CORRECTED\\nuniform vec3 environmentBoxMin;\\nuniform vec3 environmentBoxMax;\\n    #endif\\n#endif\\n#ifdef BRDFLOOKUP_ENABLED\\nuniform sampler2D brdfLookup;\\n#endif\\n#ifdef EMISSIVEMAP_ENABLED\\nuniform sampler2D emissiveMap;\\n#endif\\n#ifdef SSAOMAP_ENABLED\\nuniform sampler2D ssaoMap;\\nuniform vec4 viewport : VIEWPORT;\\n#endif\\n#ifdef AOMAP_ENABLED\\nuniform sampler2D aoMap;\\nuniform float aoIntensity;\\nvarying vec2 v_Texcoord2;\\n#endif\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\n#ifdef USE_METALNESS\\nuniform float metalness : 0.0;\\n#else\\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\\n#endif\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float emissionIntensity: 1;\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n#ifdef ENVIRONMENTMAP_PREFILTER\\nuniform float maxMipmapLevel: 5;\\n#endif\\n#ifdef AMBIENT_LIGHT_COUNT\\n@import clay.header.ambient_light\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n@import clay.header.ambient_sh_light\\n#endif\\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\\n@import clay.header.ambient_cubemap_light\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n@import clay.header.point_light\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n@import clay.header.directional_light\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n@import clay.header.spot_light\\n#endif\\n@import clay.util.calculate_attenuation\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.util.srgb\\n@import clay.plugin.compute_shadow_map\\n@import clay.util.parallax_correct\\n@import clay.util.ACES\\nfloat G_Smith(float g, float ndv, float ndl)\\n{\\n    float roughness = 1.0 - g;\\n    float k = roughness * roughness / 2.0;\\n    float G1V = ndv / (ndv * (1.0 - k) + k);\\n    float G1L = ndl / (ndl * (1.0 - k) + k);\\n    return G1L * G1V;\\n}\\nvec3 F_Schlick(float ndv, vec3 spec) {\\n    return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\\n}\\nfloat D_Phong(float g, float ndh) {\\n    float a = pow(8192.0, g);\\n    return (a + 2.0) / 8.0 * pow(ndh, a);\\n}\\nfloat D_GGX(float g, float ndh) {\\n    float r = 1.0 - g;\\n    float a = r * r;\\n    float tmp = ndh * ndh * (a - 1.0) + 1.0;\\n    return a / (PI * tmp * tmp);\\n}\\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\\nuniform float parallaxOcclusionScale : 0.02;\\nuniform float parallaxMaxLayers : 20;\\nuniform float parallaxMinLayers : 5;\\nuniform sampler2D parallaxOcclusionMap;\\nmat3 transpose(in mat3 inMat)\\n{\\n    vec3 i0 = inMat[0];\\n    vec3 i1 = inMat[1];\\n    vec3 i2 = inMat[2];\\n    return mat3(\\n        vec3(i0.x, i1.x, i2.x),\\n        vec3(i0.y, i1.y, i2.y),\\n        vec3(i0.z, i1.z, i2.z)\\n    );\\n}\\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\\n{\\n    float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\\n    float layerHeight = 1.0 / numLayers;\\n    float curLayerHeight = 0.0;\\n    vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\\n    vec2 curUv = uv;\\n    float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\\n    for (int i = 0; i < 30; i++) {\\n        curLayerHeight += layerHeight;\\n        curUv -= deltaUv;\\n        height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\\n        if (height < curLayerHeight) {\\n            break;\\n        }\\n    }\\n    vec2 prevUv = curUv + deltaUv;\\n    float next = height - curLayerHeight;\\n    float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\\n    return mix(curUv, prevUv, next / (next - prev));\\n}\\n#endif\\nvoid main() {\\n    vec4 albedoColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    albedoColor *= v_Color;\\n#endif\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 V = normalize(eyePos - v_WorldPosition);\\n    vec2 uv = v_Texcoord;\\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\\n    mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\\n#endif\\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\\n    uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 texel = texture2D(diffuseMap, uv);\\n    #ifdef SRGB_DECODE\\n    texel = sRGBToLinear(texel);\\n    #endif\\n    albedoColor.rgb *= texel.rgb;\\n    #ifdef DIFFUSEMAP_ALPHA_ALPHA\\n    albedoColor.a *= texel.a;\\n    #endif\\n#endif\\n#ifdef USE_METALNESS\\n    float m = metalness;\\n    #ifdef METALNESSMAP_ENABLED\\n    float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\\n    m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n    vec3 baseColor = albedoColor.rgb;\\n    albedoColor.rgb = baseColor * (1.0 - m);\\n    vec3 spec = mix(vec3(0.04), baseColor, m);\\n#else\\n    vec3 spec = specularColor;\\n#endif\\n#ifdef USE_ROUGHNESS\\n    float g = 1.0 - roughness;\\n    #ifdef ROUGHNESSMAP_ENABLED\\n    float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\\n    g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n#else\\n    float g = glossiness;\\n    #ifdef GLOSSINESSMAP_ENABLED\\n    float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\\n    g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    #endif\\n#endif\\n#ifdef SPECULARMAP_ENABLED\\n    spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\\n#endif\\n    vec3 N = v_Normal;\\n#ifdef DOUBLE_SIDED\\n    if (dot(N, V) < 0.0) {\\n        N = -N;\\n    }\\n#endif\\n#ifdef NORMALMAP_ENABLED\\n    if (dot(v_Tangent, v_Tangent) > 0.0) {\\n        vec3 normalTexel = texture2D(normalMap, uv).xyz;\\n        if (dot(normalTexel, normalTexel) > 0.0) {            N = normalTexel * 2.0 - 1.0;\\n            tbn[1] = -tbn[1];\\n            N = normalize(tbn * N);\\n        }\\n    }\\n#endif\\n    vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\\n    vec3 specularTerm = vec3(0.0, 0.0, 0.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    vec3 fresnelTerm = F_Schlick(ndv, spec);\\n#ifdef AMBIENT_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseTerm += ambientLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsPoint[POINT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\\n    }\\n#endif\\n    for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\\n    {{\\n        vec3 lightPosition = pointLightPosition[_idx_];\\n        vec3 lc = pointLightColor[_idx_];\\n        float range = pointLightRange[_idx_];\\n        vec3 L = lightPosition - v_WorldPosition;\\n        float dist = length(L);\\n        float attenuation = lightAttenuation(dist, range);\\n        L /= dist;\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n        if(shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsPoint[_idx_];\\n        }\\n#endif\\n        vec3 li = lc * ndl * attenuation * shadowContrib;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }}\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\\n    }\\n#endif\\n    for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\\n    {{\\n        vec3 L = -normalize(directionalLightDirection[_idx_]);\\n        vec3 lc = directionalLightColor[_idx_];\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n        if(shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsDir[_idx_];\\n        }\\n#endif\\n        vec3 li = lc * ndl * shadowContrib;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }}\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsSpot[SPOT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\\n    }\\n#endif\\n    for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = spotLightPosition[i];\\n        vec3 spotLightDirection = -normalize(spotLightDirection[i]);\\n        vec3 lc = spotLightColor[i];\\n        float range = spotLightRange[i];\\n        float a = spotLightUmbraAngleCosine[i];\\n        float b = spotLightPenumbraAngleCosine[i];\\n        float falloffFactor = spotLightFalloffFactor[i];\\n        vec3 L = lightPosition - v_WorldPosition;\\n        float dist = length(L);\\n        float attenuation = lightAttenuation(dist, range);\\n        L /= dist;\\n        float c = dot(spotLightDirection, L);\\n        float falloff;\\n        falloff = clamp((c - a) /( b - a), 0.0, 1.0);\\n        falloff = pow(falloff, falloffFactor);\\n        vec3 H = normalize(L + V);\\n        float ndl = clamp(dot(N, L), 0.0, 1.0);\\n        float ndh = clamp(dot(N, H), 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n        if (shadowEnabled)\\n        {\\n            shadowContrib = shadowContribsSpot[i];\\n        }\\n#endif\\n        vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\\n        diffuseTerm += li;\\n        specularTerm += li * fresnelTerm * D_Phong(g, ndh);\\n    }\\n#endif\\n    vec4 outColor = albedoColor;\\n    outColor.rgb *= diffuseTerm;\\n    outColor.rgb += specularTerm;\\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\\n    vec3 L = reflect(-V, N);\\n    float rough2 = clamp(1.0 - g, 0.0, 1.0);\\n    float bias2 = rough2 * 5.0;\\n    vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\\n    vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\\n    vec3 envTexel2;\\n    for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\\n    {{\\n        envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\\n        outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\\n    }}\\n#endif\\n#ifdef ENVIRONMENTMAP_ENABLED\\n    vec3 envWeight = g * fresnelTerm;\\n    vec3 L = reflect(-V, N);\\n    #ifdef PARALLAX_CORRECTED\\n    L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\\n    #endif\\n    #ifdef ENVIRONMENTMAP_PREFILTER\\n    float rough = clamp(1.0 - g, 0.0, 1.0);\\n    float bias = rough * maxMipmapLevel;\\n    vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\\n        #ifdef BRDFLOOKUP_ENABLED\\n    vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\\n    envWeight = spec * brdfParam.x + brdfParam.y;\\n        #endif\\n    #else\\n    vec3 envTexel = textureCube(environmentMap, L).xyz;\\n    #endif\\n    outColor.rgb += envTexel * envWeight;\\n#endif\\n    float aoFactor = 1.0;\\n#ifdef SSAOMAP_ENABLED\\n    aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\\n#endif\\n#ifdef AOMAP_ENABLED\\n    aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\\n#endif\\n    outColor.rgb *= aoFactor;\\n    vec3 lEmission = emission;\\n#ifdef EMISSIVEMAP_ENABLED\\n    lEmission *= texture2D(emissiveMap, uv).rgb;\\n#endif\\n    outColor.rgb += lEmission * emissionIntensity;\\n#ifdef GAMMA_ENCODE\\n    outColor.rgb = pow(outColor.rgb, vec3(1 / 2.2));\\n#endif\\n    if(lineWidth > 0.)\\n    {\\n        outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef ALPHA_TEST\\n    if (outColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    outColor.rgb = ACESToneMapping(outColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    outColor = linearTosRGB(outColor);\\n#endif\\n    gl_FragColor = encodeHDR(outColor);\\n}\\n@end\\n@export clay.standardMR.vertex\\n@import clay.standard.vertex\\n@end\\n@export clay.standardMR.fragment\\n#define USE_METALNESS\\n#define USE_ROUGHNESS\\n@import clay.standard.fragment\\n@end\";\n","import Material from './Material';\n\nimport Shader from './Shader';\nimport standardEssl from './shader/source/standard.glsl.js';\nimport util from './core/util';\n\n// Import standard shader\nShader['import'](standardEssl);\n\nvar TEXTURE_PROPERTIES = ['diffuseMap', 'normalMap', 'roughnessMap', 'metalnessMap', 'emissiveMap', 'environmentMap', 'brdfLookup', 'ssaoMap', 'aoMap'];\nvar SIMPLE_PROPERTIES = ['color', 'emission', 'emissionIntensity', 'alpha', 'roughness', 'metalness', 'uvRepeat', 'uvOffset', 'aoIntensity', 'alphaCutoff'];\nvar PROPERTIES_CHANGE_SHADER = ['linear', 'encodeRGBM', 'decodeRGBM', 'doubleSided', 'alphaTest', 'roughnessChannel', 'metalnessChannel', 'environmentMapPrefiltered'];\n\nvar NUM_DEFINE_MAP = {\n    'roughnessChannel': 'ROUGHNESS_CHANNEL',\n    'metalnessChannel': 'METALNESS_CHANNEL'\n};\nvar BOOL_DEFINE_MAP = {\n    'linear': 'SRGB_DECODE',\n    'encodeRGBM': 'RGBM_ENCODE',\n    'decodeRGBM': 'RGBM_DECODE',\n    'doubleSided': 'DOUBLE_SIDED',\n    'alphaTest': 'ALPHA_TEST',\n    'environmentMapPrefiltered': 'ENVIRONMENTMAP_PREFILTER'\n}\n\n\nvar standardShader;\n/**\n * Standard material without custom shader.\n * @constructor clay.StandardMaterial\n * @extends clay.Base\n * @example\n * var mat = new clay.StandardMaterial({\n *     color: [1, 1, 1],\n *     diffuseMap: diffuseTexture\n * });\n * mat.roughness = 1;\n */\nvar StandardMaterial = Material.extend(function () {\n    if (!standardShader) {\n        standardShader = new Shader(Shader.source('clay.standard.vertex'), Shader.source('clay.standard.fragment'));\n    }\n    return /** @lends clay.StandardMaterial# */ {\n        shader: standardShader\n    };\n}, function (option) {\n    // PENDING\n    util.extend(this, option);\n    // Extend after shader is created.\n    util.defaults(this, /** @lends clay.StandardMaterial# */  {\n        /**\n         * @type {Array.<number>}\n         * @default [1, 1, 1]\n         */\n        color: [1, 1, 1],\n\n        /**\n         * @type {Array.<number>}\n         * @default [0, 0, 0]\n         */\n        emission: [0, 0, 0],\n\n        /**\n         * @type {number}\n         * @default 0\n         */\n        emissionIntensity: 0,\n\n        /**\n         * @type {number}\n         * @default 0.5\n         */\n        roughness: 0.5,\n\n        /**\n         * @type {number}\n         * @default 0\n         */\n        metalness: 0,\n\n        /**\n         * @type {number}\n         * @default 1\n         */\n        alpha: 1,\n\n        /**\n         * @type {boolean}\n         */\n        alphaTest: false,\n\n        /**\n         * Cutoff threshold for alpha test\n         * @type {number}\n         */\n        alphaCutoff: 0.9,\n\n        /**\n         * @type {boolean}\n         */\n        // TODO Must disable culling.\n        doubleSided: false,\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.TextureCube}\n         */\n\n        /**\n         * @type {clay.math.BoundingBox}\n         */\n\n        /**\n         * BRDF Lookup is generated by clay.util.cubemap.integrateBrdf\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {clay.Texture2D}\n         */\n\n        /**\n         * @type {Array.<number>}\n         * @default [1, 1]\n         */\n        uvRepeat: [1, 1],\n\n        /**\n         * @type {Array.<number>}\n         * @default [0, 0]\n         */\n        uvOffset: [0, 0],\n\n        /**\n         * @type {number}\n         * @default 1\n         */\n        aoIntensity: 1,\n\n        /**\n         * @type {boolean}\n         */\n        environmentMapPrefiltered: false,\n\n        /**\n         * @type {boolean}\n         */\n        linear: false,\n\n        /**\n         * @type {boolean}\n         */\n        encodeRGBM: false,\n\n        /**\n         * @type {boolean}\n         */\n        decodeRGBM: false,\n\n        /**\n         * @type {Number}\n         */\n        roughnessChannel: 0,\n        /**\n         * @type {Number}\n         */\n        metalnessChannel: 1\n    });\n\n    this.define('fragment', 'USE_METALNESS');\n    this.define('fragment', 'USE_ROUGHNESS');\n}, {\n    clone: function () {\n        var material = new StandardMaterial({\n            name: this.name\n        });\n        TEXTURE_PROPERTIES.forEach(function (propName) {\n            if (this[propName]) {\n                material[propName] = this[propName];\n            }\n        }, this);\n        SIMPLE_PROPERTIES.concat(PROPERTIES_CHANGE_SHADER).forEach(function (propName) {\n            material[propName] = this[propName];\n        }, this);\n        return material;\n    }\n});\n\nSIMPLE_PROPERTIES.forEach(function (propName) {\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this.get(propName);\n        },\n        set: function (value) {\n            this.setUniform(propName, value);\n        }\n    });\n});\n\nTEXTURE_PROPERTIES.forEach(function (propName) {\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this.get(propName);\n        },\n        set: function (value) {\n            this.setUniform(propName, value);\n        }\n    });\n});\n\nPROPERTIES_CHANGE_SHADER.forEach(function (propName) {\n    var privateKey = '_' + propName;\n    Object.defineProperty(StandardMaterial.prototype, propName, {\n        get: function () {\n            return this[privateKey];\n        },\n        set: function (value) {\n            this[privateKey] = value;\n            if (propName in NUM_DEFINE_MAP) {\n                var defineName = NUM_DEFINE_MAP[propName];\n                this.define('fragment', defineName, value);\n            }\n            else {\n                var defineName = BOOL_DEFINE_MAP[propName];\n                value ? this.define('fragment', defineName) : this.undefine('fragment', defineName);\n            }\n        }\n    });\n});\n\nObject.defineProperty(StandardMaterial.prototype, 'environmentBox', {\n    get: function () {\n        var envBox = this._environmentBox;\n        if (envBox) {\n            envBox.min.setArray(this.get('environmentBoxMin'));\n            envBox.max.setArray(this.get('environmentBoxMax'));\n        }\n        return envBox;\n    },\n\n    set: function (value) {\n        this._environmentBox = value;\n\n        var uniforms = this.uniforms = this.uniforms || {};\n        uniforms['environmentBoxMin'] = uniforms['environmentBoxMin'] || {\n            value: null\n        };\n        uniforms['environmentBoxMax'] = uniforms['environmentBoxMax'] || {\n            value: null\n        };\n\n        // TODO Can't detect operation like box.min = new Vector()\n        if (value) {\n            this.setUniform('environmentBoxMin', value.min.array);\n            this.setUniform('environmentBoxMax', value.max.array);\n        }\n\n        if (value) {\n            this.define('fragment', 'PARALLAX_CORRECTED');\n        }\n        else {\n            this.undefine('fragment', 'PARALLAX_CORRECTED');\n        }\n    }\n});\n\nexport default StandardMaterial;\n","import Base from './core/Base';\n\n/**\n * @constructor clay.Joint\n * @extends clay.core.Base\n */\nvar Joint = Base.extend(\n/** @lends clay.Joint# */\n{\n    // https://github.com/KhronosGroup/glTF/issues/193#issuecomment-29216576\n    /**\n     * Joint name\n     * @type {string}\n     */\n    name: '',\n    /**\n     * Index of joint in the skeleton\n     * @type {number}\n     */\n    index: -1,\n\n    /**\n     * Scene node attached to\n     * @type {clay.Node}\n     */\n    node: null,\n\n    /**\n     * Root scene node of the skeleton, which parent node is null or don't have a joint\n     * @type {clay.Node}\n     */\n    rootNode: null\n});\n\nexport default Joint;\n","import Base from './core/Base';\nimport Joint from './Joint';\n\nimport glMatrix from './dep/glmatrix';\nvar quat = glMatrix.quat;\nvar vec3 = glMatrix.vec3;\nvar mat4 = glMatrix.mat4;\n\n/**\n * @constructor clay.Skeleton\n */\nvar Skeleton = Base.extend(function () {\n    return /** @lends clay.Skeleton# */{\n\n        /**\n         * Relative root node that not affect transform of joint.\n         * @type {clay.Node}\n         */\n        relativeRootNode: null,\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * joints\n         * @type {Array.<clay.Joint>}\n         */\n        joints: [],\n\n        _clips: [],\n\n        // Matrix to joint space (relative to root joint)\n        _invBindPoseMatricesArray: null,\n\n        // Use subarray instead of copy back each time computing matrix\n        // http://jsperf.com/subarray-vs-copy-for-array-transform/5\n        _jointMatricesSubArrays: [],\n\n        // jointMatrix * currentPoseMatrix\n        // worldTransform is relative to the root bone\n        // still in model space not world space\n        _skinMatricesArray: null,\n\n        _skinMatricesSubArrays: [],\n\n        _subSkinMatricesArray: {}\n    };\n},\n/** @lends clay.Skeleton.prototype */\n{\n\n    /**\n     * Add a skinning clip and create a map between clip and skeleton\n     * @param {clay.animation.SkinningClip} clip\n     * @param {Object} [mapRule] Map between joint name in skeleton and joint name in clip\n     */\n    addClip: function (clip, mapRule) {\n        // Clip have been exists in\n        for (var i = 0; i < this._clips.length; i++) {\n            if (this._clips[i].clip === clip) {\n                return;\n            }\n        }\n        // Map the joint index in skeleton to joint pose index in clip\n        var maps = [];\n        for (var i = 0; i < this.joints.length; i++) {\n            maps[i] = -1;\n        }\n        // Create avatar\n        for (var i = 0; i < clip.tracks.length; i++) {\n            for (var j = 0; j < this.joints.length; j++) {\n                var joint = this.joints[j];\n                var track = clip.tracks[i];\n                var jointName = joint.name;\n                if (mapRule) {\n                    jointName = mapRule[jointName];\n                }\n                if (track.name === jointName) {\n                    maps[j] = i;\n                    break;\n                }\n            }\n        }\n\n        this._clips.push({\n            maps: maps,\n            clip: clip\n        });\n\n        return this._clips.length - 1;\n    },\n\n    /**\n     * @param {clay.animation.SkinningClip} clip\n     */\n    removeClip: function (clip) {\n        var idx = -1;\n        for (var i = 0; i < this._clips.length; i++) {\n            if (this._clips[i].clip === clip) {\n                idx = i;\n                break;\n            }\n        }\n        if (idx > 0) {\n            this._clips.splice(idx, 1);\n        }\n    },\n    /**\n     * Remove all clips\n     */\n    removeClipsAll: function () {\n        this._clips = [];\n    },\n\n    /**\n     * Get clip by index\n     * @param  {number} index\n     */\n    getClip: function (index) {\n        if (this._clips[index]) {\n            return this._clips[index].clip;\n        }\n    },\n\n    /**\n     * @return {number}\n     */\n    getClipNumber: function () {\n        return this._clips.length;\n    },\n\n    /**\n     * Calculate joint matrices from node transform\n     * @function\n     */\n    updateJointMatrices: (function () {\n\n        var m4 = mat4.create();\n\n        return function () {\n            this._invBindPoseMatricesArray = new Float32Array(this.joints.length * 16);\n            this._skinMatricesArray = new Float32Array(this.joints.length * 16);\n\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                // if (this.relativeRootNode) {\n                //     mat4.invert(m4, this.relativeRootNode.worldTransform.array);\n                //     mat4.multiply(\n                //         m4,\n                //         m4,\n                //         joint.node.worldTransform.array\n                //     );\n                //     mat4.invert(m4, m4);\n                // }\n                // else {\n                    mat4.copy(m4, joint.node.worldTransform.array);\n                    mat4.invert(m4, m4);\n                // }\n\n                var offset = i * 16;\n                for (var j = 0; j < 16; j++) {\n                    this._invBindPoseMatricesArray[offset + j] = m4[j];\n                }\n            }\n\n            this.updateMatricesSubArrays();\n        };\n    })(),\n\n    setJointMatricesArray: function (arr) {\n        this._invBindPoseMatricesArray = arr;\n        this._skinMatricesArray = new Float32Array(arr.length);\n        this.updateMatricesSubArrays();\n    },\n\n    updateMatricesSubArrays: function () {\n        for (var i = 0; i < this.joints.length; i++) {\n            this._jointMatricesSubArrays[i] = this._invBindPoseMatricesArray.subarray(i * 16, (i+1) * 16);\n            this._skinMatricesSubArrays[i] = this._skinMatricesArray.subarray(i * 16, (i+1) * 16);\n        }\n    },\n\n    /**\n     * Update skinning matrices\n     */\n    update: (function () {\n        // var m4 = mat4.create();\n        return function () {\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                mat4.multiply(\n                    this._skinMatricesSubArrays[i],\n                    joint.node.worldTransform.array,\n                    this._jointMatricesSubArrays[i]\n                );\n\n                // Joint space is relative to root, if have\n                // if (this.relativeRootNode) {\n                //     mat4.invert(m4, this.relativeRootNode.worldTransform.array);\n                //     mat4.multiply(\n                //         this._skinMatricesSubArrays[i],\n                //         m4,\n                //         this._skinMatricesSubArrays[i]\n                //     );\n                // }\n            }\n        };\n    })(),\n\n    getSubSkinMatrices: function (meshId, joints) {\n        var subArray = this._subSkinMatricesArray[meshId];\n        if (!subArray) {\n            subArray\n                = this._subSkinMatricesArray[meshId]\n                = new Float32Array(joints.length * 16);\n        }\n        var cursor = 0;\n        for (var i = 0; i < joints.length; i++) {\n            var idx = joints[i];\n            for (var j = 0; j < 16; j++) {\n                subArray[cursor++] = this._skinMatricesArray[idx * 16 + j];\n            }\n        }\n        return subArray;\n    },\n\n    /**\n     * Set pose and update skinning matrices\n     * @param {number} clipIndex\n     */\n    setPose: function (clipIndex) {\n        if (this._clips[clipIndex]) {\n            var clip = this._clips[clipIndex].clip;\n            var maps = this._clips[clipIndex].maps;\n\n            for (var i = 0; i < this.joints.length; i++) {\n                var joint = this.joints[i];\n                if (maps[i] === -1) {\n                    continue;\n                }\n                var pose = clip.tracks[maps[i]];\n\n                // Not update if there is no data.\n                // PENDING If sync pose.position, pose.rotation, pose.scale\n                if (pose.channels.position) {\n                    vec3.copy(joint.node.position.array, pose.position);\n                }\n                if (pose.channels.rotation) {\n                    quat.copy(joint.node.rotation.array, pose.rotation);\n                }\n                if (pose.channels.scale) {\n                    vec3.copy(joint.node.scale.array, pose.scale);\n                }\n\n                joint.node.position._dirty = true;\n                joint.node.rotation._dirty = true;\n                joint.node.scale._dirty = true;\n            }\n        }\n        this.update();\n    },\n\n    clone: function (rootNode, newRootNode) {\n        var skeleton = new Skeleton();\n        skeleton.name = this.name;\n\n        for (var i = 0; i < this.joints.length; i++) {\n            var newJoint = new Joint();\n            newJoint.name = this.joints[i].name;\n            newJoint.index = this.joints[i].index;\n\n            var path = this.joints[i].node.getPath(rootNode);\n            var rootNodePath = this.joints[i].rootNode.getPath(rootNode);\n\n            if (path != null && rootNodePath != null) {\n                newJoint.node = newRootNode.queryNode(path);\n            }\n            else {\n                // PENDING\n                console.warn('Something wrong in clone, may be the skeleton root nodes is not mounted on the cloned root node.')\n            }\n            skeleton.joints.push(newJoint);\n        }\n\n        if (this._invBindPoseMatricesArray) {\n            var len = this._invBindPoseMatricesArray.length;\n            skeleton._invBindPoseMatricesArray = new Float32Array(len);\n            for (var i = 0; i < len; i++) {\n                skeleton._invBindPoseMatricesArray[i] = this._invBindPoseMatricesArray[i];\n            }\n\n            skeleton._skinMatricesArray = new Float32Array(len);\n\n            skeleton.updateMatricesSubArrays();\n        }\n\n        skeleton.update();\n\n        return skeleton;\n    }\n});\n\nexport default Skeleton;\n","export default \"\\n@export clay.util.rand\\nhighp float rand(vec2 uv) {\\n    const highp float a = 12.9898, b = 78.233, c = 43758.5453;\\n    highp float dt = dot(uv.xy, vec2(a,b)), sn = mod(dt, 3.141592653589793);\\n    return fract(sin(sn) * c);\\n}\\n@end\\n@export clay.util.calculate_attenuation\\nuniform float attenuationFactor : 5.0;\\nfloat lightAttenuation(float dist, float range)\\n{\\n    float attenuation = 1.0;\\n    attenuation = dist*dist/(range*range+1.0);\\n    float att_s = attenuationFactor;\\n    attenuation = 1.0/(attenuation*att_s+1.0);\\n    att_s = 1.0/(att_s+1.0);\\n    attenuation = attenuation - att_s;\\n    attenuation /= 1.0 - att_s;\\n    return clamp(attenuation, 0.0, 1.0);\\n}\\n@end\\n@export clay.util.edge_factor\\nfloat edgeFactor(float width)\\n{\\n    vec3 d = fwidth(v_Barycentric);\\n    vec3 a3 = smoothstep(vec3(0.0), d * width, v_Barycentric);\\n    return min(min(a3.x, a3.y), a3.z);\\n}\\n@end\\n@export clay.util.encode_float\\nvec4 encodeFloat(const in float depth)\\n{\\n    const vec4 bitShifts = vec4(256.0*256.0*256.0, 256.0*256.0, 256.0, 1.0);\\n    const vec4 bit_mask  = vec4(0.0, 1.0/256.0, 1.0/256.0, 1.0/256.0);\\n    vec4 res = fract(depth * bitShifts);\\n    res -= res.xxyz * bit_mask;\\n    return res;\\n}\\n@end\\n@export clay.util.decode_float\\nfloat decodeFloat(const in vec4 color)\\n{\\n    const vec4 bitShifts = vec4(1.0/(256.0*256.0*256.0), 1.0/(256.0*256.0), 1.0/256.0, 1.0);\\n    return dot(color, bitShifts);\\n}\\n@end\\n@export clay.util.float\\n@import clay.util.encode_float\\n@import clay.util.decode_float\\n@end\\n@export clay.util.rgbm_decode\\nvec3 RGBMDecode(vec4 rgbm, float range) {\\n  return range * rgbm.rgb * rgbm.a;\\n}\\n@end\\n@export clay.util.rgbm_encode\\nvec4 RGBMEncode(vec3 color, float range) {\\n    if (dot(color, color) == 0.0) {\\n        return vec4(0.0);\\n    }\\n    vec4 rgbm;\\n    color /= range;\\n    rgbm.a = clamp(max(max(color.r, color.g), max(color.b, 1e-6)), 0.0, 1.0);\\n    rgbm.a = ceil(rgbm.a * 255.0) / 255.0;\\n    rgbm.rgb = color / rgbm.a;\\n    return rgbm;\\n}\\n@end\\n@export clay.util.rgbm\\n@import clay.util.rgbm_decode\\n@import clay.util.rgbm_encode\\nvec4 decodeHDR(vec4 color)\\n{\\n#if defined(RGBM_DECODE) || defined(RGBM)\\n    return vec4(RGBMDecode(color, 51.5), 1.0);\\n#else\\n    return color;\\n#endif\\n}\\nvec4 encodeHDR(vec4 color)\\n{\\n#if defined(RGBM_ENCODE) || defined(RGBM)\\n    return RGBMEncode(color.xyz, 51.5);\\n#else\\n    return color;\\n#endif\\n}\\n@end\\n@export clay.util.srgb\\nvec4 sRGBToLinear(in vec4 value) {\\n    return vec4(mix(pow(value.rgb * 0.9478672986 + vec3(0.0521327014), vec3(2.4)), value.rgb * 0.0773993808, vec3(lessThanEqual(value.rgb, vec3(0.04045)))), value.w);\\n}\\nvec4 linearTosRGB(in vec4 value) {\\n    return vec4(mix(pow(value.rgb, vec3(0.41666)) * 1.055 - vec3(0.055), value.rgb * 12.92, vec3(lessThanEqual(value.rgb, vec3(0.0031308)))), value.w);\\n}\\n@end\\n@export clay.chunk.skinning_header\\n#ifdef SKINNING\\nattribute vec3 weight : WEIGHT;\\nattribute vec4 joint : JOINT;\\nuniform mat4 skinMatrix[JOINT_COUNT] : SKIN_MATRIX;\\nmat4 getSkinMatrix(float idx) {\\n    return skinMatrix[int(idx)];\\n}\\n#endif\\n@end\\n@export clay.chunk.skin_matrix\\nmat4 skinMatrixWS = getSkinMatrix(joint.x) * weight.x;\\nif (weight.y > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.y) * weight.y;\\n}\\nif (weight.z > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.z) * weight.z;\\n}\\nfloat weightW = 1.0-weight.x-weight.y-weight.z;\\nif (weightW > 1e-4)\\n{\\n    skinMatrixWS += getSkinMatrix(joint.w) * weightW;\\n}\\n@end\\n@export clay.util.parallax_correct\\nvec3 parallaxCorrect(in vec3 dir, in vec3 pos, in vec3 boxMin, in vec3 boxMax) {\\n    vec3 first = (boxMax - pos) / dir;\\n    vec3 second = (boxMin - pos) / dir;\\n    vec3 further = max(first, second);\\n    float dist = min(further.x, min(further.y, further.z));\\n    vec3 fixedPos = pos + dir * dist;\\n    vec3 boxCenter = (boxMax + boxMin) * 0.5;\\n    return normalize(fixedPos - boxCenter);\\n}\\n@end\\n@export clay.util.clamp_sample\\nvec4 clampSample(const in sampler2D texture, const in vec2 coord)\\n{\\n#ifdef STEREO\\n    float eye = step(0.5, coord.x) * 0.5;\\n    vec2 coordClamped = clamp(coord, vec2(eye, 0.0), vec2(0.5 + eye, 1.0));\\n#else\\n    vec2 coordClamped = clamp(coord, vec2(0.0), vec2(1.0));\\n#endif\\n    return texture2D(texture, coordClamped);\\n}\\n@end\\n@export clay.util.ACES\\nvec3 ACESToneMapping(vec3 color)\\n{\\n    const float A = 2.51;\\n    const float B = 0.03;\\n    const float C = 2.43;\\n    const float D = 0.59;\\n    const float E = 0.14;\\n    return (color * (A * color + B)) / (color * (C * color + D) + E);\\n}\\n@end\";\n","export default \"@export clay.basic.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec2 texcoord : TEXCOORD_0;\\nattribute vec3 position : POSITION;\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Barycentric;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_Barycentric = barycentric;\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n}\\n@end\\n@export clay.basic.fragment\\nvarying vec2 v_Texcoord;\\nuniform sampler2D diffuseMap;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.util.srgb\\n@import clay.util.ACES\\nvoid main()\\n{\\n#ifdef RENDER_TEXCOORD\\n    gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\\n    return;\\n#endif\\n    gl_FragColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    gl_FragColor *= v_Color;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 tex = decodeHDR(texture2D(diffuseMap, v_Texcoord));\\n#ifdef SRGB_DECODE\\n    tex = sRGBToLinear(tex);\\n#endif\\n#if defined(DIFFUSEMAP_ALPHA_ALPHA)\\n    gl_FragColor.a = tex.a;\\n#endif\\n    gl_FragColor.rgb *= tex.rgb;\\n#endif\\n    gl_FragColor.rgb += emission;\\n    if( lineWidth > 0.)\\n    {\\n        gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef GAMMA_ENCODE\\n    gl_FragColor.rgb = pow(gl_FragColor.rgb, vec3(1 / 2.2));\\n#endif\\n#ifdef ALPHA_TEST\\n    if (gl_FragColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    gl_FragColor = linearTosRGB(gl_FragColor);\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n}\\n@end\";\n","export default \"\\n@export clay.lambert.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat : [1.0, 1.0];\\nuniform vec2 uvOffset : [0.0, 0.0];\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\nattribute vec3 normal : NORMAL;\\nattribute vec3 barycentric;\\n#ifdef VERTEX_COLOR\\nattribute vec4 a_Color : COLOR;\\nvarying vec4 v_Color;\\n#endif\\n@import clay.chunk.skinning_header\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nvarying vec3 v_Barycentric;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n    vec3 skinnedNormal = normal;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4( skinnedPosition, 1.0 );\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n    v_Normal = normalize( ( worldInverseTranspose * vec4(skinnedNormal, 0.0) ).xyz );\\n    v_WorldPosition = ( world * vec4( skinnedPosition, 1.0) ).xyz;\\n    v_Barycentric = barycentric;\\n#ifdef VERTEX_COLOR\\n    v_Color = a_Color;\\n#endif\\n}\\n@end\\n@export clay.lambert.fragment\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nuniform sampler2D diffuseMap;\\nuniform sampler2D alphaMap;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform vec3 emission : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\n#ifdef ALPHA_TEST\\nuniform float alphaCutoff: 0.9;\\n#endif\\nuniform float lineWidth : 0.0;\\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\\nvarying vec3 v_Barycentric;\\n#ifdef VERTEX_COLOR\\nvarying vec4 v_Color;\\n#endif\\n#ifdef AMBIENT_LIGHT_COUNT\\n@import clay.header.ambient_light\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n@import clay.header.ambient_sh_light\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n@import clay.header.point_light\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n@import clay.header.directional_light\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n@import clay.header.spot_light\\n#endif\\n@import clay.util.calculate_attenuation\\n@import clay.util.edge_factor\\n@import clay.util.rgbm\\n@import clay.plugin.compute_shadow_map\\n@import clay.util.ACES\\nvoid main()\\n{\\n#ifdef RENDER_NORMAL\\n    gl_FragColor = vec4(v_Normal * 0.5 + 0.5, 1.0);\\n    return;\\n#endif\\n#ifdef RENDER_TEXCOORD\\n    gl_FragColor = vec4(v_Texcoord, 1.0, 1.0);\\n    return;\\n#endif\\n    gl_FragColor = vec4(color, alpha);\\n#ifdef VERTEX_COLOR\\n    gl_FragColor *= v_Color;\\n#endif\\n#ifdef DIFFUSEMAP_ENABLED\\n    vec4 tex = texture2D( diffuseMap, v_Texcoord );\\n#ifdef SRGB_DECODE\\n    tex.rgb = pow(tex.rgb, vec3(2.2));\\n#endif\\n    gl_FragColor.rgb *= tex.rgb;\\n#ifdef DIFFUSEMAP_ALPHA_ALPHA\\n    gl_FragColor.a *= tex.a;\\n#endif\\n#endif\\n    vec3 diffuseColor = vec3(0.0, 0.0, 0.0);\\n#ifdef AMBIENT_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\\n    {\\n        diffuseColor += ambientLightColor[_idx_];\\n    }\\n#endif\\n#ifdef AMBIENT_SH_LIGHT_COUNT\\n    for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\\n    {{\\n        diffuseColor += calcAmbientSHLight(_idx_, v_Normal) * ambientSHLightColor[_idx_];\\n    }}\\n#endif\\n#ifdef POINT_LIGHT_COUNT\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsPoint[POINT_LIGHT_COUNT];\\n    if( shadowEnabled )\\n    {\\n        computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\\n    }\\n#endif\\n    for(int i = 0; i < POINT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = pointLightPosition[i];\\n        vec3 lightColor = pointLightColor[i];\\n        float range = pointLightRange[i];\\n        vec3 lightDirection = lightPosition - v_WorldPosition;\\n        float dist = length(lightDirection);\\n        float attenuation = lightAttenuation(dist, range);\\n        lightDirection /= dist;\\n        float ndl = dot( v_Normal, lightDirection );\\n        float shadowContrib = 1.0;\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsPoint[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * attenuation * shadowContrib;\\n    }\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_COUNT\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\\n    }\\n#endif\\n    for(int i = 0; i < DIRECTIONAL_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightDirection = -directionalLightDirection[i];\\n        vec3 lightColor = directionalLightColor[i];\\n        float ndl = dot(v_Normal, normalize(lightDirection));\\n        float shadowContrib = 1.0;\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsDir[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * clamp(ndl, 0.0, 1.0) * shadowContrib;\\n    }\\n#endif\\n#ifdef SPOT_LIGHT_COUNT\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n    float shadowContribsSpot[SPOT_LIGHT_COUNT];\\n    if(shadowEnabled)\\n    {\\n        computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\\n    }\\n#endif\\n    for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\\n    {\\n        vec3 lightPosition = -spotLightPosition[i];\\n        vec3 spotLightDirection = -normalize( spotLightDirection[i] );\\n        vec3 lightColor = spotLightColor[i];\\n        float range = spotLightRange[i];\\n        float a = spotLightUmbraAngleCosine[i];\\n        float b = spotLightPenumbraAngleCosine[i];\\n        float falloffFactor = spotLightFalloffFactor[i];\\n        vec3 lightDirection = lightPosition - v_WorldPosition;\\n        float dist = length(lightDirection);\\n        float attenuation = lightAttenuation(dist, range);\\n        lightDirection /= dist;\\n        float c = dot(spotLightDirection, lightDirection);\\n        float falloff;\\n        falloff = clamp((c - a) /( b - a), 0.0, 1.0);\\n        falloff = pow(falloff, falloffFactor);\\n        float ndl = dot(v_Normal, lightDirection);\\n        ndl = clamp(ndl, 0.0, 1.0);\\n        float shadowContrib = 1.0;\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\n        if( shadowEnabled )\\n        {\\n            shadowContrib = shadowContribsSpot[i];\\n        }\\n#endif\\n        diffuseColor += lightColor * ndl * attenuation * (1.0-falloff) * shadowContrib;\\n    }\\n#endif\\n    gl_FragColor.rgb *= diffuseColor;\\n    gl_FragColor.rgb += emission;\\n    if(lineWidth > 0.)\\n    {\\n        gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\\n    }\\n#ifdef ALPHA_TEST\\n    if (gl_FragColor.a < alphaCutoff) {\\n        discard;\\n    }\\n#endif\\n#ifdef TONEMAPPING\\n    gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\\n#endif\\n#ifdef SRGB_ENCODE\\n    gl_FragColor = linearTosRGB(gl_FragColor);\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n}\\n@end\";\n","export default \"@export clay.wireframe.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 world : WORLD;\\nattribute vec3 position : POSITION;\\nattribute vec3 barycentric;\\n@import clay.chunk.skinning_header\\nvarying vec3 v_Barycentric;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\\n    v_Barycentric = barycentric;\\n}\\n@end\\n@export clay.wireframe.fragment\\nuniform vec3 color : [0.0, 0.0, 0.0];\\nuniform float alpha : 1.0;\\nuniform float lineWidth : 1.0;\\nvarying vec3 v_Barycentric;\\n@import clay.util.edge_factor\\nvoid main()\\n{\\n    gl_FragColor.rgb = color;\\n    gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\\n}\\n@end\";\n","export default \"@export clay.skybox.vertex\\nuniform mat4 world : WORLD;\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nvarying vec3 v_WorldPosition;\\nvoid main()\\n{\\n    v_WorldPosition = (world * vec4(position, 1.0)).xyz;\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n}\\n@end\\n@export clay.skybox.fragment\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform samplerCube environmentMap;\\nuniform float lod: 0.0;\\nvarying vec3 v_WorldPosition;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 viewDirection = normalize(v_WorldPosition - eyePos);\\n    vec3 tex = decodeHDR(textureCubeLodEXT(environmentMap, viewDirection, lod)).rgb;\\n#ifdef SRGB_DECODE\\n    tex.rgb = pow(tex.rgb, vec3(2.2));\\n#endif\\n    gl_FragColor = encodeHDR(vec4(tex, 1.0));\\n}\\n@end\";\n","export default \"@export clay.compositor.coloradjust\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float brightness : 0.0;\\nuniform float contrast : 1.0;\\nuniform float exposure : 0.0;\\nuniform float gamma : 1.0;\\nuniform float saturation : 1.0;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\\n    color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\\n    color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\\n    color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\\n    float luminance = dot( color, w );\\n    color = mix(vec3(luminance), color, saturation);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.brightness\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float brightness : 0.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = tex.rgb + vec3(brightness);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.contrast\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float contrast : 1.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord);\\n    vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.exposure\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float exposure : 0.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = tex.rgb * pow(2.0, exposure);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.gamma\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float gamma : 1.0;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = pow(tex.rgb, vec3(gamma));\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\\n@export clay.compositor.saturation\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float saturation : 1.0;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    vec3 color = tex.rgb;\\n    float luminance = dot(color, w);\\n    color = mix(vec3(luminance), color, saturation);\\n    gl_FragColor = vec4(color, tex.a);\\n}\\n@end\";\n","export default \"@export clay.compositor.kernel.gaussian_9\\nfloat gaussianKernel[9];\\ngaussianKernel[0] = 0.07;\\ngaussianKernel[1] = 0.09;\\ngaussianKernel[2] = 0.12;\\ngaussianKernel[3] = 0.14;\\ngaussianKernel[4] = 0.16;\\ngaussianKernel[5] = 0.14;\\ngaussianKernel[6] = 0.12;\\ngaussianKernel[7] = 0.09;\\ngaussianKernel[8] = 0.07;\\n@end\\n@export clay.compositor.kernel.gaussian_13\\nfloat gaussianKernel[13];\\ngaussianKernel[0] = 0.02;\\ngaussianKernel[1] = 0.03;\\ngaussianKernel[2] = 0.06;\\ngaussianKernel[3] = 0.08;\\ngaussianKernel[4] = 0.11;\\ngaussianKernel[5] = 0.13;\\ngaussianKernel[6] = 0.14;\\ngaussianKernel[7] = 0.13;\\ngaussianKernel[8] = 0.11;\\ngaussianKernel[9] = 0.08;\\ngaussianKernel[10] = 0.06;\\ngaussianKernel[11] = 0.03;\\ngaussianKernel[12] = 0.02;\\n@end\\n@export clay.compositor.gaussian_blur\\n#define SHADER_NAME gaussian_blur\\nuniform sampler2D texture;varying vec2 v_Texcoord;\\nuniform float blurSize : 2.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\nuniform float blurDir : 0.0;\\n@import clay.util.rgbm\\n@import clay.util.clamp_sample\\nvoid main (void)\\n{\\n    @import clay.compositor.kernel.gaussian_9\\n    vec2 off = blurSize / textureSize;\\n    off *= vec2(1.0 - blurDir, blurDir);\\n    vec4 sum = vec4(0.0);\\n    float weightAll = 0.0;\\n    for (int i = 0; i < 9; i++) {\\n        float w = gaussianKernel[i];\\n        vec4 texel = decodeHDR(clampSample(texture, v_Texcoord + float(i - 4) * off));\\n        sum += texel * w;\\n        weightAll += w;\\n    }\\n    gl_FragColor = encodeHDR(sum / max(weightAll, 0.01));\\n}\\n@end\\n\";\n","export default \"@export clay.compositor.hdr.log_lum\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\\n    float luminance = dot(tex.rgb, w);\\n    luminance = log(luminance + 0.001);\\n    gl_FragColor = encodeHDR(vec4(vec3(luminance), 1.0));\\n}\\n@end\\n@export clay.compositor.hdr.lum_adaption\\nvarying vec2 v_Texcoord;\\nuniform sampler2D adaptedLum;\\nuniform sampler2D currentLum;\\nuniform float frameTime : 0.02;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    float fAdaptedLum = decodeHDR(texture2D(adaptedLum, vec2(0.5, 0.5))).r;\\n    float fCurrentLum = exp(encodeHDR(texture2D(currentLum, vec2(0.5, 0.5))).r);\\n    fAdaptedLum += (fCurrentLum - fAdaptedLum) * (1.0 - pow(0.98, 30.0 * frameTime));\\n    gl_FragColor = encodeHDR(vec4(vec3(fAdaptedLum), 1.0));\\n}\\n@end\\n@export clay.compositor.lum\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\\nvoid main()\\n{\\n    vec4 tex = texture2D( texture, v_Texcoord );\\n    float luminance = dot(tex.rgb, w);\\n    gl_FragColor = vec4(vec3(luminance), 1.0);\\n}\\n@end\";\n","export default \"\\n@export clay.compositor.lut\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform sampler2D lookup;\\nvoid main()\\n{\\n    vec4 tex = texture2D(texture, v_Texcoord);\\n    float blueColor = tex.b * 63.0;\\n    vec2 quad1;\\n    quad1.y = floor(floor(blueColor) / 8.0);\\n    quad1.x = floor(blueColor) - (quad1.y * 8.0);\\n    vec2 quad2;\\n    quad2.y = floor(ceil(blueColor) / 8.0);\\n    quad2.x = ceil(blueColor) - (quad2.y * 8.0);\\n    vec2 texPos1;\\n    texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\\n    texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\\n    vec2 texPos2;\\n    texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\\n    texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\\n    vec4 newColor1 = texture2D(lookup, texPos1);\\n    vec4 newColor2 = texture2D(lookup, texPos2);\\n    vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\\n    gl_FragColor = vec4(newColor.rgb, tex.w);\\n}\\n@end\";\n","export default \"@export clay.compositor.vignette\\n#define OUTPUT_ALPHA\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\nuniform float darkness: 1;\\nuniform float offset: 1;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\\n    gl_FragColor.rgb = texel.rgb;\\n    vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(offset);\\n    gl_FragColor = encodeHDR(vec4(mix(texel.rgb, vec3(1.0 - darkness), dot(uv, uv)), texel.a));\\n}\\n@end\";\n","export default \"@export clay.compositor.output\\n#define OUTPUT_ALPHA\\nvarying vec2 v_Texcoord;\\nuniform sampler2D texture;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\\n    gl_FragColor.rgb = tex.rgb;\\n#ifdef OUTPUT_ALPHA\\n    gl_FragColor.a = tex.a;\\n#else\\n    gl_FragColor.a = 1.0;\\n#endif\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#ifdef PREMULTIPLY_ALPHA\\n    gl_FragColor.rgb *= gl_FragColor.a;\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.bright\\nuniform sampler2D texture;\\nuniform float threshold : 1;\\nuniform float scale : 1.0;\\nuniform vec2 textureSize: [512, 512];\\nvarying vec2 v_Texcoord;\\nconst vec3 lumWeight = vec3(0.2125, 0.7154, 0.0721);\\n@import clay.util.rgbm\\nvec4 median(vec4 a, vec4 b, vec4 c)\\n{\\n    return a + b + c - min(min(a, b), c) - max(max(a, b), c);\\n}\\nvoid main()\\n{\\n    vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\\n#ifdef ANTI_FLICKER\\n    vec3 d = 1.0 / textureSize.xyx * vec3(1.0, 1.0, 0.0);\\n    vec4 s1 = decodeHDR(texture2D(texture, v_Texcoord - d.xz));\\n    vec4 s2 = decodeHDR(texture2D(texture, v_Texcoord + d.xz));\\n    vec4 s3 = decodeHDR(texture2D(texture, v_Texcoord - d.zy));\\n    vec4 s4 = decodeHDR(texture2D(texture, v_Texcoord + d.zy));\\n    texel = median(median(texel, s1, s2), s3, s4);\\n#endif\\n    float lum = dot(texel.rgb , lumWeight);\\n    vec4 color;\\n    if (lum > threshold && texel.a > 0.0)\\n    {\\n        color = vec4(texel.rgb * scale, texel.a * scale);\\n    }\\n    else\\n    {\\n        color = vec4(0.0);\\n    }\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\\n\";\n","export default \"@export clay.compositor.downsample\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nfloat brightness(vec3 c)\\n{\\n    return max(max(c.r, c.g), c.b);\\n}\\n@import clay.util.clamp_sample\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n#ifdef ANTI_FLICKER\\n    vec3 s1 = decodeHDR(clampSample(texture, v_Texcoord + d.xy)).rgb;\\n    vec3 s2 = decodeHDR(clampSample(texture, v_Texcoord + d.zy)).rgb;\\n    vec3 s3 = decodeHDR(clampSample(texture, v_Texcoord + d.xw)).rgb;\\n    vec3 s4 = decodeHDR(clampSample(texture, v_Texcoord + d.zw)).rgb;\\n    float s1w = 1.0 / (brightness(s1) + 1.0);\\n    float s2w = 1.0 / (brightness(s2) + 1.0);\\n    float s3w = 1.0 / (brightness(s3) + 1.0);\\n    float s4w = 1.0 / (brightness(s4) + 1.0);\\n    float oneDivideSum = 1.0 / (s1w + s2w + s3w + s4w);\\n    vec4 color = vec4(\\n        (s1 * s1w + s2 * s2w + s3 * s3w + s4 * s4w) * oneDivideSum,\\n        1.0\\n    );\\n#else\\n    vec4 color = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\\n    color += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\\n    color *= 0.25;\\n#endif\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\";\n","export default \"\\n@export clay.compositor.upsample\\n#define HIGH_QUALITY\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.clamp_sample\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    vec4 s;\\n    s  = decodeHDR(clampSample(texture, v_Texcoord - d.xy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord - d.wy)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord - d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zw)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord       )) * 4.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xw)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.wy)) * 2.0;\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    gl_FragColor = encodeHDR(s / 16.0);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    vec4 s;\\n    s  = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\\n    s += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\\n    gl_FragColor = encodeHDR(s / 4.0);\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.hdr.composite\\nuniform sampler2D texture;\\n#ifdef BLOOM_ENABLED\\nuniform sampler2D bloom;\\n#endif\\n#ifdef LENSFLARE_ENABLED\\nuniform sampler2D lensflare;\\nuniform sampler2D lensdirt;\\n#endif\\n#ifdef LUM_ENABLED\\nuniform sampler2D lum;\\n#endif\\n#ifdef LUT_ENABLED\\nuniform sampler2D lut;\\n#endif\\n#ifdef COLOR_CORRECTION\\nuniform float brightness : 0.0;\\nuniform float contrast : 1.0;\\nuniform float saturation : 1.0;\\n#endif\\n#ifdef VIGNETTE\\nuniform float vignetteDarkness: 1.0;\\nuniform float vignetteOffset: 1.0;\\n#endif\\nuniform float exposure : 1.0;\\nuniform float bloomIntensity : 0.25;\\nuniform float lensflareIntensity : 1;\\nvarying vec2 v_Texcoord;\\n@import clay.util.srgb\\nvec3 ACESToneMapping(vec3 color)\\n{\\n    const float A = 2.51;\\n    const float B = 0.03;\\n    const float C = 2.43;\\n    const float D = 0.59;\\n    const float E = 0.14;\\n    return (color * (A * color + B)) / (color * (C * color + D) + E);\\n}\\nfloat eyeAdaption(float fLum)\\n{\\n    return mix(0.2, fLum, 0.5);\\n}\\n#ifdef LUT_ENABLED\\nvec3 lutTransform(vec3 color) {\\n    float blueColor = color.b * 63.0;\\n    vec2 quad1;\\n    quad1.y = floor(floor(blueColor) / 8.0);\\n    quad1.x = floor(blueColor) - (quad1.y * 8.0);\\n    vec2 quad2;\\n    quad2.y = floor(ceil(blueColor) / 8.0);\\n    quad2.x = ceil(blueColor) - (quad2.y * 8.0);\\n    vec2 texPos1;\\n    texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\\n    texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\\n    vec2 texPos2;\\n    texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\\n    texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\\n    vec4 newColor1 = texture2D(lut, texPos1);\\n    vec4 newColor2 = texture2D(lut, texPos2);\\n    vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\\n    return newColor.rgb;\\n}\\n#endif\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 texel = vec4(0.0);\\n    vec4 originalTexel = vec4(0.0);\\n#ifdef TEXTURE_ENABLED\\n    texel = decodeHDR(texture2D(texture, v_Texcoord));\\n    originalTexel = texel;\\n#endif\\n#ifdef BLOOM_ENABLED\\n    vec4 bloomTexel = decodeHDR(texture2D(bloom, v_Texcoord));\\n    texel.rgb += bloomTexel.rgb * bloomIntensity;\\n    texel.a += bloomTexel.a * bloomIntensity;\\n#endif\\n#ifdef LENSFLARE_ENABLED\\n    texel += decodeHDR(texture2D(lensflare, v_Texcoord)) * texture2D(lensdirt, v_Texcoord) * lensflareIntensity;\\n#endif\\n    texel.a = min(texel.a, 1.0);\\n#ifdef LUM_ENABLED\\n    float fLum = texture2D(lum, vec2(0.5, 0.5)).r;\\n    float adaptedLumDest = 3.0 / (max(0.1, 1.0 + 10.0*eyeAdaption(fLum)));\\n    float exposureBias = adaptedLumDest * exposure;\\n#else\\n    float exposureBias = exposure;\\n#endif\\n    texel.rgb *= exposureBias;\\n    texel.rgb = ACESToneMapping(texel.rgb);\\n    texel = linearTosRGB(texel);\\n#ifdef LUT_ENABLED\\n    texel.rgb = lutTransform(clamp(texel.rgb,vec3(0.0),vec3(1.0)));\\n#endif\\n#ifdef COLOR_CORRECTION\\n    texel.rgb = clamp(texel.rgb + vec3(brightness), 0.0, 1.0);\\n    texel.rgb = clamp((texel.rgb - vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\\n    float lum = dot(texel.rgb, vec3(0.2125, 0.7154, 0.0721));\\n    texel.rgb = mix(vec3(lum), texel.rgb, saturation);\\n#endif\\n#ifdef VIGNETTE\\n    vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(vignetteOffset);\\n    texel.rgb = mix(texel.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\\n#endif\\n    gl_FragColor = encodeHDR(texel);\\n#ifdef DEBUG\\n    #if DEBUG == 1\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(texture, v_Texcoord)));\\n    #elif DEBUG == 2\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(bloom, v_Texcoord)) * bloomIntensity);\\n    #elif DEBUG == 3\\n    gl_FragColor = encodeHDR(decodeHDR(texture2D(lensflare, v_Texcoord) * lensflareIntensity));\\n    #endif\\n#endif\\n    if (originalTexel.a <= 0.01 && gl_FragColor.a > 1e-5) {\\n        gl_FragColor.a = dot(gl_FragColor.rgb, vec3(0.2125, 0.7154, 0.0721));\\n    }\\n#ifdef PREMULTIPLY_ALPHA\\n    gl_FragColor.rgb *= gl_FragColor.a;\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.dof.coc\\nuniform sampler2D depth;\\nuniform float zNear: 0.1;\\nuniform float zFar: 2000;\\nuniform float focalDist: 3;\\nuniform float focalRange: 1;\\nuniform float focalLength: 30;\\nuniform float fstop: 2.8;\\nvarying vec2 v_Texcoord;\\n@import clay.util.encode_float\\nvoid main()\\n{\\n    float z = texture2D(depth, v_Texcoord).r * 2.0 - 1.0;\\n    float dist = 2.0 * zNear * zFar / (zFar + zNear - z * (zFar - zNear));\\n    float aperture = focalLength / fstop;\\n    float coc;\\n    float uppper = focalDist + focalRange;\\n    float lower = focalDist - focalRange;\\n    if (dist <= uppper && dist >= lower) {\\n        coc = 0.5;\\n    }\\n    else {\\n        float focalAdjusted = dist > uppper ? uppper : lower;\\n        coc = abs(aperture * (focalLength * (dist - focalAdjusted)) / (dist * (focalAdjusted - focalLength)));\\n        coc = clamp(coc, 0.0, 0.4) / 0.4000001;\\n        if (dist < lower) {\\n            coc = -coc;\\n        }\\n        coc = coc * 0.5 + 0.5;\\n    }\\n    gl_FragColor = encodeFloat(coc);\\n}\\n@end\\n@export clay.compositor.dof.premultiply\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nvoid main() {\\n    float fCoc = max(abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0), 0.1);\\n    gl_FragColor = encodeHDR(\\n        vec4(decodeHDR(texture2D(texture, v_Texcoord)).rgb * fCoc, 1.0)\\n    );\\n}\\n@end\\n@export clay.compositor.dof.min_coc\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\\n    fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\\n    gl_FragColor = encodeFloat(fCoc);\\n}\\n@end\\n@export clay.compositor.dof.max_coc\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\\n    fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\\n    gl_FragColor = encodeFloat(fCoc);\\n}\\n@end\\n@export clay.compositor.dof.coc_upsample\\n#define HIGH_QUALITY\\nuniform sampler2D coc;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.float\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    float s;\\n    s  = decodeFloat(texture2D(coc, v_Texcoord - d.xy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord - d.wy)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord - d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zw)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord       )) * 4.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xw)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.wy)) * 2.0;\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    gl_FragColor = encodeFloat(s / 16.0);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    float s;\\n    s  = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.xw));\\n    s += decodeFloat(texture2D(coc, v_Texcoord + d.zw));\\n    gl_FragColor = encodeFloat(s / 4.0);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.upsample\\n#define HIGH_QUALITY\\nuniform sampler2D coc;\\nuniform sampler2D texture;\\nuniform vec2 textureSize : [512, 512];\\nuniform float sampleScale: 0.5;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nfloat tap(vec2 uv, inout vec4 color, float baseWeight) {\\n    float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * baseWeight;\\n    color += decodeHDR(texture2D(texture, uv)) * weight;\\n    return weight;\\n}\\nvoid main()\\n{\\n#ifdef HIGH_QUALITY\\n    vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\\n    vec4 color = vec4(0.0);\\n    float baseWeight = 1.0 / 16.0;\\n    float w  = tap(v_Texcoord - d.xy, color, baseWeight);\\n    w += tap(v_Texcoord - d.wy, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord - d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.zw, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord       , color, baseWeight * 4.0);\\n    w += tap(v_Texcoord + d.xw, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord + d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.wy, color, baseWeight * 2.0);\\n    w += tap(v_Texcoord + d.xy, color, baseWeight);\\n    gl_FragColor = encodeHDR(color / w);\\n#else\\n    vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\\n    vec4 color = vec4(0.0);\\n    float baseWeight = 1.0 / 4.0;\\n    float w  = tap(v_Texcoord + d.xy, color, baseWeight);\\n    w += tap(v_Texcoord + d.zy, color, baseWeight);\\n    w += tap(v_Texcoord + d.xw, color, baseWeight);\\n    w += tap(v_Texcoord + d.zw, color, baseWeight);\\n    gl_FragColor = encodeHDR(color / w);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.downsample\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nuniform vec2 textureSize : [512, 512];\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.decode_float\\nfloat tap(vec2 uv, inout vec4 color) {\\n    float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * 0.25;\\n    color += decodeHDR(texture2D(texture, uv)) * weight;\\n    return weight;\\n}\\nvoid main()\\n{\\n    vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\\n    vec4 color = vec4(0.0);\\n    float weight = tap(v_Texcoord + d.xy, color);\\n    weight += tap(v_Texcoord + d.zy, color);\\n    weight += tap(v_Texcoord + d.xw, color);\\n    weight += tap(v_Texcoord + d.zw, color);\\n    color /= weight;\\n    gl_FragColor = encodeHDR(color);\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_frag\\n@import clay.util.float\\nvec4 doBlur(sampler2D targetTexture, vec2 offset) {\\n#ifdef BLUR_COC\\n    float cocSum = 0.0;\\n#else\\n    vec4 color = vec4(0.0);\\n#endif\\n    float weightSum = 0.0;\\n    float kernelWeight = 1.0 / float(KERNEL_SIZE);\\n    for (int i = 0; i < KERNEL_SIZE; i++) {\\n        vec2 coord = v_Texcoord + offset * float(i);\\n        float w = kernelWeight;\\n#ifdef BLUR_COC\\n        float fCoc = decodeFloat(texture2D(targetTexture, coord)) * 2.0 - 1.0;\\n        cocSum += clamp(fCoc, -1.0, 0.0) * w;\\n#else\\n        float fCoc = decodeFloat(texture2D(coc, coord)) * 2.0 - 1.0;\\n        vec4 texel = texture2D(targetTexture, coord);\\n    #if !defined(BLUR_NEARFIELD)\\n        w *= abs(fCoc);\\n    #endif\\n        color += decodeHDR(texel) * w;\\n#endif\\n        weightSum += w;\\n    }\\n#ifdef BLUR_COC\\n    return encodeFloat(clamp(cocSum / weightSum, -1.0, 0.0) * 0.5 + 0.5);\\n#else\\n    return color / weightSum;\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_1\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    gl_FragColor = doBlur(texture, vec2(0.0, offset.y));\\n#if !defined(BLUR_COC)\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_2\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    offset.y /= 2.0;\\n    gl_FragColor = doBlur(texture, -offset);\\n#if !defined(BLUR_COC)\\n    gl_FragColor = encodeHDR(gl_FragColor);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.hexagonal_blur_3\\n#define KERNEL_SIZE 5\\nuniform sampler2D texture1;\\nuniform sampler2D texture2;\\nuniform sampler2D coc;\\nvarying vec2 v_Texcoord;\\nuniform float blurSize : 1.0;\\nuniform vec2 textureSize : [512.0, 512.0];\\n@import clay.util.rgbm\\n@import clay.compositor.dof.hexagonal_blur_frag\\nvoid main()\\n{\\n    vec2 offset = blurSize / textureSize;\\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\\n    offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\\n#endif\\n    offset.y /= 2.0;\\n    vec2 vDownRight = vec2(offset.x, -offset.y);\\n    vec4 texel1 = doBlur(texture1, -offset);\\n    vec4 texel2 = doBlur(texture1, vDownRight);\\n    vec4 texel3 = doBlur(texture2, vDownRight);\\n#ifdef BLUR_COC\\n    float coc1 = decodeFloat(texel1) * 2.0 - 1.0;\\n    float coc2 = decodeFloat(texel2) * 2.0 - 1.0;\\n    float coc3 = decodeFloat(texel3) * 2.0 - 1.0;\\n    gl_FragColor = encodeFloat(\\n        ((coc1 + coc2 + coc3) / 3.0) * 0.5 + 0.5\\n    );\\n#else\\n    vec4 color = (texel1 + texel2 + texel3) / 3.0;\\n    gl_FragColor = encodeHDR(color);\\n#endif\\n}\\n@end\\n@export clay.compositor.dof.composite\\n#define DEBUG 0\\nuniform sampler2D original;\\nuniform sampler2D blurred;\\nuniform sampler2D nearfield;\\nuniform sampler2D coc;\\nuniform sampler2D nearcoc;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\n@import clay.util.float\\nvoid main()\\n{\\n    vec4 blurredColor = decodeHDR(texture2D(blurred, v_Texcoord));\\n    vec4 originalColor = decodeHDR(texture2D(original, v_Texcoord));\\n    float fCoc = decodeFloat(texture2D(coc, v_Texcoord));\\n    fCoc = abs(fCoc * 2.0 - 1.0);\\n    float weight = smoothstep(0.0, 1.0, fCoc);\\n#ifdef NEARFIELD_ENABLED\\n    vec4 nearfieldColor = decodeHDR(texture2D(nearfield, v_Texcoord));\\n    float fNearCoc = decodeFloat(texture2D(nearcoc, v_Texcoord));\\n    fNearCoc = abs(fNearCoc * 2.0 - 1.0);\\n    gl_FragColor = encodeHDR(\\n        mix(\\n            nearfieldColor, mix(originalColor, blurredColor, weight),\\n            pow(1.0 - fNearCoc, 4.0)\\n        )\\n    );\\n#else\\n    gl_FragColor = encodeHDR(mix(originalColor, blurredColor, weight));\\n#endif\\n#if DEBUG == 1\\n    gl_FragColor = vec4(vec3(fCoc), 1.0);\\n#elif DEBUG == 2\\n    gl_FragColor = vec4(vec3(fNearCoc), 1.0);\\n#elif DEBUG == 3\\n    gl_FragColor = encodeHDR(blurredColor);\\n#elif DEBUG == 4\\n    gl_FragColor = encodeHDR(nearfieldColor);\\n#endif\\n}\\n@end\";\n","export default \"@export clay.compositor.lensflare\\n#define SAMPLE_NUMBER 8\\nuniform sampler2D texture;\\nuniform sampler2D lenscolor;\\nuniform vec2 textureSize : [512, 512];\\nuniform float dispersal : 0.3;\\nuniform float haloWidth : 0.4;\\nuniform float distortion : 1.0;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nvec4 textureDistorted(\\n    in vec2 texcoord,\\n    in vec2 direction,\\n    in vec3 distortion\\n) {\\n    return vec4(\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.r)).r,\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.g)).g,\\n        decodeHDR(texture2D(texture, texcoord + direction * distortion.b)).b,\\n        1.0\\n    );\\n}\\nvoid main()\\n{\\n    vec2 texcoord = -v_Texcoord + vec2(1.0);    vec2 textureOffset = 1.0 / textureSize;\\n    vec2 ghostVec = (vec2(0.5) - texcoord) * dispersal;\\n    vec2 haloVec = normalize(ghostVec) * haloWidth;\\n    vec3 distortion = vec3(-textureOffset.x * distortion, 0.0, textureOffset.x * distortion);\\n    vec4 result = vec4(0.0);\\n    for (int i = 0; i < SAMPLE_NUMBER; i++)\\n    {\\n        vec2 offset = fract(texcoord + ghostVec * float(i));\\n        float weight = length(vec2(0.5) - offset) / length(vec2(0.5));\\n        weight = pow(1.0 - weight, 10.0);\\n        result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\\n    }\\n    result *= texture2D(lenscolor, vec2(length(vec2(0.5) - texcoord)) / length(vec2(0.5)));\\n    float weight = length(vec2(0.5) - fract(texcoord + haloVec)) / length(vec2(0.5));\\n    weight = pow(1.0 - weight, 10.0);\\n    vec2 offset = fract(texcoord + haloVec);\\n    result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\\n    gl_FragColor = result;\\n}\\n@end\";\n","export default \"@export clay.compositor.blend\\n#define SHADER_NAME blend\\n#ifdef TEXTURE1_ENABLED\\nuniform sampler2D texture1;\\nuniform float weight1 : 1.0;\\n#endif\\n#ifdef TEXTURE2_ENABLED\\nuniform sampler2D texture2;\\nuniform float weight2 : 1.0;\\n#endif\\n#ifdef TEXTURE3_ENABLED\\nuniform sampler2D texture3;\\nuniform float weight3 : 1.0;\\n#endif\\n#ifdef TEXTURE4_ENABLED\\nuniform sampler2D texture4;\\nuniform float weight4 : 1.0;\\n#endif\\n#ifdef TEXTURE5_ENABLED\\nuniform sampler2D texture5;\\nuniform float weight5 : 1.0;\\n#endif\\n#ifdef TEXTURE6_ENABLED\\nuniform sampler2D texture6;\\nuniform float weight6 : 1.0;\\n#endif\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec4 tex = vec4(0.0);\\n#ifdef TEXTURE1_ENABLED\\n    tex += decodeHDR(texture2D(texture1, v_Texcoord)) * weight1;\\n#endif\\n#ifdef TEXTURE2_ENABLED\\n    tex += decodeHDR(texture2D(texture2, v_Texcoord)) * weight2;\\n#endif\\n#ifdef TEXTURE3_ENABLED\\n    tex += decodeHDR(texture2D(texture3, v_Texcoord)) * weight3;\\n#endif\\n#ifdef TEXTURE4_ENABLED\\n    tex += decodeHDR(texture2D(texture4, v_Texcoord)) * weight4;\\n#endif\\n#ifdef TEXTURE5_ENABLED\\n    tex += decodeHDR(texture2D(texture5, v_Texcoord)) * weight5;\\n#endif\\n#ifdef TEXTURE6_ENABLED\\n    tex += decodeHDR(texture2D(texture6, v_Texcoord)) * weight6;\\n#endif\\n    gl_FragColor = encodeHDR(tex);\\n}\\n@end\";\n","export default \"@export clay.compositor.fxaa\\nuniform sampler2D texture;\\nuniform vec4 viewport : VIEWPORT;\\nvarying vec2 v_Texcoord;\\n#define FXAA_REDUCE_MIN   (1.0/128.0)\\n#define FXAA_REDUCE_MUL   (1.0/8.0)\\n#define FXAA_SPAN_MAX     8.0\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    vec2 resolution = 1.0 / viewport.zw;\\n    vec3 rgbNW =  decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, -1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbNE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, -1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbSW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, 1.0 ) ) * resolution ) ).xyz;\\n    vec3 rgbSE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, 1.0 ) ) * resolution ) ).xyz;\\n    vec4 rgbaM  = decodeHDR( texture2D( texture,  gl_FragCoord.xy  * resolution ) );\\n    vec3 rgbM  = rgbaM.xyz;\\n    float opacity  = rgbaM.w;\\n    vec3 luma = vec3( 0.299, 0.587, 0.114 );\\n    float lumaNW = dot( rgbNW, luma );\\n    float lumaNE = dot( rgbNE, luma );\\n    float lumaSW = dot( rgbSW, luma );\\n    float lumaSE = dot( rgbSE, luma );\\n    float lumaM  = dot( rgbM,  luma );\\n    float lumaMin = min( lumaM, min( min( lumaNW, lumaNE ), min( lumaSW, lumaSE ) ) );\\n    float lumaMax = max( lumaM, max( max( lumaNW, lumaNE) , max( lumaSW, lumaSE ) ) );\\n    vec2 dir;\\n    dir.x = -((lumaNW + lumaNE) - (lumaSW + lumaSE));\\n    dir.y =  ((lumaNW + lumaSW) - (lumaNE + lumaSE));\\n    float dirReduce = max( ( lumaNW + lumaNE + lumaSW + lumaSE ) * ( 0.25 * FXAA_REDUCE_MUL ), FXAA_REDUCE_MIN );\\n    float rcpDirMin = 1.0 / ( min( abs( dir.x ), abs( dir.y ) ) + dirReduce );\\n    dir = min( vec2( FXAA_SPAN_MAX,  FXAA_SPAN_MAX),\\n          max( vec2(-FXAA_SPAN_MAX, -FXAA_SPAN_MAX),\\n                dir * rcpDirMin)) * resolution;\\n    vec3 rgbA = decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * ( 1.0 / 3.0 - 0.5 ) ) ).xyz;\\n    rgbA += decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * ( 2.0 / 3.0 - 0.5 ) ) ).xyz;\\n    rgbA *= 0.5;\\n    vec3 rgbB = decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * -0.5 ) ).xyz;\\n    rgbB += decodeHDR( texture2D( texture, gl_FragCoord.xy  * resolution + dir * 0.5 ) ).xyz;\\n    rgbB *= 0.25;\\n    rgbB += rgbA * 0.5;\\n    float lumaB = dot( rgbB, luma );\\n    if ( ( lumaB < lumaMin ) || ( lumaB > lumaMax ) )\\n    {\\n        gl_FragColor = vec4( rgbA, opacity );\\n    }\\n    else {\\n        gl_FragColor = vec4( rgbB, opacity );\\n    }\\n}\\n@end\";\n","export default \"@export clay.compositor.fxaa3\\nuniform sampler2D texture;\\nuniform vec4 viewport : VIEWPORT;\\nuniform float subpixel: 0.75;\\nuniform float edgeThreshold: 0.125;\\nuniform float edgeThresholdMin: 0.0625;\\nvarying vec2 v_Texcoord;\\n@import clay.util.rgbm\\nfloat FxaaLuma(vec4 rgba) { return rgba.y; }\\nvec4 FxaaPixelShader(\\n    vec2 pos\\n    ,sampler2D tex\\n    ,vec2 fxaaQualityRcpFrame\\n    ,float fxaaQualitySubpix\\n    ,float fxaaQualityEdgeThreshold\\n    ,float fxaaQualityEdgeThresholdMin\\n) {\\n    vec2 posM;\\n    posM.x = pos.x;\\n    posM.y = pos.y;\\n    vec4 rgbyM = decodeHDR(texture2D(texture, posM, 0.0));\\n    float lumaS = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaN = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float maxSM = max(lumaS, rgbyM.y);\\n    float minSM = min(lumaS, rgbyM.y);\\n    float maxESM = max(lumaE, maxSM);\\n    float minESM = min(lumaE, minSM);\\n    float maxWN = max(lumaN, lumaW);\\n    float minWN = min(lumaN, lumaW);\\n    float rangeMax = max(maxWN, maxESM);\\n    float rangeMin = min(minWN, minESM);\\n    float rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;\\n    float range = rangeMax - rangeMin;\\n    float rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);\\n    bool earlyExit = range < rangeMaxClamped;\\n    if(earlyExit) return rgbyM;\\n    float lumaNW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaSE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaNE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaSW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\\n    float lumaNS = lumaN + lumaS;\\n    float lumaWE = lumaW + lumaE;\\n    float subpixRcpRange = 1.0/range;\\n    float subpixNSWE = lumaNS + lumaWE;\\n    float edgeHorz1 = (-2.0 * rgbyM.y) + lumaNS;\\n    float edgeVert1 = (-2.0 * rgbyM.y) + lumaWE;\\n    float lumaNESE = lumaNE + lumaSE;\\n    float lumaNWNE = lumaNW + lumaNE;\\n    float edgeHorz2 = (-2.0 * lumaE) + lumaNESE;\\n    float edgeVert2 = (-2.0 * lumaN) + lumaNWNE;\\n    float lumaNWSW = lumaNW + lumaSW;\\n    float lumaSWSE = lumaSW + lumaSE;\\n    float edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);\\n    float edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);\\n    float edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;\\n    float edgeVert3 = (-2.0 * lumaS) + lumaSWSE;\\n    float edgeHorz = abs(edgeHorz3) + edgeHorz4;\\n    float edgeVert = abs(edgeVert3) + edgeVert4;\\n    float subpixNWSWNESE = lumaNWSW + lumaNESE;\\n    float lengthSign = fxaaQualityRcpFrame.x;\\n    bool horzSpan = edgeHorz >= edgeVert;\\n    float subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;\\n    if(!horzSpan) lumaN = lumaW;\\n    if(!horzSpan) lumaS = lumaE;\\n    if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;\\n    float subpixB = (subpixA * (1.0/12.0)) - rgbyM.y;\\n    float gradientN = lumaN - rgbyM.y;\\n    float gradientS = lumaS - rgbyM.y;\\n    float lumaNN = lumaN + rgbyM.y;\\n    float lumaSS = lumaS + rgbyM.y;\\n    bool pairN = abs(gradientN) >= abs(gradientS);\\n    float gradient = max(abs(gradientN), abs(gradientS));\\n    if(pairN) lengthSign = -lengthSign;\\n    float subpixC = clamp(abs(subpixB) * subpixRcpRange, 0.0, 1.0);\\n    vec2 posB;\\n    posB.x = posM.x;\\n    posB.y = posM.y;\\n    vec2 offNP;\\n    offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;\\n    offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;\\n    if(!horzSpan) posB.x += lengthSign * 0.5;\\n    if( horzSpan) posB.y += lengthSign * 0.5;\\n    vec2 posN;\\n    posN.x = posB.x - offNP.x * 1.0;\\n    posN.y = posB.y - offNP.y * 1.0;\\n    vec2 posP;\\n    posP.x = posB.x + offNP.x * 1.0;\\n    posP.y = posB.y + offNP.y * 1.0;\\n    float subpixD = ((-2.0)*subpixC) + 3.0;\\n    float lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN, 0.0)));\\n    float subpixE = subpixC * subpixC;\\n    float lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP, 0.0)));\\n    if(!pairN) lumaNN = lumaSS;\\n    float gradientScaled = gradient * 1.0/4.0;\\n    float lumaMM = rgbyM.y - lumaNN * 0.5;\\n    float subpixF = subpixD * subpixE;\\n    bool lumaMLTZero = lumaMM < 0.0;\\n    lumaEndN -= lumaNN * 0.5;\\n    lumaEndP -= lumaNN * 0.5;\\n    bool doneN = abs(lumaEndN) >= gradientScaled;\\n    bool doneP = abs(lumaEndP) >= gradientScaled;\\n    if(!doneN) posN.x -= offNP.x * 1.5;\\n    if(!doneN) posN.y -= offNP.y * 1.5;\\n    bool doneNP = (!doneN) || (!doneP);\\n    if(!doneP) posP.x += offNP.x * 1.5;\\n    if(!doneP) posP.y += offNP.y * 1.5;\\n    if(doneNP) {\\n        if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n        if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n        if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n        if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n        doneN = abs(lumaEndN) >= gradientScaled;\\n        doneP = abs(lumaEndP) >= gradientScaled;\\n        if(!doneN) posN.x -= offNP.x * 2.0;\\n        if(!doneN) posN.y -= offNP.y * 2.0;\\n        doneNP = (!doneN) || (!doneP);\\n        if(!doneP) posP.x += offNP.x * 2.0;\\n        if(!doneP) posP.y += offNP.y * 2.0;\\n        if(doneNP) {\\n            if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n            if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n            if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n            if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n            doneN = abs(lumaEndN) >= gradientScaled;\\n            doneP = abs(lumaEndP) >= gradientScaled;\\n            if(!doneN) posN.x -= offNP.x * 4.0;\\n            if(!doneN) posN.y -= offNP.y * 4.0;\\n            doneNP = (!doneN) || (!doneP);\\n            if(!doneP) posP.x += offNP.x * 4.0;\\n            if(!doneP) posP.y += offNP.y * 4.0;\\n            if(doneNP) {\\n                if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\\n                if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\\n                if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\\n                if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\\n                doneN = abs(lumaEndN) >= gradientScaled;\\n                doneP = abs(lumaEndP) >= gradientScaled;\\n                if(!doneN) posN.x -= offNP.x * 12.0;\\n                if(!doneN) posN.y -= offNP.y * 12.0;\\n                doneNP = (!doneN) || (!doneP);\\n                if(!doneP) posP.x += offNP.x * 12.0;\\n                if(!doneP) posP.y += offNP.y * 12.0;\\n            }\\n        }\\n    }\\n    float dstN = posM.x - posN.x;\\n    float dstP = posP.x - posM.x;\\n    if(!horzSpan) dstN = posM.y - posN.y;\\n    if(!horzSpan) dstP = posP.y - posM.y;\\n    bool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;\\n    float spanLength = (dstP + dstN);\\n    bool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;\\n    float spanLengthRcp = 1.0/spanLength;\\n    bool directionN = dstN < dstP;\\n    float dst = min(dstN, dstP);\\n    bool goodSpan = directionN ? goodSpanN : goodSpanP;\\n    float subpixG = subpixF * subpixF;\\n    float pixelOffset = (dst * (-spanLengthRcp)) + 0.5;\\n    float subpixH = subpixG * fxaaQualitySubpix;\\n    float pixelOffsetGood = goodSpan ? pixelOffset : 0.0;\\n    float pixelOffsetSubpix = max(pixelOffsetGood, subpixH);\\n    if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;\\n    if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;\\n    return vec4(decodeHDR(texture2D(texture, posM, 0.0)).xyz, rgbyM.y);\\n}\\nvoid main()\\n{\\n    vec4 color = FxaaPixelShader(\\n        v_Texcoord,\\n        texture,\\n        vec2(1.0) / viewport.zw,\\n        subpixel,\\n        edgeThreshold,\\n        edgeThresholdMin\\n    );\\n    gl_FragColor = vec4(color.rgb, 1.0);\\n}\\n@end\";\n","import lightEssl from './source/header/light';\nimport utilEssl from './source/util.glsl.js';\n\nimport basicEssl from './source/basic.glsl.js';\nimport lambertEssl from './source/lambert.glsl.js';\nimport standardEssl from './source/standard.glsl.js';\nimport wireframeEssl from './source/wireframe.glsl.js';\nimport skyboxEssl from './source/skybox.glsl.js';\nimport prezEssl from './source/prez.glsl.js';\n\nimport library from './library';\nimport Shader from '../Shader';\n\n\nShader['import'](lightEssl);\nShader['import'](utilEssl);\n\n// Some build in shaders\nShader['import'](basicEssl);\nShader['import'](lambertEssl);\nShader['import'](standardEssl);\nShader['import'](wireframeEssl);\nShader['import'](skyboxEssl);\nShader['import'](prezEssl);\n\nlibrary.template('clay.basic', Shader.source('clay.basic.vertex'), Shader.source('clay.basic.fragment'));\nlibrary.template('clay.lambert', Shader.source('clay.lambert.vertex'), Shader.source('clay.lambert.fragment'));\nlibrary.template('clay.wireframe', Shader.source('clay.wireframe.vertex'), Shader.source('clay.wireframe.fragment'));\nlibrary.template('clay.skybox', Shader.source('clay.skybox.vertex'), Shader.source('clay.skybox.fragment'));\nlibrary.template('clay.prez', Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'));\nlibrary.template('clay.standard', Shader.source('clay.standard.vertex'), Shader.source('clay.standard.fragment'));\nlibrary.template('clay.standardMR', Shader.source('clay.standardMR.vertex'), Shader.source('clay.standardMR.fragment'));\n\n\nimport coloradjustEssl from './source/compositor/coloradjust.glsl.js';\nimport blurEssl from './source/compositor/blur.glsl.js';\nimport lumEssl from './source/compositor/lum.glsl.js';\nimport lutEssl from './source/compositor/lut.glsl.js';\nimport vigentteEssl from './source/compositor/vignette.glsl.js';\nimport outputEssl from './source/compositor/output.glsl.js';\nimport brightEssl from './source/compositor/bright.glsl.js';\nimport downsampleEssl from './source/compositor/downsample.glsl.js';\nimport upsampleEssl from './source/compositor/upsample.glsl.js';\nimport hdrEssl from './source/compositor/hdr.glsl.js';\nimport dofEssl from './source/compositor/dof.glsl.js';\nimport lensflareEssl from './source/compositor/lensflare.glsl.js';\nimport blendEssl from './source/compositor/blend.glsl.js';\n\nimport fxaaEssl from './source/compositor/fxaa.glsl.js';\nimport fxaa3Essl from './source/compositor/fxaa3.glsl.js';\n\n// Some build in shaders\nShader['import'](coloradjustEssl);\nShader['import'](blurEssl);\nShader['import'](lumEssl);\nShader['import'](lutEssl);\nShader['import'](vigentteEssl);\nShader['import'](outputEssl);\nShader['import'](brightEssl);\nShader['import'](downsampleEssl);\nShader['import'](upsampleEssl);\nShader['import'](hdrEssl);\nShader['import'](dofEssl);\nShader['import'](lensflareEssl);\nShader['import'](blendEssl);\n\nShader['import'](fxaaEssl);\nShader['import'](fxaa3Essl);\n","/**\n * glTF Loader\n * Specification https://github.com/KhronosGroup/glTF/blob/master/specification/README.md\n *\n * TODO Morph targets\n */\nimport Base from '../core/Base';\nimport request from '../core/request';\nimport util from '../core/util';\nimport vendor from '../core/vendor';\n\nimport Scene from '../Scene';\nimport Material from '../Material';\nimport StandardMaterial from '../StandardMaterial';\nimport Mesh from '../Mesh';\nimport Node from '../Node';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport shaderLibrary from '../shader/library';\nimport Skeleton from '../Skeleton';\nimport Joint from '../Joint';\nimport PerspectiveCamera from '../camera/Perspective';\nimport OrthographicCamera from '../camera/Orthographic';\nimport glenum from '../core/glenum';\n\nimport BoundingBox from '../math/BoundingBox';\n\nimport TrackClip from '../animation/TrackClip';\nimport SamplerTrack from '../animation/SamplerTrack';\n\nimport Geometry from '../Geometry';\n\n// Import builtin shader\nimport '../shader/builtin';\nimport Shader from '../Shader';\n\nvar semanticAttributeMap = {\n    'NORMAL': 'normal',\n    'POSITION': 'position',\n    'TEXCOORD_0': 'texcoord0',\n    'TEXCOORD_1': 'texcoord1',\n    'WEIGHTS_0': 'weight',\n    'JOINTS_0': 'joint',\n    'COLOR': 'color'\n};\n\nvar ARRAY_CTOR_MAP = {\n    5120: vendor.Int8Array,\n    5121: vendor.Uint8Array,\n    5122: vendor.Int16Array,\n    5123: vendor.Uint16Array,\n    5125: vendor.Uint32Array,\n    5126: vendor.Float32Array\n};\nvar SIZE_MAP = {\n    SCALAR: 1,\n    VEC2: 2,\n    VEC3: 3,\n    VEC4: 4,\n    MAT2: 4,\n    MAT3: 9,\n    MAT4: 16\n};\n\nfunction getAccessorData(json, lib, accessorIdx, isIndices) {\n    var accessorInfo = json.accessors[accessorIdx];\n\n    var buffer = lib.bufferViews[accessorInfo.bufferView];\n    var byteOffset = accessorInfo.byteOffset || 0;\n    var ArrayCtor = ARRAY_CTOR_MAP[accessorInfo.componentType] || vendor.Float32Array;\n\n    var size = SIZE_MAP[accessorInfo.type];\n    if (size == null && isIndices) {\n        size = 1;\n    }\n    var arr = new ArrayCtor(buffer, byteOffset, size * accessorInfo.count);\n\n    var quantizeExtension = accessorInfo.extensions && accessorInfo.extensions['WEB3D_quantized_attributes'];\n    if (quantizeExtension) {\n        var decodedArr = new vendor.Float32Array(size * accessorInfo.count);\n        var decodeMatrix = quantizeExtension.decodeMatrix;\n        var decodeOffset, decodeScale;\n        var decodeOffset = new Array(size);\n        var decodeScale = new Array(size);\n        for (var k = 0; k < size; k++) {\n            decodeOffset[k] = decodeMatrix[size * (size + 1) + k];\n            decodeScale[k] = decodeMatrix[k * (size + 1) + k];\n        }\n        for (var i = 0; i < accessorInfo.count; i++) {\n            for (var k = 0; k < size; k++) {\n                decodedArr[i * size + k] = arr[i * size + k] * decodeScale[k] + decodeOffset[k];\n            }\n        }\n\n        arr = decodedArr;\n    }\n    return arr;\n}\n\n/**\n * @typedef {Object} clay.loader.GLTF.IResult\n * @property {Object} json\n * @property {clay.Scene} scene\n * @property {clay.Node} rootNode\n * @property {clay.Camera[]} cameras\n * @property {clay.Texture[]} textures\n * @property {clay.Material[]} materials\n * @property {clay.Skeleton[]} skeletons\n * @property {clay.Mesh[]} meshes\n * @property {clay.animation.TrackClip[]} clips\n * @property {clay.Node[]} nodes\n */\n\n/**\n * @constructor clay.loader.GLTF\n * @extends clay.core.Base\n */\nvar GLTFLoader = Base.extend(\n/** @lends clay.loader.GLTF# */\n{\n    /**\n     *\n     * @type {clay.Node}\n     */\n    rootNode: null,\n    /**\n     * Root path for uri parsing.\n     * @type {string}\n     */\n    rootPath: null,\n\n    /**\n     * Root path for texture uri parsing. Defaultly use the rootPath\n     * @type {string}\n     */\n    textureRootPath: null,\n\n    /**\n     * Root path for buffer uri parsing. Defaultly use the rootPath\n     * @type {string}\n     */\n    bufferRootPath: null,\n\n    /**\n     * Shader used when creating the materials.\n     * @type {string|clay.Shader}\n     * @default 'clay.standard'\n     */\n    shader: 'clay.standard',\n\n    /**\n     * If use {@link clay.StandardMaterial}\n     * @type {string}\n     */\n    useStandardMaterial: false,\n\n    /**\n     * If loading the cameras.\n     * @type {boolean}\n     */\n    includeCamera: true,\n\n    /**\n     * If loading the animations.\n     * @type {boolean}\n     */\n    includeAnimation: true,\n    /**\n     * If loading the meshes\n     * @type {boolean}\n     */\n    includeMesh: true,\n    /**\n     * If loading the textures.\n     * @type {boolean}\n     */\n    includeTexture: true,\n\n    /**\n     * @type {string}\n     */\n    crossOrigin: '',\n    /**\n     * @type {boolean}\n     * @see https://github.com/KhronosGroup/glTF/issues/674\n     */\n    textureFlipY: false,\n\n    shaderLibrary: null\n},\nfunction () {\n    if (!this.shaderLibrary) {\n        this.shaderLibrary = shaderLibrary.createLibrary();\n    }\n},\n/** @lends clay.loader.GLTF.prototype */\n{\n    /**\n     * @param {string} url\n     */\n    load: function (url) {\n        var self = this;\n        var isBinary = url.endsWith('.glb');\n\n        if (this.rootPath == null) {\n            this.rootPath = url.slice(0, url.lastIndexOf('/'));\n        }\n\n        request.get({\n            url: url,\n            onprogress: function (percent, loaded, total) {\n                self.trigger('progress', percent, loaded, total);\n            },\n            onerror: function (e) {\n                self.trigger('error', e);\n            },\n            responseType: isBinary ? 'arraybuffer' : 'text',\n            onload: function (data) {\n                if (isBinary) {\n                    self.parseBinary(data);\n                }\n                else {\n                    self.parse(JSON.parse(data));\n                }\n            }\n        });\n    },\n\n    /**\n     * Parse glTF binary\n     * @param {ArrayBuffer} buffer\n     * @return {clay.loader.GLTF.IResult}\n     */\n    parseBinary: function (buffer) {\n        var header = new Uint32Array(buffer, 0, 4);\n        if (header[0] !== 0x46546C67) {\n            this.trigger('error', 'Invalid glTF binary format: Invalid header');\n            return;\n        }\n        if (header[0] < 2) {\n            this.trigger('error', 'Only glTF2.0 is supported.');\n            return;\n        }\n\n        var dataView = new DataView(buffer, 12);\n\n        var json;\n        var buffers = [];\n        // Read chunks\n        for (var i = 0; i < dataView.byteLength;) {\n            var chunkLength = dataView.getUint32(i, true);\n            i += 4;\n            var chunkType = dataView.getUint32(i, true);\n            i += 4;\n\n            // json\n            if (chunkType === 0x4E4F534A) {\n                var arr = new Uint8Array(buffer, i + 12, chunkLength);\n                // TODO, for the browser not support TextDecoder.\n                var decoder = new TextDecoder();\n                var str = decoder.decode(arr);\n                try {\n                    json = JSON.parse(str);\n                }\n                catch (e) {\n                    this.trigger('error', 'JSON Parse error:' + e.toString());\n                    return;\n                }\n            }\n            else if (chunkType === 0x004E4942) {\n                buffers.push(buffer.slice(i + 12, i + 12 + chunkLength));\n            }\n\n            i += chunkLength;\n        }\n        if (!json) {\n            this.trigger('error', 'Invalid glTF binary format: Can\\'t find JSON.');\n            return;\n        }\n\n        return this.parse(json, buffers);\n    },\n\n    /**\n     * @param {Object} json\n     * @param {ArrayBuffer[]} [buffer]\n     * @return {clay.loader.GLTF.IResult}\n     */\n    parse: function (json, buffers) {\n        var self = this;\n\n        var lib = {\n            json: json,\n            buffers: [],\n            bufferViews: [],\n            materials: [],\n            textures: [],\n            meshes: [],\n            joints: [],\n            skeletons: [],\n            cameras: [],\n            nodes: [],\n            clips: []\n        };\n        // Mount on the root node if given\n        var rootNode = this.rootNode || new Scene();\n\n        var loading = 0;\n        function checkLoad() {\n            loading--;\n            if (loading === 0) {\n                afterLoadBuffer();\n            }\n        }\n        // If already load buffers\n        if (buffers) {\n            lib.buffers = buffers.slice();\n            afterLoadBuffer(true);\n        }\n        else {\n            // Load buffers\n            util.each(json.buffers, function (bufferInfo, idx) {\n                loading++;\n                var path = bufferInfo.uri;\n\n                self._loadBuffer(path, function (buffer) {\n                    lib.buffers[idx] = buffer;\n                    checkLoad();\n                }, checkLoad);\n            });\n        }\n\n        function getResult() {\n            return {\n                json: json,\n                scene: self.rootNode ? null : rootNode,\n                rootNode: self.rootNode ? rootNode : null,\n                cameras: lib.cameras,\n                textures: lib.textures,\n                materials: lib.materials,\n                skeletons: lib.skeletons,\n                meshes: lib.meshes,\n                clips: lib.clips,\n                nodes: lib.nodes\n            };\n        }\n\n        function afterLoadBuffer(immediately) {\n            // Buffer not load complete.\n            if (lib.buffers.length !== json.buffers.length) {\n                setTimeout(function () {\n                    self.trigger('error', 'Buffer not load complete.');\n                });\n                return;\n            }\n\n            json.bufferViews.forEach(function (bufferViewInfo, idx) {\n                // PENDING Performance\n                lib.bufferViews[idx] = lib.buffers[bufferViewInfo.buffer]\n                    .slice(bufferViewInfo.byteOffset || 0, (bufferViewInfo.byteOffset || 0) + (bufferViewInfo.byteLength || 0));\n            });\n            lib.buffers = null;\n            if (self.includeMesh) {\n                if (self.includeTexture) {\n                    self._parseTextures(json, lib);\n                }\n                self._parseMaterials(json, lib);\n                self._parseMeshes(json, lib);\n            }\n            self._parseNodes(json, lib);\n\n            // Only support one scene.\n            if (json.scenes) {\n                var sceneInfo = json.scenes[json.scene || 0]; // Default use the first scene.\n                if (sceneInfo) {\n                    for (var i = 0; i < sceneInfo.nodes.length; i++) {\n                        var node = lib.nodes[sceneInfo.nodes[i]];\n                        node.update();\n                        rootNode.add(node);\n                    }\n                }\n            }\n\n            if (self.includeMesh) {\n                self._parseSkins(json, lib);\n            }\n\n            if (self.includeAnimation) {\n                self._parseAnimations(json, lib);\n            }\n            if (immediately) {\n                setTimeout(function () {\n                    self.trigger('success', getResult());\n                });\n            }\n            else {\n                self.trigger('success', getResult());\n            }\n        }\n\n        return getResult();\n    },\n\n    /**\n     * Binary file path resolver. User can override it\n     * @param {string} path\n     */\n    resolveBinaryPath: function (path) {\n        if (path && path.match(/^data:(.*?)base64,/)) {\n            return path;\n        }\n\n        var rootPath = this.bufferRootPath;\n        if (rootPath == null) {\n            rootPath = this.rootPath;\n        }\n        return util.relative2absolute(path, rootPath);\n    },\n\n    /**\n     * Texture file path resolver. User can override it\n     * @param {string} path\n     */\n    resolveTexturePath: function (path) {\n        if (path && path.match(/^data:(.*?)base64,/)) {\n            return path;\n        }\n\n        var rootPath = this.textureRootPath;\n        if (rootPath == null) {\n            rootPath = this.rootPath;\n        }\n        return util.relative2absolute(path, rootPath);\n    },\n\n    _getShader: function () {\n        if (typeof this.shader === 'string') {\n            return this.shaderLibrary.get(this.shader);\n        }\n        else if (this.shader instanceof Shader) {\n            return this.shader;\n        }\n    },\n\n    _loadBuffer: function (path, onsuccess, onerror) {\n        request.get({\n            url: this.resolveBinaryPath(path),\n            responseType: 'arraybuffer',\n            onload: function (buffer) {\n                onsuccess && onsuccess(buffer);\n            },\n            onerror: function (buffer) {\n                onerror && onerror(buffer);\n            }\n        });\n    },\n\n    // https://github.com/KhronosGroup/glTF/issues/100\n    // https://github.com/KhronosGroup/glTF/issues/193\n    _parseSkins: function (json, lib) {\n\n        // Create skeletons and joints\n        var haveInvBindMatrices = false;\n        util.each(json.skins, function (skinInfo, idx) {\n            var skeleton = new Skeleton({\n                name: skinInfo.name\n            });\n            for (var i = 0; i < skinInfo.joints.length; i++) {\n                var nodeIdx = skinInfo.joints[i];\n                var node = lib.nodes[nodeIdx];\n                var joint = new Joint({\n                    name: node.name,\n                    node: node,\n                    index: skeleton.joints.length\n                });\n                skeleton.joints.push(joint);\n            }\n            skeleton.relativeRootNode = lib.nodes[skinInfo.skeleton] || this.rootNode;\n            if (skinInfo.inverseBindMatrices) {\n                haveInvBindMatrices = true;\n                var IBMInfo = json.accessors[skinInfo.inverseBindMatrices];\n                var buffer = lib.bufferViews[IBMInfo.bufferView];\n\n                var offset = IBMInfo.byteOffset || 0;\n                var size = IBMInfo.count * 16;\n\n                var array = new vendor.Float32Array(buffer, offset, size);\n\n                skeleton.setJointMatricesArray(array);\n            }\n            else {\n                skeleton.updateJointMatrices();\n            }\n            lib.skeletons[idx] = skeleton;\n        }, this);\n\n        function enableSkinningForMesh(mesh, skeleton, jointIndices) {\n            mesh.skeleton = skeleton;\n            mesh.joints = jointIndices;\n        }\n\n        function getJointIndex(joint) {\n            return joint.index;\n        }\n\n        util.each(json.nodes, function (nodeInfo, nodeIdx) {\n            if (nodeInfo.skin != null) {\n                var skinIdx = nodeInfo.skin;\n                var skeleton = lib.skeletons[skinIdx];\n\n                var node = lib.nodes[nodeIdx];\n                var jointIndices = skeleton.joints.map(getJointIndex);\n                if (node instanceof Mesh) {\n                    enableSkinningForMesh(node, skeleton, jointIndices);\n                }\n                else {\n                    // Mesh have multiple primitives\n                    var children = node.children();\n                    for (var i = 0; i < children.length; i++) {\n                        enableSkinningForMesh(children[i], skeleton, jointIndices);\n                    }\n                }\n            }\n        }, this);\n    },\n\n    _parseTextures: function (json, lib) {\n        util.each(json.textures, function (textureInfo, idx){\n            // samplers is optional\n            var samplerInfo = (json.samplers && json.samplers[textureInfo.sampler]) || {};\n            var parameters = {};\n            ['wrapS', 'wrapT', 'magFilter', 'minFilter'].forEach(function (name) {\n                var value = samplerInfo[name];\n                if (value != null) {\n                    parameters[name] = value;\n                }\n            });\n            util.defaults(parameters, {\n                wrapS: Texture.REPEAT,\n                wrapT: Texture.REPEAT,\n                flipY: this.textureFlipY\n            });\n\n            var target = textureInfo.target || glenum.TEXTURE_2D;\n            var format = textureInfo.format;\n            if (format != null) {\n                parameters.format = format;\n            }\n\n            if (target === glenum.TEXTURE_2D) {\n                var texture = new Texture2D(parameters);\n                var imageInfo = json.images[textureInfo.source];\n                var uri;\n                if (imageInfo.uri) {\n                    uri = this.resolveTexturePath(imageInfo.uri);\n                }\n                else if (imageInfo.bufferView != null) {\n                    uri = URL.createObjectURL(new Blob([lib.bufferViews[imageInfo.bufferView]], {\n                        type: imageInfo.mimeType\n                    }));\n                }\n                if (uri) {\n                    texture.load(uri, this.crossOrigin);\n                    lib.textures[idx] = texture;\n                }\n            }\n        }, this);\n    },\n\n    _KHRCommonMaterialToStandard: function (materialInfo, lib) {\n        var uniforms = {};\n        var commonMaterialInfo = materialInfo.extensions['KHR_materials_common'];\n        uniforms = commonMaterialInfo.values || {};\n\n        if (typeof uniforms.diffuse === 'number') {\n            uniforms.diffuse = lib.textures[uniforms.diffuse] || null;\n        }\n        if (typeof uniforms.emission === 'number') {\n            uniforms.emission = lib.textures[uniforms.emission] || null;\n        }\n\n        var enabledTextures = [];\n        if (uniforms['diffuse'] instanceof Texture2D) {\n            enabledTextures.push('diffuseMap');\n        }\n        if (materialInfo.normalTexture) {\n            enabledTextures.push('normalMap');\n        }\n        if (uniforms['emission'] instanceof Texture2D) {\n            enabledTextures.push('emissiveMap');\n        }\n        var material;\n        var isStandardMaterial = this.useStandardMaterial;\n        if (isStandardMaterial) {\n            material = new StandardMaterial({\n                name: materialInfo.name,\n                doubleSided: materialInfo.doubleSided\n            });\n        }\n        else {\n            material = new Material({\n                name: materialInfo.name,\n                shader: this._getShader()\n            });\n\n            material.define('fragment', 'USE_ROUGHNESS');\n            material.define('fragment', 'USE_METALNESS');\n\n            if (materialInfo.doubleSided) {\n                material.define('fragment', 'DOUBLE_SIDED');\n            }\n        }\n\n        if (uniforms.transparent) {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        var diffuseProp = uniforms['diffuse'];\n        if (diffuseProp) {\n            // Color\n            if (Array.isArray(diffuseProp)) {\n                diffuseProp = diffuseProp.slice(0, 3);\n                isStandardMaterial ? (material.color = diffuseProp)\n                    : material.set('color', diffuseProp);\n            }\n            else { // Texture\n                isStandardMaterial ? (material.diffuseMap = diffuseProp)\n                    : material.set('diffuseMap', diffuseProp);\n            }\n        }\n        var emissionProp = uniforms['emission'];\n        if (emissionProp != null) {\n            // Color\n            if (Array.isArray(emissionProp)) {\n                emissionProp = emissionProp.slice(0, 3);\n                isStandardMaterial ? (material.emission = emissionProp)\n                    : material.set('emission', emissionProp);\n            }\n            else { // Texture\n                isStandardMaterial ? (material.emissiveMap = emissionProp)\n                    : material.set('emissiveMap', emissionProp);\n            }\n        }\n        if (materialInfo.normalTexture != null) {\n            // TODO texCoord\n            var normalTextureIndex = materialInfo.normalTexture.index;\n            if (isStandardMaterial) {\n                material.normalMap = lib.textures[normalTextureIndex] || null;\n            }\n            else {\n                material.set('normalMap', lib.textures[normalTextureIndex] || null);\n            }\n        }\n        if (uniforms['shininess'] != null) {\n            var glossiness = Math.log(uniforms['shininess']) / Math.log(8192);\n            // Uniform glossiness\n            material.set('glossiness', glossiness);\n            material.set('roughness', 1 - glossiness);\n        }\n        else {\n            material.set('glossiness', 0.3);\n            material.set('roughness', 0.3);\n        }\n        if (uniforms['specular'] != null) {\n            material.set('specularColor', uniforms['specular'].slice(0, 3));\n        }\n        if (uniforms['transparency'] != null) {\n            material.set('alpha', uniforms['transparency']);\n        }\n\n        return material;\n    },\n\n    _pbrMetallicRoughnessToStandard: function (materialInfo, metallicRoughnessMatInfo, lib) {\n        var alphaTest = materialInfo.alphaMode === 'MASK';\n\n        var isStandardMaterial = this.useStandardMaterial;\n        var material;\n        var diffuseMap, roughnessMap, metalnessMap, normalMap, emissiveMap;\n        var enabledTextures = [];\n            // TODO texCoord\n        if (metallicRoughnessMatInfo.baseColorTexture) {\n            diffuseMap = lib.textures[metallicRoughnessMatInfo.baseColorTexture.index] || null;\n            diffuseMap && enabledTextures.push('diffuseMap');\n        }\n        if (metallicRoughnessMatInfo.metallicRoughnessTexture) {\n            roughnessMap = metalnessMap = lib.textures[metallicRoughnessMatInfo.metallicRoughnessTexture.index] || null;\n            roughnessMap && enabledTextures.push('metalnessMap', 'roughnessMap');\n        }\n        if (materialInfo.normalTexture) {\n            normalMap = lib.textures[materialInfo.normalTexture.index] || null;\n            normalMap && enabledTextures.push('normalMap');\n        }\n        if (materialInfo.emissiveTexture) {\n            emissiveMap = lib.textures[materialInfo.emissiveTexture.index] || null;\n            emissiveMap && enabledTextures.push('emissiveMap');\n        }\n        var baseColor = metallicRoughnessMatInfo.baseColorFactor || [1, 1, 1, 1];\n\n        var commonProperties = {\n            diffuseMap: diffuseMap || null,\n            roughnessMap: roughnessMap || null,\n            metalnessMap: metalnessMap || null,\n            normalMap: normalMap || null,\n            emissiveMap: emissiveMap || null,\n            color: baseColor.slice(0, 3),\n            alpha: baseColor[3],\n            metalness: metallicRoughnessMatInfo.metallicFactor || 0,\n            roughness: metallicRoughnessMatInfo.roughnessFactor || 0,\n            emission: materialInfo.emissiveFactor || [0, 0, 0],\n            alphaCutoff: materialInfo.alphaCutoff || 0\n        };\n        if (commonProperties.roughnessMap) {\n            // In glTF metallicFactor will do multiply, which is different from StandardMaterial.\n            // So simply ignore it\n            commonProperties.metalness = 0.5;\n            commonProperties.roughness = 0.5;\n        }\n        if (isStandardMaterial) {\n            material = new StandardMaterial(util.extend({\n                name: materialInfo.name,\n                alphaTest: alphaTest,\n                doubleSided: materialInfo.doubleSided,\n                // G channel\n                roughnessChannel: 1,\n                // B Channel\n                metalnessChannel: 2\n            }, commonProperties));\n        }\n        else {\n\n            material = new Material({\n                name: materialInfo.name,\n                shader: this._getShader()\n            });\n\n            material.define('fragment', 'USE_ROUGHNESS');\n            material.define('fragment', 'USE_METALNESS');\n            material.define('fragment', 'ROUGHNESS_CHANNEL', 1);\n            material.define('fragment', 'METALNESS_CHANNEL', 2);\n\n            if (alphaTest) {\n                material.define('fragment', 'ALPHA_TEST');\n            }\n            if (materialInfo.doubleSided) {\n                material.define('fragment', 'DOUBLE_SIDED');\n            }\n\n            material.set(commonProperties);\n        }\n\n        if (materialInfo.alphaMode === 'BLEND') {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        return material;\n    },\n\n    _pbrSpecularGlossinessToStandard: function (materialInfo, specularGlossinessMatInfo, lib) {\n        var alphaTest = materialInfo.alphaMode === 'MASK';\n\n        if (this.useStandardMaterial) {\n            console.error('StandardMaterial doesn\\'t support specular glossiness workflow yet');\n        }\n\n        var material;\n        var diffuseMap, glossinessMap, specularMap, normalMap, emissiveMap;\n        var enabledTextures = [];\n            // TODO texCoord\n        if (specularGlossinessMatInfo.diffuseTexture) {\n            diffuseMap = lib.textures[specularGlossinessMatInfo.diffuseTexture.index] || null;\n            diffuseMap && enabledTextures.push('diffuseMap');\n        }\n        if (specularGlossinessMatInfo.specularGlossinessTexture) {\n            glossinessMap = specularMap = lib.textures[specularGlossinessMatInfo.specularGlossinessTexture.index] || null;\n            glossinessMap && enabledTextures.push('specularMap', 'glossinessMap');\n        }\n        if (materialInfo.normalTexture) {\n            normalMap = lib.textures[materialInfo.normalTexture.index] || null;\n            normalMap && enabledTextures.push('normalMap');\n        }\n        if (materialInfo.emissiveTexture) {\n            emissiveMap = lib.textures[materialInfo.emissiveTexture.index] || null;\n            emissiveMap && enabledTextures.push('emissiveMap');\n        }\n        var diffuseColor = specularGlossinessMatInfo.diffuseFactor || [1, 1, 1, 1];\n\n        var commonProperties = {\n            diffuseMap: diffuseMap || null,\n            glossinessMap: glossinessMap || null,\n            specularMap: specularMap || null,\n            normalMap: normalMap || null,\n            emissiveMap: emissiveMap || null,\n            color: diffuseColor.slice(0, 3),\n            alpha: diffuseColor[3],\n            specularColor: specularGlossinessMatInfo.specularFactor || [1, 1, 1],\n            glossiness: specularGlossinessMatInfo.glossinessFactor || 0,\n            emission: materialInfo.emissiveFactor || [0, 0, 0],\n            alphaCutoff: materialInfo.alphaCutoff == null ? 0.9 : materialInfo.alphaCutoff\n        };\n        if (commonProperties.glossinessMap) {\n            // Ignore specularFactor\n            commonProperties.glossiness = 0.5;\n        }\n        if (commonProperties.specularMap) {\n            // Ignore specularFactor\n            commonProperties.specularColor = [1, 1, 1];\n        }\n\n        material = new Material({\n            name: materialInfo.name,\n            shader: this._getShader()\n        });\n\n        material.define('fragment', 'GLOSSINESS_CHANNEL', 3);\n\n        if (alphaTest) {\n            material.define('fragment', 'ALPHA_TEST');\n        }\n        if (materialInfo.doubleSided) {\n            material.define('fragment', 'DOUBLE_SIDED');\n        }\n\n        material.set(commonProperties);\n\n        if (materialInfo.alphaMode === 'BLEND') {\n            material.depthMask = false;\n            material.depthTest = true;\n            material.transparent = true;\n        }\n\n        return material;\n    },\n\n    _parseMaterials: function (json, lib) {\n        util.each(json.materials, function (materialInfo, idx) {\n            if (materialInfo.extensions && materialInfo.extensions['KHR_materials_common']) {\n                lib.materials[idx] = this._KHRCommonMaterialToStandard(materialInfo, lib);\n            }\n            else if (materialInfo.extensions && materialInfo.extensions['KHR_materials_pbrSpecularGlossiness']) {\n                lib.materials[idx] = this._pbrSpecularGlossinessToStandard(materialInfo, materialInfo.extensions['KHR_materials_pbrSpecularGlossiness'], lib);\n            }\n            else {\n                lib.materials[idx] = this._pbrMetallicRoughnessToStandard(materialInfo, materialInfo.pbrMetallicRoughness || {}, lib);\n            }\n        }, this);\n    },\n\n    _parseMeshes: function (json, lib) {\n        var self = this;\n\n        util.each(json.meshes, function (meshInfo, idx) {\n            lib.meshes[idx] = [];\n            // Geometry\n            for (var pp = 0; pp < meshInfo.primitives.length; pp++) {\n                var primitiveInfo = meshInfo.primitives[pp];\n                var geometry = new Geometry({\n                    dynamic: false,\n                    // PENDIGN\n                    name: meshInfo.name,\n                    boundingBox: new BoundingBox()\n                });\n                // Parse attributes\n                var semantics = Object.keys(primitiveInfo.attributes);\n                for (var ss = 0; ss < semantics.length; ss++) {\n                    var semantic = semantics[ss];\n                    var accessorIdx = primitiveInfo.attributes[semantic];\n                    var attributeInfo = json.accessors[accessorIdx];\n                    var attributeName = semanticAttributeMap[semantic];\n                    if (!attributeName) {\n                        continue;\n                    }\n                    var size = SIZE_MAP[attributeInfo.type];\n                    var attributeArray = getAccessorData(json, lib, accessorIdx);\n                    // WebGL attribute buffer not support uint32.\n                    // Direct use Float32Array may also have issue.\n                    if (attributeArray instanceof vendor.Uint32Array) {\n                        attributeArray = new Float32Array(attributeArray);\n                    }\n                    if (semantic === 'WEIGHTS_0' && size === 4) {\n                        // Weight data in QTEK has only 3 component, the last component can be evaluated since it is normalized\n                        var weightArray = new attributeArray.constructor(attributeInfo.count * 3);\n                        for (var i = 0; i < attributeInfo.count; i++) {\n                            var i4 = i * 4, i3 = i * 3;\n                            var w1 = attributeArray[i4], w2 = attributeArray[i4 + 1], w3 = attributeArray[i4 + 2], w4 = attributeArray[i4 + 3];\n                            var wSum = w1 + w2 + w3 + w4;\n                            weightArray[i3] = w1 / wSum;\n                            weightArray[i3 + 1] = w2 / wSum;\n                            weightArray[i3 + 2] = w3 / wSum;\n                        }\n                        geometry.attributes[attributeName].value = weightArray;\n                    }\n                    else {\n                        geometry.attributes[attributeName].value = attributeArray;\n                    }\n                    var attributeType = 'float';\n                    if (attributeArray instanceof vendor.Uint16Array) {\n                        attributeType = 'ushort';\n                    }\n                    else if (attributeArray instanceof vendor.Int16Array) {\n                        attributeType = 'short';\n                    }\n                    else if (attributeArray instanceof vendor.Uint8Array) {\n                        attributeType = 'ubyte';\n                    }\n                    else if (attributeArray instanceof vendor.Int8Array) {\n                        attributeType = 'byte';\n                    }\n                    geometry.attributes[attributeName].type = attributeType;\n\n                    if (semantic === 'POSITION') {\n                        // Bounding Box\n                        var min = attributeInfo.min;\n                        var max = attributeInfo.max;\n                        if (min) {\n                            geometry.boundingBox.min.set(min[0], min[1], min[2]);\n                        }\n                        if (max) {\n                            geometry.boundingBox.max.set(max[0], max[1], max[2]);\n                        }\n                    }\n                }\n\n                // Parse indices\n                if (primitiveInfo.indices != null) {\n                    geometry.indices = getAccessorData(json, lib, primitiveInfo.indices, true);\n                    if (geometry.vertexCount <= 0xffff && geometry.indices instanceof vendor.Uint32Array) {\n                        geometry.indices = new vendor.Uint16Array(geometry.indices);\n                    }\n                    if(geometry.indices instanceof vendor.Uint8Array) {\n                        geometry.indices = new vendor.Uint16Array(geometry.indices);\n                    }\n                }\n\n                var material = lib.materials[primitiveInfo.material];\n                var materialInfo = (json.materials || [])[primitiveInfo.material];\n                // Use default material\n                if (!material) {\n                    material = new Material({\n                        shader: self._getShader()\n                    });\n                }\n                var mesh = new Mesh({\n                    geometry: geometry,\n                    material: material,\n                    mode: [Mesh.POINTS, Mesh.LINES, Mesh.LINE_LOOP, Mesh.LINE_STRIP, Mesh.TRIANGLES, Mesh.TRIANGLE_STRIP, Mesh.TRIANGLE_FAN][primitiveInfo.mode] || Mesh.TRIANGLES,\n                    ignoreGBuffer: material.transparent\n                });\n                if (materialInfo != null) {\n                    mesh.culling = !materialInfo.doubleSided;\n                }\n                if (!mesh.geometry.attributes.normal.value) {\n                    mesh.geometry.generateVertexNormals();\n                }\n                if (((material instanceof StandardMaterial) && material.normalMap)\n                    || (material.isTextureEnabled('normalMap'))\n                ) {\n                    if (!mesh.geometry.attributes.tangent.value) {\n                        mesh.geometry.generateTangents();\n                    }\n                }\n\n                mesh.name = GLTFLoader.generateMeshName(json.meshes, idx, pp);\n\n                lib.meshes[idx].push(mesh);\n            }\n        }, this);\n    },\n\n    _instanceCamera: function (json, nodeInfo) {\n        var cameraInfo = json.cameras[nodeInfo.camera];\n\n        if (cameraInfo.type === 'perspective') {\n            var perspectiveInfo = cameraInfo.perspective || {};\n            return new PerspectiveCamera({\n                name: nodeInfo.name,\n                aspect: perspectiveInfo.aspectRatio,\n                fov: perspectiveInfo.yfov,\n                far: perspectiveInfo.zfar,\n                near: perspectiveInfo.znear\n            });\n        }\n        else {\n            var orthographicInfo = cameraInfo.orthographic || {};\n            return new OrthographicCamera({\n                name: nodeInfo.name,\n                top: orthographicInfo.ymag,\n                right: orthographicInfo.xmag,\n                left: -orthographicInfo.xmag,\n                bottom: -orthographicInfo.ymag,\n                near: orthographicInfo.znear,\n                far: orthographicInfo.zfar\n            });\n        }\n    },\n\n    _parseNodes: function (json, lib) {\n\n        function instanceMesh(mesh) {\n            return new Mesh({\n                name: mesh.name,\n                geometry: mesh.geometry,\n                material: mesh.material,\n                culling: mesh.culling,\n                mode: mesh.mode\n            });\n        }\n\n        util.each(json.nodes, function (nodeInfo, idx) {\n            var node;\n            if (nodeInfo.camera != null && this.includeCamera) {\n                node = this._instanceCamera(json, nodeInfo);\n                lib.cameras.push(node);\n            }\n            else if (nodeInfo.mesh != null && this.includeMesh) {\n                var primitives = lib.meshes[nodeInfo.mesh];\n                if (primitives) {\n                    if (primitives.length === 1) {\n                        // Replace the node with mesh directly\n                        node = instanceMesh(primitives[0]);\n                        node.setName(nodeInfo.name);\n                    }\n                    else {\n                        node = new Node();\n                        node.setName(nodeInfo.name);\n                        for (var j = 0; j < primitives.length; j++) {\n                            node.add(instanceMesh(primitives[j]));\n                        }\n                    }\n                }\n            }\n            else {\n                node = new Node();\n                // PENDING Dulplicate name.\n                node.setName(nodeInfo.name);\n            }\n            if (nodeInfo.matrix) {\n                node.localTransform.setArray(nodeInfo.matrix);\n                node.decomposeLocalTransform();\n            }\n            else {\n                if (nodeInfo.translation) {\n                    node.position.setArray(nodeInfo.translation);\n                }\n                if (nodeInfo.rotation) {\n                    node.rotation.setArray(nodeInfo.rotation);\n                }\n                if (nodeInfo.scale) {\n                    node.scale.setArray(nodeInfo.scale);\n                }\n            }\n\n            lib.nodes[idx] = node;\n        }, this);\n\n        // Build hierarchy\n        util.each(json.nodes, function (nodeInfo, idx) {\n            var node = lib.nodes[idx];\n            if (nodeInfo.children) {\n                for (var i = 0; i < nodeInfo.children.length; i++) {\n                    var childIdx = nodeInfo.children[i];\n                    var child = lib.nodes[childIdx];\n                    node.add(child);\n                }\n            }\n        });\n        },\n\n    _parseAnimations: function (json, lib) {\n        function checkChannelPath(channelInfo) {\n            if (channelInfo.path === 'weights') {\n                console.warn('GLTFLoader not support morph targets yet.');\n                return false;\n            }\n            return true;\n        }\n\n        function getChannelHash(channelInfo, animationInfo) {\n            return channelInfo.target.node + '_' + animationInfo.samplers[channelInfo.sampler].input;\n        }\n\n        var timeAccessorMultiplied = {};\n        util.each(json.animations, function (animationInfo, idx) {\n            var channels = animationInfo.channels.filter(checkChannelPath);\n\n            if (!channels.length) {\n                return;\n            }\n            var tracks = {};\n            for (var i = 0; i < channels.length; i++) {\n                var channelInfo = channels[i];\n                var channelHash = getChannelHash(channelInfo, animationInfo);\n\n                var targetNode = lib.nodes[channelInfo.target.node];\n                var track = tracks[channelHash];\n                var samplerInfo = animationInfo.samplers[channelInfo.sampler];\n\n                if (!track) {\n                    track = tracks[channelHash] = new SamplerTrack({\n                        name: targetNode ? targetNode.name : '',\n                        target: targetNode\n                    });\n                    track.targetNodeIndex = channelInfo.target.node;\n                    track.channels.time = getAccessorData(json, lib, samplerInfo.input);\n                    var frameLen = track.channels.time.length;\n                    if (!timeAccessorMultiplied[samplerInfo.input]) {\n                        for (var k = 0; k < frameLen; k++) {\n                            track.channels.time[k] *= 1000;\n                        }\n                        timeAccessorMultiplied[samplerInfo.input] = true;\n                    }\n                }\n\n                var interpolation = samplerInfo.interpolation || 'LINEAR';\n                if (interpolation !== 'LINEAR') {\n                    console.warn('GLTFLoader only support LINEAR interpolation.');\n                }\n\n                var path = channelInfo.target.path;\n                if (path === 'translation') {\n                    path = 'position';\n                }\n\n                track.channels[path] = getAccessorData(json, lib, samplerInfo.output);\n            }\n            var clip = new TrackClip({\n                name: animationInfo.name,\n                loop: true\n            });\n            for (var hash in tracks) {\n                clip.addTrack(tracks[hash]);\n            }\n            clip.calcLifeFromTracks();\n            lib.clips.push(clip);\n        }, this);\n\n\n        // PENDING\n        var maxLife = lib.clips.reduce(function (maxTime, clip) {\n            return Math.max(maxTime, clip.life);\n        }, 0);\n        lib.clips.forEach(function (clip) {\n            clip.life = maxLife;\n        });\n\n        return lib.clips;\n    }\n});\n\nGLTFLoader.generateMeshName = function (meshes, idx, primitiveIdx) {\n    var meshInfo = meshes[idx];\n    var meshName = meshInfo.name || ('mesh_' + idx);\n    return primitiveIdx === 0 ? meshName : (meshName + '$' + primitiveIdx);\n};\n\nexport default GLTFLoader;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Directional\n * @extends clay.Light\n *\n * @example\n *     var light = new clay.light.Directional({\n *         intensity: 0.5,\n *         color: [1.0, 0.0, 0.0]\n *     });\n *     light.position.set(10, 10, 10);\n *     light.lookAt(clay.math.Vector3.ZERO);\n *     scene.add(light);\n */\nvar DirectionalLight = Light.extend(\n/** @lends clay.light.Directional# */\n{\n    /**\n     * @type {number}\n     */\n    shadowBias: 0.001,\n    /**\n     * @type {number}\n     */\n    shadowSlopeScale: 2.0,\n    /**\n     * Shadow cascade.\n     * Use PSSM technique when it is larger than 1 and have a unique directional light in scene.\n     * @type {number}\n     */\n    shadowCascade: 1,\n\n    /**\n     * Available when shadowCascade is larger than 1 and have a unique directional light in scene.\n     * @type {number}\n     */\n    cascadeSplitLogFactor: 0.2\n}, {\n\n    type: 'DIRECTIONAL_LIGHT',\n\n    uniformTemplates: {\n        directionalLightDirection: {\n            type: '3f',\n            value: function (instance) {\n                instance.__dir = instance.__dir || new Vector3();\n                // Direction is target to eye\n                return instance.__dir.copy(instance.worldTransform.z).normalize().negate().array;\n            }\n        },\n        directionalLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Directional}\n     * @memberOf clay.light.Directional.prototype\n     */\n    clone: function () {\n        var light = Light.prototype.clone.call(this);\n        light.shadowBias = this.shadowBias;\n        light.shadowSlopeScale = this.shadowSlopeScale;\n        return light;\n    }\n});\n\nexport default DirectionalLight;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Point\n * @extends clay.Light\n */\nvar PointLight = Light.extend(\n/** @lends clay.light.Point# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    castShadow: false\n}, {\n\n    type: 'POINT_LIGHT',\n\n    uniformTemplates: {\n        pointLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        pointLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n        pointLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color,\n                    intensity = instance.intensity;\n                return [ color[0]*intensity, color[1]*intensity, color[2]*intensity ];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Point}\n     * @memberOf clay.light.Point.prototype\n     */\n    clone: function() {\n        var light = Light.prototype.clone.call(this);\n        light.range = this.range;\n        return light;\n    }\n});\n\nexport default PointLight;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Spot\n * @extends clay.Light\n */\nvar SpotLight = Light.extend(\n/**@lends clay.light.Spot */\n{\n    /**\n     * @type {number}\n     */\n    range: 20,\n    /**\n     * @type {number}\n     */\n    umbraAngle: 30,\n    /**\n     * @type {number}\n     */\n    penumbraAngle: 45,\n    /**\n     * @type {number}\n     */\n    falloffFactor: 2.0,\n    /**\n     * @type {number}\n     */\n    shadowBias: 0.0002,\n    /**\n     * @type {number}\n     */\n    shadowSlopeScale: 2.0\n},{\n\n    type: 'SPOT_LIGHT',\n\n    uniformTemplates: {\n        spotLightPosition: {\n            type: '3f',\n            value: function (instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        spotLightRange: {\n            type: '1f',\n            value: function (instance) {\n                return instance.range;\n            }\n        },\n        spotLightUmbraAngleCosine: {\n            type: '1f',\n            value: function (instance) {\n                return Math.cos(instance.umbraAngle * Math.PI / 180);\n            }\n        },\n        spotLightPenumbraAngleCosine: {\n            type: '1f',\n            value: function (instance) {\n                return Math.cos(instance.penumbraAngle * Math.PI / 180);\n            }\n        },\n        spotLightFalloffFactor: {\n            type: '1f',\n            value: function (instance) {\n                return instance.falloffFactor;\n            }\n        },\n        spotLightDirection: {\n            type: '3f',\n            value: function (instance) {\n                instance.__dir = instance.__dir || new Vector3();\n                // Direction is target to eye\n                return instance.__dir.copy(instance.worldTransform.z).negate().array;\n            }\n        },\n        spotLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        }\n    },\n    /**\n     * @return {clay.light.Spot}\n     * @memberOf clay.light.Spot.prototype\n     */\n    clone: function () {\n        var light = Light.prototype.clone.call(this);\n        light.range = this.range;\n        light.umbraAngle = this.umbraAngle;\n        light.penumbraAngle = this.penumbraAngle;\n        light.falloffFactor = this.falloffFactor;\n        light.shadowBias = this.shadowBias;\n        light.shadowSlopeScale = this.shadowSlopeScale;\n        return light;\n    }\n});\n\nexport default SpotLight;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Ambient\n * @extends clay.Light\n */\nvar AmbientLight = Light.extend({\n\n    castShadow: false\n\n}, {\n\n    type: 'AMBIENT_LIGHT',\n\n    uniformTemplates: {\n        ambientLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.Ambient}\n     * @memberOf clay.light.Ambient.prototype\n     */\n});\n\nexport default AmbientLight;\n","import Texture from './Texture';\nimport glenum from './core/glenum';\nimport util from './core/util';\nimport mathUtil from './math/util';\nvar isPowerOfTwo = mathUtil.isPowerOfTwo;\n\nvar targetList = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * @constructor clay.TextureCube\n * @extends clay.Texture\n *\n * @example\n *     ...\n *     var mat = new clay.Material({\n *         shader: clay.shader.library.get('clay.phong', 'environmentMap')\n *     });\n *     var envMap = new clay.TextureCube();\n *     envMap.load({\n *         'px': 'assets/textures/sky/px.jpg',\n *         'nx': 'assets/textures/sky/nx.jpg'\n *         'py': 'assets/textures/sky/py.jpg'\n *         'ny': 'assets/textures/sky/ny.jpg'\n *         'pz': 'assets/textures/sky/pz.jpg'\n *         'nz': 'assets/textures/sky/nz.jpg'\n *     });\n *     mat.set('environmentMap', envMap);\n *     ...\n *     envMap.success(function () {\n *         // Wait for the sky texture loaded\n *         animation.on('frame', function (frameTime) {\n *             renderer.render(scene, camera);\n *         });\n *     });\n */\nvar TextureCube = Texture.extend(function () {\n    return /** @lends clay.TextureCube# */{\n        /**\n         * @type {Object}\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} px\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} nx\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} py\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} ny\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} pz\n         * @property {?HTMLImageElement|HTMLCanvasElemnet} nz\n         */\n        image: {\n            px: null,\n            nx: null,\n            py: null,\n            ny: null,\n            pz: null,\n            nz: null\n        },\n        /**\n         * Pixels data of each side. Will be ignored if images are set.\n         * @type {Object}\n         * @property {?Uint8Array} px\n         * @property {?Uint8Array} nx\n         * @property {?Uint8Array} py\n         * @property {?Uint8Array} ny\n         * @property {?Uint8Array} pz\n         * @property {?Uint8Array} nz\n         */\n        pixels: {\n            px: null,\n            nx: null,\n            py: null,\n            ny: null,\n            pz: null,\n            nz: null\n        },\n\n        /**\n         * @type {Array.<Object>}\n         */\n        mipmaps: []\n    };\n}, {\n    update: function (renderer) {\n        var _gl = renderer.gl;\n        _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture'));\n\n        this.updateCommon(renderer);\n\n        var glFormat = this.format;\n        var glType = this.type;\n\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_S, this.getAvailableWrapS());\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_WRAP_T, this.getAvailableWrapT());\n\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MAG_FILTER, this.getAvailableMagFilter());\n        _gl.texParameteri(_gl.TEXTURE_CUBE_MAP, _gl.TEXTURE_MIN_FILTER, this.getAvailableMinFilter());\n\n        var anisotropicExt = renderer.getGLExtension('EXT_texture_filter_anisotropic');\n        if (anisotropicExt && this.anisotropic > 1) {\n            _gl.texParameterf(_gl.TEXTURE_CUBE_MAP, anisotropicExt.TEXTURE_MAX_ANISOTROPY_EXT, this.anisotropic);\n        }\n\n        // Fallback to float type if browser don't have half float extension\n        if (glType === 36193) {\n            var halfFloatExt = renderer.getGLExtension('OES_texture_half_float');\n            if (!halfFloatExt) {\n                glType = glenum.FLOAT;\n            }\n        }\n\n        if (this.mipmaps.length) {\n            var width = this.width;\n            var height = this.height;\n            for (var i = 0; i < this.mipmaps.length; i++) {\n                var mipmap = this.mipmaps[i];\n                this._updateTextureData(_gl, mipmap, i, width, height, glFormat, glType);\n                width /= 2;\n                height /= 2;\n            }\n        }\n        else {\n            this._updateTextureData(_gl, this, 0, this.width, this.height, glFormat, glType);\n\n            if (!this.NPOT && this.useMipmap) {\n                _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP);\n            }\n        }\n\n        _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, null);\n    },\n\n    _updateTextureData: function (_gl, data, level, width, height, glFormat, glType) {\n        for (var i = 0; i < 6; i++) {\n            var target = targetList[i];\n            var img = data.image && data.image[target];\n            if (img) {\n                _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, glFormat, glType, img);\n            }\n            else {\n                _gl.texImage2D(_gl.TEXTURE_CUBE_MAP_POSITIVE_X + i, level, glFormat, width, height, 0, glFormat, glType, data.pixels && data.pixels[target]);\n            }\n        }\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     * @memberOf clay.TextureCube.prototype\n     */\n    generateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        if (this.useMipmap && !this.NPOT) {\n            _gl.bindTexture(_gl.TEXTURE_CUBE_MAP, this._cache.get('webgl_texture'));\n            _gl.generateMipmap(_gl.TEXTURE_CUBE_MAP);\n        }\n    },\n\n    bind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, this.getWebGLTexture(renderer));\n    },\n\n    unbind: function (renderer) {\n        renderer.gl.bindTexture(renderer.gl.TEXTURE_CUBE_MAP, null);\n    },\n\n    // Overwrite the isPowerOfTwo method\n    isPowerOfTwo: function () {\n        if (this.image.px) {\n            return isPowerOfTwo(this.image.px.width)\n                && isPowerOfTwo(this.image.px.height);\n        }\n        else {\n            return isPowerOfTwo(this.width)\n                && isPowerOfTwo(this.height);\n        }\n    },\n\n    isRenderable: function () {\n        if (this.image.px) {\n            return isImageRenderable(this.image.px)\n                && isImageRenderable(this.image.nx)\n                && isImageRenderable(this.image.py)\n                && isImageRenderable(this.image.ny)\n                && isImageRenderable(this.image.pz)\n                && isImageRenderable(this.image.nz);\n        }\n        else {\n            return !!(this.width && this.height);\n        }\n    },\n\n    load: function (imageList, crossOrigin) {\n        var loading = 0;\n        var self = this;\n        util.each(imageList, function (src, target){\n            var image = new Image();\n            if (crossOrigin) {\n                image.crossOrigin = crossOrigin;\n            }\n            image.onload = function () {\n                loading --;\n                if (loading === 0){\n                    self.dirty();\n                    self.trigger('success', self);\n                }\n                image.onload = null;\n            };\n            image.onerror = function () {\n                loading --;\n                image.onerror = null;\n            };\n\n            loading++;\n            image.src = src;\n            self.image[target] = image;\n        });\n\n        return this;\n    }\n});\n\nObject.defineProperty(TextureCube.prototype, 'width', {\n    get: function () {\n        if (this.image && this.image.px) {\n            return this.image.px.width;\n        }\n        return this._width;\n    },\n    set: function (value) {\n        if (this.image && this.image.px) {\n            console.warn('Texture from image can\\'t set width');\n        }\n        else {\n            if (this._width !== value) {\n                this.dirty();\n            }\n            this._width = value;\n        }\n    }\n});\nObject.defineProperty(TextureCube.prototype, 'height', {\n    get: function () {\n        if (this.image && this.image.px) {\n            return this.image.px.height;\n        }\n        return this._height;\n    },\n    set: function (value) {\n        if (this.image && this.image.px) {\n            console.warn('Texture from image can\\'t set height');\n        }\n        else {\n            if (this._height !== value) {\n                this.dirty();\n            }\n            this._height = value;\n        }\n    }\n});\nfunction isImageRenderable(image) {\n    return image.nodeName === 'CANVAS' ||\n            image.nodeName === 'VIDEO' ||\n            image.complete;\n}\n\nexport default TextureCube;\n","import Base from './core/Base';\nimport Texture from './Texture';\nimport TextureCube from './TextureCube';\nimport glenum from './core/glenum';\nimport Cache from './core/Cache';\n\nvar KEY_FRAMEBUFFER = 'framebuffer';\nvar KEY_RENDERBUFFER = 'renderbuffer';\nvar KEY_RENDERBUFFER_WIDTH = KEY_RENDERBUFFER + '_width';\nvar KEY_RENDERBUFFER_HEIGHT = KEY_RENDERBUFFER + '_height';\nvar KEY_RENDERBUFFER_ATTACHED = KEY_RENDERBUFFER + '_attached';\nvar KEY_DEPTHTEXTURE_ATTACHED = 'depthtexture_attached';\n\nvar GL_FRAMEBUFFER = glenum.FRAMEBUFFER;\nvar GL_RENDERBUFFER = glenum.RENDERBUFFER;\nvar GL_DEPTH_ATTACHMENT = glenum.DEPTH_ATTACHMENT;\nvar GL_COLOR_ATTACHMENT0 = glenum.COLOR_ATTACHMENT0;\n/**\n * @constructor clay.FrameBuffer\n * @extends clay.core.Base\n */\nvar FrameBuffer = Base.extend(\n/** @lends clay.FrameBuffer# */\n{\n    /**\n     * If use depth buffer\n     * @type {boolean}\n     */\n    depthBuffer: true,\n\n    /**\n     * @type {Object}\n     */\n    viewport: null,\n\n    _width: 0,\n    _height: 0,\n\n    _textures: null,\n\n    _boundRenderer: null,\n}, function () {\n    // Use cache\n    this._cache = new Cache();\n\n    this._textures = {};\n},\n\n/**@lends clay.FrameBuffer.prototype. */\n{\n    /**\n     * Get attached texture width\n     * {number}\n     */\n    // FIXME Can't use before #bind\n    getTextureWidth: function () {\n        return this._width;\n    },\n\n    /**\n     * Get attached texture height\n     * {number}\n     */\n    getTextureHeight: function () {\n        return this._height;\n    },\n\n    /**\n     * Bind the framebuffer to given renderer before rendering\n     * @param  {clay.Renderer} renderer\n     */\n    bind: function (renderer) {\n\n        if (renderer.__currentFrameBuffer) {\n            // Already bound\n            if (renderer.__currentFrameBuffer === this) {\n                return;\n            }\n\n            console.warn('Renderer already bound with another framebuffer. Unbind it first');\n        }\n        renderer.__currentFrameBuffer = this;\n\n        var _gl = renderer.gl;\n\n        _gl.bindFramebuffer(GL_FRAMEBUFFER, this._getFrameBufferGL(renderer));\n        this._boundRenderer = renderer;\n        var cache = this._cache;\n\n        cache.put('viewport', renderer.viewport);\n\n        var hasTextureAttached = false;\n        var width;\n        var height;\n        for (var attachment in this._textures) {\n            hasTextureAttached = true;\n            var obj = this._textures[attachment];\n            if (obj) {\n                // TODO Do width, height checking, make sure size are same\n                width = obj.texture.width;\n                height = obj.texture.height;\n                // Attach textures\n                this._doAttach(renderer, obj.texture, attachment, obj.target);\n            }\n        }\n\n        this._width = width;\n        this._height = height;\n\n        if (!hasTextureAttached && this.depthBuffer) {\n            console.error('Must attach texture before bind, or renderbuffer may have incorrect width and height.')\n        }\n\n        if (this.viewport) {\n            renderer.setViewport(this.viewport);\n        }\n        else {\n            renderer.setViewport(0, 0, width, height, 1);\n        }\n\n        var attachedTextures = cache.get('attached_textures');\n        if (attachedTextures) {\n            for (var attachment in attachedTextures) {\n                if (!this._textures[attachment]) {\n                    var target = attachedTextures[attachment];\n                    this._doDetach(_gl, attachment, target);\n                }\n            }\n        }\n        if (!cache.get(KEY_DEPTHTEXTURE_ATTACHED) && this.depthBuffer) {\n            // Create a new render buffer\n            if (cache.miss(KEY_RENDERBUFFER)) {\n                cache.put(KEY_RENDERBUFFER, _gl.createRenderbuffer());\n            }\n            var renderbuffer = cache.get(KEY_RENDERBUFFER);\n\n            if (width !== cache.get(KEY_RENDERBUFFER_WIDTH)\n                    || height !== cache.get(KEY_RENDERBUFFER_HEIGHT)) {\n                _gl.bindRenderbuffer(GL_RENDERBUFFER, renderbuffer);\n                _gl.renderbufferStorage(GL_RENDERBUFFER, _gl.DEPTH_COMPONENT16, width, height);\n                cache.put(KEY_RENDERBUFFER_WIDTH, width);\n                cache.put(KEY_RENDERBUFFER_HEIGHT, height);\n                _gl.bindRenderbuffer(GL_RENDERBUFFER, null);\n            }\n            if (!cache.get(KEY_RENDERBUFFER_ATTACHED)) {\n                _gl.framebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, renderbuffer);\n                cache.put(KEY_RENDERBUFFER_ATTACHED, true);\n            }\n        }\n    },\n\n    /**\n     * Unbind the frame buffer after rendering\n     * @param  {clay.Renderer} renderer\n     */\n    unbind: function (renderer) {\n        // Remove status record on renderer\n        renderer.__currentFrameBuffer = null;\n\n        var _gl = renderer.gl;\n\n        _gl.bindFramebuffer(GL_FRAMEBUFFER, null);\n        this._boundRenderer = null;\n\n        this._cache.use(renderer.__uid__);\n        var viewport = this._cache.get('viewport');\n        // Reset viewport;\n        if (viewport) {\n            renderer.setViewport(viewport);\n        }\n\n        this.updateMipmap(renderer);\n    },\n\n    // Because the data of texture is changed over time,\n    // Here update the mipmaps of texture each time after rendered;\n    updateMipmap: function (renderer) {\n        var _gl = renderer.gl;\n        for (var attachment in this._textures) {\n            var obj = this._textures[attachment];\n            if (obj) {\n                var texture = obj.texture;\n                // FIXME some texture format can't generate mipmap\n                if (!texture.NPOT && texture.useMipmap\n                    && texture.minFilter === Texture.LINEAR_MIPMAP_LINEAR) {\n                    var target = texture instanceof TextureCube ? glenum.TEXTURE_CUBE_MAP : glenum.TEXTURE_2D;\n                    _gl.bindTexture(target, texture.getWebGLTexture(renderer));\n                    _gl.generateMipmap(target);\n                    _gl.bindTexture(target, null);\n                }\n            }\n        }\n    },\n\n\n    // 0x8CD5, 36053, FRAMEBUFFER_COMPLETE\n    // 0x8CD6, 36054, FRAMEBUFFER_INCOMPLETE_ATTACHMENT\n    // 0x8CD7, 36055, FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT\n    // 0x8CD9, 36057, FRAMEBUFFER_INCOMPLETE_DIMENSIONS\n    // 0x8CDD, 36061, FRAMEBUFFER_UNSUPPORTED\n    checkStatus: function (_gl) {\n        return _gl.checkFramebufferStatus(GL_FRAMEBUFFER);\n    },\n\n    _getFrameBufferGL: function (renderer) {\n        var cache = this._cache;\n        cache.use(renderer.__uid__);\n\n        if (cache.miss(KEY_FRAMEBUFFER)) {\n            cache.put(KEY_FRAMEBUFFER, renderer.gl.createFramebuffer());\n        }\n\n        return cache.get(KEY_FRAMEBUFFER);\n    },\n\n    /**\n     * Attach a texture(RTT) to the framebuffer\n     * @param  {clay.Texture} texture\n     * @param  {number} [attachment=gl.COLOR_ATTACHMENT0]\n     * @param  {number} [target=gl.TEXTURE_2D]\n     */\n    attach: function (texture, attachment, target) {\n\n        if (!texture.width) {\n            throw new Error('The texture attached to color buffer is not a valid.');\n        }\n        // TODO width and height check\n\n        // If the depth_texture extension is enabled, developers\n        // Can attach a depth texture to the depth buffer\n        // http://blog.tojicode.com/2012/07/using-webgldepthtexture.html\n        attachment = attachment || GL_COLOR_ATTACHMENT0;\n        target = target || glenum.TEXTURE_2D;\n\n        var boundRenderer = this._boundRenderer;\n        var _gl = boundRenderer && boundRenderer.gl;\n        var attachedTextures;\n\n        if (_gl) {\n            var cache = this._cache;\n            cache.use(boundRenderer.__uid__);\n            attachedTextures = cache.get('attached_textures');\n        }\n\n        // Check if texture attached\n        var previous = this._textures[attachment];\n        if (previous && previous.target === target\n            && previous.texture === texture\n            && (attachedTextures && attachedTextures[attachment] != null)\n        ) {\n            return;\n        }\n\n        var canAttach = true;\n        if (boundRenderer) {\n            canAttach = this._doAttach(boundRenderer, texture, attachment, target);\n            // Set viewport again incase attached to different size textures.\n            if (!this.viewport) {\n                boundRenderer.setViewport(0, 0, texture.width, texture.height, 1);\n            }\n        }\n\n        if (canAttach) {\n            this._textures[attachment] = this._textures[attachment] || {};\n            this._textures[attachment].texture = texture;\n            this._textures[attachment].target = target;\n        }\n    },\n\n    _doAttach: function (renderer, texture, attachment, target) {\n        var _gl = renderer.gl;\n        // Make sure texture is always updated\n        // Because texture width or height may be changed and in this we can't be notified\n        // FIXME awkward;\n        var webglTexture = texture.getWebGLTexture(renderer);\n        // Assume cache has been used.\n        var attachedTextures = this._cache.get('attached_textures');\n        if (attachedTextures && attachedTextures[attachment]) {\n            var obj = attachedTextures[attachment];\n            // Check if texture and target not changed\n            if (obj.texture === texture && obj.target === target) {\n                return;\n            }\n        }\n        attachment = +attachment;\n\n        var canAttach = true;\n        if (attachment === GL_DEPTH_ATTACHMENT || attachment === glenum.DEPTH_STENCIL_ATTACHMENT) {\n            var extension = renderer.getGLExtension('WEBGL_depth_texture');\n\n            if (!extension) {\n                console.error('Depth texture is not supported by the browser');\n                canAttach = false;\n            }\n            if (texture.format !== glenum.DEPTH_COMPONENT\n                && texture.format !== glenum.DEPTH_STENCIL\n            ) {\n                console.error('The texture attached to depth buffer is not a valid.');\n                canAttach = false;\n            }\n\n            // Dispose render buffer created previous\n            if (canAttach) {\n                var renderbuffer = this._cache.get(KEY_RENDERBUFFER);\n                if (renderbuffer) {\n                    _gl.framebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, null);\n                    _gl.deleteRenderbuffer(renderbuffer);\n                    this._cache.put(KEY_RENDERBUFFER, false);\n                }\n\n                this._cache.put(KEY_RENDERBUFFER_ATTACHED, false);\n                this._cache.put(KEY_DEPTHTEXTURE_ATTACHED, true);\n            }\n        }\n\n        // Mipmap level can only be 0\n        _gl.framebufferTexture2D(GL_FRAMEBUFFER, attachment, target, webglTexture, 0);\n\n        if (!attachedTextures) {\n            attachedTextures = {};\n            this._cache.put('attached_textures', attachedTextures);\n        }\n        attachedTextures[attachment] = attachedTextures[attachment] || {};\n        attachedTextures[attachment].texture = texture;\n        attachedTextures[attachment].target = target;\n\n        return canAttach;\n    },\n\n    _doDetach: function (_gl, attachment, target) {\n        // Detach a texture from framebuffer\n        // https://github.com/KhronosGroup/WebGL/blob/master/conformance-suites/1.0.0/conformance/framebuffer-test.html#L145\n        _gl.framebufferTexture2D(GL_FRAMEBUFFER, attachment, target, null, 0);\n\n        // Assume cache has been used.\n        var attachedTextures = this._cache.get('attached_textures');\n        if (attachedTextures && attachedTextures[attachment]) {\n            attachedTextures[attachment] = null;\n        }\n\n        if (attachment === GL_DEPTH_ATTACHMENT || attachment === glenum.DEPTH_STENCIL_ATTACHMENT) {\n            this._cache.put(KEY_DEPTHTEXTURE_ATTACHED, false);\n        }\n    },\n\n    /**\n     * Detach a texture\n     * @param  {number} [attachment=gl.COLOR_ATTACHMENT0]\n     * @param  {number} [target=gl.TEXTURE_2D]\n     */\n    detach: function (attachment, target) {\n        // TODO depth extension check ?\n        this._textures[attachment] = null;\n        if (this._boundRenderer) {\n            var cache = this._cache;\n            cache.use(this._boundRenderer.__uid__);\n            this._doDetach(this._boundRenderer.gl, attachment, target);\n        }\n    },\n    /**\n     * Dispose\n     * @param  {WebGLRenderingContext} _gl\n     */\n    dispose: function (renderer) {\n\n        var _gl = renderer.gl;\n        var cache = this._cache;\n\n        cache.use(renderer.__uid__);\n\n        var renderBuffer = cache.get(KEY_RENDERBUFFER);\n        if (renderBuffer) {\n            _gl.deleteRenderbuffer(renderBuffer);\n        }\n        var frameBuffer = cache.get(KEY_FRAMEBUFFER);\n        if (frameBuffer) {\n            _gl.deleteFramebuffer(frameBuffer);\n        }\n        cache.deleteContext(renderer.__uid__);\n\n        // Clear cache for reusing\n        this._textures = {};\n\n    }\n});\n\nFrameBuffer.DEPTH_ATTACHMENT = GL_DEPTH_ATTACHMENT;\nFrameBuffer.COLOR_ATTACHMENT0 = GL_COLOR_ATTACHMENT0;\nFrameBuffer.STENCIL_ATTACHMENT = glenum.STENCIL_ATTACHMENT;\nFrameBuffer.DEPTH_STENCIL_ATTACHMENT = glenum.DEPTH_STENCIL_ATTACHMENT;\n\nexport default FrameBuffer;\n","export default \"\\n@export clay.compositor.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    v_Texcoord = texcoord;\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n}\\n@end\";\n","import Base from '../core/Base';\nimport OrthoCamera from '../camera/Orthographic';\nimport Plane from '../geometry/Plane';\nimport Shader from '../Shader';\nimport Material from '../Material';\nimport Mesh from '../Mesh';\nimport glenum from '../core/glenum';\nimport vertexEssl from '../shader/source/compositor/vertex.glsl.js';\n\nShader['import'](vertexEssl);\n\nvar planeGeo = new Plane();\nvar mesh = new Mesh({\n    geometry: planeGeo,\n    frustumCulling: false\n});\nvar camera = new OrthoCamera();\n\n/**\n * @constructor clay.compositor.Pass\n * @extends clay.core.Base\n */\nvar Pass = Base.extend(function () {\n    return /** @lends clay.compositor.Pass# */ {\n        /**\n         * Fragment shader string\n         * @type {string}\n         */\n        // PENDING shader or fragment ?\n        fragment : '',\n\n        /**\n         * @type {Object}\n         */\n        outputs : null,\n\n        /**\n         * @type {clay.Material}\n         */\n        material : null,\n\n        /**\n         * @type {Boolean}\n         */\n        blendWithPrevious: false,\n\n        /**\n         * @type {Boolean}\n         */\n        clearColor: false,\n\n        /**\n         * @type {Boolean}\n         */\n        clearDepth: true\n    };\n}, function() {\n\n    var shader = new Shader(Shader.source('clay.compositor.vertex'), this.fragment);\n    var material = new Material({\n        shader: shader\n    });\n    material.enableTexturesAll();\n\n    this.material = material;\n\n},\n/** @lends clay.compositor.Pass.prototype */\n{\n    /**\n     * @param {string} name\n     * @param {} value\n     */\n    setUniform : function(name, value) {\n        this.material.setUniform(name, value);\n    },\n    /**\n     * @param  {string} name\n     * @return {}\n     */\n    getUniform : function(name) {\n        var uniform = this.material.uniforms[name];\n        if (uniform) {\n            return uniform.value;\n        }\n    },\n    /**\n     * @param  {clay.Texture} texture\n     * @param  {number} attachment\n     */\n    attachOutput : function(texture, attachment) {\n        if (!this.outputs) {\n            this.outputs = {};\n        }\n        attachment = attachment || glenum.COLOR_ATTACHMENT0;\n        this.outputs[attachment] = texture;\n    },\n    /**\n     * @param  {clay.Texture} texture\n     */\n    detachOutput : function(texture) {\n        for (var attachment in this.outputs) {\n            if (this.outputs[attachment] === texture) {\n                this.outputs[attachment] = null;\n            }\n        }\n    },\n\n    bind : function(renderer, frameBuffer) {\n\n        if (this.outputs) {\n            for (var attachment in this.outputs) {\n                var texture = this.outputs[attachment];\n                if (texture) {\n                    frameBuffer.attach(texture, attachment);\n                }\n            }\n        }\n\n        if (frameBuffer) {\n            frameBuffer.bind(renderer);\n        }\n    },\n\n    unbind : function(renderer, frameBuffer) {\n        frameBuffer.unbind(renderer);\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.FrameBuffer} [frameBuffer]\n     */\n    render : function(renderer, frameBuffer) {\n\n        var _gl = renderer.gl;\n\n        if (frameBuffer) {\n            this.bind(renderer, frameBuffer);\n            // MRT Support in chrome\n            // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html\n            var ext = renderer.getGLExtension('EXT_draw_buffers');\n            if (ext && this.outputs) {\n                var bufs = [];\n                for (var attachment in this.outputs) {\n                    attachment = +attachment;\n                    if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) {\n                        bufs.push(attachment);\n                    }\n                }\n                ext.drawBuffersEXT(bufs);\n            }\n        }\n\n        this.trigger('beforerender', this, renderer);\n\n        // FIXME Don't clear in each pass in default, let the color overwrite the buffer\n        // FIXME pixels may be discard\n        var clearBit = this.clearDepth ? _gl.DEPTH_BUFFER_BIT : 0;\n        _gl.depthMask(true);\n        if (this.clearColor) {\n            clearBit = clearBit | _gl.COLOR_BUFFER_BIT;\n            _gl.colorMask(true, true, true, true);\n            var cc = this.clearColor;\n            if (Array.isArray(cc)) {\n                _gl.clearColor(cc[0], cc[1], cc[2], cc[3]);\n            }\n        }\n        _gl.clear(clearBit);\n\n        if (this.blendWithPrevious) {\n            // Blend with previous rendered scene in the final output\n            // FIXME Configure blend.\n            // FIXME It will cause screen blink？\n            _gl.enable(_gl.BLEND);\n            this.material.transparent = true;\n        }\n        else {\n            _gl.disable(_gl.BLEND);\n            this.material.transparent = false;\n        }\n\n        this.renderQuad(renderer);\n\n        this.trigger('afterrender', this, renderer);\n\n        if (frameBuffer) {\n            this.unbind(renderer, frameBuffer);\n        }\n    },\n\n    /**\n     * Simply do quad rendering\n     */\n    renderQuad: function (renderer) {\n        mesh.material = this.material;\n        renderer.renderPass([mesh], camera);\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {}\n});\n\nexport default Pass;\n","// TODO Should not derived from mesh?\nimport Mesh from '../Mesh';\nimport CubeGeometry from '../geometry/Cube';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport skyboxEssl from '../shader/source/skybox.glsl.js';\nShader.import(skyboxEssl);\n/**\n * @constructor clay.plugin.Skybox\n *\n * @example\n *     var skyTex = new clay.TextureCube();\n *     skyTex.load({\n *         'px': 'assets/textures/sky/px.jpg',\n *         'nx': 'assets/textures/sky/nx.jpg'\n *         'py': 'assets/textures/sky/py.jpg'\n *         'ny': 'assets/textures/sky/ny.jpg'\n *         'pz': 'assets/textures/sky/pz.jpg'\n *         'nz': 'assets/textures/sky/nz.jpg'\n *     });\n *     var skybox = new clay.plugin.Skybox({\n *         scene: scene\n *     });\n *     skybox.material.set('environmentMap', skyTex);\n */\nvar Skybox = Mesh.extend(function () {\n\n    var skyboxShader = new Shader({\n        vertex: Shader.source('clay.skybox.vertex'),\n        fragment: Shader.source('clay.skybox.fragment')\n    });\n    var material = new Material({\n        shader: skyboxShader,\n        depthMask: false\n    });\n\n    return {\n        /**\n         * @type {clay.Scene}\n         * @memberOf clay.plugin.Skybox.prototype\n         */\n        scene: null,\n\n        geometry: new CubeGeometry(),\n\n        material: material,\n\n        environmentMap: null,\n\n        culling: false\n    };\n}, function () {\n    var scene = this.scene;\n    if (scene) {\n        this.attachScene(scene);\n    }\n    if (this.environmentMap) {\n        this.setEnvironmentMap(this.environmentMap);\n    }\n}, /** @lends clay.plugin.Skybox# */ {\n    /**\n     * Attach the skybox to the scene\n     * @param  {clay.Scene} scene\n     */\n    attachScene: function (scene) {\n        if (this.scene) {\n            this.detachScene();\n        }\n        this.scene = scene;\n        scene.on('beforerender', this._beforeRenderScene, this);\n    },\n    /**\n     * Detach from scene\n     */\n    detachScene: function () {\n        if (this.scene) {\n            this.scene.off('beforerender', this._beforeRenderScene);\n        }\n        this.scene = null;\n    },\n\n    /**\n     * Dispose skybox\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this.detachScene();\n        this.geometry.dispose(renderer);\n    },\n    /**\n     * Set environment map\n     * @param {clay.TextureCube} envMap\n     */\n    setEnvironmentMap: function (envMap) {\n        this.material.set('environmentMap', envMap);\n    },\n    /**\n     * Get environment map\n     * @return {clay.TextureCube}\n     */\n    getEnvironmentMap: function () {\n        return this.material.get('environmentMap');\n    },\n\n    _beforeRenderScene: function(renderer, scene, camera) {\n        this.renderSkybox(renderer, camera);\n    },\n\n    renderSkybox: function (renderer, camera) {\n        this.position.copy(camera.getWorldPosition());\n        this.update();\n        // Don't remember to disable blend\n        renderer.gl.disable(renderer.gl.BLEND);\n        renderer.renderPass([this], camera);\n    }\n});\n\nexport default Skybox;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\nimport PerspectiveCamera from '../camera/Perspective';\nimport FrameBuffer from '../FrameBuffer';\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * Pass rendering scene to a environment cube map\n *\n * @constructor clay.prePass.EnvironmentMap\n * @extends clay.core.Base\n * @example\n *     // Example of car reflection\n *     var envMap = new clay.TextureCube({\n *         width: 256,\n *         height: 256\n *     });\n *     var envPass = new clay.prePass.EnvironmentMap({\n *         position: car.position,\n *         texture: envMap\n *     });\n *     var carBody = car.getChildByName('body');\n *     carBody.material.enableTexture('environmentMap');\n *     carBody.material.set('environmentMap', envMap);\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         envPass.render(renderer, scene);\n *         renderer.render(scene, camera);\n *     });\n */\nvar EnvironmentMapPass = Base.extend(function() {\n    var ret = /** @lends clay.prePass.EnvironmentMap# */ {\n        /**\n         * Camera position\n         * @type {clay.math.Vector3}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        position: new Vector3(),\n        /**\n         * Camera far plane\n         * @type {number}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        far: 1000,\n        /**\n         * Camera near plane\n         * @type {number}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        near: 0.1,\n        /**\n         * Environment cube map\n         * @type {clay.TextureCube}\n         * @memberOf clay.prePass.EnvironmentMap#\n         */\n        texture: null,\n\n        /**\n         * Used if you wan't have shadow in environment map\n         * @type {clay.prePass.ShadowMap}\n         */\n        shadowMapPass: null,\n    };\n    var cameras = ret._cameras = {\n        px: new PerspectiveCamera({ fov: 90 }),\n        nx: new PerspectiveCamera({ fov: 90 }),\n        py: new PerspectiveCamera({ fov: 90 }),\n        ny: new PerspectiveCamera({ fov: 90 }),\n        pz: new PerspectiveCamera({ fov: 90 }),\n        nz: new PerspectiveCamera({ fov: 90 })\n    };\n    cameras.px.lookAt(Vector3.POSITIVE_X, Vector3.NEGATIVE_Y);\n    cameras.nx.lookAt(Vector3.NEGATIVE_X, Vector3.NEGATIVE_Y);\n    cameras.py.lookAt(Vector3.POSITIVE_Y, Vector3.POSITIVE_Z);\n    cameras.ny.lookAt(Vector3.NEGATIVE_Y, Vector3.NEGATIVE_Z);\n    cameras.pz.lookAt(Vector3.POSITIVE_Z, Vector3.NEGATIVE_Y);\n    cameras.nz.lookAt(Vector3.NEGATIVE_Z, Vector3.NEGATIVE_Y);\n\n    // FIXME In windows, use one framebuffer only renders one side of cubemap\n    ret._frameBuffer = new FrameBuffer();\n\n    return ret;\n},  /** @lends clay.prePass.EnvironmentMap# */ {\n    /**\n     * @param  {string} target\n     * @return  {clay.Camera}\n     */\n    getCamera: function (target) {\n        return this._cameras[target];\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Scene} scene\n     * @param  {boolean} [notUpdateScene=false]\n     */\n    render: function(renderer, scene, notUpdateScene) {\n        var _gl = renderer.gl;\n        if (!notUpdateScene) {\n            scene.update();\n        }\n        // Tweak fov\n        // http://the-witness.net/news/2012/02/seamless-cube-map-filtering/\n        var n = this.texture.width;\n        var fov = 2 * Math.atan(n / (n - 0.5)) / Math.PI * 180;\n\n        for (var i = 0; i < 6; i++) {\n            var target = targets[i];\n            var camera = this._cameras[target];\n            Vector3.copy(camera.position, this.position);\n\n            camera.far = this.far;\n            camera.near = this.near;\n            camera.fov = fov;\n\n            if (this.shadowMapPass) {\n                camera.update();\n\n                // update boundingBoxLastFrame\n                var bbox = scene.getBoundingBox();\n                bbox.applyTransform(camera.viewMatrix);\n                scene.viewBoundingBoxLastFrame.copy(bbox);\n\n                this.shadowMapPass.render(renderer, scene, camera, true);\n            }\n            this._frameBuffer.attach(\n                this.texture, _gl.COLOR_ATTACHMENT0,\n                _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i\n            );\n            this._frameBuffer.bind(renderer);\n            renderer.render(scene, camera, true);\n            this._frameBuffer.unbind(renderer);\n        }\n    },\n    /**\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._frameBuffer.dispose(renderer);\n    }\n});\n\nexport default EnvironmentMapPass;\n","import Mesh from '../Mesh';\nimport SphereGeometry from '../geometry/Sphere';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport basicEssl from '../shader/source/basic.glsl.js';\nShader.import(basicEssl);\n/**\n * @constructor clay.plugin.Skydome\n *\n * @example\n *     var skyTex = new clay.Texture2D();\n *     skyTex.load('assets/textures/sky.jpg');\n *     var skydome = new clay.plugin.Skydome({\n *         scene: scene\n *     });\n *     skydome.material.set('diffuseMap', skyTex);\n */\nvar Skydome = Mesh.extend(function () {\n\n    var skydomeShader = new Shader(Shader.source('clay.basic.vertex'), Shader.source('clay.basic.fragment'));\n\n    var material = new Material({\n        shader: skydomeShader,\n        depthMask: false\n    });\n    material.enableTexture('diffuseMap');\n\n    return {\n        /**\n         * @type {clay.Scene}\n         * @memberOf clay.plugin.Skydome#\n         */\n        scene: null,\n\n        geometry: new SphereGeometry({\n            widthSegments: 30,\n            heightSegments: 30,\n            // thetaLength: Math.PI / 2\n        }),\n\n        material: material,\n\n        environmentMap: null,\n\n        culling: false\n    };\n}, function () {\n    var scene = this.scene;\n    if (scene) {\n        this.attachScene(scene);\n    }\n\n    if (this.environmentMap) {\n        this.setEnvironmentMap(this.environmentMap);\n    }\n}, {\n    /**\n     * Attach the skybox to the scene\n     * @param  {clay.Scene} scene\n     * @memberOf clay.plugin.Skydome.prototype\n     */\n    attachScene: function (scene) {\n        if (this.scene) {\n            this.detachScene();\n        }\n        this.scene = scene;\n        scene.on('beforerender', this._beforeRenderScene, this);\n    },\n    /**\n     * Detach from scene\n     * @memberOf clay.plugin.Skydome.prototype\n     */\n    detachScene: function () {\n        if (this.scene) {\n            this.scene.off('beforerender', this._beforeRenderScene);\n        }\n        this.scene = null;\n    },\n\n    _beforeRenderScene: function (renderer, scene, camera) {\n        this.position.copy(camera.getWorldPosition());\n        this.update();\n        renderer.renderPass([this], camera);\n    },\n\n    setEnvironmentMap: function (envMap) {\n        this.material.set('diffuseMap', envMap);\n    },\n\n    getEnvironmentMap: function () {\n        return this.material.get('diffuseMap');\n    },\n\n    dispose: function (renderer) {\n        this.detachScene();\n        this.geometry.dispose(renderer);\n    }\n});\n\nexport default Skydome;\n","import Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\n\n// http://msdn.microsoft.com/en-us/library/windows/desktop/bb943991(v=vs.85).aspx\n// https://github.com/toji/webgl-texture-utils/blob/master/texture-util/dds.js\nvar DDS_MAGIC = 0x20534444;\n\nvar DDSD_CAPS = 0x1;\nvar DDSD_HEIGHT = 0x2;\nvar DDSD_WIDTH = 0x4;\nvar DDSD_PITCH = 0x8;\nvar DDSD_PIXELFORMAT = 0x1000;\nvar DDSD_MIPMAPCOUNT = 0x20000;\nvar DDSD_LINEARSIZE = 0x80000;\nvar DDSD_DEPTH = 0x800000;\n\nvar DDSCAPS_COMPLEX = 0x8;\nvar DDSCAPS_MIPMAP = 0x400000;\nvar DDSCAPS_TEXTURE = 0x1000;\n\nvar DDSCAPS2_CUBEMAP = 0x200;\nvar DDSCAPS2_CUBEMAP_POSITIVEX = 0x400;\nvar DDSCAPS2_CUBEMAP_NEGATIVEX = 0x800;\nvar DDSCAPS2_CUBEMAP_POSITIVEY = 0x1000;\nvar DDSCAPS2_CUBEMAP_NEGATIVEY = 0x2000;\nvar DDSCAPS2_CUBEMAP_POSITIVEZ = 0x4000;\nvar DDSCAPS2_CUBEMAP_NEGATIVEZ = 0x8000;\nvar DDSCAPS2_VOLUME = 0x200000;\n\nvar DDPF_ALPHAPIXELS = 0x1;\nvar DDPF_ALPHA = 0x2;\nvar DDPF_FOURCC = 0x4;\nvar DDPF_RGB = 0x40;\nvar DDPF_YUV = 0x200;\nvar DDPF_LUMINANCE = 0x20000;\n\nfunction fourCCToInt32(value) {\n    return value.charCodeAt(0) +\n        (value.charCodeAt(1) << 8) +\n        (value.charCodeAt(2) << 16) +\n        (value.charCodeAt(3) << 24);\n}\n\nfunction int32ToFourCC(value) {\n    return String.fromCharCode(\n        value & 0xff,\n        (value >> 8) & 0xff,\n        (value >> 16) & 0xff,\n        (value >> 24) & 0xff\n    );\n}\n\nvar headerLengthInt = 31; // The header length in 32 bit ints\n\nvar FOURCC_DXT1 = fourCCToInt32('DXT1');\nvar FOURCC_DXT3 = fourCCToInt32('DXT3');\nvar FOURCC_DXT5 = fourCCToInt32('DXT5');\n    // Offsets into the header array\nvar off_magic = 0;\n\nvar off_size = 1;\nvar off_flags = 2;\nvar off_height = 3;\nvar off_width = 4;\n\nvar off_mipmapCount = 7;\n\nvar off_pfFlags = 20;\nvar off_pfFourCC = 21;\n\nvar off_caps = 27;\nvar off_caps2 = 28;\nvar off_caps3 = 29;\nvar off_caps4 = 30;\n\nvar ret = {\n    parse: function(arrayBuffer, out) {\n        var header = new Int32Array(arrayBuffer, 0, headerLengthInt);\n        if (header[off_magic] !== DDS_MAGIC) {\n            return null;\n        }\n        if (!header(off_pfFlags) & DDPF_FOURCC) {\n            return null;\n        }\n\n        var fourCC = header(off_pfFourCC);\n        var width = header[off_width];\n        var height = header[off_height];\n        var isCubeMap = header[off_caps2] & DDSCAPS2_CUBEMAP;\n        var hasMipmap = header[off_flags] & DDSD_MIPMAPCOUNT;\n        var blockBytes, internalFormat;\n        switch(fourCC) {\n            case FOURCC_DXT1:\n                blockBytes = 8;\n                internalFormat = Texture.COMPRESSED_RGB_S3TC_DXT1_EXT;\n                break;\n            case FOURCC_DXT3:\n                blockBytes = 16;\n                internalFormat = Texture.COMPRESSED_RGBA_S3TC_DXT3_EXT;\n                break;\n            case FOURCC_DXT5:\n                blockBytes = 16;\n                internalFormat = Texture.COMPRESSED_RGBA_S3TC_DXT5_EXT;\n                break;\n            default:\n                return null;\n        }\n        var dataOffset = header[off_size] + 4;\n        // TODO: Suppose all face are existed\n        var faceNumber = isCubeMap ? 6 : 1;\n        var mipmapCount = 1;\n        if (hasMipmap) {\n            mipmapCount = Math.max(1, header[off_mipmapCount]);\n        }\n\n        var textures = [];\n        for (var f = 0; f < faceNumber; f++) {\n            var _width = width;\n            var _height = height;\n            textures[f] = new Texture2D({\n                width : _width,\n                height : _height,\n                format : internalFormat\n            });\n            var mipmaps = [];\n            for (var i = 0; i < mipmapCount; i++) {\n                var dataLength = Math.max(4, _width) / 4 * Math.max(4, _height) / 4 * blockBytes;\n                var byteArray = new Uint8Array(arrayBuffer, dataOffset, dataLength);\n\n                dataOffset += dataLength;\n                _width *= 0.5;\n                _height *= 0.5;\n                mipmaps[i] = byteArray;\n            }\n            textures[f].pixels = mipmaps[0];\n            if (hasMipmap) {\n                textures[f].mipmaps = mipmaps;\n            }\n        }\n        // TODO\n        // return isCubeMap ? textures : textures[0];\n        if (out) {\n            out.width = textures[0].width;\n            out.height = textures[0].height;\n            out.format = textures[0].format;\n            out.pixels = textures[0].pixels;\n            out.mipmaps = textures[0].mipmaps;\n        }\n        else {\n            return textures[0];\n        }\n    }\n};\n\nexport default ret;\n","import Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nvar toChar = String.fromCharCode;\n\nvar MINELEN = 8;\nvar MAXELEN = 0x7fff;\nfunction rgbe2float(rgbe, buffer, offset, exposure) {\n    if (rgbe[3] > 0) {\n        var f = Math.pow(2.0, rgbe[3] - 128 - 8 + exposure);\n        buffer[offset + 0] = rgbe[0] * f;\n        buffer[offset + 1] = rgbe[1] * f;\n        buffer[offset + 2] = rgbe[2] * f;\n    }\n    else {\n        buffer[offset + 0] = 0;\n        buffer[offset + 1] = 0;\n        buffer[offset + 2] = 0;\n    }\n    buffer[offset + 3] = 1.0;\n    return buffer;\n}\n\nfunction uint82string(array, offset, size) {\n    var str = '';\n    for (var i = offset; i < size; i++) {\n        str += toChar(array[i]);\n    }\n    return str;\n}\n\nfunction copyrgbe(s, t) {\n    t[0] = s[0];\n    t[1] = s[1];\n    t[2] = s[2];\n    t[3] = s[3];\n}\n\n// TODO : check\nfunction oldReadColors(scan, buffer, offset, xmax) {\n    var rshift = 0, x = 0, len = xmax;\n    while (len > 0) {\n        scan[x][0] = buffer[offset++];\n        scan[x][1] = buffer[offset++];\n        scan[x][2] = buffer[offset++];\n        scan[x][3] = buffer[offset++];\n        if (scan[x][0] === 1 && scan[x][1] === 1 && scan[x][2] === 1) {\n            // exp is count of repeated pixels\n            for (var i = (scan[x][3] << rshift) >>> 0; i > 0; i--) {\n                copyrgbe(scan[x-1], scan[x]);\n                x++;\n                len--;\n            }\n            rshift += 8;\n        } else {\n            x++;\n            len--;\n            rshift = 0;\n        }\n    }\n    return offset;\n}\n\nfunction readColors(scan, buffer, offset, xmax) {\n    if ((xmax < MINELEN) | (xmax > MAXELEN)) {\n        return oldReadColors(scan, buffer, offset, xmax);\n    }\n    var i = buffer[offset++];\n    if (i != 2) {\n        return oldReadColors(scan, buffer, offset - 1, xmax);\n    }\n    scan[0][1] = buffer[offset++];\n    scan[0][2] = buffer[offset++];\n\n    i = buffer[offset++];\n    if ((((scan[0][2] << 8) >>> 0) | i) >>> 0 !== xmax) {\n        return null;\n    }\n    for (var i = 0; i < 4; i++) {\n        for (var x = 0; x < xmax;) {\n            var code = buffer[offset++];\n            if (code > 128) {\n                code = (code & 127) >>> 0;\n                var val = buffer[offset++];\n                while (code--) {\n                    scan[x++][i] = val;\n                }\n            } else {\n                while (code--) {\n                    scan[x++][i] = buffer[offset++];\n                }\n            }\n        }\n    }\n    return offset;\n}\n\n\nvar ret = {\n    // http://www.graphics.cornell.edu/~bjw/rgbe.html\n    // Blender source\n    // http://radsite.lbl.gov/radiance/refer/Notes/picture_format.html\n    parseRGBE: function(arrayBuffer, texture, exposure) {\n        if (exposure == null) {\n            exposure = 0;\n        }\n        var data = new Uint8Array(arrayBuffer);\n        var size = data.length;\n        if (uint82string(data, 0, 2) !== '#?') {\n            return;\n        }\n        // find empty line, next line is resolution info\n        for (var i = 2; i < size; i++) {\n            if (toChar(data[i]) === '\\n' && toChar(data[i+1]) === '\\n') {\n                break;\n            }\n        }\n        if (i >= size) { // not found\n            return;\n        }\n        // find resolution info line\n        i += 2;\n        var str = '';\n        for (; i < size; i++) {\n            var _char = toChar(data[i]);\n            if (_char === '\\n') {\n                break;\n            }\n            str += _char;\n        }\n        // -Y M +X N\n        var tmp = str.split(' ');\n        var height = parseInt(tmp[1]);\n        var width = parseInt(tmp[3]);\n        if (!width || !height) {\n            return;\n        }\n\n        // read and decode actual data\n        var offset = i+1;\n        var scanline = [];\n        // memzero\n        for (var x = 0; x < width; x++) {\n            scanline[x] = [];\n            for (var j = 0; j < 4; j++) {\n                scanline[x][j] = 0;\n            }\n        }\n        var pixels = new Float32Array(width * height * 4);\n        var offset2 = 0;\n        for (var y = 0; y < height; y++) {\n            var offset = readColors(scanline, data, offset, width);\n            if (!offset) {\n                return null;\n            }\n            for (var x = 0; x < width; x++) {\n                rgbe2float(scanline[x], pixels, offset2, exposure);\n                offset2 += 4;\n            }\n        }\n\n        if (!texture) {\n            texture = new Texture2D();\n        }\n        texture.width = width;\n        texture.height = height;\n        texture.pixels = pixels;\n        // HALF_FLOAT can't use Float32Array\n        texture.type = Texture.FLOAT;\n        return texture;\n    },\n\n    parseRGBEFromPNG: function(png) {\n\n    }\n};\n\nexport default ret;\n","import Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport request from '../core/request';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport Skydome from '../plugin/Skydome';\nimport Scene from '../Scene';\n\nimport dds from './dds';\nimport hdr from './hdr';\n\n/**\n * @alias clay.util.texture\n */\nvar textureUtil = {\n    /**\n     * @param  {string|object} path\n     * @param  {object} [option]\n     * @param  {Function} [onsuccess]\n     * @param  {Function} [onerror]\n     * @return {clay.Texture}\n     */\n    loadTexture: function (path, option, onsuccess, onerror) {\n        var texture;\n        if (typeof(option) === 'function') {\n            onsuccess = option;\n            onerror = onsuccess;\n            option = {};\n        }\n        else {\n            option = option || {};\n        }\n        if (typeof(path) === 'string') {\n            if (path.match(/.hdr$/) || option.fileType === 'hdr') {\n                texture = new Texture2D({\n                    width: 0,\n                    height: 0\n                });\n                textureUtil._fetchTexture(\n                    path,\n                    function (data) {\n                        hdr.parseRGBE(data, texture, option.exposure);\n                        texture.dirty();\n                        onsuccess && onsuccess(texture);\n                    },\n                    onerror\n                );\n                return texture;\n            }\n            else if (path.match(/.dds$/) || option.fileType === 'dds') {\n                texture = new Texture2D({\n                    width: 0,\n                    height: 0\n                });\n                textureUtil._fetchTexture(\n                    path,\n                    function (data) {\n                        dds.parse(data, texture);\n                        texture.dirty();\n                        onsuccess && onsuccess(texture);\n                    },\n                    onerror\n                );\n            }\n            else {\n                texture = new Texture2D();\n                texture.load(path);\n                texture.success(onsuccess);\n                texture.error(onerror);\n            }\n        }\n        else if (typeof(path) == 'object' && typeof(path.px) !== 'undefined') {\n            var texture = new TextureCube();\n            texture.load(path);\n            texture.success(onsuccess);\n            texture.error(onerror);\n        }\n        return texture;\n    },\n\n    /**\n     * Load a panorama texture and render it to a cube map\n     * @param  {clay.Renderer} renderer\n     * @param  {string} path\n     * @param  {clay.TextureCube} cubeMap\n     * @param  {object} [option]\n     * @param  {boolean} [option.encodeRGBM]\n     * @param  {number} [option.exposure]\n     * @param  {Function} [onsuccess]\n     * @param  {Function} [onerror]\n     */\n    loadPanorama: function (renderer, path, cubeMap, option, onsuccess, onerror) {\n        var self = this;\n\n        if (typeof(option) === 'function') {\n            onsuccess = option;\n            onerror = onsuccess;\n            option = {};\n        }\n        else {\n            option = option || {};\n        }\n\n        textureUtil.loadTexture(path, option, function (texture) {\n            // PENDING\n            texture.flipY = option.flipY || false;\n            self.panoramaToCubeMap(renderer, texture, cubeMap, option);\n            texture.dispose(renderer);\n            onsuccess && onsuccess(cubeMap);\n        }, onerror);\n    },\n\n    /**\n     * Render a panorama texture to a cube map\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Texture2D} panoramaMap\n     * @param  {clay.TextureCube} cubeMap\n     * @param  {Object} option\n     * @param  {boolean} [option.encodeRGBM]\n     */\n    panoramaToCubeMap: function (renderer, panoramaMap, cubeMap, option) {\n        var environmentMapPass = new EnvironmentMapPass();\n        var skydome = new Skydome({\n            scene: new Scene()\n        });\n        skydome.material.set('diffuseMap', panoramaMap);\n\n        option = option || {};\n        if (option.encodeRGBM) {\n            skydome.material.define('fragment', 'RGBM_ENCODE');\n        }\n\n        environmentMapPass.texture = cubeMap;\n        environmentMapPass.render(renderer, skydome.scene);\n        environmentMapPass.texture = null;\n        environmentMapPass.dispose(renderer);\n        return cubeMap;\n    },\n\n    /**\n     * Convert height map to normal map\n     * @param {HTMLImageElement|HTMLCanvasElement} image\n     * @param {boolean} [checkBump=false]\n     * @return {HTMLCanvasElement}\n     */\n    heightToNormal: function (image, checkBump) {\n        var canvas = document.createElement('canvas');\n        var width = canvas.width = image.width;\n        var height = canvas.height = image.height;\n        var ctx = canvas.getContext('2d');\n        ctx.drawImage(image, 0, 0, width, height);\n        checkBump = checkBump || false;\n        var srcData = ctx.getImageData(0, 0, width, height);\n        var dstData = ctx.createImageData(width, height);\n        for (var i = 0; i < srcData.data.length; i += 4) {\n            if (checkBump) {\n                var r = srcData.data[i];\n                var g = srcData.data[i + 1];\n                var b = srcData.data[i + 2];\n                var diff = Math.abs(r - g) + Math.abs(g - b);\n                if (diff > 20) {\n                    console.warn('Given image is not a height map');\n                    return image;\n                }\n            }\n            // Modified from http://mrdoob.com/lab/javascript/height2normal/\n            var x1, y1, x2, y2;\n            if (i % (width * 4) === 0) {\n                // left edge\n                x1 = srcData.data[i];\n                x2 = srcData.data[i + 4];\n            }\n            else if (i % (width * 4) === (width - 1) * 4) {\n                // right edge\n                x1 = srcData.data[i - 4];\n                x2 = srcData.data[i];\n            }\n            else {\n                x1 = srcData.data[i - 4];\n                x2 = srcData.data[i + 4];\n            }\n\n            if (i < width * 4) {\n                // top edge\n                y1 = srcData.data[i];\n                y2 = srcData.data[i + width * 4];\n            }\n            else if (i > width * (height - 1) * 4) {\n                // bottom edge\n                y1 = srcData.data[i - width * 4];\n                y2 = srcData.data[i];\n            }\n            else {\n                y1 = srcData.data[i - width * 4];\n                y2 = srcData.data[i + width * 4];\n            }\n\n            dstData.data[i] = (x1 - x2) + 127;\n            dstData.data[i + 1] = (y1 - y2) + 127;\n            dstData.data[i + 2] = 255;\n            dstData.data[i + 3] = 255;\n        }\n        ctx.putImageData(dstData, 0, 0);\n        return canvas;\n    },\n\n    /**\n     * Convert height map to normal map\n     * @param {HTMLImageElement|HTMLCanvasElement} image\n     * @param {boolean} [checkBump=false]\n     * @param {number} [threshold=20]\n     * @return {HTMLCanvasElement}\n     */\n    isHeightImage: function (img, downScaleSize, threshold) {\n        if (!img || !img.width || !img.height) {\n            return false;\n        }\n\n        var canvas = document.createElement('canvas');\n        var ctx = canvas.getContext('2d');\n        var size = downScaleSize || 32;\n        threshold = threshold || 20;\n        canvas.width = canvas.height = size;\n        ctx.drawImage(img, 0, 0, size, size);\n        var srcData = ctx.getImageData(0, 0, size, size);\n        for (var i = 0; i < srcData.data.length; i += 4) {\n            var r = srcData.data[i];\n            var g = srcData.data[i + 1];\n            var b = srcData.data[i + 2];\n            var diff = Math.abs(r - g) + Math.abs(g - b);\n            if (diff > threshold) {\n                return false;\n            }\n        }\n        return true;\n    },\n\n    _fetchTexture: function (path, onsuccess, onerror) {\n        request.get({\n            url: path,\n            responseType: 'arraybuffer',\n            onload: onsuccess,\n            onerror: onerror\n        });\n    },\n\n    /**\n     * Create a chessboard texture\n     * @param  {number} [size]\n     * @param  {number} [unitSize]\n     * @param  {string} [color1]\n     * @param  {string} [color2]\n     * @return {clay.Texture2D}\n     */\n    createChessboard: function (size, unitSize, color1, color2) {\n        size = size || 512;\n        unitSize = unitSize || 64;\n        color1 = color1 || 'black';\n        color2 = color2 || 'white';\n\n        var repeat = Math.ceil(size / unitSize);\n\n        var canvas = document.createElement('canvas');\n        canvas.width = size;\n        canvas.height = size;\n        var ctx = canvas.getContext('2d');\n        ctx.fillStyle = color2;\n        ctx.fillRect(0, 0, size, size);\n\n        ctx.fillStyle = color1;\n        for (var i = 0; i < repeat; i++) {\n            for (var j = 0; j < repeat; j++) {\n                var isFill = j % 2 ? (i % 2) : (i % 2 - 1);\n                if (isFill) {\n                    ctx.fillRect(i * unitSize, j * unitSize, unitSize, unitSize);\n                }\n            }\n        }\n\n        var texture = new Texture2D({\n            image: canvas,\n            anisotropic: 8\n        });\n\n        return texture;\n    },\n\n    /**\n     * Create a blank pure color 1x1 texture\n     * @param  {string} color\n     * @return {clay.Texture2D}\n     */\n    createBlank: function (color) {\n        var canvas = document.createElement('canvas');\n        canvas.width = 1;\n        canvas.height = 1;\n        var ctx = canvas.getContext('2d');\n        ctx.fillStyle = color;\n        ctx.fillRect(0, 0, 1, 1);\n\n        var texture = new Texture2D({\n            image: canvas\n        });\n\n        return texture;\n    }\n};\n\nexport default textureUtil;\n","export default \"#define SAMPLE_NUMBER 1024\\n#define PI 3.14159265358979\\nuniform sampler2D normalDistribution;\\nuniform vec2 viewportSize : [512, 256];\\nconst vec3 N = vec3(0.0, 0.0, 1.0);\\nconst float fSampleNumber = float(SAMPLE_NUMBER);\\nvec3 importanceSampleNormal(float i, float roughness, vec3 N) {\\n    vec3 H = texture2D(normalDistribution, vec2(roughness, i)).rgb;\\n    vec3 upVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0);\\n    vec3 tangentX = normalize(cross(upVector, N));\\n    vec3 tangentY = cross(N, tangentX);\\n    return tangentX * H.x + tangentY * H.y + N * H.z;\\n}\\nfloat G_Smith(float roughness, float NoV, float NoL) {\\n    float k = roughness * roughness / 2.0;\\n    float G1V = NoV / (NoV * (1.0 - k) + k);\\n    float G1L = NoL / (NoL * (1.0 - k) + k);\\n    return G1L * G1V;\\n}\\nvoid main() {\\n    vec2 uv = gl_FragCoord.xy / viewportSize;\\n    float NoV = uv.x;\\n    float roughness = uv.y;\\n    vec3 V;\\n    V.x = sqrt(1.0 - NoV * NoV);\\n    V.y = 0.0;\\n    V.z = NoV;\\n    float A = 0.0;\\n    float B = 0.0;\\n    for (int i = 0; i < SAMPLE_NUMBER; i++) {\\n        vec3 H = importanceSampleNormal(float(i) / fSampleNumber, roughness, N);\\n        vec3 L = reflect(-V, H);\\n        float NoL = clamp(L.z, 0.0, 1.0);\\n        float NoH = clamp(H.z, 0.0, 1.0);\\n        float VoH = clamp(dot(V, H), 0.0, 1.0);\\n        if (NoL > 0.0) {\\n            float G = G_Smith(roughness, NoV, NoL);\\n            float G_Vis = G * VoH / (NoH * NoV);\\n            float Fc = pow(1.0 - VoH, 5.0);\\n            A += (1.0 - Fc) * G_Vis;\\n            B += Fc * G_Vis;\\n        }\\n    }\\n    gl_FragColor = vec4(vec2(A, B) / fSampleNumber, 0.0, 1.0);\\n}\\n\";\n","export default \"#define SAMPLE_NUMBER 1024\\n#define PI 3.14159265358979\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform samplerCube environmentMap;\\nuniform sampler2D normalDistribution;\\nuniform float roughness : 0.5;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_WorldPosition;\\nconst float fSampleNumber = float(SAMPLE_NUMBER);\\n@import clay.util.rgbm\\nvec3 importanceSampleNormal(float i, float roughness, vec3 N) {\\n    vec3 H = texture2D(normalDistribution, vec2(roughness, i)).rgb;\\n    vec3 upVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0);\\n    vec3 tangentX = normalize(cross(upVector, N));\\n    vec3 tangentY = cross(N, tangentX);\\n    return tangentX * H.x + tangentY * H.y + N * H.z;\\n}\\nvoid main() {\\n    vec3 eyePos = viewInverse[3].xyz;\\n    vec3 V = normalize(v_WorldPosition - eyePos);\\n    vec3 N = V;\\n    vec3 R = V;\\n    vec3 prefilteredColor = vec3(0.0);\\n    float totalWeight = 0.0;\\n    for (int i = 0; i < SAMPLE_NUMBER; i++) {\\n        vec3 H = importanceSampleNormal(float(i) / fSampleNumber, roughness, N);\\n        vec3 L = reflect(-V, H);\\n        float NoL = clamp(dot(N, L), 0.0, 1.0);\\n        if (NoL > 0.0) {\\n            prefilteredColor += decodeHDR(textureCube(environmentMap, L)).rgb * NoL;\\n            totalWeight += NoL;\\n        }\\n    }\\n    gl_FragColor = encodeHDR(vec4(prefilteredColor / totalWeight, 1.0));\\n}\\n\";\n","// Cubemap prefilter utility\n// http://www.unrealengine.com/files/downloads/2013SiggraphPresentationsNotes.pdf\n// http://http.developer.nvidia.com/GPUGems3/gpugems3_ch20.html\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport Texture from '../Texture';\nimport FrameBuffer from '../FrameBuffer';\nimport Pass from '../compositor/Pass';\nimport Material from '../Material';\nimport Shader from '../Shader';\nimport Skybox from '../plugin/Skybox';\nimport Scene from '../Scene';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport vendor from '../core/vendor';\nimport textureUtil from './texture';\n\nimport integrateBRDFShaderCode from './shader/integrateBRDF.glsl.js';\nimport prefilterFragCode from './shader/prefilter.glsl.js';\n\nvar cubemapUtil = {};\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n/**\n * @name clay.util.cubemap.prefilterEnvironmentMap\n * @param  {clay.Renderer} renderer\n * @param  {clay.Texture} envMap\n * @param  {Object} [textureOpts]\n * @param  {number} [textureOpts.width=64]\n * @param  {number} [textureOpts.height=64]\n * @param  {number} [textureOpts.type]\n * @param  {boolean} [textureOpts.encodeRGBM=false]\n * @param  {boolean} [textureOpts.decodeRGBM=false]\n * @param  {clay.Texture2D} [normalDistribution]\n * @param  {clay.Texture2D} [brdfLookup]\n */\ncubemapUtil.prefilterEnvironmentMap = function (\n    renderer, envMap, textureOpts, normalDistribution, brdfLookup\n) {\n    // Not create other renderer, it is easy having issue of cross reference of resources like framebuffer\n    // PENDING preserveDrawingBuffer?\n    if (!brdfLookup || !normalDistribution) {\n        normalDistribution = cubemapUtil.generateNormalDistribution();\n        brdfLookup = cubemapUtil.integrateBRDF(renderer, normalDistribution);\n    }\n    textureOpts = textureOpts || {};\n\n    var width = textureOpts.width || 64;\n    var height = textureOpts.height || 64;\n\n    var textureType = textureOpts.type || envMap.type;\n\n    // Use same type with given envMap\n    var prefilteredCubeMap = new TextureCube({\n        width: width,\n        height: height,\n        type: textureType,\n        flipY: false,\n        mipmaps: []\n    });\n\n    if (!prefilteredCubeMap.isPowerOfTwo()) {\n        console.warn('Width and height must be power of two to enable mipmap.');\n    }\n\n    var size = Math.min(width, height);\n    var mipmapNum = Math.log(size) / Math.log(2) + 1;\n\n    var prefilterMaterial = new Material({\n        shader: new Shader({\n            vertex: Shader.source('clay.skybox.vertex'),\n            fragment: prefilterFragCode\n        })\n    });\n    prefilterMaterial.set('normalDistribution', normalDistribution);\n\n    textureOpts.encodeRGBM && prefilterMaterial.define('fragment', 'RGBM_ENCODE');\n    textureOpts.decodeRGBM && prefilterMaterial.define('fragment', 'RGBM_DECODE');\n\n    var dummyScene = new Scene();\n    var skyEnv;\n\n    if (envMap instanceof Texture2D) {\n        // Convert panorama to cubemap\n        var envCubemap = new TextureCube({\n            width: width,\n            height: height,\n            // FIXME FLOAT type will cause GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT error on iOS\n            type: textureType === Texture.FLOAT ?\n                    Texture.HALF_FLOAT : textureType\n        });\n        textureUtil.panoramaToCubeMap(renderer, envMap, envCubemap, {\n            // PENDING encodeRGBM so it can be decoded as RGBM\n            encodeRGBM: textureOpts.decodeRGBM\n        });\n        envMap = envCubemap;\n    }\n    skyEnv = new Skybox({\n        scene: dummyScene,\n        material: prefilterMaterial\n    });\n    skyEnv.material.set('environmentMap', envMap);\n\n    var envMapPass = new EnvironmentMapPass({\n        texture: prefilteredCubeMap\n    });\n\n    // Force to be UNSIGNED_BYTE\n    if (textureOpts.encodeRGBM) {\n        textureType = prefilteredCubeMap.type = Texture.UNSIGNED_BYTE;\n    }\n\n    var renderTargetTmp = new Texture2D({\n        width: width,\n        height: height,\n        type: textureType\n    });\n    var frameBuffer = new FrameBuffer({\n        depthBuffer: false\n    });\n    var ArrayCtor = vendor[textureType === Texture.UNSIGNED_BYTE ? 'Uint8Array' : 'Float32Array'];\n    for (var i = 0; i < mipmapNum; i++) {\n        prefilteredCubeMap.mipmaps[i] = {\n            pixels: {}\n        };\n        skyEnv.material.set('roughness', i / (targets.length - 1));\n\n        // Tweak fov\n        // http://the-witness.net/news/2012/02/seamless-cube-map-filtering/\n        var n = renderTargetTmp.width;\n        var fov = 2 * Math.atan(n / (n - 0.5)) / Math.PI * 180;\n\n        for (var j = 0; j < targets.length; j++) {\n            var pixels = new ArrayCtor(renderTargetTmp.width * renderTargetTmp.height * 4);\n            frameBuffer.attach(renderTargetTmp);\n            frameBuffer.bind(renderer);\n\n            var camera = envMapPass.getCamera(targets[j]);\n            camera.fov = fov;\n            renderer.render(dummyScene, camera);\n            renderer.gl.readPixels(\n                0, 0, renderTargetTmp.width, renderTargetTmp.height,\n                Texture.RGBA, textureType, pixels\n            );\n\n            // var canvas = document.createElement('canvas');\n            // var ctx = canvas.getContext('2d');\n            // canvas.width = renderTargetTmp.width;\n            // canvas.height = renderTargetTmp.height;\n            // var imageData = ctx.createImageData(renderTargetTmp.width, renderTargetTmp.height);\n            // for (var k = 0; k < pixels.length; k++) {\n            //     imageData.data[k] = pixels[k];\n            // }\n            // ctx.putImageData(imageData, 0, 0);\n            // document.body.appendChild(canvas);\n\n            frameBuffer.unbind(renderer);\n            prefilteredCubeMap.mipmaps[i].pixels[targets[j]] = pixels;\n        }\n\n        renderTargetTmp.width /= 2;\n        renderTargetTmp.height /= 2;\n        renderTargetTmp.dirty();\n    }\n\n    frameBuffer.dispose(renderer);\n    renderTargetTmp.dispose(renderer);\n    skyEnv.dispose(renderer);\n    // Remove gpu resource allucated in renderer\n    normalDistribution.dispose(renderer);\n\n    // renderer.dispose();\n\n    return {\n        environmentMap: prefilteredCubeMap,\n        brdfLookup: brdfLookup,\n        normalDistribution: normalDistribution,\n        maxMipmapLevel: mipmapNum\n    };\n};\n\ncubemapUtil.integrateBRDF = function (renderer, normalDistribution) {\n    normalDistribution = normalDistribution || cubemapUtil.generateNormalDistribution();\n    var framebuffer = new FrameBuffer({\n        depthBuffer: false\n    });\n    var pass = new Pass({\n        fragment: integrateBRDFShaderCode\n    });\n\n    var texture = new Texture2D({\n        width: 512,\n        height: 256,\n        type: Texture.HALF_FLOAT,\n        minFilter: Texture.NEAREST,\n        magFilter: Texture.NEAREST,\n        useMipmap: false\n    });\n    pass.setUniform('normalDistribution', normalDistribution);\n    pass.setUniform('viewportSize', [512, 256]);\n    pass.attachOutput(texture);\n    pass.render(renderer, framebuffer);\n\n    // FIXME Only chrome and firefox can readPixels with float type.\n    // framebuffer.bind(renderer);\n    // var pixels = new Float32Array(512 * 256 * 4);\n    // renderer.gl.readPixels(\n    //     0, 0, texture.width, texture.height,\n    //     Texture.RGBA, Texture.FLOAT, pixels\n    // );\n    // texture.pixels = pixels;\n    // texture.flipY = false;\n    // texture.dirty();\n    // framebuffer.unbind(renderer);\n\n    framebuffer.dispose(renderer);\n\n    return texture;\n};\n\ncubemapUtil.generateNormalDistribution = function (roughnessLevels, sampleSize) {\n\n    // http://holger.dammertz.org/stuff/notes_HammersleyOnHemisphere.html\n    // GLSL not support bit operation, use lookup instead\n    // V -> i / N, U -> roughness\n    var roughnessLevels = roughnessLevels || 256;\n    var sampleSize = sampleSize || 1024;\n\n    var normalDistribution = new Texture2D({\n        width: roughnessLevels,\n        height: sampleSize,\n        type: Texture.FLOAT,\n        minFilter: Texture.NEAREST,\n        magFilter: Texture.NEAREST,\n        useMipmap: false\n    });\n    var pixels = new Float32Array(sampleSize * roughnessLevels * 4);\n    for (var i = 0; i < sampleSize; i++) {\n        var x = i / sampleSize;\n        // http://holger.dammertz.org/stuff/notes_HammersleyOnHemisphere.html\n        // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators\n        // http://stackoverflow.com/questions/1908492/unsigned-integer-in-javascript\n        // http://stackoverflow.com/questions/1822350/what-is-the-javascript-operator-and-how-do-you-use-it\n        var y = (i << 16 | i >>> 16) >>> 0;\n        y = ((y & 1431655765) << 1 | (y & 2863311530) >>> 1) >>> 0;\n        y = ((y & 858993459) << 2 | (y & 3435973836) >>> 2) >>> 0;\n        y = ((y & 252645135) << 4 | (y & 4042322160) >>> 4) >>> 0;\n        y = (((y & 16711935) << 8 | (y & 4278255360) >>> 8) >>> 0) / 4294967296;\n\n        for (var j = 0; j < roughnessLevels; j++) {\n            var roughness = j / roughnessLevels;\n            var a = roughness * roughness;\n            var phi = 2.0 * Math.PI * x;\n            // CDF\n            var cosTheta = Math.sqrt((1 - y) / (1 + (a * a - 1.0) * y));\n            var sinTheta = Math.sqrt(1.0 - cosTheta * cosTheta);\n            var offset = (i * roughnessLevels + j) * 4;\n            pixels[offset] = sinTheta * Math.cos(phi);\n            pixels[offset + 1] = sinTheta * Math.sin(phi);\n            pixels[offset + 2] = cosTheta;\n            pixels[offset + 3] = 1.0;\n        }\n    }\n    normalDistribution.pixels = pixels;\n\n    return normalDistribution;\n};\n\nexport default cubemapUtil;\n","// https://docs.unrealengine.com/latest/INT/Engine/Rendering/LightingAndShadows/AmbientCubemap/\nimport Light from '../Light';\nimport cubemapUtil from '../util/cubemap';\n\n/**\n * Ambient cubemap light provides specular parts of Image Based Lighting.\n * Which is a basic requirement for Physically Based Rendering\n * @constructor clay.light.AmbientCubemap\n * @extends clay.Light\n */\nvar AmbientCubemapLight = Light.extend({\n\n    /**\n     * @type {clay.TextureCube}\n     * @memberOf clay.light.AmbientCubemap#\n     */\n    cubemap: null,\n\n    // TODO\n    // range: 100,\n\n    castShadow: false,\n\n    _normalDistribution: null,\n    _brdfLookup: null\n\n}, /** @lends clay.light.AmbientCubemap# */ {\n\n    type: 'AMBIENT_CUBEMAP_LIGHT',\n\n    /**\n     * Do prefitering the cubemap\n     * @param {clay.Renderer} renderer\n     * @param {number} [size=32]\n     */\n    prefilter: function (renderer, size) {\n        if (!this._brdfLookup) {\n            this._normalDistribution = cubemapUtil.generateNormalDistribution();\n            this._brdfLookup = cubemapUtil.integrateBRDF(renderer, this._normalDistribution);\n        }\n        var cubemap = this.cubemap;\n        if (cubemap.__prefiltered) {\n            return;\n        }\n\n        var result = cubemapUtil.prefilterEnvironmentMap(\n            renderer, cubemap, {\n                encodeRGBM: true,\n                width: size,\n                height: size\n            }, this._normalDistribution, this._brdfLookup\n        );\n        this.cubemap = result.environmentMap;\n        this.cubemap.__prefiltered = true;\n\n        cubemap.dispose(renderer);\n    },\n\n    uniformTemplates: {\n        ambientCubemapLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        },\n\n        ambientCubemapLightCubemap: {\n            type: 't',\n            value: function (instance) {\n                return instance.cubemap;\n            }\n        },\n\n        ambientCubemapLightBRDFLookup: {\n            type: 't',\n            value: function (instance) {\n                return instance._brdfLookup;\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.AmbientCubemap}\n     * @memberOf clay.light.AmbientCubemap.prototype\n     */\n});\n\nexport default AmbientCubemapLight;\n","import Light from '../Light';\nimport vendor from '../core/vendor';\n\n/**\n * Spherical Harmonic Ambient Light\n * @constructor clay.light.AmbientSH\n * @extends clay.Light\n */\nvar AmbientSHLight = Light.extend({\n\n    castShadow: false,\n\n    /**\n     * Spherical Harmonic Coefficients\n     * @type {Array.<number>}\n     * @memberOf clay.light.AmbientSH#\n     */\n    coefficients: [],\n\n}, function () {\n    this._coefficientsTmpArr = new vendor.Float32Array(9 * 3);\n}, {\n\n    type: 'AMBIENT_SH_LIGHT',\n\n    uniformTemplates: {\n        ambientSHLightColor: {\n            type: '3f',\n            value: function (instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0] * intensity, color[1] * intensity, color[2] * intensity];\n            }\n        },\n\n        ambientSHLightCoefficients: {\n            type: '3f',\n            value: function (instance) {\n                var coefficientsTmpArr = instance._coefficientsTmpArr;\n                for (var i = 0; i < instance.coefficients.length; i++) {\n                    coefficientsTmpArr[i] = instance.coefficients[i];\n                }\n                return coefficientsTmpArr;\n            }\n        }\n    }\n    /**\n     * @function\n     * @name clone\n     * @return {clay.light.Ambient}\n     * @memberOf clay.light.Ambient.prototype\n     */\n});\n\nexport default AmbientSHLight;\n","import Texture2D from '../Texture2D';\nimport glenum from '../core/glenum';\nimport util from '../core/util';\n\nvar TexturePool = function () {\n\n    this._pool = {};\n\n    this._allocatedTextures = [];\n};\n\nTexturePool.prototype = {\n\n    constructor: TexturePool,\n\n    get: function (parameters) {\n        var key = generateKey(parameters);\n        if (!this._pool.hasOwnProperty(key)) {\n            this._pool[key] = [];\n        }\n        var list = this._pool[key];\n        if (!list.length) {\n            var texture = new Texture2D(parameters);\n            this._allocatedTextures.push(texture);\n            return texture;\n        }\n        return list.pop();\n    },\n\n    put: function (texture) {\n        var key = generateKey(texture);\n        if (!this._pool.hasOwnProperty(key)) {\n            this._pool[key] = [];\n        }\n        var list = this._pool[key];\n        list.push(texture);\n    },\n\n    clear: function (renderer) {\n        for (var i = 0; i < this._allocatedTextures.length; i++) {\n            this._allocatedTextures[i].dispose(renderer);\n        }\n        this._pool = {};\n        this._allocatedTextures = [];\n    }\n};\n\nvar defaultParams = {\n    width: 512,\n    height: 512,\n    type: glenum.UNSIGNED_BYTE,\n    format: glenum.RGBA,\n    wrapS: glenum.CLAMP_TO_EDGE,\n    wrapT: glenum.CLAMP_TO_EDGE,\n    minFilter: glenum.LINEAR_MIPMAP_LINEAR,\n    magFilter: glenum.LINEAR,\n    useMipmap: true,\n    anisotropic: 1,\n    flipY: true,\n    unpackAlignment: 4,\n    premultiplyAlpha: false\n};\n\nvar defaultParamPropList = Object.keys(defaultParams);\n\nfunction generateKey(parameters) {\n    util.defaultsWithPropList(parameters, defaultParams, defaultParamPropList);\n    fallBack(parameters);\n\n    var key = '';\n    for (var i = 0; i < defaultParamPropList.length; i++) {\n        var name = defaultParamPropList[i];\n        var chunk = parameters[name].toString();\n        key += chunk;\n    }\n    return key;\n}\n\nfunction fallBack(target) {\n\n    var IPOT = isPowerOfTwo(target.width, target.height);\n\n    if (target.format === glenum.DEPTH_COMPONENT) {\n        target.useMipmap = false;\n    }\n\n    if (!IPOT || !target.useMipmap) {\n        if (target.minFilter == glenum.NEAREST_MIPMAP_NEAREST ||\n            target.minFilter == glenum.NEAREST_MIPMAP_LINEAR) {\n            target.minFilter = glenum.NEAREST;\n        } else if (\n            target.minFilter == glenum.LINEAR_MIPMAP_LINEAR ||\n            target.minFilter == glenum.LINEAR_MIPMAP_NEAREST\n        ) {\n            target.minFilter = glenum.LINEAR;\n        }\n    }\n    if (!IPOT) {\n        target.wrapS = glenum.CLAMP_TO_EDGE;\n        target.wrapT = glenum.CLAMP_TO_EDGE;\n    }\n}\n\nfunction isPowerOfTwo(width, height) {\n    return (width & (width-1)) === 0 &&\n            (height & (height-1)) === 0;\n}\n\nexport default TexturePool;\n","export default \"@export clay.sm.depth.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n#ifdef SHADOW_TRANSPARENT\\nattribute vec2 texcoord : TEXCOORD_0;\\n#endif\\n@import clay.chunk.skinning_header\\nvarying vec4 v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\nvarying vec2 v_Texcoord;\\n#endif\\nvoid main(){\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    v_ViewPosition = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    gl_Position = v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\n    v_Texcoord = texcoord;\\n#endif\\n}\\n@end\\n@export clay.sm.depth.fragment\\nvarying vec4 v_ViewPosition;\\n#ifdef SHADOW_TRANSPARENT\\nvarying vec2 v_Texcoord;\\n#endif\\nuniform float bias : 0.001;\\nuniform float slopeScale : 1.0;\\n#ifdef SHADOW_TRANSPARENT\\nuniform sampler2D transparentMap;\\n#endif\\n@import clay.util.encode_float\\nvoid main(){\\n    float depth = v_ViewPosition.z / v_ViewPosition.w;\\n#ifdef USE_VSM\\n    depth = depth * 0.5 + 0.5;\\n    float moment1 = depth;\\n    float moment2 = depth * depth;\\n    float dx = dFdx(depth);\\n    float dy = dFdy(depth);\\n    moment2 += 0.25*(dx*dx+dy*dy);\\n    gl_FragColor = vec4(moment1, moment2, 0.0, 1.0);\\n#else\\n    float dx = dFdx(depth);\\n    float dy = dFdy(depth);\\n    depth += sqrt(dx*dx + dy*dy) * slopeScale + bias;\\n#ifdef SHADOW_TRANSPARENT\\n    if (texture2D(transparentMap, v_Texcoord).a <= 0.1) {\\n        gl_FragColor = encodeFloat(0.9999);\\n        return;\\n    }\\n#endif\\n    gl_FragColor = encodeFloat(depth * 0.5 + 0.5);\\n#endif\\n}\\n@end\\n@export clay.sm.debug_depth\\nuniform sampler2D depthMap;\\nvarying vec2 v_Texcoord;\\n@import clay.util.decode_float\\nvoid main() {\\n    vec4 tex = texture2D(depthMap, v_Texcoord);\\n#ifdef USE_VSM\\n    gl_FragColor = vec4(tex.rgb, 1.0);\\n#else\\n    float depth = decodeFloat(tex);\\n    gl_FragColor = vec4(depth, depth, depth, 1.0);\\n#endif\\n}\\n@end\\n@export clay.sm.distance.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 world : WORLD;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvarying vec3 v_WorldPosition;\\nvoid main (){\\n    vec3 skinnedPosition = position;\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition , 1.0);\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n}\\n@end\\n@export clay.sm.distance.fragment\\nuniform vec3 lightPosition;\\nuniform float range : 100;\\nvarying vec3 v_WorldPosition;\\n@import clay.util.encode_float\\nvoid main(){\\n    float dist = distance(lightPosition, v_WorldPosition);\\n#ifdef USE_VSM\\n    gl_FragColor = vec4(dist, dist * dist, 0.0, 0.0);\\n#else\\n    dist = dist / range;\\n    gl_FragColor = encodeFloat(dist);\\n#endif\\n}\\n@end\\n@export clay.plugin.shadow_map_common\\n@import clay.util.decode_float\\nfloat tapShadowMap(sampler2D map, vec2 uv, float z){\\n    vec4 tex = texture2D(map, uv);\\n    return step(z, decodeFloat(tex) * 2.0 - 1.0);\\n}\\nfloat pcf(sampler2D map, vec2 uv, float z, float textureSize, vec2 scale) {\\n    float shadowContrib = tapShadowMap(map, uv, z);\\n    vec2 offset = vec2(1.0 / textureSize) * scale;\\n#ifdef PCF_KERNEL_SIZE\\n    for (int _idx_ = 0; _idx_ < PCF_KERNEL_SIZE; _idx_++) {{\\n        shadowContrib += tapShadowMap(map, uv + offset * pcfKernel[_idx_], z);\\n    }}\\n    return shadowContrib / float(PCF_KERNEL_SIZE + 1);\\n#else\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, 0.0), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(0.0, offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, 0.0), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(-offset.x, -offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(offset.x, -offset.y), z);\\n    shadowContrib += tapShadowMap(map, uv+vec2(0.0, -offset.y), z);\\n    return shadowContrib / 9.0;\\n#endif\\n}\\nfloat pcf(sampler2D map, vec2 uv, float z, float textureSize) {\\n    return pcf(map, uv, z, textureSize, vec2(1.0));\\n}\\nfloat chebyshevUpperBound(vec2 moments, float z){\\n    float p = 0.0;\\n    z = z * 0.5 + 0.5;\\n    if (z <= moments.x) {\\n        p = 1.0;\\n    }\\n    float variance = moments.y - moments.x * moments.x;\\n    variance = max(variance, 0.0000001);\\n    float mD = moments.x - z;\\n    float pMax = variance / (variance + mD * mD);\\n    pMax = clamp((pMax-0.4)/(1.0-0.4), 0.0, 1.0);\\n    return max(p, pMax);\\n}\\nfloat computeShadowContrib(\\n    sampler2D map, mat4 lightVPM, vec3 position, float textureSize, vec2 scale, vec2 offset\\n) {\\n    vec4 posInLightSpace = lightVPM * vec4(position, 1.0);\\n    posInLightSpace.xyz /= posInLightSpace.w;\\n    float z = posInLightSpace.z;\\n    if(all(greaterThan(posInLightSpace.xyz, vec3(-0.99, -0.99, -1.0))) &&\\n        all(lessThan(posInLightSpace.xyz, vec3(0.99, 0.99, 1.0)))){\\n        vec2 uv = (posInLightSpace.xy+1.0) / 2.0;\\n        #ifdef USE_VSM\\n            vec2 moments = texture2D(map, uv * scale + offset).xy;\\n            return chebyshevUpperBound(moments, z);\\n        #else\\n            return pcf(map, uv * scale + offset, z, textureSize, scale);\\n        #endif\\n    }\\n    return 1.0;\\n}\\nfloat computeShadowContrib(sampler2D map, mat4 lightVPM, vec3 position, float textureSize) {\\n    return computeShadowContrib(map, lightVPM, position, textureSize, vec2(1.0), vec2(0.0));\\n}\\nfloat computeShadowContribOmni(samplerCube map, vec3 direction, float range)\\n{\\n    float dist = length(direction);\\n    vec4 shadowTex = textureCube(map, direction);\\n#ifdef USE_VSM\\n    vec2 moments = shadowTex.xy;\\n    float variance = moments.y - moments.x * moments.x;\\n    float mD = moments.x - dist;\\n    float p = variance / (variance + mD * mD);\\n    if(moments.x + 0.001 < dist){\\n        return clamp(p, 0.0, 1.0);\\n    }else{\\n        return 1.0;\\n    }\\n#else\\n    return step(dist, (decodeFloat(shadowTex) + 0.0002) * range);\\n#endif\\n}\\n@end\\n@export clay.plugin.compute_shadow_map\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT) || defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT) || defined(POINT_LIGHT_SHADOWMAP_COUNT)\\n#ifdef SPOT_LIGHT_SHADOWMAP_COUNT\\nuniform sampler2D spotLightShadowMaps[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform mat4 spotLightMatrices[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform float spotLightShadowMapSizes[SPOT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\n#ifdef DIRECTIONAL_LIGHT_SHADOWMAP_COUNT\\n#if defined(SHADOW_CASCADE)\\nuniform sampler2D directionalLightShadowMaps[1]:unconfigurable;\\nuniform mat4 directionalLightMatrices[SHADOW_CASCADE]:unconfigurable;\\nuniform float directionalLightShadowMapSizes[1]:unconfigurable;\\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE]:unconfigurable;\\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE]:unconfigurable;\\n#else\\nuniform sampler2D directionalLightShadowMaps[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform mat4 directionalLightMatrices[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\nuniform float directionalLightShadowMapSizes[DIRECTIONAL_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\n#endif\\n#ifdef POINT_LIGHT_SHADOWMAP_COUNT\\nuniform samplerCube pointLightShadowMaps[POINT_LIGHT_SHADOWMAP_COUNT]:unconfigurable;\\n#endif\\nuniform bool shadowEnabled : true;\\n#ifdef PCF_KERNEL_SIZE\\nuniform vec2 pcfKernel[PCF_KERNEL_SIZE];\\n#endif\\n@import clay.plugin.shadow_map_common\\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\\nvoid computeShadowOfSpotLights(vec3 position, inout float shadowContribs[SPOT_LIGHT_COUNT] ) {\\n    float shadowContrib;\\n    for(int _idx_ = 0; _idx_ < SPOT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        shadowContrib = computeShadowContrib(\\n            spotLightShadowMaps[_idx_], spotLightMatrices[_idx_], position,\\n            spotLightShadowMapSizes[_idx_]\\n        );\\n        shadowContribs[_idx_] = shadowContrib;\\n    }}\\n    for(int _idx_ = SPOT_LIGHT_SHADOWMAP_COUNT; _idx_ < SPOT_LIGHT_COUNT; _idx_++){{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\\n#ifdef SHADOW_CASCADE\\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\\n    float depth = (2.0 * gl_FragCoord.z - gl_DepthRange.near - gl_DepthRange.far)\\n                    / (gl_DepthRange.far - gl_DepthRange.near);\\n    float shadowContrib;\\n    shadowContribs[0] = 1.0;\\n    for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\\n        if (\\n            depth >= shadowCascadeClipsNear[_idx_] &&\\n            depth <= shadowCascadeClipsFar[_idx_]\\n        ) {\\n            shadowContrib = computeShadowContrib(\\n                directionalLightShadowMaps[0], directionalLightMatrices[_idx_], position,\\n                directionalLightShadowMapSizes[0],\\n                vec2(1.0 / float(SHADOW_CASCADE), 1.0),\\n                vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\\n            );\\n            shadowContribs[0] = shadowContrib;\\n        }\\n    }}\\n    for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#else\\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\\n    float shadowContrib;\\n    for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        shadowContrib = computeShadowContrib(\\n            directionalLightShadowMaps[_idx_], directionalLightMatrices[_idx_], position,\\n            directionalLightShadowMapSizes[_idx_]\\n        );\\n        shadowContribs[_idx_] = shadowContrib;\\n    }}\\n    for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#endif\\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\\nvoid computeShadowOfPointLights(vec3 position, inout float shadowContribs[POINT_LIGHT_COUNT] ){\\n    vec3 lightPosition;\\n    vec3 direction;\\n    for(int _idx_ = 0; _idx_ < POINT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\\n        lightPosition = pointLightPosition[_idx_];\\n        direction = position - lightPosition;\\n        shadowContribs[_idx_] = computeShadowContribOmni(pointLightShadowMaps[_idx_], direction, pointLightRange[_idx_]);\\n    }}\\n    for(int _idx_ = POINT_LIGHT_SHADOWMAP_COUNT; _idx_ < POINT_LIGHT_COUNT; _idx_++) {{\\n        shadowContribs[_idx_] = 1.0;\\n    }}\\n}\\n#endif\\n#endif\\n@end\";\n","import Base from '../core/Base';\nimport glenum from '../core/glenum';\nimport Vector3 from '../math/Vector3';\nimport BoundingBox from '../math/BoundingBox';\nimport Frustum from '../math/Frustum';\nimport Matrix4 from '../math/Matrix4';\nimport Renderer from '../Renderer';\nimport Shader from '../Shader';\nimport Light from '../Light';\nimport Mesh from '../Mesh';\nimport SpotLight from '../light/Spot';\nimport DirectionalLight from '../light/Directional';\nimport PointLight from '../light/Point';\nimport shaderLibrary from '../shader/library';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\nimport PerspectiveCamera from '../camera/Perspective';\nimport OrthoCamera from '../camera/Orthographic';\n\nimport Pass from '../compositor/Pass';\nimport TexturePool from '../compositor/TexturePool';\n\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\nimport shadowmapEssl from '../shader/source/shadowmap.glsl.js';\nShader['import'](shadowmapEssl);\n\n/**\n * Pass rendering shadow map.\n *\n * @constructor clay.prePass.ShadowMap\n * @extends clay.core.Base\n * @example\n *     var shadowMapPass = new clay.prePass.ShadowMap({\n *         softShadow: clay.prePass.ShadowMap.VSM\n *     });\n *     ...\n *     animation.on('frame', function (frameTime) {\n *         shadowMapPass.render(renderer, scene, camera);\n *         renderer.render(scene, camera);\n *     });\n */\nvar ShadowMapPass = Base.extend(function () {\n    return /** @lends clay.prePass.ShadowMap# */ {\n        /**\n         * Soft shadow technique.\n         * Can be {@link clay.prePass.ShadowMap.PCF} or {@link clay.prePass.ShadowMap.VSM}\n         * @type {number}\n         */\n        softShadow: ShadowMapPass.PCF,\n\n        /**\n         * Soft shadow blur size\n         * @type {number}\n         */\n        shadowBlur: 1.0,\n\n        lightFrustumBias: 'auto',\n\n        kernelPCF: new Float32Array([\n            1, 0,\n            1, 1,\n            -1, 1,\n            0, 1,\n            -1, 0,\n            -1, -1,\n            1, -1,\n            0, -1\n        ]),\n\n        precision: 'mediump',\n\n        _lastRenderNotCastShadow: false,\n\n        _frameBuffer: new FrameBuffer(),\n\n        _textures: {},\n        _shadowMapNumber: {\n            'POINT_LIGHT': 0,\n            'DIRECTIONAL_LIGHT': 0,\n            'SPOT_LIGHT': 0\n        },\n\n        _depthMaterials: {},\n        _distanceMaterials: {},\n\n        _opaqueCasters: [],\n        _receivers: [],\n        _lightsCastShadow: [],\n\n        _lightCameras: {},\n        _lightMaterials: {},\n\n        _texturePool: new TexturePool()\n    };\n}, function () {\n    // Gaussian filter pass for VSM\n    this._gaussianPassH = new Pass({\n        fragment: Shader.source('clay.compositor.gaussian_blur')\n    });\n    this._gaussianPassV = new Pass({\n        fragment: Shader.source('clay.compositor.gaussian_blur')\n    });\n    this._gaussianPassH.setUniform('blurSize', this.shadowBlur);\n    this._gaussianPassH.setUniform('blurDir', 0.0);\n    this._gaussianPassV.setUniform('blurSize', this.shadowBlur);\n    this._gaussianPassV.setUniform('blurDir', 1.0);\n\n    this._outputDepthPass = new Pass({\n        fragment: Shader.source('clay.sm.debug_depth')\n    });\n}, {\n    /**\n     * Render scene to shadow textures\n     * @param  {clay.Renderer} renderer\n     * @param  {clay.Scene} scene\n     * @param  {clay.Camera} sceneCamera\n     * @param  {boolean} [notUpdateScene=false]\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    render: function (renderer, scene, sceneCamera, notUpdateScene) {\n        if (!sceneCamera) {\n            sceneCamera = scene.getMainCamera();\n        }\n        this.trigger('beforerender', this, renderer, scene, sceneCamera);\n        this._renderShadowPass(renderer, scene, sceneCamera, notUpdateScene);\n        this.trigger('afterrender', this, renderer, scene, sceneCamera);\n    },\n\n    /**\n     * Debug rendering of shadow textures\n     * @param  {clay.Renderer} renderer\n     * @param  {number} size\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    renderDebug: function (renderer, size) {\n        renderer.saveClear();\n        var viewport = renderer.viewport;\n        var x = 0, y = 0;\n        var width = size || viewport.width / 4;\n        var height = width;\n        if (this.softShadow === ShadowMapPass.VSM) {\n            this._outputDepthPass.material.define('fragment', 'USE_VSM');\n        }\n        else {\n            this._outputDepthPass.material.undefine('fragment', 'USE_VSM');\n        }\n        for (var name in this._textures) {\n            var texture = this._textures[name];\n            renderer.setViewport(x, y, width * texture.width / texture.height, height);\n            this._outputDepthPass.setUniform('depthMap', texture);\n            this._outputDepthPass.render(renderer);\n            x += width * texture.width / texture.height;\n        }\n        renderer.setViewport(viewport);\n        renderer.restoreClear();\n    },\n\n    _updateCasterAndReceiver: function (renderer, mesh) {\n        if (mesh.castShadow) {\n            this._opaqueCasters.push(mesh);\n        }\n        if (mesh.receiveShadow) {\n            this._receivers.push(mesh);\n            mesh.material.set('shadowEnabled', 1);\n\n            mesh.material.set('pcfKernel', this.kernelPCF);\n        }\n        else {\n            mesh.material.set('shadowEnabled', 0);\n        }\n\n        if (!mesh.material.shader && mesh.material.updateShader) {\n            mesh.material.updateShader(renderer);\n        }\n        if (this.softShadow === ShadowMapPass.VSM) {\n            mesh.material.define('fragment', 'USE_VSM');\n            mesh.material.undefine('fragment', 'PCF_KERNEL_SIZE');\n        }\n        else {\n            mesh.material.undefine('fragment', 'USE_VSM');\n            var kernelPCF = this.kernelPCF;\n            if (kernelPCF && kernelPCF.length) {\n                mesh.material.define('fragment', 'PCF_KERNEL_SIZE', kernelPCF.length / 2);\n            }\n            else {\n                mesh.material.undefine('fragment', 'PCF_KERNEL_SIZE');\n            }\n        }\n    },\n\n    _update: function (renderer, scene) {\n        for (var i = 0; i < scene.opaqueList.length; i++) {\n            this._updateCasterAndReceiver(renderer, scene.opaqueList[i]);\n        }\n        for (var i = 0; i < scene.transparentList.length; i++) {\n            // TODO Transparent object receive shadow will be very slow\n            // in stealth demo, still not find the reason\n            this._updateCasterAndReceiver(renderer, scene.transparentList[i]);\n        }\n        for (var i = 0; i < scene.lights.length; i++) {\n            var light = scene.lights[i];\n            if (light.castShadow) {\n                this._lightsCastShadow.push(light);\n            }\n        }\n    },\n\n    _renderShadowPass: function (renderer, scene, sceneCamera, notUpdateScene) {\n        // reset\n        for (var name in this._shadowMapNumber) {\n            this._shadowMapNumber[name] = 0;\n        }\n        this._lightsCastShadow.length = 0;\n        this._opaqueCasters.length = 0;\n        this._receivers.length = 0;\n\n        var _gl = renderer.gl;\n\n        if (!notUpdateScene) {\n            scene.update();\n        }\n        if (sceneCamera) {\n            sceneCamera.update();\n        }\n\n        this._update(renderer, scene);\n\n        // Needs to update the receivers again if shadows come from 1 to 0.\n        if (!this._lightsCastShadow.length && this._lastRenderNotCastShadow) {\n            return;\n        }\n\n        this._lastRenderNotCastShadow = this._lightsCastShadow === 0;\n\n        _gl.enable(_gl.DEPTH_TEST);\n        _gl.depthMask(true);\n        _gl.disable(_gl.BLEND);\n\n        // Clear with high-z, so the part not rendered will not been shadowed\n        // TODO\n        // TODO restore\n        _gl.clearColor(1.0, 1.0, 1.0, 1.0);\n\n        // Shadow uniforms\n        var spotLightShadowMaps = [];\n        var spotLightMatrices = [];\n        var directionalLightShadowMaps = [];\n        var directionalLightMatrices = [];\n        var shadowCascadeClips = [];\n        var pointLightShadowMaps = [];\n\n        var dirLightHasCascade;\n        // Create textures for shadow map\n        for (var i = 0; i < this._lightsCastShadow.length; i++) {\n            var light = this._lightsCastShadow[i];\n            if (light instanceof DirectionalLight) {\n\n                if (dirLightHasCascade) {\n                    console.warn('Only one direectional light supported with shadow cascade');\n                    continue;\n                }\n                if (light.shadowCascade > 4) {\n                    console.warn('Support at most 4 cascade');\n                    continue;\n                }\n                if (light.shadowCascade > 1) {\n                    dirLightHasCascade = light.shadowCascade;\n                }\n\n                this.renderDirectionalLightShadow(\n                    renderer,\n                    scene,\n                    sceneCamera,\n                    light,\n                    this._opaqueCasters,\n                    shadowCascadeClips,\n                    directionalLightMatrices,\n                    directionalLightShadowMaps\n                );\n            }\n            else if (light instanceof SpotLight) {\n                this.renderSpotLightShadow(\n                    renderer,\n                    scene,\n                    light,\n                    this._opaqueCasters,\n                    spotLightMatrices,\n                    spotLightShadowMaps\n                );\n            }\n            else if (light instanceof PointLight) {\n                this.renderPointLightShadow(\n                    renderer,\n                    scene,\n                    light,\n                    this._opaqueCasters,\n                    pointLightShadowMaps\n                );\n            }\n\n            this._shadowMapNumber[light.type]++;\n        }\n\n        for (var lightType in this._shadowMapNumber) {\n            var number = this._shadowMapNumber[lightType];\n            var key = lightType + '_SHADOWMAP_COUNT';\n            for (var i = 0; i < this._receivers.length; i++) {\n                var mesh = this._receivers[i];\n                var material = mesh.material;\n                if (material.fragmentDefines[key] !== number) {\n                    if (number > 0) {\n                        material.define('fragment', key, number);\n                    }\n                    else if (material.isDefined('fragment', key)) {\n                        material.undefine('fragment', key);\n                    }\n                }\n            }\n        }\n        for (var i = 0; i < this._receivers.length; i++) {\n            var mesh = this._receivers[i];\n            var material = mesh.material;\n            if (dirLightHasCascade) {\n                material.define('fragment', 'SHADOW_CASCADE', dirLightHasCascade.shadowCascade);\n            }\n            else {\n                material.undefine('fragment', 'SHADOW_CASCADE');\n            }\n        }\n\n        var shadowUniforms = scene.shadowUniforms;\n\n        function getSize(texture) {\n            return texture.height;\n        }\n        if (directionalLightShadowMaps.length > 0) {\n            var directionalLightShadowMapSizes = directionalLightShadowMaps.map(getSize);\n            shadowUniforms.directionalLightShadowMaps = { value: directionalLightShadowMaps, type: 'tv' };\n            shadowUniforms.directionalLightMatrices = { value: directionalLightMatrices, type: 'm4v' };\n            shadowUniforms.directionalLightShadowMapSizes = { value: directionalLightShadowMapSizes, type: '1fv' };\n            if (dirLightHasCascade) {\n                var shadowCascadeClipsNear = shadowCascadeClips.slice();\n                var shadowCascadeClipsFar = shadowCascadeClips.slice();\n                shadowCascadeClipsNear.pop();\n                shadowCascadeClipsFar.shift();\n\n                // Iterate from far to near\n                shadowCascadeClipsNear.reverse();\n                shadowCascadeClipsFar.reverse();\n                // directionalLightShadowMaps.reverse();\n                directionalLightMatrices.reverse();\n                shadowUniforms.shadowCascadeClipsNear = { value: shadowCascadeClipsNear, type: '1fv' };\n                shadowUniforms.shadowCascadeClipsFar = { value: shadowCascadeClipsFar, type: '1fv' };\n            }\n        }\n\n        if (spotLightShadowMaps.length > 0) {\n            var spotLightShadowMapSizes = spotLightShadowMaps.map(getSize);\n            var shadowUniforms = scene.shadowUniforms;\n            shadowUniforms.spotLightShadowMaps = { value: spotLightShadowMaps, type: 'tv' };\n            shadowUniforms.spotLightMatrices = { value: spotLightMatrices, type: 'm4v' };\n            shadowUniforms.spotLightShadowMapSizes = { value: spotLightShadowMapSizes, type: '1fv' };\n        }\n\n        if (pointLightShadowMaps.length > 0) {\n            shadowUniforms.pointLightShadowMaps = { value: pointLightShadowMaps, type: 'tv' };\n        }\n    },\n\n    renderDirectionalLightShadow: (function () {\n\n        var splitFrustum = new Frustum();\n        var splitProjMatrix = new Matrix4();\n        var cropBBox = new BoundingBox();\n        var cropMatrix = new Matrix4();\n        var lightViewMatrix = new Matrix4();\n        var lightViewProjMatrix = new Matrix4();\n        var lightProjMatrix = new Matrix4();\n\n        return function (renderer, scene, sceneCamera, light, casters, shadowCascadeClips, directionalLightMatrices, directionalLightShadowMaps) {\n\n            var defaultShadowMaterial = this._getDepthMaterial(light);\n            var passConfig = {\n                getMaterial: function (renderable) {\n                    return renderable.shadowDepthMaterial || defaultShadowMaterial;\n                },\n                sortCompare: Renderer.opaqueSortCompare\n            };\n\n            // First frame\n            if (!scene.viewBoundingBoxLastFrame.isFinite()) {\n                var boundingBox = scene.getBoundingBox();\n                scene.viewBoundingBoxLastFrame\n                    .copy(boundingBox).applyTransform(sceneCamera.viewMatrix);\n            }\n            // Considering moving speed since the bounding box is from last frame\n            // TODO: add a bias\n            var clippedFar = Math.min(-scene.viewBoundingBoxLastFrame.min.z, sceneCamera.far);\n            var clippedNear = Math.max(-scene.viewBoundingBoxLastFrame.max.z, sceneCamera.near);\n\n            var lightCamera = this._getDirectionalLightCamera(light, scene, sceneCamera);\n\n            var lvpMat4Arr = lightViewProjMatrix.array;\n            lightProjMatrix.copy(lightCamera.projectionMatrix);\n            mat4.invert(lightViewMatrix.array, lightCamera.worldTransform.array);\n            mat4.multiply(lightViewMatrix.array, lightViewMatrix.array, sceneCamera.worldTransform.array);\n            mat4.multiply(lvpMat4Arr, lightProjMatrix.array, lightViewMatrix.array);\n\n            var clipPlanes = [];\n            var isPerspective = sceneCamera instanceof PerspectiveCamera;\n\n            var scaleZ = (sceneCamera.near + sceneCamera.far) / (sceneCamera.near - sceneCamera.far);\n            var offsetZ = 2 * sceneCamera.near * sceneCamera.far / (sceneCamera.near - sceneCamera.far);\n            for (var i = 0; i <= light.shadowCascade; i++) {\n                var clog = clippedNear * Math.pow(clippedFar / clippedNear, i / light.shadowCascade);\n                var cuni = clippedNear + (clippedFar - clippedNear) * i / light.shadowCascade;\n                var c = clog * light.cascadeSplitLogFactor + cuni * (1 - light.cascadeSplitLogFactor);\n                clipPlanes.push(c);\n                shadowCascadeClips.push(-(-c * scaleZ + offsetZ) / -c);\n            }\n            var texture = this._getTexture(light, light.shadowCascade);\n            directionalLightShadowMaps.push(texture);\n\n            var viewport = renderer.viewport;\n\n            var _gl = renderer.gl;\n            this._frameBuffer.attach(texture);\n            this._frameBuffer.bind(renderer);\n            _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n            for (var i = 0; i < light.shadowCascade; i++) {\n                // Get the splitted frustum\n                var nearPlane = clipPlanes[i];\n                var farPlane = clipPlanes[i + 1];\n                if (isPerspective) {\n                    mat4.perspective(splitProjMatrix.array, sceneCamera.fov / 180 * Math.PI, sceneCamera.aspect, nearPlane, farPlane);\n                }\n                else {\n                    mat4.ortho(\n                        splitProjMatrix.array,\n                        sceneCamera.left, sceneCamera.right, sceneCamera.bottom, sceneCamera.top,\n                        nearPlane, farPlane\n                    );\n                }\n                splitFrustum.setFromProjection(splitProjMatrix);\n                splitFrustum.getTransformedBoundingBox(cropBBox, lightViewMatrix);\n                cropBBox.applyProjection(lightProjMatrix);\n                var _min = cropBBox.min.array;\n                var _max = cropBBox.max.array;\n                _min[0] = Math.max(_min[0], -1);\n                _min[1] = Math.max(_min[1], -1);\n                _max[0] = Math.min(_max[0], 1);\n                _max[1] = Math.min(_max[1], 1);\n                cropMatrix.ortho(_min[0], _max[0], _min[1], _max[1], 1, -1);\n                lightCamera.projectionMatrix.multiplyLeft(cropMatrix);\n\n                var shadowSize = light.shadowResolution || 512;\n\n                // Reversed, left to right => far to near\n                renderer.setViewport((light.shadowCascade - i - 1) * shadowSize, 0, shadowSize, shadowSize, 1);\n\n                renderer.renderPass(casters, lightCamera, passConfig);\n\n                // Filter for VSM\n                if (this.softShadow === ShadowMapPass.VSM) {\n                    this._gaussianFilter(renderer, texture, texture.width);\n                }\n\n                var matrix = new Matrix4();\n                matrix.copy(lightCamera.viewMatrix)\n                    .multiplyLeft(lightCamera.projectionMatrix);\n\n                directionalLightMatrices.push(matrix.array);\n\n                lightCamera.projectionMatrix.copy(lightProjMatrix);\n            }\n\n            this._frameBuffer.unbind(renderer);\n\n            renderer.setViewport(viewport);\n        };\n    })(),\n\n    renderSpotLightShadow: function (renderer, scene, light, casters, spotLightMatrices, spotLightShadowMaps) {\n\n        var texture = this._getTexture(light);\n        var lightCamera = this._getSpotLightCamera(light);\n        var _gl = renderer.gl;\n\n        this._frameBuffer.attach(texture);\n        this._frameBuffer.bind(renderer);\n\n        _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n        var defaultShadowMaterial = this._getDepthMaterial(light);\n        var passConfig = {\n            getMaterial: function (renderable) {\n                return renderable.shadowDepthMaterial || defaultShadowMaterial;\n            },\n            sortCompare: Renderer.opaqueSortCompare\n        };\n\n        renderer.renderPass(renderer.cullRenderList(casters, null, lightCamera), lightCamera, passConfig);\n\n        this._frameBuffer.unbind(renderer);\n\n        // Filter for VSM\n        if (this.softShadow === ShadowMapPass.VSM) {\n            this._gaussianFilter(renderer, texture, texture.width);\n        }\n\n        var matrix = new Matrix4();\n        matrix.copy(lightCamera.worldTransform)\n            .invert()\n            .multiplyLeft(lightCamera.projectionMatrix);\n\n        spotLightShadowMaps.push(texture);\n        spotLightMatrices.push(matrix.array);\n    },\n\n    renderPointLightShadow: function (renderer, scene, light, casters, pointLightShadowMaps) {\n        var texture = this._getTexture(light);\n        var _gl = renderer.gl;\n        pointLightShadowMaps.push(texture);\n\n        var defaultShadowMaterial = this._getDepthMaterial(light);\n        var passConfig = {\n            getMaterial: function (renderable) {\n                return renderable.shadowDepthMaterial || defaultShadowMaterial;\n            },\n            sortCompare: Renderer.opaqueSortCompare\n        };\n\n        for (var i = 0; i < 6; i++) {\n            var target = targets[i];\n            var camera = this._getPointLightCamera(light, target);\n\n            this._frameBuffer.attach(texture, _gl.COLOR_ATTACHMENT0, _gl.TEXTURE_CUBE_MAP_POSITIVE_X + i);\n            this._frameBuffer.bind(renderer);\n            _gl.clear(_gl.COLOR_BUFFER_BIT | _gl.DEPTH_BUFFER_BIT);\n\n            renderer.renderPass(renderer.cullRenderList(casters, null, camera), camera, passConfig);\n        }\n\n        this._frameBuffer.unbind(renderer);\n    },\n\n    _getDepthMaterial: function (light) {\n        var shadowMaterial = this._lightMaterials[light.__uid__];\n        var isPointLight = light instanceof PointLight;\n        if (!shadowMaterial) {\n            var shaderPrefix = isPointLight ? 'clay.sm.distance.' : 'clay.sm.depth.';\n            shadowMaterial = new Material({\n                precision: this.precision,\n                shader: new Shader(Shader.source(shaderPrefix + 'vertex'), Shader.source(shaderPrefix + 'fragment'))\n            });\n\n            this._lightMaterials[light.__uid__] = shadowMaterial;\n        }\n        if (light.shadowSlopeScale != null) {\n            shadowMaterial.setUniform('slopeScale', light.shadowSlopeScale);\n        }\n        if (light.shadowBias != null) {\n            shadowMaterial.setUniform('shadowBias', light.shadowBias);\n        }\n        if (this.softShadow === ShadowMapPass.VSM) {\n            shadowMaterial.define('fragment', 'USE_VSM');\n        }\n        else {\n            shadowMaterial.undefine('fragment', 'USE_VSM');\n        }\n\n        if (isPointLight) {\n            shadowMaterial.set('lightPosition', light.getWorldPosition().array);\n            shadowMaterial.set('range', light.range);\n        }\n\n        return shadowMaterial;\n    },\n\n    _gaussianFilter: function (renderer, texture, size) {\n        var parameter = {\n            width: size,\n            height: size,\n            type: Texture.FLOAT\n        };\n        var tmpTexture = this._texturePool.get(parameter);\n\n        this._frameBuffer.attach(tmpTexture);\n        this._frameBuffer.bind(renderer);\n        this._gaussianPassH.setUniform('texture', texture);\n        this._gaussianPassH.setUniform('textureWidth', size);\n        this._gaussianPassH.render(renderer);\n\n        this._frameBuffer.attach(texture);\n        this._gaussianPassV.setUniform('texture', tmpTexture);\n        this._gaussianPassV.setUniform('textureHeight', size);\n        this._gaussianPassV.render(renderer);\n        this._frameBuffer.unbind(renderer);\n\n        this._texturePool.put(tmpTexture);\n    },\n\n    _getTexture: function (light, cascade) {\n        var key = light.__uid__;\n        var texture = this._textures[key];\n        var resolution = light.shadowResolution || 512;\n        cascade = cascade || 1;\n        if (!texture) {\n            if (light instanceof PointLight) {\n                texture = new TextureCube();\n            }\n            else {\n                texture = new Texture2D();\n            }\n            // At most 4 cascade\n            // TODO share with height ?\n            texture.width = resolution * cascade;\n            texture.height = resolution;\n            if (this.softShadow === ShadowMapPass.VSM) {\n                texture.type = Texture.FLOAT;\n                texture.anisotropic = 4;\n            }\n            else {\n                texture.minFilter = glenum.NEAREST;\n                texture.magFilter = glenum.NEAREST;\n                texture.useMipmap = false;\n            }\n            this._textures[key] = texture;\n        }\n\n        return texture;\n    },\n\n    _getPointLightCamera: function (light, target) {\n        if (!this._lightCameras.point) {\n            this._lightCameras.point = {\n                px: new PerspectiveCamera(),\n                nx: new PerspectiveCamera(),\n                py: new PerspectiveCamera(),\n                ny: new PerspectiveCamera(),\n                pz: new PerspectiveCamera(),\n                nz: new PerspectiveCamera()\n            };\n        }\n        var camera = this._lightCameras.point[target];\n\n        camera.far = light.range;\n        camera.fov = 90;\n        camera.position.set(0, 0, 0);\n        switch (target) {\n            case 'px':\n                camera.lookAt(Vector3.POSITIVE_X, Vector3.NEGATIVE_Y);\n                break;\n            case 'nx':\n                camera.lookAt(Vector3.NEGATIVE_X, Vector3.NEGATIVE_Y);\n                break;\n            case 'py':\n                camera.lookAt(Vector3.POSITIVE_Y, Vector3.POSITIVE_Z);\n                break;\n            case 'ny':\n                camera.lookAt(Vector3.NEGATIVE_Y, Vector3.NEGATIVE_Z);\n                break;\n            case 'pz':\n                camera.lookAt(Vector3.POSITIVE_Z, Vector3.NEGATIVE_Y);\n                break;\n            case 'nz':\n                camera.lookAt(Vector3.NEGATIVE_Z, Vector3.NEGATIVE_Y);\n                break;\n        }\n        light.getWorldPosition(camera.position);\n        camera.update();\n\n        return camera;\n    },\n\n    _getDirectionalLightCamera: (function () {\n        var lightViewMatrix = new Matrix4();\n        var sceneViewBoundingBox = new BoundingBox();\n        var lightViewBBox = new BoundingBox();\n        // Camera of directional light will be adjusted\n        // to contain the view frustum and scene bounding box as tightly as possible\n        return function (light, scene, sceneCamera) {\n            if (!this._lightCameras.directional) {\n                this._lightCameras.directional = new OrthoCamera();\n            }\n            var camera = this._lightCameras.directional;\n\n            sceneViewBoundingBox.copy(scene.viewBoundingBoxLastFrame);\n            sceneViewBoundingBox.intersection(sceneCamera.frustum.boundingBox);\n            // Move to the center of frustum(in world space)\n            camera.position\n                .copy(sceneViewBoundingBox.min)\n                .add(sceneViewBoundingBox.max)\n                .scale(0.5)\n                .transformMat4(sceneCamera.worldTransform);\n            camera.rotation.copy(light.rotation);\n            camera.scale.copy(light.scale);\n            camera.updateWorldTransform();\n\n            // Transform to light view space\n            Matrix4.invert(lightViewMatrix, camera.worldTransform);\n            Matrix4.multiply(lightViewMatrix, lightViewMatrix, sceneCamera.worldTransform);\n\n            lightViewBBox.copy(sceneViewBoundingBox).applyTransform(lightViewMatrix);\n\n            var min = lightViewBBox.min.array;\n            var max = lightViewBBox.max.array;\n\n            // Move camera to adjust the near to 0\n            camera.position.set((min[0] + max[0]) / 2, (min[1] + max[1]) / 2, max[2])\n                .transformMat4(camera.worldTransform);\n            camera.near = 0;\n            camera.far = -min[2] + max[2];\n            // Make sure receivers not in the frustum will stil receive the shadow.\n            if (isNaN(this.lightFrustumBias)) {\n                camera.far *= 4;\n            }\n            else {\n                camera.far += this.lightFrustumBias;\n            }\n            camera.left = min[0];\n            camera.right = max[0];\n            camera.top = max[1];\n            camera.bottom = min[1];\n            camera.update(true);\n\n            return camera;\n        };\n    })(),\n\n    _getSpotLightCamera: function (light) {\n        if (!this._lightCameras.spot) {\n            this._lightCameras.spot = new PerspectiveCamera();\n        }\n        var camera = this._lightCameras.spot;\n        // Update properties\n        camera.fov = light.penumbraAngle * 2;\n        camera.far = light.range;\n        camera.worldTransform.copy(light.worldTransform);\n        camera.updateProjectionMatrix();\n        mat4.invert(camera.viewMatrix.array, camera.worldTransform.array);\n\n        return camera;\n    },\n\n    /**\n     * @param  {clay.Renderer|WebGLRenderingContext} [renderer]\n     * @memberOf clay.prePass.ShadowMap.prototype\n     */\n    // PENDING Renderer or WebGLRenderingContext\n    dispose: function (renderer) {\n        var _gl = renderer.gl || renderer;\n\n        if (this._frameBuffer) {\n            this._frameBuffer.dispose(_gl);\n        }\n\n        for (var name in this._textures) {\n            this._textures[name].dispose(_gl);\n        }\n\n        this._texturePool.clear(renderer.gl);\n\n        this._depthMaterials = {};\n        this._distanceMaterials = {};\n        this._textures = {};\n        this._lightCameras = {};\n        this._shadowMapNumber = {\n            'POINT_LIGHT': 0,\n            'DIRECTIONAL_LIGHT': 0,\n            'SPOT_LIGHT': 0\n        };\n        this._meshMaterials = {};\n\n        for (var i = 0; i < this._receivers.length; i++) {\n            var mesh = this._receivers[i];\n            // Mesh may be disposed\n            if (mesh.material && mesh.material.shader) {\n                var material = mesh.material;\n                var shader = material.shader;\n                shader.undefine('fragment', 'POINT_LIGHT_SHADOW_COUNT');\n                shader.undefine('fragment', 'DIRECTIONAL_LIGHT_SHADOW_COUNT');\n                shader.undefine('fragment', 'AMBIENT_LIGHT_SHADOW_COUNT');\n                material.set('shadowEnabled', 0);\n            }\n        }\n\n        this._opaqueCasters = [];\n        this._receivers = [];\n        this._lightsCastShadow = [];\n    }\n});\n\n/**\n * @name clay.prePass.ShadowMap.VSM\n * @type {number}\n */\nShadowMapPass.VSM = 1;\n\n/**\n * @name clay.prePass.ShadowMap.PCF\n * @type {number}\n */\nShadowMapPass.PCF = 2;\n\nexport default ShadowMapPass;\n","import Base from '../core/Base';\nimport Ray from '../math/Ray';\nimport Vector2 from '../math/Vector2';\nimport Vector3 from '../math/Vector3';\nimport Matrix4 from '../math/Matrix4';\nimport Renderable from '../Renderable';\nimport glenum from '../core/glenum';\nimport glmatrix from '../dep/glmatrix';\n\nvar vec3 = glmatrix.vec3;\n\n/**\n * @constructor clay.picking.RayPicking\n * @extends clay.core.Base\n */\nvar RayPicking = Base.extend(\n/** @lends clay.picking.RayPicking# */\n{\n    /**\n     * Target scene\n     * @type {clay.Scene}\n     */\n    scene: null,\n    /**\n     * Target camera\n     * @type {clay.Camera}\n     */\n    camera: null,\n    /**\n     * Target renderer\n     * @type {clay.Renderer}\n     */\n    renderer: null\n}, function () {\n    this._ray = new Ray();\n    this._ndc = new Vector2();\n},\n/** @lends clay.picking.RayPicking.prototype */\n{\n\n    /**\n     * Pick the nearest intersection object in the scene\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @param  {boolean} [forcePickAll=false] ignore ignorePicking\n     * @return {clay.picking.RayPicking~Intersection}\n     */\n    pick: function (x, y, forcePickAll) {\n        var out = this.pickAll(x, y, [], forcePickAll);\n        return out[0] || null;\n    },\n\n    /**\n     * Pick all intersection objects, wich will be sorted from near to far\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @param  {Array} [output]\n     * @param  {boolean} [forcePickAll=false] ignore ignorePicking\n     * @return {Array.<clay.picking.RayPicking~Intersection>}\n     */\n    pickAll: function (x, y, output, forcePickAll) {\n        this.renderer.screenToNDC(x, y, this._ndc);\n        this.camera.castRay(this._ndc, this._ray);\n\n        output = output || [];\n\n        this._intersectNode(this.scene, output, forcePickAll || false);\n\n        output.sort(this._intersectionCompareFunc);\n\n        return output;\n    },\n\n    _intersectNode: function (node, out, forcePickAll) {\n        if ((node instanceof Renderable) && node.isRenderable()) {\n            if ((!node.ignorePicking || forcePickAll)\n                && (\n                    // Only triangle mesh support ray picking\n                    (node.mode === glenum.TRIANGLES && node.geometry.isUseIndices())\n                    // Or if geometry has it's own pickByRay, pick, implementation\n                    || node.geometry.pickByRay\n                    || node.geometry.pick\n                )\n            ) {\n                this._intersectRenderable(node, out);\n            }\n        }\n        for (var i = 0; i < node._children.length; i++) {\n            this._intersectNode(node._children[i], out, forcePickAll);\n        }\n    },\n\n    _intersectRenderable: (function () {\n\n        var v1 = new Vector3();\n        var v2 = new Vector3();\n        var v3 = new Vector3();\n        var ray = new Ray();\n        var worldInverse = new Matrix4();\n\n        return function (renderable, out) {\n\n            var isSkinnedMesh = renderable.isSkinnedMesh();\n            ray.copy(this._ray);\n            Matrix4.invert(worldInverse, renderable.worldTransform);\n\n            // Skinned mesh will ignore the world transform.\n            if (!isSkinnedMesh) {\n                ray.applyTransform(worldInverse);\n            }\n\n            var geometry = renderable.geometry;\n            // Ignore bounding box of skinned mesh?\n            if (!isSkinnedMesh) {\n                if (geometry.boundingBox) {\n                    if (!ray.intersectBoundingBox(geometry.boundingBox)) {\n                        return;\n                    }\n                }\n            }\n            // Use user defined picking algorithm\n            if (geometry.pick) {\n                geometry.pick(\n                    this._ndc.x, this._ndc.y,\n                    this.renderer,\n                    this.camera,\n                    renderable, out\n                );\n                return;\n            }\n            // Use user defined ray picking algorithm\n            else if (geometry.pickByRay) {\n                geometry.pickByRay(ray, renderable, out);\n                return;\n            }\n\n            var cullBack = (renderable.cullFace === glenum.BACK && renderable.frontFace === glenum.CCW)\n                        || (renderable.cullFace === glenum.FRONT && renderable.frontFace === glenum.CW);\n\n            var point;\n            var indices = geometry.indices;\n            var positionAttr = geometry.attributes.position;\n            var weightAttr = geometry.attributes.weight;\n            var jointAttr = geometry.attributes.joint;\n            var skinMatricesArray;\n            var skinMatrices = [];\n            // Check if valid.\n            if (!positionAttr || !positionAttr.value || !indices) {\n                return;\n            }\n            if (isSkinnedMesh) {\n                skinMatricesArray = renderable.skeleton.getSubSkinMatrices(renderable.__uid__, renderable.joints);\n                for (var i = 0; i < renderable.joints.length; i++) {\n                    skinMatrices[i] = skinMatrices[i] || [];\n                    for (var k = 0; k < 16; k++) {\n                        skinMatrices[i][k] = skinMatricesArray[i * 16 + k];\n                    }\n                }\n                var pos = [];\n                var weight = [];\n                var joint = [];\n                var skinnedPos = [];\n                var tmp = [];\n                var skinnedPositionAttr = geometry.attributes.skinnedPosition;\n                if (!skinnedPositionAttr || !skinnedPositionAttr.value) {\n                    geometry.createAttribute('skinnedPosition', 'f', 3);\n                    skinnedPositionAttr = geometry.attributes.skinnedPosition;\n                    skinnedPositionAttr.init(geometry.vertexCount);\n                }\n                for (var i = 0; i < geometry.vertexCount; i++) {\n                    positionAttr.get(i, pos);\n                    weightAttr.get(i, weight);\n                    jointAttr.get(i, joint);\n                    weight[3] = 1 - weight[0] - weight[1] - weight[2];\n                    vec3.set(skinnedPos, 0, 0, 0);\n                    for (var k = 0; k < 4; k++) {\n                        if (joint[k] >= 0 && weight[k] > 1e-4) {\n                            vec3.transformMat4(tmp, pos, skinMatrices[joint[k]]);\n                            vec3.scaleAndAdd(skinnedPos, skinnedPos, tmp, weight[k]);\n                        }\n                    }\n                    skinnedPositionAttr.set(i, skinnedPos);\n                }\n            }\n\n            for (var i = 0; i < indices.length; i += 3) {\n                var i1 = indices[i];\n                var i2 = indices[i + 1];\n                var i3 = indices[i + 2];\n                var finalPosAttr = isSkinnedMesh\n                    ? geometry.attributes.skinnedPosition\n                    : positionAttr;\n                finalPosAttr.get(i1, v1.array);\n                finalPosAttr.get(i2, v2.array);\n                finalPosAttr.get(i3, v3.array);\n\n                if (cullBack) {\n                    point = ray.intersectTriangle(v1, v2, v3, renderable.culling);\n                }\n                else {\n                    point = ray.intersectTriangle(v1, v3, v2, renderable.culling);\n                }\n                if (point) {\n                    var pointW = new Vector3();\n                    if (!isSkinnedMesh) {\n                        Vector3.transformMat4(pointW, point, renderable.worldTransform);\n                    }\n                    else {\n                        // TODO point maybe not right.\n                        Vector3.copy(pointW, point);\n                    }\n                    out.push(new RayPicking.Intersection(\n                        point, pointW, renderable, [i1, i2, i3], i / 3,\n                        Vector3.dist(pointW, this._ray.origin)\n                    ));\n                }\n            }\n        };\n    })(),\n\n    _intersectionCompareFunc: function (a, b) {\n        return a.distance - b.distance;\n    }\n});\n\n/**\n * @constructor clay.picking.RayPicking~Intersection\n * @param {clay.math.Vector3} point\n * @param {clay.math.Vector3} pointWorld\n * @param {clay.Node} target\n * @param {Array.<number>} triangle\n * @param {number} triangleIndex\n * @param {number} distance\n */\nRayPicking.Intersection = function (point, pointWorld, target, triangle, triangleIndex, distance) {\n    /**\n     * Intersection point in local transform coordinates\n     * @type {clay.math.Vector3}\n     */\n    this.point = point;\n    /**\n     * Intersection point in world transform coordinates\n     * @type {clay.math.Vector3}\n     */\n    this.pointWorld = pointWorld;\n    /**\n     * Intersection scene node\n     * @type {clay.Node}\n     */\n    this.target = target;\n    /**\n     * Intersection triangle, which is an array of vertex index\n     * @type {Array.<number>}\n     */\n    this.triangle = triangle;\n    /**\n     * Index of intersection triangle.\n     */\n    this.triangleIndex = triangleIndex;\n    /**\n     * Distance from intersection point to ray origin\n     * @type {number}\n     */\n    this.distance = distance;\n};\n\nexport default RayPicking;\n","// Spherical Harmonic Helpers\nimport Texture from '../Texture';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture2D from '../Texture2D';\nimport Pass from '../compositor/Pass';\nimport vendor from '../core/vendor';\nimport Skybox from '../plugin/Skybox';\nimport Skydome from '../plugin/Skydome';\nimport EnvironmentMapPass from '../prePass/EnvironmentMap';\nimport Scene from '../Scene';\nimport glmatrix from '../dep/glmatrix';\nvar vec3 = glmatrix.vec3;\nvar sh = {};\n\nimport projectEnvMapShaderCode from './shader/projectEnvMap.glsl.js';\n\nvar targets = ['px', 'nx', 'py', 'ny', 'pz', 'nz'];\n\n// Project on gpu, but needs browser to support readPixels as Float32Array.\nfunction projectEnvironmentMapGPU(renderer, envMap) {\n    var shTexture = new Texture2D({\n        width: 9,\n        height: 1,\n        type: Texture.FLOAT\n    });\n    var pass = new Pass({\n        fragment: projectEnvMapShaderCode\n    });\n    pass.material.define('fragment', 'TEXTURE_SIZE', envMap.width);\n    pass.setUniform('environmentMap', envMap);\n\n    var framebuffer = new FrameBuffer();\n    framebuffer.attach(shTexture);\n    pass.render(renderer, framebuffer);\n\n    framebuffer.bind(renderer);\n    // TODO Only chrome and firefox support Float32Array\n    var pixels = new vendor.Float32Array(9 * 4);\n    renderer.gl.readPixels(0, 0, 9, 1, Texture.RGBA, Texture.FLOAT, pixels);\n\n    var coeff = new vendor.Float32Array(9 * 3);\n    for (var i = 0; i < 9; i++) {\n        coeff[i * 3] = pixels[i * 4];\n        coeff[i * 3 + 1] = pixels[i * 4 + 1];\n        coeff[i * 3 + 2] = pixels[i * 4 + 2];\n    }\n    framebuffer.unbind(renderer);\n\n    framebuffer.dispose(renderer);\n    pass.dispose(renderer);\n    return coeff;\n}\n\nfunction harmonics(normal, index){\n    var x = normal[0];\n    var y = normal[1];\n    var z = normal[2];\n\n    if (index === 0) {\n        return 1.0;\n    }\n    else if (index === 1) {\n        return x;\n    }\n    else if (index === 2) {\n        return y;\n    }\n    else if (index === 3) {\n        return z;\n    }\n    else if (index === 4) {\n        return x * z;\n    }\n    else if (index === 5) {\n        return y * z;\n    }\n    else if (index === 6) {\n        return x * y;\n    }\n    else if (index === 7) {\n        return 3.0 * z * z - 1.0;\n    }\n    else {\n        return x * x - y * y;\n    }\n}\n\nvar normalTransform = {\n    px: [2, 1, 0, -1, -1, 1],\n    nx: [2, 1, 0, 1, -1, -1],\n    py: [0, 2, 1, 1, -1, -1],\n    ny: [0, 2, 1, 1, 1, 1],\n    pz: [0, 1, 2, -1, -1, -1],\n    nz: [0, 1, 2, 1, -1, 1]\n};\n\n// Project on cpu.\nfunction projectEnvironmentMapCPU(renderer, cubePixels, width, height) {\n    var coeff = new vendor.Float32Array(9 * 3);\n    var normal = vec3.create();\n    var texel = vec3.create();\n    var fetchNormal = vec3.create();\n    for (var m = 0; m < 9; m++) {\n        var result = vec3.create();\n        for (var k = 0; k < targets.length; k++) {\n            var pixels = cubePixels[targets[k]];\n\n            var sideResult = vec3.create();\n            var divider = 0;\n            var i = 0;\n            var transform = normalTransform[targets[k]];\n            for (var y = 0; y < height; y++) {\n                for (var x = 0; x < width; x++) {\n\n                    normal[0] = x / (width - 1.0) * 2.0 - 1.0;\n                    // TODO Flip y?\n                    normal[1] = y / (height - 1.0) * 2.0 - 1.0;\n                    normal[2] = -1.0;\n                    vec3.normalize(normal, normal);\n\n                    fetchNormal[0] = normal[transform[0]] * transform[3];\n                    fetchNormal[1] = normal[transform[1]] * transform[4];\n                    fetchNormal[2] = normal[transform[2]] * transform[5];\n\n                    texel[0] = pixels[i++] / 255;\n                    texel[1] = pixels[i++] / 255;\n                    texel[2] = pixels[i++] / 255;\n                    // RGBM Decode\n                    var scale = pixels[i++] / 255 * 51.5;\n                    texel[0] *= scale;\n                    texel[1] *= scale;\n                    texel[2] *= scale;\n\n                    vec3.scaleAndAdd(sideResult, sideResult, texel, harmonics(fetchNormal, m) * -normal[2]);\n                    // -normal.z equals cos(theta) of Lambertian\n                    divider += -normal[2];\n                }\n            }\n            vec3.scaleAndAdd(result, result, sideResult, 1 / divider);\n        }\n\n        coeff[m * 3] = result[0] / 6.0;\n        coeff[m * 3 + 1] = result[1] / 6.0;\n        coeff[m * 3 + 2] = result[2] / 6.0;\n    }\n    return coeff;\n}\n\n/**\n * @param  {clay.Renderer} renderer\n * @param  {clay.Texture} envMap\n * @param  {Object} [textureOpts]\n * @param  {Object} [textureOpts.lod]\n * @param  {boolean} [textureOpts.decodeRGBM]\n */\nsh.projectEnvironmentMap = function (renderer, envMap, opts) {\n\n    // TODO sRGB\n\n    opts = opts || {};\n    opts.lod = opts.lod || 0;\n\n    var skybox;\n    var dummyScene = new Scene();\n    var size = 64;\n    if (envMap instanceof Texture2D) {\n        skybox = new Skydome({\n            scene: dummyScene,\n            environmentMap: envMap\n        });\n    }\n    else {\n        size = (envMap.image && envMap.image.px) ? envMap.image.px.width : envMap.width;\n        skybox = new Skybox({\n            scene: dummyScene,\n            environmentMap: envMap\n        });\n    }\n    // Convert to rgbm\n    var width = Math.ceil(size / Math.pow(2, opts.lod));\n    var height = Math.ceil(size / Math.pow(2, opts.lod));\n    var rgbmTexture = new Texture2D({\n        width: width,\n        height: height\n    });\n    var framebuffer = new FrameBuffer();\n    skybox.material.define('fragment', 'RGBM_ENCODE');\n    if (opts.decodeRGBM) {\n        skybox.material.define('fragment', 'RGBM_DECODE');\n    }\n    skybox.material.set('lod', opts.lod);\n    var envMapPass = new EnvironmentMapPass({\n        texture: rgbmTexture\n    });\n    var cubePixels = {};\n    for (var i = 0; i < targets.length; i++) {\n        cubePixels[targets[i]] = new Uint8Array(width * height * 4);\n        var camera = envMapPass.getCamera(targets[i]);\n        camera.fov = 90;\n        framebuffer.attach(rgbmTexture);\n        framebuffer.bind(renderer);\n        renderer.render(dummyScene, camera);\n        renderer.gl.readPixels(\n            0, 0, width, height,\n            Texture.RGBA, Texture.UNSIGNED_BYTE, cubePixels[targets[i]]\n        );\n        framebuffer.unbind(renderer);\n    }\n\n    skybox.dispose(renderer);\n    framebuffer.dispose(renderer);\n    rgbmTexture.dispose(renderer);\n\n    return projectEnvironmentMapCPU(renderer, cubePixels, width, height);\n};\n\nexport default sh;\n","\n/**\n * Helpers for creating a common 3d application.\n * @namespace clay.application\n */\n\n // TODO createCompositor\n // TODO mobile. scroll events.\n // TODO Dispose test. geoCache test.\n // TODO fitModel, normal generation.\n // TODO Skybox, Skydome.\n // TODO Particle ?\nimport Renderer from './Renderer';\nimport Scene from './Scene';\nimport Timeline from './animation/Timeline';\nimport CubeGeo from './geometry/Cube';\nimport SphereGeo from './geometry/Sphere';\nimport PlaneGeo from './geometry/Plane';\nimport Texture2D from './Texture2D';\nimport Texture from './Texture';\nimport shaderLibrary from './shader/library';\nimport Mesh from './Mesh';\nimport Material from './Material';\nimport PerspectiveCamera from './camera/Perspective';\nimport OrthographicCamera from './camera/Orthographic';\nimport Vector3 from './math/Vector3';\nimport GLTFLoader from './loader/GLTF';\nimport Node from './Node';\nimport DirectionalLight from './light/Directional';\nimport PointLight from './light/Point';\nimport SpotLight from './light/Spot';\nimport AmbientLight from './light/Ambient';\nimport AmbientCubemapLight from './light/AmbientCubemap';\nimport AmbientSHLight from './light/AmbientSH';\nimport ShadowMapPass from './prePass/ShadowMap';\nimport RayPicking from './picking/RayPicking';\nimport LRUCache from './core/LRU';\nimport util from './core/util';\nimport shUtil from './util/sh';\nimport textureUtil from './util/texture';\n\nimport colorUtil from './core/color';\nvar parseColor = colorUtil.parseToFloat;\n\nimport './shader/builtin';\nimport Shader from './Shader';\n\n/**\n * @typedef {string|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} ImageLike\n */\n/**\n * @typedef {string|Array.<number>} Color\n */\n/**\n * @typedef {HTMLDomElement|string} DomQuery\n */\n\n/**\n * @constructor\n * @alias clay.application.App3D\n * @param {DomQuery} dom Container dom element or a selector string that can be used in `querySelector`\n * @param {Object} appNS\n * @param {Function} appNS.init Initialization callback that will be called when initing app.\n *                      You can return a promise in init to start the loop asynchronously when the promise is resolved.\n * @param {Function} appNS.loop Loop callback that will be called each frame.\n * @param {Function} appNS.beforeRender\n * @param {Function} appNS.afterRender\n * @param {number} [appNS.width] Container width.\n * @param {number} [appNS.height] Container height.\n * @param {number} [appNS.devicePixelRatio]\n * @param {Object} [appNS.graphic] Graphic configuration including shadow, postEffect\n * @param {boolean} [appNS.graphic.shadow=false] If enable shadow\n * @param {boolean} [appNS.graphic.linear=false] If use linear space\n * @param {boolean} [appNS.graphic.tonemapping=false] If enable ACES tone mapping.\n * @param {boolean} [appNS.event=false] If enable mouse/touch event. It will slow down the system if geometries are complex.\n */\nfunction App3D(dom, appNS) {\n\n    appNS = appNS || {};\n    appNS.graphic = appNS.graphic || {};\n\n    if (typeof dom === 'string') {\n        dom = document.querySelector(dom);\n    }\n\n    if (!dom) { throw new Error('Invalid dom'); }\n\n    var isDomCanvas = dom.nodeName.toUpperCase() === 'CANVAS';\n    var rendererOpts = {};\n    isDomCanvas && (rendererOpts.canvas = dom);\n    appNS.devicePixelRatio && (rendererOpts.devicePixelRatio = appNS.devicePixelRatio);\n\n    var gRenderer = new Renderer(rendererOpts);\n    var gWidth = appNS.width || dom.clientWidth;\n    var gHeight = appNS.height || dom.clientHeight;\n\n    var gScene = new Scene();\n    var gTimeline = new Timeline();\n    var gShadowPass = appNS.graphic.shadow && new ShadowMapPass();\n    var gRayPicking = appNS.event && new RayPicking({\n        scene: gScene,\n        renderer: gRenderer\n    });\n\n    !isDomCanvas && dom.appendChild(gRenderer.canvas);\n\n    gRenderer.resize(gWidth, gHeight);\n\n    var gFrameTime = 0;\n    var gElapsedTime = 0;\n\n    gTimeline.start();\n\n    Object.defineProperties(this, {\n        /**\n         * Container dom element\n         * @name clay.application.App3D#container\n         * @type {HTMLDomElement}\n         */\n        container: { get: function () { return dom; } },\n        /**\n         * @name clay.application.App3D#renderer\n         * @type {clay.Renderer}\n         */\n        renderer: { get: function () { return gRenderer; }},\n        /**\n         * @name clay.application.App3D#scene\n         * @type {clay.Renderer}\n         */\n        scene: { get: function () { return gScene; }},\n        /**\n         * @name clay.application.App3D#timeline\n         * @type {clay.Renderer}\n         */\n        timeline: { get: function () { return gTimeline; }},\n        /**\n         * Time elapsed since last frame. Can be used in loop to calculate the movement.\n         * @name clay.application.App3D#frameTime\n         * @type {number}\n         */\n        frameTime: { get: function () { return gFrameTime; }},\n        /**\n         * Time elapsed since application created.\n         * @name clay.application.App3D#elapsedTime\n         * @type {number}\n         */\n        elapsedTime: { get: function () { return gElapsedTime; }}\n    });\n\n    /**\n     * Resize the application. Will use the container clientWidth/clientHeight if width/height in parameters are not given.\n     * @function\n     * @memberOf {clay.application.App3D}\n     * @param {number} [width]\n     * @param {number} [height]\n     */\n    this.resize = function (width, height) {\n        gWidth = width || appNS.width || dom.clientWidth;\n        gHeight = height || dom.height || dom.clientHeight;\n        gRenderer.resize(gWidth, gHeight);\n    };\n\n    /**\n     * Dispose the application\n     * @function\n     */\n    this.dispose = function () {\n        this._disposed = true;\n\n        if (appNS.dispose) {\n            appNS.dispose(this);\n        }\n        gTimeline.stop();\n        gRenderer.disposeScene(gScene);\n        gShadowPass && gShadowPass.dispose(gRenderer);\n\n        dom.innerHTML = '';\n        ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) {\n            this[makeHandlerName(eveType)] && dom.removeEventListener(makeHandlerName(eveType));\n        });\n    };\n\n    gRayPicking && this._initMouseEvents(gRayPicking);\n\n    this._geoCache = new LRUCache(20);\n    this._texCache = new LRUCache(20);\n\n    // Do init the application.\n    var initPromise = Promise.resolve(appNS.init && appNS.init(this));\n    // Use the inited camera.\n    gRayPicking && (gRayPicking.camera = gScene.getMainCamera());\n\n    var gTexturesList = {};\n    var gGeometriesList = {};\n\n    if (!appNS.loop) {\n        console.warn('Miss loop method.');\n    }\n\n    var self = this;\n    initPromise.then(function () {\n        appNS.loop && gTimeline.on('frame', function (frameTime) {\n            gFrameTime = frameTime;\n            gElapsedTime += frameTime;\n            appNS.loop(self);\n\n            gScene.update();\n            self._updateGraphicOptions(appNS.graphic, gScene.opaqueList);\n            self._updateGraphicOptions(appNS.graphic, gScene.transparentList);\n\n            gRayPicking && (gRayPicking.camera = gScene.getMainCamera());\n            // Render shadow pass\n            gShadowPass && gShadowPass.render(gRenderer, gScene, null, true);\n\n            appNS.beforeRender && appNS.beforeRender(self);\n            self._doRender(gRenderer, gScene, true);\n            appNS.afterRender && appNS.afterRender(self);\n\n            // Mark all resources unused;\n            markUnused(gTexturesList);\n            markUnused(gGeometriesList);\n\n            // Collect resources used in this frame.\n            var newTexturesList = [];\n            var newGeometriesList = [];\n            collectResources(gScene, newTexturesList, newGeometriesList);\n\n            // Dispose those unsed resources.\n            checkAndDispose(gRenderer, gTexturesList);\n            checkAndDispose(gRenderer, gGeometriesList);\n\n            gTexturesList = newTexturesList;\n            gGeometriesList = newGeometriesList;\n        });\n    });\n}\n\nfunction isImageLikeElement(val) {\n    return val instanceof Image\n        || val instanceof HTMLCanvasElement\n        || val instanceof HTMLVideoElement;\n}\n\nfunction getKeyFromImageLike(val) {\n    typeof val === 'string'\n        ? val : (val.__key__ || (val.__key__ = util.genGUID()));\n}\n\nfunction makeHandlerName(eveType) {\n    return '_' + eveType + 'Handler';\n}\n\nfunction packageEvent(eventType, pickResult, offsetX, offsetY) {\n    var event = util.clone(pickResult);\n    event.type = eventType;\n    event.offsetX = offsetX;\n    event.offsetY = offsetY;\n    return event;\n}\n\nfunction bubblingEvent(target, event) {\n    while (target && !event.cancelBubble) {\n        target.trigger(event.type, event);\n        target = target.getParent();\n    }\n}\n\nApp3D.prototype._initMouseEvents = function (rayPicking) {\n    var dom = this.container;\n\n    var oldTarget = null;\n    ['click', 'dblclick', 'mouseover', 'mouseout', 'mousemove'].forEach(function (eveType) {\n        dom.addEventListener(eveType, this[makeHandlerName(eveType)] = function (e) {\n            if (!rayPicking.camera) { // Not have camera yet.\n                return;\n            }\n\n            var box = dom.getBoundingClientRect();\n            var offsetX = e.clientX - box.left;\n            var offsetY = e.clientY - box.top;\n\n            var pickResult = rayPicking.pick(offsetX, offsetY);\n\n            if (pickResult) {\n                // Just ignore silent element.\n                if (pickResult.target.silent) {\n                    return;\n                }\n\n                if (eveType === 'mousemove') {\n                    var targetChanged = pickResult.target !== oldTarget;\n                    if (targetChanged) {\n                        oldTarget && bubblingEvent(oldTarget, packageEvent('mouseout', {\n                            target: oldTarget\n                        }, offsetX, offsetY));\n                    }\n                    bubblingEvent(pickResult.target, packageEvent('mousemove', pickResult, offsetX, offsetY));\n                    if (targetChanged) {\n                        bubblingEvent(pickResult.target, packageEvent('mouseover', pickResult, offsetX, offsetY));\n                    }\n                }\n                else {\n                    bubblingEvent(pickResult.target, packageEvent(eveType, pickResult, offsetX, offsetY));\n                }\n                oldTarget = pickResult.target;\n            }\n            else if (oldTarget) {\n                bubblingEvent(oldTarget, packageEvent('mouseout', {\n                    target: oldTarget\n                }, offsetX, offsetY));\n                oldTarget = null;\n            }\n        });\n    }, this);\n};\n\nApp3D.prototype._updateGraphicOptions = function (graphicOpts, list) {\n    var enableTonemapping = !!graphicOpts.tonemapping;\n    var isLinearSpace = !!graphicOpts.linear;\n\n    var prevMaterial;\n\n    for (var i = 0; i < list.length; i++) {\n        var mat = list[i].material;\n        if (mat === prevMaterial) {\n            continue;\n        }\n\n        enableTonemapping ? mat.define('fragment', 'TONEMAPPING') : mat.undefine('fragment', 'TONEMAPPING');\n        if (isLinearSpace) {\n            mat.define('fragment', 'SRGB_ENCODE');\n            mat.define('fragment', 'SRGB_DECODE');\n        }\n        else {\n            mat.undefine('fragment', 'SRGB_ENCODE');\n            mat.undefine('fragment', 'SRGB_DECODE');\n        }\n\n        prevMaterial = mat;\n    }\n};\n\nApp3D.prototype._doRender = function (renderer, scene) {\n    var camera = scene.getMainCamera();\n    camera.aspect = renderer.getViewportAspect();\n    renderer.render(scene);\n};\n\n\nfunction markUnused(resourceList) {\n    for (var i = 0; i < resourceList.length; i++) {\n        resourceList[i].__used__ = 0;\n    }\n}\n\nfunction checkAndDispose(renderer, resourceList) {\n    for (var i = 0; i < resourceList.length; i++) {\n        if (!resourceList[i].__used__) {\n            resourceList[i].dispose(renderer);\n        }\n    }\n}\n\nfunction updateUsed(resource, list) {\n    resource.__used__ = resource.__used__ || 0;\n    resource.__used__++;\n    if (resource.__used__ === 1) {\n        // Don't push to the list twice.\n        list.push(resource);\n    }\n}\nfunction collectResources(scene, textureResourceList, geometryResourceList) {\n    function trackQueue(queue) {\n        var prevMaterial;\n        var prevGeometry;\n        for (var i = 0; i < queue.length; i++) {\n            var renderable = queue[i];\n            var geometry = renderable.geometry;\n            var material = renderable.material;\n\n            // TODO optimize!!\n            if (material !== prevMaterial) {\n                var textureUniforms = material.getTextureUniforms();\n                for (var u = 0; u < textureUniforms.length; u++) {\n                    var uniformName = textureUniforms[u];\n                    var val = material.uniforms[uniformName].value;\n                    if (!val) {\n                        continue;\n                    }\n                    if (val instanceof Texture) {\n                        updateUsed(val, textureResourceList);\n                    }\n                    else if (val instanceof Array) {\n                        for (var k = 0; k < val.length; k++) {\n                            if (val[k] instanceof Texture) {\n                                updateUsed(val[k], textureResourceList);\n                            }\n                        }\n                    }\n                }\n            }\n            if (geometry !== prevGeometry) {\n                updateUsed(geometry, geometryResourceList);\n            }\n\n            prevMaterial = material;\n            prevGeometry = geometry;\n        }\n    }\n\n    trackQueue(scene.opaqueList);\n    trackQueue(scene.transparentList);\n\n    for (var k = 0; k < scene.lights.length; k++) {\n        // Track AmbientCubemap\n        if (scene.lights[k].cubemap) {\n            updateUsed(scene.lights[k].cubemap, textureResourceList);\n        }\n    }\n}\n/**\n * Load a texture from image or string.\n * @param {ImageLike} img\n * @param {Object} [opts] Texture options.\n * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY}\n * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic}\n * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS}\n * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT}\n * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter}\n * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter}\n * @param {number} [opts.exposure] Only be used when source is a HDR image.\n * @param {boolean} [useCache] If use cache.\n * @return {Promise}\n * @example\n *  app.loadTexture('diffuseMap.jpg')\n *      .then(function (texture) {\n *          material.set('diffuseMap', texture);\n *      });\n */\nApp3D.prototype.loadTexture = function (urlOrImg, opts, useCache) {\n    var self = this;\n    var key = getKeyFromImageLike(urlOrImg);\n    if (useCache) {\n        if (this._texCache.get(key)) {\n            return this._texCache.get(key);\n        }\n    }\n    // TODO Promise ?\n    var promise = new Promise(function (resolve, reject) {\n        var texture = self.loadTextureSync(urlOrImg, opts);\n        if (!texture.isRenderable()) {\n            texture.success(function () {\n                if (self._disposed) {\n                    return;\n                }\n                resolve(texture);\n            });\n            texture.error(function () {\n                if (self._disposed) {\n                    return;\n                }\n                reject();\n            });\n        }\n        else {\n            resolve(texture);\n        }\n    });\n    if (useCache) {\n        this._texCache.put(key, promise);\n    }\n    return promise;\n};\n\n/**\n * Create a texture from image or string synchronously. Texture can be use directly and don't have to wait for it's loaded.\n * @param {ImageLike} img\n * @param {Object} [opts] Texture options.\n * @param {boolean} [opts.flipY=true] If flipY. See {@link clay.Texture.flipY}\n * @param {number} [opts.anisotropic] Anisotropic filtering. See {@link clay.Texture.anisotropic}\n * @param {number} [opts.wrapS=clay.Texture.REPEAT] See {@link clay.Texture.wrapS}\n * @param {number} [opts.wrapT=clay.Texture.REPEAT] See {@link clay.Texture.wrapT}\n * @param {number} [opts.minFilter=clay.Texture.LINEAR_MIPMAP_LINEAR] See {@link clay.Texture.minFilter}\n * @param {number} [opts.magFilter=clay.Texture.LINEAR] See {@link clay.Texture.magFilter}\n * @param {number} [opts.exposure] Only be used when source is a HDR image.\n * @return {Promise}\n * @example\n *  var texture = app.loadTexture('diffuseMap.jpg', {\n *      anisotropic: 8,\n *      flipY: false\n *  });\n *  material.set('diffuseMap', texture);\n */\nApp3D.prototype.loadTextureSync = function (urlOrImg, opts) {\n    var texture = new Texture2D(opts);\n    if (typeof urlOrImg === 'string') {\n        if (urlOrImg.match(/.hdr$|^data:application\\/octet-stream/)) {\n            texture = textureUtil.loadTexture(urlOrImg, {\n                exposure: opts && opts.exposure,\n                fileType: 'hdr'\n            }, function () {\n                texture.dirty();\n                texture.trigger('success');\n            });\n        }\n        else {\n            texture.load(urlOrImg);\n        }\n    }\n    else if (isImageLikeElement(urlOrImg)) {\n        texture.image = urlOrImg;\n        texture.dynamic = urlOrImg instanceof HTMLVideoElement;\n    }\n    return texture;\n};\n\n/**\n * Create a material.\n * @param {Object} materialConfig. materialConfig contains `shader`, `transparent` and uniforms that used in corresponding uniforms.\n *                                 Uniforms can be `color`, `alpha` `diffuseMap` etc.\n * @param {string|clay.Shader} [shader='clay.standardMR'] Default to be standard shader with metalness and roughness workflow.\n * @param {boolean} [transparent=false] If material is transparent.\n * @return {clay.Material}\n */\nApp3D.prototype.createMaterial = function (matConfig) {\n    matConfig = matConfig || {};\n    matConfig.shader = matConfig.shader || 'clay.standardMR';\n    var shader = matConfig.shader instanceof Shader ? matConfig.shader : shaderLibrary.get(matConfig.shader);\n    var material = new Material({\n        shader: shader\n    });\n    function makeTextureSetter(key) {\n        return function (texture) {\n            material.setUniform(key, texture);\n        };\n    }\n    for (var key in matConfig) {\n        if (material.uniforms[key]) {\n            var val = matConfig[key];\n            if (material.uniforms[key].type === 't' || isImageLikeElement(val)) {\n                // Try to load a texture.\n                this.loadTexture(val).then(makeTextureSetter(key));\n            }\n            else {\n                material.setUniform(key, val);\n            }\n        }\n    }\n\n    if (matConfig.transparent) {\n        matConfig.depthMask = false;\n        matConfig.transparent = true;\n    }\n    return material;\n};\n\n/**\n * Create a cube mesh and add it to the scene or the given parent node.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of cube.\n *          Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a white cube.\n *  app.createCube()\n */\nApp3D.prototype.createCube = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv, subdiv];\n    }\n\n    var geoKey = 'cube-' + subdiv.join('-');\n    var cube = this._geoCache.get(geoKey);\n    if (!cube) {\n        cube = new CubeGeo({\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1],\n            depthSegments: subdiv[2]\n        });\n        this._geoCache.put(geoKey, cube);\n    }\n    return this.createMesh(cube, material, parentNode);\n};\n\n/**\n * Create a cube mesh that camera is inside the cube.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of cube.\n *          Can be a number to represent both width, height and depth dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a white cube inside.\n *  app.createCubeInside()\n */\nApp3D.prototype.createCubeInside = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv, subdiv];\n    }\n    var geoKey = 'cubeInside-' + subdiv.join('-');\n    var cube = this._geoCache.get(geoKey);\n    if (!cube) {\n        cube = new CubeGeo({\n            inside: true,\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1],\n            depthSegments: subdiv[2]\n        });\n        this._geoCache.put(geoKey, cube);\n    }\n\n    return this.createMesh(cube, material, parentNode);\n};\n\n/**\n * Create a sphere mesh and add it to the scene or the given parent node.\n * @function\n * @param {number} [subdivision=20] Subdivision of sphere.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a semi-transparent sphere.\n *  app.createSphere(20, {\n *      color: [0, 0, 1],\n *      transparent: true,\n *      alpha: 0.5\n *  })\n */\nApp3D.prototype.createSphere = function (subdivision, material, parentNode) {\n    if (subdivision == null) {\n        subdivision = 20;\n    }\n    var geoKey = 'sphere-' + subdivision;\n    var sphere = this._geoCache.get(geoKey);\n    if (!sphere) {\n        sphere = new SphereGeo({\n            widthSegments: subdivision * 2,\n            heightSegments: subdivision\n        });\n        this._geoCache.put(geoKey, sphere);\n    }\n    return this.createMesh(sphere, material, parentNode);\n};\n\n/**\n * Create a plane mesh and add it to the scene or the given parent node.\n * @function\n * @param {Array.<number>|number} [subdivision=1] Subdivision of plane.\n *          Can be a number to represent both width and height dimensions. Or an array to represent them respectively.\n * @param {Object|clay.Material} [material]\n * @param {clay.Node} [parentNode] Parent node to append. Default to be scene.\n * @return {clay.Mesh}\n * @example\n *  // Create a red color plane.\n *  app.createPlane(1, {\n *      color: [1, 0, 0]\n *  })\n */\nApp3D.prototype.createPlane = function (subdiv, material, parentNode) {\n    if (subdiv == null) {\n        subdiv = 1;\n    }\n    if (typeof subdiv === 'number') {\n        subdiv = [subdiv, subdiv];\n    }\n    var geoKey = 'plane-' + subdiv.join('-');\n    var planeGeo = this._geoCache.get(geoKey);\n    if (!planeGeo) {\n        planeGeo = new PlaneGeo({\n            widthSegments: subdiv[0],\n            heightSegments: subdiv[1]\n        });\n        this._geoCache.put(geoKey, planeGeo);\n    }\n    return this.createMesh(planeGeo, material, parentNode);\n};\n\n/**\n * Create a general mesh with given geometry instance and material config.\n * @param {*} geometry\n */\nApp3D.prototype.createMesh = function (geometry, mat, parentNode) {\n    var mesh = new Mesh({\n        geometry: geometry,\n        material: mat instanceof Material ? mat : this.createMaterial(mat)\n    });\n    parentNode = parentNode || this.scene;\n    parentNode.add(mesh);\n    return mesh;\n};\n\n/**\n * Create a perspective or orthographic camera and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} position\n * @param {Array.<number>|clay.math.Vector3} target\n * @param {string} [type=\"perspective\"] Can be 'perspective' or 'orthographic'(in short 'ortho')\n * @return {clay.camera.Perspective}\n */\nApp3D.prototype.createCamera = function (position, target, type) {\n    var CameraCtor;\n    if (type === 'ortho' || type === 'orthographic') {\n        CameraCtor = OrthographicCamera;\n    }\n    else {\n        if (type && type !== 'perspective') {\n            console.error('Unkown camera type ' + type + '. Use default perspective camera');\n        }\n        CameraCtor = PerspectiveCamera;\n    }\n\n    var camera = new CameraCtor();\n    if (position instanceof Vector3) {\n        camera.position.copy(position);\n    }\n    else if (position instanceof Array) {\n        camera.position.setArray(position);\n    }\n\n    if (target instanceof Array) {\n        target = new Vector3(target[0], target[1], target[2]);\n    }\n    if (target instanceof Vector3) {\n        camera.lookAt(target);\n    }\n\n    this.scene.add(camera);\n\n    return camera;\n};\n\n/**\n * Create a directional light and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} dir A Vector3 or array to represent the direction.\n * @param {Color} [color='#fff'] Color of directional light, default to be white.\n * @param {number} [intensity] Intensity of directional light, default to be 1.\n *\n * @example\n *  app.createDirectionalLight([-1, -1, -1], '#fff', 2);\n */\nApp3D.prototype.createDirectionalLight = function (dir, color, intensity) {\n    var light = new DirectionalLight();\n    if (dir instanceof Vector3) {\n        dir = dir.array;\n    }\n    light.position.setArray(dir).negate();\n    light.lookAt(Vector3.ZERO);\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n    return light;\n};\n\n/**\n * Create a spot light and add it to the scene.\n * @param {Array.<number>|clay.math.Vector3} position Position of the spot light.\n * @param {Array.<number>|clay.math.Vector3} [target] Target position where spot light points to.\n * @param {number} [range=20] Falloff range of spot light. Default to be 20.\n * @param {Color} [color='#fff'] Color of spot light, default to be white.\n * @param {number} [intensity=1] Intensity of spot light, default to be 1.\n * @param {number} [umbraAngle=30] Umbra angle of spot light. Default to be 30 degree from the middle line.\n * @param {number} [penumbraAngle=45] Penumbra angle of spot light. Default to be 45 degree from the middle line.\n *\n * @example\n *  app.createSpotLight([5, 5, 5], [0, 0, 0], 20, #900);\n */\nApp3D.prototype.createSpotLight = function (position, target, range, color, intensity, umbraAngle, penumbraAngle) {\n    var light = new SpotLight();\n    light.position.setArray(position instanceof Vector3 ? position.array : position);\n\n    if (target instanceof Array) {\n        target = new Vector3(target[0], target[1], target[2]);\n    }\n    if (target instanceof Vector3) {\n        light.lookAt(target);\n    }\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    range != null && (light.range = range);\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n    umbraAngle != null && (light.umbraAngle = umbraAngle);\n    penumbraAngle != null && (light.penumbraAngle = penumbraAngle);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create a point light.\n * @param {Array.<number>|clay.math.Vector3} position Position of point light..\n * @param {number} [range=100] Falloff range of point light.\n * @param {Color} [color='#fff'] Color of point light.\n * @param {number} [intensity=1] Intensity of point light.\n */\nApp3D.prototype.createPointLight = function (position, range, color, intensity) {\n    var light = new PointLight();\n    light.position.setArray(position instanceof Vector3 ? position.array : position);\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    range != null && (light.range = range);\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create a ambient light.\n * @param {Color} [color='#fff'] Color of ambient light.\n * @param {number} [intensity=1] Intensity of ambient light.\n */\nApp3D.prototype.createAmbientLight = function (color, intensity) {\n    var light = new AmbientLight();\n\n    if (typeof color === 'string') {\n        color = parseColor(color);\n    }\n    color != null && (light.color = color);\n    intensity != null && (light.intensity = intensity);\n\n    this.scene.add(light);\n\n    return light;\n};\n\n/**\n * Create an cubemap ambient light and an spherical harmonic ambient light\n * for specular and diffuse lighting in PBR rendering\n * @param {ImageLike} [envImage] Panorama environment image, HDR format is better.\n * @param {number} [specularIntenstity=0.7] Intensity of specular light.\n * @param {number} [diffuseIntenstity=0.7] Intensity of diffuse light.\n * @param {number} [exposure=1] Exposure of HDR image. Only if image in first paramter is HDR.\n * @param {number} [prefilteredCubemapSize=32] The size of prefilerted cubemap. Larger value will take more time to do expensive prefiltering.\n */\nApp3D.prototype.createAmbientCubemapLight = function (envImage, specIntensity, diffIntensity, exposure, prefilteredCubemapSize) {\n    var self = this;\n    if (exposure == null) {\n        exposure = 1;\n    }\n    if (prefilteredCubemapSize == null) {\n        prefilteredCubemapSize = 32;\n    }\n\n    var scene = this.scene;\n\n    return this.loadTexture(envImage, {\n        exposure: exposure\n    }).then(function (envTexture) {\n        var specLight = new AmbientCubemapLight({\n            intensity: specIntensity != null ? specIntensity : 0.7\n        });\n        specLight.cubemap = envTexture;\n        envTexture.flipY = false;\n        // TODO Cache prefilter ?\n        specLight.prefilter(self.renderer, 32);\n\n        var diffLight = new AmbientSHLight({\n            intensity: diffIntensity != null ? diffIntensity : 0.7,\n            coefficients: shUtil.projectEnvironmentMap(\n                self.renderer, specLight.cubemap, {\n                    lod: 1\n                }\n            )\n        });\n        scene.add(specLight);\n        scene.add(diffLight);\n\n        return {\n            specular: specLight,\n            diffuse: diffLight,\n            // Original environment map\n            environmentMap: envTexture\n        };\n    });\n};\n\n/**\n * Load a [glTF](https://github.com/KhronosGroup/glTF) format model.\n * You can convert FBX/DAE/OBJ format models to [glTF](https://github.com/KhronosGroup/glTF) with [fbx2gltf](https://github.com/pissang/claygl#fbx-to-gltf20-converter) python script,\n * or simply using the [Clay Viewer](https://github.com/pissang/clay-viewer) client application.\n * @param {string} url\n * @param {Object} opts\n * @param {string|clay.Shader} [opts.shader='clay.standard'] 'basic'|'lambert'|'standard'.\n * @param {boolean} [opts.waitTextureLoaded=false] If add to scene util textures are all loaded.\n * @param {boolean} [opts.autoPlayAnimation=true] If autoplay the animation of model.\n * @param {boolean} [opts.upAxis='y'] Change model to y up if upAxis is 'z'\n * @param {boolean} [opts.textureFlipY=false]\n * @param {string} [opts.textureRootPath] Root path of texture. Default to be relative with glTF file.\n * @return {Promise}\n */\nApp3D.prototype.loadModel = function (url, opts) {\n    if (typeof url !== 'string') {\n        throw new Error('Invalid URL.');\n    }\n\n    opts = opts || {};\n    if (opts.autoPlayAnimation == null) {\n        opts.autoPlayAnimation = true;\n    }\n    var shader = opts.shader || 'clay.standard';\n\n    var loaderOpts = {\n        rootNode: new Node(),\n        shader: shader,\n        textureRootPath: opts.textureRootPath,\n        crossOrigin: 'Anonymous',\n        textureFlipY: opts.textureFlipY\n    };\n    if (opts.upAxis && opts.upAxis.toLowerCase() === 'z') {\n        loaderOpts.rootNode.rotation.identity().rotateX(-Math.PI / 2);\n    }\n\n    var loader = new GLTFLoader(loaderOpts);\n\n    var scene = this.scene;\n    var timeline = this.timeline;\n    var self = this;\n\n    return new Promise(function (resolve, reject) {\n        function afterLoad(result) {\n            if (self._disposed) {\n                return;\n            }\n\n            scene.add(result.rootNode);\n            if (opts.autoPlayAnimation) {\n                result.clips.forEach(function (clip) {\n                    timeline.addClip(clip);\n                });\n            }\n            resolve(result);\n        }\n        loader.success(function (result) {\n            if (self._disposed) {\n                return;\n            }\n\n            if (!opts.waitTextureLoaded) {\n                afterLoad(result);\n            }\n            else {\n                Promise.all(result.textures.map(function (texture) {\n                    if (texture.isRenderable()) {\n                        return Promise.resolve(texture);\n                    }\n                    return new Promise(function (resolve) {\n                        texture.success(resolve);\n                        texture.error(resolve);\n                    });\n                })).then(function () {\n                    afterLoad(result);\n                }).catch(function () {\n                    afterLoad(result);\n                });\n            }\n        });\n        loader.error(function () {\n            reject();\n        });\n        loader.load(url);\n    });\n};\n\n\nexport default {\n    App3D: App3D,\n    /**\n     * Create a 3D application that will manage the app initialization and loop.\n     * @name clay.application.create\n     * @param {HTMLDomElement|string} dom Container dom element or a selector string that can be used in `querySelector`\n     * @param {Object} appNS\n     * @param {Function} init Initialization callback that will be called when initing app.\n     * @param {Function} loop Loop callback that will be called each frame.\n     * @param {number} [width] Container width.\n     * @param {number} [height] Container height.\n     * @param {number} [devicePixelRatio]\n     * @return {clay.application.App3D}\n     *\n     * @example\n     *  clay.application.create('#app', {\n     *      init: function (app) {\n     *          app.createCube();\n     *          var camera = app.createCamera();\n     *          camera.position.set(0, 0, 2);\n     *      },\n     *      loop: function () { // noop }\n     *  })\n     */\n    create: function (dom, appNS) {\n        return new App3D(dom, appNS);\n    }\n};","import notifier from '../core/mixin/notifier';\nimport request from '../core/request';\nimport util  from '../core/util';\n\n/**\n * @constructor\n * @alias clay.async.Task\n * @mixes clay.core.mixin.notifier\n */\nvar Task = function() {\n    this._fullfilled = false;\n    this._rejected = false;\n};\n/**\n * Task successed\n * @param {} data\n */\nTask.prototype.resolve = function(data) {\n    this._fullfilled = true;\n    this._rejected = false;\n    this.trigger('success', data);\n};\n/**\n * Task failed\n * @param {} err\n */\nTask.prototype.reject = function(err) {\n    this._rejected = true;\n    this._fullfilled = false;\n    this.trigger('error', err);\n};\n/**\n * If task successed\n * @return {boolean}\n */\nTask.prototype.isFullfilled = function() {\n    return this._fullfilled;\n};\n/**\n * If task failed\n * @return {boolean}\n */\nTask.prototype.isRejected = function() {\n    return this._rejected;\n};\n/**\n * If task finished, either successed or failed\n * @return {boolean}\n */\nTask.prototype.isSettled = function() {\n    return this._fullfilled || this._rejected;\n};\n\nutil.extend(Task.prototype, notifier);\n\nfunction makeRequestTask(url, responseType) {\n    var task = new Task();\n    request.get({\n        url: url,\n        responseType: responseType,\n        onload: function(res) {\n            task.resolve(res);\n        },\n        onerror: function(error) {\n            task.reject(error);\n        }\n    });\n    return task;\n}\n/**\n * Make a request task\n * @param  {string|object|object[]|string[]} url\n * @param  {string} [responseType]\n * @example\n *     var task = Task.makeRequestTask('./a.json');\n *     var task = Task.makeRequestTask({\n *         url: 'b.bin',\n *         responseType: 'arraybuffer'\n *     });\n *     var tasks = Task.makeRequestTask(['./a.json', './b.json']);\n *     var tasks = Task.makeRequestTask([\n *         {url: 'a.json'},\n *         {url: 'b.bin', responseType: 'arraybuffer'}\n *     ]);\n * @return {clay.async.Task|clay.async.Task[]}\n */\nTask.makeRequestTask = function(url, responseType) {\n    if (typeof url === 'string') {\n        return makeRequestTask(url, responseType);\n    } else if (url.url) {   //  Configure object\n        var obj = url;\n        return makeRequestTask(obj.url, obj.responseType);\n    } else if (Array.isArray(url)) {  // Url list\n        var urlList = url;\n        var tasks = [];\n        urlList.forEach(function(obj) {\n            var url, responseType;\n            if (typeof obj === 'string') {\n                url = obj;\n            } else if (Object(obj) === obj) {\n                url = obj.url;\n                responseType = obj.responseType;\n            }\n            tasks.push(makeRequestTask(url, responseType));\n        });\n        return tasks;\n    }\n};\n/**\n * @return {clay.async.Task}\n */\nTask.makeTask = function() {\n    return new Task();\n};\n\nutil.extend(Task.prototype, notifier);\n\nexport default Task;\n","import util from '../core/util';\nimport Task from './Task';\n\n/**\n * @constructor\n * @alias clay.async.TaskGroup\n * @extends clay.async.Task\n */\nvar TaskGroup = function () {\n\n    Task.apply(this, arguments);\n\n    this._tasks = [];\n\n    this._fulfilledNumber = 0;\n\n    this._rejectedNumber = 0;\n};\n\nvar Ctor = function (){};\nCtor.prototype = Task.prototype;\nTaskGroup.prototype = new Ctor();\n\nTaskGroup.prototype.constructor = TaskGroup;\n\n/**\n * Wait for all given tasks successed, task can also be any notifier object which will trigger success and error events. Like {@link clay.Texture2D}, {@link clay.TextureCube}, {@link clay.loader.GLTF}.\n * @param  {Array.<clay.async.Task>} tasks\n * @chainable\n * @example\n *     // Load texture list\n *     var list = ['a.jpg', 'b.jpg', 'c.jpg']\n *     var textures = list.map(function (src) {\n *         var texture = new clay.Texture2D();\n *         texture.load(src);\n *         return texture;\n *     });\n *     var taskGroup = new clay.async.TaskGroup();\n *     taskGroup.all(textures).success(function () {\n *         // Do some thing after all textures loaded\n *     });\n */\nTaskGroup.prototype.all = function (tasks) {\n    var count = 0;\n    var self = this;\n    var data = [];\n    this._tasks = tasks;\n    this._fulfilledNumber = 0;\n    this._rejectedNumber = 0;\n\n    util.each(tasks, function (task, idx) {\n        if (!task || !task.once) {\n            return;\n        }\n        count++;\n        task.once('success', function (res) {\n            count--;\n\n            self._fulfilledNumber++;\n            // TODO\n            // Some tasks like texture, loader are not inherited from task\n            // We need to set the states here\n            task._fulfilled = true;\n            task._rejected = false;\n\n            data[idx] = res;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n        task.once('error', function () {\n\n            self._rejectedNumber ++;\n\n            task._fulfilled = false;\n            task._rejected = true;\n\n            self.reject(task);\n        });\n    });\n    if (count === 0) {\n        setTimeout(function () {\n            self.resolve(data);\n        });\n        return this;\n    }\n    return this;\n};\n/**\n * Wait for all given tasks finished, either successed or failed\n * @param  {Array.<clay.async.Task>} tasks\n * @return {clay.async.TaskGroup}\n */\nTaskGroup.prototype.allSettled = function (tasks) {\n    var count = 0;\n    var self = this;\n    var data = [];\n    if (tasks.length === 0) {\n        setTimeout(function () {\n            self.trigger('success', data);\n        });\n        return this;\n    }\n    this._tasks = tasks;\n\n    util.each(tasks, function (task, idx) {\n        if (!task || !task.once) {\n            return;\n        }\n        count++;\n        task.once('success', function (res) {\n            count--;\n\n            self._fulfilledNumber++;\n\n            task._fulfilled = true;\n            task._rejected = false;\n\n            data[idx] = res;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n        task.once('error', function (err) {\n            count--;\n\n            self._rejectedNumber++;\n\n            task._fulfilled = false;\n            task._rejected = true;\n\n            // TODO\n            data[idx] = null;\n            if (count === 0) {\n                self.resolve(data);\n            }\n        });\n    });\n    return this;\n};\n/**\n * Get successed sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getFulfilledNumber = function (recursive) {\n    if (recursive) {\n        var nFulfilled = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nFulfilled += task.getFulfilledNumber(recursive);\n            } else if(task._fulfilled) {\n                nFulfilled += 1;\n            }\n        }\n        return nFulfilled;\n    } else {\n        return this._fulfilledNumber;\n    }\n};\n\n/**\n * Get failed sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getRejectedNumber = function (recursive) {\n    if (recursive) {\n        var nRejected = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nRejected += task.getRejectedNumber(recursive);\n            } else if(task._rejected) {\n                nRejected += 1;\n            }\n        }\n        return nRejected;\n    } else {\n        return this._rejectedNumber;\n    }\n};\n\n/**\n * Get finished sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getSettledNumber = function (recursive) {\n\n    if (recursive) {\n        var nSettled = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nSettled += task.getSettledNumber(recursive);\n            } else if(task._rejected || task._fulfilled) {\n                nSettled += 1;\n            }\n        }\n        return nSettled;\n    } else {\n        return this._fulfilledNumber + this._rejectedNumber;\n    }\n};\n\n/**\n * Get all sub tasks number, recursive can be true if sub task is also a TaskGroup.\n * @param  {boolean} [recursive]\n * @return {number}\n */\nTaskGroup.prototype.getTaskNumber = function (recursive) {\n    if (recursive) {\n        var nTask = 0;\n        for (var i = 0; i < this._tasks.length; i++) {\n            var task = this._tasks[i];\n            if (task instanceof TaskGroup) {\n                nTask += task.getTaskNumber(recursive);\n            } else {\n                nTask += 1;\n            }\n        }\n        return nTask;\n    } else {\n        return this._tasks.length;\n    }\n};\n\nexport default TaskGroup;\n","import Base from '../core/Base';\n\nvar CanvasMaterial = Base.extend({\n\n    color: [1, 1, 1, 1],\n\n    opacity: 1,\n\n    pointSize: 0,\n\n    pointShape: 'rectangle'\n});\n\nexport default CanvasMaterial;\n","import Base from '../core/Base';\nimport glMatrix from '../dep/glmatrix';\nimport glenum from '../core/glenum';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\nvar vec3Set = vec3.set;\nvar vec3Create = vec3.create;\n\nvar vec4Create = vec4.create;\n\nvar round = Math.round;\n\nvar PRIMITIVE_TRIANGLE = 1;\nvar PRIMITIVE_LINE = 2;\nvar PRIMITIVE_POINT = 3;\n\nfunction PrimitivePool(constructor) {\n    this.ctor = constructor;\n\n    this._data = [];\n\n    this._size = 0;\n}\n\nPrimitivePool.prototype = {\n    pick: function () {\n        var data = this._data;\n        var size = this._size;\n        var obj = data[size];\n        if (! obj) {\n            // Constructor must have no parameters\n            obj = new this.ctor();\n            data[size] = obj;\n        }\n        this._size++;\n        return obj;\n    },\n\n    reset: function () {\n        this._size = 0;\n    },\n\n    shrink: function () {\n        this._data.length = this._size;\n    },\n\n    clear: function () {\n        this._data = [];\n        this._size = 0;\n    }\n}\n\nfunction Triangle() {\n    this.vertices = [vec4Create(), vec4Create(), vec4Create()];\n    this.color = vec4Create();\n\n    this.depth = 0;\n}\n\nTriangle.prototype.type = PRIMITIVE_TRIANGLE;\n\nfunction Point() {\n    // Here use an array to make it more convinient to proccessing in _setPrimitive method\n    this.vertices = [vec4Create()];\n\n    this.color = vec4Create();\n\n    this.depth = 0;\n}\n\nPoint.prototype.type = PRIMITIVE_POINT;\n\nfunction Line() {\n    this.vertices = [vec4Create(), vec4Create()];\n    this.color = vec4Create();\n\n    this.depth = 0;\n\n    this.lineWidth = 1;\n}\n\nLine.prototype.type = PRIMITIVE_LINE;\n\nfunction depthSortFunc(x, y) {\n    // Sort from far to near, which in depth of projection space is from larger to smaller\n    return y.depth - x.depth;\n}\n\nfunction vec3ToColorStr(v3) {\n    return 'rgb(' + round(v3[0] * 255) + ',' + round(v3[1] * 255) + ',' + round(v3[2] * 255) + ')';\n}\n\nfunction vec4ToColorStr(v4) {\n    return 'rgba(' + round(v4[0] * 255) + ',' + round(v4[1] * 255) + ',' + round(v4[2] * 255) + ',' + v4[3] + ')';\n}\n\nvar CanvasRenderer = Base.extend({\n\n    canvas: null,\n\n    _width: 100,\n\n    _height: 100,\n\n    devicePixelRatio: window.devicePixelRatio || 1.0,\n\n    color: [0.0, 0.0, 0.0, 0.0],\n\n    clear: true,\n\n    ctx: null,\n\n    // Cached primitive list, including triangle, line, point\n    _primitives: [],\n\n    // Triangle pool\n    _triangles: new PrimitivePool(Triangle),\n\n    // Line pool\n    _lines: new PrimitivePool(Line),\n\n    // Point pool\n    _points: new PrimitivePool(Point)\n}, function () {\n    if (! this.canvas) {\n        this.canvas = document.createElement('canvas');\n    }\n    var canvas = this.canvas;\n\n    try {\n        this.ctx = canvas.getContext('2d');\n        var ctx = this.ctx;\n        if (!ctx) {\n            throw new Error();\n        }\n    }\n    catch (e) {\n        throw 'Error creating WebGL Context ' + e;\n    }\n\n    this.resize();\n}, {\n\n    resize: function (width, height) {\n        var dpr = this.devicePixelRatio;\n        var canvas = this.canvas;\n        if (width != null) {\n            canvas.style.width = width + 'px';\n            canvas.style.height = height + 'px';\n            canvas.width = width * dpr;\n            canvas.height = height * dpr;\n\n            this._width = width;\n            this._height = height;\n        }\n        else {\n            this._width = canvas.width / dpr;\n            this._height = canvas.height / dpr;\n        }\n    },\n\n    getWidth: function () {\n        return this._width;\n    },\n\n    getHeight: function () {\n        return this._height;\n    },\n\n    getViewportAspect: function () {\n        return this._width / this._height;\n    },\n\n    render: function (scene, camera) {\n\n        if (this.clear) {\n            var color = this.color;\n            var ctx = this.ctx;\n            var dpr = this.devicePixelRatio;\n            var w = this._width * dpr;\n            var h = this._height * dpr;\n            if (color && color[3] === 0) {\n                ctx.clearRect(0, 0, w, h);\n            }\n            else {\n                // Has transparency\n                if (color[3] < 1) {\n                    ctx.clearRect(0, 0, w, h);\n                }\n                ctx.fillStyle = color.length === 4 ? vec4ToColorStr(color) : vec3ToColorStr(color);\n                ctx.fillRect(0, 0, w, h);\n            }\n        }\n\n        scene.update();\n        camera.update();\n\n        var opaqueList = scene.opaqueList;\n        var transparentList = scene.transparentList;\n        var sceneMaterial = scene.material;\n\n        var list = opaqueList.concat(transparentList);\n\n        this.renderPass(list, camera);\n    },\n\n    renderPass: function (list, camera) {\n        var viewProj = mat4.create();\n        mat4.multiply(viewProj, camera.projectionMatrix.array, camera.viewMatrix.array);\n        var worldViewProjMat = mat4.create();\n        var posViewSpace = vec3.create();\n\n        var primitives = this._primitives;\n        var trianglesPool = this._triangles;\n        var linesPool = this._lines;\n        var pointsPool = this._points;\n\n        trianglesPool.reset();\n        linesPool.reset();\n        pointsPool.reset();\n\n        var nPrimitive = 0;\n\n        var indices = [0, 0, 0];\n        var matColor = [];\n        for (var i = 0; i < list.length; i++) {\n            var renderable = list[i];\n\n            mat4.multiply(worldViewProjMat, viewProj, renderable.worldTransform.array);\n\n            var geometry = renderable.geometry;\n            var material = renderable.material;\n            var attributes = geometry.attributes;\n\n            // alpha is default 1\n            if (material.color.length == 3) {\n                vec3.copy(matColor, material.color);\n                matColor[3] = 1;\n            }\n            else {\n                vec4.copy(matColor, material.color);\n            }\n\n            var nVertex = geometry.vertexCount;\n            // Only support TRIANGLES, LINES, POINTS draw modes\n            switch (renderable.mode) {\n                case glenum.TRIANGLES:\n                    if (geometry.isUseIndices()) {\n                        var nFace = geometry.triangleCount;\n                        for (var j = 0; j < nFace; j++) {\n                            geometry.getFace(j, indices);\n\n                            var triangle = trianglesPool.pick();\n                            triangle.material = material;\n\n                            var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor);\n\n                            if (! clipped) {\n                                primitives[nPrimitive++] = triangle;\n                            }\n                        }\n                    }\n                    else {\n                        for (var j = 0; j < nVertex;) {\n                            indices[0] = j++;\n                            indices[1] = j++;\n                            indices[2] = j++;\n\n                            var triangle = trianglesPool.pick();\n                            triangle.material = material;\n\n                            var clipped = this._setPrimitive(triangle, indices, 3, attributes, worldViewProjMat, matColor);\n\n                            if (! clipped) {\n                                primitives[nPrimitive++] = triangle;\n                            }\n                        }\n                    }\n                    break;\n                case glenum.LINES:\n                    // LINES mode can't use face\n                    for (var j = 0; j < nVertex;) {\n                        indices[0] = j++;\n                        indices[1] = j++;\n                        var line = linesPool.pick();\n                        line.material = material;\n                        line.lineWidth = renderable.lineWidth;\n\n                        var clipped = this._setPrimitive(line, indices, 2, attributes, worldViewProjMat, matColor);\n\n                        if (! clipped) {\n                            primitives[nPrimitive++] = line;\n                        }\n                    }\n                    break;\n                case glenum.POINTS:\n                    for (var j = 0; j < nVertex; j++) {\n                        indices[0] = j;\n                        var point = pointsPool.pick();\n                        point.material = material;\n\n                        var clipped = this._setPrimitive(point, indices, 1, attributes, worldViewProjMat, matColor);\n\n                        if (! clipped) {\n                            primitives[nPrimitive++] = point;\n                        }\n                    }\n                    // POINTS mode can't use face\n                    break;\n            }\n        }\n\n        trianglesPool.shrink();\n        linesPool.shrink();\n        pointsPool.shrink();\n\n        primitives.length = nPrimitive;\n\n        primitives.sort(depthSortFunc);\n        this._drawPrimitives(primitives);\n    },\n\n    _setPrimitive: (function () {\n        var vertexColor = vec4Create();\n        return function (primitive, indices, size, attributes, worldViewProjMat, matColor) {\n            var colorAttrib = attributes.color;\n            var useVertexColor = colorAttrib.value && colorAttrib.value.length > 0;\n            var priColor = primitive.color;\n\n            primitive.depth = 0;\n            if (useVertexColor) {\n                vec4.set(priColor, 0, 0, 0, 0);\n            }\n\n            var clipped = true;\n\n            var percent = 1 / size;\n            for (var i = 0; i < size; i++) {\n                var coord = primitive.vertices[i];\n                attributes.position.get(indices[i], coord);\n                coord[3] = 1;\n                vec4.transformMat4(coord, coord, worldViewProjMat);\n                if (useVertexColor) {\n                    colorAttrib.get(indices[i], vertexColor);\n                    // Average vertex color\n                    // Each primitive only call fill or stroke once\n                    // So color must be the same\n                    vec4.scaleAndAdd(priColor, priColor, vertexColor, percent);\n                }\n\n                // Clipping\n                var x = coord[0];\n                var y = coord[1];\n                var z = coord[2];\n                var w = coord[3];\n\n                // TODO Point clipping\n                if (x > -w && x < w && y > -w && y < w && z > -w && z < w) {\n                    clipped = false;\n                }\n\n                var invW = 1 / w;\n                coord[0] = x * invW;\n                coord[1] = y * invW;\n                coord[2] = z * invW;\n                // Use primitive average depth;\n                primitive.depth += coord[2];\n            }\n\n            if (! clipped) {\n                primitive.depth /= size;\n\n                if (useVertexColor) {\n                    vec4.mul(priColor, priColor, matColor);\n                }\n                else {\n                    vec4.copy(priColor, matColor);\n                }\n            }\n\n            return clipped;\n        }\n    })(),\n\n    _drawPrimitives: function (primitives) {\n        var ctx = this.ctx;\n        ctx.save();\n\n        var prevMaterial;\n\n        var dpr = this.devicePixelRatio;\n        var width = this._width * dpr;\n        var height = this._height * dpr;\n        var halfWidth = width / 2;\n        var halfHeight = height / 2;\n\n        var prevLineWidth;\n        var prevStrokeColor;\n\n        for (var i = 0; i < primitives.length; i++) {\n            var primitive = primitives[i];\n            var vertices = primitive.vertices;\n\n            var primitiveType = primitive.type;\n            var material = primitive.material;\n            if (material !== prevMaterial) {\n                // Set material\n                ctx.globalAlpha = material.opacity;\n                prevMaterial = material;\n            }\n\n            var colorStr = vec4ToColorStr(primitive.color);\n            switch (primitiveType) {\n                case PRIMITIVE_TRIANGLE:\n                    var v0 = vertices[0];\n                    var v1 = vertices[1];\n                    var v2 = vertices[2];\n                    ctx.fillStyle = colorStr;\n                    ctx.beginPath();\n                    ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight);\n                    ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight);\n                    ctx.lineTo((v2[0] + 1) * halfWidth, (-v2[1] + 1) * halfHeight);\n                    ctx.closePath();\n                    ctx.fill();\n                    break;\n                case PRIMITIVE_LINE:\n                    var v0 = vertices[0];\n                    var v1 = vertices[1];\n                    var lineWidth = primitive.lineWidth;\n                    if (prevStrokeColor !== colorStr) {\n                        prevStrokeColor = ctx.strokeStyle = colorStr;\n                    }\n                    if (lineWidth !== prevLineWidth) {\n                        ctx.lineWidth = prevLineWidth = lineWidth;\n                    }\n                    ctx.beginPath();\n                    ctx.moveTo((v0[0] + 1) * halfWidth, (-v0[1] + 1) * halfHeight);\n                    ctx.lineTo((v1[0] + 1) * halfWidth, (-v1[1] + 1) * halfHeight);\n                    ctx.stroke();\n                    break;\n                case PRIMITIVE_POINT:\n                    var pointSize = material.pointSize;\n                    var pointShape = material.pointShape;\n                    var halfSize = pointSize / 2;\n                    if (pointSize > 0) {\n                        var v0 = vertices[0];\n                        var cx = (v0[0] + 1) * halfWidth;\n                        var cy = (-v0[1] + 1) * halfHeight;\n\n                        ctx.fillStyle = colorStr;\n                        if (pointShape === 'rectangle') {\n                            ctx.fillRect(cx - halfSize, cy - halfSize, pointSize, pointSize);\n                        }\n                        else if (pointShape === 'circle') {\n                            ctx.beginPath();\n                            ctx.arc(cx, cy, halfSize, 0, Math.PI * 2);\n                            ctx.fill();\n                        }\n                    }\n                    break;\n            }\n        }\n\n        ctx.restore();\n    },\n\n    dispose: function () {\n        this._triangles.clear();\n        this._lines.clear();\n        this._points.clear();\n        this._primitives = [];\n\n        this.ctx = null;\n        this.canvas = null;\n    }\n});\n\nexport default CanvasRenderer;\n","import Base from '../core/Base';\n\n// PENDING\n// Use topological sort ?\n\n/**\n * Node of graph based post processing.\n *\n * @constructor clay.compositor.Node\n * @extends clay.core.Base\n *\n */\nvar Node = Base.extend(function () {\n    return /** @lends clay.compositor.Node# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * Input links, will be updated by the graph\n         * @example:\n         *     inputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        inputLinks: {},\n\n        /**\n         * Output links, will be updated by the graph\n         * @example:\n         *     outputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        outputLinks: {},\n\n        // Save the output texture of previous frame\n        // Will be used when there exist a circular reference\n        _prevOutputTextures: {},\n        _outputTextures: {},\n\n        // Example: { name: 2 }\n        _outputReferences: {},\n\n        _rendering: false,\n        // If rendered in this frame\n        _rendered: false,\n\n        _compositor: null\n    };\n},\n/** @lends clay.compositor.Node.prototype */\n{\n\n    // TODO Remove parameter function callback\n    updateParameter: function (outputName, renderer) {\n        var outputInfo = this.outputs[outputName];\n        var parameters = outputInfo.parameters;\n        var parametersCopy = outputInfo._parametersCopy;\n        if (!parametersCopy) {\n            parametersCopy = outputInfo._parametersCopy = {};\n        }\n        if (parameters) {\n            for (var key in parameters) {\n                if (key !== 'width' && key !== 'height') {\n                    parametersCopy[key] = parameters[key];\n                }\n            }\n        }\n        var width, height;\n        if (parameters.width instanceof Function) {\n            width = parameters.width.call(this, renderer);\n        }\n        else {\n            width = parameters.width;\n        }\n        if (parameters.height instanceof Function) {\n            height = parameters.height.call(this, renderer);\n        }\n        else {\n            height = parameters.height;\n        }\n        if (\n            parametersCopy.width !== width\n            || parametersCopy.height !== height\n        ) {\n            if (this._outputTextures[outputName]) {\n                this._outputTextures[outputName].dispose(renderer.gl);\n            }\n        }\n        parametersCopy.width = width;\n        parametersCopy.height = height;\n\n        return parametersCopy;\n    },\n\n    /**\n     * Set parameter\n     * @param {string} name\n     * @param {} value\n     */\n    setParameter: function (name, value) {},\n    /**\n     * Get parameter value\n     * @param  {string} name\n     * @return {}\n     */\n    getParameter: function (name) {},\n    /**\n     * Set parameters\n     * @param {Object} obj\n     */\n    setParameters: function (obj) {\n        for (var name in obj) {\n            this.setParameter(name, obj[name]);\n        }\n    },\n\n    render: function () {},\n\n    getOutput: function (renderer /*optional*/, name) {\n        if (name == null) {\n            // Return the output texture without rendering\n            name = renderer;\n            return this._outputTextures[name];\n        }\n        var outputInfo = this.outputs[name];\n        if (!outputInfo) {\n            return ;\n        }\n\n        // Already been rendered in this frame\n        if (this._rendered) {\n            // Force return texture in last frame\n            if (outputInfo.outputLastFrame) {\n                return this._prevOutputTextures[name];\n            }\n            else {\n                return this._outputTextures[name];\n            }\n        }\n        else if (\n            // TODO\n            this._rendering   // Solve Circular Reference\n        ) {\n            if (!this._prevOutputTextures[name]) {\n                // Create a blank texture at first pass\n                this._prevOutputTextures[name] = this._compositor.allocateTexture(outputInfo.parameters || {});\n            }\n            return this._prevOutputTextures[name];\n        }\n\n        this.render(renderer);\n\n        return this._outputTextures[name];\n    },\n\n    removeReference: function (outputName) {\n        this._outputReferences[outputName]--;\n        if (this._outputReferences[outputName] === 0) {\n            var outputInfo = this.outputs[outputName];\n            if (outputInfo.keepLastFrame) {\n                if (this._prevOutputTextures[outputName]) {\n                    this._compositor.releaseTexture(this._prevOutputTextures[outputName]);\n                }\n                this._prevOutputTextures[outputName] = this._outputTextures[outputName];\n            }\n            else {\n                // Output of this node have alreay been used by all other nodes\n                // Put the texture back to the pool.\n                this._compositor.releaseTexture(this._outputTextures[outputName]);\n            }\n        }\n    },\n\n    link: function (inputPinName, fromNode, fromPinName) {\n\n        // The relationship from output pin to input pin is one-on-multiple\n        this.inputLinks[inputPinName] = {\n            node: fromNode,\n            pin: fromPinName\n        };\n        if (!fromNode.outputLinks[fromPinName]) {\n            fromNode.outputLinks[fromPinName] = [];\n        }\n        fromNode.outputLinks[fromPinName].push({\n            node: this,\n            pin: inputPinName\n        });\n\n        // Enabled the pin texture in shader\n        this.pass.material.enableTexture(inputPinName);\n    },\n\n    clear: function () {\n        this.inputLinks = {};\n        this.outputLinks = {};\n    },\n\n    updateReference: function (outputName) {\n        if (!this._rendering) {\n            this._rendering = true;\n            for (var inputName in this.inputLinks) {\n                var link = this.inputLinks[inputName];\n                link.node.updateReference(link.pin);\n            }\n            this._rendering = false;\n        }\n        if (outputName) {\n            this._outputReferences[outputName] ++;\n        }\n    },\n\n    beforeFrame: function () {\n        this._rendered = false;\n\n        for (var name in this.outputLinks) {\n            this._outputReferences[name] = 0;\n        }\n    },\n\n    afterFrame: function () {\n        // Put back all the textures to pool\n        for (var name in this.outputLinks) {\n            if (this._outputReferences[name] > 0) {\n                var outputInfo = this.outputs[name];\n                if (outputInfo.keepLastFrame) {\n                    if (this._prevOutputTextures[name]) {\n                        this._compositor.releaseTexture(this._prevOutputTextures[name]);\n                    }\n                    this._prevOutputTextures[name] = this._outputTextures[name];\n                }\n                else {\n                    this._compositor.releaseTexture(this._outputTextures[name]);\n                }\n            }\n        }\n    }\n});\n\nexport default Node;\n","import Base from '../core/Base';\nimport GraphNode from './Node';\n\n/**\n * @constructor clay.compositor.Graph\n * @extends clay.core.Base\n */\nvar Graph = Base.extend(function () {\n    return /** @lends clay.compositor.Graph# */ {\n        /**\n         * @type {Array.<clay.compositor.Node>}\n         */\n        nodes: []\n    };\n},\n/** @lends clay.compositor.Graph.prototype */\n{\n\n    /**\n     * Mark to update\n     */\n    dirty: function () {\n        this._dirty = true;\n    },\n    /**\n     * @param {clay.compositor.Node} node\n     */\n    addNode: function (node) {\n\n        if (this.nodes.indexOf(node) >= 0) {\n            return;\n        }\n\n        this.nodes.push(node);\n\n        this._dirty = true;\n    },\n    /**\n     * @param  {clay.compositor.Node|string} node\n     */\n    removeNode: function (node) {\n        if (typeof node === 'string') {\n            node = this.getNodeByName(node);\n        }\n        var idx = this.nodes.indexOf(node);\n        if (idx >= 0) {\n            this.nodes.splice(idx, 1);\n            this._dirty = true;\n        }\n    },\n    /**\n     * @param {string} name\n     * @return {clay.compositor.Node}\n     */\n    getNodeByName: function (name) {\n        for (var i = 0; i < this.nodes.length; i++) {\n            if (this.nodes[i].name === name) {\n                return this.nodes[i];\n            }\n        }\n    },\n    /**\n     * Update links of graph\n     */\n    update: function () {\n        for (var i = 0; i < this.nodes.length; i++) {\n            this.nodes[i].clear();\n        }\n        // Traverse all the nodes and build the graph\n        for (var i = 0; i < this.nodes.length; i++) {\n            var node = this.nodes[i];\n\n            if (!node.inputs) {\n                continue;\n            }\n            for (var inputName in node.inputs) {\n                if (!node.inputs[inputName]) {\n                    continue;\n                }\n                if (node.pass && !node.pass.material.isUniformEnabled(inputName)) {\n                    console.warn('Pin '  + node.name + '.' + inputName + ' not used.');\n                    continue;\n                }\n                var fromPinInfo = node.inputs[inputName];\n\n                var fromPin = this.findPin(fromPinInfo);\n                if (fromPin) {\n                    node.link(inputName, fromPin.node, fromPin.pin);\n                }\n                else {\n                    if (typeof fromPinInfo === 'string') {\n                        console.warn('Node ' + fromPinInfo + ' not exist');\n                    }\n                    else {\n                        console.warn('Pin of ' + fromPinInfo.node + '.' + fromPinInfo.pin + ' not exist');\n                    }\n                }\n            }\n        }\n    },\n\n    findPin: function (input) {\n        var node;\n        // Try to take input as a directly a node\n        if (typeof input === 'string' || input instanceof GraphNode) {\n            input = {\n                node: input\n            };\n        }\n\n        if (typeof input.node === 'string') {\n            for (var i = 0; i < this.nodes.length; i++) {\n                var tmp = this.nodes[i];\n                if (tmp.name === input.node) {\n                    node = tmp;\n                }\n            }\n        }\n        else {\n            node = input.node;\n        }\n        if (node) {\n            var inputPin = input.pin;\n            if (!inputPin) {\n                // Use first pin defaultly\n                if (node.outputs) {\n                    inputPin = Object.keys(node.outputs)[0];\n                }\n            }\n            if (node.outputs[inputPin]) {\n                return {\n                    node: node,\n                    pin: inputPin\n                };\n            }\n        }\n    }\n});\n\nexport default Graph;\n","import Graph from './Graph';\nimport TexturePool from './TexturePool';\nimport FrameBuffer from '../FrameBuffer';\n\n/**\n * Compositor provide graph based post processing\n *\n * @constructor clay.compositor.Compositor\n * @extends clay.compositor.Graph\n *\n */\nvar Compositor = Graph.extend(function() {\n    return {\n        // Output node\n        _outputs: [],\n\n        _texturePool: new TexturePool(),\n\n        _frameBuffer: new FrameBuffer({\n            depthBuffer: false\n        })\n    };\n},\n/** @lends clay.compositor.Compositor.prototype */\n{\n    addNode: function(node) {\n        Graph.prototype.addNode.call(this, node);\n        node._compositor = this;\n    },\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    render: function(renderer, frameBuffer) {\n        if (this._dirty) {\n            this.update();\n            this._dirty = false;\n\n            this._outputs.length = 0;\n            for (var i = 0; i < this.nodes.length; i++) {\n                if (!this.nodes[i].outputs) {\n                    this._outputs.push(this.nodes[i]);\n                }\n            }\n        }\n\n        for (var i = 0; i < this.nodes.length; i++) {\n            // Update the reference number of each output texture\n            this.nodes[i].beforeFrame();\n        }\n\n        for (var i = 0; i < this._outputs.length; i++) {\n            this._outputs[i].updateReference();\n        }\n\n        for (var i = 0; i < this._outputs.length; i++) {\n            this._outputs[i].render(renderer, frameBuffer);\n        }\n\n        for (var i = 0; i < this.nodes.length; i++) {\n            // Clear up\n            this.nodes[i].afterFrame();\n        }\n    },\n\n    allocateTexture: function (parameters) {\n        return this._texturePool.get(parameters);\n    },\n\n    releaseTexture: function (parameters) {\n        this._texturePool.put(parameters);\n    },\n\n    getFrameBuffer: function () {\n        return this._frameBuffer;\n    },\n\n    /**\n     * Dispose compositor\n     * @param {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._texturePool.clear(renderer);\n    }\n});\n\nexport default Compositor;\n","import Node from './Node';\nimport glenum from '../core/glenum';\nimport FrameBuffer from '../FrameBuffer';\n\n/**\n * @constructor clay.compositor.SceneNode\n * @extends clay.compositor.Node\n */\nvar SceneNode = Node.extend(\n/** @lends clay.compositor.SceneNode# */\n{\n    name: 'scene',\n    /**\n     * @type {clay.Scene}\n     */\n    scene: null,\n    /**\n     * @type {clay.Camera}\n     */\n    camera: null,\n    /**\n     * @type {boolean}\n     */\n    autoUpdateScene: true,\n    /**\n     * @type {boolean}\n     */\n    preZ: false\n\n}, function() {\n    this.frameBuffer = new FrameBuffer();\n}, {\n    render: function(renderer) {\n\n        this._rendering = true;\n        var _gl = renderer.gl;\n\n        this.trigger('beforerender');\n\n        var renderInfo;\n\n        if (!this.outputs) {\n\n            renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ);\n\n        }\n        else {\n\n            var frameBuffer = this.frameBuffer;\n            for (var name in this.outputs) {\n                var parameters = this.updateParameter(name, renderer);\n                var outputInfo = this.outputs[name];\n                var texture = this._compositor.allocateTexture(parameters);\n                this._outputTextures[name] = texture;\n\n                var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0;\n                if (typeof(attachment) == 'string') {\n                    attachment = _gl[attachment];\n                }\n                frameBuffer.attach(texture, attachment);\n            }\n            frameBuffer.bind(renderer);\n\n            // MRT Support in chrome\n            // https://www.khronos.org/registry/webgl/sdk/tests/conformance/extensions/ext-draw-buffers.html\n            var ext = renderer.getGLExtension('EXT_draw_buffers');\n            if (ext) {\n                var bufs = [];\n                for (var attachment in this.outputs) {\n                    attachment = parseInt(attachment);\n                    if (attachment >= _gl.COLOR_ATTACHMENT0 && attachment <= _gl.COLOR_ATTACHMENT0 + 8) {\n                        bufs.push(attachment);\n                    }\n                }\n                ext.drawBuffersEXT(bufs);\n            }\n\n            // Always clear\n            // PENDING\n            renderer.saveClear();\n            renderer.clearBit = glenum.DEPTH_BUFFER_BIT | glenum.COLOR_BUFFER_BIT;\n            renderInfo = renderer.render(this.scene, this.camera, !this.autoUpdateScene, this.preZ);\n            renderer.restoreClear();\n\n            frameBuffer.unbind(renderer);\n        }\n\n        this.trigger('afterrender', renderInfo);\n\n        this._rendering = false;\n        this._rendered = true;\n    }\n});\n\nexport default SceneNode;\n","import Node from './Node';\n\n/**\n * @constructor clay.compositor.TextureNode\n * @extends clay.compositor.Node\n */\nvar TextureNode = Node.extend(function() {\n    return /** @lends clay.compositor.TextureNode# */ {\n        /**\n         * @type {clay.Texture2D}\n         */\n        texture: null,\n\n        // Texture node must have output without parameters\n        outputs: {\n            color: {}\n        }\n    };\n}, function () {\n}, {\n\n    getOutput: function (renderer, name) {\n        return this.texture;\n    },\n\n    // Do nothing\n    beforeFrame: function () {},\n    afterFrame: function () {}\n});\n\nexport default TextureNode;\n","// TODO Shader library\nimport Pass from './Pass';\nimport Node from './Node';\n\n// TODO curlnoise demo wrong\n\n// PENDING\n// Use topological sort ?\n\n/**\n * Filter node\n *\n * @constructor clay.compositor.FilterNode\n * @extends clay.compositor.Node\n *\n * @example\n    var node = new clay.compositor.Node({\n        name: 'fxaa',\n        shader: clay.Shader.source('clay.compositor.fxaa'),\n        inputs: {\n            texture: {\n                    node: 'scene',\n                    pin: 'color'\n            }\n        },\n        // Multiple outputs is preserved for MRT support in WebGL2.0\n        outputs: {\n            color: {\n                attachment: clay.FrameBuffer.COLOR_ATTACHMENT0\n                parameters: {\n                    format: clay.Texture.RGBA,\n                    width: 512,\n                    height: 512\n                },\n                // Node will keep the RTT rendered in last frame\n                keepLastFrame: true,\n                // Force the node output the RTT rendered in last frame\n                outputLastFrame: true\n            }\n        }\n    });\n    *\n    */\nvar FilterNode = Node.extend(function () {\n    return /** @lends clay.compositor.Node# */ {\n        /**\n         * @type {string}\n         */\n        name: '',\n\n        /**\n         * @type {Object}\n         */\n        inputs: {},\n\n        /**\n         * @type {Object}\n         */\n        outputs: null,\n\n        /**\n         * @type {string}\n         */\n        shader: '',\n\n        /**\n         * Input links, will be updated by the graph\n         * @example:\n         *     inputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        inputLinks: {},\n\n        /**\n         * Output links, will be updated by the graph\n         * @example:\n         *     outputName: {\n         *         node: someNode,\n         *         pin: 'xxxx'\n         *     }\n         * @type {Object}\n         */\n        outputLinks: {},\n\n        /**\n         * @type {clay.compositor.Pass}\n         */\n        pass: null,\n\n        // Save the output texture of previous frame\n        // Will be used when there exist a circular reference\n        _prevOutputTextures: {},\n        _outputTextures: {},\n\n        // Example: { name: 2 }\n        _outputReferences: {},\n\n        _rendering: false,\n        // If rendered in this frame\n        _rendered: false,\n\n        _compositor: null\n    };\n}, function () {\n\n    var pass = new Pass({\n        fragment: this.shader\n    });\n    this.pass = pass;\n},\n/** @lends clay.compositor.Node.prototype */\n{\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    render: function (renderer, frameBuffer) {\n        this.trigger('beforerender', renderer);\n\n        this._rendering = true;\n\n        var _gl = renderer.gl;\n\n        for (var inputName in this.inputLinks) {\n            var link = this.inputLinks[inputName];\n            var inputTexture = link.node.getOutput(renderer, link.pin);\n            this.pass.setUniform(inputName, inputTexture);\n        }\n        // Output\n        if (!this.outputs) {\n            this.pass.outputs = null;\n\n            this._compositor.getFrameBuffer().unbind(renderer);\n\n            this.pass.render(renderer, frameBuffer);\n        }\n        else {\n            this.pass.outputs = {};\n\n            var attachedTextures = {};\n            for (var name in this.outputs) {\n                var parameters = this.updateParameter(name, renderer);\n                if (isNaN(parameters.width)) {\n                    this.updateParameter(name, renderer);\n                }\n                var outputInfo = this.outputs[name];\n                var texture = this._compositor.allocateTexture(parameters);\n                this._outputTextures[name] = texture;\n                var attachment = outputInfo.attachment || _gl.COLOR_ATTACHMENT0;\n                if (typeof(attachment) == 'string') {\n                    attachment = _gl[attachment];\n                }\n                attachedTextures[attachment] = texture;\n            }\n            this._compositor.getFrameBuffer().bind(renderer);\n\n            for (var attachment in attachedTextures) {\n                // FIXME attachment changes in different nodes\n                this._compositor.getFrameBuffer().attach(\n                    attachedTextures[attachment], attachment\n                );\n            }\n\n            this.pass.render(renderer);\n\n            // Because the data of texture is changed over time,\n            // Here update the mipmaps of texture each time after rendered;\n            this._compositor.getFrameBuffer().updateMipmap(renderer.gl);\n        }\n\n        for (var inputName in this.inputLinks) {\n            var link = this.inputLinks[inputName];\n            link.node.removeReference(link.pin);\n        }\n\n        this._rendering = false;\n        this._rendered = true;\n\n        this.trigger('afterrender', renderer);\n    },\n\n    // TODO Remove parameter function callback\n    updateParameter: function (outputName, renderer) {\n        var outputInfo = this.outputs[outputName];\n        var parameters = outputInfo.parameters;\n        var parametersCopy = outputInfo._parametersCopy;\n        if (!parametersCopy) {\n            parametersCopy = outputInfo._parametersCopy = {};\n        }\n        if (parameters) {\n            for (var key in parameters) {\n                if (key !== 'width' && key !== 'height') {\n                    parametersCopy[key] = parameters[key];\n                }\n            }\n        }\n        var width, height;\n        if (parameters.width instanceof Function) {\n            width = parameters.width.call(this, renderer);\n        }\n        else {\n            width = parameters.width;\n        }\n        if (parameters.height instanceof Function) {\n            height = parameters.height.call(this, renderer);\n        }\n        else {\n            height = parameters.height;\n        }\n        if (\n            parametersCopy.width !== width\n            || parametersCopy.height !== height\n        ) {\n            if (this._outputTextures[outputName]) {\n                this._outputTextures[outputName].dispose(renderer);\n            }\n        }\n        parametersCopy.width = width;\n        parametersCopy.height = height;\n\n        return parametersCopy;\n    },\n\n    /**\n     * Set parameter\n     * @param {string} name\n     * @param {} value\n     */\n    setParameter: function (name, value) {\n        this.pass.setUniform(name, value);\n    },\n    /**\n     * Get parameter value\n     * @param  {string} name\n     * @return {}\n     */\n    getParameter: function (name) {\n        return this.pass.getUniform(name);\n    },\n    /**\n     * Set parameters\n     * @param {Object} obj\n     */\n    setParameters: function (obj) {\n        for (var name in obj) {\n            this.setParameter(name, obj[name]);\n        }\n    },\n    // /**\n    //  * Set shader code\n    //  * @param {string} shaderStr\n    //  */\n    // setShader: function (shaderStr) {\n    //     var material = this.pass.material;\n    //     material.shader.setFragment(shaderStr);\n    //     material.attachShader(material.shader, true);\n    // },\n    /**\n     * Proxy of pass.material.define('fragment', xxx);\n     * @param  {string} symbol\n     * @param  {number} [val]\n     */\n    define: function (symbol, val) {\n        this.pass.material.define('fragment', symbol, val);\n    },\n\n    /**\n     * Proxy of pass.material.undefine('fragment', xxx)\n     * @param  {string} symbol\n     */\n    undefine: function (symbol) {\n        this.pass.material.undefine('fragment', symbol);\n    },\n\n    removeReference: function (outputName) {\n        this._outputReferences[outputName]--;\n        if (this._outputReferences[outputName] === 0) {\n            var outputInfo = this.outputs[outputName];\n            if (outputInfo.keepLastFrame) {\n                if (this._prevOutputTextures[outputName]) {\n                    this._compositor.releaseTexture(this._prevOutputTextures[outputName]);\n                }\n                this._prevOutputTextures[outputName] = this._outputTextures[outputName];\n            }\n            else {\n                // Output of this node have alreay been used by all other nodes\n                // Put the texture back to the pool.\n                this._compositor.releaseTexture(this._outputTextures[outputName]);\n            }\n        }\n    },\n\n    clear: function () {\n        Node.prototype.clear.call(this);\n\n        // Default disable all texture\n        this.pass.material.disableTexturesAll();\n    }\n});\n\nexport default FilterNode;\n","import util from '../core/util';\nimport Compositor from './Compositor';\nimport CompoSceneNode from './SceneNode';\nimport CompoTextureNode from './TextureNode';\nimport CompoFilterNode from './FilterNode';\nimport Shader from '../Shader';\nimport Texture from '../Texture';\nimport Texture2D from '../Texture2D';\nimport TextureCube from '../TextureCube';\n\nvar shaderSourceReg = /^#source\\((.*?)\\)/;\n\n/**\n * @param {Object} json\n * @param {Object} [opts]\n * @return {clay.compositor.Compositor}\n */\nfunction createCompositor(json, opts) {\n    var compositor = new Compositor();\n    opts = opts || {};\n\n    var lib = {\n        textures: {},\n        parameters: {}\n    };\n    var afterLoad = function(shaderLib, textureLib) {\n        for (var i = 0; i < json.nodes.length; i++) {\n            var nodeInfo = json.nodes[i];\n            var node = createNode(nodeInfo, lib, opts);\n            if (node) {\n                compositor.addNode(node);\n            }\n        }\n    };\n\n    for (var name in json.parameters) {\n        var paramInfo = json.parameters[name];\n        lib.parameters[name] = convertParameter(paramInfo);\n    }\n    // TODO load texture asynchronous\n    loadTextures(json, lib, opts, function(textureLib) {\n        lib.textures = textureLib;\n        afterLoad();\n    });\n\n    return compositor;\n}\n\nfunction createNode(nodeInfo, lib, opts) {\n    var type = nodeInfo.type || 'filter';\n    var shaderSource;\n    var inputs;\n    var outputs;\n\n    if (type === 'filter') {\n        var shaderExp = nodeInfo.shader.trim();\n        var res = shaderSourceReg.exec(shaderExp);\n        if (res) {\n            shaderSource = Shader.source(res[1].trim());\n        }\n        else if (shaderExp.charAt(0) === '#') {\n            shaderSource = lib.shaders[shaderExp.substr(1)];\n        }\n        if (!shaderSource) {\n            shaderSource = shaderExp;\n        }\n        if (!shaderSource) {\n            return;\n        }\n    }\n\n    if (nodeInfo.inputs) {\n        inputs = {};\n        for (var name in nodeInfo.inputs) {\n            if (typeof nodeInfo.inputs[name] === 'string') {\n                inputs[name] = nodeInfo.inputs[name];\n            }\n            else {\n                inputs[name] = {\n                    node: nodeInfo.inputs[name].node,\n                    pin: nodeInfo.inputs[name].pin\n                };\n            }\n        }\n    }\n    if (nodeInfo.outputs) {\n        outputs = {};\n        for (var name in nodeInfo.outputs) {\n            var outputInfo = nodeInfo.outputs[name];\n            outputs[name] = {};\n            if (outputInfo.attachment != null) {\n                outputs[name].attachment = outputInfo.attachment;\n            }\n            if (outputInfo.keepLastFrame != null) {\n                outputs[name].keepLastFrame = outputInfo.keepLastFrame;\n            }\n            if (outputInfo.outputLastFrame != null) {\n                outputs[name].outputLastFrame = outputInfo.outputLastFrame;\n            }\n            if (outputInfo.parameters) {\n                outputs[name].parameters = convertParameter(outputInfo.parameters);\n            }\n        }\n    }\n    var node;\n    if (type === 'scene') {\n        node = new CompoSceneNode({\n            name: nodeInfo.name,\n            scene: opts.scene,\n            camera: opts.camera,\n            outputs: outputs\n        });\n    }\n    else if (type === 'texture') {\n        node = new CompoTextureNode({\n            name: nodeInfo.name,\n            outputs: outputs\n        });\n    }\n    // Default is filter\n    else {\n        node = new CompoFilterNode({\n            name: nodeInfo.name,\n            shader: shaderSource,\n            inputs: inputs,\n            outputs: outputs\n        });\n    }\n    if (node) {\n        if (nodeInfo.parameters) {\n            for (var name in nodeInfo.parameters) {\n                var val = nodeInfo.parameters[name];\n                if (typeof(val) === 'string') {\n                    val = val.trim();\n                    if (val.charAt(0) === '#') {\n                        val = lib.textures[val.substr(1)];\n                    }\n                    else {\n                        node.on(\n                            'beforerender', createSizeSetHandler(\n                                name, tryConvertExpr(val)\n                            )\n                        );\n                    }\n                }\n                node.setParameter(name, val);\n            }\n        }\n        if (nodeInfo.defines && node.pass) {\n            for (var name in nodeInfo.defines) {\n                var val = nodeInfo.defines[name];\n                node.pass.material.define('fragment', name, val);\n            }\n        }\n    }\n    return node;\n}\n\nfunction convertParameter(paramInfo) {\n    var param = {};\n    if (!paramInfo) {\n        return param;\n    }\n    ['type', 'minFilter', 'magFilter', 'wrapS', 'wrapT', 'flipY', 'useMipmap']\n        .forEach(function(name) {\n            var val = paramInfo[name];\n            if (val != null) {\n                // Convert string to enum\n                if (typeof val === 'string') {\n                    val = Texture[val];\n                }\n                param[name] = val;\n            }\n        });\n    ['width', 'height']\n        .forEach(function(name) {\n            if (paramInfo[name] != null) {\n                var val = paramInfo[name];\n                if (typeof val === 'string') {\n                    val = val.trim();\n                    param[name] = createSizeParser(\n                        name, tryConvertExpr(val)\n                    );\n                }\n                else {\n                    param[name] = val;\n                }\n            }\n        });\n    if (paramInfo.useMipmap != null) {\n        param.useMipmap = paramInfo.useMipmap;\n    }\n    return param;\n}\n\nfunction loadTextures(json, lib, opts, callback) {\n    if (!json.textures) {\n        callback({});\n        return;\n    }\n    var textures = {};\n    var loading = 0;\n\n    var cbd = false;\n    var textureRootPath = opts.textureRootPath;\n    util.each(json.textures, function(textureInfo, name) {\n        var texture;\n        var path = textureInfo.path;\n        var parameters = convertParameter(textureInfo.parameters);\n        if (Array.isArray(path) && path.length === 6) {\n            if (textureRootPath) {\n                path = path.map(function(item) {\n                    return util.relative2absolute(item, textureRootPath);\n                });\n            }\n            texture = new TextureCube(parameters);\n        }\n        else if(typeof path === 'string') {\n            if (textureRootPath) {\n                path = util.relative2absolute(path, textureRootPath);\n            }\n            texture = new Texture2D(parameters);\n        }\n        else {\n            return;\n        }\n\n        texture.load(path);\n        loading++;\n        texture.once('success', function() {\n            textures[name] = texture;\n            loading--;\n            if (loading === 0) {\n                callback(textures);\n                cbd = true;\n            }\n        });\n    });\n\n    if (loading === 0 && !cbd) {\n        callback(textures);\n    }\n}\n\nfunction createSizeSetHandler(name, exprFunc) {\n    return function (renderer) {\n        // PENDING viewport size or window size\n        var dpr = renderer.getDevicePixelRatio();\n        // PENDING If multiply dpr ?\n        var width = renderer.getWidth();\n        var height = renderer.getHeight();\n        var result = exprFunc(width, height, dpr);\n        this.setParameter(name, result);\n    };\n}\n\nfunction createSizeParser(name, exprFunc) {\n    return function (renderer) {\n        var dpr = renderer.getDevicePixelRatio();\n        var width = renderer.getWidth();\n        var height = renderer.getHeight();\n        return exprFunc(width, height, dpr);\n    };\n}\n\nfunction tryConvertExpr(string) {\n    // PENDING\n    var exprRes = /^expr\\((.*)\\)$/.exec(string);\n    if (exprRes) {\n        try {\n            var func = new Function('width', 'height', 'dpr', 'return ' + exprRes[1]);\n            // Try run t\n            func(1, 1);\n\n            return func;\n        }\n        catch (e) {\n            throw new Error('Invalid expression.');\n        }\n    }\n}\n\nexport default createCompositor;\n","export default \"@export clay.deferred.gbuffer.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\\nuniform mat4 world : WORLD;\\nuniform vec2 uvRepeat;\\nuniform vec2 uvOffset;\\nattribute vec3 position : POSITION;\\nattribute vec2 texcoord : TEXCOORD_0;\\n#ifdef FIRST_PASS\\nattribute vec3 normal : NORMAL;\\n#endif\\n@import clay.chunk.skinning_header\\n#ifdef FIRST_PASS\\nvarying vec3 v_Normal;\\nattribute vec4 tangent : TANGENT;\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\nvarying vec3 v_WorldPosition;\\n#endif\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    vec3 skinnedPosition = position;\\n#ifdef FIRST_PASS\\n    vec3 skinnedNormal = normal;\\n    vec3 skinnedTangent = tangent.xyz;\\n    bool hasTangent = dot(tangent, tangent) > 0.0;\\n#endif\\n#ifdef SKINNING\\n    @import clay.chunk.skin_matrix\\n    skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    #ifdef FIRST_PASS\\n    skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\\n    if (hasTangent) {\\n        skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\\n    }\\n    #endif\\n#endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n    v_Texcoord = texcoord * uvRepeat + uvOffset;\\n#ifdef FIRST_PASS\\n    v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\\n    if (hasTangent) {\\n        v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\\n        v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\\n    }\\n    v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\\n#endif\\n}\\n@end\\n@export clay.deferred.gbuffer1.fragment\\nuniform mat4 viewInverse : VIEWINVERSE;\\nuniform float glossiness;\\nvarying vec2 v_Texcoord;\\nvarying vec3 v_Normal;\\nvarying vec3 v_WorldPosition;\\nuniform sampler2D normalMap;\\nvarying vec3 v_Tangent;\\nvarying vec3 v_Bitangent;\\nuniform sampler2D roughGlossMap;\\nuniform bool useRoughGlossMap;\\nuniform bool useRoughness;\\nuniform bool doubleSided;\\nuniform int roughGlossChannel: 0;\\nfloat indexingTexel(in vec4 texel, in int idx) {\\n    if (idx == 3) return texel.a;\\n    else if (idx == 1) return texel.g;\\n    else if (idx == 2) return texel.b;\\n    else return texel.r;\\n}\\nvoid main()\\n{\\n    vec3 N = v_Normal;\\n    if (doubleSided) {\\n        vec3 eyePos = viewInverse[3].xyz;\\n        vec3 V = eyePos - v_WorldPosition;\\n        if (dot(N, V) < 0.0) {\\n            N = -N;\\n        }\\n    }\\n    if (dot(v_Tangent, v_Tangent) > 0.0) {\\n        vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\\n        if (dot(normalTexel, normalTexel) > 0.0) {            N = normalTexel * 2.0 - 1.0;\\n            mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\\n            N = normalize(tbn * N);\\n        }\\n    }\\n    gl_FragColor.rgb = (N + 1.0) * 0.5;\\n    float g = glossiness;\\n    if (useRoughGlossMap) {\\n        float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\\n        if (useRoughness) {\\n            g2 = 1.0 - g2;\\n        }\\n        g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\\n    }\\n    gl_FragColor.a = g + 0.005;\\n}\\n@end\\n@export clay.deferred.gbuffer2.fragment\\nuniform sampler2D diffuseMap;\\nuniform sampler2D metalnessMap;\\nuniform vec3 color;\\nuniform float metalness;\\nuniform bool useMetalnessMap;\\nuniform bool linear;\\nvarying vec2 v_Texcoord;\\n@import clay.util.srgb\\nvoid main ()\\n{\\n    float m = metalness;\\n    if (useMetalnessMap) {\\n        vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\\n        m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\\n    }\\n    vec4 texel = texture2D(diffuseMap, v_Texcoord);\\n    if (linear) {\\n        texel = sRGBToLinear(texel);\\n    }\\n    gl_FragColor.rgb = texel.rgb * color;\\n    gl_FragColor.a = m + 0.005;\\n}\\n@end\\n@export clay.deferred.gbuffer.debug\\n@import clay.deferred.chunk.light_head\\nuniform int debug: 0;\\nvoid main ()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    if (debug == 0) {\\n        gl_FragColor = vec4(N, 1.0);\\n    }\\n    else if (debug == 1) {\\n        gl_FragColor = vec4(vec3(z), 1.0);\\n    }\\n    else if (debug == 2) {\\n        gl_FragColor = vec4(position, 1.0);\\n    }\\n    else if (debug == 3) {\\n        gl_FragColor = vec4(vec3(glossiness), 1.0);\\n    }\\n    else if (debug == 4) {\\n        gl_FragColor = vec4(vec3(metalness), 1.0);\\n    }\\n    else {\\n        gl_FragColor = vec4(albedo, 1.0);\\n    }\\n}\\n@end\";\n","export default \"@export clay.deferred.chunk.light_head\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture2;\\nuniform sampler2D gBufferTexture3;\\nuniform vec2 windowSize: WINDOW_SIZE;\\nuniform vec4 viewport: VIEWPORT;\\nuniform mat4 viewProjectionInv;\\n#ifdef DEPTH_ENCODED\\n@import clay.util.decode_float\\n#endif\\n@end\\n@export clay.deferred.chunk.gbuffer_read\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    vec4 texel3 = texture2D(gBufferTexture3, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    float glossiness = texel1.a;\\n    float metalness = texel3.a;\\n    vec3 N = texel1.rgb * 2.0 - 1.0;\\n    float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\\n    vec2 xy = uv2 * 2.0 - 1.0;\\n    vec4 projectedPos = vec4(xy, z, 1.0);\\n    vec4 p4 = viewProjectionInv * projectedPos;\\n    vec3 position = p4.xyz / p4.w;\\n    vec3 albedo = texel3.rgb;\\n    vec3 diffuseColor = albedo * (1.0 - metalness);\\n    vec3 specularColor = mix(vec3(0.04), albedo, metalness);\\n@end\\n@export clay.deferred.chunk.light_equation\\nfloat D_Phong(in float g, in float ndh) {\\n    float a = pow(8192.0, g);\\n    return (a + 2.0) / 8.0 * pow(ndh, a);\\n}\\nfloat D_GGX(in float g, in float ndh) {\\n    float r = 1.0 - g;\\n    float a = r * r;\\n    float tmp = ndh * ndh * (a - 1.0) + 1.0;\\n    return a / (3.1415926 * tmp * tmp);\\n}\\nvec3 F_Schlick(in float ndv, vec3 spec) {\\n    return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\\n}\\nvec3 lightEquation(\\n    in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\\n    in float ndl, in float ndh, in float ndv, in float g\\n)\\n{\\n    return ndl * lightColor\\n        * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\\n}\\n@end\";\n","import Base from '../core/Base';\nimport Texture2D from '../Texture2D';\nimport Texture from '../Texture';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport Shader from '../Shader';\nimport ForwardRenderer from '../Renderer';\nimport Pass from '../compositor/Pass';\nimport Matrix4 from '../math/Matrix4';\n\nimport gbufferEssl from '../shader/source/deferred/gbuffer.glsl.js';\nimport chunkEssl from '../shader/source/deferred/chunk.glsl.js';\n\nShader.import(gbufferEssl);\nShader.import(chunkEssl);\n\nfunction createFillCanvas(color) {\n    var canvas = document.createElement('canvas');\n    canvas.width = canvas.height = 1;\n    var ctx = canvas.getContext('2d');\n    ctx.fillStyle = color || '#000';\n    ctx.fillRect(0, 0, 1, 1);\n\n    return canvas;\n}\n\nfunction attachTextureToSlot(renderer, program, symbol, texture, slot) {\n    var gl = renderer.gl;\n    program.setUniform(gl, '1i', symbol, slot);\n\n    gl.activeTexture(gl.TEXTURE0 + slot);\n    // Maybe texture is not loaded yet;\n    if (texture.isRenderable()) {\n        texture.bind(renderer);\n    }\n    else {\n        // Bind texture to null\n        texture.unbind(renderer);\n    }\n}\n\n// TODO Use globalShader insteadof globalMaterial?\nfunction getBeforeRenderHook1 (gl, defaultNormalMap, defaultRoughnessMap) {\n\n    var previousNormalMap;\n    var previousRougGlossMap;\n    var previousRenderable;\n\n    return function (renderable, gBufferMat, prevMaterial) {\n        // Material not change\n        if (previousRenderable && previousRenderable.material === renderable.material) {\n            return;\n        }\n\n        var standardMaterial = renderable.material;\n        var program = renderable.__program;\n\n        var glossiness;\n        var roughGlossMap;\n        var useRoughnessWorkflow = standardMaterial.isDefined('fragment', 'USE_ROUGHNESS');\n        var doubleSided = standardMaterial.isDefined('fragment', 'DOUBLE_SIDED');\n        var roughGlossChannel;\n        if (useRoughnessWorkflow) {\n            glossiness = 1.0 - standardMaterial.get('roughness');\n            roughGlossMap = standardMaterial.get('roughnessMap');\n            roughGlossChannel = standardMaterial.getDefine('fragment', 'ROUGHNESS_CHANNEL');\n        }\n        else {\n            glossiness = standardMaterial.get('glossiness');\n            roughGlossMap = standardMaterial.get('glossinessMap');\n            roughGlossChannel = standardMaterial.getDefine('fragment', 'GLOSSINESS_CHANNEL');\n        }\n        var useRoughGlossMap = !!roughGlossMap;\n\n        var normalMap = standardMaterial.get('normalMap') || defaultNormalMap;\n        var uvRepeat = standardMaterial.get('uvRepeat');\n        var uvOffset = standardMaterial.get('uvOffset');\n\n        roughGlossMap = roughGlossMap || defaultRoughnessMap;\n\n        if (prevMaterial !== gBufferMat) {\n            gBufferMat.set('glossiness', glossiness);\n            gBufferMat.set('normalMap', normalMap);\n            gBufferMat.set('roughGlossMap', roughGlossMap);\n            gBufferMat.set('useRoughGlossMap', +useRoughGlossMap);\n            gBufferMat.set('useRoughness', +useRoughnessWorkflow);\n            gBufferMat.set('doubleSided', +doubleSided);\n            gBufferMat.set('roughGlossChannel', +roughGlossChannel || 0);\n            gBufferMat.set('uvRepeat', uvRepeat);\n            gBufferMat.set('uvOffset', uvOffset);\n        }\n        else {\n            program.setUniform(\n                gl, '1f', 'glossiness', glossiness\n            );\n\n            if (previousNormalMap !== normalMap) {\n                attachTextureToSlot(this, program, 'normalMap', normalMap, 0);\n            }\n            if (previousRougGlossMap !== roughGlossMap) {\n                attachTextureToSlot(this, program, 'roughGlossMap', roughGlossMap, 1);\n            }\n            program.setUniform(gl, '1i', 'useRoughGlossMap', +useRoughGlossMap);\n            program.setUniform(gl, '1i', 'useRoughness', +useRoughnessWorkflow);\n            program.setUniform(gl, '1i', 'doubleSided', +doubleSided);\n            program.setUniform(gl, '1i', 'roughGlossChannel', +roughGlossChannel || 0);\n            if (uvRepeat != null) {\n                program.setUniform(gl, '2f', 'uvRepeat', uvRepeat);\n            }\n            if (uvOffset != null) {\n                program.setUniform(gl, '2f', 'uvOffset', uvOffset);\n            }\n        }\n\n        previousNormalMap = normalMap;\n        previousRougGlossMap = roughGlossMap;\n\n        previousRenderable = renderable;\n    };\n}\n\nfunction getBeforeRenderHook2(gl, defaultDiffuseMap, defaultMetalnessMap) {\n    var previousDiffuseMap;\n    var previousRenderable;\n    var previousMetalnessMap;\n\n    return function (renderable, gBufferMat, prevMaterial) {\n        // Material not change\n        if (previousRenderable && previousRenderable.material === renderable.material) {\n            return;\n        }\n\n        var program = renderable.__program;\n        var standardMaterial = renderable.material;\n\n        var color = standardMaterial.get('color');\n        var metalness = standardMaterial.get('metalness');\n\n        var diffuseMap = standardMaterial.get('diffuseMap');\n        var metalnessMap = standardMaterial.get('metalnessMap');\n\n        var uvRepeat = standardMaterial.get('uvRepeat');\n        var uvOffset = standardMaterial.get('uvOffset');\n\n        var useMetalnessMap = !!metalnessMap;\n\n        diffuseMap = diffuseMap || defaultDiffuseMap;\n        metalnessMap = metalnessMap || defaultMetalnessMap;\n\n        if (prevMaterial !== gBufferMat) {\n            gBufferMat.set('color', color);\n            gBufferMat.set('metalness', metalness);\n            gBufferMat.set('diffuseMap', diffuseMap);\n            gBufferMat.set('metalnessMap', metalnessMap);\n            gBufferMat.set('useMetalnessMap', +useMetalnessMap);\n            gBufferMat.set('uvRepeat', uvRepeat);\n            gBufferMat.set('uvOffset', uvOffset);\n\n            gBufferMat.set('linear', +standardMaterial.linear);\n        }\n        else {\n            program.setUniform(gl, '1f', 'metalness', metalness);\n\n            program.setUniform(gl, '3f', 'color', color);\n            if (previousDiffuseMap !== diffuseMap) {\n                attachTextureToSlot(this, program, 'diffuseMap', diffuseMap, 0);\n            }\n            if (previousMetalnessMap !== metalnessMap) {\n                attachTextureToSlot(this, program, 'metalnessMap', metalnessMap, 1);\n            }\n            program.setUniform(gl, '1i', 'useMetalnessMap', +useMetalnessMap);\n            program.setUniform(gl, '2f', 'uvRepeat', uvRepeat);\n            program.setUniform(gl, '2f', 'uvOffset', uvOffset);\n\n            program.setUniform(gl, '1i', 'linear', +standardMaterial.linear);\n        }\n\n        previousDiffuseMap = diffuseMap;\n        previousMetalnessMap = metalnessMap;\n\n        previousRenderable = renderable;\n    };\n}\n\n/**\n * GBuffer is provided for deferred rendering and SSAO, SSR pass.\n * It will do two passes rendering to three target textures. See\n * + {@link clay.deferred.GBuffer#getTargetTexture1}\n * + {@link clay.deferred.GBuffer#getTargetTexture2}\n * + {@link clay.deferred.GBuffer#getTargetTexture3}\n * @constructor\n * @alias clay.deferred.GBuffer\n * @extends clay.core.Base\n */\nvar GBuffer = Base.extend(function () {\n\n    return {\n\n        enableTargetTexture1: true,\n\n        enableTargetTexture2: true,\n\n        enableTargetTexture3: true,\n\n        renderTransparent: false,\n\n        _renderList: [],\n        // - R: normal.x\n        // - G: normal.y\n        // - B: normal.z\n        // - A: glossiness\n        _gBufferTex1: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST,\n            // PENDING\n            type: Texture.HALF_FLOAT\n        }),\n\n        // - R: depth\n        _gBufferTex2: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST,\n            // format: Texture.DEPTH_COMPONENT,\n            // type: Texture.UNSIGNED_INT\n\n            format: Texture.DEPTH_STENCIL,\n            type: Texture.UNSIGNED_INT_24_8_WEBGL\n        }),\n\n        // - R: albedo.r\n        // - G: albedo.g\n        // - B: albedo.b\n        // - A: metalness\n        _gBufferTex3: new Texture2D({\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST\n        }),\n\n        _defaultNormalMap: new Texture2D({\n            image: createFillCanvas('#000')\n        }),\n        _defaultRoughnessMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n        _defaultMetalnessMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n        _defaultDiffuseMap: new Texture2D({\n            image: createFillCanvas('#fff')\n        }),\n\n        _frameBuffer: new FrameBuffer(),\n\n        _gBufferMaterial1: new Material({\n            shader: new Shader(\n                Shader.source('clay.deferred.gbuffer.vertex'),\n                Shader.source('clay.deferred.gbuffer1.fragment')\n            ),\n            vertexDefines: {\n                FIRST_PASS: null\n            },\n            fragmentDefines: {\n                FIRST_PASS: null\n            }\n        }),\n        _gBufferMaterial2: new Material({\n            shader: new Shader(\n                Shader.source('clay.deferred.gbuffer.vertex'),\n                Shader.source('clay.deferred.gbuffer2.fragment')\n            )\n        }),\n\n        _debugPass: new Pass({\n            fragment: Shader.source('clay.deferred.gbuffer.debug')\n        })\n    };\n}, /** @lends clay.deferred.GBuffer# */{\n\n    /**\n     * Set G Buffer size.\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function (width, height) {\n        if (this._gBufferTex1.width === width\n            && this._gBufferTex1.height === height\n        ) {\n            return;\n        }\n        this._gBufferTex1.width = width;\n        this._gBufferTex1.height = height;\n\n        this._gBufferTex2.width = width;\n        this._gBufferTex2.height = height;\n\n        this._gBufferTex3.width = width;\n        this._gBufferTex3.height = height;\n    },\n\n    // TODO is dpr needed?\n    setViewport: function (x, y, width, height, dpr) {\n        var viewport;\n        if (typeof x === 'object') {\n            viewport = x;\n        }\n        else {\n            viewport = {\n                x: x, y: y,\n                width: width, height: height,\n                devicePixelRatio: dpr || 1\n            };\n        }\n        this._frameBuffer.viewport = viewport;\n    },\n\n    getViewport: function () {\n        if (this._frameBuffer.viewport) {\n            return this._frameBuffer.viewport;\n        }\n        else {\n            return {\n                x: 0, y: 0,\n                width: this._gBufferTex1.width,\n                height: this._gBufferTex1.height,\n                devicePixelRatio: 1\n            };\n        }\n    },\n\n    /**\n     * Update G Buffer\n     * @param {clay.Renderer} renderer\n     * @param {clay.Scene} scene\n     * @param {clay.camera.Perspective} camera\n     */\n    update: function (renderer, scene, camera) {\n\n        var gl = renderer.gl;\n\n        var frameBuffer = this._frameBuffer;\n        var viewport = frameBuffer.viewport;\n        var opaqueList = scene.opaqueList;\n        var transparentList = scene.transparentList;\n\n        var offset = 0;\n        var renderList = this._renderList;\n        for (var i = 0; i < opaqueList.length; i++) {\n            if (!opaqueList[i].ignoreGBuffer) {\n                renderList[offset++] = opaqueList[i];\n            }\n        }\n        if (this.renderTransparent) {\n            for (var i = 0; i < transparentList.length; i++) {\n                if (!transparentList[i].ignoreGBuffer) {\n                    renderList[offset++] = transparentList[i];\n                }\n            }\n        }\n        renderList.length = offset;\n\n        gl.clearColor(0, 0, 0, 0);\n        gl.depthMask(true);\n        gl.colorMask(true, true, true, true);\n        gl.disable(gl.BLEND);\n\n        var enableTargetTexture1 = this.enableTargetTexture1;\n        var enableTargetTexture2 = this.enableTargetTexture2;\n        var enableTargetTexture3 = this.enableTargetTexture3;\n        if (!enableTargetTexture1 && !enableTargetTexture3) {\n            console.warn('Can\\'t disable targetTexture1 targetTexture3 both');\n            enableTargetTexture1 = true;\n        }\n\n        if (enableTargetTexture2) {\n            frameBuffer.attach(this._gBufferTex2, renderer.gl.DEPTH_STENCIL_ATTACHMENT);\n        }\n\n        // PENDING, scene.boundingBoxLastFrame needs be updated if have shadow\n        renderer.bindSceneRendering(scene);\n        if (enableTargetTexture1) {\n            // Pass 1\n            frameBuffer.attach(this._gBufferTex1);\n            frameBuffer.bind(renderer);\n\n            if (viewport) {\n                var dpr = viewport.devicePixelRatio;\n                // use scissor to make sure only clear the viewport\n                gl.enable(gl.SCISSOR_TEST);\n                gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n            }\n            gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n            if (viewport) {\n                gl.disable(gl.SCISSOR_TEST);\n            }\n            var gBufferMaterial1 = this._gBufferMaterial1;\n            var passConfig = {\n                getMaterial: function () {\n                    return gBufferMaterial1;\n                },\n                beforeRender: getBeforeRenderHook1(gl, this._defaultNormalMap, this._defaultRoughnessMap),\n                sortCompare: renderer.opaqueSortCompare\n            };\n            // FIXME Use MRT if possible\n            renderer.renderPass(renderList, camera, passConfig);\n\n        }\n        if (enableTargetTexture3) {\n\n            // Pass 2\n            frameBuffer.attach(this._gBufferTex3);\n            frameBuffer.bind(renderer);\n\n            if (viewport) {\n                var dpr = viewport.devicePixelRatio;\n                // use scissor to make sure only clear the viewport\n                gl.enable(gl.SCISSOR_TEST);\n                gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n            }\n            gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n            if (viewport) {\n                gl.disable(gl.SCISSOR_TEST);\n            }\n\n            var gBufferMaterial2 = this._gBufferMaterial2;\n            var passConfig = {\n                getMaterial: function () {\n                    return gBufferMaterial2;\n                },\n                beforeRender: getBeforeRenderHook2(gl, this._defaultDiffuseMap, this._defaultMetalnessMap),\n                sortCompare: renderer.opaqueSortCompare\n            };\n            renderer.renderPass(renderList, camera, passConfig);\n        }\n\n        renderer.bindSceneRendering(null);\n        frameBuffer.unbind(renderer);\n    },\n\n    renderDebug: function (renderer, camera, type, viewport) {\n        var debugTypes = {\n            normal: 0,\n            depth: 1,\n            position: 2,\n            glossiness: 3,\n            metalness: 4,\n            albedo: 5\n        };\n        if (debugTypes[type] == null) {\n            console.warn('Unkown type \"' + type + '\"');\n            // Default use normal\n            type = 'normal';\n        }\n\n        renderer.saveClear();\n        renderer.saveViewport();\n        renderer.clearBit = renderer.gl.DEPTH_BUFFER_BIT;\n\n        if (viewport) {\n            renderer.setViewport(viewport);\n        }\n        var viewProjectionInv = new Matrix4();\n        Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix);\n\n        var debugPass = this._debugPass;\n        debugPass.setUniform('viewportSize', [renderer.getWidth(), renderer.getHeight()]);\n        debugPass.setUniform('gBufferTexture1', this._gBufferTex1);\n        debugPass.setUniform('gBufferTexture2', this._gBufferTex2);\n        debugPass.setUniform('gBufferTexture3', this._gBufferTex3);\n        debugPass.setUniform('debug', debugTypes[type]);\n        debugPass.setUniform('viewProjectionInv', viewProjectionInv.array);\n        debugPass.render(renderer);\n\n        renderer.restoreViewport();\n        renderer.restoreClear();\n    },\n\n    /**\n     * Get first target texture.\n     * Channel storage:\n     * + R: normal.x * 0.5 + 0.5\n     * + G: normal.y * 0.5 + 0.5\n     * + B: normal.z * 0.5 + 0.5\n     * + A: glossiness\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture1: function () {\n        return this._gBufferTex1;\n    },\n\n    /**\n     * Get second target texture.\n     * Channel storage:\n     * + R: depth\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture2: function () {\n        return this._gBufferTex2;\n    },\n\n    /**\n     * Get third target texture.\n     * Channel storage:\n     * + R: albedo.r\n     * + G: albedo.g\n     * + B: albedo.b\n     * + A: metalness\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture3: function () {\n        return this._gBufferTex3;\n    },\n\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n    }\n});\n\nexport default GBuffer;","import Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\nvar vec2 = glMatrix.vec2;\n\n/**\n * @constructor clay.geometry.Cone\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.topRadius]\n * @param {number} [opt.bottomRadius]\n * @param {number} [opt.height]\n * @param {number} [opt.capSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Cone = Geometry.extend(\n/** @lends clay.geometry.Cone# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    topRadius: 0,\n\n    /**\n     * @type {number}\n     */\n    bottomRadius: 1,\n\n    /**\n     * @type {number}\n     */\n    height: 2,\n\n    /**\n     * @type {number}\n     */\n    capSegments: 20,\n\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cone.prototype */\n{\n    /**\n     * Build cone geometry\n     */\n    build: function() {\n        var positions = [];\n        var texcoords = [];\n        var faces = [];\n        positions.length = 0;\n        texcoords.length = 0;\n        faces.length = 0;\n        // Top cap\n        var capSegRadial = Math.PI * 2 / this.capSegments;\n\n        var topCap = [];\n        var bottomCap = [];\n\n        var r1 = this.topRadius;\n        var r2 = this.bottomRadius;\n        var y = this.height / 2;\n\n        var c1 = vec3.fromValues(0, y, 0);\n        var c2 = vec3.fromValues(0, -y, 0);\n        for (var i = 0; i < this.capSegments; i++) {\n            var theta = i * capSegRadial;\n            var x = r1 * Math.sin(theta);\n            var z = r1 * Math.cos(theta);\n            topCap.push(vec3.fromValues(x, y, z));\n\n            x = r2 * Math.sin(theta);\n            z = r2 * Math.cos(theta);\n            bottomCap.push(vec3.fromValues(x, -y, z));\n        }\n\n        // Build top cap\n        positions.push(c1);\n        // FIXME\n        texcoords.push(vec2.fromValues(0, 1));\n        var n = this.capSegments;\n        for (var i = 0; i < n; i++) {\n            positions.push(topCap[i]);\n            // FIXME\n            texcoords.push(vec2.fromValues(i / n, 0));\n            faces.push([0, i+1, (i+1) % n + 1]);\n        }\n\n        // Build bottom cap\n        var offset = positions.length;\n        positions.push(c2);\n        texcoords.push(vec2.fromValues(0, 1));\n        for (var i = 0; i < n; i++) {\n            positions.push(bottomCap[i]);\n            // FIXME\n            texcoords.push(vec2.fromValues(i / n, 0));\n            faces.push([offset, offset+((i+1) % n + 1), offset+i+1]);\n        }\n\n        // Build side\n        offset = positions.length;\n        var n2 = this.heightSegments;\n        for (var i = 0; i < n; i++) {\n            for (var j = 0; j < n2+1; j++) {\n                var v = j / n2;\n                positions.push(vec3.lerp(vec3.create(), topCap[i], bottomCap[i], v));\n                texcoords.push(vec2.fromValues(i / n, v));\n            }\n        }\n        for (var i = 0; i < n; i++) {\n            for (var j = 0; j < n2; j++) {\n                var i1 = i * (n2 + 1) + j;\n                var i2 = ((i + 1) % n) * (n2 + 1) + j;\n                var i3 = ((i + 1) % n) * (n2 + 1) + j + 1;\n                var i4 = i * (n2 + 1) + j + 1;\n                faces.push([offset+i2, offset+i1, offset+i4]);\n                faces.push([offset+i4, offset+i3, offset+i2]);\n            }\n        }\n\n        this.attributes.position.fromArray(positions);\n        this.attributes.texcoord0.fromArray(texcoords);\n\n        this.initIndicesFromArray(faces);\n\n        this.generateVertexNormals();\n\n        this.boundingBox = new BoundingBox();\n        var r = Math.max(this.topRadius, this.bottomRadius);\n        this.boundingBox.min.set(-r, -this.height/2, -r);\n        this.boundingBox.max.set(r, this.height/2, r);\n    }\n});\n\nexport default Cone;\n","import Geometry from '../Geometry';\nimport ConeGeometry from './Cone';\n\n/**\n * @constructor clay.geometry.Cylinder\n * @extends clay.Geometry\n * @param {Object} [opt]\n * @param {number} [opt.radius]\n * @param {number} [opt.height]\n * @param {number} [opt.capSegments]\n * @param {number} [opt.heightSegments]\n */\nvar Cylinder = Geometry.extend(\n/** @lends clay.geometry.Cylinder# */\n{\n    dynamic: false,\n    /**\n     * @type {number}\n     */\n    radius: 1,\n\n    /**\n     * @type {number}\n     */\n    height: 2,\n\n    /**\n     * @type {number}\n     */\n    capSegments: 50,\n\n    /**\n     * @type {number}\n     */\n    heightSegments: 1\n}, function() {\n    this.build();\n},\n/** @lends clay.geometry.Cylinder.prototype */\n{\n    /**\n     * Build cylinder geometry\n     */\n    build: function() {\n        var cone = new ConeGeometry({\n            topRadius: this.radius,\n            bottomRadius: this.radius,\n            capSegments: this.capSegments,\n            heightSegments: this.heightSegments,\n            height: this.height\n        });\n\n        this.attributes.position.value = cone.attributes.position.value;\n        this.attributes.normal.value = cone.attributes.normal.value;\n        this.attributes.texcoord0.value = cone.attributes.texcoord0.value;\n        this.indices = cone.indices;\n\n        this.boundingBox = cone.boundingBox;\n    }\n});\n\nexport default Cylinder;\n","export default \"@export clay.deferred.light_volume.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    gl_Position = worldViewProjection * vec4(position, 1.0);\\n    v_Position = position;\\n}\\n@end\";\n","export default \"@export clay.deferred.spot_light\\n@import clay.deferred.chunk.light_head\\n@import clay.deferred.chunk.light_equation\\n@import clay.util.calculate_attenuation\\nuniform vec3 lightPosition;\\nuniform vec3 lightDirection;\\nuniform vec3 lightColor;\\nuniform float umbraAngleCosine;\\nuniform float penumbraAngleCosine;\\nuniform float lightRange;\\nuniform float falloffFactor;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform sampler2D lightShadowMap;\\nuniform mat4 lightMatrix;\\nuniform float lightShadowMapSize;\\n#endif\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    L /= dist;\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    float c = dot(-normalize(lightDirection), L);\\n    float falloff = clamp((c - umbraAngleCosine) / (penumbraAngleCosine - umbraAngleCosine), 0.0, 1.0);\\n    falloff = pow(falloff, falloffFactor);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    gl_FragColor.rgb = (1.0 - falloff) * attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = computeShadowContrib(\\n        lightShadowMap, lightMatrix, position, lightShadowMapSize\\n    );\\n    gl_FragColor.rgb *= shadowContrib;\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\\n\";\n","export default \"@export clay.deferred.directional_light\\n@import clay.deferred.chunk.light_head\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightDirection;\\nuniform vec3 lightColor;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform sampler2D lightShadowMap;\\nuniform float lightShadowMapSize;\\nuniform mat4 lightMatrices[SHADOW_CASCADE];\\nuniform float shadowCascadeClipsNear[SHADOW_CASCADE];\\nuniform float shadowCascadeClipsFar[SHADOW_CASCADE];\\n#endif\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = -normalize(lightDirection);\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    gl_FragColor.rgb = lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = 1.0;\\n    for (int _idx_ = 0; _idx_ < SHADOW_CASCADE; _idx_++) {{\\n        if (\\n            z >= shadowCascadeClipsNear[_idx_] &&\\n            z <= shadowCascadeClipsFar[_idx_]\\n        ) {\\n            shadowContrib = computeShadowContrib(\\n                lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\\n                vec2(1.0 / float(SHADOW_CASCADE), 1.0),\\n                vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\\n            );\\n        }\\n    }}\\n    gl_FragColor.rgb *= shadowContrib;\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\\n\";\n","export default \"@export clay.deferred.ambient_light\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture3;\\nuniform vec3 lightColor;\\nuniform vec2 windowSize: WINDOW_SIZE;\\nvoid main()\\n{\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\\n    gl_FragColor.rgb = lightColor * albedo;\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.ambient_sh_light\\nuniform sampler2D gBufferTexture1;\\nuniform sampler2D gBufferTexture3;\\nuniform vec3 lightColor;\\nuniform vec3 lightCoefficients[9];\\nuniform vec2 windowSize: WINDOW_SIZE;\\nvec3 calcAmbientSHLight(vec3 N) {\\n    return lightCoefficients[0]\\n        + lightCoefficients[1] * N.x\\n        + lightCoefficients[2] * N.y\\n        + lightCoefficients[3] * N.z\\n        + lightCoefficients[4] * N.x * N.z\\n        + lightCoefficients[5] * N.z * N.y\\n        + lightCoefficients[6] * N.y * N.x\\n        + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\\n        + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\\n}\\nvoid main()\\n{\\n    vec2 uv = gl_FragCoord.xy / windowSize;\\n    vec4 texel1 = texture2D(gBufferTexture1, uv);\\n    if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\\n        discard;\\n    }\\n    vec3 N = texel1.rgb * 2.0 - 1.0;\\n    vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\\n    gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.ambient_cubemap_light\\n@import clay.deferred.chunk.light_head\\nuniform vec3 lightColor;\\nuniform samplerCube lightCubemap;\\nuniform sampler2D brdfLookup;\\nuniform vec3 eyePosition;\\n@import clay.util.rgbm\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 L = reflect(-V, N);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float rough = clamp(1.0 - glossiness, 0.0, 1.0);\\n    float bias = rough * 5.0;\\n    vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\\n    vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\\n    vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\\n    gl_FragColor.rgb = lightColor * envTexel * envWeight;\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.point_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform vec3 eyePosition;\\n#ifdef SHADOWMAP_ENABLED\\nuniform samplerCube lightShadowMap;\\nuniform float lightShadowMapSize;\\n#endif\\nvarying vec3 v_Position;\\n@import clay.plugin.shadow_map_common\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    L /= dist;\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    gl_FragColor.rgb = attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n#ifdef SHADOWMAP_ENABLED\\n    float shadowContrib = computeShadowContribOmni(\\n        lightShadowMap, -L * dist, lightRange\\n    );\\n    gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\\n#endif\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.sphere_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform float lightRadius;\\nuniform vec3 eyePosition;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    float dist = length(L);\\n    vec3 R = reflect(V, N);\\n    float tmp = dot(L, R);\\n    vec3 cToR = tmp * R - L;\\n    float d = length(cToR);\\n    L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\\n    L = normalize(L);\\n    vec3 H = normalize(L + V);\\n    float ndl = clamp(dot(N, L), 0.0, 1.0);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    float attenuation = lightAttenuation(dist, lightRange);\\n    gl_FragColor.rgb = lightColor * ndl * attenuation;\\n    glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\\n    gl_FragColor.rgb = attenuation * lightEquation(\\n        lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\\n    );\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","export default \"@export clay.deferred.tube_light\\n@import clay.deferred.chunk.light_head\\n@import clay.util.calculate_attenuation\\n@import clay.deferred.chunk.light_equation\\nuniform vec3 lightPosition;\\nuniform vec3 lightColor;\\nuniform float lightRange;\\nuniform vec3 lightExtend;\\nuniform vec3 eyePosition;\\nvarying vec3 v_Position;\\nvoid main()\\n{\\n    @import clay.deferred.chunk.gbuffer_read\\n    vec3 L = lightPosition - position;\\n    vec3 V = normalize(eyePosition - position);\\n    vec3 R = reflect(V, N);\\n    vec3 L0 = lightPosition - lightExtend - position;\\n    vec3 L1 = lightPosition + lightExtend - position;\\n    vec3 LD = L1 - L0;\\n    float len0 = length(L0);\\n    float len1 = length(L1);\\n    float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\\n    float LDDotR = dot(R, LD);\\n    float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\\n    t = clamp(t, 0.0, 1.0);\\n    L = L0 + t * LD;\\n    float dist = length(L);\\n    L /= dist;\\n    vec3 H = normalize(L + V);\\n    float ndh = clamp(dot(N, H), 0.0, 1.0);\\n    float ndv = clamp(dot(N, V), 0.0, 1.0);\\n    glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\\n    gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\\n        * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\\n    gl_FragColor.a = 1.0;\\n}\\n@end\";\n","// Light-pre pass deferred rendering\n// http://www.realtimerendering.com/blog/deferred-lighting-approaches/\nimport Base from '../core/Base';\nimport Shader from '../Shader';\nimport Material from '../Material';\nimport FrameBuffer from '../FrameBuffer';\nimport FullQuadPass from '../compositor/Pass';\nimport Texture2D from '../Texture2D';\nimport Texture from '../Texture';\nimport Mesh from '../Mesh';\nimport SphereGeo from '../geometry/Sphere';\nimport ConeGeo from '../geometry/Cone';\nimport CylinderGeo from '../geometry/Cylinder';\nimport Matrix4 from '../math/Matrix4';\nimport Vector3 from '../math/Vector3';\nimport GBuffer from './GBuffer';\n\nimport prezGlsl from '../shader/source/prez.glsl.js';\nimport utilGlsl from '../shader/source/util.glsl.js';\n\nimport lightvolumeGlsl from '../shader/source/deferred/lightvolume.glsl.js';\n// Light shaders\nimport spotGlsl from '../shader/source/deferred/spot.glsl.js';\nimport directionalGlsl from '../shader/source/deferred/directional.glsl.js';\nimport ambientGlsl from '../shader/source/deferred/ambient.glsl.js';\nimport ambientshGlsl from '../shader/source/deferred/ambientsh.glsl.js';\nimport ambientcubemapGlsl from '../shader/source/deferred/ambientcubemap.glsl.js';\nimport pointGlsl from '../shader/source/deferred/point.glsl.js';\nimport sphereGlsl from '../shader/source/deferred/sphere.glsl.js';\nimport tubeGlsl from '../shader/source/deferred/tube.glsl.js';\n\nShader.import(prezGlsl);\nShader.import(utilGlsl);\nShader.import(lightvolumeGlsl);\n\n// Light shaders\nShader.import(spotGlsl);\nShader.import(directionalGlsl);\nShader.import(ambientGlsl);\nShader.import(ambientshGlsl);\nShader.import(ambientcubemapGlsl);\nShader.import(pointGlsl);\nShader.import(sphereGlsl);\nShader.import(tubeGlsl);\n\nShader.import(prezGlsl);\n\n/**\n * Deferred renderer\n * @constructor\n * @alias clay.deferred.Renderer\n * @extends clay.core.Base\n */\nvar DeferredRenderer = Base.extend(function () {\n\n    var fullQuadVertex = Shader.source('clay.compositor.vertex');\n    var lightVolumeVertex = Shader.source('clay.deferred.light_volume.vertex');\n\n    var directionalLightShader = new Shader(fullQuadVertex, Shader.source('clay.deferred.directional_light'));\n\n    var lightAccumulateBlendFunc = function (gl) {\n        gl.blendEquation(gl.FUNC_ADD);\n        gl.blendFunc(gl.ONE, gl.ONE);\n    };\n\n    var createLightPassMat = function (shader) {\n        return new Material({\n            shader: shader,\n            blend: lightAccumulateBlendFunc,\n            transparent: true,\n            depthMask: false\n        });\n    };\n\n    var createVolumeShader = function (name) {\n        return new Shader(lightVolumeVertex, Shader.source('clay.deferred.' + name));\n    };\n\n    // Rotate and positioning to fit the spot light\n    // Which the cusp of cone pointing to the positive z\n    // and positioned on the origin\n    var coneGeo = new ConeGeo({\n        capSegments: 10\n    });\n    var mat = new Matrix4();\n    mat.rotateX(Math.PI / 2)\n        .translate(new Vector3(0, -1, 0));\n\n    coneGeo.applyTransform(mat);\n\n    var cylinderGeo = new CylinderGeo({\n        capSegments: 10\n    });\n    // Align with x axis\n    mat.identity().rotateZ(Math.PI / 2);\n    cylinderGeo.applyTransform(mat);\n\n    return /** @lends clay.deferred.Renderer# */ {\n\n        /**\n         * Provide ShadowMapPass for shadow rendering.\n         * @type {clay.prePass.ShadowMap}\n         */\n        shadowMapPass: null,\n        /**\n         * If enable auto resizing from given defualt renderer size.\n         * @type {boolean}\n         */\n        autoResize: true,\n\n        _createLightPassMat: createLightPassMat,\n\n        _gBuffer: new GBuffer(),\n\n        _lightAccumFrameBuffer: new FrameBuffer({\n            depthBuffer: false\n        }),\n\n        _lightAccumTex: new Texture2D({\n            // FIXME Device not support float texture\n            type: Texture.HALF_FLOAT,\n            minFilter: Texture.NEAREST,\n            magFilter: Texture.NEAREST\n        }),\n\n        _fullQuadPass: new FullQuadPass({\n            blendWithPrevious: true\n        }),\n\n        _directionalLightMat: createLightPassMat(directionalLightShader),\n\n        _ambientMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_light')\n        )),\n        _ambientSHMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_sh_light')\n        )),\n        _ambientCubemapMat: createLightPassMat(new Shader(\n            fullQuadVertex, Shader.source('clay.deferred.ambient_cubemap_light')\n        )),\n\n        _spotLightShader: createVolumeShader('spot_light'),\n        _pointLightShader: createVolumeShader('point_light'),\n\n        _sphereLightShader: createVolumeShader('sphere_light'),\n        _tubeLightShader: createVolumeShader('tube_light'),\n\n        _lightSphereGeo: new SphereGeo({\n            widthSegments: 10,\n            heightSegements: 10\n        }),\n\n        _lightConeGeo: coneGeo,\n\n        _lightCylinderGeo: cylinderGeo,\n\n        _outputPass: new FullQuadPass({\n            fragment: Shader.source('clay.compositor.output')\n        })\n    };\n}, /** @lends clay.deferred.Renderer# */ {\n    /**\n     * Do render\n     * @param {clay.Renderer} renderer\n     * @param {clay.Scene} scene\n     * @param {clay.Camera} camera\n     * @param {Object} [opts]\n     * @param {boolean} [opts.renderToTarget = false] If not ouput and render to the target texture\n     * @param {boolean} [opts.notUpdateShadow = true] If not update the shadow.\n     * @param {boolean} [opts.notUpdateScene = true] If not update the scene.\n     */\n    render: function (renderer, scene, camera, opts) {\n\n        opts = opts || {};\n        opts.renderToTarget = opts.renderToTarget || false;\n        opts.notUpdateShadow = opts.notUpdateShadow || false;\n        opts.notUpdateScene = opts.notUpdateScene || false;\n\n        if (!opts.notUpdateScene) {\n            scene.update(false, true);\n        }\n\n        camera.update(true);\n\n        // PENDING For stereo rendering\n        var dpr = renderer.getDevicePixelRatio();\n        if (this.autoResize\n            && (renderer.getWidth() * dpr !== this._lightAccumTex.width\n            || renderer.getHeight() * dpr !== this._lightAccumTex.height)\n        ) {\n            this.resize(renderer.getWidth() * dpr, renderer.getHeight() * dpr);\n        }\n\n        this._gBuffer.update(renderer, scene, camera);\n\n        // Accumulate light buffer\n        this._accumulateLightBuffer(renderer, scene, camera, !opts.notUpdateShadow);\n\n        if (!opts.renderToTarget) {\n            this._outputPass.setUniform('texture', this._lightAccumTex);\n\n            this._outputPass.render(renderer);\n            // this._gBuffer.renderDebug(renderer, camera, 'normal');\n        }\n    },\n\n    /**\n     * @return {clay.Texture2D}\n     */\n    getTargetTexture: function () {\n        return this._lightAccumTex;\n    },\n\n    /**\n     * @return {clay.FrameBuffer}\n     */\n    getTargetFrameBuffer: function () {\n        return this._lightAccumFrameBuffer;\n    },\n\n    /**\n     * @return {clay.deferred.GBuffer}\n     */\n    getGBuffer: function () {\n        return this._gBuffer;\n    },\n\n    // TODO is dpr needed?\n    setViewport: function (x, y, width, height, dpr) {\n        this._gBuffer.setViewport(x, y, width, height, dpr);\n        this._lightAccumFrameBuffer.viewport = this._gBuffer.getViewport();\n    },\n\n    // getFullQuadLightPass: function () {\n    //     return this._fullQuadPass;\n    // },\n\n    /**\n     * Set renderer size.\n     * @param {number} width\n     * @param {number} height\n     */\n    resize: function (width, height) {\n        this._lightAccumTex.width = width;\n        this._lightAccumTex.height = height;\n\n        // PENDING viewport ?\n        this._gBuffer.resize(width, height);\n    },\n\n    _accumulateLightBuffer: function (renderer, scene, camera, updateShadow) {\n        var gl = renderer.gl;\n        var lightAccumTex = this._lightAccumTex;\n        var lightAccumFrameBuffer = this._lightAccumFrameBuffer;\n\n        var eyePosition = camera.getWorldPosition().array;\n\n        // Update volume meshes\n        for (var i = 0; i < scene.lights.length; i++) {\n            this._updateLightProxy(scene.lights[i]);\n        }\n\n        var shadowMapPass = this.shadowMapPass;\n        if (shadowMapPass && updateShadow) {\n            gl.clearColor(1, 1, 1, 1);\n            this._prepareLightShadow(renderer, scene, camera);\n        }\n\n        this.trigger('beforelightaccumulate', renderer, scene, camera, updateShadow);\n\n        lightAccumFrameBuffer.attach(lightAccumTex);\n        lightAccumFrameBuffer.bind(renderer);\n        var clearColor = renderer.clearColor;\n\n        var viewport = lightAccumFrameBuffer.viewport;\n        if (viewport) {\n            var dpr = viewport.devicePixelRatio;\n            // use scissor to make sure only clear the viewport\n            gl.enable(gl.SCISSOR_TEST);\n            gl.scissor(viewport.x * dpr, viewport.y * dpr, viewport.width * dpr, viewport.height * dpr);\n        }\n        gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n        gl.clear(gl.COLOR_BUFFER_BIT);\n        gl.enable(gl.BLEND);\n        if (viewport) {\n            gl.disable(gl.SCISSOR_TEST);\n        }\n\n        this.trigger('startlightaccumulate', renderer, scene, camera);\n\n        var viewProjectionInv = new Matrix4();\n        Matrix4.multiply(viewProjectionInv, camera.worldTransform, camera.invProjectionMatrix);\n\n        var volumeMeshList = [];\n\n        for (var i = 0; i < scene.lights.length; i++) {\n            var light = scene.lights[i];\n            var uTpl = light.uniformTemplates;\n\n            var volumeMesh = light.volumeMesh || light.__volumeMesh;\n\n            if (volumeMesh) {\n                var material = volumeMesh.material;\n                // Volume mesh will affect the scene bounding box when rendering\n                // if castShadow is true\n                volumeMesh.castShadow = false;\n\n                var unknownLightType = false;\n                switch (light.type) {\n                    case 'POINT_LIGHT':\n                        material.setUniform('lightColor', uTpl.pointLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.pointLightRange.value(light));\n                        material.setUniform('lightPosition', uTpl.pointLightPosition.value(light));\n                        break;\n                    case 'SPOT_LIGHT':\n                        material.setUniform('lightPosition', uTpl.spotLightPosition.value(light));\n                        material.setUniform('lightColor', uTpl.spotLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.spotLightRange.value(light));\n                        material.setUniform('lightDirection', uTpl.spotLightDirection.value(light));\n                        material.setUniform('umbraAngleCosine', uTpl.spotLightUmbraAngleCosine.value(light));\n                        material.setUniform('penumbraAngleCosine', uTpl.spotLightPenumbraAngleCosine.value(light));\n                        material.setUniform('falloffFactor', uTpl.spotLightFalloffFactor.value(light));\n                        break;\n                    case 'SPHERE_LIGHT':\n                        material.setUniform('lightColor', uTpl.sphereLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.sphereLightRange.value(light));\n                        material.setUniform('lightRadius', uTpl.sphereLightRadius.value(light));\n                        material.setUniform('lightPosition', uTpl.sphereLightPosition.value(light));\n                        break;\n                    case 'TUBE_LIGHT':\n                        material.setUniform('lightColor', uTpl.tubeLightColor.value(light));\n                        material.setUniform('lightRange', uTpl.tubeLightRange.value(light));\n                        material.setUniform('lightExtend', uTpl.tubeLightExtend.value(light));\n                        material.setUniform('lightPosition', uTpl.tubeLightPosition.value(light));\n                        break;\n                    default:\n                        unknownLightType = true;\n                }\n\n                if (unknownLightType) {\n                    continue;\n                }\n\n                material.setUniform('eyePosition', eyePosition);\n                material.setUniform('viewProjectionInv', viewProjectionInv.array);\n                material.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1());\n                material.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2());\n                material.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3());\n\n                volumeMeshList.push(volumeMesh);\n\n            }\n            else {\n                var pass = this._fullQuadPass;\n                var unknownLightType = false;\n                // Full quad light\n                switch (light.type) {\n                    case 'AMBIENT_LIGHT':\n                        pass.material = this._ambientMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientLightColor.value(light));\n                        break;\n                    case 'AMBIENT_SH_LIGHT':\n                        pass.material = this._ambientSHMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientSHLightColor.value(light));\n                        pass.material.setUniform('lightCoefficients', uTpl.ambientSHLightCoefficients.value(light));\n                        break;\n                    case 'AMBIENT_CUBEMAP_LIGHT':\n                        pass.material = this._ambientCubemapMat;\n                        pass.material.setUniform('lightColor', uTpl.ambientCubemapLightColor.value(light));\n                        pass.material.setUniform('lightCubemap', uTpl.ambientCubemapLightCubemap.value(light));\n                        pass.material.setUniform('brdfLookup', uTpl.ambientCubemapLightBRDFLookup.value(light));\n                        break;\n                    case 'DIRECTIONAL_LIGHT':\n                        var hasShadow = shadowMapPass && light.castShadow;\n                        pass.material = this._directionalLightMat;\n                        pass.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED');\n                        if (hasShadow) {\n                            pass.material.define('fragment', 'SHADOW_CASCADE', light.shadowCascade);\n                        }\n                        pass.material.setUniform('lightColor', uTpl.directionalLightColor.value(light));\n                        pass.material.setUniform('lightDirection', uTpl.directionalLightDirection.value(light));\n                        break;\n                    default:\n                        // Unkonw light type\n                        unknownLightType = true;\n                }\n                if (unknownLightType) {\n                    continue;\n                }\n\n                var passMaterial = pass.material;\n                passMaterial.setUniform('eyePosition', eyePosition);\n                passMaterial.setUniform('viewProjectionInv', viewProjectionInv.array);\n                passMaterial.setUniform('gBufferTexture1', this._gBuffer.getTargetTexture1());\n                passMaterial.setUniform('gBufferTexture2', this._gBuffer.getTargetTexture2());\n                passMaterial.setUniform('gBufferTexture3', this._gBuffer.getTargetTexture3());\n\n                // TODO\n                if (shadowMapPass && light.castShadow) {\n                    passMaterial.setUniform('lightShadowMap', light.__shadowMap);\n                    passMaterial.setUniform('lightMatrices', light.__lightMatrices);\n                    passMaterial.setUniform('shadowCascadeClipsNear', light.__cascadeClipsNear);\n                    passMaterial.setUniform('shadowCascadeClipsFar', light.__cascadeClipsFar);\n\n                    passMaterial.setUniform('lightShadowMapSize', light.shadowResolution);\n                }\n\n                pass.renderQuad(renderer);\n            }\n        }\n\n        this._renderVolumeMeshList(renderer, camera, volumeMeshList);\n\n        this.trigger('lightaccumulate', renderer, scene, camera);\n\n        lightAccumFrameBuffer.unbind(renderer);\n\n        this.trigger('afterlightaccumulate', renderer, scene, camera);\n\n    },\n\n    _prepareLightShadow: (function () {\n        var worldView = new Matrix4();\n        return function (renderer, scene, camera) {\n            var shadowCasters;\n\n            shadowCasters = this._shadowCasters || (this._shadowCasters = []);\n            var count = 0;\n            var list = scene.opaqueList;\n            for (var i = 0; i < list.length; i++) {\n                if (list[i].castShadow) {\n                    shadowCasters[count++] = list[i];\n                }\n            }\n            shadowCasters.length = count;\n\n            for (var i = 0; i < scene.lights.length; i++) {\n                var light = scene.lights[i];\n                var volumeMesh = light.volumeMesh || light.__volumeMesh;\n                if (!light.castShadow) {\n                    continue;\n                }\n\n                switch (light.type) {\n                    case 'POINT_LIGHT':\n                    case 'SPOT_LIGHT':\n                        // Frustum culling\n                        Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform);\n                        if (renderer.isFrustumCulled(\n                            volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array\n                        )) {\n                            continue;\n                        }\n\n                        this._prepareSingleLightShadow(\n                            renderer, scene, camera, light, shadowCasters, volumeMesh.material\n                        );\n                        break;\n                    case 'DIRECTIONAL_LIGHT':\n                        this._prepareSingleLightShadow(\n                            renderer, scene, camera, light, shadowCasters, null\n                        );\n                }\n            }\n        };\n    })(),\n\n    _prepareSingleLightShadow: function (renderer, scene, camera, light, casters, material) {\n        switch (light.type) {\n            case 'POINT_LIGHT':\n                var shadowMaps = [];\n                this.shadowMapPass.renderPointLightShadow(\n                    renderer, scene, light, casters, shadowMaps\n                );\n                material.setUniform('lightShadowMap', shadowMaps[0]);\n                material.setUniform('lightShadowMapSize', light.shadowResolution);\n                break;\n            case 'SPOT_LIGHT':\n                var shadowMaps = [];\n                var lightMatrices = [];\n                this.shadowMapPass.renderSpotLightShadow(\n                    renderer, scene, light, casters, lightMatrices, shadowMaps\n                );\n                material.setUniform('lightShadowMap', shadowMaps[0]);\n                material.setUniform('lightMatrix', lightMatrices[0]);\n                material.setUniform('lightShadowMapSize', light.shadowResolution);\n                break;\n            case 'DIRECTIONAL_LIGHT':\n                var shadowMaps = [];\n                var lightMatrices = [];\n                var cascadeClips = [];\n                this.shadowMapPass.renderDirectionalLightShadow(\n                    renderer, scene, camera, light, casters, cascadeClips, lightMatrices, shadowMaps\n                );\n                var cascadeClipsNear = cascadeClips.slice();\n                var cascadeClipsFar = cascadeClips.slice();\n                cascadeClipsNear.pop();\n                cascadeClipsFar.shift();\n\n                // Iterate from far to near\n                cascadeClipsNear.reverse();\n                cascadeClipsFar.reverse();\n                lightMatrices.reverse();\n\n                light.__cascadeClipsNear = cascadeClipsNear;\n                light.__cascadeClipsFar = cascadeClipsFar;\n                light.__shadowMap = shadowMaps[0];\n                light.__lightMatrices = lightMatrices;\n                break;\n        }\n    },\n\n    // Update light volume mesh\n    // Light volume mesh is rendered in light accumulate pass instead of full quad.\n    // It will reduce pixels significantly when local light is relatively small.\n    // And we can use custom volume mesh to shape the light.\n    //\n    // See \"Deferred Shading Optimizations\" in GDC2011\n    _updateLightProxy: function (light) {\n        var volumeMesh;\n        if (light.volumeMesh) {\n            volumeMesh = light.volumeMesh;\n        }\n        else {\n            switch (light.type) {\n                // Only local light (point and spot) needs volume mesh.\n                // Directional and ambient light renders in full quad\n                case 'POINT_LIGHT':\n                case 'SPHERE_LIGHT':\n                    var shader = light.type === 'SPHERE_LIGHT'\n                        ? this._sphereLightShader : this._pointLightShader;\n                    // Volume mesh created automatically\n                    if (!light.__volumeMesh) {\n                        light.__volumeMesh = new Mesh({\n                            material: this._createLightPassMat(shader),\n                            geometry: this._lightSphereGeo,\n                            // Disable culling\n                            // if light volume mesh intersect camera near plane\n                            // We need mesh inside can still be rendered\n                            culling: false\n                        });\n                    }\n                    volumeMesh = light.__volumeMesh;\n                    var r = light.range + (light.radius || 0);\n                    volumeMesh.scale.set(r, r, r);\n                    break;\n                case 'SPOT_LIGHT':\n                    light.__volumeMesh = light.__volumeMesh || new Mesh({\n                        material: this._createLightPassMat(this._spotLightShader),\n                        geometry: this._lightConeGeo,\n                        culling: false\n                    });\n                    volumeMesh = light.__volumeMesh;\n                    var aspect = Math.tan(light.penumbraAngle * Math.PI / 180);\n                    var range = light.range;\n                    volumeMesh.scale.set(aspect * range, aspect * range, range / 2);\n                    break;\n                case 'TUBE_LIGHT':\n                    light.__volumeMesh = light.__volumeMesh || new Mesh({\n                        material: this._createLightPassMat(this._tubeLightShader),\n                        geometry: this._lightCylinderGeo,\n                        culling: false\n                    });\n                    volumeMesh = light.__volumeMesh;\n                    var range = light.range;\n                    volumeMesh.scale.set(light.length / 2 + range, range, range);\n                    break;\n            }\n        }\n        if (volumeMesh) {\n            volumeMesh.update();\n            // Apply light transform\n            Matrix4.multiply(volumeMesh.worldTransform, light.worldTransform, volumeMesh.worldTransform);\n            var hasShadow = this.shadowMapPass && light.castShadow;\n            volumeMesh.material[hasShadow ? 'define' : 'undefine']('fragment', 'SHADOWMAP_ENABLED');\n        }\n    },\n\n    _renderVolumeMeshList: (function () {\n        var worldViewProjection = new Matrix4();\n        var worldView = new Matrix4();\n        var preZMaterial = new Material({\n            shader: new Shader(Shader.source('clay.prez.vertex'), Shader.source('clay.prez.fragment'))\n        });\n        return function (renderer, camera, volumeMeshList) {\n            var gl = renderer.gl;\n\n            gl.enable(gl.DEPTH_TEST);\n            gl.disable(gl.CULL_FACE);\n            gl.blendEquation(gl.FUNC_ADD);\n            gl.blendFuncSeparate(gl.ONE, gl.ONE, gl.ONE, gl.ONE);\n            gl.depthFunc(gl.LEQUAL);\n\n            gl.clear(gl.DEPTH_BUFFER_BIT);\n\n            var viewport = renderer.viewport;\n            var dpr = viewport.devicePixelRatio;\n            var viewportUniform = [\n                viewport.x * dpr, viewport.y * dpr,\n                viewport.width * dpr, viewport.height * dpr\n            ];\n\n            var windowSizeUniform = [\n                this._lightAccumTex.width,\n                this._lightAccumTex.height\n            ];\n\n            for (var i = 0; i < volumeMeshList.length; i++) {\n                var volumeMesh = volumeMeshList[i];\n\n                // Frustum culling\n                Matrix4.multiply(worldView, camera.viewMatrix, volumeMesh.worldTransform);\n                if (renderer.isFrustumCulled(\n                    volumeMesh, null, camera, worldView.array, camera.projectionMatrix.array\n                )) {\n                    continue;\n                }\n\n                // Use prez to avoid one pixel rendered twice\n                gl.colorMask(false, false, false, false);\n                gl.depthMask(true);\n                // depthMask must be enabled before clear DEPTH_BUFFER\n                gl.clear(gl.DEPTH_BUFFER_BIT);\n\n                Matrix4.multiply(worldViewProjection, camera.projectionMatrix, worldView);\n\n                var preZProgram = renderer.getProgram(volumeMesh, preZMaterial);\n                volumeMesh.__program = preZProgram;\n                renderer.validateProgram(preZProgram);\n                preZProgram.bind(renderer);\n\n                var semanticInfo = preZMaterial.shader.matrixSemantics.WORLDVIEWPROJECTION;\n                preZProgram.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array);\n                volumeMesh.render(renderer, preZMaterial, preZProgram);\n\n                // Render light\n                gl.colorMask(true, true, true, true);\n                gl.depthMask(false);\n                var program = renderer.getProgram(volumeMesh, volumeMesh.material);\n                volumeMesh.__program = program;\n                renderer.validateProgram(program);\n                program.bind(renderer);\n\n                var semanticInfo = volumeMesh.material.shader.matrixSemantics.WORLDVIEWPROJECTION;\n                // Set some common uniforms\n                program.setUniform(gl, semanticInfo.type, semanticInfo.symbol, worldViewProjection.array);\n                program.setUniformOfSemantic(gl, 'WINDOW_SIZE', windowSizeUniform);\n                program.setUniformOfSemantic(gl, 'VIEWPORT', viewportUniform);\n\n                volumeMesh.material.bind(renderer, program);\n                volumeMesh.render(renderer, volumeMesh.material, program);\n            }\n\n            gl.depthFunc(gl.LESS);\n        };\n    })(),\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function (renderer) {\n        this._gBuffer.dispose(renderer);\n\n        this._lightAccumFrameBuffer.dispose(renderer);\n        this._lightAccumTex.dispose(renderer);\n\n        this._lightConeGeo.dispose(renderer);\n        this._lightCylinderGeo.dispose(renderer);\n        this._lightSphereGeo.dispose(renderer);\n\n        this._fullQuadPass.dispose(renderer);\n        this._outputPass.dispose(renderer);\n\n        this._directionalLightMat.dispose(renderer);\n\n        this.shadowMapPass.dispose(renderer);\n    }\n});\n\nexport default DeferredRenderer;\n","import Light from '../Light';\n\n/**\n * @constructor clay.light.Sphere\n * @extends {clay.Light}\n */\nvar SphereLight = Light.extend(\n/** @lends clay.light.Sphere# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    radius: 5\n}, {\n\n    type: 'SPHERE_LIGHT',\n\n    uniformTemplates: {\n        sphereLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n        sphereLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n        sphereLightRadius: {\n            type: '1f',\n            value: function(instance) {\n                return instance.radius;\n            }\n        },\n        sphereLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n});\n\nexport default SphereLight;\n","import Light from '../Light';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.light.Tube\n * @extends {clay.Light}\n */\nvar TubeLight = Light.extend(\n/** @lends clay.light.Tube# */\n{\n    /**\n     * @type {number}\n     */\n    range: 100,\n\n    /**\n     * @type {number}\n     */\n    length: 10\n}, {\n\n    type: 'TUBE_LIGHT',\n\n    uniformTemplates: {\n        tubeLightPosition: {\n            type: '3f',\n            value: function(instance) {\n                return instance.getWorldPosition().array;\n            }\n        },\n\n        tubeLightExtend: {\n            type: '3f',\n            value: (function() {\n                var x = new Vector3();\n                return function(instance) {\n                    // Extend in x axis\n                    return x.copy(instance.worldTransform.x)\n                        .normalize().scale(instance.length / 2).array;\n                };\n            })()\n        },\n\n        tubeLightRange: {\n            type: '1f',\n            value: function(instance) {\n                return instance.range;\n            }\n        },\n\n        tubeLightColor: {\n            type: '3f',\n            value: function(instance) {\n                var color = instance.color;\n                var intensity = instance.intensity;\n                return [color[0]*intensity, color[1]*intensity, color[2]*intensity];\n            }\n        }\n    }\n});\n\nexport default TubeLight;\n","import Base from '../core/Base';\nimport request from '../core/request';\nimport createCompositor from '../compositor/createCompositor';\n\n/**\n * @constructor clay.loader.FX\n * @extends clay.core.Base\n */\nvar FXLoader = Base.extend(\n/** @lends clay.loader.FX# */\n{\n    /**\n     * @type {string}\n     */\n    rootPath: '',\n    /**\n     * @type {string}\n     */\n    textureRootPath: '',\n    /**\n     * @type {string}\n     */\n    shaderRootPath: '',\n\n    /**\n     * @type {clay.Scene}\n     */\n    scene: null,\n\n    /**\n     * @type {clay.Camera}\n     */\n    camera: null\n},\n/** @lends clay.loader.FX.prototype */\n{\n    /**\n     * @param  {string} url\n     */\n    load: function(url) {\n        var self = this;\n\n        if (!this.rootPath) {\n            this.rootPath = url.slice(0, url.lastIndexOf('/'));\n        }\n\n        request.get({\n            url: url,\n            onprogress: function(percent, loaded, total) {\n                self.trigger('progress', percent, loaded, total);\n            },\n            onerror: function(e) {\n                self.trigger('error', e);\n            },\n            responseType: 'text',\n            onload: function (data) {\n                createCompositor(JSON.parse(data), {\n                    textureRootPath: this.textureRootPath || this.rootPath,\n                    camera: this.camera,\n                    scene: this.scene\n                });\n            }\n        });\n    }\n});\n\nexport default FXLoader;\n","import glMatrix from '../dep/glmatrix';\nvar mat2 = glMatrix.mat2;\n\n/**\n * @constructor\n * @alias clay.math.Matrix2\n */\nvar Matrix2 = function() {\n\n    /**\n     * Storage of Matrix2\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix2#\n     */\n    this.array = mat2.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix2#\n     */\n    this._dirty = true;\n};\n\nMatrix2.prototype = {\n\n    constructor: Matrix2,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Clone a new Matrix2\n     * @return {clay.math.Matrix2}\n     */\n    clone: function() {\n        return (new Matrix2()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    copy: function(b) {\n        mat2.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix2}\n     */\n    adjoint: function() {\n        mat2.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat2.determinant(this.array);\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix2}\n     */\n    identity: function() {\n        mat2.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix2}\n     */\n    invert: function() {\n        mat2.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    mul: function(b) {\n        mat2.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix2} a\n     * @return {clay.math.Matrix2}\n     */\n    mulLeft: function(a) {\n        mat2.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix2} b\n     * @return {clay.math.Matrix2}\n     */\n    multiply: function(b) {\n        mat2.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix2} a\n     * @return {clay.math.Matrix2}\n     */\n    multiplyLeft: function(a) {\n        mat2.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix2}\n     */\n    rotate: function(rad) {\n        mat2.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix2}\n     */\n    scale: function(v) {\n        mat2.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function() {\n        mat2.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n/**\n * @param  {Matrix2} out\n * @param  {Matrix2} a\n * @return {Matrix2}\n */\nMatrix2.adjoint = function(out, a) {\n    mat2.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @return {clay.math.Matrix2}\n */\nMatrix2.copy = function(out, a) {\n    mat2.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} a\n * @return {number}\n */\nMatrix2.determinant = function(a) {\n    return mat2.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @return {clay.math.Matrix2}\n */\nMatrix2.identity = function(out) {\n    mat2.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @return {clay.math.Matrix2}\n */\nMatrix2.invert = function(out, a) {\n    mat2.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Matrix2} b\n * @return {clay.math.Matrix2}\n */\nMatrix2.mul = function(out, a, b) {\n    mat2.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Matrix2} b\n * @return {clay.math.Matrix2}\n */\nMatrix2.multiply = Matrix2.mul;\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {number}   rad\n * @return {clay.math.Matrix2}\n */\nMatrix2.rotate = function(out, a, rad) {\n    mat2.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2} out\n * @param  {clay.math.Matrix2} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2}\n */\nMatrix2.scale = function(out, a, v) {\n    mat2.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @param  {Matrix2} out\n * @param  {Matrix2} a\n * @return {Matrix2}\n */\nMatrix2.transpose = function(out, a) {\n    mat2.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix2;\n","import glMatrix from '../dep/glmatrix';\nvar mat2d = glMatrix.mat2d;\n\n/**\n * @constructor\n * @alias clay.math.Matrix2d\n */\nvar Matrix2d = function() {\n    /**\n     * Storage of Matrix2d\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix2d#\n     */\n    this.array = mat2d.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix2d#\n     */\n    this._dirty = true;\n};\n\nMatrix2d.prototype = {\n\n    constructor: Matrix2d,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Clone a new Matrix2d\n     * @return {clay.math.Matrix2d}\n     */\n    clone: function() {\n        return (new Matrix2d()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    copy: function(b) {\n        mat2d.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function() {\n        return mat2d.determinant(this.array);\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix2d}\n     */\n    identity: function() {\n        mat2d.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix2d}\n     */\n    invert: function() {\n        mat2d.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    mul: function(b) {\n        mat2d.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix2d}\n     */\n    mulLeft: function(b) {\n        mat2d.mul(this.array, b.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix2d} b\n     * @return {clay.math.Matrix2d}\n     */\n    multiply: function(b) {\n        mat2d.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix2d}\n     */\n    multiplyLeft: function(b) {\n        mat2d.multiply(this.array, b.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix2d}\n     */\n    rotate: function(rad) {\n        mat2d.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix2d}\n     */\n    scale: function(s) {\n        mat2d.scale(this.array, this.array, s.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v\n     * @param  {clay.math.Vector2}  v\n     * @return {clay.math.Matrix2d}\n     */\n    translate: function(v) {\n        mat2d.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.copy = function(out, a) {\n    mat2d.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} a\n * @return {number}\n */\nMatrix2d.determinant = function(a) {\n    return mat2d.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.identity = function(out) {\n    mat2d.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.invert = function(out, a) {\n    mat2d.invert(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Matrix2d} b\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.mul = function(out, a, b) {\n    mat2d.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Matrix2d} b\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.multiply = Matrix2d.mul;\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {number}   rad\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.rotate = function(out, a, rad) {\n    mat2d.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.scale = function(out, a, v) {\n    mat2d.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix2d} out\n * @param  {clay.math.Matrix2d} a\n * @param  {clay.math.Vector2}  v\n * @return {clay.math.Matrix2d}\n */\nMatrix2d.translate = function(out, a, v) {\n    mat2d.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix2d;\n","import glMatrix from '../dep/glmatrix';\nvar mat3 = glMatrix.mat3;\n\n/**\n * @constructor\n * @alias clay.math.Matrix3\n */\nvar Matrix3 = function () {\n\n    /**\n     * Storage of Matrix3\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Matrix3#\n     */\n    this.array = mat3.create();\n\n    /**\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Matrix3#\n     */\n    this._dirty = true;\n};\n\nMatrix3.prototype = {\n\n    constructor: Matrix3,\n\n    /**\n     * Set components from array\n     * @param  {Float32Array|number[]} arr\n     */\n    setArray: function (arr) {\n        for (var i = 0; i < this.array.length; i++) {\n            this.array[i] = arr[i];\n        }\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculate the adjugate of self, in-place\n     * @return {clay.math.Matrix3}\n     */\n    adjoint: function () {\n        mat3.adjoint(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Matrix3\n     * @return {clay.math.Matrix3}\n     */\n    clone: function () {\n        return (new Matrix3()).copy(this);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    copy: function (b) {\n        mat3.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculate matrix determinant\n     * @return {number}\n     */\n    determinant: function () {\n        return mat3.determinant(this.array);\n    },\n\n    /**\n     * Copy the values from Matrix2d a\n     * @param  {clay.math.Matrix2d} a\n     * @return {clay.math.Matrix3}\n     */\n    fromMat2d: function (a) {\n        mat3.fromMat2d(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Copies the upper-left 3x3 values of Matrix4\n     * @param  {clay.math.Matrix4} a\n     * @return {clay.math.Matrix3}\n     */\n    fromMat4: function (a) {\n        mat3.fromMat4(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Calculates a rotation matrix from the given quaternion\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Matrix3}\n     */\n    fromQuat: function (q) {\n        mat3.fromQuat(this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set to a identity matrix\n     * @return {clay.math.Matrix3}\n     */\n    identity: function () {\n        mat3.identity(this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Invert self\n     * @return {clay.math.Matrix3}\n     */\n    invert: function () {\n        mat3.invert(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for mutiply\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    mul: function (b) {\n        mat3.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiplyLeft\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    mulLeft: function (a) {\n        mat3.mul(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply self and b\n     * @param  {clay.math.Matrix3} b\n     * @return {clay.math.Matrix3}\n     */\n    multiply: function (b) {\n        mat3.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Multiply a and self, a is on the left\n     * @param  {clay.math.Matrix3} a\n     * @return {clay.math.Matrix3}\n     */\n    multiplyLeft: function (a) {\n        mat3.multiply(this.array, a.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Rotate self by a given radian\n     * @param  {number}   rad\n     * @return {clay.math.Matrix3}\n     */\n    rotate: function (rad) {\n        mat3.rotate(this.array, this.array, rad);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self by s\n     * @param  {clay.math.Vector2}  s\n     * @return {clay.math.Matrix3}\n     */\n    scale: function (v) {\n        mat3.scale(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Translate self by v\n     * @param  {clay.math.Vector2}  v\n     * @return {clay.math.Matrix3}\n     */\n    translate: function (v) {\n        mat3.translate(this.array, this.array, v.array);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Calculates a 3x3 normal matrix (transpose inverse) from the 4x4 matrix\n     * @param {clay.math.Matrix4} a\n     */\n    normalFromMat4: function (a) {\n        mat3.normalFromMat4(this.array, a.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transpose self, in-place.\n     * @return {clay.math.Matrix2}\n     */\n    transpose: function () {\n        mat3.transpose(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function () {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.adjoint = function (out, a) {\n    mat3.adjoint(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.copy = function (out, a) {\n    mat3.copy(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} a\n * @return {number}\n */\nMatrix3.determinant = function (a) {\n    return mat3.determinant(a.array);\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @return {clay.math.Matrix3}\n */\nMatrix3.identity = function (out) {\n    mat3.identity(out.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.invert = function (out, a) {\n    mat3.invert(out.array, a.array);\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Matrix3} b\n * @return {clay.math.Matrix3}\n */\nMatrix3.mul = function (out, a, b) {\n    mat3.mul(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Matrix3} b\n * @return {clay.math.Matrix3}\n */\nMatrix3.multiply = Matrix3.mul;\n\n/**\n * @param  {clay.math.Matrix3}  out\n * @param  {clay.math.Matrix2d} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromMat2d = function (out, a) {\n    mat3.fromMat2d(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromMat4 = function (out, a) {\n    mat3.fromMat4(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3}    out\n * @param  {clay.math.Quaternion} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.fromQuat = function (out, q) {\n    mat3.fromQuat(out.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix4} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.normalFromMat4 = function (out, a) {\n    mat3.normalFromMat4(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {number}  rad\n * @return {clay.math.Matrix3}\n */\nMatrix3.rotate = function (out, a, rad) {\n    mat3.rotate(out.array, a.array, rad);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Vector2} v\n * @return {clay.math.Matrix3}\n */\nMatrix3.scale = function (out, a, v) {\n    mat3.scale(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @return {clay.math.Matrix3}\n */\nMatrix3.transpose = function (out, a) {\n    mat3.transpose(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Matrix3} out\n * @param  {clay.math.Matrix3} a\n * @param  {clay.math.Vector2} v\n * @return {clay.math.Matrix3}\n */\nMatrix3.translate = function (out, a, v) {\n    mat3.translate(out.array, a.array, v.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Matrix3;\n","import Vector3 from './Vector3';\nimport Vector2 from './Vector2';\n\n/**\n * Random or constant 1d, 2d, 3d vector generator\n * @constructor\n * @alias clay.math.Value\n */\nvar Value = function() {};\n\n/**\n * @function\n * @param {number|clay.math.Vector2|clay.math.Vector3} [out]\n * @return {number|clay.math.Vector2|clay.math.Vector3}\n */\nValue.prototype.get = function(out) {};\n\n// Constant\nvar ConstantValue = function(val) {\n    this.get = function() {\n        return val;\n    };\n};\nConstantValue.prototype = new Value();\nConstantValue.prototype.constructor = ConstantValue;\n\n// Vector\nvar VectorValue = function(val) {\n    var Constructor = val.constructor;\n    this.get = function(out) {\n        if (!out) {\n            out = new Constructor();\n        }\n        out.copy(val);\n        return out;\n    };\n};\nVectorValue.prototype = new Value();\nVectorValue.prototype.constructor = VectorValue;\n//Random 1D\nvar Random1D = function(min, max) {\n    var range = max - min;\n    this.get = function() {\n        return Math.random() * range + min;\n    };\n};\nRandom1D.prototype = new Value();\nRandom1D.prototype.constructor = Random1D;\n\n// Random2D\nvar Random2D = function(min, max) {\n    var rangeX = max.x - min.x;\n    var rangeY = max.y - min.y;\n\n    this.get = function(out) {\n        if (!out) {\n            out = new Vector2();\n        }\n        Vector2.set(\n            out,\n            rangeX * Math.random() + min.array[0],\n            rangeY * Math.random() + min.array[1]\n        );\n\n        return out;\n    };\n};\nRandom2D.prototype = new Value();\nRandom2D.prototype.constructor = Random2D;\n\nvar Random3D = function(min, max) {\n    var rangeX = max.x - min.x;\n    var rangeY = max.y - min.y;\n    var rangeZ = max.z - min.z;\n\n    this.get = function(out) {\n        if (!out) {\n            out = new Vector3();\n        }\n        Vector3.set(\n            out,\n            rangeX * Math.random() + min.array[0],\n            rangeY * Math.random() + min.array[1],\n            rangeZ * Math.random() + min.array[2]\n        );\n\n        return out;\n    };\n};\nRandom3D.prototype = new Value();\nRandom3D.prototype.constructor = Random3D;\n\n// Factory methods\n\n/**\n * Create a constant 1d value generator\n * @param  {number} constant\n * @return {clay.math.Value}\n */\nValue.constant = function(constant) {\n    return new ConstantValue(constant);\n};\n\n/**\n * Create a constant vector value(2d or 3d) generator\n * @param  {clay.math.Vector2|clay.math.Vector3} vector\n * @return {clay.math.Value}\n */\nValue.vector = function(vector) {\n    return new VectorValue(vector);\n};\n\n/**\n * Create a random 1d value generator\n * @param  {number} min\n * @param  {number} max\n * @return {clay.math.Value}\n */\nValue.random1D = function(min, max) {\n    return new Random1D(min, max);\n};\n\n/**\n * Create a random 2d value generator\n * @param  {clay.math.Vector2} min\n * @param  {clay.math.Vector2} max\n * @return {clay.math.Value}\n */\nValue.random2D = function(min, max) {\n    return new Random2D(min, max);\n};\n\n/**\n * Create a random 3d value generator\n * @param  {clay.math.Vector3} min\n * @param  {clay.math.Vector3} max\n * @return {clay.math.Value}\n */\nValue.random3D = function(min, max) {\n    return new Random3D(min, max);\n};\n\nexport default Value;\n","import glMatrix from '../dep/glmatrix';\nvar vec4 = glMatrix.vec4;\n\n/**\n * @constructor\n * @alias clay.math.Vector4\n * @param {number} x\n * @param {number} y\n * @param {number} z\n * @param {number} w\n */\nvar Vector4 = function(x, y, z, w) {\n\n    x = x || 0;\n    y = y || 0;\n    z = z || 0;\n    w = w || 0;\n\n    /**\n     * Storage of Vector4, read and write of x, y, z, w will change the values in array\n     * All methods also operate on the array instead of x, y, z, w components\n     * @name array\n     * @type {Float32Array}\n     * @memberOf clay.math.Vector4#\n     */\n    this.array = vec4.fromValues(x, y, z, w);\n\n    /**\n     * Dirty flag is used by the Node to determine\n     * if the matrix is updated to latest\n     * @name _dirty\n     * @type {boolean}\n     * @memberOf clay.math.Vector4#\n     */\n    this._dirty = true;\n};\n\nVector4.prototype = {\n\n    constructor: Vector4,\n\n    /**\n     * Add b to self\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    add: function(b) {\n        vec4.add(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y and z components\n     * @param  {number}  x\n     * @param  {number}  y\n     * @param  {number}  z\n     * @param  {number}  w\n     * @return {clay.math.Vector4}\n     */\n    set: function(x, y, z, w) {\n        this.array[0] = x;\n        this.array[1] = y;\n        this.array[2] = z;\n        this.array[3] = w;\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Set x, y, z and w components from array\n     * @param  {Float32Array|number[]} arr\n     * @return {clay.math.Vector4}\n     */\n    setArray: function(arr) {\n        this.array[0] = arr[0];\n        this.array[1] = arr[1];\n        this.array[2] = arr[2];\n        this.array[3] = arr[3];\n\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Clone a new Vector4\n     * @return {clay.math.Vector4}\n     */\n    clone: function() {\n        return new Vector4(this.x, this.y, this.z, this.w);\n    },\n\n    /**\n     * Copy from b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    copy: function(b) {\n        vec4.copy(this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for distance\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    dist: function(b) {\n        return vec4.dist(this.array, b.array);\n    },\n\n    /**\n     * Distance between self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    distance: function(b) {\n        return vec4.distance(this.array, b.array);\n    },\n\n    /**\n     * Alias for divide\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    div: function(b) {\n        vec4.div(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Divide self by b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    divide: function(b) {\n        vec4.divide(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Dot product of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    dot: function(b) {\n        return vec4.dot(this.array, b.array);\n    },\n\n    /**\n     * Alias of length\n     * @return {number}\n     */\n    len: function() {\n        return vec4.len(this.array);\n    },\n\n    /**\n     * Calculate the length\n     * @return {number}\n     */\n    length: function() {\n        return vec4.length(this.array);\n    },\n    /**\n     * Linear interpolation between a and b\n     * @param  {clay.math.Vector4} a\n     * @param  {clay.math.Vector4} b\n     * @param  {number}  t\n     * @return {clay.math.Vector4}\n     */\n    lerp: function(a, b, t) {\n        vec4.lerp(this.array, a.array, b.array, t);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Minimum of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    min: function(b) {\n        vec4.min(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Maximum of self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    max: function(b) {\n        vec4.max(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for multiply\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    mul: function(b) {\n        vec4.mul(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Mutiply self and b\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    multiply: function(b) {\n        vec4.multiply(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Negate self\n     * @return {clay.math.Vector4}\n     */\n    negate: function() {\n        vec4.negate(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Normalize self\n     * @return {clay.math.Vector4}\n     */\n    normalize: function() {\n        vec4.normalize(this.array, this.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Generate random x, y, z, w components with a given scale\n     * @param  {number} scale\n     * @return {clay.math.Vector4}\n     */\n    random: function(scale) {\n        vec4.random(this.array, scale);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Scale self\n     * @param  {number}  scale\n     * @return {clay.math.Vector4}\n     */\n    scale: function(s) {\n        vec4.scale(this.array, this.array, s);\n        this._dirty = true;\n        return this;\n    },\n    /**\n     * Scale b and add to self\n     * @param  {clay.math.Vector4} b\n     * @param  {number}  scale\n     * @return {clay.math.Vector4}\n     */\n    scaleAndAdd: function(b, s) {\n        vec4.scaleAndAdd(this.array, this.array, b.array, s);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Alias for squaredDistance\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    sqrDist: function(b) {\n        return vec4.sqrDist(this.array, b.array);\n    },\n\n    /**\n     * Squared distance between self and b\n     * @param  {clay.math.Vector4} b\n     * @return {number}\n     */\n    squaredDistance: function(b) {\n        return vec4.squaredDistance(this.array, b.array);\n    },\n\n    /**\n     * Alias for squaredLength\n     * @return {number}\n     */\n    sqrLen: function() {\n        return vec4.sqrLen(this.array);\n    },\n\n    /**\n     * Squared length of self\n     * @return {number}\n     */\n    squaredLength: function() {\n        return vec4.squaredLength(this.array);\n    },\n\n    /**\n     * Alias for subtract\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    sub: function(b) {\n        vec4.sub(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Subtract b from self\n     * @param  {clay.math.Vector4} b\n     * @return {clay.math.Vector4}\n     */\n    subtract: function(b) {\n        vec4.subtract(this.array, this.array, b.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Matrix4 m\n     * @param  {clay.math.Matrix4} m\n     * @return {clay.math.Vector4}\n     */\n    transformMat4: function(m) {\n        vec4.transformMat4(this.array, this.array, m.array);\n        this._dirty = true;\n        return this;\n    },\n\n    /**\n     * Transform self with a Quaternion q\n     * @param  {clay.math.Quaternion} q\n     * @return {clay.math.Vector4}\n     */\n    transformQuat: function(q) {\n        vec4.transformQuat(this.array, this.array, q.array);\n        this._dirty = true;\n        return this;\n    },\n\n    toString: function() {\n        return '[' + Array.prototype.join.call(this.array, ',') + ']';\n    },\n\n    toArray: function () {\n        return Array.prototype.slice.call(this.array);\n    }\n};\n\nvar defineProperty = Object.defineProperty;\n// Getter and Setter\nif (defineProperty) {\n\n    var proto = Vector4.prototype;\n    /**\n     * @name x\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'x', {\n        get: function () {\n            return this.array[0];\n        },\n        set: function (value) {\n            this.array[0] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name y\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'y', {\n        get: function () {\n            return this.array[1];\n        },\n        set: function (value) {\n            this.array[1] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name z\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'z', {\n        get: function () {\n            return this.array[2];\n        },\n        set: function (value) {\n            this.array[2] = value;\n            this._dirty = true;\n        }\n    });\n\n    /**\n     * @name w\n     * @type {number}\n     * @memberOf clay.math.Vector4\n     * @instance\n     */\n    defineProperty(proto, 'w', {\n        get: function () {\n            return this.array[3];\n        },\n        set: function (value) {\n            this.array[3] = value;\n            this._dirty = true;\n        }\n    });\n}\n\n// Supply methods that are not in place\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.add = function(out, a, b) {\n    vec4.add(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {number}  x\n * @param  {number}  y\n * @param  {number}  z\n * @return {clay.math.Vector4}\n */\nVector4.set = function(out, x, y, z, w) {\n    vec4.set(out.array, x, y, z, w);\n    out._dirty = true;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.copy = function(out, b) {\n    vec4.copy(out.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.dist = function(a, b) {\n    return vec4.distance(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.distance = Vector4.dist;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.div = function(out, a, b) {\n    vec4.divide(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.divide = Vector4.div;\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.dot = function(a, b) {\n    return vec4.dot(a.array, b.array);\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.len = function(b) {\n    return vec4.length(b.array);\n};\n\n// Vector4.length = Vector4.len;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @param  {number}  t\n * @return {clay.math.Vector4}\n */\nVector4.lerp = function(out, a, b, t) {\n    vec4.lerp(out.array, a.array, b.array, t);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.min = function(out, a, b) {\n    vec4.min(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.max = function(out, a, b) {\n    vec4.max(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.mul = function(out, a, b) {\n    vec4.multiply(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.multiply = Vector4.mul;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @return {clay.math.Vector4}\n */\nVector4.negate = function(out, a) {\n    vec4.negate(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @return {clay.math.Vector4}\n */\nVector4.normalize = function(out, a) {\n    vec4.normalize(out.array, a.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.random = function(out, scale) {\n    vec4.random(out.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.scale = function(out, a, scale) {\n    vec4.scale(out.array, a.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @param  {number}  scale\n * @return {clay.math.Vector4}\n */\nVector4.scaleAndAdd = function(out, a, b, scale) {\n    vec4.scaleAndAdd(out.array, a.array, b.array, scale);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.sqrDist = function(a, b) {\n    return vec4.sqrDist(a.array, b.array);\n};\n\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {number}\n */\nVector4.squaredDistance = Vector4.sqrDist;\n\n/**\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.sqrLen = function(a) {\n    return vec4.sqrLen(a.array);\n};\n/**\n * @function\n * @param  {clay.math.Vector4} a\n * @return {number}\n */\nVector4.squaredLength = Vector4.sqrLen;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.sub = function(out, a, b) {\n    vec4.subtract(out.array, a.array, b.array);\n    out._dirty = true;\n    return out;\n};\n/**\n * @function\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Vector4} b\n * @return {clay.math.Vector4}\n */\nVector4.subtract = Vector4.sub;\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Matrix4} m\n * @return {clay.math.Vector4}\n */\nVector4.transformMat4 = function(out, a, m) {\n    vec4.transformMat4(out.array, a.array, m.array);\n    out._dirty = true;\n    return out;\n};\n\n/**\n * @param  {clay.math.Vector4} out\n * @param  {clay.math.Vector4} a\n * @param  {clay.math.Quaternion} q\n * @return {clay.math.Vector4}\n */\nVector4.transformQuat = function(out, a, q) {\n    vec4.transformQuat(out.array, a.array, q.array);\n    out._dirty = true;\n    return out;\n};\n\nexport default Vector4;\n","import Vector3 from '../math/Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 = glMatrix.vec3;\n\n/**\n * @constructor\n * @alias clay.particle.Particle\n */\nvar Particle = function() {\n    /**\n     * @type {clay.math.Vector3}\n     */\n    this.position = new Vector3();\n\n    /**\n     * Use euler angle to represent particle rotation\n     * @type {clay.math.Vector3}\n     */\n    this.rotation = new Vector3();\n\n    /**\n     * @type {?clay.math.Vector3}\n     */\n    this.velocity = null;\n\n    /**\n     * @type {?clay.math.Vector3}\n     */\n    this.angularVelocity = null;\n\n    /**\n     * @type {number}\n     */\n    this.life = 1;\n\n    /**\n     * @type {number}\n     */\n    this.age = 0;\n\n    /**\n     * @type {number}\n     */\n    this.spriteSize = 1;\n\n    /**\n     * @type {number}\n     */\n    this.weight = 1;\n\n    /**\n     * @type {clay.particle.Emitter}\n     */\n    this.emitter = null;\n};\n\n/**\n * Update particle position\n * @param  {number} deltaTime\n */\nParticle.prototype.update = function(deltaTime) {\n    if (this.velocity) {\n        vec3.scaleAndAdd(this.position.array, this.position.array, this.velocity.array, deltaTime);\n    }\n    if (this.angularVelocity) {\n        vec3.scaleAndAdd(this.rotation.array, this.rotation.array, this.angularVelocity.array, deltaTime);\n    }\n};\n\nexport default Particle;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\nimport Particle from './Particle';\nimport Value from '../math/Value';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 =  glMatrix.vec3;\n\n/**\n * @constructor clay.particle.Emitter\n * @extends clay.core.Base\n */\nvar Emitter = Base.extend(\n/** @lends clay.particle.Emitter# */\n{\n    /**\n     * Maximum number of particles created by this emitter\n     * @type {number}\n     */\n    max: 1000,\n    /**\n     * Number of particles created by this emitter each shot\n     * @type {number}\n     */\n    amount: 20,\n\n    // Init status for each particle\n    /**\n     * Particle life generator\n     * @type {?clay.math.Value.<number>}\n     */\n    life: null,\n    /**\n     * Particle position generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    position: null,\n    /**\n     * Particle rotation generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    rotation: null,\n    /**\n     * Particle velocity generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    velocity: null,\n    /**\n     * Particle angular velocity generator\n     * @type {?clay.math.Value.<clay.math.Vector3>}\n     */\n    angularVelocity: null,\n    /**\n     * Particle sprite size generator\n     * @type {?clay.math.Value.<number>}\n     */\n    spriteSize: null,\n    /**\n     * Particle weight generator\n     * @type {?clay.math.Value.<number>}\n     */\n    weight: null,\n\n    _particlePool: null\n\n}, function() {\n\n    this._particlePool = [];\n\n    // TODO Reduce heap memory\n    for (var i = 0; i < this.max; i++) {\n        var particle = new Particle();\n        particle.emitter = this;\n        this._particlePool.push(particle);\n\n        if (this.velocity) {\n            particle.velocity = new Vector3();\n        }\n        if (this.angularVelocity) {\n            particle.angularVelocity = new Vector3();\n        }\n    }\n},\n/** @lends clay.particle.Emitter.prototype */\n{\n    /**\n     * Emitter number of particles and push them to a given particle list. Emmit number is defined by amount property\n     * @param  {Array.<clay.particle.Particle>} out\n     */\n    emit: function(out) {\n        var amount = Math.min(this._particlePool.length, this.amount);\n\n        var particle;\n        for (var i = 0; i < amount; i++) {\n            particle = this._particlePool.pop();\n            // Initialize particle status\n            if (this.position) {\n                this.position.get(particle.position);\n            }\n            if (this.rotation) {\n                this.rotation.get(particle.rotation);\n            }\n            if (this.velocity) {\n                this.velocity.get(particle.velocity);\n            }\n            if (this.angularVelocity) {\n                this.angularVelocity.get(particle.angularVelocity);\n            }\n            if (this.life) {\n                particle.life = this.life.get();\n            }\n            if (this.spriteSize) {\n                particle.spriteSize = this.spriteSize.get();\n            }\n            if (this.weight) {\n                particle.weight = this.weight.get();\n            }\n            particle.age = 0;\n\n            out.push(particle);\n        }\n    },\n    /**\n     * Kill a dead particle and put it back in the pool\n     * @param  {clay.particle.Particle} particle\n     */\n    kill: function(particle) {\n        this._particlePool.push(particle);\n    }\n});\n\n/**\n * Create a constant 1d value generator. Alias for {@link clay.math.Value.constant}\n * @function clay.particle.Emitter.constant\n */\nEmitter.constant = Value.constant;\n\n/**\n * Create a constant vector value(2d or 3d) generator. Alias for {@link clay.math.Value.vector}\n * @function clay.particle.Emitter.vector\n */\nEmitter.vector = Value.vector;\n\n/**\n * Create a random 1d value generator. Alias for {@link clay.math.Value.random1D}\n * @function clay.particle.Emitter.random1D\n */\nEmitter.random1D = Value.random1D;\n\n/**\n * Create a random 2d value generator. Alias for {@link clay.math.Value.random2D}\n * @function clay.particle.Emitter.random2D\n */\nEmitter.random2D = Value.random2D;\n\n/**\n * Create a random 3d value generator. Alias for {@link clay.math.Value.random3D}\n * @function clay.particle.Emitter.random3D\n */\nEmitter.random3D = Value.random3D;\n\nexport default Emitter;\n","import Base from '../core/Base';\n/**\n * @constructor clay.particle.Field\n * @extends clay.core.Base\n */\nvar Field = Base.extend({}, {\n    /**\n     * Apply a field to the particle and update the particle velocity\n     * @param  {clay.math.Vector3} velocity\n     * @param  {clay.math.Vector3} position\n     * @param  {number} weight\n     * @param  {number} deltaTime\n     * @memberOf clay.particle.Field.prototype\n     */\n    applyTo: function(velocity, position, weight, deltaTime) {}\n});\n\nexport default Field;\n","import Field from './Field';\nimport Vector3 from '../math/Vector3';\nimport glMatrix from '../dep/glmatrix';\nvar vec3 =  glMatrix.vec3;\n\n/**\n * @constructor clay.particle.ForceField\n * @extends clay.particle.Field\n */\nvar ForceField = Field.extend(function() {\n    return {\n        force: new Vector3()\n    };\n}, {\n    applyTo: function(velocity, position, weight, deltaTime) {\n        if (weight > 0) {\n            vec3.scaleAndAdd(velocity.array, velocity.array, this.force.array, deltaTime / weight);\n        }\n    }\n});\n\nexport default ForceField;\n","export default \"@export clay.particle.vertex\\nuniform mat4 worldView : WORLDVIEW;\\nuniform mat4 projection : PROJECTION;\\nattribute vec3 position : POSITION;\\nattribute vec3 normal : NORMAL;\\n#ifdef UV_ANIMATION\\nattribute vec2 texcoord0 : TEXCOORD_0;\\nattribute vec2 texcoord1 : TEXCOORD_1;\\nvarying vec2 v_Uv0;\\nvarying vec2 v_Uv1;\\n#endif\\nvarying float v_Age;\\nvoid main() {\\n    v_Age = normal.x;\\n    float rotation = normal.y;\\n    vec4 worldViewPosition = worldView * vec4(position, 1.0);\\n    gl_Position = projection * worldViewPosition;\\n    float w = gl_Position.w;\\n    gl_PointSize = normal.z * projection[0].x / w;\\n    #ifdef UV_ANIMATION\\n        v_Uv0 = texcoord0;\\n        v_Uv1 = texcoord1;\\n    #endif\\n}\\n@end\\n@export clay.particle.fragment\\nuniform sampler2D sprite;\\nuniform sampler2D gradient;\\nuniform vec3 color : [1.0, 1.0, 1.0];\\nuniform float alpha : 1.0;\\nvarying float v_Age;\\n#ifdef UV_ANIMATION\\nvarying vec2 v_Uv0;\\nvarying vec2 v_Uv1;\\n#endif\\nvoid main() {\\n    vec4 color = vec4(color, alpha);\\n    #ifdef SPRITE_ENABLED\\n        #ifdef UV_ANIMATION\\n            color *= texture2D(sprite, mix(v_Uv0, v_Uv1, gl_PointCoord));\\n        #else\\n            color *= texture2D(sprite, gl_PointCoord);\\n        #endif\\n    #endif\\n    #ifdef GRADIENT_ENABLED\\n        color *= texture2D(gradient, vec2(v_Age, 0.5));\\n    #endif\\n    gl_FragColor = color;\\n}\\n@end\";\n","import Renderable from '../Renderable';\n\nimport Geometry from '../Geometry';\nimport Material from '../Material';\nimport Shader from '../Shader';\n\nimport particleEssl from './particle.glsl.js';\nShader['import'](particleEssl);\n\nvar particleShader = new Shader(Shader.source('clay.particle.vertex'), Shader.source('clay.particle.fragment'));\n\n/**\n * @constructor clay.particle.ParticleRenderable\n * @extends clay.Renderable\n *\n * @example\n *     var particleRenderable = new clay.particle.ParticleRenderable({\n *         spriteAnimationTileX: 4,\n *         spriteAnimationTileY: 4,\n *         spriteAnimationRepeat: 1\n *     });\n *     scene.add(particleRenderable);\n *     // Enable uv animation in the shader\n *     particleRenderable.material.define('both', 'UV_ANIMATION');\n *     var Emitter = clay.particle.Emitter;\n *     var Vector3 = clay.math.Vector3;\n *     var emitter = new Emitter({\n *         max: 2000,\n *         amount: 100,\n *         life: Emitter.random1D(10, 20),\n *         position: Emitter.vector(new Vector3()),\n *         velocity: Emitter.random3D(new Vector3(-10, 0, -10), new Vector3(10, 0, 10));\n *     });\n *     particleRenderable.addEmitter(emitter);\n *     var gravityField = new clay.particle.ForceField();\n *     gravityField.force.y = -10;\n *     particleRenderable.addField(gravityField);\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         particleRenderable.updateParticles(frameTime);\n *         renderer.render(scene, camera);\n *     });\n */\nvar ParticleRenderable = Renderable.extend(\n/** @lends clay.particle.ParticleRenderable# */\n{\n    /**\n     * @type {boolean}\n     */\n    loop: true,\n    /**\n     * @type {boolean}\n     */\n    oneshot: false,\n    /**\n     * Duration of particle system in milliseconds\n     * @type {number}\n     */\n    duration: 1,\n\n    // UV Animation\n    /**\n     * @type {number}\n     */\n    spriteAnimationTileX: 1,\n    /**\n     * @type {number}\n     */\n    spriteAnimationTileY: 1,\n    /**\n     * @type {number}\n     */\n    spriteAnimationRepeat: 0,\n\n    mode: Renderable.POINTS,\n\n    ignorePicking: true,\n\n    _elapsedTime: 0,\n\n    _emitting: true\n\n}, function(){\n\n    this.geometry = new Geometry({\n        dynamic: true\n    });\n\n    if (!this.material) {\n        this.material = new Material({\n            shader: particleShader,\n            transparent: true,\n            depthMask: false\n        });\n\n        this.material.enableTexture('sprite');\n    }\n\n    this._particles = [];\n    this._fields = [];\n    this._emitters = [];\n},\n/** @lends clay.particle.ParticleRenderable.prototype */\n{\n\n    culling: false,\n\n    frustumCulling: false,\n\n    castShadow: false,\n    receiveShadow: false,\n\n    /**\n     * Add emitter\n     * @param {clay.particle.Emitter} emitter\n     */\n    addEmitter: function(emitter) {\n        this._emitters.push(emitter);\n    },\n\n    /**\n     * Remove emitter\n     * @param {clay.particle.Emitter} emitter\n     */\n    removeEmitter: function(emitter) {\n        this._emitters.splice(this._emitters.indexOf(emitter), 1);\n    },\n\n    /**\n     * Add field\n     * @param {clay.particle.Field} field\n     */\n    addField: function(field) {\n        this._fields.push(field);\n    },\n\n    /**\n     * Remove field\n     * @param {clay.particle.Field} field\n     */\n    removeField: function(field) {\n        this._fields.splice(this._fields.indexOf(field), 1);\n    },\n\n    /**\n     * Reset the particle system.\n     */\n    reset: function() {\n        // Put all the particles back\n        for (var i = 0; i < this._particles.length; i++) {\n            var p = this._particles[i];\n            p.emitter.kill(p);\n        }\n        this._particles.length = 0;\n        this._elapsedTime = 0;\n        this._emitting = true;\n    },\n\n    /**\n     * @param  {number} deltaTime\n     */\n    updateParticles: function(deltaTime) {\n\n        // MS => Seconds\n        deltaTime /= 1000;\n        this._elapsedTime += deltaTime;\n\n        var particles = this._particles;\n\n        if (this._emitting) {\n            for (var i = 0; i < this._emitters.length; i++) {\n                this._emitters[i].emit(particles);\n            }\n            if (this.oneshot) {\n                this._emitting = false;\n            }\n        }\n\n        // Aging\n        var len = particles.length;\n        for (var i = 0; i < len;) {\n            var p = particles[i];\n            p.age += deltaTime;\n            if (p.age >= p.life) {\n                p.emitter.kill(p);\n                particles[i] = particles[len-1];\n                particles.pop();\n                len--;\n            } else {\n                i++;\n            }\n        }\n\n        for (var i = 0; i < len; i++) {\n            // Update\n            var p = particles[i];\n            if (this._fields.length > 0) {\n                for (var j = 0; j < this._fields.length; j++) {\n                    this._fields[j].applyTo(p.velocity, p.position, p.weight, deltaTime);\n                }\n            }\n            p.update(deltaTime);\n        }\n\n        this._updateVertices();\n    },\n\n    _updateVertices: function() {\n        var geometry = this.geometry;\n        // If has uv animation\n        var animTileX = this.spriteAnimationTileX;\n        var animTileY = this.spriteAnimationTileY;\n        var animRepeat = this.spriteAnimationRepeat;\n        var nUvAnimFrame = animTileY * animTileX * animRepeat;\n        var hasUvAnimation = nUvAnimFrame > 1;\n        var positions = geometry.attributes.position.value;\n        // Put particle status in normal\n        var normals = geometry.attributes.normal.value;\n        var uvs = geometry.attributes.texcoord0.value;\n        var uvs2 = geometry.attributes.texcoord1.value;\n\n        var len = this._particles.length;\n        if (!positions || positions.length !== len * 3) {\n            // TODO Optimize\n            positions = geometry.attributes.position.value = new Float32Array(len * 3);\n            normals = geometry.attributes.normal.value = new Float32Array(len * 3);\n            if (hasUvAnimation) {\n                uvs = geometry.attributes.texcoord0.value = new Float32Array(len * 2);\n                uvs2 = geometry.attributes.texcoord1.value = new Float32Array(len * 2);\n            }\n        }\n\n        var invAnimTileX = 1 / animTileX;\n        for (var i = 0; i < len; i++) {\n            var particle = this._particles[i];\n            var offset = i * 3;\n            for (var j = 0; j < 3; j++) {\n                positions[offset + j] = particle.position.array[j];\n                normals[offset] = particle.age / particle.life;\n                // normals[offset + 1] = particle.rotation;\n                normals[offset + 1] = 0;\n                normals[offset + 2] = particle.spriteSize;\n            }\n            var offset2 = i * 2;\n            if (hasUvAnimation) {\n                // TODO\n                var p = particle.age / particle.life;\n                var stage = Math.round(p * (nUvAnimFrame - 1)) * animRepeat;\n                var v = Math.floor(stage * invAnimTileX);\n                var u = stage - v * animTileX;\n                uvs[offset2] = u / animTileX;\n                uvs[offset2 + 1] = 1 - v / animTileY;\n                uvs2[offset2] = (u + 1) / animTileX;\n                uvs2[offset2 + 1] = 1 - (v + 1) / animTileY;\n            }\n        }\n\n        geometry.dirty();\n    },\n\n    /**\n     * @return {boolean}\n     */\n    isFinished: function() {\n        return this._elapsedTime > this.duration && !this.loop;\n    },\n\n    /**\n     * @param  {clay.Renderer} renderer\n     */\n    dispose: function(renderer) {\n        // Put all the particles back\n        for (var i = 0; i < this._particles.length; i++) {\n            var p = this._particles[i];\n            p.emitter.kill(p);\n        }\n        this.geometry.dispose(renderer);\n        // TODO Dispose texture ?\n    },\n\n    /**\n     * @return {clay.particle.ParticleRenderable}\n     */\n    clone: function() {\n        var particleRenderable = new ParticleRenderable({\n            material: this.material\n        });\n        particleRenderable.loop = this.loop;\n        particleRenderable.duration = this.duration;\n        particleRenderable.oneshot = this.oneshot;\n        particleRenderable.spriteAnimationRepeat = this.spriteAnimationRepeat;\n        particleRenderable.spriteAnimationTileY = this.spriteAnimationTileY;\n        particleRenderable.spriteAnimationTileX = this.spriteAnimationTileX;\n\n        particleRenderable.position.copy(this.position);\n        particleRenderable.rotation.copy(this.rotation);\n        particleRenderable.scale.copy(this.scale);\n\n        for (var i = 0; i < this._children.length; i++) {\n            particleRenderable.add(this._children[i].clone());\n        }\n        return particleRenderable;\n    }\n});\n\nexport default ParticleRenderable;\n","export default \"@export clay.picking.color.vertex\\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\\nattribute vec3 position : POSITION;\\n@import clay.chunk.skinning_header\\nvoid main(){\\n    vec3 skinnedPosition = position;\\n    #ifdef SKINNING\\n        @import clay.chunk.skin_matrix\\n        skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\\n    #endif\\n    gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\\n}\\n@end\\n@end\\n@export clay.picking.color.fragment\\nuniform vec4 color : [1.0, 1.0, 1.0, 1.0];\\nvoid main() {\\n    gl_FragColor = color;\\n}\\n@end\";\n","import Base from '../core/Base';\nimport FrameBuffer from '../FrameBuffer';\nimport Texture2D from '../Texture2D';\nimport Shader from '../Shader';\nimport Material from '../Material';\n\nimport colorEssl from './color.glsl.js';\nShader.import(colorEssl);\n\n/**\n * Pixel picking is gpu based picking, which is fast and accurate.\n * But not like ray picking, it can't get the intersection point and triangle.\n * @constructor clay.picking.PixelPicking\n * @extends clay.core.Base\n */\nvar PixelPicking = Base.extend(function() {\n    return /** @lends clay.picking.PixelPicking# */ {\n        /**\n         * Target renderer\n         * @type {clay.Renderer}\n         */\n        renderer: null,\n        /**\n         * Downsample ratio of hidden frame buffer\n         * @type {number}\n         */\n        downSampleRatio: 1,\n\n        width: 100,\n        height: 100,\n\n        lookupOffset: 1,\n\n        _frameBuffer: null,\n        _texture: null,\n        _shader: null,\n\n        _idMaterials: [],\n        _lookupTable: [],\n\n        _meshMaterials: [],\n\n        _idOffset: 0\n    };\n}, function() {\n    if (this.renderer) {\n        this.width = this.renderer.getWidth();\n        this.height = this.renderer.getHeight();\n    }\n    this._init();\n}, /** @lends clay.picking.PixelPicking.prototype */ {\n    _init: function() {\n        this._texture = new Texture2D({\n            width: this.width * this.downSampleRatio,\n            height: this.height * this.downSampleRatio\n        });\n        this._frameBuffer = new FrameBuffer();\n\n        this._shader = new Shader(Shader.source('clay.picking.color.vertex'), Shader.source('clay.picking.color.fragment'));\n    },\n    /**\n     * Set picking presision\n     * @param {number} ratio\n     */\n    setPrecision: function(ratio) {\n        this._texture.width = this.width * ratio;\n        this._texture.height = this.height * ratio;\n        this.downSampleRatio = ratio;\n    },\n    resize: function(width, height) {\n        this._texture.width = width * this.downSampleRatio;\n        this._texture.height = height * this.downSampleRatio;\n        this.width = width;\n        this.height = height;\n        this._texture.dirty();\n    },\n    /**\n     * Update the picking framebuffer\n     * @param {number} ratio\n     */\n    update: function(scene, camera) {\n        var renderer = this.renderer;\n        if (renderer.getWidth() !== this.width || renderer.getHeight() !== this.height) {\n            this.resize(renderer.width, renderer.height);\n        }\n\n        this._frameBuffer.attach(this._texture);\n        this._frameBuffer.bind(renderer);\n        this._idOffset = this.lookupOffset;\n        this._setMaterial(scene);\n        renderer.render(scene, camera);\n        this._restoreMaterial();\n        this._frameBuffer.unbind(renderer);\n    },\n\n    _setMaterial: function(root) {\n        for (var i =0; i < root._children.length; i++) {\n            var child = root._children[i];\n            if (child.geometry && child.material && child.material.shader) {\n                var id = this._idOffset++;\n                var idx = id - this.lookupOffset;\n                var material = this._idMaterials[idx];\n                if (!material) {\n                    material = new Material({\n                        shader: this._shader\n                    });\n                    var color = packID(id);\n                    color[0] /= 255;\n                    color[1] /= 255;\n                    color[2] /= 255;\n                    color[3] = 1.0;\n                    material.set('color', color);\n                    this._idMaterials[idx] = material;\n                }\n                this._meshMaterials[idx] = child.material;\n                this._lookupTable[idx] = child;\n                child.material = material;\n            }\n            if (child._children.length) {\n                this._setMaterial(child);\n            }\n        }\n    },\n\n    /**\n     * Pick the object\n     * @param  {number} x Mouse position x\n     * @param  {number} y Mouse position y\n     * @return {clay.Node}\n     */\n    pick: function(x, y) {\n        var renderer = this.renderer;\n\n        var ratio = this.downSampleRatio;\n        x = Math.ceil(ratio * x);\n        y = Math.ceil(ratio * (this.height - y));\n\n        this._frameBuffer.bind(renderer);\n        var pixel = new Uint8Array(4);\n        var _gl = renderer.gl;\n        // TODO out of bounds ?\n        // preserveDrawingBuffer ?\n        _gl.readPixels(x, y, 1, 1, _gl.RGBA, _gl.UNSIGNED_BYTE, pixel);\n        this._frameBuffer.unbind(renderer);\n        // Skip interpolated pixel because of anti alias\n        if (pixel[3] === 255) {\n            var id = unpackID(pixel[0], pixel[1], pixel[2]);\n            if (id) {\n                var el = this._lookupTable[id - this.lookupOffset];\n                return el;\n            }\n        }\n    },\n\n    _restoreMaterial: function() {\n        for (var i = 0; i < this._lookupTable.length; i++) {\n            this._lookupTable[i].material = this._meshMaterials[i];\n        }\n    },\n\n    dispose: function(renderer) {\n        this._frameBuffer.dispose(renderer);\n    }\n});\n\nfunction packID(id){\n    var r = id >> 16;\n    var g = (id - (r << 8)) >> 8;\n    var b = id - (r << 16) - (g<<8);\n    return [r, g, b];\n}\n\nfunction unpackID(r, g, b){\n    return (r << 16) + (g<<8) + b;\n}\n\nexport default PixelPicking;\n","import Base from '../core/Base';\nimport Vector3 from '../math/Vector3';\n\n/**\n * @constructor clay.plugin.FreeControl\n * @example\n *     var control = new clay.plugin.FreeControl({\n *         target: camera,\n *         domElement: renderer.canvas\n *     });\n *     ...\n *     animation.on('frame', function(frameTime) {\n *         control.update(frameTime);\n *         renderer.render(scene, camera);\n *     });\n */\nvar FreeControl = Base.extend(function() {\n    return /** @lends clay.plugin.FreeControl# */ {\n        /**\n         * Scene node to control, mostly it is a camera\n         * @type {clay.Node}\n         */\n        target: null,\n\n        /**\n         * Target dom to bind with mouse events\n         * @type {HTMLElement}\n         */\n        domElement: null,\n\n        /**\n         * Mouse move sensitivity\n         * @type {number}\n         */\n        sensitivity: 1,\n\n        /**\n         * Target move speed\n         * @type {number}\n         */\n        speed: 0.4,\n\n        /**\n         * Up axis\n         * @type {clay.math.Vector3}\n         */\n        up: new Vector3(0, 1, 0),\n\n        /**\n         * If lock vertical movement\n         * @type {boolean}\n         */\n        verticalMoveLock: false,\n\n        /**\n         * @type {clay.animation.Animation}\n         */\n        animation: null,\n\n        _moveForward: false,\n        _moveBackward: false,\n        _moveLeft: false,\n        _moveRight: false,\n\n        _offsetPitch: 0,\n        _offsetRoll: 0\n    };\n}, function() {\n    this._lockChange = this._lockChange.bind(this);\n    this._keyDown = this._keyDown.bind(this);\n    this._keyUp = this._keyUp.bind(this);\n    this._mouseMove = this._mouseMove.bind(this);\n\n    if (this.domElement) {\n        this.enable();\n    }\n},\n/** @lends clay.plugin.FreeControl.prototype */\n{\n    /**\n     * Enable control\n     */\n    enable: function() {\n        // Use pointer lock\n        // http://www.html5rocks.com/en/tutorials/pointerlock/intro/\n        var el = this.domElement;\n\n        //Must request pointer lock after click event, can't not do it directly\n        //Why ? ?\n        el.addEventListener('click', this._requestPointerLock);\n\n        document.addEventListener('pointerlockchange', this._lockChange);\n        document.addEventListener('mozpointerlockchange', this._lockChange);\n        document.addEventListener('webkitpointerlockchange', this._lockChange);\n\n        document.addEventListener('keydown', this._keyDown);\n        document.addEventListener('keyup', this._keyUp);\n\n        if (this.animation) {\n            this.animation.on('frame', this._detectMovementChange, this);\n        }\n    },\n\n    /**\n     * Disable control\n     */\n    disable: function() {\n\n        this.target.off('beforeupdate', this._beforeUpdateCamera);\n\n        var el = this.domElement;\n\n        el.exitPointerLock = el.exitPointerLock\n            || el.mozExitPointerLock\n            || el.webkitExitPointerLock;\n\n        if (el.exitPointerLock) {\n            el.exitPointerLock();\n        }\n\n        this.domElement.removeEventListener('click', this._requestPointerLock);\n\n        document.removeEventListener('pointerlockchange', this._lockChange);\n        document.removeEventListener('mozpointerlockchange', this._lockChange);\n        document.removeEventListener('webkitpointerlockchange', this._lockChange);\n\n        document.removeEventListener('keydown', this._keyDown);\n        document.removeEventListener('keyup', this._keyUp);\n\n        if (this.animation) {\n            this.animation.off('frame', this._detectMovementChange);\n        }\n    },\n\n    _requestPointerLock: function() {\n        var el = this;\n        el.requestPointerLock = el.requestPointerLock\n            || el.mozRequestPointerLock\n            || el.webkitRequestPointerLock;\n\n        el.requestPointerLock();\n    },\n\n    /**\n     * Control update. Should be invoked every frame\n     * @param {number} frameTime Frame time\n     */\n    update: function(frameTime) {\n        var target = this.target;\n\n        var position = this.target.position;\n        var xAxis = target.localTransform.x.normalize();\n        var zAxis = target.localTransform.z.normalize();\n\n        if (this.verticalMoveLock) {\n            zAxis.y = 0;\n            zAxis.normalize();\n        }\n\n        var speed = this.speed * frameTime / 20;\n\n        if (this._moveForward) {\n            // Opposite direction of z\n            position.scaleAndAdd(zAxis, -speed);\n        }\n        if (this._moveBackward) {\n            position.scaleAndAdd(zAxis, speed);\n        }\n        if (this._moveLeft) {\n            position.scaleAndAdd(xAxis, -speed / 2);\n        }\n        if (this._moveRight) {\n            position.scaleAndAdd(xAxis, speed / 2);\n        }\n\n        target.rotateAround(target.position, this.up, -this._offsetPitch * frameTime * Math.PI / 360);\n        var xAxis = target.localTransform.x;\n        target.rotateAround(target.position, xAxis, -this._offsetRoll * frameTime * Math.PI / 360);\n\n        this._offsetRoll = this._offsetPitch = 0;\n    },\n\n    _lockChange: function() {\n        if (\n            document.pointerLockElement === this.domElement\n            || document.mozPointerLockElement === this.domElement\n            || document.webkitPointerLockElement === this.domElement\n        ) {\n            document.addEventListener('mousemove', this._mouseMove, false);\n        } else {\n            document.removeEventListener('mousemove', this._mouseMove);\n        }\n    },\n\n    _mouseMove: function(e) {\n        var dx = e.movementX || e.mozMovementX || e.webkitMovementX || 0;\n        var dy = e.movementY || e.mozMovementY || e.webkitMovementY || 0;\n\n        this._offsetPitch += dx * this.sensitivity / 200;\n        this._offsetRoll += dy * this.sensitivity / 200;\n\n        // Trigger change event to remind renderer do render\n        this.trigger('change');\n    },\n\n    _detectMovementChange: function () {\n        if (this._moveForward || this._moveBackward || this._moveLeft || this._moveRight) {\n            this.trigger('change');\n        }\n    },\n\n    _keyDown: function(e) {\n        switch(e.keyCode) {\n            case 87: //w\n            case 37: //up arrow\n                this._moveForward = true;\n                break;\n            case 83: //s\n            case 40: //down arrow\n                this._moveBackward = true;\n                break;\n            case 65: //a\n            case 37: //left arrow\n                this._moveLeft = true;\n                break;\n            case 68: //d\n            case 39: //right arrow\n                this._moveRight = true;\n                break;\n        }\n        // Trigger change event to remind renderer do render\n        this.trigger('change');\n    },\n\n    _keyUp: function(e) {\n        switch(e.keyCode) {\n            case 87: //w\n            case 37: //up arrow\n                this._moveForward = false;\n                break;\n            case 83: //s\n            case 40: //down arrow\n                this._moveBackward = false;\n                break;\n            case 65: //a\n            case 37: //left arrow\n                this._moveLeft = false;\n                break;\n            case 68: //d\n            case 39: //right arrow\n                this._moveRight = false;\n                break;\n        }\n    }\n});\n\nexport default FreeControl;\n","var GestureMgr = function () {\n\n    this._track = [];\n};\n\nGestureMgr.prototype = {\n\n    constructor: GestureMgr,\n\n    recognize: function (event, target, root) {\n        this._doTrack(event, target, root);\n        return this._recognize(event);\n    },\n\n    clear: function () {\n        this._track.length = 0;\n        return this;\n    },\n\n    _doTrack: function (event, target, root) {\n        var touches = event.targetTouches;\n\n        if (!touches) {\n            return;\n        }\n\n        var trackItem = {\n            points: [],\n            touches: [],\n            target: target,\n            event: event\n        };\n\n        for (var i = 0, len = touches.length; i < len; i++) {\n            var touch = touches[i];\n            trackItem.points.push([touch.clientX, touch.clientY]);\n            trackItem.touches.push(touch);\n        }\n\n        this._track.push(trackItem);\n    },\n\n    _recognize: function (event) {\n        for (var eventName in recognizers) {\n            if (recognizers.hasOwnProperty(eventName)) {\n                var gestureInfo = recognizers[eventName](this._track, event);\n                if (gestureInfo) {\n                    return gestureInfo;\n                }\n            }\n        }\n    }\n};\n\nfunction dist(pointPair) {\n    var dx = pointPair[1][0] - pointPair[0][0];\n    var dy = pointPair[1][1] - pointPair[0][1];\n\n    return Math.sqrt(dx * dx + dy * dy);\n}\n\nfunction center(pointPair) {\n    return [\n        (pointPair[0][0] + pointPair[1][0]) / 2,\n        (pointPair[0][1] + pointPair[1][1]) / 2\n    ];\n}\n\nvar recognizers = {\n\n    pinch: function (track, event) {\n        var trackLen = track.length;\n\n        if (!trackLen) {\n            return;\n        }\n\n        var pinchEnd = (track[trackLen - 1] || {}).points;\n        var pinchPre = (track[trackLen - 2] || {}).points || pinchEnd;\n\n        if (pinchPre\n            && pinchPre.length > 1\n            && pinchEnd\n            && pinchEnd.length > 1\n        ) {\n            var pinchScale = dist(pinchEnd) / dist(pinchPre);\n            !isFinite(pinchScale) && (pinchScale = 1);\n\n            event.pinchScale = pinchScale;\n\n            var pinchCenter = center(pinchEnd);\n            event.pinchX = pinchCenter[0];\n            event.pinchY = pinchCenter[1];\n\n            return {\n                type: 'pinch',\n                target: track[0].target,\n                event: event\n            };\n        }\n    }\n};\n\nexport default GestureMgr;\n","import Mesh from '../Mesh';\nimport Geometry from '../Geometry';\nimport Plane from '../math/Plane';\nimport Vector3 from '../math/Vector3';\nimport Matrix4 from '../math/Matrix4';\nimport Ray from '../math/Ray';\n\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\nvar vec4 = glMatrix.vec4;\n\nvar uvs = [[0, 0], [0, 1], [1, 1], [1, 0]];\nvar tris = [0, 1, 2, 2, 3, 0];\n\nvar InfinitePlane = Mesh.extend({\n\n    camera: null,\n\n    plane: null,\n\n    maxGrid: 0,\n\n    // TODO\n    frustumCulling: false\n\n}, function () {\n    var geometry = this.geometry = new Geometry({\n        dynamic: true\n    });\n    geometry.attributes.position.init(6);\n    geometry.attributes.normal.init(6);\n    geometry.attributes.texcoord0.init(6);\n    geometry.indices = new Uint16Array(6);\n\n    this.plane = new Plane();\n}, {\n\n    updateGeometry: function () {\n\n        var coords = this._unProjectGrid();\n        if (!coords) {\n            return;\n        }\n        var positionAttr = this.geometry.attributes.position;\n        var normalAttr = this.geometry.attributes.normal;\n        var texcoords = this.geometry.attributes.texcoord0;\n        var indices = this.geometry.indices;\n\n        for (var i = 0; i < 6; i++) {\n            var idx = tris[i];\n            positionAttr.set(i, coords[idx].array);\n            normalAttr.set(i, this.plane.normal.array);\n            texcoords.set(i, uvs[idx]);\n            indices[i] = i;\n        }\n        this.geometry.dirty();\n    },\n\n    // http://fileadmin.cs.lth.se/graphics/theses/projects/projgrid/\n    _unProjectGrid: (function () {\n\n        var planeViewSpace = new Plane();\n        var lines = [\n            0, 1, 0, 2, 1, 3, 2, 3,\n            4, 5, 4, 6, 5, 7, 6, 7,\n            0, 4, 1, 5, 2, 6, 3, 7\n        ];\n\n        var start = new Vector3();\n        var end = new Vector3();\n\n        var points = [];\n\n        // 1----2\n        // |    |\n        // 0----3\n        var coords = [];\n        for (var i = 0; i < 4; i++) {\n            coords[i] = new Vector3(0, 0);\n        }\n\n        var ray = new Ray();\n\n        return function () {\n            planeViewSpace.copy(this.plane);\n            planeViewSpace.applyTransform(this.camera.viewMatrix);\n\n            var frustumVertices = this.camera.frustum.vertices;\n\n            var nPoints = 0;\n            // Intersect with lines of frustum\n            for (var i = 0; i < 12; i++) {\n                start.array = frustumVertices[lines[i * 2]];\n                end.array = frustumVertices[lines[i * 2 + 1]];\n\n                var point = planeViewSpace.intersectLine(start, end, points[nPoints]);\n                if (point) {\n                    if (!points[nPoints]) {\n                        points[nPoints] = point;\n                    }\n                    nPoints++;\n                }\n            }\n            if (nPoints === 0) {\n                return;\n            }\n            for (var i = 0; i < nPoints; i++) {\n                points[i].applyProjection(this.camera.projectionMatrix);\n            }\n            var minX = points[0].array[0];\n            var minY = points[0].array[1];\n            var maxX = points[0].array[0];\n            var maxY = points[0].array[1];\n            for (var i = 1; i < nPoints; i++) {\n                maxX = Math.max(maxX, points[i].array[0]);\n                maxY = Math.max(maxY, points[i].array[1]);\n                minX = Math.min(minX, points[i].array[0]);\n                minY = Math.min(minY, points[i].array[1]);\n            }\n            if (minX == maxX || minY == maxY) {\n                return;\n            }\n            coords[0].array[0] = minX;\n            coords[0].array[1] = minY;\n            coords[1].array[0] = minX;\n            coords[1].array[1] = maxY;\n            coords[2].array[0] = maxX;\n            coords[2].array[1] = maxY;\n            coords[3].array[0] = maxX;\n            coords[3].array[1] = minY;\n\n            for (var i = 0; i < 4; i++) {\n                this.camera.castRay(coords[i], ray);\n                ray.intersectPlane(this.plane, coords[i]);\n            }\n\n            return coords;\n        };\n    })()\n});\n\nexport default InfinitePlane;\n","import Base from '../core/Base';\nimport Vector2 from '../math/Vector2';\nimport Vector3 from '../math/Vector3';\nimport GestureMgr from './GestureMgr';\n\nfunction firstNotNull() {\n    for (var i = 0, len = arguments.length; i < len; i++) {\n        if (arguments[i] != null) {\n            return arguments[i];\n        }\n    }\n}\n\nfunction convertToArray(val) {\n    if (!Array.isArray(val)) {\n        val = [val, val];\n    }\n    return val;\n}\n\n/**\n * @constructor\n * @alias clay.plugin.OrbitControl\n */\nvar OrbitControl = Base.extend(function () {\n\n    return /** @lends clay.plugin.OrbitControl# */ {\n\n        timeline: null,\n\n        /**\n         * @type {HTMLDomElement}\n         */\n        domElement: null,\n\n        /**\n         * @type {clay.Node}\n         */\n        target: null,\n        /**\n         * @type {clay.math.Vector3}\n         */\n        _center: new Vector3(),\n\n        /**\n         * Minimum distance to the center\n         * @type {number}\n         * @default 0.5\n         */\n        minDistance: 0.1,\n\n        /**\n         * Maximum distance to the center\n         * @type {number}\n         * @default 2\n         */\n        maxDistance: 1000,\n\n        /**\n         * Minimum alpha rotation\n         */\n        minAlpha: -90,\n\n        /**\n         * Maximum alpha rotation\n         */\n        maxAlpha: 90,\n\n        /**\n         * Minimum beta rotation\n         */\n        minBeta: -Infinity,\n        /**\n         * Maximum beta rotation\n         */\n        maxBeta: Infinity,\n\n        /**\n         * Start auto rotating after still for the given time\n         */\n        autoRotateAfterStill: 0,\n\n        /**\n         * Direction of autoRotate. cw or ccw when looking top down.\n         */\n        autoRotateDirection: 'cw',\n\n        /**\n         * Degree per second\n         */\n        autoRotateSpeed: 60,\n\n        /**\n         * Pan or rotate\n         * @type {String}\n         */\n        _mode: 'rotate',\n\n        /**\n         * @param {number}\n         */\n        damping: 0.8,\n\n        /**\n         * @param {number}\n         */\n        rotateSensitivity: 1,\n\n        /**\n         * @param {number}\n         */\n        zoomSensitivity: 1,\n\n        /**\n         * @param {number}\n         */\n        panSensitivity: 1,\n\n        _needsUpdate: false,\n\n        _rotating: false,\n\n        // Rotation around yAxis\n        _phi: 0,\n        // Rotation around xAxis\n        _theta: 0,\n\n        _mouseX: 0,\n        _mouseY: 0,\n\n        _rotateVelocity: new Vector2(),\n\n        _panVelocity: new Vector2(),\n\n        _distance: 20,\n\n        _zoomSpeed: 0,\n\n        _stillTimeout: 0,\n\n        _animators: [],\n\n        _gestureMgr: new GestureMgr()\n    };\n}, function () {\n    // Each OrbitControl has it's own handler\n    this._mouseDownHandler = this._mouseDownHandler.bind(this);\n    this._mouseWheelHandler = this._mouseWheelHandler.bind(this);\n    this._mouseMoveHandler = this._mouseMoveHandler.bind(this);\n    this._mouseUpHandler = this._mouseUpHandler.bind(this);\n    this._pinchHandler = this._pinchHandler.bind(this);\n\n    this.update = this.update.bind(this);\n\n    this.init();\n}, /** @lends clay.plugin.OrbitControl# */ {\n    /**\n     * Initialize.\n     * Mouse event binding\n     */\n    init: function () {\n        var dom = this.domElement;\n\n        dom.addEventListener('touchstart', this._mouseDownHandler);\n\n        dom.addEventListener('mousedown', this._mouseDownHandler);\n        dom.addEventListener('mousewheel', this._mouseWheelHandler);\n\n        if (this.timeline) {\n            this.timeline.on('frame', this.update);\n        }\n    },\n\n    /**\n     * Dispose.\n     * Mouse event unbinding\n     */\n    dispose: function () {\n        var dom = this.domElement;\n\n        dom.removeEventListener('touchstart', this._mouseDownHandler);\n        dom.removeEventListener('touchmove', this._mouseMoveHandler);\n        dom.removeEventListener('touchend', this._mouseUpHandler);\n\n        dom.removeEventListener('mousedown', this._mouseDownHandler);\n        dom.removeEventListener('mousemove', this._mouseMoveHandler);\n        dom.removeEventListener('mouseup', this._mouseUpHandler);\n        dom.removeEventListener('mousewheel', this._mouseWheelHandler);\n\n        if (this.timeline) {\n            this.timeline.off('frame', this.update);\n        }\n        this.stopAllAnimation();\n    },\n\n    /**\n     * Get distance\n     * @return {number}\n     */\n    getDistance: function () {\n        return this._distance;\n    },\n\n    /**\n     * Set distance\n     * @param {number} distance\n     */\n    setDistance: function (distance) {\n        this._distance = distance;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Get alpha rotation\n     * Alpha angle for top-down rotation. Positive to rotate to top.\n     *\n     * Which means camera rotation around x axis.\n     */\n    getAlpha: function () {\n        return this._theta / Math.PI * 180;\n    },\n\n    /**\n     * Get beta rotation\n     * Beta angle for left-right rotation. Positive to rotate to right.\n     *\n     * Which means camera rotation around y axis.\n     */\n    getBeta: function () {\n        return -this._phi / Math.PI * 180;\n    },\n\n    /**\n     * Get control center\n     * @return {Array.<number>}\n     */\n    getCenter: function () {\n        return this._center.toArray();\n    },\n\n    /**\n     * Set alpha rotation angle\n     * @param {number} alpha\n     */\n    setAlpha: function (alpha) {\n        alpha = Math.max(Math.min(this.maxAlpha, alpha), this.minAlpha);\n\n        this._theta = alpha / 180 * Math.PI;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Set beta rotation angle\n     * @param {number} beta\n     */\n    setBeta: function (beta) {\n        beta = Math.max(Math.min(this.maxBeta, beta), this.minBeta);\n\n        this._phi = -beta / 180 * Math.PI;\n        this._needsUpdate = true;\n    },\n\n    /**\n     * Set control center\n     * @param {Array.<number>} center\n     */\n    setCenter: function (centerArr) {\n        this._center.setArray(centerArr);\n    },\n\n    setOption: function (opts) {\n        opts = opts || {};\n\n        ['autoRotate', 'autoRotateAfterStill',\n            'autoRotateDirection', 'autoRotateSpeed',\n            'damping',\n            'minDistance', 'maxDistance',\n            'minAlpha', 'maxAlpha', 'minBeta', 'maxBeta',\n            'rotateSensitivity', 'zoomSensitivity', 'panSensitivity'\n        ].forEach(function (key) {\n            if (opts[key] != null) {\n                this[key] = opts[key];\n            }\n        }, this);\n\n        if (opts.distance != null) {\n            this.setDistance(opts.distance);\n        }\n\n        if (opts.alpha != null) {\n            this.setAlpha(opts.alpha);\n        }\n        if (opts.beta != null) {\n            this.setBeta(opts.beta);\n        }\n\n        if (opts.center) {\n            this.setCenter(opts.center);\n        }\n    },\n\n    /**\n     * @param {Object} opts\n     * @param {number} opts.distance\n     * @param {number} opts.alpha\n     * @param {number} opts.beta\n     * @param {number} [opts.duration=1000]\n     * @param {number} [opts.easing='linear']\n     * @param {number} [opts.done]\n     */\n    animateTo: function (opts) {\n        var self = this;\n\n        var obj = {};\n        var target = {};\n        var timeline = this.timeline;\n        if (!timeline) {\n            return;\n        }\n        if (opts.distance != null) {\n            obj.distance = this.getDistance();\n            target.distance = opts.distance;\n        }\n        if (opts.alpha != null) {\n            obj.alpha = this.getAlpha();\n            target.alpha = opts.alpha;\n        }\n        if (opts.beta != null) {\n            obj.beta = this.getBeta();\n            target.beta = opts.beta;\n        }\n        if (opts.center != null) {\n            obj.center = this.getCenter();\n            target.center = opts.center;\n        }\n\n        return this._addAnimator(\n            timeline.animate(obj)\n                .when(opts.duration || 1000, target)\n                .during(function () {\n                    if (obj.alpha != null) {\n                        self.setAlpha(obj.alpha);\n                    }\n                    if (obj.beta != null) {\n                        self.setBeta(obj.beta);\n                    }\n                    if (obj.distance != null) {\n                        self.setDistance(obj.distance);\n                    }\n                    if (obj.center != null) {\n                        self.setCenter(obj.center);\n                    }\n                    self._needsUpdate = true;\n                })\n                .done(opts.done)\n        ).start(opts.easing || 'linear');\n    },\n\n    /**\n     * Stop all animations\n     */\n    stopAllAnimation: function () {\n        for (var i = 0; i < this._animators.length; i++) {\n            this._animators[i].stop();\n        }\n        this._animators.length = 0;\n    },\n\n    _isAnimating: function () {\n        return this._animators.length > 0;\n    },\n    /**\n     * Call update each frame\n     * @param  {number} deltaTime Frame time\n     */\n    update: function (deltaTime) {\n\n        deltaTime = deltaTime || 16;\n\n        if (this._rotating) {\n            var radian = (this.autoRotateDirection === 'cw' ? 1 : -1)\n                * this.autoRotateSpeed / 180 * Math.PI;\n            this._phi -= radian * deltaTime / 1000;\n            this._needsUpdate = true;\n        }\n        else if (this._rotateVelocity.len() > 0) {\n            this._needsUpdate = true;\n        }\n\n        if (Math.abs(this._zoomSpeed) > 0.01 || this._panVelocity.len() > 0) {\n            this._needsUpdate = true;\n        }\n\n        if (!this._needsUpdate) {\n            return;\n        }\n\n        // Fixed deltaTime\n        this._updateDistance(Math.min(deltaTime, 50));\n        this._updatePan(Math.min(deltaTime, 50));\n\n        this._updateRotate(Math.min(deltaTime, 50));\n\n        this._updateTransform();\n\n        this.target.update();\n\n        this.trigger('update');\n\n        this._needsUpdate = false;\n    },\n\n    _updateRotate: function (deltaTime) {\n        var velocity = this._rotateVelocity;\n        this._phi = velocity.y * deltaTime / 20 + this._phi;\n        this._theta = velocity.x * deltaTime / 20 + this._theta;\n\n        this.setAlpha(this.getAlpha());\n        this.setBeta(this.getBeta());\n\n        this._vectorDamping(velocity, this.damping);\n    },\n\n    _updateDistance: function (deltaTime) {\n        this._setDistance(this._distance + this._zoomSpeed * deltaTime / 20);\n        this._zoomSpeed *= this.damping;\n    },\n\n    _setDistance: function (distance) {\n        this._distance = Math.max(Math.min(distance, this.maxDistance), this.minDistance);\n    },\n\n    _updatePan: function (deltaTime) {\n        var velocity = this._panVelocity;\n        var len = this._distance;\n\n        var target = this.target;\n        var yAxis = target.worldTransform.y;\n        var xAxis = target.worldTransform.x;\n\n        // PENDING\n        this._center\n            .scaleAndAdd(xAxis, -velocity.x * len / 200)\n            .scaleAndAdd(yAxis, -velocity.y * len / 200);\n\n        this._vectorDamping(velocity, 0);\n    },\n\n    _updateTransform: function () {\n        var camera = this.target;\n\n        var dir = new Vector3();\n        var theta = this._theta + Math.PI / 2;\n        var phi = this._phi + Math.PI / 2;\n        var r = Math.sin(theta);\n\n        dir.x = r * Math.cos(phi);\n        dir.y = -Math.cos(theta);\n        dir.z = r * Math.sin(phi);\n\n        camera.position.copy(this._center).scaleAndAdd(dir, this._distance);\n        camera.rotation.identity()\n            // First around y, then around x\n            .rotateY(-this._phi)\n            .rotateX(-this._theta);\n    },\n\n    _startCountingStill: function () {\n        clearTimeout(this._stillTimeout);\n\n        var time = this.autoRotateAfterStill;\n        var self = this;\n        if (!isNaN(time) && time > 0) {\n            this._stillTimeout = setTimeout(function () {\n                self._rotating = true;\n            }, time * 1000);\n        }\n    },\n\n    _vectorDamping: function (v, damping) {\n        var speed = v.len();\n        speed = speed * damping;\n        if (speed < 1e-4) {\n            speed = 0;\n        }\n        v.normalize().scale(speed);\n    },\n\n    decomposeTransform: function () {\n        if (!this.target) {\n            return;\n        }\n\n        // FIXME euler order......\n        // FIXME alpha is not certain when beta is 90 or -90\n        // var euler = new Vector3();\n        // euler.eulerFromMat3(\n        //    new Matrix3().fromQuat(this.target.rotation), 'ZYX'\n        // );\n        // euler.eulerFromQuat(\n        //     this.target.rotation.normalize(), 'ZYX'\n        // );\n        this.target.updateWorldTransform();\n\n        var forward = this.target.worldTransform.z;\n        var alpha = Math.asin(forward.y);\n        var beta = Math.atan2(forward.x, forward.z);\n\n        this._theta = alpha;\n        this._phi = -beta;\n\n        this.setBeta(this.getBeta());\n        this.setAlpha(this.getAlpha());\n\n        this._setDistance(this.target.position.dist(this._center));\n    },\n\n    _mouseDownHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var x = e.clientX;\n        var y = e.clientY;\n        // Touch\n        if (e.targetTouches) {\n            var touch = e.targetTouches[0];\n            x = touch.clientX;\n            y = touch.clientY;\n\n            this._mode = 'rotate';\n\n            this._processGesture(e, 'start');\n        }\n\n        var dom = this.domElement;\n        dom.addEventListener('touchmove', this._mouseMoveHandler);\n        dom.addEventListener('touchend', this._mouseUpHandler);\n\n        dom.addEventListener('mousemove', this._mouseMoveHandler);\n        dom.addEventListener('mouseup', this._mouseUpHandler);\n\n        if (e.button === 0) {\n            this._mode = 'rotate';\n        }\n        else if (e.button === 1) {\n            this._mode = 'pan';\n        }\n\n        // Reset rotate velocity\n        this._rotateVelocity.set(0, 0);\n        this._rotating = false;\n        if (this.autoRotate) {\n            this._startCountingStill();\n        }\n\n        this._mouseX = x;\n        this._mouseY = y;\n    },\n\n    _mouseMoveHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var x = e.clientX;\n        var y = e.clientY;\n\n        var haveGesture;\n        // Touch\n        if (e.targetTouches) {\n            var touch = e.targetTouches[0];\n            x = touch.clientX;\n            y = touch.clientY;\n\n            haveGesture = this._processGesture(e, 'change');\n        }\n\n        var panSensitivity = convertToArray(this.panSensitivity);\n        var rotateSensitivity = convertToArray(this.rotateSensitivity);\n\n        if (!haveGesture) {\n            if (this._mode === 'rotate') {\n                this._rotateVelocity.y = (x - this._mouseX) / this.domElement.clientHeight * 2 * rotateSensitivity[0];\n                this._rotateVelocity.x = (y - this._mouseY) / this.domElement.clientWidth * 2 * rotateSensitivity[1];\n            }\n            else if (this._mode === 'pan') {\n                this._panVelocity.x = (x - this._mouseX) / this.domElement.clientWidth * panSensitivity[0] * 400;\n                this._panVelocity.y = (-y + this._mouseY) / this.domElement.clientHeight * panSensitivity[1] * 400;\n            }\n        }\n\n        this._mouseX = x;\n        this._mouseY = y;\n\n        e.preventDefault();\n    },\n\n    _mouseWheelHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        var delta = e.wheelDelta // Webkit\n                || -e.detail; // Firefox\n        if (delta === 0) {\n            return;\n        }\n        this._zoomHandler(e, delta > 0 ? -1 : 1);\n    },\n\n    _pinchHandler: function (e) {\n        if (this._isAnimating()) {\n            return;\n        }\n        this._zoomHandler(e, e.pinchScale > 1 ? -0.4 : 0.4);\n    },\n\n    _zoomHandler: function (e, delta) {\n\n        var distance = Math.max(Math.min(\n            this._distance - this.minDistance,\n            this.maxDistance - this._distance\n        ));\n        this._zoomSpeed = delta * Math.max(distance / 40 * this.zoomSensitivity, 0.2);\n\n        this._rotating = false;\n\n        if (this.autoRotate && this._mode === 'rotate') {\n            this._startCountingStill();\n        }\n\n        e.preventDefault();\n    },\n\n    _mouseUpHandler: function (event) {\n        var dom = this.domElement;\n        dom.removeEventListener('touchmove', this._mouseMoveHandler);\n        dom.removeEventListener('touchend', this._mouseUpHandler);\n        dom.removeEventListener('mousemove', this._mouseMoveHandler);\n        dom.removeEventListener('mouseup', this._mouseUpHandler);\n\n        this._processGesture(event, 'end');\n    },\n\n    _addAnimator: function (animator) {\n        var animators = this._animators;\n        animators.push(animator);\n        animator.done(function () {\n            var idx = animators.indexOf(animator);\n            if (idx >= 0) {\n                animators.splice(idx, 1);\n            }\n        });\n        return animator;\n    },\n\n\n    _processGesture: function (event, stage) {\n        var gestureMgr = this._gestureMgr;\n\n        stage === 'start' && gestureMgr.clear();\n\n        var gestureInfo = gestureMgr.recognize(\n            event,\n            null,\n            this.domElement\n        );\n\n        stage === 'end' && gestureMgr.clear();\n\n        // Do not do any preventDefault here. Upper application do that if necessary.\n        if (gestureInfo) {\n            var type = gestureInfo.type;\n            event.gestureEvent = type;\n\n            this._pinchHandler(gestureInfo.event);\n        }\n\n        return gestureInfo;\n    }\n});\n\n/**\n * If auto rotate the target\n * @type {boolean}\n * @default false\n */\nObject.defineProperty(OrbitControl.prototype, 'autoRotate', {\n    get: function () {\n        return this._autoRotate;\n    },\n    set: function (val) {\n        this._autoRotate = val;\n        this._rotating = val;\n    }\n});\n\nObject.defineProperty(OrbitControl.prototype, 'target', {\n    get: function () {\n        return this._target;\n    },\n    set: function (val) {\n        if (val && val.target) {\n            this.setCenter(val.target.toArray());\n        }\n        this._target = val;\n        this.decomposeTransform();\n    }\n});\n\n\nexport default OrbitControl;\n","/**\n * StaticGeometry can not be changed once they've been setup\n */\nimport Geometry from './Geometry';\n/**\n * @constructor clay.StaticGeometry\n * @extends clay.Geometry\n */\nvar StaticGeometry = Geometry.extend({\n    dynamic: false\n});\nexport default StaticGeometry;\n","// TODO test\nimport Geometry from '../Geometry';\nimport Mesh from '../Mesh';\nimport Node from '../Node';\nimport StandardMaterial from '../StandardMaterial';\nimport BoundingBox from '../math/BoundingBox';\nimport glMatrix from '../dep/glmatrix';\nvar mat4 = glMatrix.mat4;\nvar vec3 = glMatrix.vec3;\n\n/**\n * @namespace clay.util.mesh\n */\nvar meshUtil = {\n    /**\n     * Merge multiple meshes to one.\n     * Note that these meshes must have the same material\n     *\n     * @param {Array.<clay.Mesh>} meshes\n     * @param {boolean} applyWorldTransform\n     * @return clay.Mesh\n     * @memberOf clay.util.mesh\n     */\n    merge: function (meshes, applyWorldTransform) {\n\n        if (! meshes.length) {\n            return;\n        }\n\n        var templateMesh = meshes[0];\n        var templateGeo = templateMesh.geometry;\n        var material = templateMesh.material;\n\n        var geometry = new Geometry({\n            dynamic: false\n        });\n        geometry.boundingBox = new BoundingBox();\n\n        var attributeNames = templateGeo.getEnabledAttributes();\n\n        for (var i = 0; i < attributeNames.length; i++) {\n            var name = attributeNames[i];\n            var attr = templateGeo.attributes[name];\n            // Extend custom attributes\n            if (!geometry.attributes[name]) {\n                geometry.attributes[name] = attr.clone(false);\n            }\n        }\n\n        var inverseTransposeMatrix = mat4.create();\n        // Initialize the array data and merge bounding box\n        var nVertex = 0;\n        var nFace = 0;\n        for (var k = 0; k < meshes.length; k++) {\n            var currentGeo = meshes[k].geometry;\n            if (currentGeo.boundingBox) {\n                currentGeo.boundingBox.applyTransform(applyWorldTransform ? meshes[k].worldTransform : meshes[k].localTransform);\n                geometry.boundingBox.union(currentGeo.boundingBox);\n            }\n            nVertex += currentGeo.vertexCount;\n            nFace += currentGeo.triangleCount;\n        }\n        for (var n = 0; n < attributeNames.length; n++) {\n            var name = attributeNames[n];\n            var attrib = geometry.attributes[name];\n            attrib.init(nVertex);\n        }\n        if (nVertex >= 0xffff) {\n            geometry.indices = new Uint32Array(nFace * 3);\n        }\n        else {\n            geometry.indices = new Uint16Array(nFace * 3);\n        }\n\n        var vertexOffset = 0;\n        var indicesOffset = 0;\n        var useIndices = templateGeo.isUseIndices();\n\n        for (var mm = 0; mm < meshes.length; mm++) {\n            var mesh = meshes[mm];\n            var currentGeo = mesh.geometry;\n\n            var nVertex = currentGeo.vertexCount;\n\n            var matrix = applyWorldTransform ? mesh.worldTransform.array : mesh.localTransform.array;\n            mat4.invert(inverseTransposeMatrix, matrix);\n            mat4.transpose(inverseTransposeMatrix, inverseTransposeMatrix);\n\n            for (var nn = 0; nn < attributeNames.length; nn++) {\n                var name = attributeNames[nn];\n                var currentAttr = currentGeo.attributes[name];\n                var targetAttr = geometry.attributes[name];\n                // Skip the unused attributes;\n                if (!currentAttr.value.length) {\n                    continue;\n                }\n                var len = currentAttr.value.length;\n                var size = currentAttr.size;\n                var offset = vertexOffset * size;\n                var count = len / size;\n                for (var i = 0; i < len; i++) {\n                    targetAttr.value[offset + i] = currentAttr.value[i];\n                }\n                // Transform position, normal and tangent\n                if (name === 'position') {\n                    vec3.forEach(targetAttr.value, size, offset, count, vec3.transformMat4, matrix);\n                }\n                else if (name === 'normal' || name === 'tangent') {\n                    vec3.forEach(targetAttr.value, size, offset, count, vec3.transformMat4, inverseTransposeMatrix);\n                }\n            }\n\n            if (useIndices) {\n                var len = currentGeo.indices.length;\n                for (var i = 0; i < len; i++) {\n                    geometry.indices[i + indicesOffset] = currentGeo.indices[i] + vertexOffset;\n                }\n                indicesOffset += len;\n            }\n\n            vertexOffset += nVertex;\n        }\n\n        return new Mesh({\n            material: material,\n            geometry: geometry\n        });\n    },\n\n    /**\n     * Split mesh into sub meshes, each mesh will have maxJointNumber joints.\n     * @param {clay.Mesh} mesh\n     * @param {number} maxJointNumber\n     * @param {boolean} inPlace\n     * @return {clay.Node}\n     *\n     * @memberOf clay.util.mesh\n     */\n\n    // FIXME, Have issues on some models\n    splitByJoints: function (mesh, maxJointNumber, inPlace) {\n        var geometry = mesh.geometry;\n        var skeleton = mesh.skeleton;\n        var material = mesh.material;\n        var joints = mesh.joints;\n        if (!geometry || !skeleton || !joints.length) {\n            return;\n        }\n        if (joints.length < maxJointNumber) {\n            return mesh;\n        }\n\n\n        var indices = geometry.indices;\n\n        var faceLen = geometry.triangleCount;\n        var rest = faceLen;\n        var isFaceAdded = [];\n        var jointValues = geometry.attributes.joint.value;\n        for (var i = 0; i < faceLen; i++) {\n            isFaceAdded[i] = false;\n        }\n        var addedJointIdxPerFace = [];\n\n        var buckets = [];\n\n        var getJointByIndex = function (idx) {\n            return joints[idx];\n        };\n        while (rest > 0) {\n            var bucketTriangles = [];\n            var bucketJointReverseMap = [];\n            var bucketJoints = [];\n            var subJointNumber = 0;\n            for (var i = 0; i < joints.length; i++) {\n                bucketJointReverseMap[i] = -1;\n            }\n            for (var f = 0; f < faceLen; f++) {\n                if (isFaceAdded[f]) {\n                    continue;\n                }\n                var canAddToBucket = true;\n                var addedNumber = 0;\n                for (var i = 0; i < 3; i++) {\n\n                    var idx = indices[f * 3 + i];\n\n                    for (var j = 0; j < 4; j++) {\n                        var jointIdx = jointValues[idx * 4 + j];\n\n                        if (jointIdx >= 0) {\n                            if (bucketJointReverseMap[jointIdx] === -1) {\n                                if (subJointNumber < maxJointNumber) {\n                                    bucketJointReverseMap[jointIdx] = subJointNumber;\n                                    bucketJoints[subJointNumber++] = jointIdx;\n                                    addedJointIdxPerFace[addedNumber++] = jointIdx;\n                                }\n                                else {\n                                    canAddToBucket = false;\n                                }\n                            }\n                        }\n                    }\n                }\n                if (!canAddToBucket) {\n                    // Reverse operation\n                    for (var i = 0; i < addedNumber; i++) {\n                        bucketJointReverseMap[addedJointIdxPerFace[i]] = -1;\n                        bucketJoints.pop();\n                        subJointNumber--;\n                    }\n                }\n                else {\n                    bucketTriangles.push(indices.subarray(f * 3, (f + 1) * 3));\n\n                    isFaceAdded[f] = true;\n                    rest--;\n                }\n            }\n            buckets.push({\n                triangles: bucketTriangles,\n                joints: bucketJoints.map(getJointByIndex),\n                jointReverseMap: bucketJointReverseMap\n            });\n        }\n\n        var root = new Node({\n            name: mesh.name\n        });\n        var attribNames = geometry.getEnabledAttributes();\n\n        attribNames.splice(attribNames.indexOf('joint'), 1);\n        // Map from old vertex index to new vertex index\n        var newIndices = [];\n        for (var b = 0; b < buckets.length; b++) {\n            var bucket = buckets[b];\n            var jointReverseMap = bucket.jointReverseMap;\n            var subJointNumber = bucket.joints.length;\n\n            var subMat = material.clone();\n            subMat.name = [material.name, b].join('-');\n\n            var subGeo = new Geometry();\n\n            var subMesh = new Mesh({\n                name: [mesh.name, i].join('-'),\n                material: subMat,\n                geometry: subGeo,\n                skeleton: skeleton,\n                joints: bucket.joints.slice()\n            });\n            var nVertex = 0;\n            var nVertex2 = geometry.vertexCount;\n            for (var i = 0; i < nVertex2; i++) {\n                newIndices[i] = -1;\n            }\n            // Count sub geo number\n            for (var f = 0; f < bucket.triangles.length; f++) {\n                var face = bucket.triangles[f];\n                for (var i = 0; i < 3; i++) {\n                    var idx = face[i];\n                    if (newIndices[idx] === -1) {\n                        newIndices[idx] = nVertex;\n                        nVertex++;\n                    }\n                }\n            }\n            for (var a = 0; a < attribNames.length; a++) {\n                var attribName = attribNames[a];\n                var subAttrib = subGeo.attributes[attribName];\n                subAttrib.init(nVertex);\n            }\n            subGeo.attributes.joint.value = new Float32Array(nVertex * 4);\n\n            if (nVertex > 0xffff) {\n                subGeo.indices = new Uint32Array(bucket.triangles.length * 3);\n            }\n            else {\n                subGeo.indices = new Uint16Array(bucket.triangles.length * 3);\n            }\n\n            var indicesOffset = 0;\n            nVertex = 0;\n            for (var i = 0; i < nVertex2; i++) {\n                newIndices[i] = -1;\n            }\n\n            for (var f = 0; f < bucket.triangles.length; f++) {\n                var triangle = bucket.triangles[f];\n                for (var i = 0; i < 3; i++) {\n\n                    var idx = triangle[i];\n\n                    if (newIndices[idx] === -1) {\n                        newIndices[idx] = nVertex;\n                        for (var a = 0; a < attribNames.length; a++) {\n                            var attribName = attribNames[a];\n                            var attrib = geometry.attributes[attribName];\n                            var subAttrib = subGeo.attributes[attribName];\n                            var size = attrib.size;\n\n                            for (var j = 0; j < size; j++) {\n                                subAttrib.value[nVertex * size + j] = attrib.value[idx * size + j];\n                            }\n                        }\n                        for (var j = 0; j < 4; j++) {\n                            var jointIdx = geometry.attributes.joint.value[idx * 4 + j];\n                            var offset = nVertex * 4 + j;\n                            if (jointIdx >= 0) {\n                                subGeo.attributes.joint.value[offset] = jointReverseMap[jointIdx];\n                            }\n                            else {\n                                subGeo.attributes.joint.value[offset] = -1;\n                            }\n                        }\n                        nVertex++;\n                    }\n                    subGeo.indices[indicesOffset++] = newIndices[idx];\n                }\n            }\n            subGeo.updateBoundingBox();\n\n            root.add(subMesh);\n        }\n        var children = mesh.children();\n        for (var i = 0; i < children.length; i++) {\n            root.add(children[i]);\n        }\n        root.position.copy(mesh.position);\n        root.rotation.copy(mesh.rotation);\n        root.scale.copy(mesh.scale);\n\n        if (inPlace) {\n            if (mesh.getParent()) {\n                var parent = mesh.getParent();\n                parent.remove(mesh);\n                parent.add(root);\n            }\n        }\n        return root;\n    }\n};\n\nexport default meshUtil;\n","import util from '../core/util';\nimport Geometry from '../Geometry';\nimport BoundingBox from '../math/BoundingBox';\nimport Vector3 from '../math/Vector3';\n\nvar META = {\n    version: 1.0,\n    type: 'Geometry',\n    generator: 'util.transferable.toObject'\n};\n\n/**\n * @alias clay.util.transferable\n */\nvar transferableUtil = {\n    /**\n     * Convert geometry to a object containing transferable data\n     * @param {Geometry} geometry geometry\n     * @param {Boolean} shallow whether shallow copy\n     * @returns {Object} { data : data, buffers : buffers }, buffers is the transferable list\n     */\n    toObject : function (geometry, shallow) {\n        if (!geometry) {\n            return null;\n        }\n        var data = {\n            metadata : util.extend({}, META)\n        };\n        //transferable buffers\n        var buffers = [];\n\n        //dynamic\n        data.dynamic = geometry.dynamic;\n\n        //bounding box\n        if (geometry.boundingBox) {\n            data.boundingBox = {\n                min : geometry.boundingBox.min.toArray(),\n                max : geometry.boundingBox.max.toArray()\n            };\n        }\n\n        //indices\n        if (geometry.indices && geometry.indices.length > 0) {\n            data.indices = copyIfNecessary(geometry.indices, shallow);\n            buffers.push(data.indices.buffer);\n        }\n\n        //attributes\n        data.attributes = {};\n        for (var p in geometry.attributes) { \n            if (geometry.attributes.hasOwnProperty(p)) {\n                var attr = geometry.attributes[p];\n                //ignore empty attributes\n                if (attr && attr.value && attr.value.length > 0) {\n                    attr = data.attributes[p] = copyAttribute(attr, shallow);\n                    buffers.push(attr.value.buffer);\n                }\n            }\n        }\n\n        return {\n            data : data,\n            buffers : buffers\n        };\n    },\n    \n    /**\n     * Reproduce a geometry from object generated by toObject\n     * @param {Object} object object generated by toObject\n     * @returns {Geometry} geometry\n     */\n    toGeometry : function (object) {\n        if (!object) {\n            return null;\n        }\n        if (object.data && object.buffers) {\n            return transferableUtil.toGeometry(object.data);\n        }\n        if (!object.metadata || object.metadata.generator !== META.generator) {\n            throw new Error('[util.transferable.toGeometry] the object is not generated by util.transferable.');\n        }\n\n        //basic options\n        var options = {\n            dynamic : object.dynamic,\n            indices : object.indices\n        };\n\n        if (object.boundingBox) {\n            var min = new Vector3().setArray(object.boundingBox.min);\n            var max = new Vector3().setArray(object.boundingBox.max);\n            options.boundingBox = new BoundingBox(min, max);\n        }\n\n        //attributes\n        var attributes = {};\n        for (var p in object.attributes) {\n            if (object.attributes.hasOwnProperty(p)) {\n                var attr = object.attributes[p];\n                attributes[p] = new Geometry.Attribute(attr.name, attr.type, attr.size, attr.semantic);\n                attributes[p].value = attr.value;\n            }\n        }\n        options.attributes = attributes;\n\n        return new Geometry(options);\n    }\n    \n}\n\nfunction copyAttribute(attr, shallow) {\n    return {\n        name : attr.name,\n        type : attr.type,\n        size : attr.size,\n        semantic : attr.semantic,\n        value : copyIfNecessary(attr.value, shallow)\n    };\n}\n\nfunction copyIfNecessary(arr, shallow) {\n    if (!shallow) {\n        return new arr.constructor(arr);\n    } else {\n        return arr;\n    }\n}\n\nexport default transferableUtil;\n","/**\n * @name clay.version\n */\nexport default '1.0.0-rc.1';\n","export default \"@export clay.vr.disorter.output.vertex\\nattribute vec2 texcoord: TEXCOORD_0;\\nattribute vec3 position: POSITION;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    v_Texcoord = texcoord;\\n    gl_Position = vec4(position.xy, 0.5, 1.0);\\n}\\n@end\\n@export clay.vr.disorter.output.fragment\\nuniform sampler2D texture;\\nvarying vec2 v_Texcoord;\\nvoid main()\\n{\\n    gl_FragColor = texture2D(texture, v_Texcoord);\\n}\\n@end\";\n","// https://github.com/googlevr/webvr-polyfill/blob/master/src/cardboard-distorter.js\n\n// Use webvr may have scale problem.\n// https://github.com/googlevr/webvr-polyfill/issues/140\n// https://github.com/googlevr/webvr-polyfill/search?q=SCALE&type=Issues&utf8=%E2%9C%93\n// https://github.com/googlevr/webvr-polyfill/issues/147\n\n\nimport Mesh from '../Mesh';\nimport Material from '../Material';\nimport Geometry from '../Geometry';\nimport Shader from '../Shader';\nimport Base from '../core/Base';\nimport PerspectiveCamera from '../camera/Perspective';\n\nimport outputEssl from './output.glsl.js';\n\nShader.import(outputEssl);\n\nfunction lerp (a, b, t) {\n    return a * (1 - t) + b * t;\n}\n\nvar CardboardDistorter = Base.extend(function () {\n    return {\n\n        clearColor: [0, 0, 0, 1],\n\n        _mesh: new Mesh({\n            geometry: new Geometry({\n                dynamic: true\n            }),\n            culling: false,\n            material: new Material({\n                // FIXME Why disable depthMask will be wrong\n                // depthMask: false,\n                depthTest: false,\n                shader: new Shader({\n                    vertex: Shader.source('clay.vr.disorter.output.vertex'),\n                    fragment: Shader.source('clay.vr.disorter.output.fragment')\n                })\n            })\n        }),\n        _fakeCamera: new PerspectiveCamera()\n    };\n}, {\n\n    render: function (renderer, sourceTexture) {\n        var clearColor = this.clearColor;\n        var gl = renderer.gl;\n        gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);\n        gl.clear(gl.COLOR_BUFFER_BIT);\n\n        gl.disable(gl.BLEND);\n\n        this._mesh.material.set('texture', sourceTexture);\n\n        // Full size?\n        renderer.saveViewport();\n        renderer.setViewport(0, 0, renderer.getWidth(), renderer.getHeight());\n        renderer.renderPass([this._mesh], this._fakeCamera);\n        renderer.restoreViewport();\n        // this._mesh.material.shader.bind(renderer);\n        // this._mesh.material.bind(renderer);\n        // this._mesh.render(renderer.gl);\n    },\n\n    updateFromVRDisplay: function (vrDisplay) {\n\n        // FIXME\n        if (vrDisplay.deviceInfo_) {\n            // Hardcoded mesh size\n            this._updateMesh(20, 20, vrDisplay.deviceInfo_);\n        }\n        else {\n            console.warn('Cant get vrDisplay.deviceInfo_, seems code changed');\n        }\n    },\n\n    _updateMesh: function (width, height, deviceInfo) {\n\n        var positionAttr = this._mesh.geometry.attributes.position;\n        var texcoordAttr = this._mesh.geometry.attributes.texcoord0;\n        positionAttr.init(2 * width * height);\n        texcoordAttr.init(2 * width * height);\n\n        var lensFrustum = deviceInfo.getLeftEyeVisibleTanAngles();\n        var noLensFrustum = deviceInfo.getLeftEyeNoLensTanAngles();\n        var viewport = deviceInfo.getLeftEyeVisibleScreenRect(noLensFrustum);\n        var vidx = 0;\n\n        var pos = [];\n        var uv = [];\n\n        // Vertices\n        for (var e = 0; e < 2; e++) {\n            for (var j = 0; j < height; j++) {\n                for (var i = 0; i < width; i++, vidx++) {\n                    var u = i / (width - 1);\n                    var v = j / (height - 1);\n\n                    // Grid points regularly spaced in StreoScreen, and barrel distorted in\n                    // the mesh.\n                    var s = u;\n                    var t = v;\n                    var x = lerp(lensFrustum[0], lensFrustum[2], u);\n                    var y = lerp(lensFrustum[3], lensFrustum[1], v);\n                    var d = Math.sqrt(x * x + y * y);\n                    var r = deviceInfo.distortion.distortInverse(d);\n                    var p = x * r / d;\n                    var q = y * r / d;\n                    u = (p - noLensFrustum[0]) / (noLensFrustum[2] - noLensFrustum[0]);\n                    v = (q - noLensFrustum[3]) / (noLensFrustum[1] - noLensFrustum[3]);\n\n                    // Convert u,v to mesh screen coordinates.\n                    var aspect = deviceInfo.device.widthMeters / deviceInfo.device.heightMeters;\n\n                    // FIXME: The original Unity plugin multiplied U by the aspect ratio\n                    // and didn't multiply either value by 2, but that seems to get it\n                    // really close to correct looking for me. I hate this kind of \"Don't\n                    // know why it works\" code though, and wold love a more logical\n                    // explanation of what needs to happen here.\n                    u = (viewport.x + u * viewport.width - 0.5) * 2.0; //* aspect;\n                    v = (viewport.y + v * viewport.height - 0.5) * 2.0;\n\n                    pos[0] = u;\n                    pos[1] = v;\n                    pos[2] = 0;\n\n                    uv[0] = s * 0.5 + e * 0.5;\n                    uv[1] = t;\n\n                    positionAttr.set(vidx, pos);\n                    texcoordAttr.set(vidx, uv);\n                }\n            }\n\n            var w = lensFrustum[2] - lensFrustum[0];\n            lensFrustum[0] = -(w + lensFrustum[0]);\n            lensFrustum[2] = w - lensFrustum[2];\n            w = noLensFrustum[2] - noLensFrustum[0];\n            noLensFrustum[0] = -(w + noLensFrustum[0]);\n            noLensFrustum[2] = w - noLensFrustum[2];\n            viewport.x = 1 - (viewport.x + viewport.width);\n        }\n\n        // Indices\n        var indices = new Uint16Array(2 * (width - 1) * (height - 1) * 6);\n        var halfwidth = width / 2;\n        var halfheight = height / 2;\n        var vidx = 0;\n        var iidx = 0;\n        for (var e = 0; e < 2; e++) {\n            for (var j = 0; j < height; j++) {\n                for (var i = 0; i < width; i++, vidx++) {\n                    if (i === 0 || j === 0) {\n                        continue;\n                    }\n                    // Build a quad.  Lower right and upper left quadrants have quads with\n                    // the triangle diagonal flipped to get the vignette to interpolate\n                    // correctly.\n                    if ((i <= halfwidth) == (j <= halfheight)) {\n                        // Quad diagonal lower left to upper right.\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - width - 1;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx - width - 1;\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - 1;\n                    }\n                    else {\n                        // Quad diagonal upper left to lower right.\n                        indices[iidx++] = vidx - 1;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx;\n                        indices[iidx++] = vidx - width;\n                        indices[iidx++] = vidx - 1;\n                        indices[iidx++] = vidx - width - 1;\n                    }\n                }\n            }\n        }\n\n        this._mesh.geometry.indices = indices;\n\n        this._mesh.geometry.dirty();\n    }\n});\n\nexport default CardboardDistorter;\n","import Base from '../Node';\nimport Camera from '../camera/Perspective';\nimport Matrix4 from '../math/Matrix4';\n\nvar tmpProjectionMatrix = new Matrix4();\n\nvar StereoCamera = Base.extend(function () {\n    return {\n\n        aspect: 0.5,\n\n        _leftCamera: new Camera(),\n\n        _rightCamera: new Camera(),\n\n        _eyeLeft: new Matrix4(),\n        _eyeRight: new Matrix4(),\n\n        _frameData: null\n    };\n}, {\n\n    updateFromCamera: function (camera, focus, zoom, eyeSep) {\n        if (camera.transformNeedsUpdate()) {\n            console.warn('Node transform is not updated');\n        }\n\n        focus = focus == null ? 10 : focus;\n        zoom = zoom == null ? 1 : zoom;\n        eyeSep = eyeSep == null ? 0.064 : eyeSep;\n\n        var fov = camera.fov;\n        var aspect = camera.aspect * this.aspect;\n        var near = camera.near;\n\n        // Off-axis stereoscopic effect based on\n        // http://paulbourke.net/stereographics/stereorender/\n\n        tmpProjectionMatrix.copy(camera.projectionMatrix);\n        var eyeSep = eyeSep / 2;\n        var eyeSepOnProjection = eyeSep * near / focus;\n        var ymax = (near * Math.tan(Math.PI / 180 * fov * 0.5 ) ) / zoom;\n        var xmin, xmax;\n\n        // translate xOffset\n        this._eyeLeft.array[12] = - eyeSep;\n        this._eyeRight.array[12] = eyeSep;\n\n        // for left eye\n        xmin = - ymax * aspect + eyeSepOnProjection;\n        xmax = ymax * aspect + eyeSepOnProjection;\n\n        tmpProjectionMatrix.array[0] = 2 * near / (xmax - xmin);\n        tmpProjectionMatrix.array[8] = (xmax + xmin ) / (xmax - xmin);\n\n        this._leftCamera.projectionMatrix.copy(tmpProjectionMatrix);\n\n        // for right eye\n        xmin = - ymax * aspect - eyeSepOnProjection;\n        xmax = ymax * aspect - eyeSepOnProjection;\n\n        tmpProjectionMatrix.array[0] = 2 * near / (xmax - xmin);\n        tmpProjectionMatrix.array[8] = (xmax + xmin ) / (xmax - xmin);\n\n        this._rightCamera.projectionMatrix.copy(tmpProjectionMatrix);\n\n        this._leftCamera.worldTransform\n            .copy(camera.worldTransform)\n            .multiply(this._eyeLeft);\n\n        this._rightCamera.worldTransform\n            .copy(camera.worldTransform)\n            .multiply(this._eyeRight);\n\n        this._leftCamera.decomposeWorldTransform();\n        this._leftCamera.decomposeProjectionMatrix();\n\n        this._rightCamera.decomposeWorldTransform();\n        this._rightCamera.decomposeProjectionMatrix();\n    },\n\n    updateFromVRDisplay: function (vrDisplay, parentNode) {\n\n        if (typeof VRFrameData === 'undefined') {\n            return;\n        }\n\n        var frameData = this._frameData || (this._frameData = new VRFrameData());\n        vrDisplay.getFrameData(frameData);\n        var leftCamera = this._leftCamera;\n        var rightCamera = this._rightCamera;\n\n        leftCamera.projectionMatrix.setArray(frameData.leftProjectionMatrix);\n        leftCamera.decomposeProjectionMatrix();\n        leftCamera.viewMatrix.setArray(frameData.leftViewMatrix);\n        leftCamera.setViewMatrix(leftCamera.viewMatrix);\n\n        rightCamera.projectionMatrix.setArray(frameData.rightProjectionMatrix);\n        rightCamera.decomposeProjectionMatrix();\n        rightCamera.viewMatrix.setArray(frameData.rightViewMatrix);\n        rightCamera.setViewMatrix(rightCamera.viewMatrix);\n\n        if (parentNode && parentNode.worldTransform) {\n            if (parentNode.transformNeedsUpdate()) {\n                console.warn('Node transform is not updated');\n            }\n            leftCamera.worldTransform.multiplyLeft(parentNode.worldTransform);\n            leftCamera.decomposeWorldTransform();\n            rightCamera.worldTransform.multiplyLeft(parentNode.worldTransform);\n            rightCamera.decomposeWorldTransform();\n        }\n    },\n\n    getLeftCamera: function () {\n        return this._leftCamera;\n    },\n\n    getRightCamera: function () {\n        return this._rightCamera;\n    }\n});\n\nexport default StereoCamera;\n","/** @namespace clay */\n/** @namespace clay.math */\n/** @namespace clay.animation */\n/** @namespace clay.async */\n/** @namespace clay.camera */\n/** @namespace clay.compositor */\n/** @namespace clay.core */\n/** @namespace clay.geometry */\n/** @namespace clay.helper */\n/** @namespace clay.light */\n/** @namespace clay.loader */\n/** @namespace clay.particleSystem */\n/** @namespace clay.plugin */\n/** @namespace clay.prePass */\n/** @namespace clay.shader */\n/** @namespace clay.texture */\n/** @namespace clay.util */\n\nimport Animator$0 from './animation/Animator';\nimport Blend1DClip$1 from './animation/Blend1DClip';\nimport Blend2DClip$2 from './animation/Blend2DClip';\nimport Clip$3 from './animation/Clip';\nimport easing$4 from './animation/easing';\nimport SamplerTrack$5 from './animation/SamplerTrack';\nimport Timeline$6 from './animation/Timeline';\nimport TrackClip$7 from './animation/TrackClip';\nimport TransformTrack$8 from './animation/TransformTrack';\nimport application$9 from './application';\nimport Task$10 from './async/Task';\nimport TaskGroup$11 from './async/TaskGroup';\nimport Camera$12 from './Camera';\nimport Orthographic$13 from './camera/Orthographic';\nimport Perspective$14 from './camera/Perspective';\nimport Material$15 from './canvas/Material';\nimport Renderer$16 from './canvas/Renderer';\nimport Compositor$17 from './compositor/Compositor';\nimport createCompositor$18 from './compositor/createCompositor';\nimport FilterNode$19 from './compositor/FilterNode';\nimport Graph$20 from './compositor/Graph';\nimport Node$21 from './compositor/Node';\nimport Pass$22 from './compositor/Pass';\nimport SceneNode$23 from './compositor/SceneNode';\nimport TextureNode$24 from './compositor/TextureNode';\nimport TexturePool$25 from './compositor/TexturePool';\nimport Base$26 from './core/Base';\nimport Cache$27 from './core/Cache';\nimport color$28 from './core/color';\nimport glenum$29 from './core/glenum';\nimport GLInfo$30 from './core/GLInfo';\nimport LinkedList$31 from './core/LinkedList';\nimport LRU$32 from './core/LRU';\nimport extend$33 from './core/mixin/extend';\nimport notifier$34 from './core/mixin/notifier';\nimport request$35 from './core/request';\nimport util$36 from './core/util';\nimport vendor$37 from './core/vendor';\nimport GBuffer$38 from './deferred/GBuffer';\nimport Renderer$39 from './deferred/Renderer';\nimport glmatrix$40 from './dep/glmatrix';\nimport FrameBuffer$41 from './FrameBuffer';\nimport Geometry$42 from './Geometry';\nimport Cone$43 from './geometry/Cone';\nimport Cube$44 from './geometry/Cube';\nimport Cylinder$45 from './geometry/Cylinder';\nimport Plane$46 from './geometry/Plane';\nimport Sphere$47 from './geometry/Sphere';\nimport GLProgram$48 from './gpu/GLProgram';\nimport ProgramManager$49 from './gpu/ProgramManager';\nimport Joint$50 from './Joint';\nimport Light$51 from './Light';\nimport Ambient$52 from './light/Ambient';\nimport AmbientCubemap$53 from './light/AmbientCubemap';\nimport AmbientSH$54 from './light/AmbientSH';\nimport Directional$55 from './light/Directional';\nimport Point$56 from './light/Point';\nimport Sphere$57 from './light/Sphere';\nimport Spot$58 from './light/Spot';\nimport Tube$59 from './light/Tube';\nimport FX$60 from './loader/FX';\nimport GLTF$61 from './loader/GLTF';\nimport Material$62 from './Material';\nimport BoundingBox$63 from './math/BoundingBox';\nimport Frustum$64 from './math/Frustum';\nimport Matrix2$65 from './math/Matrix2';\nimport Matrix2d$66 from './math/Matrix2d';\nimport Matrix3$67 from './math/Matrix3';\nimport Matrix4$68 from './math/Matrix4';\nimport Plane$69 from './math/Plane';\nimport Quaternion$70 from './math/Quaternion';\nimport Ray$71 from './math/Ray';\nimport util$72 from './math/util';\nimport Value$73 from './math/Value';\nimport Vector2$74 from './math/Vector2';\nimport Vector3$75 from './math/Vector3';\nimport Vector4$76 from './math/Vector4';\nimport Mesh$77 from './Mesh';\nimport Node$78 from './Node';\nimport Emitter$79 from './particle/Emitter';\nimport Field$80 from './particle/Field';\nimport ForceField$81 from './particle/ForceField';\nimport Particle$82 from './particle/Particle';\nimport ParticleRenderable$83 from './particle/ParticleRenderable';\nimport PixelPicking$84 from './picking/PixelPicking';\nimport RayPicking$85 from './picking/RayPicking';\nimport FreeControl$86 from './plugin/FreeControl';\nimport GestureMgr$87 from './plugin/GestureMgr';\nimport InfinitePlane$88 from './plugin/InfinitePlane';\nimport OrbitControl$89 from './plugin/OrbitControl';\nimport Skybox$90 from './plugin/Skybox';\nimport Skydome$91 from './plugin/Skydome';\nimport EnvironmentMap$92 from './prePass/EnvironmentMap';\nimport ShadowMap$93 from './prePass/ShadowMap';\nimport Renderable$94 from './Renderable';\nimport Renderer$95 from './Renderer';\nimport Scene$96 from './Scene';\nimport Shader$97 from './Shader';\nimport library$98 from './shader/library';\nimport light$99 from './shader/source/header/light';\nimport Skeleton$100 from './Skeleton';\nimport StandardMaterial$101 from './StandardMaterial';\nimport StaticGeometry$102 from './StaticGeometry';\nimport Texture$103 from './Texture';\nimport Texture2D$104 from './Texture2D';\nimport TextureCube$105 from './TextureCube';\nimport cubemap$106 from './util/cubemap';\nimport dds$107 from './util/dds';\nimport delaunay$108 from './util/delaunay';\nimport hdr$109 from './util/hdr';\nimport mesh$110 from './util/mesh';\nimport sh$111 from './util/sh';\nimport texture$112 from './util/texture';\nimport transferable$113 from './util/transferable';\nimport version$114 from './version';\nimport CardboardDistorter$115 from './vr/CardboardDistorter';\nimport StereoCamera$116 from './vr/StereoCamera';\n\n\nvar animation = {\n    Animator : Animator$0,\n    Blend1DClip : Blend1DClip$1,\n    Blend2DClip : Blend2DClip$2,\n    Clip : Clip$3,\n    easing : easing$4,\n    SamplerTrack : SamplerTrack$5,\n    Timeline : Timeline$6,\n    TrackClip : TrackClip$7,\n    TransformTrack : TransformTrack$8\n};\nexport { animation };\n\nexport { application$9 as application };\n\nvar async = {\n    Task : Task$10,\n    TaskGroup : TaskGroup$11\n};\nexport { async };\n\nexport { Camera$12 as Camera };\n\nvar camera = {\n    Orthographic : Orthographic$13,\n    Perspective : Perspective$14\n};\nexport { camera };\n\n\nvar canvas = {\n    Material : Material$15,\n    Renderer : Renderer$16\n};\nexport { canvas };\n\n\nvar compositor = {\n    Compositor : Compositor$17,\n    createCompositor : createCompositor$18,\n    FilterNode : FilterNode$19,\n    Graph : Graph$20,\n    Node : Node$21,\n    Pass : Pass$22,\n    SceneNode : SceneNode$23,\n    TextureNode : TextureNode$24,\n    TexturePool : TexturePool$25\n};\nexport { compositor };\n\n\nvar core = {\n    Base : Base$26,\n    Cache : Cache$27,\n    color : color$28,\n    glenum : glenum$29,\n    GLInfo : GLInfo$30,\n    LinkedList : LinkedList$31,\n    LRU : LRU$32,\n    mixin : {\n        extend : extend$33,\n        notifier : notifier$34\n    },\n    request : request$35,\n    util : util$36,\n    vendor : vendor$37\n};\nexport { core };\n\n\nvar deferred = {\n    GBuffer : GBuffer$38,\n    Renderer : Renderer$39\n};\nexport { deferred };\n\n\nvar dep = {\n    glmatrix : glmatrix$40\n};\nexport { dep };\n\nexport { FrameBuffer$41 as FrameBuffer };\nexport { Geometry$42 as Geometry };\n\nvar geometry = {\n    Cone : Cone$43,\n    Cube : Cube$44,\n    Cylinder : Cylinder$45,\n    Plane : Plane$46,\n    Sphere : Sphere$47\n};\nexport { geometry };\n\n\nvar gpu = {\n    GLProgram : GLProgram$48,\n    ProgramManager : ProgramManager$49\n};\nexport { gpu };\n\nexport { Joint$50 as Joint };\nexport { Light$51 as Light };\n\nvar light = {\n    Ambient : Ambient$52,\n    AmbientCubemap : AmbientCubemap$53,\n    AmbientSH : AmbientSH$54,\n    Directional : Directional$55,\n    Point : Point$56,\n    Sphere : Sphere$57,\n    Spot : Spot$58,\n    Tube : Tube$59\n};\nexport { light };\n\n\nvar loader = {\n    FX : FX$60,\n    GLTF : GLTF$61\n};\nexport { loader };\n\nexport { Material$62 as Material };\n\nvar math = {\n    BoundingBox : BoundingBox$63,\n    Frustum : Frustum$64,\n    Matrix2 : Matrix2$65,\n    Matrix2d : Matrix2d$66,\n    Matrix3 : Matrix3$67,\n    Matrix4 : Matrix4$68,\n    Plane : Plane$69,\n    Quaternion : Quaternion$70,\n    Ray : Ray$71,\n    util : util$72,\n    Value : Value$73,\n    Vector2 : Vector2$74,\n    Vector3 : Vector3$75,\n    Vector4 : Vector4$76\n};\nexport { math };\n\nexport { Mesh$77 as Mesh };\nexport { Node$78 as Node };\n\nvar particle = {\n    Emitter : Emitter$79,\n    Field : Field$80,\n    ForceField : ForceField$81,\n    Particle : Particle$82,\n    ParticleRenderable : ParticleRenderable$83\n};\nexport { particle };\n\n\nvar picking = {\n    PixelPicking : PixelPicking$84,\n    RayPicking : RayPicking$85\n};\nexport { picking };\n\n\nvar plugin = {\n    FreeControl : FreeControl$86,\n    GestureMgr : GestureMgr$87,\n    InfinitePlane : InfinitePlane$88,\n    OrbitControl : OrbitControl$89,\n    Skybox : Skybox$90,\n    Skydome : Skydome$91\n};\nexport { plugin };\n\n\nvar prePass = {\n    EnvironmentMap : EnvironmentMap$92,\n    ShadowMap : ShadowMap$93\n};\nexport { prePass };\n\nexport { Renderable$94 as Renderable };\nexport { Renderer$95 as Renderer };\nexport { Scene$96 as Scene };\nexport { Shader$97 as Shader };\n\nvar shader = {\n    library : library$98,\n    source : {\n    header : {\n        light : light$99\n    }\n    }\n};\nexport { shader };\n\nexport { Skeleton$100 as Skeleton };\nexport { StandardMaterial$101 as StandardMaterial };\nexport { StaticGeometry$102 as StaticGeometry };\nexport { Texture$103 as Texture };\nexport { Texture2D$104 as Texture2D };\nexport { TextureCube$105 as TextureCube };\n\nvar util = {\n    cubemap : cubemap$106,\n    dds : dds$107,\n    delaunay : delaunay$108,\n    hdr : hdr$109,\n    mesh : mesh$110,\n    sh : sh$111,\n    texture : texture$112,\n    transferable : transferable$113\n};\nexport { util };\n\nexport { version$114 as version };\n\nvar vr = {\n    CardboardDistorter : CardboardDistorter$115,\n    StereoCamera : StereoCamera$116\n};\nexport { vr };\n;\n"],"names":["easing","Easing","this","glMatrix","quat","vec3","util","notifierMixin","canvas","proto","mat4","defineProperty","LRU","parseColor","getDefineCode","mat3","lightShader","prezEssl","noop","vec4","Plane","vec3Set","vec3Copy","EPSILON","programKeyCache","getProgramKey","Cube","Sphere","Perspective","Orthographic","utilEssl","shaderLibrary","PerspectiveCamera","OrthographicCamera","isPowerOfTwo","camera","OrthoCamera","CubeGeometry","targets","SphereGeometry","ret","hdr","dds","LRUCache","CubeGeo","SphereGeo","PlaneGeo","shUtil","Node","GraphNode","SceneNode","TextureNode","FilterNode","CompoSceneNode","CompoTextureNode","CompoFilterNode","vec2","Cone","Cylinder","ConeGeometry","ConeGeo","CylinderGeo","FullQuadPass","mat2","outputEssl","Base","Camera","Animator$0","Blend1DClip$1","Blend2DClip$2","Clip$3","easing$4","SamplerTrack$5","Timeline$6","TrackClip$7","TransformTrack$8","Task$10","TaskGroup$11","Orthographic$13","Perspective$14","Material$15","Renderer$16","Compositor$17","createCompositor$18","FilterNode$19","Graph$20","Node$21","Pass$22","SceneNode$23","TextureNode$24","TexturePool$25","Base$26","Cache$27","color$28","glenum$29","GLInfo$30","LinkedList$31","LRU$32","extend$33","notifier$34","request$35","util$36","vendor$37","GBuffer$38","Renderer$39","glmatrix$40","Cone$43","Cube$44","Cylinder$45","Plane$46","Sphere$47","GLProgram$48","ProgramManager$49","Ambient$52","AmbientCubemap$53","AmbientSH$54","Directional$55","Point$56","Sphere$57","Spot$58","Tube$59","FX$60","GLTF$61","BoundingBox$63","Frustum$64","Matrix2$65","Matrix2d$66","Matrix3$67","Matrix4$68","Plane$69","Quaternion$70","Ray$71","util$72","Value$73","Vector2$74","Vector3$75","Vector4$76","Emitter$79","Field$80","ForceField$81","Particle$82","ParticleRenderable$83","PixelPicking$84","RayPicking$85","FreeControl$86","GestureMgr$87","InfinitePlane$88","OrbitControl$89","Skybox$90","Skydome$91","EnvironmentMap$92","ShadowMap$93","library$98","light$99","cubemap$106","dds$107","delaunay$108","hdr$109","mesh$110","sh$111","texture$112","transferable$113","CardboardDistorter$115","StereoCamera$116"],"mappings":"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AAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACnD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;IACpD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,CAAC;;IAEpD,OAAO,GAAG,CAAC;CACd,CAAC;;;;;;;;;AASF,IAAI,CAAC,OAAO,GAAG,SAAS,GAAG,EAAE,CAAC,EAAE;IAC5B,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAC9C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAC9C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC;QAChD,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;IAEvD,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;IAC3G,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,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AAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;;IAGvD,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE3C,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE3C,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IAC7C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC3C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;IAE5C,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IAC/C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAC5C,OAAO,GAAG,CAAC;CACd,CAAC;;;;;;;;;;AAUF,IAAI,CAAC,cAAc,GAAG,UAAU,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE;IACvC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAClC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QAClC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC;QACnC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;;IAG1C,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACrC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;;IAGlC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAChC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;;IAGlC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IACjC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;IAClC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC;;;IAGnC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;IACnC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC;IACzC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC;IACzC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC;;IAEzC,OAAO,GAAG,CAAC;CACd,CAAC;;;;;;AAMF,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC;;;;;;AAMzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;;;;;;;;;AASrC,IAAI,CAAC,SAAS,GAAG,UAAU,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE;IAClC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC5B,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAClB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAClB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;;IAEvB,IAAI,CAAC,KAAK,GAAG,EAAE;QACX,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QACjD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QACjD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAClD,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;KACrD,MAAM;QACH,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;QAEjD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QACvD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;QACvD,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;;QAEzD,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9C,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,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GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;;IAGjD,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACtE,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACtE,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;;;IAGtE,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IAC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AC;YACpE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;;YAEpE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;YACrE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;;YAErE,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;YAE1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;YAC1F,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,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AC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YACxC,MAAM;QACV,KAAK,KAAK;YACN,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,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"} diff --git a/dist/claygl.min.js b/dist/claygl.min.js index 34b5ba088..39549e536 100644 --- a/dist/claygl.min.js +++ b/dist/claygl.min.js @@ -1,14 +1,14 @@ -!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e(t.clay={})}(this,function(t){"use strict";function e(){}function r(t,e){return t[e]}function n(t,e,r){t[e]=r}function i(t,e,r){return(e-t)*r+t}function a(t,e,r,n,a){var o=t.length;if(1==a)for(var s=0;si)t.length=i;else for(var a=n;a=0&&!(T[S]<=e);S--);S=Math.min(S,_-2)}else{for(S=I;S<_&&!(T[S]>e);S++);S=Math.min(S-1,_-2)}I=S,O=e;var r=T[S+1]-T[S];0!==r&&(M=(e-T[S])/r,p?(L=E[S],R=E[0===S?S:S-1],P=E[S>_-2?_-1:S+1],D=E[S>_-3?_-1:S+2],f?m(t,s,f(d(t,s),R,L,P,D,M)):v?u(R,L,P,D,M,M*M,M*M*M,d(t,s),y):m(t,s,l(R,L,P,D,M,M*M,M*M*M))):f?m(t,s,f(d(t,s),E[S],E[S+1],M)):v?a(E[S],E[S+1],M,d(t,s),y):m(t,s,i(E[S],E[S+1],M)))},F=new oe({target:t._target,life:x,loop:t._loop,delay:t._delay,onframe:B,onfinish:r});return e&&"spline"!==e&&F.setEasing(e),F}}}function d(t,e,i,a,o){this._tracks={},this._target=t,this._loop=e||!1,this._getter=i||r,this._setter=a||n,this._interpolater=o||null,this._delay=0,this._doneList=[],this._onframeList=[],this._clipList=[]}function m(t){var e,r,n,i,a,o,s=Number.POSITIVE_INFINITY,u=Number.POSITIVE_INFINITY,l=Number.NEGATIVE_INFINITY,c=Number.NEGATIVE_INFINITY;for(e=t.length;e--;)t[e][0]l&&(l=t[e][0]),t[e][1]c&&(c=t[e][1]);return r=l-s,n=c-u,i=Math.max(r,n),a=s+.5*r,o=u+.5*n,[[a-20*i,o-i],[a,o+20*i],[a+20*i,o-i]]}function p(t,e,r,n){var i,a,o,s,u,l,c,h,f,d,m=t[e][0],p=t[e][1],_=t[r][0],g=t[r][1],v=t[n][0],y=t[n][1],x=Math.abs(p-g),T=Math.abs(g-y);if(xT?o*(i-u)+c:s*(i-l)+h),f=_-i,d=g-a,{i:e,j:r,k:n,x:i,y:a,r:f*f+d*d}}function _(t){var e,r,n,i,a,o;for(r=t.length;r;)for(i=t[--r],n=t[--r],e=r;e;)if(o=t[--e],a=t[--e],n===a&&i===o||n===o&&i===a){t.splice(r,2),t.splice(e,2);break}}function g(t,e){return t.time-e.time}function v(t,e,r,n,i,a){var o=e[i],s=e[i+1],u=e[i+2];return t[0]=o+n*(r[a]-o),t[1]=s+n*(r[a+1]-s),t[2]=u+n*(r[a+2]-u),t}function y(t,e,r,n,i,a){var o,s,u,l,c,h=e[0+i],f=e[1+i],d=e[2+i],m=e[3+i],p=r[0+a],_=r[1+a],g=r[2+a],v=r[3+a];return s=h*p+f*_+d*g+m*v,s<0&&(s=-s,p=-p,_=-_,g=-g,v=-v),1-s>1e-6?(o=Math.acos(s),u=Math.sin(o),l=Math.sin((1-n)*o)/u,c=Math.sin(n*o)/u):(l=1-n,c=n),t[0]=l*h+c*p,t[1]=l*f+c*_,t[2]=l*d+c*g,t[3]=l*m+c*v,t}function x(t,e,r){"object"==typeof e&&(r=e,e=null);var n,i=this;if(!(t instanceof Function)){n=[];for(var a in t)t.hasOwnProperty(a)&&n.push(a)}var o=function(e){if(i.apply(this,arguments),t instanceof Function?T(this,t.call(this,e)):E(this,t,n),this.constructor===o)for(var r=o.__initializers__,a=0;ar?r:t}function w(t){return t=Math.round(t),t<0?0:t>255?255:t}function C(t){return t=Math.round(t),t<0?0:t>360?360:t}function N(t){return t<0?0:t>1?1:t}function M(t){return w(t.length&&"%"===t.charAt(t.length-1)?parseFloat(t)/100*255:parseInt(t,10))}function R(t){return N(t.length&&"%"===t.charAt(t.length-1)?parseFloat(t)/100:parseFloat(t))}function L(t,e,r){return r<0?r+=1:r>1&&(r-=1),6*r<1?t+(e-t)*r*6:2*r<1?e:3*r<2?t+(e-t)*(2/3-r)*6:t}function P(t,e,r){return t+(e-t)*r}function D(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function I(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function O(t,e){fr&&I(fr,e),fr=hr.put(t,fr||e.slice())}function B(t,e){var r=(parseFloat(t[0])%360+360)%360/360,n=R(t[1]),i=R(t[2]),a=i<=.5?i*(n+1):i+n-i*n,o=2*i-a;return e=e||[],D(e,w(255*L(o,a,r+1/3)),w(255*L(o,a,r)),w(255*L(o,a,r-1/3)),1),4===t.length&&(e[3]=t[3]),e}function F(t){if(t){var e,r,n=t[0]/255,i=t[1]/255,a=t[2]/255,o=Math.min(n,i,a),s=Math.max(n,i,a),u=s-o,l=(s+o)/2;if(0===u)e=0,r=0;else{r=l<.5?u/(s+o):u/(2-s-o);var c=((s-n)/6+u/2)/u,h=((s-i)/6+u/2)/u,f=((s-a)/6+u/2)/u;n===s?e=f-h:i===s?e=1/3+c-f:a===s&&(e=2/3+h-c),e<0&&(e+=1),e>1&&(e-=1)}var d=[360*e,r,l];return null!=t[3]&&d.push(t[3]),d}}function U(t,e,r){var n=Object.keys(t);n.sort();for(var i=[],a=0;a0&&n.push("#define "+i.toUpperCase()+"_COUNT "+a)}if(r)for(var o=0;o=400?t.onerror&&t.onerror():t.onload&&t.onload(e.response)},t.onerror&&(e.onerror=t.onerror),e.send(null)}function lt(t,e,r,n){var i=t.accessors[r],a=e.bufferViews[i.bufferView],o=i.byteOffset||0,s=ai[i.componentType]||He.Float32Array,u=oi[i.type];null==u&&n&&(u=1);var l=new s(a,o,u*i.count),c=i.extensions&&i.extensions.WEB3D_quantized_attributes;if(c){for(var h,f,d=new He.Float32Array(u*i.count),m=c.decodeMatrix,h=new Array(u),f=new Array(u),p=0;p0){var i=Math.pow(2,t[3]-128-8+n);e[r+0]=t[0]*i,e[r+1]=t[1]*i,e[r+2]=t[2]*i}else e[r+0]=0,e[r+1]=0,e[r+2]=0;return e[r+3]=1,e}function dt(t,e,r){for(var n="",i=e;i0;)if(t[a][0]=e[r++],t[a][1]=e[r++],t[a][2]=e[r++],t[a][3]=e[r++],1===t[a][0]&&1===t[a][1]&&1===t[a][2]){for(var s=t[a][3]<>>0;s>0;s--)mt(t[a-1],t[a]),a++,o--;i+=8}else a++,o--,i=0;return r}function _t(t,e,r,n){if(nIi)return pt(t,e,r,n);var i=e[r++];if(2!=i)return pt(t,e,r-1,n);if(t[0][1]=e[r++],t[0][2]=e[r++],i=e[r++],(t[0][2]<<8>>>0|i)>>>0!==n)return null;for(var i=0;i<4;i++)for(var a=0;a128){o=(127&o)>>>0;for(var s=e[r++];o--;)t[a++][i]=s}else for(;o--;)t[a++][i]=e[r++]}return r}function gt(t){Ne.defaultsWithPropList(t,Vi,Wi),vt(t);for(var e="",r=0;r>16,r=t-(e<<8)>>8;return[e,r,t-(e<<16)-(r<<8)]}function Qt(t,e,r){return(t<<16)+(e<<8)+r}function $t(t){var e=t[1][0]-t[0][0],r=t[1][1]-t[0][1];return Math.sqrt(e*e+r*r)}function te(t){return[(t[0][0]+t[1][0])/2,(t[0][1]+t[1][1])/2]}function ee(t){return Array.isArray(t)||(t=[t,t]),t}function re(t,e){return{name:t.name,type:t.type,size:t.size,semantic:t.semantic,value:ne(t.value,e)}}function ne(t,e){return e?t:new t.constructor(t)}function ie(t,e,r){return t*(1-r)+e*r}var ae={linear:function(t){return t},quadraticIn:function(t){return t*t},quadraticOut:function(t){return t*(2-t)},quadraticInOut:function(t){return(t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)},cubicIn:function(t){return t*t*t},cubicOut:function(t){return--t*t*t+1},cubicInOut:function(t){return(t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)},quarticIn:function(t){return t*t*t*t},quarticOut:function(t){return 1- --t*t*t*t},quarticInOut:function(t){return(t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)},quinticIn:function(t){return t*t*t*t*t},quinticOut:function(t){return--t*t*t*t*t+1},quinticInOut:function(t){return(t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)},sinusoidalIn:function(t){return 1-Math.cos(t*Math.PI/2)},sinusoidalOut:function(t){return Math.sin(t*Math.PI/2)},sinusoidalInOut:function(t){return.5*(1-Math.cos(Math.PI*t))},exponentialIn:function(t){return 0===t?0:Math.pow(1024,t-1)},exponentialOut:function(t){return 1===t?1:1-Math.pow(2,-10*t)},exponentialInOut:function(t){return 0===t?0:1===t?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(2-Math.pow(2,-10*(t-1)))},circularIn:function(t){return 1-Math.sqrt(1-t*t)},circularOut:function(t){return Math.sqrt(1- --t*t)},circularInOut:function(t){return(t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)},elasticIn:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),-r*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4))},elasticOut:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),r*Math.pow(2,-10*t)*Math.sin((t-e)*(2*Math.PI)/.4)+1)},elasticInOut:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),(t*=2)<1?r*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4)*-.5:r*Math.pow(2,-10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4)*.5+1)},backIn:function(t){var e=1.70158;return t*t*((e+1)*t-e)},backOut:function(t){var e=1.70158;return--t*t*((e+1)*t+e)+1},backInOut:function(t){var e=2.5949095;return(t*=2)<1?t*t*((e+1)*t-e)*.5:.5*((t-=2)*t*((e+1)*t+e)+2)},bounceIn:function(t){return 1-ae.bounceOut(1-t)},bounceOut:function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375},bounceInOut:function(t){return t<.5?.5*ae.bounceIn(2*t):.5*ae.bounceOut(2*t-1)+.5}},oe=function(t){t=t||{},this.name=t.name||"",this.target=t.target,this.life=t.life||1e3,this.delay=t.delay||0,this.gap=t.gap||0,this.playbackRate=t.playbackRate||1,this._initialized=!1,this._elapsedTime=0,this._loop=null!=t.loop&&t.loop,this.setLoop(this._loop),null!=t.easing&&this.setEasing(t.easing),this.onframe=t.onframe||e,this.onfinish=t.onfinish||e,this.onrestart=t.onrestart||e,this._paused=!1};oe.prototype={gap:0,life:0,delay:0,setLoop:function(t){this._loop=t,t&&(this._loopRemained="number"==typeof t?t:1e8)},setEasing:function(t){"string"==typeof t&&(t=ae[t]),this.easing=t},step:function(t,e,r){if(this._initialized||(this._startTime=t+this.delay,this._initialized=!0),null!=this._currentTime&&(e=t-this._currentTime),this._currentTime=t,this._paused)return"paused";if(!(t0?(this._restartInLoop(t),this._loopRemained--,"restart"):(this._needsRemove=!0,"finish"):null}}},setTime:function(t){return this.step(t+this._startTime)},restart:function(t){var e=0;t&&(this._elapse(t),e=this._elapsedTime%this.life),t=t||Date.now(),this._startTime=t-e+this.delay,this._elapsedTime=0,this._needsRemove=!1,this._paused=!1},getElapsedTime:function(){return this._elapsedTime},_restartInLoop:function(t){this._startTime=t+this.gap,this._elapsedTime=0},_elapse:function(t,e){this._elapsedTime+=e*this.playbackRate},fire:function(t,e){var r="on"+t;this[r]&&this[r](this.target,e)},clone:function(){var t=new this.constructor;return t.name=this.name,t._loop=this._loop,t._loopRemained=this._loopRemained,t.life=this.life,t.gap=this.gap,t.delay=this.delay,t},pause:function(){this._paused=!0},resume:function(){this._paused=!1}},oe.prototype.constructor=oe;var se=Array.prototype.slice;d.prototype={constructor:d,when:function(t,e){for(var r in e)this._tracks[r]||(this._tracks[r]=[],0!==t&&this._tracks[r].push({time:0,value:s(this._getter(this._target,r))})),this._tracks[r].push({time:parseInt(t),value:e[r]});return this},during:function(t){return this._onframeList.push(t),this},_doneCallback:function(){this._tracks={},this._clipList.length=0;for(var t=this._doneList,e=t.length,r=0;rt)this.inputs.unshift(n);else if(this.inputs[i-1].position<=t)this.inputs.push(n);else{var a=this._findKey(t);this.inputs.splice(a,n)}return n},le.prototype.step=function(t,e,r){var n=oe.prototype.step.call(this,t);return"finish"!==n&&this.setTime(this.getElapsedTime()),r||"paused"===n||this.fire("frame"),n},le.prototype.setTime=function(t){var e=this.position,r=this.inputs,n=r.length,i=r[0].position,a=r[n-1].position;if(e<=i||e>=a){var o=e<=i?r[0]:r[n-1],s=o.clip,u=o.offset;s.setTime((t+u)%s.life),s.output instanceof oe?this.output.copy(s.output):this.output.copy(s)}else{var l=this._findKey(e),c=r[l],h=r[l+1],f=c.clip,d=h.clip;f.setTime((t+c.offset)%f.life),d.setTime((t+h.offset)%d.life);var m=(this.position-c.position)/(h.position-c.position),p=f.output instanceof oe?f.output:f,_=d.output instanceof oe?d.output:d;this.output.blend1D(p,_,m)}},le.prototype.clone=function(t){var e=oe.prototype.clone.call(this);e.output=this.output.clone();for(var r=0;r=r[i].position&&t=0;i--)t>=r[i].position&&t=0&&(this._cacheKey=e,this._cachePosition=t),e};var ce=1/1048576,he={triangulate:function(t,e){var r,n,i,a,o,s,u,l,c,h,f,d,g=t.length;if(g<3)return[];if(t=t.slice(0),e)for(r=g;r--;)t[r]=t[r][e];for(i=new Array(g),r=g;r--;)i[r]=r;for(i.sort(function(e,r){var n=t[r][0]-t[e][0];return 0!==n?n:e-r}),a=m(t),t.push(a[0],a[1],a[2]),o=[p(t,g+0,g+1,g+2)],s=[],u=[],r=i.length;r--;u.length=0){for(d=i[r],n=o.length;n--;)l=t[d][0]-o[n].x,l>0&&l*l>o[n].r?(s.push(o[n]),o.splice(n,1)):(c=t[d][1]-o[n].y,l*l+c*c-o[n].r>ce||(u.push(o[n].i,o[n].j,o[n].j,o[n].k,o[n].k,o[n].i),o.splice(n,1)));for(_(u),n=u.length;n;)f=u[--n],h=u[--n],o.push(p(t,h,f,d))}for(r=o.length;r--;)s.push(o[r]);for(o.length=0,r=s.length;r--;)s[r].it[0][0]&&e[0]>t[1][0]&&e[0]>t[2][0]||e[1]t[0][1]&&e[1]>t[1][1]&&e[1]>t[2][1])return null;var r=t[1][0]-t[0][0],n=t[2][0]-t[0][0],i=t[1][1]-t[0][1],a=t[2][1]-t[0][1],o=r*a-n*i;if(0===o)return null;var s=(a*(e[0]-t[0][0])-n*(e[1]-t[0][1]))/o,u=(r*(e[1]-t[0][1])-i*(e[0]-t[0][0]))/o;return s<0||u<0||s+u>1?null:[s,u]}},fe=("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self,function(t,e){return e={exports:{}},t(e,e.exports),e.exports}(function(t,e){!function(t){var r={};r.exports=e,function(t){if(!e)var e=1e-6;if(!r)var r="undefined"!=typeof Float32Array?Float32Array:Array;if(!n)var n=Math.random;var i={};i.setMatrixArrayType=function(t){r=t},void 0!==t&&(t.glMatrix=i);var a=Math.PI/180;i.toRadian=function(t){return t*a};var o={};o.create=function(){var t=new r(2);return t[0]=0,t[1]=0,t},o.clone=function(t){var e=new r(2);return e[0]=t[0],e[1]=t[1],e},o.fromValues=function(t,e){var n=new r(2);return n[0]=t,n[1]=e,n},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t},o.set=function(t,e,r){return t[0]=e,t[1]=r,t},o.add=function(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t},o.subtract=function(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t},o.sub=o.subtract,o.multiply=function(t,e,r){ -return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t},o.mul=o.multiply,o.divide=function(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t},o.div=o.divide,o.min=function(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t},o.max=function(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t},o.scale=function(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t},o.scaleAndAdd=function(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t},o.distance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1];return Math.sqrt(r*r+n*n)},o.dist=o.distance,o.squaredDistance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1];return r*r+n*n},o.sqrDist=o.squaredDistance,o.length=function(t){var e=t[0],r=t[1];return Math.sqrt(e*e+r*r)},o.len=o.length,o.squaredLength=function(t){var e=t[0],r=t[1];return e*e+r*r},o.sqrLen=o.squaredLength,o.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t},o.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t},o.normalize=function(t,e){var r=e[0],n=e[1],i=r*r+n*n;return i>0&&(i=1/Math.sqrt(i),t[0]=e[0]*i,t[1]=e[1]*i),t},o.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]},o.cross=function(t,e,r){var n=e[0]*r[1]-e[1]*r[0];return t[0]=t[1]=0,t[2]=n,t},o.lerp=function(t,e,r,n){var i=e[0],a=e[1];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t},o.random=function(t,e){e=e||1;var r=2*n()*Math.PI;return t[0]=Math.cos(r)*e,t[1]=Math.sin(r)*e,t},o.transformMat2=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[2]*i,t[1]=r[1]*n+r[3]*i,t},o.transformMat2d=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[2]*i+r[4],t[1]=r[1]*n+r[3]*i+r[5],t},o.transformMat3=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[3]*i+r[6],t[1]=r[1]*n+r[4]*i+r[7],t},o.transformMat4=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[4]*i+r[12],t[1]=r[1]*n+r[5]*i+r[13],t},o.forEach=function(){var t=o.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=2),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s0&&(a=1/Math.sqrt(a),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a),t},s.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]},s.cross=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2];return t[0]=i*u-a*s,t[1]=a*o-n*u,t[2]=n*s-i*o,t},s.lerp=function(t,e,r,n){var i=e[0],a=e[1],o=e[2];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t},s.random=function(t,e){e=e||1;var r=2*n()*Math.PI,i=2*n()-1,a=Math.sqrt(1-i*i)*e;return t[0]=Math.cos(r)*a,t[1]=Math.sin(r)*a,t[2]=i*e,t},s.transformMat4=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[3]*n+r[7]*i+r[11]*a+r[15];return o=o||1,t[0]=(r[0]*n+r[4]*i+r[8]*a+r[12])/o,t[1]=(r[1]*n+r[5]*i+r[9]*a+r[13])/o,t[2]=(r[2]*n+r[6]*i+r[10]*a+r[14])/o,t},s.transformMat3=function(t,e,r){var n=e[0],i=e[1],a=e[2];return t[0]=n*r[0]+i*r[3]+a*r[6],t[1]=n*r[1]+i*r[4]+a*r[7],t[2]=n*r[2]+i*r[5]+a*r[8],t},s.transformQuat=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2],l=r[3],c=l*n+s*a-u*i,h=l*i+u*n-o*a,f=l*a+o*i-s*n,d=-o*n-s*i-u*a;return t[0]=c*l+d*-o+h*-u-f*-s,t[1]=h*l+d*-s+f*-o-c*-u,t[2]=f*l+d*-u+c*-s-h*-o,t},s.rotateX=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0],a[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),a[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.rotateY=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),a[1]=i[1],a[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.rotateZ=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),a[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),a[2]=i[2],t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.forEach=function(){var t=s.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=3),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s1?0:Math.acos(i)},s.str=function(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"},void 0!==t&&(t.vec3=s);var u={};u.create=function(){var t=new r(4);return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t},u.clone=function(t){var e=new r(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e},u.fromValues=function(t,e,n,i){var a=new r(4);return a[0]=t,a[1]=e,a[2]=n,a[3]=i,a},u.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t},u.set=function(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t},u.add=function(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t},u.subtract=function(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t},u.sub=u.subtract,u.multiply=function(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t[3]=e[3]*r[3],t},u.mul=u.multiply,u.divide=function(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t[3]=e[3]/r[3],t},u.div=u.divide,u.min=function(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t[3]=Math.min(e[3],r[3]),t},u.max=function(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t[3]=Math.max(e[3],r[3]),t},u.scale=function(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t},u.scaleAndAdd=function(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t},u.distance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+a*a)},u.dist=u.distance,u.squaredDistance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return r*r+n*n+i*i+a*a},u.sqrDist=u.squaredDistance,u.length=function(t){var e=t[0],r=t[1],n=t[2],i=t[3];return Math.sqrt(e*e+r*r+n*n+i*i)},u.len=u.length,u.squaredLength=function(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i},u.sqrLen=u.squaredLength,u.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t},u.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t[3]=1/e[3],t},u.normalize=function(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a;return o>0&&(o=1/Math.sqrt(o),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o,t[3]=e[3]*o),t},u.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]},u.lerp=function(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t[3]=s+n*(r[3]-s),t},u.random=function(t,e){return e=e||1,t[0]=n(),t[1]=n(),t[2]=n(),t[3]=n(),u.normalize(t,t),u.scale(t,t,e),t},u.transformMat4=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*a+r[12]*o,t[1]=r[1]*n+r[5]*i+r[9]*a+r[13]*o,t[2]=r[2]*n+r[6]*i+r[10]*a+r[14]*o,t[3]=r[3]*n+r[7]*i+r[11]*a+r[15]*o,t},u.transformQuat=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2],l=r[3],c=l*n+s*a-u*i,h=l*i+u*n-o*a,f=l*a+o*i-s*n,d=-o*n-s*i-u*a;return t[0]=c*l+d*-o+h*-u-f*-s,t[1]=h*l+d*-s+f*-o-c*-u,t[2]=f*l+d*-u+c*-s-h*-o,t},u.forEach=function(){var t=u.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=4),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(s.cross(t,i,a),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+o,d.normalize(n,n))}}(),d.setAxes=function(){var t=h.create();return function(e,r,n,i){return t[0]=n[0],t[3]=n[1],t[6]=n[2],t[1]=i[0],t[4]=i[1],t[7]=i[2],t[2]=-r[0],t[5]=-r[1],t[8]=-r[2],d.normalize(e,d.fromMat3(e,t))}}(),d.clone=u.clone,d.fromValues=u.fromValues,d.copy=u.copy,d.set=u.set,d.identity=function(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t},d.setAxisAngle=function(t,e,r){r*=.5;var n=Math.sin(r);return t[0]=n*e[0],t[1]=n*e[1],t[2]=n*e[2],t[3]=Math.cos(r),t},d.add=u.add,d.multiply=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=r[0],u=r[1],l=r[2],c=r[3];return t[0]=n*c+o*s+i*l-a*u,t[1]=i*c+o*u+a*s-n*l,t[2]=a*c+o*l+n*u-i*s,t[3]=o*c-n*s-i*u-a*l,t},d.mul=d.multiply,d.scale=u.scale,d.rotateX=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u+o*s,t[1]=i*u+a*s,t[2]=a*u-i*s,t[3]=o*u-n*s,t},d.rotateY=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u-a*s,t[1]=i*u+o*s,t[2]=a*u+n*s,t[3]=o*u-i*s,t},d.rotateZ=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u+i*s,t[1]=i*u-n*s,t[2]=a*u+o*s,t[3]=o*u-a*s,t},d.calculateW=function(t,e){var r=e[0],n=e[1],i=e[2];return t[0]=r,t[1]=n,t[2]=i,t[3]=Math.sqrt(Math.abs(1-r*r-n*n-i*i)),t},d.dot=u.dot,d.lerp=u.lerp,d.slerp=function(t,e,r,n){var i,a,o,s,u,l=e[0],c=e[1],h=e[2],f=e[3],d=r[0],m=r[1],p=r[2],_=r[3];return a=l*d+c*m+h*p+f*_,a<0&&(a=-a,d=-d,m=-m,p=-p,_=-_),1-a>1e-6?(i=Math.acos(a),o=Math.sin(i),s=Math.sin((1-n)*i)/o,u=Math.sin(n*i)/o):(s=1-n,u=n),t[0]=s*l+u*d,t[1]=s*c+u*m,t[2]=s*h+u*p,t[3]=s*f+u*_,t},d.invert=function(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a,s=o?1/o:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=a*s,t},d.conjugate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t},d.length=u.length,d.len=d.length,d.squaredLength=u.squaredLength,d.sqrLen=d.squaredLength,d.normalize=u.normalize,d.fromMat3=function(t,e){var r,n=e[0]+e[4]+e[8];if(n>0)r=Math.sqrt(n+1),t[3]=.5*r,r=.5/r,t[0]=(e[5]-e[7])*r,t[1]=(e[6]-e[2])*r,t[2]=(e[1]-e[3])*r;else{var i=0;e[4]>e[0]&&(i=1),e[8]>e[3*i+i]&&(i=2);var a=(i+1)%3,o=(i+2)%3;r=Math.sqrt(e[3*i+i]-e[3*a+a]-e[3*o+o]+1),t[i]=.5*r,r=.5/r,t[3]=(e[3*a+o]-e[3*o+a])*r,t[a]=(e[3*a+i]+e[3*i+a])*r,t[o]=(e[3*o+i]+e[3*i+o])*r}return t},d.str=function(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"},void 0!==t&&(t.quat=d)}(r.exports)}()})),de=fe.vec2,me=function(t,e){t=t||0,e=e||0,this.array=de.fromValues(t,e),this._dirty=!0};if(me.prototype={constructor:me,add:function(t){return de.add(this.array,this.array,t.array),this._dirty=!0,this},set:function(t,e){return this.array[0]=t,this.array[1]=e,this._dirty=!0,this},setArray:function(t){return this.array[0]=t[0],this.array[1]=t[1],this._dirty=!0,this},clone:function(){return new me(this.x,this.y)},copy:function(t){return de.copy(this.array,t.array),this._dirty=!0,this},cross:function(t,e){return de.cross(t.array,this.array,e.array),t._dirty=!0,this},dist:function(t){return de.dist(this.array,t.array)},distance:function(t){return de.distance(this.array,t.array)},div:function(t){return de.div(this.array,this.array,t.array),this._dirty=!0,this},divide:function(t){return de.divide(this.array,this.array,t.array),this._dirty=!0,this},dot:function(t){return de.dot(this.array,t.array)},len:function(){return de.len(this.array)},length:function(){return de.length(this.array)},lerp:function(t,e,r){return de.lerp(this.array,t.array,e.array,r),this._dirty=!0,this},min:function(t){return de.min(this.array,this.array,t.array),this._dirty=!0,this},max:function(t){return de.max(this.array,this.array,t.array),this._dirty=!0,this},mul:function(t){return de.mul(this.array,this.array,t.array),this._dirty=!0,this},multiply:function(t){return de.multiply(this.array,this.array,t.array),this._dirty=!0,this},negate:function(){return de.negate(this.array,this.array),this._dirty=!0,this},normalize:function(){return de.normalize(this.array,this.array),this._dirty=!0,this},random:function(t){return de.random(this.array,t),this._dirty=!0,this},scale:function(t){return de.scale(this.array,this.array,t),this._dirty=!0,this},scaleAndAdd:function(t,e){return de.scaleAndAdd(this.array,this.array,t.array,e),this._dirty=!0,this},sqrDist:function(t){return de.sqrDist(this.array,t.array)},squaredDistance:function(t){return de.squaredDistance(this.array,t.array)},sqrLen:function(){return de.sqrLen(this.array)},squaredLength:function(){return de.squaredLength(this.array)},sub:function(t){return de.sub(this.array,this.array,t.array),this._dirty=!0,this},subtract:function(t){return de.subtract(this.array,this.array,t.array),this._dirty=!0,this},transformMat2:function(t){return de.transformMat2(this.array,this.array,t.array),this._dirty=!0,this},transformMat2d:function(t){return de.transformMat2d(this.array,this.array,t.array),this._dirty=!0,this},transformMat3:function(t){return de.transformMat3(this.array,this.array,t.array),this._dirty=!0,this},transformMat4:function(t){return de.transformMat4(this.array,this.array,t.array),this._dirty=!0,this},toString:function(){return"["+Array.prototype.join.call(this.array,",")+"]"},toArray:function(){return Array.prototype.slice.call(this.array)}},Object.defineProperty){var pe=me.prototype;Object.defineProperty(pe,"x",{get:function(){return this.array[0]},set:function(t){this.array[0]=t,this._dirty=!0}}),Object.defineProperty(pe,"y",{get:function(){return this.array[1]},set:function(t){this.array[1]=t,this._dirty=!0}})}me.add=function(t,e,r){return de.add(t.array,e.array,r.array),t._dirty=!0,t},me.set=function(t,e,r){return de.set(t.array,e,r),t._dirty=!0,t},me.copy=function(t,e){return de.copy(t.array,e.array),t._dirty=!0,t},me.cross=function(t,e,r){return de.cross(t.array,e.array,r.array),t._dirty=!0,t},me.dist=function(t,e){return de.distance(t.array,e.array)},me.distance=me.dist,me.div=function(t,e,r){return de.divide(t.array,e.array,r.array),t._dirty=!0,t},me.divide=me.div,me.dot=function(t,e){return de.dot(t.array,e.array)},me.len=function(t){return de.length(t.array)},me.lerp=function(t,e,r,n){return de.lerp(t.array,e.array,r.array,n),t._dirty=!0,t},me.min=function(t,e,r){return de.min(t.array,e.array,r.array),t._dirty=!0,t},me.max=function(t,e,r){return de.max(t.array,e.array,r.array),t._dirty=!0,t},me.mul=function(t,e,r){return de.multiply(t.array,e.array,r.array),t._dirty=!0,t},me.multiply=me.mul,me.negate=function(t,e){return de.negate(t.array,e.array),t._dirty=!0,t},me.normalize=function(t,e){return de.normalize(t.array,e.array),t._dirty=!0,t},me.random=function(t,e){return de.random(t.array,e),t._dirty=!0,t},me.scale=function(t,e,r){return de.scale(t.array,e.array,r),t._dirty=!0,t},me.scaleAndAdd=function(t,e,r,n){return de.scaleAndAdd(t.array,e.array,r.array,n),t._dirty=!0,t},me.sqrDist=function(t,e){return de.sqrDist(t.array,e.array)},me.squaredDistance=me.sqrDist,me.sqrLen=function(t){return de.sqrLen(t.array)},me.squaredLength=me.sqrLen,me.sub=function(t,e,r){return de.subtract(t.array,e.array,r.array),t._dirty=!0,t -},me.subtract=me.sub,me.transformMat2=function(t,e,r){return de.transformMat2(t.array,e.array,r.array),t._dirty=!0,t},me.transformMat2d=function(t,e,r){return de.transformMat2d(t.array,e.array,r.array),t._dirty=!0,t},me.transformMat3=function(t,e,r){return de.transformMat3(t.array,e.array,r.array),t._dirty=!0,t},me.transformMat4=function(t,e,r){return de.transformMat4(t.array,e.array,r.array),t._dirty=!0,t};var _e=function(t){t=t||{},oe.call(this,t),this.output=t.output||null,this.inputs=t.inputs||[],this.position=new me,this._cacheTriangle=null,this._triangles=[],this._updateTriangles()};_e.prototype=new oe,_e.prototype.constructor=_e,_e.prototype.addInput=function(t,e,r){var n={position:t,clip:e,offset:r||0};return this.inputs.push(n),this.life=Math.max(e.life,this.life),this._updateTriangles(),n},_e.prototype._updateTriangles=function(){var t=this.inputs.map(function(t){return t.position});this._triangles=he.triangulate(t,"array")},_e.prototype.step=function(t,e,r){var n=oe.prototype.step.call(this,t);return"finish"!==n&&this.setTime(this.getElapsedTime()),r||"paused"===n||this.fire("frame"),n},_e.prototype.setTime=function(t){var e=this._findTriangle(this.position);if(e){var r=e[1],n=e[2],i=e[0],a=this.inputs[i.indices[0]],o=this.inputs[i.indices[1]],s=this.inputs[i.indices[2]],u=a.clip,l=o.clip,c=s.clip;u.setTime((t+a.offset)%u.life),l.setTime((t+o.offset)%l.life),c.setTime((t+s.offset)%c.life);var h=u.output instanceof oe?u.output:u,f=l.output instanceof oe?l.output:l,d=c.output instanceof oe?c.output:c;this.output.blend2D(h,f,d,r,n)}},_e.prototype.clone=function(t){var e=oe.prototype.clone.call(this);e.output=this.output.clone();for(var r=0;r=t.time)return this.keyFrames.splice(e,0,t),e}this.life=t.time,this.keyFrames.push(t)},ye.prototype.addKeyFrames=function(t){for(var e=0;ei[i.length-1].time)){if(t=a-1?a-1:this._cacheKey+1,s=o;s>=0;s--)if(i[s].time<=t&&i[s][e])r=i[s],this._cacheKey=s,this._cacheTime=t;else if(i[s][e]){n=i[s];break}}else for(var s=this._cacheKey;s=e.time[r-1])t=e.time[r-1],n=r-2;else if(t=0;a--)if(e.time[a-1]<=t&&e.time[a]>t){n=a-1;break}}else for(var a=this._cacheKey;at){n=a;break}if(n>-1){this._cacheKey=n,this._cacheTime=t;var o=n,s=n+1,u=e.time[o],l=e.time[s],c=l-u,h=0===c?0:(t-u)/c;e.rotation&&y(this.rotation,e.rotation,e.rotation,h,4*o,4*s),e.position&&v(this.position,e.position,e.position,h,3*o,3*s),e.scale&&v(this.scale,e.scale,e.scale,h,3*o,3*s)}n==r-2&&(this._cacheKey=0,this._cacheTime=0),this.updateTarget()}},Ee.prototype.updateTarget=function(){var t=this.channels;this.target&&(t.position&&this.target.position.setArray(this.position),t.rotation&&this.target.rotation.setArray(this.rotation),t.scale&&this.target.scale.setArray(this.scale))},Ee.prototype.getMaxTime=function(){return this.channels.time[this.channels.time.length-1]},Ee.prototype.getSubTrack=function(t,e){var r=new Ee({name:this.name}),n=this.channels.time[0];t=Math.min(Math.max(t,n),this.life),e=Math.min(Math.max(e,n),this.life);var i=this._findRange(t),a=this._findRange(e),o=a[0]-i[0]+1;0===i[1]&&0===a[1]&&(o-=1),this.channels.rotation&&(r.channels.rotation=new Float32Array(4*o)),this.channels.position&&(r.channels.position=new Float32Array(3*o)),this.channels.scale&&(r.channels.scale=new Float32Array(3*o)),this.channels.time&&(r.channels.time=new Float32Array(o)),this.setTime(t);for(var s=0;s<3;s++)r.channels.rotation[s]=this.rotation[s],r.channels.position[s]=this.position[s],r.channels.scale[s]=this.scale[s];r.channels.time[0]=0,r.channels.rotation[3]=this.rotation[3];for(var s=1;st&&(n=i);var a=0;if(n>=0)var o=e.time[n],s=e.time[n+1],a=(t-o)/(s-o);return[n,a]},Ee.prototype.blend1D=ye.prototype.blend1D,Ee.prototype.blend2D=ye.prototype.blend2D,Ee.prototype.additiveBlend=ye.prototype.additiveBlend,Ee.prototype.subtractiveBlend=ye.prototype.subtractiveBlend,Ee.prototype.clone=function(){var t=Ee.prototype.clone.call(this);return t.channels={time:this.channels.time||null,position:this.channels.position||null,rotation:this.channels.rotation||null,scale:this.channels.scale||null},Te.copy(t.position,this.position),xe.copy(t.rotation,this.rotation),Te.copy(t.scale,this.scale),t.target=this.target,t.updateTarget(),t};var be={extend:x,derive:x},Ae={trigger:function(t){if(this.hasOwnProperty("__handlers__")&&this.__handlers__.hasOwnProperty(t)){var e=this.__handlers__[t],r=e.length,n=-1,i=arguments;switch(i.length){case 1:for(;++n=0&&this._clips.splice(e,1)},removeAnimator:function(t){for(var e=t.getClips(),r=0;r=0&&this.tracks.splice(e,1)},Ie.prototype.getSubClip=function(t,e,r){for(var n=new Ie({name:this.name}),i=0;i0){var e=this.min,r=this.max,n=e.array,i=r.array;Ke(n,t[0]),Ke(i,t[0]);for(var a=1;ai[0]&&(i[0]=o[0]),o[1]>i[1]&&(i[1]=o[1]),o[2]>i[2]&&(i[2]=o[2])}e._dirty=!0,r._dirty=!0}},union:function(t){var e=this.min,r=this.max;return Ye.min(e.array,e.array,t.min.array),Ye.max(r.array,r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},intersection:function(t){var e=this.min,r=this.max;return Ye.max(e.array,e.array,t.min.array),Ye.min(r.array,r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},intersectBoundingBox:function(t){var e=this.min.array,r=this.max.array,n=t.min.array,i=t.max.array;return!(e[0]>i[0]||e[1]>i[1]||e[2]>i[2]||r[0]=i[0]&&r[1]>=i[1]&&r[2]>=i[2]},containPoint:function(t){var e=this.min.array,r=this.max.array,n=t.array;return e[0]<=n[0]&&e[1]<=n[1]&&e[2]<=n[2]&&r[0]>=n[0]&&r[1]>=n[1]&&r[2]>=n[2]},isFinite:function(){var t=this.min.array,e=this.max.array;return isFinite(t[0])&&isFinite(t[1])&&isFinite(t[2])&&isFinite(e[0])&&isFinite(e[1])&&isFinite(e[2])},applyTransform:function(){var t=Ye.create(),e=Ye.create(),r=Ye.create(),n=Ye.create(),i=Ye.create(),a=Ye.create();return function(o){var s=this.min.array,u=this.max.array,l=o.array;return t[0]=l[0]*s[0],t[1]=l[1]*s[0],t[2]=l[2]*s[0],e[0]=l[0]*u[0],e[1]=l[1]*u[0],e[2]=l[2]*u[0],r[0]=l[4]*s[1],r[1]=l[5]*s[1],r[2]=l[6]*s[1],n[0]=l[4]*u[1],n[1]=l[5]*u[1],n[2]=l[6]*u[1],i[0]=l[8]*s[2],i[1]=l[9]*s[2],i[2]=l[10]*s[2],a[0]=l[8]*u[2],a[1]=l[9]*u[2],a[2]=l[10]*u[2],s[0]=Math.min(t[0],e[0])+Math.min(r[0],n[0])+Math.min(i[0],a[0])+l[12],s[1]=Math.min(t[1],e[1])+Math.min(r[1],n[1])+Math.min(i[1],a[1])+l[13],s[2]=Math.min(t[2],e[2])+Math.min(r[2],n[2])+Math.min(i[2],a[2])+l[14],u[0]=Math.max(t[0],e[0])+Math.max(r[0],n[0])+Math.max(i[0],a[0])+l[12], -u[1]=Math.max(t[1],e[1])+Math.max(r[1],n[1])+Math.max(i[1],a[1])+l[13],u[2]=Math.max(t[2],e[2])+Math.max(r[2],n[2])+Math.max(i[2],a[2])+l[14],this.min._dirty=!0,this.max._dirty=!0,this}}(),applyProjection:function(t){var e=this.min.array,r=this.max.array,n=t.array,i=e[0],a=e[1],o=e[2],s=r[0],u=r[1],l=e[2],c=r[0],h=r[1],f=r[2];if(1===n[15])e[0]=n[0]*i+n[12],e[1]=n[5]*a+n[13],r[2]=n[10]*o+n[14],r[0]=n[0]*c+n[12],r[1]=n[5]*h+n[13],e[2]=n[10]*f+n[14];else{var d=-1/o;e[0]=n[0]*i*d,e[1]=n[5]*a*d,r[2]=(n[10]*o+n[14])*d,d=-1/l,r[0]=n[0]*s*d,r[1]=n[5]*u*d,d=-1/f,e[2]=(n[10]*f+n[14])*d}return this.min._dirty=!0,this.max._dirty=!0,this},updateVertices:function(){var t=this.vertices;if(!t){for(var t=[],e=0;e<8;e++)t[e]=Ye.fromValues(0,0,0);this.vertices=t}var r=this.min.array,n=this.max.array;return Ze(t[0],r[0],r[1],r[2]),Ze(t[1],r[0],n[1],r[2]),Ze(t[2],n[0],r[1],r[2]),Ze(t[3],n[0],n[1],r[2]),Ze(t[4],r[0],r[1],n[2]),Ze(t[5],r[0],n[1],n[2]),Ze(t[6],n[0],r[1],n[2]),Ze(t[7],n[0],n[1],n[2]),this},copy:function(t){var e=this.min,r=this.max;return Ke(e.array,t.min.array),Ke(r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},clone:function(){var t=new Je;return t.copy(this),t}};var Qe=fe.mat4,$e=fe.vec3,tr=fe.mat3,er=fe.quat,rr=function(){this._axisX=new Ve,this._axisY=new Ve,this._axisZ=new Ve,this.array=Qe.create(),this._dirty=!0};rr.prototype={constructor:rr,setArray:function(t){for(var e=0;e>e;return t+1},dispose:function(t){var e=this._cache;e.use(t.__uid__);var r=e.get("webgl_texture");r&&t.gl.deleteTexture(r),e.deleteContext(t.__uid__)},isRenderable:function(){},isPowerOfTwo:function(){}});Object.defineProperty(or.prototype,"width",{get:function(){return this._width},set:function(t){this._width=t}}),Object.defineProperty(or.prototype,"height",{get:function(){return this._height},set:function(t){this._height=t}}),or.BYTE=Fe.BYTE,or.UNSIGNED_BYTE=Fe.UNSIGNED_BYTE,or.SHORT=Fe.SHORT,or.UNSIGNED_SHORT=Fe.UNSIGNED_SHORT,or.INT=Fe.INT,or.UNSIGNED_INT=Fe.UNSIGNED_INT,or.FLOAT=Fe.FLOAT,or.HALF_FLOAT=36193,or.UNSIGNED_INT_24_8_WEBGL=34042,or.DEPTH_COMPONENT=Fe.DEPTH_COMPONENT,or.DEPTH_STENCIL=Fe.DEPTH_STENCIL,or.ALPHA=Fe.ALPHA,or.RGB=Fe.RGB,or.RGBA=Fe.RGBA,or.LUMINANCE=Fe.LUMINANCE,or.LUMINANCE_ALPHA=Fe.LUMINANCE_ALPHA,or.SRGB=35904,or.SRGB_ALPHA=35906,or.COMPRESSED_RGB_S3TC_DXT1_EXT=33776,or.COMPRESSED_RGBA_S3TC_DXT1_EXT=33777,or.COMPRESSED_RGBA_S3TC_DXT3_EXT=33778,or.COMPRESSED_RGBA_S3TC_DXT5_EXT=33779,or.NEAREST=Fe.NEAREST,or.LINEAR=Fe.LINEAR,or.NEAREST_MIPMAP_NEAREST=Fe.NEAREST_MIPMAP_NEAREST,or.LINEAR_MIPMAP_NEAREST=Fe.LINEAR_MIPMAP_NEAREST,or.NEAREST_MIPMAP_LINEAR=Fe.NEAREST_MIPMAP_LINEAR,or.LINEAR_MIPMAP_LINEAR=Fe.LINEAR_MIPMAP_LINEAR,or.REPEAT=Fe.REPEAT,or.CLAMP_TO_EDGE=Fe.CLAMP_TO_EDGE,or.MIRRORED_REPEAT=Fe.MIRRORED_REPEAT;var sr=function(){this.head=null,this.tail=null,this._length=0};sr.prototype.insert=function(t){var e=new sr.Entry(t);return this.insertEntry(e),e},sr.prototype.insertAt=function(t,e){if(!(t<0)){for(var r=this.head,n=0;r&&n!=t;)r=r.next,n++;if(r){var i=new sr.Entry(e),a=r.prev;a?(a.next=i,i.prev=a):this.head=i,i.next=r,r.prev=i}else this.insert(e)}},sr.prototype.insertBeforeEntry=function(t,e){var r=new sr.Entry(t),n=e.prev;n?(n.next=r,r.prev=n):this.head=r,r.next=e,e.prev=r,this._length++},sr.prototype.insertEntry=function(t){this.head?(this.tail.next=t,t.prev=this.tail,this.tail=t):this.head=this.tail=t,this._length++},sr.prototype.remove=function(t){var e=t.prev,r=t.next;e?e.next=r:this.head=r,r?r.prev=e:this.tail=e,t.next=t.prev=null,this._length--},sr.prototype.removeAt=function(t){if(!(t<0)){for(var e=this.head,r=0;e&&r!=t;)e=e.next,r++;return e?(this.remove(e),e.value):void 0}},sr.prototype.getHead=function(){if(this.head)return this.head.value},sr.prototype.getTail=function(){if(this.tail)return this.tail.value},sr.prototype.getAt=function(t){if(!(t<0)){for(var e=this.head,r=0;e&&r!=t;)e=e.next,r++;return e.value}},sr.prototype.indexOf=function(t){for(var e=this.head,r=0;e;){if(e.value===t)return r;e=e.next,r++}},sr.prototype.length=function(){return this._length},sr.prototype.isEmpty=function(){return 0===this._length},sr.prototype.forEach=function(t,e){for(var r=this.head,n=0,i=void 0!==e;r;)i?t.call(e,r.value,n):t(r.value,n),r=r.next,n++},sr.prototype.clear=function(){this.tail=this.head=null,this._length=0},sr.Entry=function(t){this.value=t,this.next=null,this.prev=null};var ur=function(t){this._list=new sr,this._map={},this._maxSize=t||10};ur.prototype.setMaxSize=function(t){this._maxSize=t},ur.prototype.put=function(t,e){if(void 0===this._map[t]){var r=this._list.length();if(r>=this._maxSize&&r>0){var n=this._list.head;this._list.remove(n),delete this._map[n.key]}var i=this._list.insert(e);i.key=t,this._map[t]=i}},ur.prototype.get=function(t){var e=this._map[t];if(void 0!==e)return e!==this._list.tail&&(this._list.remove(e),this._list.insertEntry(e)),e.value},ur.prototype.remove=function(t){var e=this._map[t];void 0!==e&&(delete this._map[t],this._list.remove(e))},ur.prototype.clear=function(){this._list.clear(),this._map={}};var lr={},cr={transparent:[0,0,0,0],aliceblue:[240,248,255,1],antiquewhite:[250,235,215,1],aqua:[0,255,255,1],aquamarine:[127,255,212,1],azure:[240,255,255,1],beige:[245,245,220,1],bisque:[255,228,196,1],black:[0,0,0,1],blanchedalmond:[255,235,205,1],blue:[0,0,255,1],blueviolet:[138,43,226,1],brown:[165,42,42,1],burlywood:[222,184,135,1],cadetblue:[95,158,160,1],chartreuse:[127,255,0,1],chocolate:[210,105,30,1],coral:[255,127,80,1],cornflowerblue:[100,149,237,1],cornsilk:[255,248,220,1],crimson:[220,20,60,1],cyan:[0,255,255,1],darkblue:[0,0,139,1],darkcyan:[0,139,139,1],darkgoldenrod:[184,134,11,1],darkgray:[169,169,169,1],darkgreen:[0,100,0,1],darkgrey:[169,169,169,1],darkkhaki:[189,183,107,1],darkmagenta:[139,0,139,1],darkolivegreen:[85,107,47,1],darkorange:[255,140,0,1],darkorchid:[153,50,204,1],darkred:[139,0,0,1],darksalmon:[233,150,122,1],darkseagreen:[143,188,143,1],darkslateblue:[72,61,139,1],darkslategray:[47,79,79,1],darkslategrey:[47,79,79,1],darkturquoise:[0,206,209,1],darkviolet:[148,0,211,1],deeppink:[255,20,147,1],deepskyblue:[0,191,255,1],dimgray:[105,105,105,1],dimgrey:[105,105,105,1],dodgerblue:[30,144,255,1],firebrick:[178,34,34,1],floralwhite:[255,250,240,1],forestgreen:[34,139,34,1],fuchsia:[255,0,255,1],gainsboro:[220,220,220,1],ghostwhite:[248,248,255,1],gold:[255,215,0,1],goldenrod:[218,165,32,1],gray:[128,128,128,1],green:[0,128,0,1],greenyellow:[173,255,47,1],grey:[128,128,128,1],honeydew:[240,255,240,1],hotpink:[255,105,180,1],indianred:[205,92,92,1],indigo:[75,0,130,1],ivory:[255,255,240,1],khaki:[240,230,140,1],lavender:[230,230,250,1],lavenderblush:[255,240,245,1],lawngreen:[124,252,0,1],lemonchiffon:[255,250,205,1],lightblue:[173,216,230,1],lightcoral:[240,128,128,1],lightcyan:[224,255,255,1],lightgoldenrodyellow:[250,250,210,1],lightgray:[211,211,211,1],lightgreen:[144,238,144,1],lightgrey:[211,211,211,1],lightpink:[255,182,193,1],lightsalmon:[255,160,122,1],lightseagreen:[32,178,170,1],lightskyblue:[135,206,250,1],lightslategray:[119,136,153,1],lightslategrey:[119,136,153,1],lightsteelblue:[176,196,222,1],lightyellow:[255,255,224,1],lime:[0,255,0,1],limegreen:[50,205,50,1],linen:[250,240,230,1],magenta:[255,0,255,1],maroon:[128,0,0,1],mediumaquamarine:[102,205,170,1],mediumblue:[0,0,205,1],mediumorchid:[186,85,211,1],mediumpurple:[147,112,219,1],mediumseagreen:[60,179,113,1],mediumslateblue:[123,104,238,1],mediumspringgreen:[0,250,154,1],mediumturquoise:[72,209,204,1],mediumvioletred:[199,21,133,1],midnightblue:[25,25,112,1],mintcream:[245,255,250,1],mistyrose:[255,228,225,1],moccasin:[255,228,181,1],navajowhite:[255,222,173,1],navy:[0,0,128,1],oldlace:[253,245,230,1],olive:[128,128,0,1],olivedrab:[107,142,35,1],orange:[255,165,0,1],orangered:[255,69,0,1],orchid:[218,112,214,1],palegoldenrod:[238,232,170,1],palegreen:[152,251,152,1],paleturquoise:[175,238,238,1],palevioletred:[219,112,147,1],papayawhip:[255,239,213,1],peachpuff:[255,218,185,1],peru:[205,133,63,1],pink:[255,192,203,1],plum:[221,160,221,1],powderblue:[176,224,230,1],purple:[128,0,128,1],red:[255,0,0,1],rosybrown:[188,143,143,1],royalblue:[65,105,225,1],saddlebrown:[139,69,19,1],salmon:[250,128,114,1],sandybrown:[244,164,96,1],seagreen:[46,139,87,1],seashell:[255,245,238,1],sienna:[160,82,45,1],silver:[192,192,192,1],skyblue:[135,206,235,1],slateblue:[106,90,205,1],slategray:[112,128,144,1],slategrey:[112,128,144,1],snow:[255,250,250,1],springgreen:[0,255,127,1],steelblue:[70,130,180,1],tan:[210,180,140,1],teal:[0,128,128,1],thistle:[216,191,216,1],tomato:[255,99,71,1],turquoise:[64,224,208,1],violet:[238,130,238,1],wheat:[245,222,179,1],white:[255,255,255,1],whitesmoke:[245,245,245,1],yellow:[255,255,0,1],yellowgreen:[154,205,50,1]},hr=new ur(20),fr=null;lr.parse=function(t,e){if(t){e=e||[];var r=hr.get(t);if(r)return I(e,r);t+="";var n=t.replace(/ /g,"").toLowerCase();if(n in cr)return I(e,cr[n]),O(t,e),e;if("#"!==n.charAt(0)){var i=n.indexOf("("),a=n.indexOf(")");if(-1!==i&&a+1===n.length){var o=n.substr(0,i),s=n.substr(i+1,a-(i+1)).split(","),u=1;switch(o){case"rgba":if(4!==s.length)return void D(e,0,0,0,1);u=R(s.pop());case"rgb":return 3!==s.length?void D(e,0,0,0,1):(D(e,M(s[0]),M(s[1]),M(s[2]),u),O(t,e),e);case"hsla":return 4!==s.length?void D(e,0,0,0,1):(s[3]=R(s[3]),B(s,e),O(t,e),e);case"hsl":return 3!==s.length?void D(e,0,0,0,1):(B(s,e),O(t,e),e);default:return}}D(e,0,0,0,1)}else{if(4===n.length){var l=parseInt(n.substr(1),16);return l>=0&&l<=4095?(D(e,(3840&l)>>4|(3840&l)>>8,240&l|(240&l)>>4,15&l|(15&l)<<4,1),O(t,e),e):void D(e,0,0,0,1)}if(7===n.length){var l=parseInt(n.substr(1),16);return l>=0&&l<=16777215?(D(e,(16711680&l)>>16,(65280&l)>>8,255&l,1),O(t,e),e):void D(e,0,0,0,1)}}}},lr.parseToFloat=function(t,e){if(e=lr.parse(t,e))return e[0]/=255,e[1]/=255,e[2]/=255,e},lr.lift=function(t,e){var r=lr.parse(t);if(r){for(var n=0;n<3;n++)r[n]=e<0?r[n]*(1-e)|0:(255-r[n])*e+r[n]|0;return lr.stringify(r,4===r.length?"rgba":"rgb")}},lr.toHex=function(t){var e=lr.parse(t);if(e)return((1<<24)+(e[0]<<16)+(e[1]<<8)+ +e[2]).toString(16).slice(1)},lr.fastLerp=function(t,e,r){if(e&&e.length&&t>=0&&t<=1){r=r||[];var n=t*(e.length-1),i=Math.floor(n),a=Math.ceil(n),o=e[i],s=e[a],u=n-i;return r[0]=w(P(o[0],s[0],u)),r[1]=w(P(o[1],s[1],u)),r[2]=w(P(o[2],s[2],u)),r[3]=N(P(o[3],s[3],u)),r}},lr.fastMapToColor=lr.fastLerp,lr.lerp=function(t,e,r){if(e&&e.length&&t>=0&&t<=1){var n=t*(e.length-1),i=Math.floor(n),a=Math.ceil(n),o=lr.parse(e[i]),s=lr.parse(e[a]),u=n-i,l=lr.stringify([w(P(o[0],s[0],u)),w(P(o[1],s[1],u)),w(P(o[2],s[2],u)),N(P(o[3],s[3],u))],"rgba");return r?{color:l,leftIndex:i,rightIndex:a,value:n}:l}},lr.mapToColor=lr.lerp,lr.modifyHSL=function(t,e,r,n){if(t=lr.parse(t))return t=F(t),null!=e&&(t[0]=C(e)),null!=r&&(t[1]=R(r)),null!=n&&(t[2]=R(n)),lr.stringify(B(t),"rgba")},lr.modifyAlpha=function(t,e){if((t=lr.parse(t))&&null!=e)return t[3]=N(e),lr.stringify(t,"rgba")},lr.stringify=function(t,e){if(t&&t.length){var r=t[0]+","+t[1]+","+t[2];return"rgba"!==e&&"hsva"!==e&&"hsla"!==e||(r+=","+t[3]),e+"("+r+")"}};var dr=lr.parseToFloat,mr={},pr=Me.extend(function(){return{name:"",depthTest:!0,depthMask:!0,transparent:!1,blend:null,autoUpdateTextureStatus:!0,uniforms:{},vertexDefines:{},fragmentDefines:{},_textureStatus:{},_enabledUniforms:null}},function(){this.name||(this.name="MATERIAL_"+this.__uid__),this.shader&&this.attachShader(this.shader,!0)},{precision:"highp",bind:function(t,e,r,n){for(var i=t.gl,a=e.currentTextureSlot(),o=0;o=0},getEnabledUniforms:function(){return this._enabledUniforms},getTextureUniforms:function(){return this._textureUniforms},set:function(t,e){if("object"==typeof t)for(var r in t){var n=t[r];this.setUniform(r,n)}else this.setUniform(t,e)},get:function(t){var e=this.uniforms[t];if(e)return e.value},attachShader:function(t,e){var r=this.uniforms;this.uniforms=t.createUniforms(),this.shader=t;var n=this.uniforms;this._enabledUniforms=Object.keys(n),this._enabledUniforms.sort(),this._textureUniforms=this._enabledUniforms.filter(function(t){var e=this.uniforms[t].type;return"t"===e||"tv"===e},this);var i=this.vertexDefines,a=this.fragmentDefines;if(this.vertexDefines=Ne.clone(t.vertexDefines),this.fragmentDefines=Ne.clone(t.fragmentDefines),e){for(var o in r)n[o]&&(n[o].value=r[o].value);Ne.defaults(this.vertexDefines,i),Ne.defaults(this.fragmentDefines,a)}var s={};for(var u in t.textures)s[u]={shaderType:t.textures[u].shaderType,type:t.textures[u].type,enabled:!(!e||!this._textureStatus[u])&&this._textureStatus[u].enabled};this._textureStatus=s,this._programKey=""},clone:function(){var t=new this.constructor({name:this.name,shader:this.shader});for(var e in this.uniforms)t.uniforms[e].value=this.uniforms[e].value;return t.depthTest=this.depthTest,t.depthMask=this.depthMask,t.transparent=this.transparent,t.blend=this.blend,t.vertexDefines=Ne.clone(this.vertexDefines),t.fragmentDefines=Ne.clone(this.fragmentDefines),t.enableTexture(this.getEnabledTextures()),t.precision=this.precision,t},define:function(t,e,r){var n=this.vertexDefines,i=this.fragmentDefines;"vertex"!==t&&"fragment"!==t&&"both"!==t&&arguments.length<3&&(r=e,e=t,t="both"),r=null!=r?r:null,"vertex"!==t&&"both"!==t||n[e]!==r&&(n[e]=r,this._programKey=""),"fragment"!==t&&"both"!==t||i[e]!==r&&(i[e]=r,"both"!==t&&(this._programKey=""))},undefine:function(t,e){"vertex"!==t&&"fragment"!==t&&"both"!==t&&arguments.length<2&&(e=t,t="both"),"vertex"!==t&&"both"!==t||this.isDefined("vertex",e)&&(delete this.vertexDefines[e],this._programKey=""),"fragment"!==t&&"both"!==t||this.isDefined("fragment",e)&&(delete this.fragmentDefines[e],"both"!==t&&(this._programKey=""))},isDefined:function(t,e){switch(t){case"vertex":return void 0!==this.vertexDefines[e];case"fragment":return void 0!==this.fragmentDefines[e]}},getDefine:function(t,e){switch(t){case"vertex":return this.vertexDefines[e];case"fragment":return this.fragmentDefines[e]}},enableTexture:function(t){if(Array.isArray(t))for(var e=0;e=0)r.attributeSemantics[u]={symbol:a,type:c},h=!1;else if(Mr.indexOf(u)>=0){var f=!1,d=u;u.match(/TRANSPOSE$/)&&(f=!0,d=u.slice(0,-9)),r.matrixSemantics[u]={symbol:a,type:c,isTranspose:f,semanticNoTranspose:d},h=!1}else if(Nr.indexOf(u)>=0)r.uniformSemantics[u]={symbol:a,type:c},h=!1;else if("unconfigurable"===u)h=!1;else{if(!(l=r._parseDefaultValue(i,u)))throw new Error('Unkown semantic "'+u+'"');u=""}h&&(e[a]={type:c,value:o?wr.array:l||wr[i],semantic:u||null})}return["uniform",i,a,o].join(" ")+";\n"}}var e={},r=this,n="vertex";this._uniformList=[],this._vertexCode=this._vertexCode.replace(Er,t),n="fragment",this._fragmentCode=this._fragmentCode.replace(Er,t),r.matrixSemanticKeys=Object.keys(this.matrixSemantics),this.uniformTemplates=e},_parseDefaultValue:function(t,e){var r=/\[\s*(.*)\s*\]/;{if("vec2"!==t&&"vec3"!==t&&"vec4"!==t)return"bool"===t?function(){return"true"===e.toLowerCase()}:"float"===t?function(){return parseFloat(e)}:"int"===t?function(){return parseInt(e)}:void 0;var n=r.exec(e)[1];if(n){var i=n.split(/\s*,\s*/);return function(){return new He.Float32Array(i)}}}},_parseAttributes:function(){function t(t,n,i,a,o){if(n&&i){var s=1;switch(n){case"vec4":s=4;break;case"vec3":s=3;break;case"vec2":s=2;break;case"float":s=1}if(e[i]={type:"float",size:s,semantic:o||null},o){if(Cr.indexOf(o)<0)throw new Error('Unkown semantic "'+o+'"');r.attributeSemantics[o]={symbol:i,type:n}}}return["attribute",n,i].join(" ")+";\n"}var e={},r=this;this._vertexCode=this._vertexCode.replace(br,t),this.attributes=e},_parseDefines:function(){function t(t,n,i){var a="vertex"===r?e.vertexDefines:e.fragmentDefines -;return a[n]||(a[n]="false"!=i&&("true"==i||(i?isNaN(parseFloat(i))?i.trim():parseFloat(i):null))),""}var e=this,r="vertex";this._vertexCode=this._vertexCode.replace(Ar,t),r="fragment",this._fragmentCode=this._fragmentCode.replace(Ar,t)},clone:function(){var t=Lr[this._shaderID];return new Y(t.vertex,t.fragment)}},Object.defineProperty&&(Object.defineProperty(Y.prototype,"shaderID",{get:function(){return this._shaderID}}),Object.defineProperty(Y.prototype,"vertex",{get:function(){return this._vertexCode}}),Object.defineProperty(Y.prototype,"fragment",{get:function(){return this._fragmentCode}}),Object.defineProperty(Y.prototype,"uniforms",{get:function(){return this._uniformList}}));var Pr=/(@import)\s*([0-9a-zA-Z_\-\.]*)/g;Y.parseImport=function(t){return t=t.replace(Pr,function(t,e,r){var t=Y.source(r);return t?Y.parseImport(t):(console.error('Shader chunk "'+r+'" not existed in library'),"")})};var Dr=/(@export)\s*([0-9a-zA-Z_\-\.]*)\s*\n([\s\S]*?)@end/g;Y.import=function(t){t.replace(Dr,function(t,e,r,n){var n=n.replace(/(^[\s\t\xa0\u3000]+)|([\u3000\xa0\s\t]+\x24)/g,"");if(n){for(var i,a=r.split("."),o=Y.codes,s=0;s0&&this.setViewport(this._viewportStack.pop())},saveClear:function(){this._clearStack.push({clearBit:this.clearBit,clearColor:this.clearColor})},restoreClear:function(){if(this._clearStack.length>0){var t=this._clearStack.pop();this.clearColor=t.clearColor,this.clearBit=t.clearBit}},bindSceneRendering:function(t){this._sceneRendering=t},render:function(t,e,r,n){var i=this.gl,a=this.clearColor;if(this.clearBit){i.colorMask(!0,!0,!0,!0),i.depthMask(!0);var o=this.viewport,s=!1,u=o.devicePixelRatio;(o.width!==this._width||o.height!==this._height||u&&u!==this.devicePixelRatio||o.x||o.y)&&(s=!0,i.enable(i.SCISSOR_TEST),i.scissor(o.x*u,o.y*u,o.width*u,o.height*u)),i.clearColor(a[0],a[1],a[2],a[3]),i.clear(this.clearBit),s&&i.disable(i.SCISSOR_TEST)}if(r||t.update(!1),!(e=e||t.getMainCamera()))return void console.error("Can't find camera in the scene.");e.getScene()||e.update(!0),this._sceneRendering=t,t.viewBoundingBoxLastFrame.min.set(1/0,1/0,1/0),t.viewBoundingBoxLastFrame.max.set(-1/0,-1/0,-1/0);var l=this.cullRenderList(t.opaqueList,t,e),c=this.cullRenderList(t.transparentList,t,e),h=t.material;t.trigger("beforerender",this,t,e),n?(this.renderPreZ(l,t,e),i.depthFunc(i.LEQUAL)):i.depthFunc(i.LESS);for(var f=kr(),d=Ur.create(),m=0;m0){var s=t[i-1],u=s.joints?s.joints.length:0;if((a.joints.length?a.joints.length:0)===u&&a.material===s.material&&a.lightGroup===s.lightGroup){a.__program=s.__program;continue}}var l=this._programMgr.getProgram(a,o,e);this.validateProgram(l),a.__program=l}},cullRenderList:function(t,e,r){for(var n=[],i=0;i0&&t.min.array[2]<0&&(t.max.array[2]=-1e-20),t.applyProjection(e);var u=t.min.array,l=t.max.array;if(l[0]<-1||u[0]>1||l[1]<-1||u[1]>1||l[2]<-1||u[2]>1)return!0}return!1}}(),disposeScene:function(t){this.disposeNode(t,!0,!0),t.dispose()},disposeNode:function(t,e,r){t.getParent()&&t.getParent().remove(t),t.traverse(function(t){t.geometry&&e&&t.geometry.dispose(this),t.dispose&&t.dispose(this)},this)},disposeGeometry:function(t){t.dispose(this)},disposeTexture:function(t){t.dispose(this)},disposeFrameBuffer:function(t){t.dispose(this)},dispose:function(){},screenToNDC:function(t,e,r){r||(r=new me),e=this._height-e;var n=this.viewport,i=r.array;return i[0]=(t-n.x)/n.width,i[0]=2*i[0]-1,i[1]=(e-n.y)/n.height,i[1]=2*i[1]-1,r}});Gr.opaqueSortCompare=Gr.prototype.opaqueSortCompare=function(t,e){return t.renderOrder===e.renderOrder?t.__program===e.__program?t.material===e.material?t.geometry.__uid__-e.geometry.__uid__:t.material.__uid__-e.material.__uid__:t.__program&&e.__program?t.__program.__uid__-e.__program.__uid__:0:t.renderOrder-e.renderOrder},Gr.transparentSortCompare=Gr.prototype.transparentSortCompare=function(t,e){return t.renderOrder===e.renderOrder?t.__depth===e.__depth?t.__program===e.__program?t.material===e.material?t.geometry.__uid__-e.geometry.__uid__:t.material.__uid__-e.material.__uid__:t.__program&&e.__program?t.__program.__uid__-e.__program.__uid__:0:t.__depth-e.__depth:t.renderOrder-e.renderOrder};var Vr={IDENTITY:kr(),WORLD:kr(),VIEW:kr(),PROJECTION:kr(),WORLDVIEW:kr(),VIEWPROJECTION:kr(),WORLDVIEWPROJECTION:kr(),WORLDINVERSE:kr(),VIEWINVERSE:kr(),PROJECTIONINVERSE:kr(),WORLDVIEWINVERSE:kr(),VIEWPROJECTIONINVERSE:kr(),WORLDVIEWPROJECTIONINVERSE:kr(),WORLDTRANSPOSE:kr(),VIEWTRANSPOSE:kr(),PROJECTIONTRANSPOSE:kr(),WORLDVIEWTRANSPOSE:kr(),VIEWPROJECTIONTRANSPOSE:kr(),WORLDVIEWPROJECTIONTRANSPOSE:kr(),WORLDINVERSETRANSPOSE:kr(),VIEWINVERSETRANSPOSE:kr(),PROJECTIONINVERSETRANSPOSE:kr(),WORLDVIEWINVERSETRANSPOSE:kr(),VIEWPROJECTIONINVERSETRANSPOSE:kr(),WORLDVIEWPROJECTIONINVERSETRANSPOSE:kr()};Gr.COLOR_BUFFER_BIT=Fe.COLOR_BUFFER_BIT,Gr.DEPTH_BUFFER_BIT=Fe.DEPTH_BUFFER_BIT,Gr.STENCIL_BUFFER_BIT=Fe.STENCIL_BUFFER_BIT;var Wr=fe.quat,zr=function(t,e,r,n){t=t||0,e=e||0,r=r||0,n=void 0===n?1:n,this.array=Wr.fromValues(t,e,r,n),this._dirty=!0};zr.prototype={constructor:zr,add:function(t){return Wr.add(this.array,this.array,t.array),this._dirty=!0,this},calculateW:function(){return Wr.calculateW(this.array,this.array),this._dirty=!0,this},set:function(t,e,r,n){return this.array[0]=t,this.array[1]=e,this.array[2]=r,this.array[3]=n,this._dirty=!0,this},setArray:function(t){return this.array[0]=t[0],this.array[1]=t[1],this.array[2]=t[2],this.array[3]=t[3],this._dirty=!0,this},clone:function(){return new zr(this.x,this.y,this.z,this.w)},conjugate:function(){return Wr.conjugate(this.array,this.array),this._dirty=!0,this},copy:function(t){return Wr.copy(this.array,t.array),this._dirty=!0,this},dot:function(t){return Wr.dot(this.array,t.array)},fromMat3:function(t){return Wr.fromMat3(this.array,t.array),this._dirty=!0,this},fromMat4:function(){var t=fe.mat3,e=t.create();return function(r){return t.fromMat4(e,r.array),t.transpose(e,e),Wr.fromMat3(this.array,e),this._dirty=!0,this}}(),identity:function(){return Wr.identity(this.array),this._dirty=!0,this},invert:function(){return Wr.invert(this.array,this.array),this._dirty=!0,this},len:function(){return Wr.len(this.array)},length:function(){return Wr.length(this.array)},lerp:function(t,e,r){return Wr.lerp(this.array,t.array,e.array,r),this._dirty=!0,this},mul:function(t){return Wr.mul(this.array,this.array,t.array),this._dirty=!0,this},mulLeft:function(t){return Wr.multiply(this.array,t.array,this.array),this._dirty=!0,this},multiply:function(t){return Wr.multiply(this.array,this.array,t.array),this._dirty=!0,this},multiplyLeft:function(t){return Wr.multiply(this.array,t.array,this.array),this._dirty=!0,this},normalize:function(){return Wr.normalize(this.array,this.array),this._dirty=!0,this},rotateX:function(t){return Wr.rotateX(this.array,this.array,t),this._dirty=!0,this},rotateY:function(t){return Wr.rotateY(this.array,this.array,t),this._dirty=!0,this},rotateZ:function(t){return Wr.rotateZ(this.array,this.array,t),this._dirty=!0,this},rotationTo:function(t,e){return Wr.rotationTo(this.array,t.array,e.array),this._dirty=!0,this},setAxes:function(t,e,r){return Wr.setAxes(this.array,t.array,e.array,r.array),this._dirty=!0,this},setAxisAngle:function(t,e){return Wr.setAxisAngle(this.array,t.array,e),this._dirty=!0,this},slerp:function(t,e,r){return Wr.slerp(this.array,t.array,e.array,r),this._dirty=!0,this},sqrLen:function(){return Wr.sqrLen(this.array)},squaredLength:function(){return Wr.squaredLength(this.array)},fromEuler:function(t,e){return zr.fromEuler(this,t,e)},toString:function(){return"["+Array.prototype.join.call(this.array,",")+"]"},toArray:function(){return Array.prototype.slice.call(this.array)}};var Xr=Object.defineProperty;if(Xr){var jr=zr.prototype;Xr(jr,"x",{get:function(){return this.array[0]},set:function(t){this.array[0]=t,this._dirty=!0}}),Xr(jr,"y",{get:function(){return this.array[1]},set:function(t){this.array[1]=t,this._dirty=!0}}),Xr(jr,"z",{get:function(){return this.array[2]},set:function(t){this.array[2]=t,this._dirty=!0}}),Xr(jr,"w",{get:function(){return this.array[3]},set:function(t){this.array[3]=t,this._dirty=!0}})}zr.add=function(t,e,r){return Wr.add(t.array,e.array,r.array),t._dirty=!0,t},zr.set=function(t,e,r,n,i){Wr.set(t.array,e,r,n,i),t._dirty=!0},zr.copy=function(t,e){return Wr.copy(t.array,e.array),t._dirty=!0,t},zr.calculateW=function(t,e){return Wr.calculateW(t.array,e.array),t._dirty=!0,t},zr.conjugate=function(t,e){return Wr.conjugate(t.array,e.array),t._dirty=!0,t},zr.identity=function(t){return Wr.identity(t.array),t._dirty=!0,t},zr.invert=function(t,e){return Wr.invert(t.array,e.array),t._dirty=!0,t},zr.dot=function(t,e){return Wr.dot(t.array,e.array)},zr.len=function(t){return Wr.length(t.array)},zr.lerp=function(t,e,r,n){return Wr.lerp(t.array,e.array,r.array,n),t._dirty=!0,t},zr.slerp=function(t,e,r,n){return Wr.slerp(t.array,e.array,r.array,n),t._dirty=!0,t},zr.mul=function(t,e,r){return Wr.multiply(t.array,e.array,r.array),t._dirty=!0,t},zr.multiply=zr.mul,zr.rotateX=function(t,e,r){return Wr.rotateX(t.array,e.array,r),t._dirty=!0,t},zr.rotateY=function(t,e,r){return Wr.rotateY(t.array,e.array,r),t._dirty=!0,t},zr.rotateZ=function(t,e,r){return Wr.rotateZ(t.array,e.array,r),t._dirty=!0,t},zr.setAxisAngle=function(t,e,r){return Wr.setAxisAngle(t.array,e.array,r),t._dirty=!0,t},zr.normalize=function(t,e){return Wr.normalize(t.array,e.array),t._dirty=!0,t},zr.sqrLen=function(t){return Wr.sqrLen(t.array)},zr.squaredLength=zr.sqrLen,zr.fromMat3=function(t,e){return Wr.fromMat3(t.array,e.array),t._dirty=!0,t},zr.setAxes=function(t,e,r,n){return Wr.setAxes(t.array,e.array,r.array,n.array),t._dirty=!0,t},zr.rotationTo=function(t,e,r){return Wr.rotationTo(t.array,e.array,r.array),t._dirty=!0,t},zr.fromEuler=function(t,e,r){t._dirty=!0,e=e.array;var n=t.array,i=Math.cos(e[0]/2),a=Math.cos(e[1]/2),o=Math.cos(e[2]/2),s=Math.sin(e[0]/2),u=Math.sin(e[1]/2),l=Math.sin(e[2]/2),r=(r||"XYZ").toUpperCase();switch(r){case"XYZ":n[0]=s*a*o+i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o-s*u*l;break;case"YXZ":n[0]=s*a*o+i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o+s*u*l;break;case"ZXY":n[0]=s*a*o-i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o-s*u*l;break;case"ZYX":n[0]=s*a*o-i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o+s*u*l;break;case"YZX":n[0]=s*a*o+i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o-s*u*l;break;case"XZY":n[0]=s*a*o-i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o+s*u*l}};var qr=fe.mat4,Yr=0,Kr=Me.extend({name:"",position:null,rotation:null,scale:null,worldTransform:null,localTransform:null,autoUpdateLocalTransform:!0,_parent:null,_scene:null,_needsUpdateWorldTransform:!0,_inIterating:!1,__depth:0},function(){this.name||(this.name=(this.type||"NODE")+"_"+Yr++),this.position||(this.position=new Ve),this.rotation||(this.rotation=new zr),this.scale||(this.scale=new Ve(1,1,1)),this.worldTransform=new rr,this.localTransform=new rr,this._children=[]},{target:null,invisible:!1,isSkinnedMesh:function(){return!1},isRenderable:function(){return!1},setName:function(t){var e=this._scene;if(e){var r=e._nodeRepository;delete r[this.name],r[t]=this}this.name=t},add:function(t){this._inIterating&&console.warn("Add operation can cause unpredictable error when in iterating");var e=t._parent;if(e!==this){e&&e.remove(t),t._parent=this,this._children.push(t);var r=this._scene;r&&r!==t.scene&&t.traverse(this._addSelfToScene,this),t._needsUpdateWorldTransform=!0}},remove:function(t){this._inIterating&&console.warn("Remove operation can cause unpredictable error when in iterating");var e=this._children,r=e.indexOf(t);r<0||(e.splice(r,1),t._parent=null,this._scene&&t.traverse(this._removeSelfFromScene,this))},removeAll:function(){for(var t=this._children,e=0;ethis.distance,i=1;i<8;i++)if(Jr.dot(e[i].array,r)>this.distance!=n)return!0},intersectLine:function(){var t=Jr.create();return function(e,r,n){var i=this.distanceToPoint(e),a=this.distanceToPoint(r);if(i>0&&a>0||i<0&&a<0)return null;var o=this.normal.array,s=this.distance,u=e.array;Jr.sub(t,r.array,e.array),Jr.normalize(t,t);var l=Jr.dot(o,t);if(0===l)return null;n||(n=new Ve);var c=(Jr.dot(o,u)-s)/l;return Jr.scaleAndAdd(n.array,u,t,-c),n._dirty=!0,n}}(),applyTransform:function(){var t=Qr.create(),e=$r.create(),r=$r.create();return r[3]=1,function(n){n=n.array,Jr.scale(r,this.normal.array,this.distance),$r.transformMat4(r,r,n),this.distance=Jr.dot(r,this.normal.array),Qr.invert(t,n),Qr.transpose(t,t),e[3]=0,Jr.copy(e,this.normal.array),$r.transformMat4(e,e,t),Jr.copy(this.normal.array,e)}}(),copy:function(t){Jr.copy(this.normal.array,t.normal.array),this.normal._dirty=!0,this.distance=t.distance},clone:function(){var t=new tn;return t.copy(this),t}};var en=fe.vec3,rn=en.set,nn=en.copy,an=en.transformMat4,on=Math.min,sn=Math.max,un=function(){this.planes=[];for(var t=0;t<6;t++)this.planes.push(new tn);this.boundingBox=new Je,this.vertices=[];for(var t=0;t<8;t++)this.vertices[t]=en.fromValues(0,0,0)};un.prototype={setFromProjection:function(t){var e=this.planes,r=t.array,n=r[0],i=r[1],a=r[2],o=r[3],s=r[4],u=r[5],l=r[6],c=r[7],h=r[8],f=r[9],d=r[10],m=r[11],p=r[12],_=r[13],g=r[14],v=r[15];rn(e[0].normal.array,o-n,c-s,m-h),e[0].distance=-(v-p),e[0].normalize(),rn(e[1].normal.array,o+n,c+s,m+h),e[1].distance=-(v+p),e[1].normalize(),rn(e[2].normal.array,o+i,c+u,m+f),e[2].distance=-(v+_),e[2].normalize(),rn(e[3].normal.array,o-i,c-u,m-f),e[3].distance=-(v-_),e[3].normalize(),rn(e[4].normal.array,o-a,c-l,m-d),e[4].distance=-(v-g),e[4].normalize(),rn(e[5].normal.array,o+a,c+l,m+d),e[5].distance=-(v+g),e[5].normalize();var y=this.boundingBox;if(0===v){var x=u/n,T=-g/(d-1),E=-g/(d+1),b=-E/u,A=-T/u;y.min.set(-b*x,-b,E),y.max.set(b*x,b,T);var S=this.vertices;rn(S[0],-b*x,-b,E),rn(S[1],-b*x,b,E),rn(S[2],b*x,-b,E),rn(S[3],b*x,b,E),rn(S[4],-A*x,-A,T),rn(S[5],-A*x,A,T),rn(S[6],A*x,-A,T),rn(S[7],A*x,A,T)}else{var w=(-1-p)/n,C=(1-p)/n,N=(1-_)/u,M=(-1-_)/u,R=(-1-g)/d,L=(1-g)/d;y.min.set(Math.min(w,C),Math.min(M,N),Math.min(L,R)),y.max.set(Math.max(C,w),Math.max(N,M),Math.max(R,L));var P=y.min.array,D=y.max.array,S=this.vertices;rn(S[0],P[0],P[1],P[2]),rn(S[1],P[0],D[1],P[2]),rn(S[2],D[0],P[1],P[2]),rn(S[3],D[0],D[1],P[2]),rn(S[4],P[0],P[1],D[2]),rn(S[5],P[0],D[1],D[2]),rn(S[6],D[0],P[1],D[2]),rn(S[7],D[0],D[1],D[2])}},getTransformedBoundingBox:function(){var t=en.create();return function(e,r){var n=this.vertices,i=r.array,a=e.min,o=e.max,s=a.array,u=o.array,l=n[0];an(t,l,i),nn(s,t),nn(u,t);for(var c=1;c<8;c++)l=n[c],an(t,l,i),s[0]=on(t[0],s[0]),s[1]=on(t[1],s[1]),s[2]=on(t[2],s[2]),u[0]=sn(t[0],u[0]),u[1]=sn(t[1],u[1]),u[2]=sn(t[2],u[2]);return a._dirty=!0,o._dirty=!0,e}}()};var ln=fe.vec3,cn=function(t,e){this.origin=t||new Ve,this.direction=e||new Ve};cn.prototype={constructor:cn,intersectPlane:function(t,e){var r=t.normal.array,n=t.distance,i=this.origin.array,a=this.direction.array,o=ln.dot(r,a);if(0===o)return null;e||(e=new Ve);var s=(ln.dot(r,i)-n)/o;return ln.scaleAndAdd(e.array,i,a,-s),e._dirty=!0,e},mirrorAgainstPlane:function(t){var e=ln.dot(t.normal.array,this.direction.array);ln.scaleAndAdd(this.direction.array,this.direction.array,t.normal.array,2*-e),this.direction._dirty=!0},distanceToPoint:function(){var t=ln.create();return function(e){ln.sub(t,e,this.origin.array);var r=ln.dot(t,this.direction.array);if(r<0)return ln.distance(this.origin.array,e);var n=ln.lenSquared(t);return Math.sqrt(n-r*r)}}(),intersectSphere:function(){var t=ln.create();return function(e,r,n){var i=this.origin.array,a=this.direction.array;e=e.array,ln.sub(t,e,i);var o=ln.dot(t,a),s=ln.squaredLength(t),u=s-o*o,l=r*r;if(!(u>l)){var c=Math.sqrt(l-u),h=o-c,f=o+c;return n||(n=new Ve),h<0?f<0?null:(ln.scaleAndAdd(n.array,i,a,f),n):(ln.scaleAndAdd(n.array,i,a,h),n)}}}(),intersectBoundingBox:function(t,e){var r,n,i,a,o,s,u=this.direction.array,l=this.origin.array,c=t.min.array,h=t.max.array,f=1/u[0],d=1/u[1],m=1/u[2];if(f>=0?(r=(c[0]-l[0])*f,n=(h[0]-l[0])*f):(n=(c[0]-l[0])*f,r=(h[0]-l[0])*f),d>=0?(i=(c[1]-l[1])*d,a=(h[1]-l[1])*d):(a=(c[1]-l[1])*d,i=(h[1]-l[1])*d),r>a||i>n)return null;if((i>r||r!==r)&&(r=i),(a=0?(o=(c[2]-l[2])*m,s=(h[2]-l[2])*m):(s=(c[2]-l[2])*m,o=(h[2]-l[2])*m),r>s||o>n)return null;if((o>r||r!==r)&&(r=o),(s=0?r:n;return e||(e=new Ve),ln.scaleAndAdd(e.array,l,u,p),e},intersectTriangle:function(){var t=ln.create(),e=ln.create(),r=ln.create(),n=ln.create();return function(i,a,o,s,u,l){var c=this.direction.array,h=this.origin.array;i=i.array,a=a.array,o=o.array,ln.sub(t,a,i),ln.sub(e,o,i),ln.cross(n,e,c);var f=ln.dot(t,n);if(s){if(f>-1e-5)return null}else if(f>-1e-5&&f<1e-5)return null;ln.sub(r,h,i);var d=ln.dot(n,r)/f;if(d<0||d>1)return null;ln.cross(n,t,r);var m=ln.dot(c,n)/f;if(m<0||m>1||d+m>1)return null;ln.cross(n,t,e) -;var p=-ln.dot(r,n)/f;return p<0?null:(u||(u=new Ve),l&&Ve.set(l,1-d-m,d,m),ln.scaleAndAdd(u.array,h,c,p),u)}}(),applyTransform:function(t){Ve.add(this.direction,this.direction,this.origin),Ve.transformMat4(this.origin,this.origin,t),Ve.transformMat4(this.direction,this.direction,t),Ve.sub(this.direction,this.direction,this.origin),Ve.normalize(this.direction,this.direction)},copy:function(t){Ve.copy(this.origin,t.origin),Ve.copy(this.direction,t.direction)},clone:function(){var t=new cn;return t.copy(this),t}};var hn=fe.vec3,fn=fe.vec4,dn=Kr.extend(function(){return{projectionMatrix:new rr,invProjectionMatrix:new rr,viewMatrix:new rr,frustum:new un}},function(){this.update(!0)},{update:function(t){Kr.prototype.update.call(this,t),rr.invert(this.viewMatrix,this.worldTransform),this.updateProjectionMatrix(),rr.invert(this.invProjectionMatrix,this.projectionMatrix),this.frustum.setFromProjection(this.projectionMatrix)},setViewMatrix:function(t){rr.copy(this.viewMatrix,t),rr.invert(this.worldTransform,t),this.decomposeWorldTransform()},decomposeProjectionMatrix:function(){},setProjectionMatrix:function(t){rr.copy(this.projectionMatrix,t),rr.invert(this.invProjectionMatrix,t),this.decomposeProjectionMatrix()},updateProjectionMatrix:function(){},castRay:function(){var t=fn.create();return function(e,r){var n=void 0!==r?r:new cn,i=e.array[0],a=e.array[1];return fn.set(t,i,a,-1,1),fn.transformMat4(t,t,this.invProjectionMatrix.array),fn.transformMat4(t,t,this.worldTransform.array),hn.scale(n.origin.array,t,1/t[3]),fn.set(t,i,a,1,1),fn.transformMat4(t,t,this.invProjectionMatrix.array),fn.transformMat4(t,t,this.worldTransform.array),hn.scale(t,t,1/t[3]),hn.sub(n.direction.array,t,n.origin.array),hn.normalize(n.direction.array,n.direction.array),n.direction._dirty=!0,n.origin._dirty=!0,n}}()}),mn={},pn=Kr.extend(function(){return{material:null,autoUpdate:!0,opaqueList:[],transparentList:[],lights:[],viewBoundingBoxLastFrame:new Je,shadowUniforms:{},_cameraList:[],_lightUniforms:{},_previousLightNumber:{},_lightNumber:{},_lightProgramKeys:{},_opaqueObjectCount:0,_transparentObjectCount:0,_nodeRepository:{}}},function(){this._scene=this},{addToScene:function(t){t instanceof dn&&(this._cameraList.length>0&&console.warn("Found multiple camera in one scene. Use the fist one."),this._cameraList.push(t)),t.name&&(this._nodeRepository[t.name]=t)},removeFromScene:function(t){if(t instanceof dn){var e=this._cameraList.indexOf(t);e>=0&&this._cameraList.splice(e,1)}t.name&&delete this._nodeRepository[t.name]},getNode:function(t){return this._nodeRepository[t]},cloneNode:function(t){var e=t.clone(),r={},n=function(i,a){i.skeleton&&(a.skeleton=i.skeleton.clone(t,e),a.joints=i.joints.slice()),i.material&&(r[i.material.__uid__]={oldMat:i.material});for(var o=0;o0&&this._updateRenderList(n)}},_updateLightUniforms:function(){var t=this.lights;t.sort(Q);var e=this._lightUniforms;for(var r in e)for(var n in e[r])e[r][n].value.length=0;for(var i=0;ia[0]&&(a[0]=s),u>a[1]&&(a[1]=u),l>a[2]&&(a[2]=l)}r._dirty=!0,n._dirty=!0}},dirty:function(){for(var t=this.getEnabledAttributes(),e=0;e=0){e||(e=vn());var r=this.indices;return e[0]=r[3*t],e[1]=r[3*t+1],e[2]=r[3*t+2],e}},setTriangleIndices:function(t,e){var r=this.indices;r[3*t]=e[0],r[3*t+1]=e[1],r[3*t+2]=e[2]},isUseIndices:function(){return!!this.indices},initIndicesFromArray:function(t){var e,r=this.vertexCount>65535?He.Uint32Array:He.Uint16Array;if(t[0]&&t[0].length){var n=0;e=new r(3*t.length);for(var i=0;i=0&&(e.splice(r,1),delete this.attributes[t],!0)},getAttribute:function(t){return this.attributes[t]},getEnabledAttributes:function(){var t=this._enabledAttributes,e=this._attributeList;if(t)return t;for(var r=[],n=this.vertexCount,i=0;i65535&&(this.indices=new He.Uint32Array(this.indices));for(var t=this.attributes,e=this.indices,r=this.getEnabledAttributes(),n={},i=0;i65535?Uint32Array:Uint16Array,m=this.indices=new d(e*t*6),p=this.radius,_=this.phiStart,g=this.phiLength,v=this.thetaStart,y=this.thetaLength,p=this.radius,x=[],T=[],E=0,b=1/p;for(f=0;f<=t;f++)for(h=0;h<=e;h++)l=h/e,c=f/t,o=-p*Math.cos(_+l*g)*Math.sin(v+c*y),s=p*Math.cos(v+c*y),u=p*Math.sin(_+l*g)*Math.sin(v+c*y),x[0]=o,x[1]=s,x[2]=u,T[0]=l,T[1]=c,r.set(E,x),n.set(E,T),x[0]*=b,x[1]*=b,x[2]*=b,i.set(E,x),E++;var A,S,w,C,N=e+1,M=0;for(f=0;f>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t},wn.nearestPowerOfTwo=function(t){return Math.pow(2,Math.round(Math.log(t)/Math.LN2))};var Cn=wn.isPowerOfTwo,Nn=or.extend(function(){return{image:null,pixels:null,mipmaps:[]}},{update:function(t){var e=t.gl;e.bindTexture(e.TEXTURE_2D,this._cache.get("webgl_texture")),this.updateCommon(t);var r=this.format,n=this.type;e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,this.getAvailableWrapS()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,this.getAvailableWrapT()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,this.getAvailableMagFilter()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,this.getAvailableMinFilter());var i=t.getGLExtension("EXT_texture_filter_anisotropic");if(i&&this.anisotropic>1&&e.texParameterf(e.TEXTURE_2D,i.TEXTURE_MAX_ANISOTROPY_EXT,this.anisotropic),36193===n){t.getGLExtension("OES_texture_half_float")||(n=Fe.FLOAT)}if(this.mipmaps.length)for(var a=this.width,o=this.height,s=0;s=or.COMPRESSED_RGB_S3TC_DXT1_EXT?t.compressedTexImage2D(t.TEXTURE_2D,r,a,n,i,0,e.pixels):t.texImage2D(t.TEXTURE_2D,r,a,n,i,0,a,o,e.pixels)},generateMipmap:function(t){var e=t.gl;this.useMipmap&&!this.NPOT&&(e.bindTexture(e.TEXTURE_2D,this._cache.get("webgl_texture")),e.generateMipmap(e.TEXTURE_2D))},isPowerOfTwo:function(){var t,e;return this.image?(t=this.image.width,e=this.image.height):(t=this.width,e=this.height),Cn(t)&&Cn(e)},isRenderable:function(){return this.image?"CANVAS"===this.image.nodeName||"VIDEO"===this.image.nodeName||this.image.complete:!(!this.width||!this.height)},bind:function(t){t.gl.bindTexture(t.gl.TEXTURE_2D,this.getWebGLTexture(t))},unbind:function(t){t.gl.bindTexture(t.gl.TEXTURE_2D,null)},load:function(t,e){var r=new Image;e&&(r.crossOrigin=e);var n=this;return r.onload=function(){n.dirty(),n.trigger("success",n),r.onload=null},r.onerror=function(){n.trigger("error",n),r.onerror=null},r.src=t,this.image=r,this}});Object.defineProperty(Nn.prototype,"width",{get:function(){return this.image?this.image.width:this._width},set:function(t){this.image?console.warn("Texture from image can't set width"):(this._width!==t&&this.dirty(),this._width=t)}}),Object.defineProperty(Nn.prototype,"height",{get:function(){return this.image?this.image.height:this._height},set:function(t){this.image?console.warn("Texture from image can't set height"):(this._height!==t&&this.dirty(),this._height=t)}});var Mn={};at.prototype.get=function(t){var e=t;if(this._pool[e])return this._pool[e];var r=Mn[t];if(!r)return void console.error('Shader "'+t+'" is not in the library');var n=new Y(r.vertex,r.fragment);return this._pool[e]=n,n},at.prototype.clear=function(){this._pool={}};var Rn,Ln=new at,Pn={createLibrary:function(){return new at},get:function(){return Ln.get.apply(Ln,arguments)},template:ot,clear:function(){return Ln.clear()}},Dn=0,In=null,On=!0,Bn=function(){this.triangleCount=0,this.vertexCount=0,this.drawCallCount=0},Fn=Kr.extend({material:null,geometry:null,mode:Fe.TRIANGLES,_drawCache:null,_renderInfo:null},function(){this._drawCache={},this._renderInfo=new Bn},{__program:null,lightGroup:0,renderOrder:0,lineWidth:1,culling:!0,cullFace:Fe.BACK,frontFace:Fe.CCW,frustumCulling:!0,receiveShadow:!0,castShadow:!0,ignorePicking:!1,ignorePreZ:!1,ignoreGBuffer:!1,isRenderable:function(){return this.geometry&&this.material&&this.material.shader&&!this.invisible&&this.geometry.vertexCount>0},beforeRender:function(t){},afterRender:function(t,e){},getBoundingBox:function(t,e){return e=Kr.prototype.getBoundingBox.call(this,t,e),this.geometry&&this.geometry.boundingBox&&e.union(this.geometry.boundingBox),e},render:function(t,e,r){var n=t.gl;e=e||this.material;var i=e.shader,a=this.geometry,o=this.mode,s=a.vertexCount,u=(a.isUseIndices(),t.getGLExtension("OES_element_index_uint")),l=u&&s>65535,c=l?n.UNSIGNED_INT:n.UNSIGNED_SHORT,h=t.getGLExtension("OES_vertex_array_object"),f=!a.dynamic,d=this._renderInfo;d.vertexCount=s,d.triangleCount=0,d.drawCallCount=0;var m=!1;if(Rn=t.__uid__+"-"+a.__uid__+"-"+r.__uid__,Rn!==Dn?m=!0:(h&&f||a._cache.isDirty("any"))&&(m=!0),Dn=Rn,m){var p=this._drawCache[Rn];if(!p){var _=a.getBufferChunks(t);if(!_)return;p=[];for(var g=0;g<_.length;g++){for(var v=_[g],y=v.attributeBuffers,x=v.indicesBuffer,T=[],E=[],b=0;b0)},render:function(t,e,r){var n=t.gl;if(this.skeleton){this.skeleton.update();var i=this.skeleton.getSubSkinMatrices(this.__uid__,this.joints);r.setUniformOfSemantic(n,"SKIN_MATRIX",i)}return Fn.prototype.render.call(this,t,e,r)},getSkinMatricesTexture:function(){return this._skinMatricesTexture=this._skinMatricesTexture||new Nn({type:Fe.FLOAT,minFilter:Fe.NEAREST,magFilter:Fe.NEAREST,useMipmap:!1,flipY:!1}),this._skinMatricesTexture}});Un.POINTS=Fe.POINTS,Un.LINES=Fe.LINES,Un.LINE_LOOP=Fe.LINE_LOOP,Un.LINE_STRIP=Fe.LINE_STRIP,Un.TRIANGLES=Fe.TRIANGLES,Un.TRIANGLE_STRIP=Fe.TRIANGLE_STRIP,Un.TRIANGLE_FAN=Fe.TRIANGLE_FAN,Un.BACK=Fe.BACK,Un.FRONT=Fe.FRONT,Un.FRONT_AND_BACK=Fe.FRONT_AND_BACK,Un.CW=Fe.CW,Un.CCW=Fe.CCW;var kn=dn.extend({fov:50,aspect:1,near:.1,far:2e3},{updateProjectionMatrix:function(){var t=this.fov/180*Math.PI;this.projectionMatrix.perspective(t,this.aspect,this.near,this.far)},decomposeProjectionMatrix:function(){var t=this.projectionMatrix.array,e=2*Math.atan(1/t[5]);this.fov=e/Math.PI*180,this.aspect=t[5]/t[0],this.near=t[14]/(t[10]-1),this.far=t[14]/(t[10]+1)},clone:function(){var t=dn.prototype.clone.call(this);return t.fov=this.fov,t.aspect=this.aspect,t.near=this.near,t.far=this.far,t}}),Hn=dn.extend({left:-1,right:1,near:-1,far:1,top:1,bottom:-1},{updateProjectionMatrix:function(){this.projectionMatrix.ortho(this.left,this.right,this.bottom,this.top,this.near,this.far)},decomposeProjectionMatrix:function(){var t=this.projectionMatrix.array;this.left=(-1-t[12])/t[0],this.right=(1-t[12])/t[0],this.top=(1-t[13])/t[5],this.bottom=(-1-t[13])/t[5],this.near=-(-1-t[14])/t[10],this.far=-(1-t[14])/t[10]},clone:function(){var t=dn.prototype.clone.call(this);return t.left=this.left,t.right=this.right,t.near=this.near,t.far=this.far,t.top=this.top,t.bottom=this.bottom,t}}),Gn={get:ut -},Vn="\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n#ifdef GAMMA_ENCODE\n outColor.rgb = pow(outColor.rgb, vec3(1 / 2.2));\n#endif\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end";Y.import(Vn);var Wn,zn=["diffuseMap","normalMap","roughnessMap","metalnessMap","emissiveMap","environmentMap","brdfLookup","ssaoMap","aoMap"],Xn=["color","emission","emissionIntensity","alpha","roughness","metalness","uvRepeat","uvOffset","aoIntensity","alphaCutoff"],jn=["linear","encodeRGBM","decodeRGBM","doubleSided","alphaTest","roughnessChannel","metalnessChannel","environmentMapPrefiltered"],qn={roughnessChannel:"ROUGHNESS_CHANNEL",metalnessChannel:"METALNESS_CHANNEL"},Yn={linear:"SRGB_DECODE",encodeRGBM:"RGBM_ENCODE",decodeRGBM:"RGBM_DECODE",doubleSided:"DOUBLE_SIDED",alphaTest:"ALPHA_TEST",environmentMapPrefiltered:"ENVIRONMENTMAP_PREFILTER"},Kn=pr.extend(function(){return Wn||(Wn=new Y(Y.source("clay.standard.vertex"),Y.source("clay.standard.fragment"))),{shader:Wn}},function(t){Ne.extend(this,t),Ne.defaults(this,{color:[1,1,1],emission:[0,0,0],emissionIntensity:0,roughness:.5,metalness:0,alpha:1,alphaTest:!1,alphaCutoff:.9,doubleSided:!1,uvRepeat:[1,1],uvOffset:[0,0],aoIntensity:1,environmentMapPrefiltered:!1,linear:!1,encodeRGBM:!1,decodeRGBM:!1,roughnessChannel:0,metalnessChannel:1}),this.define("fragment","USE_METALNESS"),this.define("fragment","USE_ROUGHNESS")},{clone:function(){var t=new Kn({name:this.name});return zn.forEach(function(e){this[e]&&(t[e]=this[e])},this),Xn.concat(jn).forEach(function(e){t[e]=this[e]},this),t}});Xn.forEach(function(t){Object.defineProperty(Kn.prototype,t,{get:function(){return this.get(t)},set:function(e){this.setUniform(t,e)}})}),zn.forEach(function(t){Object.defineProperty(Kn.prototype,t,{get:function(){return this.get(t)},set:function(e){this.setUniform(t,e)}})}),jn.forEach(function(t){var e="_"+t;Object.defineProperty(Kn.prototype,t,{get:function(){return this[e]},set:function(r){if(this[e]=r,t in qn){var n=qn[t];this.define("fragment",n,r)}else{var n=Yn[t];r?this.define("fragment",n):this.undefine("fragment",n)}}})}),Object.defineProperty(Kn.prototype,"environmentBox",{get:function(){var t=this._environmentBox;return t&&(t.min.setArray(this.get("environmentBoxMin")),t.max.setArray(this.get("environmentBoxMax"))),t},set:function(t){this._environmentBox=t;var e=this.uniforms=this.uniforms||{};e.environmentBoxMin=e.environmentBoxMin||{value:null},e.environmentBoxMax=e.environmentBoxMax||{value:null},t&&(this.setUniform("environmentBoxMin",t.min.array),this.setUniform("environmentBoxMax",t.max.array)),t?this.define("fragment","PARALLAX_CORRECTED"):this.undefine("fragment","PARALLAX_CORRECTED")}});var Zn=Me.extend({name:"",index:-1,node:null,rootNode:null}),Jn=fe.quat,Qn=fe.vec3,$n=fe.mat4,ti=Me.extend(function(){return{relativeRootNode:null,name:"",joints:[],_clips:[],_invBindPoseMatricesArray:null,_jointMatricesSubArrays:[],_skinMatricesArray:null,_skinMatricesSubArrays:[],_subSkinMatricesArray:{}}},{addClip:function(t,e){for(var r=0;r0&&this._clips.splice(e,1)},removeClipsAll:function(){this._clips=[]},getClip:function(t){if(this._clips[t])return this._clips[t].clip},getClipNumber:function(){return this._clips.length},updateJointMatrices:function(){var t=$n.create();return function(){this._invBindPoseMatricesArray=new Float32Array(16*this.joints.length),this._skinMatricesArray=new Float32Array(16*this.joints.length);for(var e=0;e 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"),Y.import(Vn),Y.import("@export clay.wireframe.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 world : WORLD;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\n v_Barycentric = barycentric;\n}\n@end\n@export clay.wireframe.fragment\nuniform vec3 color : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\nuniform float lineWidth : 1.0;\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\nvoid main()\n{\n gl_FragColor.rgb = color;\n gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\n}\n@end"),Y.import(ni),Y.import(Br),Pn.template("clay.basic",Y.source("clay.basic.vertex"),Y.source("clay.basic.fragment")),Pn.template("clay.lambert",Y.source("clay.lambert.vertex"),Y.source("clay.lambert.fragment")),Pn.template("clay.wireframe",Y.source("clay.wireframe.vertex"),Y.source("clay.wireframe.fragment")),Pn.template("clay.skybox",Y.source("clay.skybox.vertex"),Y.source("clay.skybox.fragment")),Pn.template("clay.prez",Y.source("clay.prez.vertex"),Y.source("clay.prez.fragment")),Pn.template("clay.standard",Y.source("clay.standard.vertex"),Y.source("clay.standard.fragment")),Pn.template("clay.standardMR",Y.source("clay.standardMR.vertex"),Y.source("clay.standardMR.fragment")),Y.import("@export clay.compositor.coloradjust\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float exposure : 0.0;\nuniform float gamma : 1.0;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\n color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\n color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\n float luminance = dot( color, w );\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.brightness\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = tex.rgb + vec3(brightness);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.contrast\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float contrast : 1.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.exposure\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float exposure : 0.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb * pow(2.0, exposure);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.gamma\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float gamma : 1.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = pow(tex.rgb, vec3(gamma));\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.saturation\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb;\n float luminance = dot(color, w);\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end"),Y.import("@export clay.compositor.kernel.gaussian_9\nfloat gaussianKernel[9];\ngaussianKernel[0] = 0.07;\ngaussianKernel[1] = 0.09;\ngaussianKernel[2] = 0.12;\ngaussianKernel[3] = 0.14;\ngaussianKernel[4] = 0.16;\ngaussianKernel[5] = 0.14;\ngaussianKernel[6] = 0.12;\ngaussianKernel[7] = 0.09;\ngaussianKernel[8] = 0.07;\n@end\n@export clay.compositor.kernel.gaussian_13\nfloat gaussianKernel[13];\ngaussianKernel[0] = 0.02;\ngaussianKernel[1] = 0.03;\ngaussianKernel[2] = 0.06;\ngaussianKernel[3] = 0.08;\ngaussianKernel[4] = 0.11;\ngaussianKernel[5] = 0.13;\ngaussianKernel[6] = 0.14;\ngaussianKernel[7] = 0.13;\ngaussianKernel[8] = 0.11;\ngaussianKernel[9] = 0.08;\ngaussianKernel[10] = 0.06;\ngaussianKernel[11] = 0.03;\ngaussianKernel[12] = 0.02;\n@end\n@export clay.compositor.gaussian_blur\n#define SHADER_NAME gaussian_blur\nuniform sampler2D texture;varying vec2 v_Texcoord;\nuniform float blurSize : 2.0;\nuniform vec2 textureSize : [512.0, 512.0];\nuniform float blurDir : 0.0;\n@import clay.util.rgbm\n@import clay.util.clamp_sample\nvoid main (void)\n{\n @import clay.compositor.kernel.gaussian_9\n vec2 off = blurSize / textureSize;\n off *= vec2(1.0 - blurDir, blurDir);\n vec4 sum = vec4(0.0);\n float weightAll = 0.0;\n for (int i = 0; i < 9; i++) {\n float w = gaussianKernel[i];\n vec4 texel = decodeHDR(clampSample(texture, v_Texcoord + float(i - 4) * off));\n sum += texel * w;\n weightAll += w;\n }\n gl_FragColor = encodeHDR(sum / max(weightAll, 0.01));\n}\n@end\n"),Y.import("@export clay.compositor.hdr.log_lum\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\n float luminance = dot(tex.rgb, w);\n luminance = log(luminance + 0.001);\n gl_FragColor = encodeHDR(vec4(vec3(luminance), 1.0));\n}\n@end\n@export clay.compositor.hdr.lum_adaption\nvarying vec2 v_Texcoord;\nuniform sampler2D adaptedLum;\nuniform sampler2D currentLum;\nuniform float frameTime : 0.02;\n@import clay.util.rgbm\nvoid main()\n{\n float fAdaptedLum = decodeHDR(texture2D(adaptedLum, vec2(0.5, 0.5))).r;\n float fCurrentLum = exp(encodeHDR(texture2D(currentLum, vec2(0.5, 0.5))).r);\n fAdaptedLum += (fCurrentLum - fAdaptedLum) * (1.0 - pow(0.98, 30.0 * frameTime));\n gl_FragColor = encodeHDR(vec4(vec3(fAdaptedLum), 1.0));\n}\n@end\n@export clay.compositor.lum\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord );\n float luminance = dot(tex.rgb, w);\n gl_FragColor = vec4(vec3(luminance), 1.0);\n}\n@end"),Y.import("\n@export clay.compositor.lut\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform sampler2D lookup;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n float blueColor = tex.b * 63.0;\n vec2 quad1;\n quad1.y = floor(floor(blueColor) / 8.0);\n quad1.x = floor(blueColor) - (quad1.y * 8.0);\n vec2 quad2;\n quad2.y = floor(ceil(blueColor) / 8.0);\n quad2.x = ceil(blueColor) - (quad2.y * 8.0);\n vec2 texPos1;\n texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\n texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\n vec2 texPos2;\n texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\n texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\n vec4 newColor1 = texture2D(lookup, texPos1);\n vec4 newColor2 = texture2D(lookup, texPos2);\n vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\n gl_FragColor = vec4(newColor.rgb, tex.w);\n}\n@end"),Y.import("@export clay.compositor.vignette\n#define OUTPUT_ALPHA\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float darkness: 1;\nuniform float offset: 1;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\n gl_FragColor.rgb = texel.rgb;\n vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(offset);\n gl_FragColor = encodeHDR(vec4(mix(texel.rgb, vec3(1.0 - darkness), dot(uv, uv)), texel.a));\n}\n@end"),Y.import("@export clay.compositor.output\n#define OUTPUT_ALPHA\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\n gl_FragColor.rgb = tex.rgb;\n#ifdef OUTPUT_ALPHA\n gl_FragColor.a = tex.a;\n#else\n gl_FragColor.a = 1.0;\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n#ifdef PREMULTIPLY_ALPHA\n gl_FragColor.rgb *= gl_FragColor.a;\n#endif\n}\n@end"),Y.import("@export clay.compositor.bright\nuniform sampler2D texture;\nuniform float threshold : 1;\nuniform float scale : 1.0;\nuniform vec2 textureSize: [512, 512];\nvarying vec2 v_Texcoord;\nconst vec3 lumWeight = vec3(0.2125, 0.7154, 0.0721);\n@import clay.util.rgbm\nvec4 median(vec4 a, vec4 b, vec4 c)\n{\n return a + b + c - min(min(a, b), c) - max(max(a, b), c);\n}\nvoid main()\n{\n vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\n#ifdef ANTI_FLICKER\n vec3 d = 1.0 / textureSize.xyx * vec3(1.0, 1.0, 0.0);\n vec4 s1 = decodeHDR(texture2D(texture, v_Texcoord - d.xz));\n vec4 s2 = decodeHDR(texture2D(texture, v_Texcoord + d.xz));\n vec4 s3 = decodeHDR(texture2D(texture, v_Texcoord - d.zy));\n vec4 s4 = decodeHDR(texture2D(texture, v_Texcoord + d.zy));\n texel = median(median(texel, s1, s2), s3, s4);\n#endif\n float lum = dot(texel.rgb , lumWeight);\n vec4 color;\n if (lum > threshold && texel.a > 0.0)\n {\n color = vec4(texel.rgb * scale, texel.a * scale);\n }\n else\n {\n color = vec4(0.0);\n }\n gl_FragColor = encodeHDR(color);\n}\n@end\n"),Y.import("@export clay.compositor.downsample\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nfloat brightness(vec3 c)\n{\n return max(max(c.r, c.g), c.b);\n}\n@import clay.util.clamp_sample\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n#ifdef ANTI_FLICKER\n vec3 s1 = decodeHDR(clampSample(texture, v_Texcoord + d.xy)).rgb;\n vec3 s2 = decodeHDR(clampSample(texture, v_Texcoord + d.zy)).rgb;\n vec3 s3 = decodeHDR(clampSample(texture, v_Texcoord + d.xw)).rgb;\n vec3 s4 = decodeHDR(clampSample(texture, v_Texcoord + d.zw)).rgb;\n float s1w = 1.0 / (brightness(s1) + 1.0);\n float s2w = 1.0 / (brightness(s2) + 1.0);\n float s3w = 1.0 / (brightness(s3) + 1.0);\n float s4w = 1.0 / (brightness(s4) + 1.0);\n float oneDivideSum = 1.0 / (s1w + s2w + s3w + s4w);\n vec4 color = vec4(\n (s1 * s1w + s2 * s2w + s3 * s3w + s4 * s4w) * oneDivideSum,\n 1.0\n );\n#else\n vec4 color = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\n color *= 0.25;\n#endif\n gl_FragColor = encodeHDR(color);\n}\n@end"),Y.import("\n@export clay.compositor.upsample\n#define HIGH_QUALITY\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.clamp_sample\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n vec4 s;\n s = decodeHDR(clampSample(texture, v_Texcoord - d.xy));\n s += decodeHDR(clampSample(texture, v_Texcoord - d.wy)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord - d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zw)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord )) * 4.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xw)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.wy)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n gl_FragColor = encodeHDR(s / 16.0);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n vec4 s;\n s = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\n gl_FragColor = encodeHDR(s / 4.0);\n#endif\n}\n@end"),Y.import("@export clay.compositor.hdr.composite\nuniform sampler2D texture;\n#ifdef BLOOM_ENABLED\nuniform sampler2D bloom;\n#endif\n#ifdef LENSFLARE_ENABLED\nuniform sampler2D lensflare;\nuniform sampler2D lensdirt;\n#endif\n#ifdef LUM_ENABLED\nuniform sampler2D lum;\n#endif\n#ifdef LUT_ENABLED\nuniform sampler2D lut;\n#endif\n#ifdef COLOR_CORRECTION\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float saturation : 1.0;\n#endif\n#ifdef VIGNETTE\nuniform float vignetteDarkness: 1.0;\nuniform float vignetteOffset: 1.0;\n#endif\nuniform float exposure : 1.0;\nuniform float bloomIntensity : 0.25;\nuniform float lensflareIntensity : 1;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvec3 ACESToneMapping(vec3 color)\n{\n const float A = 2.51;\n const float B = 0.03;\n const float C = 2.43;\n const float D = 0.59;\n const float E = 0.14;\n return (color * (A * color + B)) / (color * (C * color + D) + E);\n}\nfloat eyeAdaption(float fLum)\n{\n return mix(0.2, fLum, 0.5);\n}\n#ifdef LUT_ENABLED\nvec3 lutTransform(vec3 color) {\n float blueColor = color.b * 63.0;\n vec2 quad1;\n quad1.y = floor(floor(blueColor) / 8.0);\n quad1.x = floor(blueColor) - (quad1.y * 8.0);\n vec2 quad2;\n quad2.y = floor(ceil(blueColor) / 8.0);\n quad2.x = ceil(blueColor) - (quad2.y * 8.0);\n vec2 texPos1;\n texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\n texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\n vec2 texPos2;\n texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\n texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\n vec4 newColor1 = texture2D(lut, texPos1);\n vec4 newColor2 = texture2D(lut, texPos2);\n vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\n return newColor.rgb;\n}\n#endif\n@import clay.util.rgbm\nvoid main()\n{\n vec4 texel = vec4(0.0);\n vec4 originalTexel = vec4(0.0);\n#ifdef TEXTURE_ENABLED\n texel = decodeHDR(texture2D(texture, v_Texcoord));\n originalTexel = texel;\n#endif\n#ifdef BLOOM_ENABLED\n vec4 bloomTexel = decodeHDR(texture2D(bloom, v_Texcoord));\n texel.rgb += bloomTexel.rgb * bloomIntensity;\n texel.a += bloomTexel.a * bloomIntensity;\n#endif\n#ifdef LENSFLARE_ENABLED\n texel += decodeHDR(texture2D(lensflare, v_Texcoord)) * texture2D(lensdirt, v_Texcoord) * lensflareIntensity;\n#endif\n texel.a = min(texel.a, 1.0);\n#ifdef LUM_ENABLED\n float fLum = texture2D(lum, vec2(0.5, 0.5)).r;\n float adaptedLumDest = 3.0 / (max(0.1, 1.0 + 10.0*eyeAdaption(fLum)));\n float exposureBias = adaptedLumDest * exposure;\n#else\n float exposureBias = exposure;\n#endif\n texel.rgb *= exposureBias;\n texel.rgb = ACESToneMapping(texel.rgb);\n texel = linearTosRGB(texel);\n#ifdef LUT_ENABLED\n texel.rgb = lutTransform(clamp(texel.rgb,vec3(0.0),vec3(1.0)));\n#endif\n#ifdef COLOR_CORRECTION\n texel.rgb = clamp(texel.rgb + vec3(brightness), 0.0, 1.0);\n texel.rgb = clamp((texel.rgb - vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n float lum = dot(texel.rgb, vec3(0.2125, 0.7154, 0.0721));\n texel.rgb = mix(vec3(lum), texel.rgb, saturation);\n#endif\n#ifdef VIGNETTE\n vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(vignetteOffset);\n texel.rgb = mix(texel.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\n#endif\n gl_FragColor = encodeHDR(texel);\n#ifdef DEBUG\n #if DEBUG == 1\n gl_FragColor = encodeHDR(decodeHDR(texture2D(texture, v_Texcoord)));\n #elif DEBUG == 2\n gl_FragColor = encodeHDR(decodeHDR(texture2D(bloom, v_Texcoord)) * bloomIntensity);\n #elif DEBUG == 3\n gl_FragColor = encodeHDR(decodeHDR(texture2D(lensflare, v_Texcoord) * lensflareIntensity));\n #endif\n#endif\n if (originalTexel.a <= 0.01 && gl_FragColor.a > 1e-5) {\n gl_FragColor.a = dot(gl_FragColor.rgb, vec3(0.2125, 0.7154, 0.0721));\n }\n#ifdef PREMULTIPLY_ALPHA\n gl_FragColor.rgb *= gl_FragColor.a;\n#endif\n}\n@end"), -Y.import("@export clay.compositor.dof.coc\nuniform sampler2D depth;\nuniform float zNear: 0.1;\nuniform float zFar: 2000;\nuniform float focalDist: 3;\nuniform float focalRange: 1;\nuniform float focalLength: 30;\nuniform float fstop: 2.8;\nvarying vec2 v_Texcoord;\n@import clay.util.encode_float\nvoid main()\n{\n float z = texture2D(depth, v_Texcoord).r * 2.0 - 1.0;\n float dist = 2.0 * zNear * zFar / (zFar + zNear - z * (zFar - zNear));\n float aperture = focalLength / fstop;\n float coc;\n float uppper = focalDist + focalRange;\n float lower = focalDist - focalRange;\n if (dist <= uppper && dist >= lower) {\n coc = 0.5;\n }\n else {\n float focalAdjusted = dist > uppper ? uppper : lower;\n coc = abs(aperture * (focalLength * (dist - focalAdjusted)) / (dist * (focalAdjusted - focalLength)));\n coc = clamp(coc, 0.0, 0.4) / 0.4000001;\n if (dist < lower) {\n coc = -coc;\n }\n coc = coc * 0.5 + 0.5;\n }\n gl_FragColor = encodeFloat(coc);\n}\n@end\n@export clay.compositor.dof.premultiply\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nvoid main() {\n float fCoc = max(abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0), 0.1);\n gl_FragColor = encodeHDR(\n vec4(decodeHDR(texture2D(texture, v_Texcoord)).rgb * fCoc, 1.0)\n );\n}\n@end\n@export clay.compositor.dof.min_coc\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.float\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\n gl_FragColor = encodeFloat(fCoc);\n}\n@end\n@export clay.compositor.dof.max_coc\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.float\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\n gl_FragColor = encodeFloat(fCoc);\n}\n@end\n@export clay.compositor.dof.coc_upsample\n#define HIGH_QUALITY\nuniform sampler2D coc;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.float\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n float s;\n s = decodeFloat(texture2D(coc, v_Texcoord - d.xy));\n s += decodeFloat(texture2D(coc, v_Texcoord - d.wy)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord - d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zw)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord )) * 4.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xw)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.wy)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n gl_FragColor = encodeFloat(s / 16.0);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n float s;\n s = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xw));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zw));\n gl_FragColor = encodeFloat(s / 4.0);\n#endif\n}\n@end\n@export clay.compositor.dof.upsample\n#define HIGH_QUALITY\nuniform sampler2D coc;\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nfloat tap(vec2 uv, inout vec4 color, float baseWeight) {\n float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * baseWeight;\n color += decodeHDR(texture2D(texture, uv)) * weight;\n return weight;\n}\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n vec4 color = vec4(0.0);\n float baseWeight = 1.0 / 16.0;\n float w = tap(v_Texcoord - d.xy, color, baseWeight);\n w += tap(v_Texcoord - d.wy, color, baseWeight * 2.0);\n w += tap(v_Texcoord - d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.zw, color, baseWeight * 2.0);\n w += tap(v_Texcoord , color, baseWeight * 4.0);\n w += tap(v_Texcoord + d.xw, color, baseWeight * 2.0);\n w += tap(v_Texcoord + d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.wy, color, baseWeight * 2.0);\n w += tap(v_Texcoord + d.xy, color, baseWeight);\n gl_FragColor = encodeHDR(color / w);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n vec4 color = vec4(0.0);\n float baseWeight = 1.0 / 4.0;\n float w = tap(v_Texcoord + d.xy, color, baseWeight);\n w += tap(v_Texcoord + d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.xw, color, baseWeight);\n w += tap(v_Texcoord + d.zw, color, baseWeight);\n gl_FragColor = encodeHDR(color / w);\n#endif\n}\n@end\n@export clay.compositor.dof.downsample\nuniform sampler2D texture;\nuniform sampler2D coc;\nuniform vec2 textureSize : [512, 512];\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nfloat tap(vec2 uv, inout vec4 color) {\n float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * 0.25;\n color += decodeHDR(texture2D(texture, uv)) * weight;\n return weight;\n}\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n vec4 color = vec4(0.0);\n float weight = tap(v_Texcoord + d.xy, color);\n weight += tap(v_Texcoord + d.zy, color);\n weight += tap(v_Texcoord + d.xw, color);\n weight += tap(v_Texcoord + d.zw, color);\n color /= weight;\n gl_FragColor = encodeHDR(color);\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_frag\n@import clay.util.float\nvec4 doBlur(sampler2D targetTexture, vec2 offset) {\n#ifdef BLUR_COC\n float cocSum = 0.0;\n#else\n vec4 color = vec4(0.0);\n#endif\n float weightSum = 0.0;\n float kernelWeight = 1.0 / float(KERNEL_SIZE);\n for (int i = 0; i < KERNEL_SIZE; i++) {\n vec2 coord = v_Texcoord + offset * float(i);\n float w = kernelWeight;\n#ifdef BLUR_COC\n float fCoc = decodeFloat(texture2D(targetTexture, coord)) * 2.0 - 1.0;\n cocSum += clamp(fCoc, -1.0, 0.0) * w;\n#else\n float fCoc = decodeFloat(texture2D(coc, coord)) * 2.0 - 1.0;\n vec4 texel = texture2D(targetTexture, coord);\n #if !defined(BLUR_NEARFIELD)\n w *= abs(fCoc);\n #endif\n color += decodeHDR(texel) * w;\n#endif\n weightSum += w;\n }\n#ifdef BLUR_COC\n return encodeFloat(clamp(cocSum / weightSum, -1.0, 0.0) * 0.5 + 0.5);\n#else\n return color / weightSum;\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_1\n#define KERNEL_SIZE 5\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n gl_FragColor = doBlur(texture, vec2(0.0, offset.y));\n#if !defined(BLUR_COC)\n gl_FragColor = encodeHDR(gl_FragColor);\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_2\n#define KERNEL_SIZE 5\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n offset.y /= 2.0;\n gl_FragColor = doBlur(texture, -offset);\n#if !defined(BLUR_COC)\n gl_FragColor = encodeHDR(gl_FragColor);\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_3\n#define KERNEL_SIZE 5\nuniform sampler2D texture1;\nuniform sampler2D texture2;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n offset.y /= 2.0;\n vec2 vDownRight = vec2(offset.x, -offset.y);\n vec4 texel1 = doBlur(texture1, -offset);\n vec4 texel2 = doBlur(texture1, vDownRight);\n vec4 texel3 = doBlur(texture2, vDownRight);\n#ifdef BLUR_COC\n float coc1 = decodeFloat(texel1) * 2.0 - 1.0;\n float coc2 = decodeFloat(texel2) * 2.0 - 1.0;\n float coc3 = decodeFloat(texel3) * 2.0 - 1.0;\n gl_FragColor = encodeFloat(\n ((coc1 + coc2 + coc3) / 3.0) * 0.5 + 0.5\n );\n#else\n vec4 color = (texel1 + texel2 + texel3) / 3.0;\n gl_FragColor = encodeHDR(color);\n#endif\n}\n@end\n@export clay.compositor.dof.composite\n#define DEBUG 0\nuniform sampler2D original;\nuniform sampler2D blurred;\nuniform sampler2D nearfield;\nuniform sampler2D coc;\nuniform sampler2D nearcoc;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.float\nvoid main()\n{\n vec4 blurredColor = decodeHDR(texture2D(blurred, v_Texcoord));\n vec4 originalColor = decodeHDR(texture2D(original, v_Texcoord));\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord));\n fCoc = abs(fCoc * 2.0 - 1.0);\n float weight = smoothstep(0.0, 1.0, fCoc);\n#ifdef NEARFIELD_ENABLED\n vec4 nearfieldColor = decodeHDR(texture2D(nearfield, v_Texcoord));\n float fNearCoc = decodeFloat(texture2D(nearcoc, v_Texcoord));\n fNearCoc = abs(fNearCoc * 2.0 - 1.0);\n gl_FragColor = encodeHDR(\n mix(\n nearfieldColor, mix(originalColor, blurredColor, weight),\n pow(1.0 - fNearCoc, 4.0)\n )\n );\n#else\n gl_FragColor = encodeHDR(mix(originalColor, blurredColor, weight));\n#endif\n#if DEBUG == 1\n gl_FragColor = vec4(vec3(fCoc), 1.0);\n#elif DEBUG == 2\n gl_FragColor = vec4(vec3(fNearCoc), 1.0);\n#elif DEBUG == 3\n gl_FragColor = encodeHDR(blurredColor);\n#elif DEBUG == 4\n gl_FragColor = encodeHDR(nearfieldColor);\n#endif\n}\n@end"),Y.import("@export clay.compositor.lensflare\n#define SAMPLE_NUMBER 8\nuniform sampler2D texture;\nuniform sampler2D lenscolor;\nuniform vec2 textureSize : [512, 512];\nuniform float dispersal : 0.3;\nuniform float haloWidth : 0.4;\nuniform float distortion : 1.0;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nvec4 textureDistorted(\n in vec2 texcoord,\n in vec2 direction,\n in vec3 distortion\n) {\n return vec4(\n decodeHDR(texture2D(texture, texcoord + direction * distortion.r)).r,\n decodeHDR(texture2D(texture, texcoord + direction * distortion.g)).g,\n decodeHDR(texture2D(texture, texcoord + direction * distortion.b)).b,\n 1.0\n );\n}\nvoid main()\n{\n vec2 texcoord = -v_Texcoord + vec2(1.0); vec2 textureOffset = 1.0 / textureSize;\n vec2 ghostVec = (vec2(0.5) - texcoord) * dispersal;\n vec2 haloVec = normalize(ghostVec) * haloWidth;\n vec3 distortion = vec3(-textureOffset.x * distortion, 0.0, textureOffset.x * distortion);\n vec4 result = vec4(0.0);\n for (int i = 0; i < SAMPLE_NUMBER; i++)\n {\n vec2 offset = fract(texcoord + ghostVec * float(i));\n float weight = length(vec2(0.5) - offset) / length(vec2(0.5));\n weight = pow(1.0 - weight, 10.0);\n result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\n }\n result *= texture2D(lenscolor, vec2(length(vec2(0.5) - texcoord)) / length(vec2(0.5)));\n float weight = length(vec2(0.5) - fract(texcoord + haloVec)) / length(vec2(0.5));\n weight = pow(1.0 - weight, 10.0);\n vec2 offset = fract(texcoord + haloVec);\n result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\n gl_FragColor = result;\n}\n@end"),Y.import("@export clay.compositor.blend\n#define SHADER_NAME blend\n#ifdef TEXTURE1_ENABLED\nuniform sampler2D texture1;\nuniform float weight1 : 1.0;\n#endif\n#ifdef TEXTURE2_ENABLED\nuniform sampler2D texture2;\nuniform float weight2 : 1.0;\n#endif\n#ifdef TEXTURE3_ENABLED\nuniform sampler2D texture3;\nuniform float weight3 : 1.0;\n#endif\n#ifdef TEXTURE4_ENABLED\nuniform sampler2D texture4;\nuniform float weight4 : 1.0;\n#endif\n#ifdef TEXTURE5_ENABLED\nuniform sampler2D texture5;\nuniform float weight5 : 1.0;\n#endif\n#ifdef TEXTURE6_ENABLED\nuniform sampler2D texture6;\nuniform float weight6 : 1.0;\n#endif\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = vec4(0.0);\n#ifdef TEXTURE1_ENABLED\n tex += decodeHDR(texture2D(texture1, v_Texcoord)) * weight1;\n#endif\n#ifdef TEXTURE2_ENABLED\n tex += decodeHDR(texture2D(texture2, v_Texcoord)) * weight2;\n#endif\n#ifdef TEXTURE3_ENABLED\n tex += decodeHDR(texture2D(texture3, v_Texcoord)) * weight3;\n#endif\n#ifdef TEXTURE4_ENABLED\n tex += decodeHDR(texture2D(texture4, v_Texcoord)) * weight4;\n#endif\n#ifdef TEXTURE5_ENABLED\n tex += decodeHDR(texture2D(texture5, v_Texcoord)) * weight5;\n#endif\n#ifdef TEXTURE6_ENABLED\n tex += decodeHDR(texture2D(texture6, v_Texcoord)) * weight6;\n#endif\n gl_FragColor = encodeHDR(tex);\n}\n@end"),Y.import("@export clay.compositor.fxaa\nuniform sampler2D texture;\nuniform vec4 viewport : VIEWPORT;\nvarying vec2 v_Texcoord;\n#define FXAA_REDUCE_MIN (1.0/128.0)\n#define FXAA_REDUCE_MUL (1.0/8.0)\n#define FXAA_SPAN_MAX 8.0\n@import clay.util.rgbm\nvoid main()\n{\n vec2 resolution = 1.0 / viewport.zw;\n vec3 rgbNW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, -1.0 ) ) * resolution ) ).xyz;\n vec3 rgbNE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, -1.0 ) ) * resolution ) ).xyz;\n vec3 rgbSW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, 1.0 ) ) * resolution ) ).xyz;\n vec3 rgbSE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, 1.0 ) ) * resolution ) ).xyz;\n vec4 rgbaM = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution ) );\n vec3 rgbM = rgbaM.xyz;\n float opacity = rgbaM.w;\n vec3 luma = vec3( 0.299, 0.587, 0.114 );\n float lumaNW = dot( rgbNW, luma );\n float lumaNE = dot( rgbNE, luma );\n float lumaSW = dot( rgbSW, luma );\n float lumaSE = dot( rgbSE, luma );\n float lumaM = dot( rgbM, luma );\n float lumaMin = min( lumaM, min( min( lumaNW, lumaNE ), min( lumaSW, lumaSE ) ) );\n float lumaMax = max( lumaM, max( max( lumaNW, lumaNE) , max( lumaSW, lumaSE ) ) );\n vec2 dir;\n dir.x = -((lumaNW + lumaNE) - (lumaSW + lumaSE));\n dir.y = ((lumaNW + lumaSW) - (lumaNE + lumaSE));\n float dirReduce = max( ( lumaNW + lumaNE + lumaSW + lumaSE ) * ( 0.25 * FXAA_REDUCE_MUL ), FXAA_REDUCE_MIN );\n float rcpDirMin = 1.0 / ( min( abs( dir.x ), abs( dir.y ) ) + dirReduce );\n dir = min( vec2( FXAA_SPAN_MAX, FXAA_SPAN_MAX),\n max( vec2(-FXAA_SPAN_MAX, -FXAA_SPAN_MAX),\n dir * rcpDirMin)) * resolution;\n vec3 rgbA = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * ( 1.0 / 3.0 - 0.5 ) ) ).xyz;\n rgbA += decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * ( 2.0 / 3.0 - 0.5 ) ) ).xyz;\n rgbA *= 0.5;\n vec3 rgbB = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * -0.5 ) ).xyz;\n rgbB += decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * 0.5 ) ).xyz;\n rgbB *= 0.25;\n rgbB += rgbA * 0.5;\n float lumaB = dot( rgbB, luma );\n if ( ( lumaB < lumaMin ) || ( lumaB > lumaMax ) )\n {\n gl_FragColor = vec4( rgbA, opacity );\n }\n else {\n gl_FragColor = vec4( rgbB, opacity );\n }\n}\n@end"),Y.import("@export clay.compositor.fxaa3\nuniform sampler2D texture;\nuniform vec4 viewport : VIEWPORT;\nuniform float subpixel: 0.75;\nuniform float edgeThreshold: 0.125;\nuniform float edgeThresholdMin: 0.0625;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nfloat FxaaLuma(vec4 rgba) { return rgba.y; }\nvec4 FxaaPixelShader(\n vec2 pos\n ,sampler2D tex\n ,vec2 fxaaQualityRcpFrame\n ,float fxaaQualitySubpix\n ,float fxaaQualityEdgeThreshold\n ,float fxaaQualityEdgeThresholdMin\n) {\n vec2 posM;\n posM.x = pos.x;\n posM.y = pos.y;\n vec4 rgbyM = decodeHDR(texture2D(texture, posM, 0.0));\n float lumaS = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaN = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float maxSM = max(lumaS, rgbyM.y);\n float minSM = min(lumaS, rgbyM.y);\n float maxESM = max(lumaE, maxSM);\n float minESM = min(lumaE, minSM);\n float maxWN = max(lumaN, lumaW);\n float minWN = min(lumaN, lumaW);\n float rangeMax = max(maxWN, maxESM);\n float rangeMin = min(minWN, minESM);\n float rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;\n float range = rangeMax - rangeMin;\n float rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);\n bool earlyExit = range < rangeMaxClamped;\n if(earlyExit) return rgbyM;\n float lumaNW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaSE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaNE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaSW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaNS = lumaN + lumaS;\n float lumaWE = lumaW + lumaE;\n float subpixRcpRange = 1.0/range;\n float subpixNSWE = lumaNS + lumaWE;\n float edgeHorz1 = (-2.0 * rgbyM.y) + lumaNS;\n float edgeVert1 = (-2.0 * rgbyM.y) + lumaWE;\n float lumaNESE = lumaNE + lumaSE;\n float lumaNWNE = lumaNW + lumaNE;\n float edgeHorz2 = (-2.0 * lumaE) + lumaNESE;\n float edgeVert2 = (-2.0 * lumaN) + lumaNWNE;\n float lumaNWSW = lumaNW + lumaSW;\n float lumaSWSE = lumaSW + lumaSE;\n float edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);\n float edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);\n float edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;\n float edgeVert3 = (-2.0 * lumaS) + lumaSWSE;\n float edgeHorz = abs(edgeHorz3) + edgeHorz4;\n float edgeVert = abs(edgeVert3) + edgeVert4;\n float subpixNWSWNESE = lumaNWSW + lumaNESE;\n float lengthSign = fxaaQualityRcpFrame.x;\n bool horzSpan = edgeHorz >= edgeVert;\n float subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;\n if(!horzSpan) lumaN = lumaW;\n if(!horzSpan) lumaS = lumaE;\n if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;\n float subpixB = (subpixA * (1.0/12.0)) - rgbyM.y;\n float gradientN = lumaN - rgbyM.y;\n float gradientS = lumaS - rgbyM.y;\n float lumaNN = lumaN + rgbyM.y;\n float lumaSS = lumaS + rgbyM.y;\n bool pairN = abs(gradientN) >= abs(gradientS);\n float gradient = max(abs(gradientN), abs(gradientS));\n if(pairN) lengthSign = -lengthSign;\n float subpixC = clamp(abs(subpixB) * subpixRcpRange, 0.0, 1.0);\n vec2 posB;\n posB.x = posM.x;\n posB.y = posM.y;\n vec2 offNP;\n offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;\n offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;\n if(!horzSpan) posB.x += lengthSign * 0.5;\n if( horzSpan) posB.y += lengthSign * 0.5;\n vec2 posN;\n posN.x = posB.x - offNP.x * 1.0;\n posN.y = posB.y - offNP.y * 1.0;\n vec2 posP;\n posP.x = posB.x + offNP.x * 1.0;\n posP.y = posB.y + offNP.y * 1.0;\n float subpixD = ((-2.0)*subpixC) + 3.0;\n float lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN, 0.0)));\n float subpixE = subpixC * subpixC;\n float lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP, 0.0)));\n if(!pairN) lumaNN = lumaSS;\n float gradientScaled = gradient * 1.0/4.0;\n float lumaMM = rgbyM.y - lumaNN * 0.5;\n float subpixF = subpixD * subpixE;\n bool lumaMLTZero = lumaMM < 0.0;\n lumaEndN -= lumaNN * 0.5;\n lumaEndP -= lumaNN * 0.5;\n bool doneN = abs(lumaEndN) >= gradientScaled;\n bool doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 1.5;\n if(!doneN) posN.y -= offNP.y * 1.5;\n bool doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 1.5;\n if(!doneP) posP.y += offNP.y * 1.5;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 2.0;\n if(!doneN) posN.y -= offNP.y * 2.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 2.0;\n if(!doneP) posP.y += offNP.y * 2.0;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 4.0;\n if(!doneN) posN.y -= offNP.y * 4.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 4.0;\n if(!doneP) posP.y += offNP.y * 4.0;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 12.0;\n if(!doneN) posN.y -= offNP.y * 12.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 12.0;\n if(!doneP) posP.y += offNP.y * 12.0;\n }\n }\n }\n float dstN = posM.x - posN.x;\n float dstP = posP.x - posM.x;\n if(!horzSpan) dstN = posM.y - posN.y;\n if(!horzSpan) dstP = posP.y - posM.y;\n bool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;\n float spanLength = (dstP + dstN);\n bool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;\n float spanLengthRcp = 1.0/spanLength;\n bool directionN = dstN < dstP;\n float dst = min(dstN, dstP);\n bool goodSpan = directionN ? goodSpanN : goodSpanP;\n float subpixG = subpixF * subpixF;\n float pixelOffset = (dst * (-spanLengthRcp)) + 0.5;\n float subpixH = subpixG * fxaaQualitySubpix;\n float pixelOffsetGood = goodSpan ? pixelOffset : 0.0;\n float pixelOffsetSubpix = max(pixelOffsetGood, subpixH);\n if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;\n if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;\n return vec4(decodeHDR(texture2D(texture, posM, 0.0)).xyz, rgbyM.y);\n}\nvoid main()\n{\n vec4 color = FxaaPixelShader(\n v_Texcoord,\n texture,\n vec2(1.0) / viewport.zw,\n subpixel,\n edgeThreshold,\n edgeThresholdMin\n );\n gl_FragColor = vec4(color.rgb, 1.0);\n}\n@end");var ii={NORMAL:"normal",POSITION:"position",TEXCOORD_0:"texcoord0",TEXCOORD_1:"texcoord1",WEIGHTS_0:"weight",JOINTS_0:"joint",COLOR:"color"},ai={5120:He.Int8Array,5121:He.Uint8Array,5122:He.Int16Array,5123:He.Uint16Array,5125:He.Uint32Array,5126:He.Float32Array},oi={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},si=Me.extend({rootNode:null,rootPath:null,textureRootPath:null,bufferRootPath:null,shader:"clay.standard",useStandardMaterial:!1,includeCamera:!0,includeAnimation:!0,includeMesh:!0,includeTexture:!0,crossOrigin:"",textureFlipY:!1,shaderLibrary:null},function(){this.shaderLibrary||(this.shaderLibrary=Pn.createLibrary())},{load:function(t){var e=this,r=t.endsWith(".glb");null==this.rootPath&&(this.rootPath=t.slice(0,t.lastIndexOf("/"))),Gn.get({url:t,onprogress:function(t,r,n){e.trigger("progress",t,r,n)},onerror:function(t){e.trigger("error",t)},responseType:r?"arraybuffer":"text",onload:function(t){r?e.parseBinary(t):e.parse(JSON.parse(t))}})},parseBinary:function(t){var e=new Uint32Array(t,0,4);if(1179937895!==e[0])return void this.trigger("error","Invalid glTF binary format: Invalid header");if(e[0]<2)return void this.trigger("error","Only glTF2.0 is supported.");for(var r,n=new DataView(t,12),i=[],a=0;a1&&e.texParameterf(e.TEXTURE_CUBE_MAP,i.TEXTURE_MAX_ANISOTROPY_EXT,this.anisotropic),36193===n){t.getGLExtension("OES_texture_half_float")||(n=Fe.FLOAT)}if(this.mipmaps.length)for(var a=this.width,o=this.height,s=0;s=r.COLOR_ATTACHMENT0&&a<=r.COLOR_ATTACHMENT0+8&&i.push(a);n.drawBuffersEXT(i)}}this.trigger("beforerender",this,t);var o=this.clearDepth?r.DEPTH_BUFFER_BIT:0;if(r.depthMask(!0),this.clearColor){o|=r.COLOR_BUFFER_BIT,r.colorMask(!0,!0,!0,!0);var s=this.clearColor;Array.isArray(s)&&r.clearColor(s[0],s[1],s[2],s[3])}r.clear(o),this.blendWithPrevious?(r.enable(r.BLEND),this.material.transparent=!0):(r.disable(r.BLEND),this.material.transparent=!1),this.renderQuad(t),this.trigger("afterrender",this,t),e&&this.unbind(t,e)},renderQuad:function(t){Ti.material=this.material,t.renderPass([Ti],Ei)},dispose:function(t){}});Y.import(ni);var Ai=Un.extend(function(){var t=new Y({vertex:Y.source("clay.skybox.vertex"),fragment:Y.source("clay.skybox.fragment")}),e=new pr({shader:t,depthMask:!1});return{scene:null,geometry:new An,material:e,environmentMap:null,culling:!1}},function(){var t=this.scene;t&&this.attachScene(t),this.environmentMap&&this.setEnvironmentMap(this.environmentMap)},{attachScene:function(t){this.scene&&this.detachScene(),this.scene=t,t.on("beforerender",this._beforeRenderScene,this)},detachScene:function(){this.scene&&this.scene.off("beforerender",this._beforeRenderScene),this.scene=null},dispose:function(t){this.detachScene(),this.geometry.dispose(t)},setEnvironmentMap:function(t){this.material.set("environmentMap",t)},getEnvironmentMap:function(){return this.material.get("environmentMap")},_beforeRenderScene:function(t,e,r){this.renderSkybox(t,r)},renderSkybox:function(t,e){this.position.copy(e.getWorldPosition()),this.update(),t.gl.disable(t.gl.BLEND),t.renderPass([this],e)}}),Si=["px","nx","py","ny","pz","nz"],wi=Me.extend(function(){var t={position:new Ve,far:1e3,near:.1,texture:null,shadowMapPass:null},e=t._cameras={px:new kn({fov:90}),nx:new kn({fov:90}),py:new kn({fov:90}),ny:new kn({fov:90}),pz:new kn({fov:90}),nz:new kn({fov:90})};return e.px.lookAt(Ve.POSITIVE_X,Ve.NEGATIVE_Y),e.nx.lookAt(Ve.NEGATIVE_X,Ve.NEGATIVE_Y),e.py.lookAt(Ve.POSITIVE_Y,Ve.POSITIVE_Z),e.ny.lookAt(Ve.NEGATIVE_Y,Ve.NEGATIVE_Z),e.pz.lookAt(Ve.POSITIVE_Z,Ve.NEGATIVE_Y),e.nz.lookAt(Ve.NEGATIVE_Z,Ve.NEGATIVE_Y),t._frameBuffer=new yi,t},{getCamera:function(t){return this._cameras[t]},render:function(t,e,r){var n=t.gl;r||e.update();for(var i=this.texture.width,a=2*Math.atan(i/(i-.5))/Math.PI*180,o=0;o<6;o++){var s=Si[o],u=this._cameras[s];if(Ve.copy(u.position,this.position),u.far=this.far,u.near=this.near,u.fov=a,this.shadowMapPass){u.update();var l=e.getBoundingBox();l.applyTransform(u.viewMatrix),e.viewBoundingBoxLastFrame.copy(l),this.shadowMapPass.render(t,e,u,!0)}this._frameBuffer.attach(this.texture,n.COLOR_ATTACHMENT0,n.TEXTURE_CUBE_MAP_POSITIVE_X+o),this._frameBuffer.bind(t),t.render(e,u,!0),this._frameBuffer.unbind(t)}},dispose:function(t){this._frameBuffer.dispose(t)}});Y.import(ri);var Ci=Un.extend(function(){var t=new Y(Y.source("clay.basic.vertex"),Y.source("clay.basic.fragment")),e=new pr({shader:t,depthMask:!1});return e.enableTexture("diffuseMap"),{scene:null,geometry:new Sn({widthSegments:30,heightSegments:30}),material:e,environmentMap:null,culling:!1}},function(){var t=this.scene;t&&this.attachScene(t),this.environmentMap&&this.setEnvironmentMap(this.environmentMap)},{attachScene:function(t){this.scene&&this.detachScene(),this.scene=t,t.on("beforerender",this._beforeRenderScene,this)},detachScene:function(){this.scene&&this.scene.off("beforerender",this._beforeRenderScene),this.scene=null},_beforeRenderScene:function(t,e,r){this.position.copy(r.getWorldPosition()),this.update(),t.renderPass([this],r)},setEnvironmentMap:function(t){this.material.set("diffuseMap",t)},getEnvironmentMap:function(){return this.material.get("diffuseMap")},dispose:function(t){this.detachScene(),this.geometry.dispose(t)}}),Ni=ht("DXT1"),Mi=ht("DXT3"),Ri=ht("DXT5"),Li={parse:function(t,e){var r=new Int32Array(t,0,31);if(542327876!==r[0])return null;if(4&!r(20))return null;var n,i,a=r(21),o=r[4],s=r[3],u=512&r[28],l=131072&r[2];switch(a){case Ni:n=8,i=or.COMPRESSED_RGB_S3TC_DXT1_EXT;break;case Mi:n=16,i=or.COMPRESSED_RGBA_S3TC_DXT3_EXT;break;case Ri:n=16,i=or.COMPRESSED_RGBA_S3TC_DXT5_EXT;break;default:return null}var c=r[1]+4,h=u?6:1,f=1;l&&(f=Math.max(1,r[7]));for(var d=[],m=0;m=i)){a+=2;for(var o="";a20)return console.warn("Given image is not a height map"),t}var f,d,m,p;u%(4*n)==0?(f=o.data[u],m=o.data[u+4]):u%(4*n)==4*(n-1)?(f=o.data[u-4],m=o.data[u]):(f=o.data[u-4],m=o.data[u+4]),u<4*n?(d=o.data[u],p=o.data[u+4*n]):u>n*(i-1)*4?(d=o.data[u-4*n],p=o.data[u]):(d=o.data[u-4*n],p=o.data[u+4*n]),s.data[u]=f-m+127,s.data[u+1]=d-p+127,s.data[u+2]=255,s.data[u+3]=255}return a.putImageData(s,0,0),r},isHeightImage:function(t,e,r){if(!t||!t.width||!t.height)return!1;var n=document.createElement("canvas"),i=n.getContext("2d"),a=e||32;r=r||20,n.width=n.height=a,i.drawImage(t,0,0,a,a);for(var o=i.getImageData(0,0,a,a),s=0;sr)return!1}return!0},_fetchTexture:function(t,e,r){Gn.get({url:t,responseType:"arraybuffer",onload:e,onerror:r})},createChessboard:function(t,e,r,n){t=t||512,e=e||64,r=r||"black",n=n||"white";var i=Math.ceil(t/e),a=document.createElement("canvas");a.width=t,a.height=t;var o=a.getContext("2d");o.fillStyle=n,o.fillRect(0,0,t,t),o.fillStyle=r;for(var s=0;s 0.0) {\n prefilteredColor += decodeHDR(textureCube(environmentMap, L)).rgb * NoL;\n totalWeight += NoL;\n }\n }\n gl_FragColor = encodeHDR(vec4(prefilteredColor / totalWeight, 1.0));\n}\n"})});h.set("normalDistribution",n),r.encodeRGBM&&h.define("fragment","RGBM_ENCODE"),r.decodeRGBM&&h.define("fragment","RGBM_DECODE");var f,d=new pn;if(e instanceof Nn){var m=new mi({width:a,height:o,type:s===or.FLOAT?or.HALF_FLOAT:s});Bi.panoramaToCubeMap(t,e,m,{encodeRGBM:r.decodeRGBM}),e=m}f=new Ai({scene:d,material:h}),f.material.set("environmentMap",e);var p=new wi({texture:u});r.encodeRGBM&&(s=u.type=or.UNSIGNED_BYTE);for(var _=new Nn({width:a,height:o,type:s}),g=new yi({depthBuffer:!1}),v=He[s===or.UNSIGNED_BYTE?"Uint8Array":"Float32Array"],y=0;y 0.0) {\n float G = G_Smith(roughness, NoV, NoL);\n float G_Vis = G * VoH / (NoH * NoV);\n float Fc = pow(1.0 - VoH, 5.0);\n A += (1.0 - Fc) * G_Vis;\n B += Fc * G_Vis;\n }\n }\n gl_FragColor = vec4(vec2(A, B) / fSampleNumber, 0.0, 1.0);\n}\n"}),i=new Nn({width:512,height:256,type:or.HALF_FLOAT,minFilter:or.NEAREST,magFilter:or.NEAREST,useMipmap:!1});return n.setUniform("normalDistribution",e),n.setUniform("viewportSize",[512,256]),n.attachOutput(i),n.render(t,r),r.dispose(t),i},Fi.generateNormalDistribution=function(t,e){for(var t=t||256,e=e||1024,r=new Nn({width:t,height:e,type:or.FLOAT,minFilter:or.NEAREST,magFilter:or.NEAREST,useMipmap:!1}),n=new Float32Array(e*t*4),i=0;i>>16)>>>0;o=((1431655765&o)<<1|(2863311530&o)>>>1)>>>0,o=((858993459&o)<<2|(3435973836&o)>>>2)>>>0,o=((252645135&o)<<4|(4042322160&o)>>>4)>>>0,o=(((16711935&o)<<8|(4278255360&o)>>>8)>>>0)/4294967296;for(var s=0;s= shadowCascadeClipsNear[_idx_] &&\n depth <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n directionalLightShadowMaps[0], directionalLightMatrices[_idx_], position,\n directionalLightShadowMapSizes[0],\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n shadowContribs[0] = shadowContrib;\n }\n }}\n for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#else\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\n float shadowContrib;\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\n shadowContrib = computeShadowContrib(\n directionalLightShadowMaps[_idx_], directionalLightMatrices[_idx_], position,\n directionalLightShadowMapSizes[_idx_]\n );\n shadowContribs[_idx_] = shadowContrib;\n }}\n for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#endif\n#endif\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\nvoid computeShadowOfPointLights(vec3 position, inout float shadowContribs[POINT_LIGHT_COUNT] ){\n vec3 lightPosition;\n vec3 direction;\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\n lightPosition = pointLightPosition[_idx_];\n direction = position - lightPosition;\n shadowContribs[_idx_] = computeShadowContribOmni(pointLightShadowMaps[_idx_], direction, pointLightRange[_idx_]);\n }}\n for(int _idx_ = POINT_LIGHT_SHADOWMAP_COUNT; _idx_ < POINT_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#endif\n#endif\n@end");var ji=Me.extend(function(){return{softShadow:ji.PCF,shadowBlur:1,lightFrustumBias:"auto",kernelPCF:new Float32Array([1,0,1,1,-1,1,0,1,-1,0,-1,-1,1,-1,0,-1]),precision:"mediump",_lastRenderNotCastShadow:!1,_frameBuffer:new yi,_textures:{},_shadowMapNumber:{POINT_LIGHT:0,DIRECTIONAL_LIGHT:0,SPOT_LIGHT:0},_depthMaterials:{},_distanceMaterials:{},_opaqueCasters:[],_receivers:[],_lightsCastShadow:[],_lightCameras:{},_lightMaterials:{},_texturePool:new Gi}},function(){this._gaussianPassH=new bi({fragment:Y.source("clay.compositor.gaussian_blur")}),this._gaussianPassV=new bi({fragment:Y.source("clay.compositor.gaussian_blur")}),this._gaussianPassH.setUniform("blurSize",this.shadowBlur),this._gaussianPassH.setUniform("blurDir",0),this._gaussianPassV.setUniform("blurSize",this.shadowBlur),this._gaussianPassV.setUniform("blurDir",1),this._outputDepthPass=new bi({fragment:Y.source("clay.sm.debug_depth")})},{render:function(t,e,r,n){r||(r=e.getMainCamera()),this.trigger("beforerender",this,t,e,r),this._renderShadowPass(t,e,r,n),this.trigger("afterrender",this,t,e,r)},renderDebug:function(t,e){t.saveClear();var r=t.viewport,n=0,i=e||r.width/4,a=i;this.softShadow===ji.VSM?this._outputDepthPass.material.define("fragment","USE_VSM"):this._outputDepthPass.material.undefine("fragment","USE_VSM");for(var o in this._textures){var s=this._textures[o];t.setViewport(n,0,i*s.width/s.height,a),this._outputDepthPass.setUniform("depthMap",s),this._outputDepthPass.render(t),n+=i*s.width/s.height}t.setViewport(r),t.restoreClear()},_updateCasterAndReceiver:function(t,e){if(e.castShadow&&this._opaqueCasters.push(e),e.receiveShadow?(this._receivers.push(e),e.material.set("shadowEnabled",1),e.material.set("pcfKernel",this.kernelPCF)):e.material.set("shadowEnabled",0),!e.material.shader&&e.material.updateShader&&e.material.updateShader(t),this.softShadow===ji.VSM)e.material.define("fragment","USE_VSM"),e.material.undefine("fragment","PCF_KERNEL_SIZE");else{e.material.undefine("fragment","USE_VSM");var r=this.kernelPCF;r&&r.length?e.material.define("fragment","PCF_KERNEL_SIZE",r.length/2):e.material.undefine("fragment","PCF_KERNEL_SIZE")}},_update:function(t,e){for(var r=0;r4){console.warn("Support at most 4 cascade");continue}p.shadowCascade>1&&(s=p.shadowCascade),this.renderDirectionalLightShadow(t,e,r,p,this._opaqueCasters,f,h,c)}else p instanceof ci?this.renderSpotLightShadow(t,e,p,this._opaqueCasters,l,u):p instanceof li&&this.renderPointLightShadow(t,e,p,this._opaqueCasters,d);this._shadowMapNumber[p.type]++}for(var _ in this._shadowMapNumber)for(var g=this._shadowMapNumber[_],v=_+"_SHADOWMAP_COUNT",m=0;m0?x.define("fragment",v,g):x.isDefined("fragment",v)&&x.undefine("fragment",v))}for(var m=0;m0){var E=c.map(i);if(T.directionalLightShadowMaps={value:c,type:"tv"},T.directionalLightMatrices={value:h,type:"m4v"},T.directionalLightShadowMapSizes={value:E,type:"1fv"},s){var b=f.slice(),A=f.slice();b.pop(),A.shift(),b.reverse(),A.reverse(),h.reverse(),T.shadowCascadeClipsNear={value:b,type:"1fv"},T.shadowCascadeClipsFar={value:A,type:"1fv"}}}if(u.length>0){var S=u.map(i),T=e.shadowUniforms;T.spotLightShadowMaps={value:u,type:"tv"},T.spotLightMatrices={value:l,type:"m4v"},T.spotLightShadowMapSizes={value:S,type:"1fv"}}d.length>0&&(T.pointLightShadowMaps={value:d,type:"tv"})}},renderDirectionalLightShadow:function(){var t=new un,e=new rr,r=new Je,n=new rr,i=new rr,a=new rr,o=new rr;return function(s,u,l,c,h,f,d,m){var p=this._getDepthMaterial(c),_={getMaterial:function(t){return t.shadowDepthMaterial||p},sortCompare:Gr.opaqueSortCompare};if(!u.viewBoundingBoxLastFrame.isFinite()){var g=u.getBoundingBox();u.viewBoundingBoxLastFrame.copy(g).applyTransform(l.viewMatrix)}var v=Math.min(-u.viewBoundingBoxLastFrame.min.z,l.far),y=Math.max(-u.viewBoundingBoxLastFrame.max.z,l.near),x=this._getDirectionalLightCamera(c,u,l),T=a.array;o.copy(x.projectionMatrix),zi.invert(i.array,x.worldTransform.array),zi.multiply(i.array,i.array,l.worldTransform.array),zi.multiply(T,o.array,i.array);for(var E=[],b=l instanceof kn,A=(l.near+l.far)/(l.near-l.far),S=2*l.near*l.far/(l.near-l.far),w=0;w<=c.shadowCascade;w++){var C=y*Math.pow(v/y,w/c.shadowCascade),N=y+(v-y)*w/c.shadowCascade,M=C*c.cascadeSplitLogFactor+N*(1-c.cascadeSplitLogFactor);E.push(M),f.push(-(-M*A+S)/-M)}var R=this._getTexture(c,c.shadowCascade);m.push(R);var L=s.viewport,P=s.gl;this._frameBuffer.attach(R),this._frameBuffer.bind(s),P.clear(P.COLOR_BUFFER_BIT|P.DEPTH_BUFFER_BIT);for(var w=0;w=0&&x[v]>1e-4&&(qi.transformMat4(b,y,_[T[v]]),qi.scaleAndAdd(E,E,b,x[v]));A.set(g,E)}}for(var g=0;g0,l=e.color;e.depth=0,u&&sa.set(l,0,0,0,0);for(var c=!0,h=1/n,f=0;f-g&&m-g&&p-g&&_0){var _=f[0],b=(_[0]+1)*u,A=(1-_[1])*l;e.fillStyle=p,"rectangle"===T?e.fillRect(b-E,A-E,x,x):"circle"===T&&(e.beginPath(),e.arc(b,A,E,0,2*Math.PI),e.fill())}}}e.restore()},dispose:function(){this._triangles.clear(),this._lines.clear(),this._points.clear(),this._primitives=[],this.ctx=null,this.canvas=null}}),ha=Me.extend(function(){return{name:"",inputLinks:{},outputLinks:{},_prevOutputTextures:{},_outputTextures:{},_outputReferences:{},_rendering:!1,_rendered:!1,_compositor:null}},{updateParameter:function(t,e){var r=this.outputs[t],n=r.parameters,i=r._parametersCopy;if(i||(i=r._parametersCopy={}),n)for(var a in n)"width"!==a&&"height"!==a&&(i[a]=n[a]);var o,s;return o=n.width instanceof Function?n.width.call(this,e):n.width,s=n.height instanceof Function?n.height.call(this,e):n.height,i.width===o&&i.height===s||this._outputTextures[t]&&this._outputTextures[t].dispose(e.gl),i.width=o,i.height=s,i},setParameter:function(t,e){},getParameter:function(t){},setParameters:function(t){for(var e in t)this.setParameter(e,t[e])},render:function(){},getOutput:function(t,e){if(null==e)return e=t,this._outputTextures[e];var r=this.outputs[e];if(r)return this._rendered?r.outputLastFrame?this._prevOutputTextures[e]:this._outputTextures[e]:this._rendering?(this._prevOutputTextures[e]||(this._prevOutputTextures[e]=this._compositor.allocateTexture(r.parameters||{})),this._prevOutputTextures[e]):(this.render(t),this._outputTextures[e])},removeReference:function(t){if(0===--this._outputReferences[t]){this.outputs[t].keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}},link:function(t,e,r){this.inputLinks[t]={node:e,pin:r},e.outputLinks[r]||(e.outputLinks[r]=[]),e.outputLinks[r].push({node:this,pin:t}),this.pass.material.enableTexture(t)},clear:function(){this.inputLinks={},this.outputLinks={}},updateReference:function(t){if(!this._rendering){this._rendering=!0;for(var e in this.inputLinks){var r=this.inputLinks[e];r.node.updateReference(r.pin)}this._rendering=!1}t&&this._outputReferences[t]++},beforeFrame:function(){this._rendered=!1;for(var t in this.outputLinks)this._outputReferences[t]=0},afterFrame:function(){for(var t in this.outputLinks)if(this._outputReferences[t]>0){var e=this.outputs[t];e.keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}}}),fa=Me.extend(function(){return{nodes:[]}},{dirty:function(){this._dirty=!0},addNode:function(t){this.nodes.indexOf(t)>=0||(this.nodes.push(t),this._dirty=!0)},removeNode:function(t){"string"==typeof t&&(t=this.getNodeByName(t));var e=this.nodes.indexOf(t);e>=0&&(this.nodes.splice(e,1),this._dirty=!0)},getNodeByName:function(t){for(var e=0;e=e.COLOR_ATTACHMENT0&&u<=e.COLOR_ATTACHMENT0+8&&c.push(u);l.drawBuffersEXT(c)}t.saveClear(),t.clearBit=Fe.DEPTH_BUFFER_BIT|Fe.COLOR_BUFFER_BIT,r=t.render(this.scene,this.camera,!this.autoUpdateScene,this.preZ),t.restoreClear(),n.unbind(t)}else r=t.render(this.scene,this.camera,!this.autoUpdateScene,this.preZ);this.trigger("afterrender",r),this._rendering=!1,this._rendered=!0}}),pa=ha.extend(function(){return{texture:null,outputs:{color:{}}}},function(){},{getOutput:function(t,e){return this.texture},beforeFrame:function(){},afterFrame:function(){}}),_a=ha.extend(function(){return{name:"",inputs:{},outputs:null,shader:"",inputLinks:{},outputLinks:{},pass:null,_prevOutputTextures:{},_outputTextures:{},_outputReferences:{},_rendering:!1,_rendered:!1,_compositor:null}},function(){var t=new bi({fragment:this.shader});this.pass=t},{render:function(t,e){this.trigger("beforerender",t),this._rendering=!0;var r=t.gl;for(var n in this.inputLinks){var i=this.inputLinks[n],a=i.node.getOutput(t,i.pin);this.pass.setUniform(n,a)}if(this.outputs){this.pass.outputs={};var o={};for(var s in this.outputs){var u=this.updateParameter(s,t);isNaN(u.width)&&this.updateParameter(s,t);var l=this.outputs[s],c=this._compositor.allocateTexture(u);this._outputTextures[s]=c;var h=l.attachment||r.COLOR_ATTACHMENT0;"string"==typeof h&&(h=r[h]),o[h]=c}this._compositor.getFrameBuffer().bind(t);for(var h in o)this._compositor.getFrameBuffer().attach(o[h],h);this.pass.render(t),this._compositor.getFrameBuffer().updateMipmap(t.gl)}else this.pass.outputs=null,this._compositor.getFrameBuffer().unbind(t),this.pass.render(t,e);for(var n in this.inputLinks){var i=this.inputLinks[n];i.node.removeReference(i.pin)}this._rendering=!1,this._rendered=!0,this.trigger("afterrender",t)},updateParameter:function(t,e){var r=this.outputs[t],n=r.parameters,i=r._parametersCopy;if(i||(i=r._parametersCopy={}),n)for(var a in n)"width"!==a&&"height"!==a&&(i[a]=n[a]);var o,s;return o=n.width instanceof Function?n.width.call(this,e):n.width,s=n.height instanceof Function?n.height.call(this,e):n.height,i.width===o&&i.height===s||this._outputTextures[t]&&this._outputTextures[t].dispose(e),i.width=o,i.height=s,i},setParameter:function(t,e){this.pass.setUniform(t,e)},getParameter:function(t){return this.pass.getUniform(t)},setParameters:function(t){for(var e in t)this.setParameter(e,t[e])},define:function(t,e){this.pass.material.define("fragment",t,e)},undefine:function(t){this.pass.material.undefine("fragment",t)},removeReference:function(t){if(0===--this._outputReferences[t]){this.outputs[t].keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}},clear:function(){ha.prototype.clear.call(this),this.pass.material.disableTexturesAll()}}),ga=/^#source\((.*?)\)/;Y.import("@export clay.deferred.gbuffer.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat;\nuniform vec2 uvOffset;\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#ifdef FIRST_PASS\nattribute vec3 normal : NORMAL;\n#endif\n@import clay.chunk.skinning_header\n#ifdef FIRST_PASS\nvarying vec3 v_Normal;\nattribute vec4 tangent : TANGENT;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nvarying vec3 v_WorldPosition;\n#endif\nvarying vec2 v_Texcoord;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef FIRST_PASS\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n bool hasTangent = dot(tangent, tangent) > 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"),Y.import("@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end");var va=Me.extend(function(){return{enableTargetTexture1:!0,enableTargetTexture2:!0,enableTargetTexture3:!0,renderTransparent:!1,_renderList:[],_gBufferTex1:new Nn({minFilter:or.NEAREST,magFilter:or.NEAREST,type:or.HALF_FLOAT}),_gBufferTex2:new Nn({minFilter:or.NEAREST,magFilter:or.NEAREST,format:or.DEPTH_STENCIL,type:or.UNSIGNED_INT_24_8_WEBGL}),_gBufferTex3:new Nn({minFilter:or.NEAREST,magFilter:or.NEAREST}),_defaultNormalMap:new Nn({image:qt("#000")}),_defaultRoughnessMap:new Nn({image:qt("#fff")}),_defaultMetalnessMap:new Nn({image:qt("#fff")}),_defaultDiffuseMap:new Nn({image:qt("#fff")}),_frameBuffer:new yi,_gBufferMaterial1:new pr({shader:new Y(Y.source("clay.deferred.gbuffer.vertex"),Y.source("clay.deferred.gbuffer1.fragment")),vertexDefines:{FIRST_PASS:null},fragmentDefines:{FIRST_PASS:null}}),_gBufferMaterial2:new pr({shader:new Y(Y.source("clay.deferred.gbuffer.vertex"),Y.source("clay.deferred.gbuffer2.fragment"))}),_debugPass:new bi({fragment:Y.source("clay.deferred.gbuffer.debug")})}},{resize:function(t,e){this._gBufferTex1.width===t&&this._gBufferTex1.height===e||(this._gBufferTex1.width=t,this._gBufferTex1.height=e,this._gBufferTex2.width=t,this._gBufferTex2.height=e,this._gBufferTex3.width=t,this._gBufferTex3.height=e)},setViewport:function(t,e,r,n,i){var a;a="object"==typeof t?t:{x:t,y:e,width:r,height:n,devicePixelRatio:i||1},this._frameBuffer.viewport=a},getViewport:function(){return this._frameBuffer.viewport?this._frameBuffer.viewport:{x:0,y:0,width:this._gBufferTex1.width,height:this._gBufferTex1.height,devicePixelRatio:1}},update:function(t,e,r){for(var n=t.gl,i=this._frameBuffer,a=i.viewport,o=e.opaqueList,s=e.transparentList,u=0,l=this._renderList,c=0;c= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"),Y.import("@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"),Y.import("@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"), -Y.import("@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"),Y.import("@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"),Y.import("@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"),Y.import("@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"),Y.import(Br);var ba=Me.extend(function(){var t=Y.source("clay.compositor.vertex"),e=Y.source("clay.deferred.light_volume.vertex"),r=new Y(t,Y.source("clay.deferred.directional_light")),n=function(t){t.blendEquation(t.FUNC_ADD),t.blendFunc(t.ONE,t.ONE)},i=function(t){return new pr({shader:t,blend:n,transparent:!0,depthMask:!1})},a=function(t){return new Y(e,Y.source("clay.deferred."+t))},o=new Ta({capSegments:10}),s=new rr;s.rotateX(Math.PI/2).translate(new Ve(0,-1,0)),o.applyTransform(s);var u=new Ea({capSegments:10});return s.identity().rotateZ(Math.PI/2),u.applyTransform(s),{shadowMapPass:null,autoResize:!0,_createLightPassMat:i,_gBuffer:new va,_lightAccumFrameBuffer:new yi({depthBuffer:!1}),_lightAccumTex:new Nn({type:or.HALF_FLOAT,minFilter:or.NEAREST,magFilter:or.NEAREST}),_fullQuadPass:new bi({blendWithPrevious:!0}),_directionalLightMat:i(r),_ambientMat:i(new Y(t,Y.source("clay.deferred.ambient_light"))),_ambientSHMat:i(new Y(t,Y.source("clay.deferred.ambient_sh_light"))),_ambientCubemapMat:i(new Y(t,Y.source("clay.deferred.ambient_cubemap_light"))),_spotLightShader:a("spot_light"),_pointLightShader:a("point_light"),_sphereLightShader:a("sphere_light"),_tubeLightShader:a("tube_light"),_lightSphereGeo:new Sn({widthSegments:10,heightSegements:10}),_lightConeGeo:o,_lightCylinderGeo:u,_outputPass:new bi({fragment:Y.source("clay.compositor.output")})}},{render:function(t,e,r,n){n=n||{},n.renderToTarget=n.renderToTarget||!1,n.notUpdateShadow=n.notUpdateShadow||!1,n.notUpdateScene=n.notUpdateScene||!1,n.notUpdateScene||e.update(!1,!0),r.update(!0);var i=t.getDevicePixelRatio();!this.autoResize||t.getWidth()*i===this._lightAccumTex.width&&t.getHeight()*i===this._lightAccumTex.height||this.resize(t.getWidth()*i,t.getHeight()*i),this._gBuffer.update(t,e,r),this._accumulateLightBuffer(t,e,r,!n.notUpdateShadow),n.renderToTarget||(this._outputPass.setUniform("texture",this._lightAccumTex),this._outputPass.render(t))},getTargetTexture:function(){return this._lightAccumTex},getTargetFrameBuffer:function(){return this._lightAccumFrameBuffer},getGBuffer:function(){return this._gBuffer},setViewport:function(t,e,r,n,i){this._gBuffer.setViewport(t,e,r,n,i),this._lightAccumFrameBuffer.viewport=this._gBuffer.getViewport()},resize:function(t,e){this._lightAccumTex.width=t,this._lightAccumTex.height=e,this._gBuffer.resize(t,e)},_accumulateLightBuffer:function(t,e,r,n){for(var i=t.gl,a=this._lightAccumTex,o=this._lightAccumFrameBuffer,s=r.getWorldPosition().array,u=0;u0&&qa.scaleAndAdd(t.array,t.array,this.force.array,n/r)}}) -;Y.import("@export clay.particle.vertex\nuniform mat4 worldView : WORLDVIEW;\nuniform mat4 projection : PROJECTION;\nattribute vec3 position : POSITION;\nattribute vec3 normal : NORMAL;\n#ifdef UV_ANIMATION\nattribute vec2 texcoord0 : TEXCOORD_0;\nattribute vec2 texcoord1 : TEXCOORD_1;\nvarying vec2 v_Uv0;\nvarying vec2 v_Uv1;\n#endif\nvarying float v_Age;\nvoid main() {\n v_Age = normal.x;\n float rotation = normal.y;\n vec4 worldViewPosition = worldView * vec4(position, 1.0);\n gl_Position = projection * worldViewPosition;\n float w = gl_Position.w;\n gl_PointSize = normal.z * projection[0].x / w;\n #ifdef UV_ANIMATION\n v_Uv0 = texcoord0;\n v_Uv1 = texcoord1;\n #endif\n}\n@end\n@export clay.particle.fragment\nuniform sampler2D sprite;\nuniform sampler2D gradient;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\nvarying float v_Age;\n#ifdef UV_ANIMATION\nvarying vec2 v_Uv0;\nvarying vec2 v_Uv1;\n#endif\nvoid main() {\n vec4 color = vec4(color, alpha);\n #ifdef SPRITE_ENABLED\n #ifdef UV_ANIMATION\n color *= texture2D(sprite, mix(v_Uv0, v_Uv1, gl_PointCoord));\n #else\n color *= texture2D(sprite, gl_PointCoord);\n #endif\n #endif\n #ifdef GRADIENT_ENABLED\n color *= texture2D(gradient, vec2(v_Age, 0.5));\n #endif\n gl_FragColor = color;\n}\n@end");var Ka=new Y(Y.source("clay.particle.vertex"),Y.source("clay.particle.fragment")),Za=Fn.extend({loop:!0,oneshot:!1,duration:1,spriteAnimationTileX:1,spriteAnimationTileY:1,spriteAnimationRepeat:0,mode:Fn.POINTS,ignorePicking:!0,_elapsedTime:0,_emitting:!0},function(){this.geometry=new Tn({dynamic:!0}),this.material||(this.material=new pr({shader:Ka,transparent:!0,depthMask:!1}),this.material.enableTexture("sprite")),this._particles=[],this._fields=[],this._emitters=[]},{culling:!1,frustumCulling:!1,castShadow:!1,receiveShadow:!1,addEmitter:function(t){this._emitters.push(t)},removeEmitter:function(t){this._emitters.splice(this._emitters.indexOf(t),1)},addField:function(t){this._fields.push(t)},removeField:function(t){this._fields.splice(this._fields.indexOf(t),1)},reset:function(){for(var t=0;t=i.life?(i.emitter.kill(i),e[r]=e[n-1],e.pop(),n--):r++}for(var r=0;r0)for(var a=0;a1,o=t.attributes.position.value,s=t.attributes.normal.value,u=t.attributes.texcoord0.value,l=t.attributes.texcoord1.value,c=this._particles.length;o&&o.length===3*c||(o=t.attributes.position.value=new Float32Array(3*c),s=t.attributes.normal.value=new Float32Array(3*c),a&&(u=t.attributes.texcoord0.value=new Float32Array(2*c),l=t.attributes.texcoord1.value=new Float32Array(2*c)));for(var h=1/e,f=0;fthis.duration&&!this.loop},dispose:function(t){for(var e=0;e1&&n&&n.length>1){var a=$t(n)/$t(i);!isFinite(a)&&(a=1),e.pinchScale=a;var o=te(n);return e.pinchX=o[0],e.pinchY=o[1],{type:"pinch",target:t[0].target,event:e}}}}},eo=[[0,0],[0,1],[1,1],[1,0]],ro=[0,1,2,2,3,0],no=Un.extend({camera:null,plane:null,maxGrid:0,frustumCulling:!1},function(){var t=this.geometry=new Tn({dynamic:!0});t.attributes.position.init(6),t.attributes.normal.init(6),t.attributes.texcoord0.init(6),t.indices=new Uint16Array(6),this.plane=new tn},{updateGeometry:function(){var t=this._unProjectGrid();if(t){for(var e=this.geometry.attributes.position,r=this.geometry.attributes.normal,n=this.geometry.attributes.texcoord0,i=this.geometry.indices,a=0;a<6;a++){var o=ro[a];e.set(a,t[o].array),r.set(a,this.plane.normal.array),n.set(a,eo[o]),i[a]=a}this.geometry.dirty()}},_unProjectGrid:function(){for(var t=new tn,e=[0,1,0,2,1,3,2,3,4,5,4,6,5,7,6,7,0,4,1,5,2,6,3,7],r=new Ve,n=new Ve,i=[],a=[],o=0;o<4;o++)a[o]=new Ve(0,0);var s=new cn;return function(){t.copy(this.plane),t.applyTransform(this.camera.viewMatrix);for(var o=this.camera.frustum.vertices,u=0,l=0;l<12;l++){r.array=o[e[2*l]],n.array=o[e[2*l+1]];var c=t.intersectLine(r,n,i[u]);c&&(i[u]||(i[u]=c),u++)}if(0!==u){for(var l=0;l0},update:function(t){if(t=t||16,this._rotating){var e=("cw"===this.autoRotateDirection?1:-1)*this.autoRotateSpeed/180*Math.PI;this._phi-=e*t/1e3,this._needsUpdate=!0}else this._rotateVelocity.len()>0&&(this._needsUpdate=!0);(Math.abs(this._zoomSpeed)>.01||this._panVelocity.len()>0)&&(this._needsUpdate=!0),this._needsUpdate&&(this._updateDistance(Math.min(t,50)),this._updatePan(Math.min(t,50)),this._updateRotate(Math.min(t,50)),this._updateTransform(),this.target.update(),this.trigger("update"),this._needsUpdate=!1)},_updateRotate:function(t){var e=this._rotateVelocity;this._phi=e.y*t/20+this._phi,this._theta=e.x*t/20+this._theta,this.setAlpha(this.getAlpha()),this.setBeta(this.getBeta()),this._vectorDamping(e,this.damping)},_updateDistance:function(t){this._setDistance(this._distance+this._zoomSpeed*t/20),this._zoomSpeed*=this.damping},_setDistance:function(t){this._distance=Math.max(Math.min(t,this.maxDistance),this.minDistance)},_updatePan:function(t){var e=this._panVelocity,r=this._distance,n=this.target,i=n.worldTransform.y,a=n.worldTransform.x;this._center.scaleAndAdd(a,-e.x*r/200).scaleAndAdd(i,-e.y*r/200),this._vectorDamping(e,0)},_updateTransform:function(){var t=this.target,e=new Ve,r=this._theta+Math.PI/2,n=this._phi+Math.PI/2,i=Math.sin(r);e.x=i*Math.cos(n),e.y=-Math.cos(r),e.z=i*Math.sin(n),t.position.copy(this._center).scaleAndAdd(e,this._distance),t.rotation.identity().rotateY(-this._phi).rotateX(-this._theta)},_startCountingStill:function(){clearTimeout(this._stillTimeout);var t=this.autoRotateAfterStill,e=this;!isNaN(t)&&t>0&&(this._stillTimeout=setTimeout(function(){e._rotating=!0},1e3*t))},_vectorDamping:function(t,e){var r=t.len();r*=e,r<1e-4&&(r=0),t.normalize().scale(r)},decomposeTransform:function(){if(this.target){this.target.updateWorldTransform();var t=this.target.worldTransform.z,e=Math.asin(t.y),r=Math.atan2(t.x,t.z);this._theta=e,this._phi=-r,this.setBeta(this.getBeta()),this.setAlpha(this.getAlpha()),this._setDistance(this.target.position.dist(this._center))}},_mouseDownHandler:function(t){if(!this._isAnimating()){var e=t.clientX,r=t.clientY;if(t.targetTouches){var n=t.targetTouches[0];e=n.clientX,r=n.clientY,this._mode="rotate",this._processGesture(t,"start")}var i=this.domElement;i.addEventListener("touchmove",this._mouseMoveHandler),i.addEventListener("touchend",this._mouseUpHandler),i.addEventListener("mousemove",this._mouseMoveHandler),i.addEventListener("mouseup",this._mouseUpHandler),0===t.button?this._mode="rotate":1===t.button&&(this._mode="pan"),this._rotateVelocity.set(0,0),this._rotating=!1,this.autoRotate&&this._startCountingStill(),this._mouseX=e,this._mouseY=r}},_mouseMoveHandler:function(t){if(!this._isAnimating()){var e,r=t.clientX,n=t.clientY;if(t.targetTouches){var i=t.targetTouches[0];r=i.clientX,n=i.clientY,e=this._processGesture(t,"change")}var a=ee(this.panSensitivity),o=ee(this.rotateSensitivity);e||("rotate"===this._mode?(this._rotateVelocity.y=(r-this._mouseX)/this.domElement.clientHeight*2*o[0],this._rotateVelocity.x=(n-this._mouseY)/this.domElement.clientWidth*2*o[1]):"pan"===this._mode&&(this._panVelocity.x=(r-this._mouseX)/this.domElement.clientWidth*a[0]*400,this._panVelocity.y=(-n+this._mouseY)/this.domElement.clientHeight*a[1]*400)),this._mouseX=r,this._mouseY=n,t.preventDefault()}},_mouseWheelHandler:function(t){if(!this._isAnimating()){var e=t.wheelDelta||-t.detail;0!==e&&this._zoomHandler(t,e>0?-1:1)}},_pinchHandler:function(t){this._isAnimating()||this._zoomHandler(t,t.pinchScale>1?-.4:.4)},_zoomHandler:function(t,e){var r=Math.max(Math.min(this._distance-this.minDistance,this.maxDistance-this._distance));this._zoomSpeed=e*Math.max(r/40*this.zoomSensitivity,.2),this._rotating=!1,this.autoRotate&&"rotate"===this._mode&&this._startCountingStill(),t.preventDefault()},_mouseUpHandler:function(t){var e=this.domElement;e.removeEventListener("touchmove",this._mouseMoveHandler),e.removeEventListener("touchend",this._mouseUpHandler),e.removeEventListener("mousemove",this._mouseMoveHandler),e.removeEventListener("mouseup",this._mouseUpHandler),this._processGesture(t,"end")},_addAnimator:function(t){var e=this._animators;return e.push(t),t.done(function(){var r=e.indexOf(t);r>=0&&e.splice(r,1)}),t},_processGesture:function(t,e){var r=this._gestureMgr;"start"===e&&r.clear();var n=r.recognize(t,null,this.domElement);if("end"===e&&r.clear(),n){var i=n.type;t.gestureEvent=i,this._pinchHandler(n.event)}return n}});Object.defineProperty(io.prototype,"autoRotate",{get:function(){return this._autoRotate},set:function(t){this._autoRotate=t,this._rotating=t}}),Object.defineProperty(io.prototype,"target",{get:function(){return this._target},set:function(t){t&&t.target&&this.setCenter(t.target.toArray()),this._target=t,this.decomposeTransform()}});var ao=Tn.extend({dynamic:!1}),oo=fe.mat4,so=fe.vec3,uo={merge:function(t,e){if(t.length){var r=t[0],n=r.geometry,i=r.material,a=new Tn({dynamic:!1});a.boundingBox=new Je;for(var o=n.getEnabledAttributes(),s=0;s=65535?new Uint32Array(3*f):new Uint16Array(3*f);for(var _=0,g=0,v=n.isUseIndices(),y=0;y0;){for(var _=[],g=[],v=[],y=0,f=0;f=0&&-1===g[S]&&(y65535?new Uint32Array(3*R.triangles.length):new Uint16Array(3*R.triangles.length);var G=0;O=0;for(var f=0;f=0?L[S]:-1}O++}D.indices[G++]=N[b]}D.updateBoundingBox(),w.add(I)}for(var j=t.children(),f=0;f0&&(r.indices=ne(t.indices,e),n.push(r.indices.buffer)),r.attributes={};for(var i in t.attributes)if(t.attributes.hasOwnProperty(i)){var a=t.attributes[i];a&&a.value&&a.value.length>0&&(a=r.attributes[i]=re(a,e),n.push(a.value.buffer))}return{data:r,buffers:n}},toGeometry:function(t){if(!t)return null;if(t.data&&t.buffers)return co.toGeometry(t.data);if(!t.metadata||t.metadata.generator!==lo.generator)throw new Error("[util.transferable.toGeometry] the object is not generated by util.transferable.");var e={dynamic:t.dynamic,indices:t.indices};if(t.boundingBox){var r=(new Ve).setArray(t.boundingBox.min),n=(new Ve).setArray(t.boundingBox.max);e.boundingBox=new Je(r,n)}var i={};for(var a in t.attributes)if(t.attributes.hasOwnProperty(a)){var o=t.attributes[a];i[a]=new Tn.Attribute(o.name,o.type,o.size,o.semantic),i[a].value=o.value}return e.attributes=i,new Tn(e)}};Y.import("@export clay.vr.disorter.output.vertex\nattribute vec2 texcoord: TEXCOORD_0;\nattribute vec3 position: POSITION;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n v_Texcoord = texcoord;\n gl_Position = vec4(position.xy, 0.5, 1.0);\n}\n@end\n@export clay.vr.disorter.output.fragment\nuniform sampler2D texture;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n gl_FragColor = texture2D(texture, v_Texcoord);\n}\n@end");var ho=Me.extend(function(){return{clearColor:[0,0,0,1],_mesh:new Un({geometry:new Tn({dynamic:!0}),culling:!1,material:new pr({depthTest:!1,shader:new Y({vertex:Y.source("clay.vr.disorter.output.vertex"),fragment:Y.source("clay.vr.disorter.output.fragment")})})}),_fakeCamera:new kn}},{render:function(t,e){var r=this.clearColor,n=t.gl;n.clearColor(r[0],r[1],r[2],r[3]),n.clear(n.COLOR_BUFFER_BIT),n.disable(n.BLEND),this._mesh.material.set("texture",e),t.saveViewport(),t.setViewport(0,0,t.getWidth(),t.getHeight()),t.renderPass([this._mesh],this._fakeCamera),t.restoreViewport()},updateFromVRDisplay:function(t){t.deviceInfo_?this._updateMesh(20,20,t.deviceInfo_):console.warn("Cant get vrDisplay.deviceInfo_, seems code changed")},_updateMesh:function(t,e,r){var n=this._mesh.geometry.attributes.position,i=this._mesh.geometry.attributes.texcoord0;n.init(2*t*e),i.init(2*t*e);for(var a=r.getLeftEyeVisibleTanAngles(),o=r.getLeftEyeNoLensTanAngles(),s=r.getLeftEyeVisibleScreenRect(o),u=0,l=[],c=[],h=0;h<2;h++){for(var f=0;fi)t.length=i;else for(var a=n;a=0&&!(T[w]<=e);w--);w=Math.min(w,g-2)}else{for(w=O;we);w++);w=Math.min(w-1,g-2)}O=w,B=e;var r=T[w+1]-T[w];0!==r&&(R=(e-T[w])/r,R=Math.max(Math.min(1,R),0),R=b[w+1](R),_?(P=E[w],L=E[0===w?w:w-1],D=E[w>g-2?g-1:w+1],I=E[w>g-3?g-1:w+2],f?p(t,s,f(m(t,s),L,P,D,I,R)):y?u(L,P,D,I,R,R*R,R*R*R,m(t,s),x):p(t,s,l(L,P,D,I,R,R*R,R*R*R))):f?p(t,s,f(m(t,s),E[w],E[w+1],R)):y?a(E[w],E[w+1],R,m(t,s),x):p(t,s,i(E[w],E[w+1],R)))},U=new le({target:t._target,life:d,loop:t._loop,delay:t._delay,onframe:F,onfinish:r});return e&&"spline"!==e&&U.setEasing(e),U}}}function d(t,e,i,a,o){this._tracks={},this._target=t,this._loop=e||!1,this._getter=i||r,this._setter=a||n,this._interpolater=o||null,this._delay=0,this._doneList=[],this._onframeList=[],this._clipList=[],this._maxTime=0,this._lastKFTime=0}function m(t){return t}function p(t){var e,r,n,i,a,o,s=Number.POSITIVE_INFINITY,u=Number.POSITIVE_INFINITY,l=Number.NEGATIVE_INFINITY,c=Number.NEGATIVE_INFINITY;for(e=t.length;e--;)t[e][0]l&&(l=t[e][0]),t[e][1]c&&(c=t[e][1]);return r=l-s,n=c-u,i=Math.max(r,n),a=s+.5*r,o=u+.5*n,[[a-20*i,o-i],[a,o+20*i],[a+20*i,o-i]]}function _(t,e,r,n){var i,a,o,s,u,l,c,h,f,d,m=t[e][0],p=t[e][1],_=t[r][0],g=t[r][1],v=t[n][0],y=t[n][1],x=Math.abs(p-g),T=Math.abs(g-y);if(xT?o*(i-u)+c:s*(i-l)+h),f=_-i,d=g-a,{i:e,j:r,k:n,x:i,y:a,r:f*f+d*d}}function g(t){var e,r,n,i,a,o;for(r=t.length;r;)for(i=t[--r],n=t[--r],e=r;e;)if(o=t[--e],a=t[--e],n===a&&i===o||n===o&&i===a){t.splice(r,2),t.splice(e,2);break}}function v(t,e){return t.time-e.time}function y(t,e,r,n,i,a){var o=e[i],s=e[i+1],u=e[i+2];return t[0]=o+n*(r[a]-o),t[1]=s+n*(r[a+1]-s),t[2]=u+n*(r[a+2]-u),t}function x(t,e,r,n,i,a){var o,s,u,l,c,h=e[0+i],f=e[1+i],d=e[2+i],m=e[3+i],p=r[0+a],_=r[1+a],g=r[2+a],v=r[3+a];return s=h*p+f*_+d*g+m*v,s<0&&(s=-s,p=-p,_=-_,g=-g,v=-v),1-s>1e-6?(o=Math.acos(s),u=Math.sin(o),l=Math.sin((1-n)*o)/u,c=Math.sin(n*o)/u):(l=1-n,c=n),t[0]=l*h+c*p,t[1]=l*f+c*_,t[2]=l*d+c*g,t[3]=l*m+c*v,t}function T(t,e,r){"object"==typeof e&&(r=e,e=null);var n,i=this;if(!(t instanceof Function)){n=[];for(var a in t)t.hasOwnProperty(a)&&n.push(a)}var o=function(e){if(i.apply(this,arguments),t instanceof Function?E(this,t.call(this,e)):b(this,t,n),this.constructor===o)for(var r=o.__initializers__,a=0;ar?r:t}function M(t){return t=Math.round(t),t<0?0:t>255?255:t}function C(t){return t=Math.round(t),t<0?0:t>360?360:t}function N(t){return t<0?0:t>1?1:t}function R(t){return M(t.length&&"%"===t.charAt(t.length-1)?parseFloat(t)/100*255:parseInt(t,10))}function L(t){return N(t.length&&"%"===t.charAt(t.length-1)?parseFloat(t)/100:parseFloat(t))}function P(t,e,r){return r<0?r+=1:r>1&&(r-=1),6*r<1?t+(e-t)*r*6:2*r<1?e:3*r<2?t+(e-t)*(2/3-r)*6:t}function D(t,e,r){return t+(e-t)*r}function I(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function O(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function B(t,e){pr&&O(pr,e),pr=mr.put(t,pr||e.slice())}function F(t,e){var r=(parseFloat(t[0])%360+360)%360/360,n=L(t[1]),i=L(t[2]),a=i<=.5?i*(n+1):i+n-i*n,o=2*i-a;return e=e||[],I(e,M(255*P(o,a,r+1/3)),M(255*P(o,a,r)),M(255*P(o,a,r-1/3)),1),4===t.length&&(e[3]=t[3]),e}function U(t){if(t){var e,r,n=t[0]/255,i=t[1]/255,a=t[2]/255,o=Math.min(n,i,a),s=Math.max(n,i,a),u=s-o,l=(s+o)/2;if(0===u)e=0,r=0;else{r=l<.5?u/(s+o):u/(2-s-o);var c=((s-n)/6+u/2)/u,h=((s-i)/6+u/2)/u,f=((s-a)/6+u/2)/u;n===s?e=f-h:i===s?e=1/3+c-f:a===s&&(e=2/3+h-c),e<0&&(e+=1),e>1&&(e-=1)}var d=[360*e,r,l];return null!=t[3]&&d.push(t[3]),d}}function k(t,e,r){var n=Object.keys(t);n.sort();for(var i=[],a=0;a0&&n.push("#define "+i.toUpperCase()+"_COUNT "+a)}if(r)for(var o=0;o=400?t.onerror&&t.onerror():t.onload&&t.onload(e.response)},t.onerror&&(e.onerror=t.onerror),e.send(null)}function ht(t,e,r,n){var i=t.accessors[r],a=e.bufferViews[i.bufferView],o=i.byteOffset||0,s=fi[i.componentType]||We.Float32Array,u=di[i.type];null==u&&n&&(u=1);var l=new s(a,o,u*i.count),c=i.extensions&&i.extensions.WEB3D_quantized_attributes;if(c){for(var h,f,d=new We.Float32Array(u*i.count),m=c.decodeMatrix,h=new Array(u),f=new Array(u),p=0;p0){var i=Math.pow(2,t[3]-128-8+n);e[r+0]=t[0]*i,e[r+1]=t[1]*i,e[r+2]=t[2]*i}else e[r+0]=0,e[r+1]=0,e[r+2]=0;return e[r+3]=1,e}function mt(t,e,r){for(var n="",i=e;i0;)if(t[a][0]=e[r++],t[a][1]=e[r++],t[a][2]=e[r++],t[a][3]=e[r++],1===t[a][0]&&1===t[a][1]&&1===t[a][2]){for(var s=t[a][3]<>>0;s>0;s--)pt(t[a-1],t[a]),a++,o--;i+=8}else a++,o--,i=0;return r}function gt(t,e,r,n){if(nUi)return _t(t,e,r,n);var i=e[r++];if(2!=i)return _t(t,e,r-1,n);if(t[0][1]=e[r++],t[0][2]=e[r++],i=e[r++],(t[0][2]<<8>>>0|i)>>>0!==n)return null;for(var i=0;i<4;i++)for(var a=0;a128){o=(127&o)>>>0;for(var s=e[r++];o--;)t[a++][i]=s}else for(;o--;)t[a++][i]=e[r++]}return r}function vt(t){Le.defaultsWithPropList(t,ji,qi),yt(t);for(var e="",r=0;r>16,r=t-(e<<8)>>8;return[e,r,t-(e<<16)-(r<<8)]}function ee(t,e,r){return(t<<16)+(e<<8)+r}function re(t){var e=t[1][0]-t[0][0],r=t[1][1]-t[0][1];return Math.sqrt(e*e+r*r)}function ne(t){return[(t[0][0]+t[1][0])/2,(t[0][1]+t[1][1])/2]}function ie(t){return Array.isArray(t)||(t=[t,t]),t}function ae(t,e){return{name:t.name,type:t.type,size:t.size,semantic:t.semantic,value:oe(t.value,e)}}function oe(t,e){return e?t:new t.constructor(t)}function se(t,e,r){return t*(1-r)+e*r}var ue={linear:function(t){return t},quadraticIn:function(t){return t*t},quadraticOut:function(t){return t*(2-t)},quadraticInOut:function(t){return(t*=2)<1?.5*t*t:-.5*(--t*(t-2)-1)},cubicIn:function(t){return t*t*t},cubicOut:function(t){return--t*t*t+1},cubicInOut:function(t){return(t*=2)<1?.5*t*t*t:.5*((t-=2)*t*t+2)},quarticIn:function(t){return t*t*t*t},quarticOut:function(t){return 1- --t*t*t*t},quarticInOut:function(t){return(t*=2)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2)},quinticIn:function(t){return t*t*t*t*t},quinticOut:function(t){return--t*t*t*t*t+1},quinticInOut:function(t){return(t*=2)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2)},sinusoidalIn:function(t){return 1-Math.cos(t*Math.PI/2)},sinusoidalOut:function(t){return Math.sin(t*Math.PI/2)},sinusoidalInOut:function(t){return.5*(1-Math.cos(Math.PI*t))},exponentialIn:function(t){return 0===t?0:Math.pow(1024,t-1)},exponentialOut:function(t){return 1===t?1:1-Math.pow(2,-10*t)},exponentialInOut:function(t){return 0===t?0:1===t?1:(t*=2)<1?.5*Math.pow(1024,t-1):.5*(2-Math.pow(2,-10*(t-1)))},circularIn:function(t){return 1-Math.sqrt(1-t*t)},circularOut:function(t){return Math.sqrt(1- --t*t)},circularInOut:function(t){return(t*=2)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1)},elasticIn:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),-r*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4))},elasticOut:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),r*Math.pow(2,-10*t)*Math.sin((t-e)*(2*Math.PI)/.4)+1)},elasticInOut:function(t){var e,r=.1;return 0===t?0:1===t?1:(!r||r<1?(r=1,e=.1):e=.4*Math.asin(1/r)/(2*Math.PI),(t*=2)<1?r*Math.pow(2,10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4)*-.5:r*Math.pow(2,-10*(t-=1))*Math.sin((t-e)*(2*Math.PI)/.4)*.5+1)},backIn:function(t){var e=1.70158;return t*t*((e+1)*t-e)},backOut:function(t){var e=1.70158;return--t*t*((e+1)*t+e)+1},backInOut:function(t){var e=2.5949095;return(t*=2)<1?t*t*((e+1)*t-e)*.5:.5*((t-=2)*t*((e+1)*t+e)+2)},bounceIn:function(t){return 1-ue.bounceOut(1-t)},bounceOut:function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375},bounceInOut:function(t){return t<.5?.5*ue.bounceIn(2*t):.5*ue.bounceOut(2*t-1)+.5}},le=function(t){t=t||{},this.name=t.name||"",this.target=t.target,this.life=t.life||1e3,this.delay=t.delay||0,this.gap=t.gap||0,this.playbackRate=t.playbackRate||1,this._initialized=!1,this._elapsedTime=0,this._loop=null!=t.loop&&t.loop,this.setLoop(this._loop),null!=t.easing&&this.setEasing(t.easing),this.onframe=t.onframe||e,this.onfinish=t.onfinish||e,this.onrestart=t.onrestart||e,this._paused=!1};le.prototype={gap:0,life:0,delay:0,setLoop:function(t){this._loop=t,t&&(this._loopRemained="number"==typeof t?t:1e8)},setEasing:function(t){"string"==typeof t&&(t=ue[t]),this.easing=t},step:function(t,e,r){if(this._initialized||(this._startTime=t+this.delay,this._initialized=!0),null!=this._currentTime&&(e=t-this._currentTime),this._currentTime=t,this._paused)return"paused";if(!(t0?(this._restartInLoop(t),this._loopRemained--,"restart"):(this._needsRemove=!0,"finish"):null}}},setTime:function(t){return this.step(t+this._startTime)},restart:function(t){var e=0;t&&(this._elapse(t),e=this._elapsedTime%this.life),t=t||Date.now(),this._startTime=t-e+this.delay,this._elapsedTime=0,this._needsRemove=!1,this._paused=!1},getElapsedTime:function(){return this._elapsedTime},_restartInLoop:function(t){this._startTime=t+this.gap,this._elapsedTime=0},_elapse:function(t,e){this._elapsedTime+=e*this.playbackRate},fire:function(t,e){var r="on"+t;this[r]&&this[r](this.target,e)},clone:function(){var t=new this.constructor;return t.name=this.name,t._loop=this._loop,t._loopRemained=this._loopRemained,t.life=this.life,t.gap=this.gap,t.delay=this.delay,t},pause:function(){this._paused=!0},resume:function(){this._paused=!1}},le.prototype.constructor=le;var ce=Array.prototype.slice;d.prototype={constructor:d,when:function(t,e,r){this._maxTime=Math.max(t,this._maxTime),r=("function"==typeof r?r:ue[r])||m;for(var n in e)this._tracks[n]||(this._tracks[n]=[],0!==t&&this._tracks[n].push({time:0,value:s(this._getter(this._target,n)),easing:r})),this._tracks[n].push({time:parseInt(t),value:e[n],easing:r});return this},then:function(t,e,r){return this.when(t+this._lastKFTime,e,r),this._lastKFTime+=t,this},during:function(t){return this._onframeList.push(t),this},_doneCallback:function(){this._tracks={},this._clipList.length=0;for(var t=this._doneList,e=t.length,r=0;rt)this.inputs.unshift(n);else if(this.inputs[i-1].position<=t)this.inputs.push(n);else{var a=this._findKey(t);this.inputs.splice(a,n)}return n},fe.prototype.step=function(t,e,r){var n=le.prototype.step.call(this,t);return"finish"!==n&&this.setTime(this.getElapsedTime()),r||"paused"===n||this.fire("frame"),n},fe.prototype.setTime=function(t){var e=this.position,r=this.inputs,n=r.length,i=r[0].position,a=r[n-1].position;if(e<=i||e>=a){var o=e<=i?r[0]:r[n-1],s=o.clip,u=o.offset;s.setTime((t+u)%s.life),s.output instanceof le?this.output.copy(s.output):this.output.copy(s)}else{var l=this._findKey(e),c=r[l],h=r[l+1],f=c.clip,d=h.clip;f.setTime((t+c.offset)%f.life),d.setTime((t+h.offset)%d.life);var m=(this.position-c.position)/(h.position-c.position),p=f.output instanceof le?f.output:f,_=d.output instanceof le?d.output:d;this.output.blend1D(p,_,m)}},fe.prototype.clone=function(t){var e=le.prototype.clone.call(this);e.output=this.output.clone();for(var r=0;r=r[i].position&&t=0;i--)t>=r[i].position&&t=0&&(this._cacheKey=e,this._cachePosition=t),e};var de=1/1048576,me={triangulate:function(t,e){var r,n,i,a,o,s,u,l,c,h,f,d,m=t.length;if(m<3)return[];if(t=t.slice(0),e)for(r=m;r--;)t[r]=t[r][e];for(i=new Array(m),r=m;r--;)i[r]=r;for(i.sort(function(e,r){var n=t[r][0]-t[e][0];return 0!==n?n:e-r}),a=p(t),t.push(a[0],a[1],a[2]),o=[_(t,m+0,m+1,m+2)],s=[],u=[],r=i.length;r--;u.length=0){for(d=i[r],n=o.length;n--;)l=t[d][0]-o[n].x,l>0&&l*l>o[n].r?(s.push(o[n]),o.splice(n,1)):(c=t[d][1]-o[n].y,l*l+c*c-o[n].r>de||(u.push(o[n].i,o[n].j,o[n].j,o[n].k,o[n].k,o[n].i),o.splice(n,1)));for(g(u),n=u.length;n;)f=u[--n],h=u[--n],o.push(_(t,h,f,d))}for(r=o.length;r--;)s.push(o[r]);for(o.length=0,r=s.length;r--;)s[r].it[0][0]&&e[0]>t[1][0]&&e[0]>t[2][0]||e[1]t[0][1]&&e[1]>t[1][1]&&e[1]>t[2][1])return null;var r=t[1][0]-t[0][0],n=t[2][0]-t[0][0],i=t[1][1]-t[0][1],a=t[2][1]-t[0][1],o=r*a-n*i;if(0===o)return null;var s=(a*(e[0]-t[0][0])-n*(e[1]-t[0][1]))/o,u=(r*(e[1]-t[0][1])-i*(e[0]-t[0][0]))/o;return s<0||u<0||s+u>1?null:[s,u]}},pe=("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self,function(t,e){return e={exports:{}},t(e,e.exports),e.exports}(function(t,e){!function(t){ +var r={};r.exports=e,function(t){if(!e)var e=1e-6;if(!r)var r="undefined"!=typeof Float32Array?Float32Array:Array;if(!n)var n=Math.random;var i={};i.setMatrixArrayType=function(t){r=t},void 0!==t&&(t.glMatrix=i);var a=Math.PI/180;i.toRadian=function(t){return t*a};var o={};o.create=function(){var t=new r(2);return t[0]=0,t[1]=0,t},o.clone=function(t){var e=new r(2);return e[0]=t[0],e[1]=t[1],e},o.fromValues=function(t,e){var n=new r(2);return n[0]=t,n[1]=e,n},o.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t},o.set=function(t,e,r){return t[0]=e,t[1]=r,t},o.add=function(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t},o.subtract=function(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t},o.sub=o.subtract,o.multiply=function(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t},o.mul=o.multiply,o.divide=function(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t},o.div=o.divide,o.min=function(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t},o.max=function(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t},o.scale=function(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t},o.scaleAndAdd=function(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t},o.distance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1];return Math.sqrt(r*r+n*n)},o.dist=o.distance,o.squaredDistance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1];return r*r+n*n},o.sqrDist=o.squaredDistance,o.length=function(t){var e=t[0],r=t[1];return Math.sqrt(e*e+r*r)},o.len=o.length,o.squaredLength=function(t){var e=t[0],r=t[1];return e*e+r*r},o.sqrLen=o.squaredLength,o.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t},o.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t},o.normalize=function(t,e){var r=e[0],n=e[1],i=r*r+n*n;return i>0&&(i=1/Math.sqrt(i),t[0]=e[0]*i,t[1]=e[1]*i),t},o.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]},o.cross=function(t,e,r){var n=e[0]*r[1]-e[1]*r[0];return t[0]=t[1]=0,t[2]=n,t},o.lerp=function(t,e,r,n){var i=e[0],a=e[1];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t},o.random=function(t,e){e=e||1;var r=2*n()*Math.PI;return t[0]=Math.cos(r)*e,t[1]=Math.sin(r)*e,t},o.transformMat2=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[2]*i,t[1]=r[1]*n+r[3]*i,t},o.transformMat2d=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[2]*i+r[4],t[1]=r[1]*n+r[3]*i+r[5],t},o.transformMat3=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[3]*i+r[6],t[1]=r[1]*n+r[4]*i+r[7],t},o.transformMat4=function(t,e,r){var n=e[0],i=e[1];return t[0]=r[0]*n+r[4]*i+r[12],t[1]=r[1]*n+r[5]*i+r[13],t},o.forEach=function(){var t=o.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=2),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s0&&(a=1/Math.sqrt(a),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a),t},s.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]},s.cross=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2];return t[0]=i*u-a*s,t[1]=a*o-n*u,t[2]=n*s-i*o,t},s.lerp=function(t,e,r,n){var i=e[0],a=e[1],o=e[2];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t},s.random=function(t,e){e=e||1;var r=2*n()*Math.PI,i=2*n()-1,a=Math.sqrt(1-i*i)*e;return t[0]=Math.cos(r)*a,t[1]=Math.sin(r)*a,t[2]=i*e,t},s.transformMat4=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[3]*n+r[7]*i+r[11]*a+r[15];return o=o||1,t[0]=(r[0]*n+r[4]*i+r[8]*a+r[12])/o,t[1]=(r[1]*n+r[5]*i+r[9]*a+r[13])/o,t[2]=(r[2]*n+r[6]*i+r[10]*a+r[14])/o,t},s.transformMat3=function(t,e,r){var n=e[0],i=e[1],a=e[2];return t[0]=n*r[0]+i*r[3]+a*r[6],t[1]=n*r[1]+i*r[4]+a*r[7],t[2]=n*r[2]+i*r[5]+a*r[8],t},s.transformQuat=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2],l=r[3],c=l*n+s*a-u*i,h=l*i+u*n-o*a,f=l*a+o*i-s*n,d=-o*n-s*i-u*a;return t[0]=c*l+d*-o+h*-u-f*-s,t[1]=h*l+d*-s+f*-o-c*-u,t[2]=f*l+d*-u+c*-s-h*-o,t},s.rotateX=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0],a[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),a[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.rotateY=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),a[1]=i[1],a[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.rotateZ=function(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),a[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),a[2]=i[2],t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t},s.forEach=function(){var t=s.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=3),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s1?0:Math.acos(i)},s.str=function(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"},void 0!==t&&(t.vec3=s);var u={};u.create=function(){var t=new r(4);return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t},u.clone=function(t){var e=new r(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e},u.fromValues=function(t,e,n,i){var a=new r(4);return a[0]=t,a[1]=e,a[2]=n,a[3]=i,a},u.copy=function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t},u.set=function(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t},u.add=function(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t},u.subtract=function(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t},u.sub=u.subtract,u.multiply=function(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t[3]=e[3]*r[3],t},u.mul=u.multiply,u.divide=function(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t[3]=e[3]/r[3],t},u.div=u.divide,u.min=function(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t[3]=Math.min(e[3],r[3]),t},u.max=function(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t[3]=Math.max(e[3],r[3]),t},u.scale=function(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t},u.scaleAndAdd=function(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t},u.distance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+a*a)},u.dist=u.distance,u.squaredDistance=function(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return r*r+n*n+i*i+a*a},u.sqrDist=u.squaredDistance,u.length=function(t){var e=t[0],r=t[1],n=t[2],i=t[3];return Math.sqrt(e*e+r*r+n*n+i*i)},u.len=u.length,u.squaredLength=function(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i},u.sqrLen=u.squaredLength,u.negate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t},u.inverse=function(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t[3]=1/e[3],t},u.normalize=function(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a;return o>0&&(o=1/Math.sqrt(o),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o,t[3]=e[3]*o),t},u.dot=function(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]},u.lerp=function(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t[3]=s+n*(r[3]-s),t},u.random=function(t,e){return e=e||1,t[0]=n(),t[1]=n(),t[2]=n(),t[3]=n(),u.normalize(t,t),u.scale(t,t,e),t},u.transformMat4=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*a+r[12]*o,t[1]=r[1]*n+r[5]*i+r[9]*a+r[13]*o,t[2]=r[2]*n+r[6]*i+r[10]*a+r[14]*o,t[3]=r[3]*n+r[7]*i+r[11]*a+r[15]*o,t},u.transformQuat=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],u=r[2],l=r[3],c=l*n+s*a-u*i,h=l*i+u*n-o*a,f=l*a+o*i-s*n,d=-o*n-s*i-u*a;return t[0]=c*l+d*-o+h*-u-f*-s,t[1]=h*l+d*-s+f*-o-c*-u,t[2]=f*l+d*-u+c*-s-h*-o,t},u.forEach=function(){var t=u.create();return function(e,r,n,i,a,o){var s,u;for(r||(r=4),n||(n=0),u=i?Math.min(i*r+n,e.length):e.length,s=n;s.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(s.cross(t,i,a),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+o,d.normalize(n,n))}}(),d.setAxes=function(){var t=h.create();return function(e,r,n,i){return t[0]=n[0],t[3]=n[1],t[6]=n[2],t[1]=i[0],t[4]=i[1],t[7]=i[2],t[2]=-r[0],t[5]=-r[1],t[8]=-r[2],d.normalize(e,d.fromMat3(e,t))}}(),d.clone=u.clone,d.fromValues=u.fromValues,d.copy=u.copy,d.set=u.set,d.identity=function(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t},d.setAxisAngle=function(t,e,r){r*=.5;var n=Math.sin(r);return t[0]=n*e[0],t[1]=n*e[1],t[2]=n*e[2],t[3]=Math.cos(r),t},d.add=u.add,d.multiply=function(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=r[0],u=r[1],l=r[2],c=r[3];return t[0]=n*c+o*s+i*l-a*u,t[1]=i*c+o*u+a*s-n*l,t[2]=a*c+o*l+n*u-i*s,t[3]=o*c-n*s-i*u-a*l,t},d.mul=d.multiply,d.scale=u.scale,d.rotateX=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u+o*s,t[1]=i*u+a*s,t[2]=a*u-i*s,t[3]=o*u-n*s,t},d.rotateY=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u-a*s,t[1]=i*u+o*s,t[2]=a*u+n*s,t[3]=o*u-i*s,t},d.rotateZ=function(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),u=Math.cos(r);return t[0]=n*u+i*s,t[1]=i*u-n*s,t[2]=a*u+o*s,t[3]=o*u-a*s,t},d.calculateW=function(t,e){var r=e[0],n=e[1],i=e[2];return t[0]=r,t[1]=n,t[2]=i,t[3]=Math.sqrt(Math.abs(1-r*r-n*n-i*i)),t},d.dot=u.dot,d.lerp=u.lerp,d.slerp=function(t,e,r,n){var i,a,o,s,u,l=e[0],c=e[1],h=e[2],f=e[3],d=r[0],m=r[1],p=r[2],_=r[3];return a=l*d+c*m+h*p+f*_,a<0&&(a=-a,d=-d,m=-m,p=-p,_=-_),1-a>1e-6?(i=Math.acos(a),o=Math.sin(i),s=Math.sin((1-n)*i)/o,u=Math.sin(n*i)/o):(s=1-n,u=n),t[0]=s*l+u*d,t[1]=s*c+u*m,t[2]=s*h+u*p,t[3]=s*f+u*_,t},d.invert=function(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a,s=o?1/o:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=a*s,t},d.conjugate=function(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t},d.length=u.length,d.len=d.length,d.squaredLength=u.squaredLength,d.sqrLen=d.squaredLength,d.normalize=u.normalize,d.fromMat3=function(t,e){var r,n=e[0]+e[4]+e[8];if(n>0)r=Math.sqrt(n+1),t[3]=.5*r,r=.5/r,t[0]=(e[5]-e[7])*r,t[1]=(e[6]-e[2])*r,t[2]=(e[1]-e[3])*r;else{var i=0;e[4]>e[0]&&(i=1),e[8]>e[3*i+i]&&(i=2);var a=(i+1)%3,o=(i+2)%3;r=Math.sqrt(e[3*i+i]-e[3*a+a]-e[3*o+o]+1),t[i]=.5*r,r=.5/r,t[3]=(e[3*a+o]-e[3*o+a])*r,t[a]=(e[3*a+i]+e[3*i+a])*r,t[o]=(e[3*o+i]+e[3*i+o])*r}return t},d.str=function(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"},void 0!==t&&(t.quat=d)}(r.exports)}()})),_e=pe.vec2,ge=function(t,e){t=t||0,e=e||0,this.array=_e.fromValues(t,e),this._dirty=!0};if(ge.prototype={constructor:ge,add:function(t){return _e.add(this.array,this.array,t.array),this._dirty=!0,this},set:function(t,e){return this.array[0]=t,this.array[1]=e,this._dirty=!0,this},setArray:function(t){return this.array[0]=t[0],this.array[1]=t[1],this._dirty=!0,this},clone:function(){return new ge(this.x,this.y)},copy:function(t){return _e.copy(this.array,t.array),this._dirty=!0,this},cross:function(t,e){return _e.cross(t.array,this.array,e.array),t._dirty=!0,this},dist:function(t){return _e.dist(this.array,t.array)},distance:function(t){return _e.distance(this.array,t.array)},div:function(t){return _e.div(this.array,this.array,t.array),this._dirty=!0,this},divide:function(t){return _e.divide(this.array,this.array,t.array),this._dirty=!0,this},dot:function(t){return _e.dot(this.array,t.array)},len:function(){return _e.len(this.array)},length:function(){return _e.length(this.array)},lerp:function(t,e,r){return _e.lerp(this.array,t.array,e.array,r),this._dirty=!0,this},min:function(t){return _e.min(this.array,this.array,t.array),this._dirty=!0,this},max:function(t){return _e.max(this.array,this.array,t.array),this._dirty=!0,this},mul:function(t){return _e.mul(this.array,this.array,t.array),this._dirty=!0,this},multiply:function(t){return _e.multiply(this.array,this.array,t.array),this._dirty=!0,this},negate:function(){return _e.negate(this.array,this.array),this._dirty=!0,this},normalize:function(){return _e.normalize(this.array,this.array),this._dirty=!0,this},random:function(t){return _e.random(this.array,t),this._dirty=!0,this},scale:function(t){return _e.scale(this.array,this.array,t),this._dirty=!0,this},scaleAndAdd:function(t,e){return _e.scaleAndAdd(this.array,this.array,t.array,e),this._dirty=!0,this},sqrDist:function(t){return _e.sqrDist(this.array,t.array)},squaredDistance:function(t){return _e.squaredDistance(this.array,t.array)},sqrLen:function(){return _e.sqrLen(this.array)},squaredLength:function(){return _e.squaredLength(this.array)},sub:function(t){return _e.sub(this.array,this.array,t.array),this._dirty=!0,this},subtract:function(t){return _e.subtract(this.array,this.array,t.array),this._dirty=!0,this},transformMat2:function(t){return _e.transformMat2(this.array,this.array,t.array),this._dirty=!0,this},transformMat2d:function(t){return _e.transformMat2d(this.array,this.array,t.array),this._dirty=!0,this},transformMat3:function(t){return _e.transformMat3(this.array,this.array,t.array),this._dirty=!0,this},transformMat4:function(t){return _e.transformMat4(this.array,this.array,t.array),this._dirty=!0,this},toString:function(){return"["+Array.prototype.join.call(this.array,",")+"]"},toArray:function(){return Array.prototype.slice.call(this.array)}},Object.defineProperty){var ve=ge.prototype;Object.defineProperty(ve,"x",{get:function(){return this.array[0]},set:function(t){this.array[0]=t,this._dirty=!0}}),Object.defineProperty(ve,"y",{get:function(){return this.array[1]},set:function(t){this.array[1]=t,this._dirty=!0}})}ge.add=function(t,e,r){return _e.add(t.array,e.array,r.array),t._dirty=!0,t},ge.set=function(t,e,r){return _e.set(t.array,e,r),t._dirty=!0,t},ge.copy=function(t,e){return _e.copy(t.array,e.array),t._dirty=!0,t},ge.cross=function(t,e,r){return _e.cross(t.array,e.array,r.array),t._dirty=!0,t},ge.dist=function(t,e){return _e.distance(t.array,e.array)},ge.distance=ge.dist,ge.div=function(t,e,r){return _e.divide(t.array,e.array,r.array),t._dirty=!0,t},ge.divide=ge.div,ge.dot=function(t,e){return _e.dot(t.array,e.array)},ge.len=function(t){return _e.length(t.array)},ge.lerp=function(t,e,r,n){return _e.lerp(t.array,e.array,r.array,n),t._dirty=!0,t},ge.min=function(t,e,r){return _e.min(t.array,e.array,r.array),t._dirty=!0,t},ge.max=function(t,e,r){return _e.max(t.array,e.array,r.array),t._dirty=!0,t}, +ge.mul=function(t,e,r){return _e.multiply(t.array,e.array,r.array),t._dirty=!0,t},ge.multiply=ge.mul,ge.negate=function(t,e){return _e.negate(t.array,e.array),t._dirty=!0,t},ge.normalize=function(t,e){return _e.normalize(t.array,e.array),t._dirty=!0,t},ge.random=function(t,e){return _e.random(t.array,e),t._dirty=!0,t},ge.scale=function(t,e,r){return _e.scale(t.array,e.array,r),t._dirty=!0,t},ge.scaleAndAdd=function(t,e,r,n){return _e.scaleAndAdd(t.array,e.array,r.array,n),t._dirty=!0,t},ge.sqrDist=function(t,e){return _e.sqrDist(t.array,e.array)},ge.squaredDistance=ge.sqrDist,ge.sqrLen=function(t){return _e.sqrLen(t.array)},ge.squaredLength=ge.sqrLen,ge.sub=function(t,e,r){return _e.subtract(t.array,e.array,r.array),t._dirty=!0,t},ge.subtract=ge.sub,ge.transformMat2=function(t,e,r){return _e.transformMat2(t.array,e.array,r.array),t._dirty=!0,t},ge.transformMat2d=function(t,e,r){return _e.transformMat2d(t.array,e.array,r.array),t._dirty=!0,t},ge.transformMat3=function(t,e,r){return _e.transformMat3(t.array,e.array,r.array),t._dirty=!0,t},ge.transformMat4=function(t,e,r){return _e.transformMat4(t.array,e.array,r.array),t._dirty=!0,t};var ye=function(t){t=t||{},le.call(this,t),this.output=t.output||null,this.inputs=t.inputs||[],this.position=new ge,this._cacheTriangle=null,this._triangles=[],this._updateTriangles()};ye.prototype=new le,ye.prototype.constructor=ye,ye.prototype.addInput=function(t,e,r){var n={position:t,clip:e,offset:r||0};return this.inputs.push(n),this.life=Math.max(e.life,this.life),this._updateTriangles(),n},ye.prototype._updateTriangles=function(){var t=this.inputs.map(function(t){return t.position});this._triangles=me.triangulate(t,"array")},ye.prototype.step=function(t,e,r){var n=le.prototype.step.call(this,t);return"finish"!==n&&this.setTime(this.getElapsedTime()),r||"paused"===n||this.fire("frame"),n},ye.prototype.setTime=function(t){var e=this._findTriangle(this.position);if(e){var r=e[1],n=e[2],i=e[0],a=this.inputs[i.indices[0]],o=this.inputs[i.indices[1]],s=this.inputs[i.indices[2]],u=a.clip,l=o.clip,c=s.clip;u.setTime((t+a.offset)%u.life),l.setTime((t+o.offset)%l.life),c.setTime((t+s.offset)%c.life);var h=u.output instanceof le?u.output:u,f=l.output instanceof le?l.output:l,d=c.output instanceof le?c.output:c;this.output.blend2D(h,f,d,r,n)}},ye.prototype.clone=function(t){var e=le.prototype.clone.call(this);e.output=this.output.clone();for(var r=0;r=t.time)return this.keyFrames.splice(e,0,t),e}this.life=t.time,this.keyFrames.push(t)},Ee.prototype.addKeyFrames=function(t){for(var e=0;ei[i.length-1].time)){if(t=a-1?a-1:this._cacheKey+1,s=o;s>=0;s--)if(i[s].time<=t&&i[s][e])r=i[s],this._cacheKey=s,this._cacheTime=t;else if(i[s][e]){n=i[s];break}}else for(var s=this._cacheKey;s=e.time[r-1])t=e.time[r-1],n=r-2;else if(t=0;a--)if(e.time[a-1]<=t&&e.time[a]>t){n=a-1;break}}else for(var a=this._cacheKey;at){n=a;break}if(n>-1){this._cacheKey=n,this._cacheTime=t;var o=n,s=n+1,u=e.time[o],l=e.time[s],c=l-u,h=0===c?0:(t-u)/c;e.rotation&&x(this.rotation,e.rotation,e.rotation,h,4*o,4*s),e.position&&y(this.position,e.position,e.position,h,3*o,3*s),e.scale&&y(this.scale,e.scale,e.scale,h,3*o,3*s)}n==r-2&&(this._cacheKey=0,this._cacheTime=0),this.updateTarget()}},Se.prototype.updateTarget=function(){var t=this.channels;this.target&&(t.position&&this.target.position.setArray(this.position),t.rotation&&this.target.rotation.setArray(this.rotation),t.scale&&this.target.scale.setArray(this.scale))},Se.prototype.getMaxTime=function(){return this.channels.time[this.channels.time.length-1]},Se.prototype.getSubTrack=function(t,e){var r=new Se({name:this.name}),n=this.channels.time[0];t=Math.min(Math.max(t,n),this.life),e=Math.min(Math.max(e,n),this.life);var i=this._findRange(t),a=this._findRange(e),o=a[0]-i[0]+1;0===i[1]&&0===a[1]&&(o-=1),this.channels.rotation&&(r.channels.rotation=new Float32Array(4*o)),this.channels.position&&(r.channels.position=new Float32Array(3*o)),this.channels.scale&&(r.channels.scale=new Float32Array(3*o)),this.channels.time&&(r.channels.time=new Float32Array(o)),this.setTime(t);for(var s=0;s<3;s++)r.channels.rotation[s]=this.rotation[s],r.channels.position[s]=this.position[s],r.channels.scale[s]=this.scale[s];r.channels.time[0]=0,r.channels.rotation[3]=this.rotation[3];for(var s=1;st&&(n=i);var a=0;if(n>=0)var o=e.time[n],s=e.time[n+1],a=(t-o)/(s-o);return[n,a]},Se.prototype.blend1D=Ee.prototype.blend1D,Se.prototype.blend2D=Ee.prototype.blend2D,Se.prototype.additiveBlend=Ee.prototype.additiveBlend,Se.prototype.subtractiveBlend=Ee.prototype.subtractiveBlend,Se.prototype.clone=function(){var t=Se.prototype.clone.call(this);return t.channels={time:this.channels.time||null,position:this.channels.position||null,rotation:this.channels.rotation||null,scale:this.channels.scale||null},Ae.copy(t.position,this.position),be.copy(t.rotation,this.rotation),Ae.copy(t.scale,this.scale),t.target=this.target,t.updateTarget(),t};var we={extend:T,derive:T},Me={trigger:function(t){if(this.hasOwnProperty("__handlers__")&&this.__handlers__.hasOwnProperty(t)){var e=this.__handlers__[t],r=e.length,n=-1,i=arguments;switch(i.length){case 1:for(;++n=0&&this._clips.splice(e,1)},removeAnimator:function(t){for(var e=t.getClips(),r=0;r=0&&this.tracks.splice(e,1)},Fe.prototype.getSubClip=function(t,e,r){for(var n=new Fe({name:this.name}),i=0;i0){var e=this.min,r=this.max,n=e.array,i=r.array;Qe(n,t[0]),Qe(i,t[0]);for(var a=1;ai[0]&&(i[0]=o[0]),o[1]>i[1]&&(i[1]=o[1]),o[2]>i[2]&&(i[2]=o[2])}e._dirty=!0,r._dirty=!0}},union:function(t){var e=this.min,r=this.max;return Je.min(e.array,e.array,t.min.array),Je.max(r.array,r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},intersection:function(t){var e=this.min,r=this.max;return Je.max(e.array,e.array,t.min.array),Je.min(r.array,r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},intersectBoundingBox:function(t){var e=this.min.array,r=this.max.array,n=t.min.array,i=t.max.array;return!(e[0]>i[0]||e[1]>i[1]||e[2]>i[2]||r[0]=i[0]&&r[1]>=i[1]&&r[2]>=i[2]},containPoint:function(t){var e=this.min.array,r=this.max.array,n=t.array;return e[0]<=n[0]&&e[1]<=n[1]&&e[2]<=n[2]&&r[0]>=n[0]&&r[1]>=n[1]&&r[2]>=n[2]},isFinite:function(){var t=this.min.array,e=this.max.array;return isFinite(t[0])&&isFinite(t[1])&&isFinite(t[2])&&isFinite(e[0])&&isFinite(e[1])&&isFinite(e[2])}, +applyTransform:function(){var t=Je.create(),e=Je.create(),r=Je.create(),n=Je.create(),i=Je.create(),a=Je.create();return function(o){var s=this.min.array,u=this.max.array,l=o.array;return t[0]=l[0]*s[0],t[1]=l[1]*s[0],t[2]=l[2]*s[0],e[0]=l[0]*u[0],e[1]=l[1]*u[0],e[2]=l[2]*u[0],r[0]=l[4]*s[1],r[1]=l[5]*s[1],r[2]=l[6]*s[1],n[0]=l[4]*u[1],n[1]=l[5]*u[1],n[2]=l[6]*u[1],i[0]=l[8]*s[2],i[1]=l[9]*s[2],i[2]=l[10]*s[2],a[0]=l[8]*u[2],a[1]=l[9]*u[2],a[2]=l[10]*u[2],s[0]=Math.min(t[0],e[0])+Math.min(r[0],n[0])+Math.min(i[0],a[0])+l[12],s[1]=Math.min(t[1],e[1])+Math.min(r[1],n[1])+Math.min(i[1],a[1])+l[13],s[2]=Math.min(t[2],e[2])+Math.min(r[2],n[2])+Math.min(i[2],a[2])+l[14],u[0]=Math.max(t[0],e[0])+Math.max(r[0],n[0])+Math.max(i[0],a[0])+l[12],u[1]=Math.max(t[1],e[1])+Math.max(r[1],n[1])+Math.max(i[1],a[1])+l[13],u[2]=Math.max(t[2],e[2])+Math.max(r[2],n[2])+Math.max(i[2],a[2])+l[14],this.min._dirty=!0,this.max._dirty=!0,this}}(),applyProjection:function(t){var e=this.min.array,r=this.max.array,n=t.array,i=e[0],a=e[1],o=e[2],s=r[0],u=r[1],l=e[2],c=r[0],h=r[1],f=r[2];if(1===n[15])e[0]=n[0]*i+n[12],e[1]=n[5]*a+n[13],r[2]=n[10]*o+n[14],r[0]=n[0]*c+n[12],r[1]=n[5]*h+n[13],e[2]=n[10]*f+n[14];else{var d=-1/o;e[0]=n[0]*i*d,e[1]=n[5]*a*d,r[2]=(n[10]*o+n[14])*d,d=-1/l,r[0]=n[0]*s*d,r[1]=n[5]*u*d,d=-1/f,e[2]=(n[10]*f+n[14])*d}return this.min._dirty=!0,this.max._dirty=!0,this},updateVertices:function(){var t=this.vertices;if(!t){for(var t=[],e=0;e<8;e++)t[e]=Je.fromValues(0,0,0);this.vertices=t}var r=this.min.array,n=this.max.array;return $e(t[0],r[0],r[1],r[2]),$e(t[1],r[0],n[1],r[2]),$e(t[2],n[0],r[1],r[2]),$e(t[3],n[0],n[1],r[2]),$e(t[4],r[0],r[1],n[2]),$e(t[5],r[0],n[1],n[2]),$e(t[6],n[0],r[1],n[2]),$e(t[7],n[0],n[1],n[2]),this},copy:function(t){var e=this.min,r=this.max;return Qe(e.array,t.min.array),Qe(r.array,t.max.array),e._dirty=!0,r._dirty=!0,this},clone:function(){var t=new tr;return t.copy(this),t}};var er=pe.mat4,rr=pe.vec3,nr=pe.mat3,ir=pe.quat,ar=function(){this._axisX=new Xe,this._axisY=new Xe,this._axisZ=new Xe,this.array=er.create(),this._dirty=!0};ar.prototype={constructor:ar,setArray:function(t){for(var e=0;e>e;return t+1},dispose:function(t){var e=this._cache;e.use(t.__uid__);var r=e.get("webgl_texture");r&&t.gl.deleteTexture(r),e.deleteContext(t.__uid__)},isRenderable:function(){},isPowerOfTwo:function(){}});Object.defineProperty(lr.prototype,"width",{get:function(){return this._width},set:function(t){this._width=t}}),Object.defineProperty(lr.prototype,"height",{get:function(){return this._height},set:function(t){this._height=t}}),lr.BYTE=He.BYTE,lr.UNSIGNED_BYTE=He.UNSIGNED_BYTE,lr.SHORT=He.SHORT,lr.UNSIGNED_SHORT=He.UNSIGNED_SHORT,lr.INT=He.INT,lr.UNSIGNED_INT=He.UNSIGNED_INT,lr.FLOAT=He.FLOAT,lr.HALF_FLOAT=36193,lr.UNSIGNED_INT_24_8_WEBGL=34042,lr.DEPTH_COMPONENT=He.DEPTH_COMPONENT,lr.DEPTH_STENCIL=He.DEPTH_STENCIL,lr.ALPHA=He.ALPHA,lr.RGB=He.RGB,lr.RGBA=He.RGBA,lr.LUMINANCE=He.LUMINANCE,lr.LUMINANCE_ALPHA=He.LUMINANCE_ALPHA,lr.SRGB=35904,lr.SRGB_ALPHA=35906,lr.COMPRESSED_RGB_S3TC_DXT1_EXT=33776,lr.COMPRESSED_RGBA_S3TC_DXT1_EXT=33777,lr.COMPRESSED_RGBA_S3TC_DXT3_EXT=33778,lr.COMPRESSED_RGBA_S3TC_DXT5_EXT=33779,lr.NEAREST=He.NEAREST,lr.LINEAR=He.LINEAR,lr.NEAREST_MIPMAP_NEAREST=He.NEAREST_MIPMAP_NEAREST,lr.LINEAR_MIPMAP_NEAREST=He.LINEAR_MIPMAP_NEAREST,lr.NEAREST_MIPMAP_LINEAR=He.NEAREST_MIPMAP_LINEAR,lr.LINEAR_MIPMAP_LINEAR=He.LINEAR_MIPMAP_LINEAR,lr.REPEAT=He.REPEAT,lr.CLAMP_TO_EDGE=He.CLAMP_TO_EDGE,lr.MIRRORED_REPEAT=He.MIRRORED_REPEAT;var cr=function(){this.head=null,this.tail=null,this._length=0};cr.prototype.insert=function(t){var e=new cr.Entry(t);return this.insertEntry(e),e},cr.prototype.insertAt=function(t,e){if(!(t<0)){for(var r=this.head,n=0;r&&n!=t;)r=r.next,n++;if(r){var i=new cr.Entry(e),a=r.prev;a?(a.next=i,i.prev=a):this.head=i,i.next=r,r.prev=i}else this.insert(e)}},cr.prototype.insertBeforeEntry=function(t,e){var r=new cr.Entry(t),n=e.prev;n?(n.next=r,r.prev=n):this.head=r,r.next=e,e.prev=r,this._length++},cr.prototype.insertEntry=function(t){this.head?(this.tail.next=t,t.prev=this.tail,this.tail=t):this.head=this.tail=t,this._length++},cr.prototype.remove=function(t){var e=t.prev,r=t.next;e?e.next=r:this.head=r,r?r.prev=e:this.tail=e,t.next=t.prev=null,this._length--},cr.prototype.removeAt=function(t){if(!(t<0)){for(var e=this.head,r=0;e&&r!=t;)e=e.next,r++;return e?(this.remove(e),e.value):void 0}},cr.prototype.getHead=function(){if(this.head)return this.head.value},cr.prototype.getTail=function(){if(this.tail)return this.tail.value},cr.prototype.getAt=function(t){if(!(t<0)){for(var e=this.head,r=0;e&&r!=t;)e=e.next,r++;return e.value}},cr.prototype.indexOf=function(t){for(var e=this.head,r=0;e;){if(e.value===t)return r;e=e.next,r++}},cr.prototype.length=function(){return this._length},cr.prototype.isEmpty=function(){return 0===this._length},cr.prototype.forEach=function(t,e){for(var r=this.head,n=0,i=void 0!==e;r;)i?t.call(e,r.value,n):t(r.value,n),r=r.next,n++},cr.prototype.clear=function(){this.tail=this.head=null,this._length=0},cr.Entry=function(t){this.value=t,this.next=null,this.prev=null};var hr=function(t){this._list=new cr,this._map={},this._maxSize=t||10};hr.prototype.setMaxSize=function(t){this._maxSize=t},hr.prototype.put=function(t,e){if(void 0===this._map[t]){var r=this._list.length();if(r>=this._maxSize&&r>0){var n=this._list.head;this._list.remove(n),delete this._map[n.key]}var i=this._list.insert(e);i.key=t,this._map[t]=i}},hr.prototype.get=function(t){var e=this._map[t];if(void 0!==e)return e!==this._list.tail&&(this._list.remove(e),this._list.insertEntry(e)),e.value},hr.prototype.remove=function(t){var e=this._map[t];void 0!==e&&(delete this._map[t],this._list.remove(e))},hr.prototype.clear=function(){this._list.clear(),this._map={}};var fr={},dr={transparent:[0,0,0,0],aliceblue:[240,248,255,1],antiquewhite:[250,235,215,1],aqua:[0,255,255,1],aquamarine:[127,255,212,1],azure:[240,255,255,1],beige:[245,245,220,1],bisque:[255,228,196,1],black:[0,0,0,1],blanchedalmond:[255,235,205,1],blue:[0,0,255,1],blueviolet:[138,43,226,1],brown:[165,42,42,1],burlywood:[222,184,135,1],cadetblue:[95,158,160,1],chartreuse:[127,255,0,1],chocolate:[210,105,30,1],coral:[255,127,80,1],cornflowerblue:[100,149,237,1],cornsilk:[255,248,220,1],crimson:[220,20,60,1],cyan:[0,255,255,1],darkblue:[0,0,139,1],darkcyan:[0,139,139,1],darkgoldenrod:[184,134,11,1],darkgray:[169,169,169,1],darkgreen:[0,100,0,1],darkgrey:[169,169,169,1],darkkhaki:[189,183,107,1],darkmagenta:[139,0,139,1],darkolivegreen:[85,107,47,1],darkorange:[255,140,0,1],darkorchid:[153,50,204,1],darkred:[139,0,0,1],darksalmon:[233,150,122,1],darkseagreen:[143,188,143,1],darkslateblue:[72,61,139,1],darkslategray:[47,79,79,1],darkslategrey:[47,79,79,1],darkturquoise:[0,206,209,1],darkviolet:[148,0,211,1],deeppink:[255,20,147,1],deepskyblue:[0,191,255,1],dimgray:[105,105,105,1],dimgrey:[105,105,105,1],dodgerblue:[30,144,255,1],firebrick:[178,34,34,1],floralwhite:[255,250,240,1],forestgreen:[34,139,34,1],fuchsia:[255,0,255,1],gainsboro:[220,220,220,1],ghostwhite:[248,248,255,1],gold:[255,215,0,1],goldenrod:[218,165,32,1],gray:[128,128,128,1],green:[0,128,0,1],greenyellow:[173,255,47,1],grey:[128,128,128,1],honeydew:[240,255,240,1],hotpink:[255,105,180,1],indianred:[205,92,92,1],indigo:[75,0,130,1],ivory:[255,255,240,1],khaki:[240,230,140,1],lavender:[230,230,250,1],lavenderblush:[255,240,245,1],lawngreen:[124,252,0,1],lemonchiffon:[255,250,205,1],lightblue:[173,216,230,1],lightcoral:[240,128,128,1],lightcyan:[224,255,255,1],lightgoldenrodyellow:[250,250,210,1],lightgray:[211,211,211,1],lightgreen:[144,238,144,1],lightgrey:[211,211,211,1],lightpink:[255,182,193,1],lightsalmon:[255,160,122,1],lightseagreen:[32,178,170,1],lightskyblue:[135,206,250,1],lightslategray:[119,136,153,1],lightslategrey:[119,136,153,1],lightsteelblue:[176,196,222,1],lightyellow:[255,255,224,1],lime:[0,255,0,1],limegreen:[50,205,50,1],linen:[250,240,230,1],magenta:[255,0,255,1],maroon:[128,0,0,1],mediumaquamarine:[102,205,170,1],mediumblue:[0,0,205,1],mediumorchid:[186,85,211,1],mediumpurple:[147,112,219,1],mediumseagreen:[60,179,113,1],mediumslateblue:[123,104,238,1],mediumspringgreen:[0,250,154,1],mediumturquoise:[72,209,204,1],mediumvioletred:[199,21,133,1],midnightblue:[25,25,112,1],mintcream:[245,255,250,1],mistyrose:[255,228,225,1],moccasin:[255,228,181,1],navajowhite:[255,222,173,1],navy:[0,0,128,1],oldlace:[253,245,230,1],olive:[128,128,0,1],olivedrab:[107,142,35,1],orange:[255,165,0,1],orangered:[255,69,0,1],orchid:[218,112,214,1],palegoldenrod:[238,232,170,1],palegreen:[152,251,152,1],paleturquoise:[175,238,238,1],palevioletred:[219,112,147,1],papayawhip:[255,239,213,1],peachpuff:[255,218,185,1],peru:[205,133,63,1],pink:[255,192,203,1],plum:[221,160,221,1],powderblue:[176,224,230,1],purple:[128,0,128,1],red:[255,0,0,1],rosybrown:[188,143,143,1],royalblue:[65,105,225,1],saddlebrown:[139,69,19,1],salmon:[250,128,114,1],sandybrown:[244,164,96,1],seagreen:[46,139,87,1],seashell:[255,245,238,1],sienna:[160,82,45,1],silver:[192,192,192,1],skyblue:[135,206,235,1],slateblue:[106,90,205,1],slategray:[112,128,144,1],slategrey:[112,128,144,1],snow:[255,250,250,1],springgreen:[0,255,127,1],steelblue:[70,130,180,1],tan:[210,180,140,1],teal:[0,128,128,1],thistle:[216,191,216,1],tomato:[255,99,71,1],turquoise:[64,224,208,1],violet:[238,130,238,1],wheat:[245,222,179,1],white:[255,255,255,1],whitesmoke:[245,245,245,1],yellow:[255,255,0,1],yellowgreen:[154,205,50,1]},mr=new hr(20),pr=null;fr.parse=function(t,e){if(t){e=e||[];var r=mr.get(t);if(r)return O(e,r);t+="";var n=t.replace(/ /g,"").toLowerCase();if(n in dr)return O(e,dr[n]),B(t,e),e;if("#"!==n.charAt(0)){var i=n.indexOf("("),a=n.indexOf(")");if(-1!==i&&a+1===n.length){var o=n.substr(0,i),s=n.substr(i+1,a-(i+1)).split(","),u=1;switch(o){case"rgba":if(4!==s.length)return void I(e,0,0,0,1);u=L(s.pop());case"rgb":return 3!==s.length?void I(e,0,0,0,1):(I(e,R(s[0]),R(s[1]),R(s[2]),u),B(t,e),e);case"hsla":return 4!==s.length?void I(e,0,0,0,1):(s[3]=L(s[3]),F(s,e),B(t,e),e);case"hsl":return 3!==s.length?void I(e,0,0,0,1):(F(s,e),B(t,e),e);default:return}}I(e,0,0,0,1)}else{if(4===n.length){var l=parseInt(n.substr(1),16);return l>=0&&l<=4095?(I(e,(3840&l)>>4|(3840&l)>>8,240&l|(240&l)>>4,15&l|(15&l)<<4,1),B(t,e),e):void I(e,0,0,0,1)}if(7===n.length){var l=parseInt(n.substr(1),16);return l>=0&&l<=16777215?(I(e,(16711680&l)>>16,(65280&l)>>8,255&l,1),B(t,e),e):void I(e,0,0,0,1)}}}},fr.parseToFloat=function(t,e){if(e=fr.parse(t,e))return e[0]/=255,e[1]/=255,e[2]/=255,e},fr.lift=function(t,e){var r=fr.parse(t);if(r){for(var n=0;n<3;n++)r[n]=e<0?r[n]*(1-e)|0:(255-r[n])*e+r[n]|0;return fr.stringify(r,4===r.length?"rgba":"rgb")}},fr.toHex=function(t){var e=fr.parse(t);if(e)return((1<<24)+(e[0]<<16)+(e[1]<<8)+ +e[2]).toString(16).slice(1)},fr.fastLerp=function(t,e,r){if(e&&e.length&&t>=0&&t<=1){r=r||[];var n=t*(e.length-1),i=Math.floor(n),a=Math.ceil(n),o=e[i],s=e[a],u=n-i;return r[0]=M(D(o[0],s[0],u)),r[1]=M(D(o[1],s[1],u)),r[2]=M(D(o[2],s[2],u)),r[3]=N(D(o[3],s[3],u)),r}},fr.fastMapToColor=fr.fastLerp,fr.lerp=function(t,e,r){if(e&&e.length&&t>=0&&t<=1){var n=t*(e.length-1),i=Math.floor(n),a=Math.ceil(n),o=fr.parse(e[i]),s=fr.parse(e[a]),u=n-i,l=fr.stringify([M(D(o[0],s[0],u)),M(D(o[1],s[1],u)),M(D(o[2],s[2],u)),N(D(o[3],s[3],u))],"rgba");return r?{color:l,leftIndex:i,rightIndex:a,value:n}:l}},fr.mapToColor=fr.lerp,fr.modifyHSL=function(t,e,r,n){if(t=fr.parse(t))return t=U(t),null!=e&&(t[0]=C(e)),null!=r&&(t[1]=L(r)),null!=n&&(t[2]=L(n)),fr.stringify(F(t),"rgba")},fr.modifyAlpha=function(t,e){if((t=fr.parse(t))&&null!=e)return t[3]=N(e),fr.stringify(t,"rgba")},fr.stringify=function(t,e){if(t&&t.length){var r=t[0]+","+t[1]+","+t[2];return"rgba"!==e&&"hsva"!==e&&"hsla"!==e||(r+=","+t[3]),e+"("+r+")"}};var _r=fr.parseToFloat,gr={},vr=Pe.extend(function(){return{name:"",depthTest:!0,depthMask:!0,transparent:!1,blend:null,autoUpdateTextureStatus:!0,uniforms:{},vertexDefines:{},fragmentDefines:{},_textureStatus:{},_enabledUniforms:null}},function(){this.name||(this.name="MATERIAL_"+this.__uid__),this.shader&&this.attachShader(this.shader,!0)},{precision:"highp",bind:function(t,e,r,n){for(var i=t.gl,a=e.currentTextureSlot(),o=0;o=0},getEnabledUniforms:function(){return this._enabledUniforms},getTextureUniforms:function(){return this._textureUniforms},set:function(t,e){if("object"==typeof t)for(var r in t){var n=t[r];this.setUniform(r,n)}else this.setUniform(t,e)},get:function(t){var e=this.uniforms[t];if(e)return e.value},attachShader:function(t,e){var r=this.uniforms;this.uniforms=t.createUniforms(),this.shader=t;var n=this.uniforms;this._enabledUniforms=Object.keys(n),this._enabledUniforms.sort(),this._textureUniforms=this._enabledUniforms.filter(function(t){var e=this.uniforms[t].type;return"t"===e||"tv"===e},this);var i=this.vertexDefines,a=this.fragmentDefines;if(this.vertexDefines=Le.clone(t.vertexDefines),this.fragmentDefines=Le.clone(t.fragmentDefines),e){for(var o in r)n[o]&&(n[o].value=r[o].value);Le.defaults(this.vertexDefines,i),Le.defaults(this.fragmentDefines,a)}var s={};for(var u in t.textures)s[u]={shaderType:t.textures[u].shaderType,type:t.textures[u].type,enabled:!(!e||!this._textureStatus[u])&&this._textureStatus[u].enabled};this._textureStatus=s,this._programKey=""},clone:function(){var t=new this.constructor({name:this.name,shader:this.shader});for(var e in this.uniforms)t.uniforms[e].value=this.uniforms[e].value;return t.depthTest=this.depthTest,t.depthMask=this.depthMask,t.transparent=this.transparent,t.blend=this.blend,t.vertexDefines=Le.clone(this.vertexDefines),t.fragmentDefines=Le.clone(this.fragmentDefines),t.enableTexture(this.getEnabledTextures()),t.precision=this.precision,t},define:function(t,e,r){var n=this.vertexDefines,i=this.fragmentDefines;"vertex"!==t&&"fragment"!==t&&"both"!==t&&arguments.length<3&&(r=e,e=t,t="both"),r=null!=r?r:null,"vertex"!==t&&"both"!==t||n[e]!==r&&(n[e]=r,this._programKey=""),"fragment"!==t&&"both"!==t||i[e]!==r&&(i[e]=r,"both"!==t&&(this._programKey=""))},undefine:function(t,e){"vertex"!==t&&"fragment"!==t&&"both"!==t&&arguments.length<2&&(e=t,t="both"),"vertex"!==t&&"both"!==t||this.isDefined("vertex",e)&&(delete this.vertexDefines[e],this._programKey=""),"fragment"!==t&&"both"!==t||this.isDefined("fragment",e)&&(delete this.fragmentDefines[e],"both"!==t&&(this._programKey=""))},isDefined:function(t,e){switch(t){case"vertex":return void 0!==this.vertexDefines[e];case"fragment":return void 0!==this.fragmentDefines[e]}},getDefine:function(t,e){switch(t){case"vertex":return this.vertexDefines[e];case"fragment":return this.fragmentDefines[e]}},enableTexture:function(t){if(Array.isArray(t))for(var e=0;e=0)r.attributeSemantics[u]={symbol:a,type:c},h=!1;else if(Pr.indexOf(u)>=0){var f=!1,d=u;u.match(/TRANSPOSE$/)&&(f=!0,d=u.slice(0,-9)),r.matrixSemantics[u]={symbol:a,type:c,isTranspose:f,semanticNoTranspose:d},h=!1}else if(Lr.indexOf(u)>=0)r.uniformSemantics[u]={symbol:a,type:c},h=!1;else if("unconfigurable"===u)h=!1;else{if(!(l=r._parseDefaultValue(i,u)))throw new Error('Unkown semantic "'+u+'"');u=""}h&&(e[a]={type:c,value:o?Nr.array:l||Nr[i],semantic:u||null})}return["uniform",i,a,o].join(" ")+";\n"}}var e={},r=this,n="vertex";this._uniformList=[],this._vertexCode=this._vertexCode.replace(Sr,t),n="fragment",this._fragmentCode=this._fragmentCode.replace(Sr,t),r.matrixSemanticKeys=Object.keys(this.matrixSemantics),this.uniformTemplates=e},_parseDefaultValue:function(t,e){var r=/\[\s*(.*)\s*\]/;{if("vec2"!==t&&"vec3"!==t&&"vec4"!==t)return"bool"===t?function(){return"true"===e.toLowerCase() +}:"float"===t?function(){return parseFloat(e)}:"int"===t?function(){return parseInt(e)}:void 0;var n=r.exec(e)[1];if(n){var i=n.split(/\s*,\s*/);return function(){return new We.Float32Array(i)}}}},_parseAttributes:function(){function t(t,n,i,a,o){if(n&&i){var s=1;switch(n){case"vec4":s=4;break;case"vec3":s=3;break;case"vec2":s=2;break;case"float":s=1}if(e[i]={type:"float",size:s,semantic:o||null},o){if(Rr.indexOf(o)<0)throw new Error('Unkown semantic "'+o+'"');r.attributeSemantics[o]={symbol:i,type:n}}}return["attribute",n,i].join(" ")+";\n"}var e={},r=this;this._vertexCode=this._vertexCode.replace(wr,t),this.attributes=e},_parseDefines:function(){function t(t,n,i){var a="vertex"===r?e.vertexDefines:e.fragmentDefines;return a[n]||(a[n]="false"!=i&&("true"==i||(i?isNaN(parseFloat(i))?i.trim():parseFloat(i):null))),""}var e=this,r="vertex";this._vertexCode=this._vertexCode.replace(Mr,t),r="fragment",this._fragmentCode=this._fragmentCode.replace(Mr,t)},clone:function(){var t=Ir[this._shaderID];return new K(t.vertex,t.fragment)}},Object.defineProperty&&(Object.defineProperty(K.prototype,"shaderID",{get:function(){return this._shaderID}}),Object.defineProperty(K.prototype,"vertex",{get:function(){return this._vertexCode}}),Object.defineProperty(K.prototype,"fragment",{get:function(){return this._fragmentCode}}),Object.defineProperty(K.prototype,"uniforms",{get:function(){return this._uniformList}}));var Or=/(@import)\s*([0-9a-zA-Z_\-\.]*)/g;K.parseImport=function(t){return t=t.replace(Or,function(t,e,r){var t=K.source(r);return t?K.parseImport(t):(console.error('Shader chunk "'+r+'" not existed in library'),"")})};var Br=/(@export)\s*([0-9a-zA-Z_\-\.]*)\s*\n([\s\S]*?)@end/g;K.import=function(t){t.replace(Br,function(t,e,r,n){var n=n.replace(/(^[\s\t\xa0\u3000]+)|([\u3000\xa0\s\t]+\x24)/g,"");if(n){for(var i,a=r.split("."),o=K.codes,s=0;s0&&this.setViewport(this._viewportStack.pop())},saveClear:function(){this._clearStack.push({clearBit:this.clearBit,clearColor:this.clearColor})},restoreClear:function(){if(this._clearStack.length>0){var t=this._clearStack.pop();this.clearColor=t.clearColor,this.clearBit=t.clearBit}},bindSceneRendering:function(t){this._sceneRendering=t},render:function(t,e,r,n){var i=this.gl,a=this.clearColor;if(this.clearBit){i.colorMask(!0,!0,!0,!0),i.depthMask(!0);var o=this.viewport,s=!1,u=o.devicePixelRatio;(o.width!==this._width||o.height!==this._height||u&&u!==this.devicePixelRatio||o.x||o.y)&&(s=!0,i.enable(i.SCISSOR_TEST),i.scissor(o.x*u,o.y*u,o.width*u,o.height*u)),i.clearColor(a[0],a[1],a[2],a[3]),i.clear(this.clearBit),s&&i.disable(i.SCISSOR_TEST)}if(r||t.update(!1),!(e=e||t.getMainCamera()))return void console.error("Can't find camera in the scene.");e.getScene()||e.update(!0),this._sceneRendering=t,t.viewBoundingBoxLastFrame.min.set(1/0,1/0,1/0),t.viewBoundingBoxLastFrame.max.set(-1/0,-1/0,-1/0);var l=this.cullRenderList(t.opaqueList,t,e),c=this.cullRenderList(t.transparentList,t,e),h=t.material;t.trigger("beforerender",this,t,e),n?(this.renderPreZ(l,t,e),i.depthFunc(i.LEQUAL)):i.depthFunc(i.LESS);for(var f=Vr(),d=Gr.create(),m=0;m0){var s=t[i-1],u=s.joints?s.joints.length:0;if((a.joints.length?a.joints.length:0)===u&&a.material===s.material&&a.lightGroup===s.lightGroup){a.__program=s.__program;continue}}var l=this._programMgr.getProgram(a,o,e);this.validateProgram(l),a.__program=l}},cullRenderList:function(t,e,r){for(var n=[],i=0;i0&&t.min.array[2]<0&&(t.max.array[2]=-1e-20),t.applyProjection(e);var u=t.min.array,l=t.max.array;if(l[0]<-1||u[0]>1||l[1]<-1||u[1]>1||l[2]<-1||u[2]>1)return!0}return!1}}(),disposeScene:function(t){this.disposeNode(t,!0,!0),t.dispose()},disposeNode:function(t,e,r){t.getParent()&&t.getParent().remove(t),t.traverse(function(t){t.geometry&&e&&t.geometry.dispose(this),t.dispose&&t.dispose(this)},this)},disposeGeometry:function(t){t.dispose(this)},disposeTexture:function(t){t.dispose(this)},disposeFrameBuffer:function(t){t.dispose(this)},dispose:function(){},screenToNDC:function(t,e,r){r||(r=new ge),e=this._height-e;var n=this.viewport,i=r.array;return i[0]=(t-n.x)/n.width,i[0]=2*i[0]-1,i[1]=(e-n.y)/n.height,i[1]=2*i[1]-1,r}});zr.opaqueSortCompare=zr.prototype.opaqueSortCompare=function(t,e){return t.renderOrder===e.renderOrder?t.__program===e.__program?t.material===e.material?t.geometry.__uid__-e.geometry.__uid__:t.material.__uid__-e.material.__uid__:t.__program&&e.__program?t.__program.__uid__-e.__program.__uid__:0:t.renderOrder-e.renderOrder},zr.transparentSortCompare=zr.prototype.transparentSortCompare=function(t,e){return t.renderOrder===e.renderOrder?t.__depth===e.__depth?t.__program===e.__program?t.material===e.material?t.geometry.__uid__-e.geometry.__uid__:t.material.__uid__-e.material.__uid__:t.__program&&e.__program?t.__program.__uid__-e.__program.__uid__:0:t.__depth-e.__depth:t.renderOrder-e.renderOrder};var Xr={IDENTITY:Vr(),WORLD:Vr(),VIEW:Vr(),PROJECTION:Vr(),WORLDVIEW:Vr(),VIEWPROJECTION:Vr(),WORLDVIEWPROJECTION:Vr(),WORLDINVERSE:Vr(),VIEWINVERSE:Vr(),PROJECTIONINVERSE:Vr(),WORLDVIEWINVERSE:Vr(),VIEWPROJECTIONINVERSE:Vr(),WORLDVIEWPROJECTIONINVERSE:Vr(),WORLDTRANSPOSE:Vr(),VIEWTRANSPOSE:Vr(),PROJECTIONTRANSPOSE:Vr(),WORLDVIEWTRANSPOSE:Vr(),VIEWPROJECTIONTRANSPOSE:Vr(),WORLDVIEWPROJECTIONTRANSPOSE:Vr(),WORLDINVERSETRANSPOSE:Vr(),VIEWINVERSETRANSPOSE:Vr(),PROJECTIONINVERSETRANSPOSE:Vr(),WORLDVIEWINVERSETRANSPOSE:Vr(),VIEWPROJECTIONINVERSETRANSPOSE:Vr(),WORLDVIEWPROJECTIONINVERSETRANSPOSE:Vr()};zr.COLOR_BUFFER_BIT=He.COLOR_BUFFER_BIT,zr.DEPTH_BUFFER_BIT=He.DEPTH_BUFFER_BIT,zr.STENCIL_BUFFER_BIT=He.STENCIL_BUFFER_BIT;var jr=pe.quat,qr=function(t,e,r,n){t=t||0,e=e||0,r=r||0,n=void 0===n?1:n,this.array=jr.fromValues(t,e,r,n),this._dirty=!0};qr.prototype={constructor:qr,add:function(t){return jr.add(this.array,this.array,t.array),this._dirty=!0,this},calculateW:function(){return jr.calculateW(this.array,this.array),this._dirty=!0,this},set:function(t,e,r,n){return this.array[0]=t,this.array[1]=e,this.array[2]=r,this.array[3]=n,this._dirty=!0,this},setArray:function(t){return this.array[0]=t[0],this.array[1]=t[1],this.array[2]=t[2],this.array[3]=t[3],this._dirty=!0,this},clone:function(){return new qr(this.x,this.y,this.z,this.w)},conjugate:function(){return jr.conjugate(this.array,this.array),this._dirty=!0,this},copy:function(t){return jr.copy(this.array,t.array),this._dirty=!0,this},dot:function(t){return jr.dot(this.array,t.array)},fromMat3:function(t){return jr.fromMat3(this.array,t.array),this._dirty=!0,this},fromMat4:function(){var t=pe.mat3,e=t.create();return function(r){return t.fromMat4(e,r.array),t.transpose(e,e),jr.fromMat3(this.array,e),this._dirty=!0,this}}(),identity:function(){return jr.identity(this.array),this._dirty=!0,this},invert:function(){return jr.invert(this.array,this.array),this._dirty=!0,this},len:function(){return jr.len(this.array)},length:function(){return jr.length(this.array)},lerp:function(t,e,r){return jr.lerp(this.array,t.array,e.array,r),this._dirty=!0,this},mul:function(t){return jr.mul(this.array,this.array,t.array),this._dirty=!0,this},mulLeft:function(t){return jr.multiply(this.array,t.array,this.array),this._dirty=!0,this},multiply:function(t){return jr.multiply(this.array,this.array,t.array),this._dirty=!0,this},multiplyLeft:function(t){return jr.multiply(this.array,t.array,this.array),this._dirty=!0,this},normalize:function(){return jr.normalize(this.array,this.array),this._dirty=!0,this},rotateX:function(t){return jr.rotateX(this.array,this.array,t),this._dirty=!0,this},rotateY:function(t){return jr.rotateY(this.array,this.array,t),this._dirty=!0,this},rotateZ:function(t){return jr.rotateZ(this.array,this.array,t),this._dirty=!0,this},rotationTo:function(t,e){return jr.rotationTo(this.array,t.array,e.array),this._dirty=!0,this},setAxes:function(t,e,r){return jr.setAxes(this.array,t.array,e.array,r.array),this._dirty=!0,this},setAxisAngle:function(t,e){return jr.setAxisAngle(this.array,t.array,e),this._dirty=!0,this},slerp:function(t,e,r){return jr.slerp(this.array,t.array,e.array,r),this._dirty=!0,this},sqrLen:function(){return jr.sqrLen(this.array)},squaredLength:function(){return jr.squaredLength(this.array)},fromEuler:function(t,e){return qr.fromEuler(this,t,e)},toString:function(){return"["+Array.prototype.join.call(this.array,",")+"]"},toArray:function(){return Array.prototype.slice.call(this.array)}};var Yr=Object.defineProperty;if(Yr){var Kr=qr.prototype;Yr(Kr,"x",{get:function(){return this.array[0]},set:function(t){this.array[0]=t,this._dirty=!0}}),Yr(Kr,"y",{get:function(){return this.array[1]},set:function(t){this.array[1]=t,this._dirty=!0}}),Yr(Kr,"z",{get:function(){return this.array[2]},set:function(t){this.array[2]=t,this._dirty=!0}}),Yr(Kr,"w",{get:function(){return this.array[3]},set:function(t){this.array[3]=t,this._dirty=!0}})}qr.add=function(t,e,r){return jr.add(t.array,e.array,r.array),t._dirty=!0,t},qr.set=function(t,e,r,n,i){jr.set(t.array,e,r,n,i),t._dirty=!0},qr.copy=function(t,e){return jr.copy(t.array,e.array),t._dirty=!0,t},qr.calculateW=function(t,e){return jr.calculateW(t.array,e.array),t._dirty=!0,t},qr.conjugate=function(t,e){return jr.conjugate(t.array,e.array),t._dirty=!0,t},qr.identity=function(t){return jr.identity(t.array),t._dirty=!0,t},qr.invert=function(t,e){return jr.invert(t.array,e.array),t._dirty=!0,t},qr.dot=function(t,e){return jr.dot(t.array,e.array)},qr.len=function(t){return jr.length(t.array)},qr.lerp=function(t,e,r,n){return jr.lerp(t.array,e.array,r.array,n),t._dirty=!0,t},qr.slerp=function(t,e,r,n){return jr.slerp(t.array,e.array,r.array,n),t._dirty=!0,t},qr.mul=function(t,e,r){return jr.multiply(t.array,e.array,r.array),t._dirty=!0,t},qr.multiply=qr.mul,qr.rotateX=function(t,e,r){return jr.rotateX(t.array,e.array,r),t._dirty=!0,t},qr.rotateY=function(t,e,r){return jr.rotateY(t.array,e.array,r),t._dirty=!0,t},qr.rotateZ=function(t,e,r){return jr.rotateZ(t.array,e.array,r),t._dirty=!0,t},qr.setAxisAngle=function(t,e,r){return jr.setAxisAngle(t.array,e.array,r),t._dirty=!0,t},qr.normalize=function(t,e){return jr.normalize(t.array,e.array),t._dirty=!0,t},qr.sqrLen=function(t){return jr.sqrLen(t.array)},qr.squaredLength=qr.sqrLen,qr.fromMat3=function(t,e){return jr.fromMat3(t.array,e.array),t._dirty=!0,t},qr.setAxes=function(t,e,r,n){return jr.setAxes(t.array,e.array,r.array,n.array),t._dirty=!0,t},qr.rotationTo=function(t,e,r){return jr.rotationTo(t.array,e.array,r.array),t._dirty=!0,t},qr.fromEuler=function(t,e,r){t._dirty=!0,e=e.array;var n=t.array,i=Math.cos(e[0]/2),a=Math.cos(e[1]/2),o=Math.cos(e[2]/2),s=Math.sin(e[0]/2),u=Math.sin(e[1]/2),l=Math.sin(e[2]/2),r=(r||"XYZ").toUpperCase();switch(r){case"XYZ":n[0]=s*a*o+i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o-s*u*l;break;case"YXZ":n[0]=s*a*o+i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o+s*u*l;break;case"ZXY":n[0]=s*a*o-i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o-s*u*l;break;case"ZYX":n[0]=s*a*o-i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o+s*u*l;break;case"YZX":n[0]=s*a*o+i*u*l,n[1]=i*u*o+s*a*l,n[2]=i*a*l-s*u*o,n[3]=i*a*o-s*u*l;break;case"XZY":n[0]=s*a*o-i*u*l,n[1]=i*u*o-s*a*l,n[2]=i*a*l+s*u*o,n[3]=i*a*o+s*u*l}};var Zr=pe.mat4,Jr=0,Qr=Pe.extend({name:"",position:null,rotation:null,scale:null,worldTransform:null,localTransform:null,autoUpdateLocalTransform:!0,_parent:null,_scene:null,_needsUpdateWorldTransform:!0,_inIterating:!1,__depth:0},function(){this.name||(this.name=(this.type||"NODE")+"_"+Jr++),this.position||(this.position=new Xe),this.rotation||(this.rotation=new qr),this.scale||(this.scale=new Xe(1,1,1)),this.worldTransform=new ar,this.localTransform=new ar,this._children=[]},{target:null,invisible:!1,isSkinnedMesh:function(){return!1},isRenderable:function(){return!1},setName:function(t){var e=this._scene;if(e){var r=e._nodeRepository;delete r[this.name],r[t]=this}this.name=t},add:function(t){this._inIterating&&console.warn("Add operation can cause unpredictable error when in iterating");var e=t._parent;if(e!==this){e&&e.remove(t),t._parent=this,this._children.push(t);var r=this._scene;r&&r!==t.scene&&t.traverse(this._addSelfToScene,this),t._needsUpdateWorldTransform=!0}},remove:function(t){this._inIterating&&console.warn("Remove operation can cause unpredictable error when in iterating");var e=this._children,r=e.indexOf(t);r<0||(e.splice(r,1),t._parent=null,this._scene&&t.traverse(this._removeSelfFromScene,this))},removeAll:function(){for(var t=this._children,e=0;ethis.distance,i=1;i<8;i++)if(tn.dot(e[i].array,r)>this.distance!=n)return!0},intersectLine:function(){var t=tn.create();return function(e,r,n){var i=this.distanceToPoint(e),a=this.distanceToPoint(r);if(i>0&&a>0||i<0&&a<0)return null;var o=this.normal.array,s=this.distance,u=e.array;tn.sub(t,r.array,e.array),tn.normalize(t,t);var l=tn.dot(o,t);if(0===l)return null;n||(n=new Xe);var c=(tn.dot(o,u)-s)/l;return tn.scaleAndAdd(n.array,u,t,-c),n._dirty=!0,n}}(),applyTransform:function(){var t=en.create(),e=rn.create(),r=rn.create();return r[3]=1,function(n){n=n.array,tn.scale(r,this.normal.array,this.distance),rn.transformMat4(r,r,n),this.distance=tn.dot(r,this.normal.array),en.invert(t,n),en.transpose(t,t),e[3]=0,tn.copy(e,this.normal.array),rn.transformMat4(e,e,t),tn.copy(this.normal.array,e)}}(),copy:function(t){tn.copy(this.normal.array,t.normal.array),this.normal._dirty=!0,this.distance=t.distance},clone:function(){var t=new nn;return t.copy(this),t}};var an=pe.vec3,on=an.set,sn=an.copy,un=an.transformMat4,ln=Math.min,cn=Math.max,hn=function(){this.planes=[];for(var t=0;t<6;t++)this.planes.push(new nn);this.boundingBox=new tr,this.vertices=[];for(var t=0;t<8;t++)this.vertices[t]=an.fromValues(0,0,0)};hn.prototype={setFromProjection:function(t){var e=this.planes,r=t.array,n=r[0],i=r[1],a=r[2],o=r[3],s=r[4],u=r[5],l=r[6],c=r[7],h=r[8],f=r[9],d=r[10],m=r[11],p=r[12],_=r[13],g=r[14],v=r[15];on(e[0].normal.array,o-n,c-s,m-h),e[0].distance=-(v-p),e[0].normalize(),on(e[1].normal.array,o+n,c+s,m+h),e[1].distance=-(v+p),e[1].normalize(),on(e[2].normal.array,o+i,c+u,m+f),e[2].distance=-(v+_),e[2].normalize(),on(e[3].normal.array,o-i,c-u,m-f),e[3].distance=-(v-_),e[3].normalize(),on(e[4].normal.array,o-a,c-l,m-d),e[4].distance=-(v-g),e[4].normalize(),on(e[5].normal.array,o+a,c+l,m+d),e[5].distance=-(v+g),e[5].normalize();var y=this.boundingBox;if(0===v){var x=u/n,T=-g/(d-1),E=-g/(d+1),b=-E/u,A=-T/u;y.min.set(-b*x,-b,E),y.max.set(b*x,b,T);var S=this.vertices;on(S[0],-b*x,-b,E),on(S[1],-b*x,b,E),on(S[2],b*x,-b,E),on(S[3],b*x,b,E),on(S[4],-A*x,-A,T),on(S[5],-A*x,A,T),on(S[6],A*x,-A,T),on(S[7],A*x,A,T)}else{var w=(-1-p)/n,M=(1-p)/n,C=(1-_)/u,N=(-1-_)/u,R=(-1-g)/d,L=(1-g)/d;y.min.set(Math.min(w,M),Math.min(N,C),Math.min(L,R)),y.max.set(Math.max(M,w),Math.max(C,N),Math.max(R,L));var P=y.min.array,D=y.max.array,S=this.vertices;on(S[0],P[0],P[1],P[2]),on(S[1],P[0],D[1],P[2]),on(S[2],D[0],P[1],P[2]),on(S[3],D[0],D[1],P[2]),on(S[4],P[0],P[1],D[2]),on(S[5],P[0],D[1],D[2]),on(S[6],D[0],P[1],D[2]),on(S[7],D[0],D[1],D[2])}},getTransformedBoundingBox:function(){var t=an.create();return function(e,r){var n=this.vertices,i=r.array,a=e.min,o=e.max,s=a.array,u=o.array,l=n[0];un(t,l,i),sn(s,t),sn(u,t);for(var c=1;c<8;c++)l=n[c],un(t,l,i),s[0]=ln(t[0],s[0]),s[1]=ln(t[1],s[1]),s[2]=ln(t[2],s[2]),u[0]=cn(t[0],u[0]),u[1]=cn(t[1],u[1]),u[2]=cn(t[2],u[2]);return a._dirty=!0,o._dirty=!0,e}}()};var fn=pe.vec3,dn=function(t,e){this.origin=t||new Xe,this.direction=e||new Xe};dn.prototype={constructor:dn,intersectPlane:function(t,e){var r=t.normal.array,n=t.distance,i=this.origin.array,a=this.direction.array,o=fn.dot(r,a);if(0===o)return null;e||(e=new Xe);var s=(fn.dot(r,i)-n)/o;return fn.scaleAndAdd(e.array,i,a,-s),e._dirty=!0,e},mirrorAgainstPlane:function(t){var e=fn.dot(t.normal.array,this.direction.array);fn.scaleAndAdd(this.direction.array,this.direction.array,t.normal.array,2*-e),this.direction._dirty=!0},distanceToPoint:function(){var t=fn.create();return function(e){fn.sub(t,e,this.origin.array);var r=fn.dot(t,this.direction.array);if(r<0)return fn.distance(this.origin.array,e);var n=fn.lenSquared(t);return Math.sqrt(n-r*r)}}(),intersectSphere:function(){var t=fn.create();return function(e,r,n){var i=this.origin.array,a=this.direction.array;e=e.array,fn.sub(t,e,i);var o=fn.dot(t,a),s=fn.squaredLength(t),u=s-o*o,l=r*r;if(!(u>l)){var c=Math.sqrt(l-u),h=o-c,f=o+c;return n||(n=new Xe),h<0?f<0?null:(fn.scaleAndAdd(n.array,i,a,f),n):(fn.scaleAndAdd(n.array,i,a,h),n)}}}(),intersectBoundingBox:function(t,e){var r,n,i,a,o,s,u=this.direction.array,l=this.origin.array,c=t.min.array,h=t.max.array,f=1/u[0],d=1/u[1],m=1/u[2];if(f>=0?(r=(c[0]-l[0])*f,n=(h[0]-l[0])*f):(n=(c[0]-l[0])*f,r=(h[0]-l[0])*f),d>=0?(i=(c[1]-l[1])*d,a=(h[1]-l[1])*d):(a=(c[1]-l[1])*d,i=(h[1]-l[1])*d),r>a||i>n)return null;if((i>r||r!==r)&&(r=i),(a=0?(o=(c[2]-l[2])*m,s=(h[2]-l[2])*m):(s=(c[2]-l[2])*m, +o=(h[2]-l[2])*m),r>s||o>n)return null;if((o>r||r!==r)&&(r=o),(s=0?r:n;return e||(e=new Xe),fn.scaleAndAdd(e.array,l,u,p),e},intersectTriangle:function(){var t=fn.create(),e=fn.create(),r=fn.create(),n=fn.create();return function(i,a,o,s,u,l){var c=this.direction.array,h=this.origin.array;i=i.array,a=a.array,o=o.array,fn.sub(t,a,i),fn.sub(e,o,i),fn.cross(n,e,c);var f=fn.dot(t,n);if(s){if(f>-1e-5)return null}else if(f>-1e-5&&f<1e-5)return null;fn.sub(r,h,i);var d=fn.dot(n,r)/f;if(d<0||d>1)return null;fn.cross(n,t,r);var m=fn.dot(c,n)/f;if(m<0||m>1||d+m>1)return null;fn.cross(n,t,e);var p=-fn.dot(r,n)/f;return p<0?null:(u||(u=new Xe),l&&Xe.set(l,1-d-m,d,m),fn.scaleAndAdd(u.array,h,c,p),u)}}(),applyTransform:function(t){Xe.add(this.direction,this.direction,this.origin),Xe.transformMat4(this.origin,this.origin,t),Xe.transformMat4(this.direction,this.direction,t),Xe.sub(this.direction,this.direction,this.origin),Xe.normalize(this.direction,this.direction)},copy:function(t){Xe.copy(this.origin,t.origin),Xe.copy(this.direction,t.direction)},clone:function(){var t=new dn;return t.copy(this),t}};var mn=pe.vec3,pn=pe.vec4,_n=Qr.extend(function(){return{projectionMatrix:new ar,invProjectionMatrix:new ar,viewMatrix:new ar,frustum:new hn}},function(){this.update(!0)},{update:function(t){Qr.prototype.update.call(this,t),ar.invert(this.viewMatrix,this.worldTransform),this.updateProjectionMatrix(),ar.invert(this.invProjectionMatrix,this.projectionMatrix),this.frustum.setFromProjection(this.projectionMatrix)},setViewMatrix:function(t){ar.copy(this.viewMatrix,t),ar.invert(this.worldTransform,t),this.decomposeWorldTransform()},decomposeProjectionMatrix:function(){},setProjectionMatrix:function(t){ar.copy(this.projectionMatrix,t),ar.invert(this.invProjectionMatrix,t),this.decomposeProjectionMatrix()},updateProjectionMatrix:function(){},castRay:function(){var t=pn.create();return function(e,r){var n=void 0!==r?r:new dn,i=e.array[0],a=e.array[1];return pn.set(t,i,a,-1,1),pn.transformMat4(t,t,this.invProjectionMatrix.array),pn.transformMat4(t,t,this.worldTransform.array),mn.scale(n.origin.array,t,1/t[3]),pn.set(t,i,a,1,1),pn.transformMat4(t,t,this.invProjectionMatrix.array),pn.transformMat4(t,t,this.worldTransform.array),mn.scale(t,t,1/t[3]),mn.sub(n.direction.array,t,n.origin.array),mn.normalize(n.direction.array,n.direction.array),n.direction._dirty=!0,n.origin._dirty=!0,n}}()}),gn={},vn=Qr.extend(function(){return{material:null,autoUpdate:!0,opaqueList:[],transparentList:[],lights:[],viewBoundingBoxLastFrame:new tr,shadowUniforms:{},_cameraList:[],_lightUniforms:{},_previousLightNumber:{},_lightNumber:{},_lightProgramKeys:{},_opaqueObjectCount:0,_transparentObjectCount:0,_nodeRepository:{}}},function(){this._scene=this},{addToScene:function(t){t instanceof _n&&(this._cameraList.length>0&&console.warn("Found multiple camera in one scene. Use the fist one."),this._cameraList.push(t)),t.name&&(this._nodeRepository[t.name]=t)},removeFromScene:function(t){if(t instanceof _n){var e=this._cameraList.indexOf(t);e>=0&&this._cameraList.splice(e,1)}t.name&&delete this._nodeRepository[t.name]},getNode:function(t){return this._nodeRepository[t]},cloneNode:function(t){var e=t.clone(),r={},n=function(i,a){i.skeleton&&(a.skeleton=i.skeleton.clone(t,e),a.joints=i.joints.slice()),i.material&&(r[i.material.__uid__]={oldMat:i.material});for(var o=0;o0&&this._updateRenderList(n)}},_updateLightUniforms:function(){var t=this.lights;t.sort($);var e=this._lightUniforms;for(var r in e)for(var n in e[r])e[r][n].value.length=0;for(var i=0;ia[0]&&(a[0]=s),u>a[1]&&(a[1]=u),l>a[2]&&(a[2]=l)}r._dirty=!0,n._dirty=!0}},dirty:function(){for(var t=this.getEnabledAttributes(),e=0;e=0){e||(e=Tn());var r=this.indices;return e[0]=r[3*t],e[1]=r[3*t+1],e[2]=r[3*t+2],e}},setTriangleIndices:function(t,e){var r=this.indices;r[3*t]=e[0],r[3*t+1]=e[1],r[3*t+2]=e[2]},isUseIndices:function(){return!!this.indices},initIndicesFromArray:function(t){var e,r=this.vertexCount>65535?We.Uint32Array:We.Uint16Array;if(t[0]&&t[0].length){var n=0;e=new r(3*t.length);for(var i=0;i=0&&(e.splice(r,1),delete this.attributes[t],!0)},getAttribute:function(t){return this.attributes[t]},getEnabledAttributes:function(){var t=this._enabledAttributes,e=this._attributeList;if(t)return t;for(var r=[],n=this.vertexCount,i=0;i65535&&(this.indices=new We.Uint32Array(this.indices));for(var t=this.attributes,e=this.indices,r=this.getEnabledAttributes(),n={},i=0;i65535?Uint32Array:Uint16Array,m=this.indices=new d(e*t*6),p=this.radius,_=this.phiStart,g=this.phiLength,v=this.thetaStart,y=this.thetaLength,p=this.radius,x=[],T=[],E=0,b=1/p;for(f=0;f<=t;f++)for(h=0;h<=e;h++)l=h/e,c=f/t,o=-p*Math.cos(_+l*g)*Math.sin(v+c*y),s=p*Math.cos(v+c*y),u=p*Math.sin(_+l*g)*Math.sin(v+c*y),x[0]=o,x[1]=s,x[2]=u,T[0]=l,T[1]=c,r.set(E,x),n.set(E,T),x[0]*=b,x[1]*=b,x[2]*=b,i.set(E,x),E++;var A,S,w,M,C=e+1,N=0;for(f=0;f65535?Uint32Array:Uint16Array,g=(o-1)*(s-1)*6,v=this.indices=new _(g),y=0,f=0;f>1,t|=t>>2,t|=t>>4,t|=t>>8,t|=t>>16,++t},Rn.nearestPowerOfTwo=function(t){return Math.pow(2,Math.round(Math.log(t)/Math.LN2))};var Ln=Rn.isPowerOfTwo,Pn=lr.extend(function(){return{image:null,pixels:null,mipmaps:[]}},{update:function(t){var e=t.gl;e.bindTexture(e.TEXTURE_2D,this._cache.get("webgl_texture")),this.updateCommon(t);var r=this.format,n=this.type;e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,this.getAvailableWrapS()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,this.getAvailableWrapT()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,this.getAvailableMagFilter()),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,this.getAvailableMinFilter());var i=t.getGLExtension("EXT_texture_filter_anisotropic");if(i&&this.anisotropic>1&&e.texParameterf(e.TEXTURE_2D,i.TEXTURE_MAX_ANISOTROPY_EXT,this.anisotropic),36193===n){t.getGLExtension("OES_texture_half_float")||(n=He.FLOAT)}if(this.mipmaps.length)for(var a=this.width,o=this.height,s=0;s=lr.COMPRESSED_RGB_S3TC_DXT1_EXT?t.compressedTexImage2D(t.TEXTURE_2D,r,a,n,i,0,e.pixels):t.texImage2D(t.TEXTURE_2D,r,a,n,i,0,a,o,e.pixels)},generateMipmap:function(t){var e=t.gl;this.useMipmap&&!this.NPOT&&(e.bindTexture(e.TEXTURE_2D,this._cache.get("webgl_texture")),e.generateMipmap(e.TEXTURE_2D))},isPowerOfTwo:function(){var t,e;return this.image?(t=this.image.width,e=this.image.height):(t=this.width,e=this.height),Ln(t)&&Ln(e)},isRenderable:function(){return this.image?"CANVAS"===this.image.nodeName||"VIDEO"===this.image.nodeName||this.image.complete:!(!this.width||!this.height)},bind:function(t){t.gl.bindTexture(t.gl.TEXTURE_2D,this.getWebGLTexture(t))},unbind:function(t){t.gl.bindTexture(t.gl.TEXTURE_2D,null)},load:function(t,e){var r=new Image;e&&(r.crossOrigin=e);var n=this;return r.onload=function(){n.dirty(),n.trigger("success",n),r.onload=null},r.onerror=function(){n.trigger("error",n),r.onerror=null},r.src=t,this.image=r,this}});Object.defineProperty(Pn.prototype,"width",{get:function(){return this.image?this.image.width:this._width},set:function(t){this.image?console.warn("Texture from image can't set width"):(this._width!==t&&this.dirty(),this._width=t)}}),Object.defineProperty(Pn.prototype,"height",{get:function(){return this.image?this.image.height:this._height},set:function(t){this.image?console.warn("Texture from image can't set height"):(this._height!==t&&this.dirty(),this._height=t)}});var Dn=Rn.isPowerOfTwo,In=["px","nx","py","ny","pz","nz"],On=lr.extend(function(){return{image:{px:null,nx:null,py:null,ny:null,pz:null,nz:null},pixels:{px:null,nx:null,py:null,ny:null,pz:null,nz:null},mipmaps:[]}},{update:function(t){var e=t.gl;e.bindTexture(e.TEXTURE_CUBE_MAP,this._cache.get("webgl_texture")),this.updateCommon(t);var r=this.format,n=this.type;e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_WRAP_S,this.getAvailableWrapS()),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_WRAP_T,this.getAvailableWrapT()),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_MAG_FILTER,this.getAvailableMagFilter()),e.texParameteri(e.TEXTURE_CUBE_MAP,e.TEXTURE_MIN_FILTER,this.getAvailableMinFilter());var i=t.getGLExtension("EXT_texture_filter_anisotropic");if(i&&this.anisotropic>1&&e.texParameterf(e.TEXTURE_CUBE_MAP,i.TEXTURE_MAX_ANISOTROPY_EXT,this.anisotropic),36193===n){t.getGLExtension("OES_texture_half_float")||(n=He.FLOAT)}if(this.mipmaps.length)for(var a=this.width,o=this.height,s=0;s0},beforeRender:function(t){},afterRender:function(t,e){},getBoundingBox:function(t,e){return e=Qr.prototype.getBoundingBox.call(this,t,e),this.geometry&&this.geometry.boundingBox&&e.union(this.geometry.boundingBox),e},render:function(t,e,r){var n=t.gl;e=e||this.material;var i=e.shader,a=this.geometry,o=this.mode,s=a.vertexCount,u=(a.isUseIndices(),t.getGLExtension("OES_element_index_uint")),l=u&&s>65535,c=l?n.UNSIGNED_INT:n.UNSIGNED_SHORT,h=t.getGLExtension("OES_vertex_array_object"),f=!a.dynamic,d=this._renderInfo;d.vertexCount=s,d.triangleCount=0,d.drawCallCount=0;var m=!1;if(Fn=t.__uid__+"-"+a.__uid__+"-"+r.__uid__,Fn!==Hn?m=!0:(h&&f||a._cache.isDirty("any"))&&(m=!0),Hn=Fn,m){var p=this._drawCache[Fn];if(!p){var _=a.getBufferChunks(t);if(!_)return;p=[];for(var g=0;g<_.length;g++){for(var v=_[g],y=v.attributeBuffers,x=v.indicesBuffer,T=[],E=[],b=0;b0)},render:function(t,e,r){var n=t.gl;if(this.skeleton){this.skeleton.update();var i=this.skeleton.getSubSkinMatrices(this.__uid__,this.joints);r.setUniformOfSemantic(n,"SKIN_MATRIX",i)}return zn.prototype.render.call(this,t,e,r)},getSkinMatricesTexture:function(){return this._skinMatricesTexture=this._skinMatricesTexture||new Pn({type:He.FLOAT,minFilter:He.NEAREST,magFilter:He.NEAREST,useMipmap:!1,flipY:!1}),this._skinMatricesTexture}});Xn.POINTS=He.POINTS,Xn.LINES=He.LINES,Xn.LINE_LOOP=He.LINE_LOOP,Xn.LINE_STRIP=He.LINE_STRIP,Xn.TRIANGLES=He.TRIANGLES,Xn.TRIANGLE_STRIP=He.TRIANGLE_STRIP,Xn.TRIANGLE_FAN=He.TRIANGLE_FAN,Xn.BACK=He.BACK,Xn.FRONT=He.FRONT,Xn.FRONT_AND_BACK=He.FRONT_AND_BACK,Xn.CW=He.CW,Xn.CCW=He.CCW;var jn=_n.extend({fov:50,aspect:1,near:.1,far:2e3},{updateProjectionMatrix:function(){var t=this.fov/180*Math.PI;this.projectionMatrix.perspective(t,this.aspect,this.near,this.far)},decomposeProjectionMatrix:function(){var t=this.projectionMatrix.array,e=2*Math.atan(1/t[5]);this.fov=e/Math.PI*180,this.aspect=t[5]/t[0],this.near=t[14]/(t[10]-1),this.far=t[14]/(t[10]+1)},clone:function(){var t=_n.prototype.clone.call(this);return t.fov=this.fov,t.aspect=this.aspect,t.near=this.near,t.far=this.far,t}}),qn=_n.extend({left:-1,right:1,near:-1,far:1,top:1,bottom:-1},{updateProjectionMatrix:function(){this.projectionMatrix.ortho(this.left,this.right,this.bottom,this.top,this.near,this.far)},decomposeProjectionMatrix:function(){var t=this.projectionMatrix.array;this.left=(-1-t[12])/t[0],this.right=(1-t[12])/t[0],this.top=(1-t[13])/t[5],this.bottom=(-1-t[13])/t[5],this.near=-(-1-t[14])/t[10],this.far=-(1-t[14])/t[10]},clone:function(){var t=_n.prototype.clone.call(this);return t.left=this.left,t.right=this.right,t.near=this.near,t.far=this.far,t.top=this.top,t.bottom=this.bottom,t}}),Yn={get:ct +},Kn="\n@export clay.standard.vertex\n#define SHADER_NAME standard\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 worldInverseTranspose : WORLDINVERSETRANSPOSE;\nuniform mat4 world : WORLD;\nuniform vec2 uvRepeat : [1.0, 1.0];\nuniform vec2 uvOffset : [0.0, 0.0];\nattribute vec3 position : POSITION;\nattribute vec2 texcoord : TEXCOORD_0;\n#if defined(AOMAP_ENABLED)\nattribute vec2 texcoord2 : TEXCOORD_1;\n#endif\nattribute vec3 normal : NORMAL;\nattribute vec4 tangent : TANGENT;\n#ifdef VERTEX_COLOR\nattribute vec4 a_Color : COLOR;\nvarying vec4 v_Color;\n#endif\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nvarying vec3 v_Barycentric;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#if defined(AOMAP_ENABLED)\nvarying vec2 v_Texcoord2;\n#endif\nvoid main()\n{\n vec3 skinnedPosition = position;\n vec3 skinnedNormal = normal;\n vec3 skinnedTangent = tangent.xyz;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n v_Barycentric = barycentric;\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n#endif\n#ifdef VERTEX_COLOR\n v_Color = a_Color;\n#endif\n#if defined(AOMAP_ENABLED)\n v_Texcoord2 = texcoord2;\n#endif\n}\n@end\n@export clay.standard.fragment\n#define PI 3.14159265358979\n#define GLOSSINESS_CHANNEL 0\n#define ROUGHNESS_CHANNEL 0\n#define METALNESS_CHANNEL 1\nuniform mat4 viewInverse : VIEWINVERSE;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\n#ifdef VERTEX_COLOR\nvarying vec4 v_Color;\n#endif\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\n#endif\n#ifdef NORMALMAP_ENABLED\nuniform sampler2D normalMap;\n#endif\n#ifdef DIFFUSEMAP_ENABLED\nuniform sampler2D diffuseMap;\n#endif\n#ifdef SPECULARMAP_ENABLED\nuniform sampler2D specularMap;\n#endif\n#ifdef USE_ROUGHNESS\nuniform float roughness : 0.5;\n #ifdef ROUGHNESSMAP_ENABLED\nuniform sampler2D roughnessMap;\n #endif\n#else\nuniform float glossiness: 0.5;\n #ifdef GLOSSINESSMAP_ENABLED\nuniform sampler2D glossinessMap;\n #endif\n#endif\n#ifdef METALNESSMAP_ENABLED\nuniform sampler2D metalnessMap;\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\nuniform samplerCube environmentMap;\n #ifdef PARALLAX_CORRECTED\nuniform vec3 environmentBoxMin;\nuniform vec3 environmentBoxMax;\n #endif\n#endif\n#ifdef BRDFLOOKUP_ENABLED\nuniform sampler2D brdfLookup;\n#endif\n#ifdef EMISSIVEMAP_ENABLED\nuniform sampler2D emissiveMap;\n#endif\n#ifdef SSAOMAP_ENABLED\nuniform sampler2D ssaoMap;\nuniform vec4 viewport : VIEWPORT;\n#endif\n#ifdef AOMAP_ENABLED\nuniform sampler2D aoMap;\nuniform float aoIntensity;\nvarying vec2 v_Texcoord2;\n#endif\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\n#ifdef ALPHA_TEST\nuniform float alphaCutoff: 0.9;\n#endif\n#ifdef USE_METALNESS\nuniform float metalness : 0.0;\n#else\nuniform vec3 specularColor : [0.1, 0.1, 0.1];\n#endif\nuniform vec3 emission : [0.0, 0.0, 0.0];\nuniform float emissionIntensity: 1;\nuniform float lineWidth : 0.0;\nuniform vec4 lineColor : [0.0, 0.0, 0.0, 0.6];\nvarying vec3 v_Barycentric;\n#ifdef ENVIRONMENTMAP_PREFILTER\nuniform float maxMipmapLevel: 5;\n#endif\n#ifdef AMBIENT_LIGHT_COUNT\n@import clay.header.ambient_light\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n@import clay.header.ambient_sh_light\n#endif\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n@import clay.header.ambient_cubemap_light\n#endif\n#ifdef POINT_LIGHT_COUNT\n@import clay.header.point_light\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n@import clay.header.directional_light\n#endif\n#ifdef SPOT_LIGHT_COUNT\n@import clay.header.spot_light\n#endif\n@import clay.util.calculate_attenuation\n@import clay.util.edge_factor\n@import clay.util.rgbm\n@import clay.util.srgb\n@import clay.plugin.compute_shadow_map\n@import clay.util.parallax_correct\n@import clay.util.ACES\nfloat G_Smith(float g, float ndv, float ndl)\n{\n float roughness = 1.0 - g;\n float k = roughness * roughness / 2.0;\n float G1V = ndv / (ndv * (1.0 - k) + k);\n float G1L = ndl / (ndl * (1.0 - k) + k);\n return G1L * G1V;\n}\nvec3 F_Schlick(float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nfloat D_Phong(float g, float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(float g, float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (PI * tmp * tmp);\n}\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\nuniform float parallaxOcclusionScale : 0.02;\nuniform float parallaxMaxLayers : 20;\nuniform float parallaxMinLayers : 5;\nuniform sampler2D parallaxOcclusionMap;\nmat3 transpose(in mat3 inMat)\n{\n vec3 i0 = inMat[0];\n vec3 i1 = inMat[1];\n vec3 i2 = inMat[2];\n return mat3(\n vec3(i0.x, i1.x, i2.x),\n vec3(i0.y, i1.y, i2.y),\n vec3(i0.z, i1.z, i2.z)\n );\n}\nvec2 parallaxUv(vec2 uv, vec3 viewDir)\n{\n float numLayers = mix(parallaxMaxLayers, parallaxMinLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));\n float layerHeight = 1.0 / numLayers;\n float curLayerHeight = 0.0;\n vec2 deltaUv = viewDir.xy * parallaxOcclusionScale / (viewDir.z * numLayers);\n vec2 curUv = uv;\n float height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n for (int i = 0; i < 30; i++) {\n curLayerHeight += layerHeight;\n curUv -= deltaUv;\n height = 1.0 - texture2D(parallaxOcclusionMap, curUv).r;\n if (height < curLayerHeight) {\n break;\n }\n }\n vec2 prevUv = curUv + deltaUv;\n float next = height - curLayerHeight;\n float prev = 1.0 - texture2D(parallaxOcclusionMap, prevUv).r - curLayerHeight + layerHeight;\n return mix(curUv, prevUv, next / (next - prev));\n}\n#endif\nvoid main() {\n vec4 albedoColor = vec4(color, alpha);\n#ifdef VERTEX_COLOR\n albedoColor *= v_Color;\n#endif\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = normalize(eyePos - v_WorldPosition);\n vec2 uv = v_Texcoord;\n#if defined(PARALLAXOCCLUSIONMAP_ENABLED) || defined(NORMALMAP_ENABLED)\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n#endif\n#ifdef PARALLAXOCCLUSIONMAP_ENABLED\n uv = parallaxUv(v_Texcoord, normalize(transpose(tbn) * -V));\n#endif\n#ifdef DIFFUSEMAP_ENABLED\n vec4 texel = texture2D(diffuseMap, uv);\n #ifdef SRGB_DECODE\n texel = sRGBToLinear(texel);\n #endif\n albedoColor.rgb *= texel.rgb;\n #ifdef DIFFUSEMAP_ALPHA_ALPHA\n albedoColor.a *= texel.a;\n #endif\n#endif\n#ifdef USE_METALNESS\n float m = metalness;\n #ifdef METALNESSMAP_ENABLED\n float m2 = texture2D(metalnessMap, uv)[METALNESS_CHANNEL];\n m = clamp(m2 + (m - 0.5) * 2.0, 0.0, 1.0);\n #endif\n vec3 baseColor = albedoColor.rgb;\n albedoColor.rgb = baseColor * (1.0 - m);\n vec3 spec = mix(vec3(0.04), baseColor, m);\n#else\n vec3 spec = specularColor;\n#endif\n#ifdef USE_ROUGHNESS\n float g = 1.0 - roughness;\n #ifdef ROUGHNESSMAP_ENABLED\n float g2 = 1.0 - texture2D(roughnessMap, uv)[ROUGHNESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#else\n float g = glossiness;\n #ifdef GLOSSINESSMAP_ENABLED\n float g2 = texture2D(glossinessMap, uv)[GLOSSINESS_CHANNEL];\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n #endif\n#endif\n#ifdef SPECULARMAP_ENABLED\n spec *= sRGBToLinear(texture2D(specularMap, uv)).rgb;\n#endif\n vec3 N = v_Normal;\n#ifdef DOUBLE_SIDED\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n#endif\n#ifdef NORMALMAP_ENABLED\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, uv).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n tbn[1] = -tbn[1];\n N = normalize(tbn * N);\n }\n }\n#endif\n vec3 diffuseTerm = vec3(0.0, 0.0, 0.0);\n vec3 specularTerm = vec3(0.0, 0.0, 0.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n vec3 fresnelTerm = F_Schlick(ndv, spec);\n#ifdef AMBIENT_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += ambientLightColor[_idx_];\n }}\n#endif\n#ifdef AMBIENT_SH_LIGHT_COUNT\n for(int _idx_ = 0; _idx_ < AMBIENT_SH_LIGHT_COUNT; _idx_++)\n {{\n diffuseTerm += calcAmbientSHLight(_idx_, N) * ambientSHLightColor[_idx_];\n }}\n#endif\n#ifdef POINT_LIGHT_COUNT\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsPoint[POINT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfPointLights(v_WorldPosition, shadowContribsPoint);\n }\n#endif\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_COUNT; _idx_++)\n {{\n vec3 lightPosition = pointLightPosition[_idx_];\n vec3 lc = pointLightColor[_idx_];\n float range = pointLightRange[_idx_];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsPoint[_idx_];\n }\n#endif\n vec3 li = lc * ndl * attenuation * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef DIRECTIONAL_LIGHT_COUNT\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsDir[DIRECTIONAL_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfDirectionalLights(v_WorldPosition, shadowContribsDir);\n }\n#endif\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++)\n {{\n vec3 L = -normalize(directionalLightDirection[_idx_]);\n vec3 lc = directionalLightColor[_idx_];\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(DIRECTIONAL_LIGHT_SHADOWMAP_COUNT)\n if(shadowEnabled)\n {\n shadowContrib = shadowContribsDir[_idx_];\n }\n#endif\n vec3 li = lc * ndl * shadowContrib;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }}\n#endif\n#ifdef SPOT_LIGHT_COUNT\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n float shadowContribsSpot[SPOT_LIGHT_COUNT];\n if(shadowEnabled)\n {\n computeShadowOfSpotLights(v_WorldPosition, shadowContribsSpot);\n }\n#endif\n for(int i = 0; i < SPOT_LIGHT_COUNT; i++)\n {\n vec3 lightPosition = spotLightPosition[i];\n vec3 spotLightDirection = -normalize(spotLightDirection[i]);\n vec3 lc = spotLightColor[i];\n float range = spotLightRange[i];\n float a = spotLightUmbraAngleCosine[i];\n float b = spotLightPenumbraAngleCosine[i];\n float falloffFactor = spotLightFalloffFactor[i];\n vec3 L = lightPosition - v_WorldPosition;\n float dist = length(L);\n float attenuation = lightAttenuation(dist, range);\n L /= dist;\n float c = dot(spotLightDirection, L);\n float falloff;\n falloff = clamp((c - a) /( b - a), 0.0, 1.0);\n falloff = pow(falloff, falloffFactor);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float shadowContrib = 1.0;\n#if defined(SPOT_LIGHT_SHADOWMAP_COUNT)\n if (shadowEnabled)\n {\n shadowContrib = shadowContribsSpot[i];\n }\n#endif\n vec3 li = lc * attenuation * (1.0 - falloff) * shadowContrib * ndl;\n diffuseTerm += li;\n specularTerm += li * fresnelTerm * D_Phong(g, ndh);\n }\n#endif\n vec4 outColor = albedoColor;\n outColor.rgb *= diffuseTerm;\n outColor.rgb += specularTerm;\n#ifdef AMBIENT_CUBEMAP_LIGHT_COUNT\n vec3 L = reflect(-V, N);\n float rough2 = clamp(1.0 - g, 0.0, 1.0);\n float bias2 = rough2 * 5.0;\n vec2 brdfParam2 = texture2D(ambientCubemapLightBRDFLookup[0], vec2(rough2, ndv)).xy;\n vec3 envWeight2 = spec * brdfParam2.x + brdfParam2.y;\n vec3 envTexel2;\n for(int _idx_ = 0; _idx_ < AMBIENT_CUBEMAP_LIGHT_COUNT; _idx_++)\n {{\n envTexel2 = RGBMDecode(textureCubeLodEXT(ambientCubemapLightCubemap[_idx_], L, bias2), 51.5);\n outColor.rgb += ambientCubemapLightColor[_idx_] * envTexel2 * envWeight2;\n }}\n#endif\n#ifdef ENVIRONMENTMAP_ENABLED\n vec3 envWeight = g * fresnelTerm;\n vec3 L = reflect(-V, N);\n #ifdef PARALLAX_CORRECTED\n L = parallaxCorrect(L, v_WorldPosition, environmentBoxMin, environmentBoxMax);\n #endif\n #ifdef ENVIRONMENTMAP_PREFILTER\n float rough = clamp(1.0 - g, 0.0, 1.0);\n float bias = rough * maxMipmapLevel;\n vec3 envTexel = decodeHDR(textureCubeLodEXT(environmentMap, L, bias)).rgb;\n #ifdef BRDFLOOKUP_ENABLED\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n envWeight = spec * brdfParam.x + brdfParam.y;\n #endif\n #else\n vec3 envTexel = textureCube(environmentMap, L).xyz;\n #endif\n outColor.rgb += envTexel * envWeight;\n#endif\n float aoFactor = 1.0;\n#ifdef SSAOMAP_ENABLED\n aoFactor = min(texture2D(ssaoMap, (gl_FragCoord.xy - viewport.xy) / viewport.zw).r, aoFactor);\n#endif\n#ifdef AOMAP_ENABLED\n aoFactor = min(1.0 - clamp((1.0 - texture2D(aoMap, v_Texcoord2).r) * aoIntensity, 0.0, 1.0), aoFactor);\n#endif\n outColor.rgb *= aoFactor;\n vec3 lEmission = emission;\n#ifdef EMISSIVEMAP_ENABLED\n lEmission *= texture2D(emissiveMap, uv).rgb;\n#endif\n outColor.rgb += lEmission * emissionIntensity;\n if(lineWidth > 0.)\n {\n outColor.rgb = mix(outColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (outColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n outColor.rgb = ACESToneMapping(outColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n outColor = linearTosRGB(outColor);\n#endif\n gl_FragColor = encodeHDR(outColor);\n}\n@end\n@export clay.standardMR.vertex\n@import clay.standard.vertex\n@end\n@export clay.standardMR.fragment\n#define USE_METALNESS\n#define USE_ROUGHNESS\n@import clay.standard.fragment\n@end";K.import(Kn);var Zn,Jn=["diffuseMap","normalMap","roughnessMap","metalnessMap","emissiveMap","environmentMap","brdfLookup","ssaoMap","aoMap"],Qn=["color","emission","emissionIntensity","alpha","roughness","metalness","uvRepeat","uvOffset","aoIntensity","alphaCutoff"],$n=["linear","encodeRGBM","decodeRGBM","doubleSided","alphaTest","roughnessChannel","metalnessChannel","environmentMapPrefiltered"],ti={roughnessChannel:"ROUGHNESS_CHANNEL",metalnessChannel:"METALNESS_CHANNEL"},ei={linear:"SRGB_DECODE",encodeRGBM:"RGBM_ENCODE",decodeRGBM:"RGBM_DECODE",doubleSided:"DOUBLE_SIDED",alphaTest:"ALPHA_TEST",environmentMapPrefiltered:"ENVIRONMENTMAP_PREFILTER"},ri=vr.extend(function(){return Zn||(Zn=new K(K.source("clay.standard.vertex"),K.source("clay.standard.fragment"))),{shader:Zn}},function(t){Le.extend(this,t),Le.defaults(this,{color:[1,1,1],emission:[0,0,0],emissionIntensity:0,roughness:.5,metalness:0,alpha:1,alphaTest:!1,alphaCutoff:.9,doubleSided:!1,uvRepeat:[1,1],uvOffset:[0,0],aoIntensity:1,environmentMapPrefiltered:!1,linear:!1,encodeRGBM:!1,decodeRGBM:!1,roughnessChannel:0,metalnessChannel:1}),this.define("fragment","USE_METALNESS"),this.define("fragment","USE_ROUGHNESS")},{clone:function(){var t=new ri({name:this.name});return Jn.forEach(function(e){this[e]&&(t[e]=this[e])},this),Qn.concat($n).forEach(function(e){t[e]=this[e]},this),t}});Qn.forEach(function(t){Object.defineProperty(ri.prototype,t,{get:function(){return this.get(t)},set:function(e){this.setUniform(t,e)}})}),Jn.forEach(function(t){Object.defineProperty(ri.prototype,t,{get:function(){return this.get(t)},set:function(e){this.setUniform(t,e)}})}),$n.forEach(function(t){var e="_"+t;Object.defineProperty(ri.prototype,t,{get:function(){return this[e]},set:function(r){if(this[e]=r,t in ti){var n=ti[t];this.define("fragment",n,r)}else{var n=ei[t];r?this.define("fragment",n):this.undefine("fragment",n)}}})}),Object.defineProperty(ri.prototype,"environmentBox",{get:function(){var t=this._environmentBox;return t&&(t.min.setArray(this.get("environmentBoxMin")),t.max.setArray(this.get("environmentBoxMax"))),t},set:function(t){this._environmentBox=t;var e=this.uniforms=this.uniforms||{};e.environmentBoxMin=e.environmentBoxMin||{value:null},e.environmentBoxMax=e.environmentBoxMax||{value:null},t&&(this.setUniform("environmentBoxMin",t.min.array),this.setUniform("environmentBoxMax",t.max.array)),t?this.define("fragment","PARALLAX_CORRECTED"):this.undefine("fragment","PARALLAX_CORRECTED")}});var ni=Pe.extend({name:"",index:-1,node:null,rootNode:null}),ii=pe.quat,ai=pe.vec3,oi=pe.mat4,si=Pe.extend(function(){return{relativeRootNode:null,name:"",joints:[],_clips:[],_invBindPoseMatricesArray:null,_jointMatricesSubArrays:[],_skinMatricesArray:null,_skinMatricesSubArrays:[],_subSkinMatricesArray:{}}},{addClip:function(t,e){for(var r=0;r0&&this._clips.splice(e,1)},removeClipsAll:function(){this._clips=[]},getClip:function(t){if(this._clips[t])return this._clips[t].clip},getClipNumber:function(){return this._clips.length},updateJointMatrices:function(){var t=oi.create();return function(){this._invBindPoseMatricesArray=new Float32Array(16*this.joints.length),this._skinMatricesArray=new Float32Array(16*this.joints.length);for(var e=0;e 0.)\n {\n gl_FragColor.rgb = mix(gl_FragColor.rgb, lineColor.rgb, (1.0 - edgeFactor(lineWidth)) * lineColor.a);\n }\n#ifdef ALPHA_TEST\n if (gl_FragColor.a < alphaCutoff) {\n discard;\n }\n#endif\n#ifdef TONEMAPPING\n gl_FragColor.rgb = ACESToneMapping(gl_FragColor.rgb);\n#endif\n#ifdef SRGB_ENCODE\n gl_FragColor = linearTosRGB(gl_FragColor);\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n}\n@end"),K.import(Kn),K.import("@export clay.wireframe.vertex\nuniform mat4 worldViewProjection : WORLDVIEWPROJECTION;\nuniform mat4 world : WORLD;\nattribute vec3 position : POSITION;\nattribute vec3 barycentric;\n@import clay.chunk.skinning_header\nvarying vec3 v_Barycentric;\nvoid main()\n{\n vec3 skinnedPosition = position;\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0 );\n v_Barycentric = barycentric;\n}\n@end\n@export clay.wireframe.fragment\nuniform vec3 color : [0.0, 0.0, 0.0];\nuniform float alpha : 1.0;\nuniform float lineWidth : 1.0;\nvarying vec3 v_Barycentric;\n@import clay.util.edge_factor\nvoid main()\n{\n gl_FragColor.rgb = color;\n gl_FragColor.a = (1.0-edgeFactor(lineWidth)) * alpha;\n}\n@end"),K.import(ci),K.import(kr),kn.template("clay.basic",K.source("clay.basic.vertex"),K.source("clay.basic.fragment")),kn.template("clay.lambert",K.source("clay.lambert.vertex"),K.source("clay.lambert.fragment")),kn.template("clay.wireframe",K.source("clay.wireframe.vertex"),K.source("clay.wireframe.fragment")),kn.template("clay.skybox",K.source("clay.skybox.vertex"),K.source("clay.skybox.fragment")),kn.template("clay.prez",K.source("clay.prez.vertex"),K.source("clay.prez.fragment")),kn.template("clay.standard",K.source("clay.standard.vertex"),K.source("clay.standard.fragment")),kn.template("clay.standardMR",K.source("clay.standardMR.vertex"),K.source("clay.standardMR.fragment")),K.import("@export clay.compositor.coloradjust\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float exposure : 0.0;\nuniform float gamma : 1.0;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = clamp(tex.rgb + vec3(brightness), 0.0, 1.0);\n color = clamp( (color-vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n color = clamp( color * pow(2.0, exposure), 0.0, 1.0);\n color = clamp( pow(color, vec3(gamma)), 0.0, 1.0);\n float luminance = dot( color, w );\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.brightness\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float brightness : 0.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = tex.rgb + vec3(brightness);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.contrast\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float contrast : 1.0;\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord);\n vec3 color = (tex.rgb-vec3(0.5))*contrast+vec3(0.5);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.exposure\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float exposure : 0.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb * pow(2.0, exposure);\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.gamma\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float gamma : 1.0;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = pow(tex.rgb, vec3(gamma));\n gl_FragColor = vec4(color, tex.a);\n}\n@end\n@export clay.compositor.saturation\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float saturation : 1.0;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n vec3 color = tex.rgb;\n float luminance = dot(color, w);\n color = mix(vec3(luminance), color, saturation);\n gl_FragColor = vec4(color, tex.a);\n}\n@end"),K.import("@export clay.compositor.kernel.gaussian_9\nfloat gaussianKernel[9];\ngaussianKernel[0] = 0.07;\ngaussianKernel[1] = 0.09;\ngaussianKernel[2] = 0.12;\ngaussianKernel[3] = 0.14;\ngaussianKernel[4] = 0.16;\ngaussianKernel[5] = 0.14;\ngaussianKernel[6] = 0.12;\ngaussianKernel[7] = 0.09;\ngaussianKernel[8] = 0.07;\n@end\n@export clay.compositor.kernel.gaussian_13\nfloat gaussianKernel[13];\ngaussianKernel[0] = 0.02;\ngaussianKernel[1] = 0.03;\ngaussianKernel[2] = 0.06;\ngaussianKernel[3] = 0.08;\ngaussianKernel[4] = 0.11;\ngaussianKernel[5] = 0.13;\ngaussianKernel[6] = 0.14;\ngaussianKernel[7] = 0.13;\ngaussianKernel[8] = 0.11;\ngaussianKernel[9] = 0.08;\ngaussianKernel[10] = 0.06;\ngaussianKernel[11] = 0.03;\ngaussianKernel[12] = 0.02;\n@end\n@export clay.compositor.gaussian_blur\n#define SHADER_NAME gaussian_blur\nuniform sampler2D texture;varying vec2 v_Texcoord;\nuniform float blurSize : 2.0;\nuniform vec2 textureSize : [512.0, 512.0];\nuniform float blurDir : 0.0;\n@import clay.util.rgbm\n@import clay.util.clamp_sample\nvoid main (void)\n{\n @import clay.compositor.kernel.gaussian_9\n vec2 off = blurSize / textureSize;\n off *= vec2(1.0 - blurDir, blurDir);\n vec4 sum = vec4(0.0);\n float weightAll = 0.0;\n for (int i = 0; i < 9; i++) {\n float w = gaussianKernel[i];\n vec4 texel = decodeHDR(clampSample(texture, v_Texcoord + float(i - 4) * off));\n sum += texel * w;\n weightAll += w;\n }\n gl_FragColor = encodeHDR(sum / max(weightAll, 0.01));\n}\n@end\n"),K.import("@export clay.compositor.hdr.log_lum\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\n float luminance = dot(tex.rgb, w);\n luminance = log(luminance + 0.001);\n gl_FragColor = encodeHDR(vec4(vec3(luminance), 1.0));\n}\n@end\n@export clay.compositor.hdr.lum_adaption\nvarying vec2 v_Texcoord;\nuniform sampler2D adaptedLum;\nuniform sampler2D currentLum;\nuniform float frameTime : 0.02;\n@import clay.util.rgbm\nvoid main()\n{\n float fAdaptedLum = decodeHDR(texture2D(adaptedLum, vec2(0.5, 0.5))).r;\n float fCurrentLum = exp(encodeHDR(texture2D(currentLum, vec2(0.5, 0.5))).r);\n fAdaptedLum += (fCurrentLum - fAdaptedLum) * (1.0 - pow(0.98, 30.0 * frameTime));\n gl_FragColor = encodeHDR(vec4(vec3(fAdaptedLum), 1.0));\n}\n@end\n@export clay.compositor.lum\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nconst vec3 w = vec3(0.2125, 0.7154, 0.0721);\nvoid main()\n{\n vec4 tex = texture2D( texture, v_Texcoord );\n float luminance = dot(tex.rgb, w);\n gl_FragColor = vec4(vec3(luminance), 1.0);\n}\n@end"),K.import("\n@export clay.compositor.lut\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform sampler2D lookup;\nvoid main()\n{\n vec4 tex = texture2D(texture, v_Texcoord);\n float blueColor = tex.b * 63.0;\n vec2 quad1;\n quad1.y = floor(floor(blueColor) / 8.0);\n quad1.x = floor(blueColor) - (quad1.y * 8.0);\n vec2 quad2;\n quad2.y = floor(ceil(blueColor) / 8.0);\n quad2.x = ceil(blueColor) - (quad2.y * 8.0);\n vec2 texPos1;\n texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\n texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\n vec2 texPos2;\n texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.r);\n texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * tex.g);\n vec4 newColor1 = texture2D(lookup, texPos1);\n vec4 newColor2 = texture2D(lookup, texPos2);\n vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\n gl_FragColor = vec4(newColor.rgb, tex.w);\n}\n@end"),K.import("@export clay.compositor.vignette\n#define OUTPUT_ALPHA\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\nuniform float darkness: 1;\nuniform float offset: 1;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\n gl_FragColor.rgb = texel.rgb;\n vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(offset);\n gl_FragColor = encodeHDR(vec4(mix(texel.rgb, vec3(1.0 - darkness), dot(uv, uv)), texel.a));\n}\n@end"),K.import("@export clay.compositor.output\n#define OUTPUT_ALPHA\nvarying vec2 v_Texcoord;\nuniform sampler2D texture;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = decodeHDR(texture2D(texture, v_Texcoord));\n gl_FragColor.rgb = tex.rgb;\n#ifdef OUTPUT_ALPHA\n gl_FragColor.a = tex.a;\n#else\n gl_FragColor.a = 1.0;\n#endif\n gl_FragColor = encodeHDR(gl_FragColor);\n#ifdef PREMULTIPLY_ALPHA\n gl_FragColor.rgb *= gl_FragColor.a;\n#endif\n}\n@end"),K.import("@export clay.compositor.bright\nuniform sampler2D texture;\nuniform float threshold : 1;\nuniform float scale : 1.0;\nuniform vec2 textureSize: [512, 512];\nvarying vec2 v_Texcoord;\nconst vec3 lumWeight = vec3(0.2125, 0.7154, 0.0721);\n@import clay.util.rgbm\nvec4 median(vec4 a, vec4 b, vec4 c)\n{\n return a + b + c - min(min(a, b), c) - max(max(a, b), c);\n}\nvoid main()\n{\n vec4 texel = decodeHDR(texture2D(texture, v_Texcoord));\n#ifdef ANTI_FLICKER\n vec3 d = 1.0 / textureSize.xyx * vec3(1.0, 1.0, 0.0);\n vec4 s1 = decodeHDR(texture2D(texture, v_Texcoord - d.xz));\n vec4 s2 = decodeHDR(texture2D(texture, v_Texcoord + d.xz));\n vec4 s3 = decodeHDR(texture2D(texture, v_Texcoord - d.zy));\n vec4 s4 = decodeHDR(texture2D(texture, v_Texcoord + d.zy));\n texel = median(median(texel, s1, s2), s3, s4);\n#endif\n float lum = dot(texel.rgb , lumWeight);\n vec4 color;\n if (lum > threshold && texel.a > 0.0)\n {\n color = vec4(texel.rgb * scale, texel.a * scale);\n }\n else\n {\n color = vec4(0.0);\n }\n gl_FragColor = encodeHDR(color);\n}\n@end\n"),K.import("@export clay.compositor.downsample\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nfloat brightness(vec3 c)\n{\n return max(max(c.r, c.g), c.b);\n}\n@import clay.util.clamp_sample\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n#ifdef ANTI_FLICKER\n vec3 s1 = decodeHDR(clampSample(texture, v_Texcoord + d.xy)).rgb;\n vec3 s2 = decodeHDR(clampSample(texture, v_Texcoord + d.zy)).rgb;\n vec3 s3 = decodeHDR(clampSample(texture, v_Texcoord + d.xw)).rgb;\n vec3 s4 = decodeHDR(clampSample(texture, v_Texcoord + d.zw)).rgb;\n float s1w = 1.0 / (brightness(s1) + 1.0);\n float s2w = 1.0 / (brightness(s2) + 1.0);\n float s3w = 1.0 / (brightness(s3) + 1.0);\n float s4w = 1.0 / (brightness(s4) + 1.0);\n float oneDivideSum = 1.0 / (s1w + s2w + s3w + s4w);\n vec4 color = vec4(\n (s1 * s1w + s2 * s2w + s3 * s3w + s4 * s4w) * oneDivideSum,\n 1.0\n );\n#else\n vec4 color = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\n color += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\n color *= 0.25;\n#endif\n gl_FragColor = encodeHDR(color);\n}\n@end"),K.import("\n@export clay.compositor.upsample\n#define HIGH_QUALITY\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.clamp_sample\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n vec4 s;\n s = decodeHDR(clampSample(texture, v_Texcoord - d.xy));\n s += decodeHDR(clampSample(texture, v_Texcoord - d.wy)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord - d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zw)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord )) * 4.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xw)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.wy)) * 2.0;\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n gl_FragColor = encodeHDR(s / 16.0);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n vec4 s;\n s = decodeHDR(clampSample(texture, v_Texcoord + d.xy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zy));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.xw));\n s += decodeHDR(clampSample(texture, v_Texcoord + d.zw));\n gl_FragColor = encodeHDR(s / 4.0);\n#endif\n}\n@end"),K.import("@export clay.compositor.hdr.composite\nuniform sampler2D texture;\n#ifdef BLOOM_ENABLED\nuniform sampler2D bloom;\n#endif\n#ifdef LENSFLARE_ENABLED\nuniform sampler2D lensflare;\nuniform sampler2D lensdirt;\n#endif\n#ifdef LUM_ENABLED\nuniform sampler2D lum;\n#endif\n#ifdef LUT_ENABLED\nuniform sampler2D lut;\n#endif\n#ifdef COLOR_CORRECTION\nuniform float brightness : 0.0;\nuniform float contrast : 1.0;\nuniform float saturation : 1.0;\n#endif\n#ifdef VIGNETTE\nuniform float vignetteDarkness: 1.0;\nuniform float vignetteOffset: 1.0;\n#endif\nuniform float exposure : 1.0;\nuniform float bloomIntensity : 0.25;\nuniform float lensflareIntensity : 1;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvec3 ACESToneMapping(vec3 color)\n{\n const float A = 2.51;\n const float B = 0.03;\n const float C = 2.43;\n const float D = 0.59;\n const float E = 0.14;\n return (color * (A * color + B)) / (color * (C * color + D) + E);\n}\nfloat eyeAdaption(float fLum)\n{\n return mix(0.2, fLum, 0.5);\n}\n#ifdef LUT_ENABLED\nvec3 lutTransform(vec3 color) {\n float blueColor = color.b * 63.0;\n vec2 quad1;\n quad1.y = floor(floor(blueColor) / 8.0);\n quad1.x = floor(blueColor) - (quad1.y * 8.0);\n vec2 quad2;\n quad2.y = floor(ceil(blueColor) / 8.0);\n quad2.x = ceil(blueColor) - (quad2.y * 8.0);\n vec2 texPos1;\n texPos1.x = (quad1.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\n texPos1.y = (quad1.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\n vec2 texPos2;\n texPos2.x = (quad2.x * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.r);\n texPos2.y = (quad2.y * 0.125) + 0.5/512.0 + ((0.125 - 1.0/512.0) * color.g);\n vec4 newColor1 = texture2D(lut, texPos1);\n vec4 newColor2 = texture2D(lut, texPos2);\n vec4 newColor = mix(newColor1, newColor2, fract(blueColor));\n return newColor.rgb;\n}\n#endif\n@import clay.util.rgbm\nvoid main()\n{\n vec4 texel = vec4(0.0);\n vec4 originalTexel = vec4(0.0);\n#ifdef TEXTURE_ENABLED\n texel = decodeHDR(texture2D(texture, v_Texcoord));\n originalTexel = texel;\n#endif\n#ifdef BLOOM_ENABLED\n vec4 bloomTexel = decodeHDR(texture2D(bloom, v_Texcoord));\n texel.rgb += bloomTexel.rgb * bloomIntensity;\n texel.a += bloomTexel.a * bloomIntensity;\n#endif\n#ifdef LENSFLARE_ENABLED\n texel += decodeHDR(texture2D(lensflare, v_Texcoord)) * texture2D(lensdirt, v_Texcoord) * lensflareIntensity;\n#endif\n texel.a = min(texel.a, 1.0);\n#ifdef LUM_ENABLED\n float fLum = texture2D(lum, vec2(0.5, 0.5)).r;\n float adaptedLumDest = 3.0 / (max(0.1, 1.0 + 10.0*eyeAdaption(fLum)));\n float exposureBias = adaptedLumDest * exposure;\n#else\n float exposureBias = exposure;\n#endif\n texel.rgb *= exposureBias;\n texel.rgb = ACESToneMapping(texel.rgb);\n texel = linearTosRGB(texel);\n#ifdef LUT_ENABLED\n texel.rgb = lutTransform(clamp(texel.rgb,vec3(0.0),vec3(1.0)));\n#endif\n#ifdef COLOR_CORRECTION\n texel.rgb = clamp(texel.rgb + vec3(brightness), 0.0, 1.0);\n texel.rgb = clamp((texel.rgb - vec3(0.5))*contrast+vec3(0.5), 0.0, 1.0);\n float lum = dot(texel.rgb, vec3(0.2125, 0.7154, 0.0721));\n texel.rgb = mix(vec3(lum), texel.rgb, saturation);\n#endif\n#ifdef VIGNETTE\n vec2 uv = (v_Texcoord - vec2(0.5)) * vec2(vignetteOffset);\n texel.rgb = mix(texel.rgb, vec3(1.0 - vignetteDarkness), dot(uv, uv));\n#endif\n gl_FragColor = encodeHDR(texel);\n#ifdef DEBUG\n #if DEBUG == 1\n gl_FragColor = encodeHDR(decodeHDR(texture2D(texture, v_Texcoord)));\n #elif DEBUG == 2\n gl_FragColor = encodeHDR(decodeHDR(texture2D(bloom, v_Texcoord)) * bloomIntensity);\n #elif DEBUG == 3\n gl_FragColor = encodeHDR(decodeHDR(texture2D(lensflare, v_Texcoord) * lensflareIntensity));\n #endif\n#endif\n if (originalTexel.a <= 0.01 && gl_FragColor.a > 1e-5) {\n gl_FragColor.a = dot(gl_FragColor.rgb, vec3(0.2125, 0.7154, 0.0721));\n }\n#ifdef PREMULTIPLY_ALPHA\n gl_FragColor.rgb *= gl_FragColor.a;\n#endif\n}\n@end"), +K.import("@export clay.compositor.dof.coc\nuniform sampler2D depth;\nuniform float zNear: 0.1;\nuniform float zFar: 2000;\nuniform float focalDist: 3;\nuniform float focalRange: 1;\nuniform float focalLength: 30;\nuniform float fstop: 2.8;\nvarying vec2 v_Texcoord;\n@import clay.util.encode_float\nvoid main()\n{\n float z = texture2D(depth, v_Texcoord).r * 2.0 - 1.0;\n float dist = 2.0 * zNear * zFar / (zFar + zNear - z * (zFar - zNear));\n float aperture = focalLength / fstop;\n float coc;\n float uppper = focalDist + focalRange;\n float lower = focalDist - focalRange;\n if (dist <= uppper && dist >= lower) {\n coc = 0.5;\n }\n else {\n float focalAdjusted = dist > uppper ? uppper : lower;\n coc = abs(aperture * (focalLength * (dist - focalAdjusted)) / (dist * (focalAdjusted - focalLength)));\n coc = clamp(coc, 0.0, 0.4) / 0.4000001;\n if (dist < lower) {\n coc = -coc;\n }\n coc = coc * 0.5 + 0.5;\n }\n gl_FragColor = encodeFloat(coc);\n}\n@end\n@export clay.compositor.dof.premultiply\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nvoid main() {\n float fCoc = max(abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0), 0.1);\n gl_FragColor = encodeHDR(\n vec4(decodeHDR(texture2D(texture, v_Texcoord)).rgb * fCoc, 1.0)\n );\n}\n@end\n@export clay.compositor.dof.min_coc\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.float\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\n fCoc = min(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\n gl_FragColor = encodeFloat(fCoc);\n}\n@end\n@export clay.compositor.dof.max_coc\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.float\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zy)));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.xw)));\n fCoc = max(fCoc, decodeFloat(texture2D(coc, v_Texcoord + d.zw)));\n gl_FragColor = encodeFloat(fCoc);\n}\n@end\n@export clay.compositor.dof.coc_upsample\n#define HIGH_QUALITY\nuniform sampler2D coc;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.float\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n float s;\n s = decodeFloat(texture2D(coc, v_Texcoord - d.xy));\n s += decodeFloat(texture2D(coc, v_Texcoord - d.wy)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord - d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zw)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord )) * 4.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xw)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.wy)) * 2.0;\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n gl_FragColor = encodeFloat(s / 16.0);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n float s;\n s = decodeFloat(texture2D(coc, v_Texcoord + d.xy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zy));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.xw));\n s += decodeFloat(texture2D(coc, v_Texcoord + d.zw));\n gl_FragColor = encodeFloat(s / 4.0);\n#endif\n}\n@end\n@export clay.compositor.dof.upsample\n#define HIGH_QUALITY\nuniform sampler2D coc;\nuniform sampler2D texture;\nuniform vec2 textureSize : [512, 512];\nuniform float sampleScale: 0.5;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nfloat tap(vec2 uv, inout vec4 color, float baseWeight) {\n float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * baseWeight;\n color += decodeHDR(texture2D(texture, uv)) * weight;\n return weight;\n}\nvoid main()\n{\n#ifdef HIGH_QUALITY\n vec4 d = vec4(1.0, 1.0, -1.0, 0.0) / textureSize.xyxy * sampleScale;\n vec4 color = vec4(0.0);\n float baseWeight = 1.0 / 16.0;\n float w = tap(v_Texcoord - d.xy, color, baseWeight);\n w += tap(v_Texcoord - d.wy, color, baseWeight * 2.0);\n w += tap(v_Texcoord - d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.zw, color, baseWeight * 2.0);\n w += tap(v_Texcoord , color, baseWeight * 4.0);\n w += tap(v_Texcoord + d.xw, color, baseWeight * 2.0);\n w += tap(v_Texcoord + d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.wy, color, baseWeight * 2.0);\n w += tap(v_Texcoord + d.xy, color, baseWeight);\n gl_FragColor = encodeHDR(color / w);\n#else\n vec4 d = vec4(-1.0, -1.0, +1.0, +1.0) / textureSize.xyxy;\n vec4 color = vec4(0.0);\n float baseWeight = 1.0 / 4.0;\n float w = tap(v_Texcoord + d.xy, color, baseWeight);\n w += tap(v_Texcoord + d.zy, color, baseWeight);\n w += tap(v_Texcoord + d.xw, color, baseWeight);\n w += tap(v_Texcoord + d.zw, color, baseWeight);\n gl_FragColor = encodeHDR(color / w);\n#endif\n}\n@end\n@export clay.compositor.dof.downsample\nuniform sampler2D texture;\nuniform sampler2D coc;\nuniform vec2 textureSize : [512, 512];\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.decode_float\nfloat tap(vec2 uv, inout vec4 color) {\n float weight = abs(decodeFloat(texture2D(coc, uv)) * 2.0 - 1.0) * 0.25;\n color += decodeHDR(texture2D(texture, uv)) * weight;\n return weight;\n}\nvoid main()\n{\n vec4 d = vec4(-1.0, -1.0, 1.0, 1.0) / textureSize.xyxy;\n vec4 color = vec4(0.0);\n float weight = tap(v_Texcoord + d.xy, color);\n weight += tap(v_Texcoord + d.zy, color);\n weight += tap(v_Texcoord + d.xw, color);\n weight += tap(v_Texcoord + d.zw, color);\n color /= weight;\n gl_FragColor = encodeHDR(color);\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_frag\n@import clay.util.float\nvec4 doBlur(sampler2D targetTexture, vec2 offset) {\n#ifdef BLUR_COC\n float cocSum = 0.0;\n#else\n vec4 color = vec4(0.0);\n#endif\n float weightSum = 0.0;\n float kernelWeight = 1.0 / float(KERNEL_SIZE);\n for (int i = 0; i < KERNEL_SIZE; i++) {\n vec2 coord = v_Texcoord + offset * float(i);\n float w = kernelWeight;\n#ifdef BLUR_COC\n float fCoc = decodeFloat(texture2D(targetTexture, coord)) * 2.0 - 1.0;\n cocSum += clamp(fCoc, -1.0, 0.0) * w;\n#else\n float fCoc = decodeFloat(texture2D(coc, coord)) * 2.0 - 1.0;\n vec4 texel = texture2D(targetTexture, coord);\n #if !defined(BLUR_NEARFIELD)\n w *= abs(fCoc);\n #endif\n color += decodeHDR(texel) * w;\n#endif\n weightSum += w;\n }\n#ifdef BLUR_COC\n return encodeFloat(clamp(cocSum / weightSum, -1.0, 0.0) * 0.5 + 0.5);\n#else\n return color / weightSum;\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_1\n#define KERNEL_SIZE 5\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n gl_FragColor = doBlur(texture, vec2(0.0, offset.y));\n#if !defined(BLUR_COC)\n gl_FragColor = encodeHDR(gl_FragColor);\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_2\n#define KERNEL_SIZE 5\nuniform sampler2D texture;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n offset.y /= 2.0;\n gl_FragColor = doBlur(texture, -offset);\n#if !defined(BLUR_COC)\n gl_FragColor = encodeHDR(gl_FragColor);\n#endif\n}\n@end\n@export clay.compositor.dof.hexagonal_blur_3\n#define KERNEL_SIZE 5\nuniform sampler2D texture1;\nuniform sampler2D texture2;\nuniform sampler2D coc;\nvarying vec2 v_Texcoord;\nuniform float blurSize : 1.0;\nuniform vec2 textureSize : [512.0, 512.0];\n@import clay.util.rgbm\n@import clay.compositor.dof.hexagonal_blur_frag\nvoid main()\n{\n vec2 offset = blurSize / textureSize;\n#if !defined(BLUR_NEARFIELD) && !defined(BLUR_COC)\n offset *= abs(decodeFloat(texture2D(coc, v_Texcoord)) * 2.0 - 1.0);\n#endif\n offset.y /= 2.0;\n vec2 vDownRight = vec2(offset.x, -offset.y);\n vec4 texel1 = doBlur(texture1, -offset);\n vec4 texel2 = doBlur(texture1, vDownRight);\n vec4 texel3 = doBlur(texture2, vDownRight);\n#ifdef BLUR_COC\n float coc1 = decodeFloat(texel1) * 2.0 - 1.0;\n float coc2 = decodeFloat(texel2) * 2.0 - 1.0;\n float coc3 = decodeFloat(texel3) * 2.0 - 1.0;\n gl_FragColor = encodeFloat(\n ((coc1 + coc2 + coc3) / 3.0) * 0.5 + 0.5\n );\n#else\n vec4 color = (texel1 + texel2 + texel3) / 3.0;\n gl_FragColor = encodeHDR(color);\n#endif\n}\n@end\n@export clay.compositor.dof.composite\n#define DEBUG 0\nuniform sampler2D original;\nuniform sampler2D blurred;\nuniform sampler2D nearfield;\nuniform sampler2D coc;\nuniform sampler2D nearcoc;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\n@import clay.util.float\nvoid main()\n{\n vec4 blurredColor = decodeHDR(texture2D(blurred, v_Texcoord));\n vec4 originalColor = decodeHDR(texture2D(original, v_Texcoord));\n float fCoc = decodeFloat(texture2D(coc, v_Texcoord));\n fCoc = abs(fCoc * 2.0 - 1.0);\n float weight = smoothstep(0.0, 1.0, fCoc);\n#ifdef NEARFIELD_ENABLED\n vec4 nearfieldColor = decodeHDR(texture2D(nearfield, v_Texcoord));\n float fNearCoc = decodeFloat(texture2D(nearcoc, v_Texcoord));\n fNearCoc = abs(fNearCoc * 2.0 - 1.0);\n gl_FragColor = encodeHDR(\n mix(\n nearfieldColor, mix(originalColor, blurredColor, weight),\n pow(1.0 - fNearCoc, 4.0)\n )\n );\n#else\n gl_FragColor = encodeHDR(mix(originalColor, blurredColor, weight));\n#endif\n#if DEBUG == 1\n gl_FragColor = vec4(vec3(fCoc), 1.0);\n#elif DEBUG == 2\n gl_FragColor = vec4(vec3(fNearCoc), 1.0);\n#elif DEBUG == 3\n gl_FragColor = encodeHDR(blurredColor);\n#elif DEBUG == 4\n gl_FragColor = encodeHDR(nearfieldColor);\n#endif\n}\n@end"),K.import("@export clay.compositor.lensflare\n#define SAMPLE_NUMBER 8\nuniform sampler2D texture;\nuniform sampler2D lenscolor;\nuniform vec2 textureSize : [512, 512];\nuniform float dispersal : 0.3;\nuniform float haloWidth : 0.4;\nuniform float distortion : 1.0;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nvec4 textureDistorted(\n in vec2 texcoord,\n in vec2 direction,\n in vec3 distortion\n) {\n return vec4(\n decodeHDR(texture2D(texture, texcoord + direction * distortion.r)).r,\n decodeHDR(texture2D(texture, texcoord + direction * distortion.g)).g,\n decodeHDR(texture2D(texture, texcoord + direction * distortion.b)).b,\n 1.0\n );\n}\nvoid main()\n{\n vec2 texcoord = -v_Texcoord + vec2(1.0); vec2 textureOffset = 1.0 / textureSize;\n vec2 ghostVec = (vec2(0.5) - texcoord) * dispersal;\n vec2 haloVec = normalize(ghostVec) * haloWidth;\n vec3 distortion = vec3(-textureOffset.x * distortion, 0.0, textureOffset.x * distortion);\n vec4 result = vec4(0.0);\n for (int i = 0; i < SAMPLE_NUMBER; i++)\n {\n vec2 offset = fract(texcoord + ghostVec * float(i));\n float weight = length(vec2(0.5) - offset) / length(vec2(0.5));\n weight = pow(1.0 - weight, 10.0);\n result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\n }\n result *= texture2D(lenscolor, vec2(length(vec2(0.5) - texcoord)) / length(vec2(0.5)));\n float weight = length(vec2(0.5) - fract(texcoord + haloVec)) / length(vec2(0.5));\n weight = pow(1.0 - weight, 10.0);\n vec2 offset = fract(texcoord + haloVec);\n result += textureDistorted(offset, normalize(ghostVec), distortion) * weight;\n gl_FragColor = result;\n}\n@end"),K.import("@export clay.compositor.blend\n#define SHADER_NAME blend\n#ifdef TEXTURE1_ENABLED\nuniform sampler2D texture1;\nuniform float weight1 : 1.0;\n#endif\n#ifdef TEXTURE2_ENABLED\nuniform sampler2D texture2;\nuniform float weight2 : 1.0;\n#endif\n#ifdef TEXTURE3_ENABLED\nuniform sampler2D texture3;\nuniform float weight3 : 1.0;\n#endif\n#ifdef TEXTURE4_ENABLED\nuniform sampler2D texture4;\nuniform float weight4 : 1.0;\n#endif\n#ifdef TEXTURE5_ENABLED\nuniform sampler2D texture5;\nuniform float weight5 : 1.0;\n#endif\n#ifdef TEXTURE6_ENABLED\nuniform sampler2D texture6;\nuniform float weight6 : 1.0;\n#endif\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nvoid main()\n{\n vec4 tex = vec4(0.0);\n#ifdef TEXTURE1_ENABLED\n tex += decodeHDR(texture2D(texture1, v_Texcoord)) * weight1;\n#endif\n#ifdef TEXTURE2_ENABLED\n tex += decodeHDR(texture2D(texture2, v_Texcoord)) * weight2;\n#endif\n#ifdef TEXTURE3_ENABLED\n tex += decodeHDR(texture2D(texture3, v_Texcoord)) * weight3;\n#endif\n#ifdef TEXTURE4_ENABLED\n tex += decodeHDR(texture2D(texture4, v_Texcoord)) * weight4;\n#endif\n#ifdef TEXTURE5_ENABLED\n tex += decodeHDR(texture2D(texture5, v_Texcoord)) * weight5;\n#endif\n#ifdef TEXTURE6_ENABLED\n tex += decodeHDR(texture2D(texture6, v_Texcoord)) * weight6;\n#endif\n gl_FragColor = encodeHDR(tex);\n}\n@end"),K.import("@export clay.compositor.fxaa\nuniform sampler2D texture;\nuniform vec4 viewport : VIEWPORT;\nvarying vec2 v_Texcoord;\n#define FXAA_REDUCE_MIN (1.0/128.0)\n#define FXAA_REDUCE_MUL (1.0/8.0)\n#define FXAA_SPAN_MAX 8.0\n@import clay.util.rgbm\nvoid main()\n{\n vec2 resolution = 1.0 / viewport.zw;\n vec3 rgbNW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, -1.0 ) ) * resolution ) ).xyz;\n vec3 rgbNE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, -1.0 ) ) * resolution ) ).xyz;\n vec3 rgbSW = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( -1.0, 1.0 ) ) * resolution ) ).xyz;\n vec3 rgbSE = decodeHDR( texture2D( texture, ( gl_FragCoord.xy + vec2( 1.0, 1.0 ) ) * resolution ) ).xyz;\n vec4 rgbaM = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution ) );\n vec3 rgbM = rgbaM.xyz;\n float opacity = rgbaM.w;\n vec3 luma = vec3( 0.299, 0.587, 0.114 );\n float lumaNW = dot( rgbNW, luma );\n float lumaNE = dot( rgbNE, luma );\n float lumaSW = dot( rgbSW, luma );\n float lumaSE = dot( rgbSE, luma );\n float lumaM = dot( rgbM, luma );\n float lumaMin = min( lumaM, min( min( lumaNW, lumaNE ), min( lumaSW, lumaSE ) ) );\n float lumaMax = max( lumaM, max( max( lumaNW, lumaNE) , max( lumaSW, lumaSE ) ) );\n vec2 dir;\n dir.x = -((lumaNW + lumaNE) - (lumaSW + lumaSE));\n dir.y = ((lumaNW + lumaSW) - (lumaNE + lumaSE));\n float dirReduce = max( ( lumaNW + lumaNE + lumaSW + lumaSE ) * ( 0.25 * FXAA_REDUCE_MUL ), FXAA_REDUCE_MIN );\n float rcpDirMin = 1.0 / ( min( abs( dir.x ), abs( dir.y ) ) + dirReduce );\n dir = min( vec2( FXAA_SPAN_MAX, FXAA_SPAN_MAX),\n max( vec2(-FXAA_SPAN_MAX, -FXAA_SPAN_MAX),\n dir * rcpDirMin)) * resolution;\n vec3 rgbA = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * ( 1.0 / 3.0 - 0.5 ) ) ).xyz;\n rgbA += decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * ( 2.0 / 3.0 - 0.5 ) ) ).xyz;\n rgbA *= 0.5;\n vec3 rgbB = decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * -0.5 ) ).xyz;\n rgbB += decodeHDR( texture2D( texture, gl_FragCoord.xy * resolution + dir * 0.5 ) ).xyz;\n rgbB *= 0.25;\n rgbB += rgbA * 0.5;\n float lumaB = dot( rgbB, luma );\n if ( ( lumaB < lumaMin ) || ( lumaB > lumaMax ) )\n {\n gl_FragColor = vec4( rgbA, opacity );\n }\n else {\n gl_FragColor = vec4( rgbB, opacity );\n }\n}\n@end"),K.import("@export clay.compositor.fxaa3\nuniform sampler2D texture;\nuniform vec4 viewport : VIEWPORT;\nuniform float subpixel: 0.75;\nuniform float edgeThreshold: 0.125;\nuniform float edgeThresholdMin: 0.0625;\nvarying vec2 v_Texcoord;\n@import clay.util.rgbm\nfloat FxaaLuma(vec4 rgba) { return rgba.y; }\nvec4 FxaaPixelShader(\n vec2 pos\n ,sampler2D tex\n ,vec2 fxaaQualityRcpFrame\n ,float fxaaQualitySubpix\n ,float fxaaQualityEdgeThreshold\n ,float fxaaQualityEdgeThresholdMin\n) {\n vec2 posM;\n posM.x = pos.x;\n posM.y = pos.y;\n vec4 rgbyM = decodeHDR(texture2D(texture, posM, 0.0));\n float lumaS = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaN = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 0.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 0.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float maxSM = max(lumaS, rgbyM.y);\n float minSM = min(lumaS, rgbyM.y);\n float maxESM = max(lumaE, maxSM);\n float minESM = min(lumaE, minSM);\n float maxWN = max(lumaN, lumaW);\n float minWN = min(lumaN, lumaW);\n float rangeMax = max(maxWN, maxESM);\n float rangeMin = min(minWN, minESM);\n float rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;\n float range = rangeMax - rangeMin;\n float rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);\n bool earlyExit = range < rangeMaxClamped;\n if(earlyExit) return rgbyM;\n float lumaNW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaSE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaNE = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2( 1.0,-1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaSW = FxaaLuma(decodeHDR(texture2D(texture, posM + (vec2(-1.0, 1.0) * fxaaQualityRcpFrame.xy), 0.0)));\n float lumaNS = lumaN + lumaS;\n float lumaWE = lumaW + lumaE;\n float subpixRcpRange = 1.0/range;\n float subpixNSWE = lumaNS + lumaWE;\n float edgeHorz1 = (-2.0 * rgbyM.y) + lumaNS;\n float edgeVert1 = (-2.0 * rgbyM.y) + lumaWE;\n float lumaNESE = lumaNE + lumaSE;\n float lumaNWNE = lumaNW + lumaNE;\n float edgeHorz2 = (-2.0 * lumaE) + lumaNESE;\n float edgeVert2 = (-2.0 * lumaN) + lumaNWNE;\n float lumaNWSW = lumaNW + lumaSW;\n float lumaSWSE = lumaSW + lumaSE;\n float edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);\n float edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);\n float edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;\n float edgeVert3 = (-2.0 * lumaS) + lumaSWSE;\n float edgeHorz = abs(edgeHorz3) + edgeHorz4;\n float edgeVert = abs(edgeVert3) + edgeVert4;\n float subpixNWSWNESE = lumaNWSW + lumaNESE;\n float lengthSign = fxaaQualityRcpFrame.x;\n bool horzSpan = edgeHorz >= edgeVert;\n float subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;\n if(!horzSpan) lumaN = lumaW;\n if(!horzSpan) lumaS = lumaE;\n if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;\n float subpixB = (subpixA * (1.0/12.0)) - rgbyM.y;\n float gradientN = lumaN - rgbyM.y;\n float gradientS = lumaS - rgbyM.y;\n float lumaNN = lumaN + rgbyM.y;\n float lumaSS = lumaS + rgbyM.y;\n bool pairN = abs(gradientN) >= abs(gradientS);\n float gradient = max(abs(gradientN), abs(gradientS));\n if(pairN) lengthSign = -lengthSign;\n float subpixC = clamp(abs(subpixB) * subpixRcpRange, 0.0, 1.0);\n vec2 posB;\n posB.x = posM.x;\n posB.y = posM.y;\n vec2 offNP;\n offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;\n offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;\n if(!horzSpan) posB.x += lengthSign * 0.5;\n if( horzSpan) posB.y += lengthSign * 0.5;\n vec2 posN;\n posN.x = posB.x - offNP.x * 1.0;\n posN.y = posB.y - offNP.y * 1.0;\n vec2 posP;\n posP.x = posB.x + offNP.x * 1.0;\n posP.y = posB.y + offNP.y * 1.0;\n float subpixD = ((-2.0)*subpixC) + 3.0;\n float lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN, 0.0)));\n float subpixE = subpixC * subpixC;\n float lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP, 0.0)));\n if(!pairN) lumaNN = lumaSS;\n float gradientScaled = gradient * 1.0/4.0;\n float lumaMM = rgbyM.y - lumaNN * 0.5;\n float subpixF = subpixD * subpixE;\n bool lumaMLTZero = lumaMM < 0.0;\n lumaEndN -= lumaNN * 0.5;\n lumaEndP -= lumaNN * 0.5;\n bool doneN = abs(lumaEndN) >= gradientScaled;\n bool doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 1.5;\n if(!doneN) posN.y -= offNP.y * 1.5;\n bool doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 1.5;\n if(!doneP) posP.y += offNP.y * 1.5;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 2.0;\n if(!doneN) posN.y -= offNP.y * 2.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 2.0;\n if(!doneP) posP.y += offNP.y * 2.0;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 4.0;\n if(!doneN) posN.y -= offNP.y * 4.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 4.0;\n if(!doneP) posP.y += offNP.y * 4.0;\n if(doneNP) {\n if(!doneN) lumaEndN = FxaaLuma(decodeHDR(texture2D(texture, posN.xy, 0.0)));\n if(!doneP) lumaEndP = FxaaLuma(decodeHDR(texture2D(texture, posP.xy, 0.0)));\n if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;\n if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;\n doneN = abs(lumaEndN) >= gradientScaled;\n doneP = abs(lumaEndP) >= gradientScaled;\n if(!doneN) posN.x -= offNP.x * 12.0;\n if(!doneN) posN.y -= offNP.y * 12.0;\n doneNP = (!doneN) || (!doneP);\n if(!doneP) posP.x += offNP.x * 12.0;\n if(!doneP) posP.y += offNP.y * 12.0;\n }\n }\n }\n float dstN = posM.x - posN.x;\n float dstP = posP.x - posM.x;\n if(!horzSpan) dstN = posM.y - posN.y;\n if(!horzSpan) dstP = posP.y - posM.y;\n bool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;\n float spanLength = (dstP + dstN);\n bool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;\n float spanLengthRcp = 1.0/spanLength;\n bool directionN = dstN < dstP;\n float dst = min(dstN, dstP);\n bool goodSpan = directionN ? goodSpanN : goodSpanP;\n float subpixG = subpixF * subpixF;\n float pixelOffset = (dst * (-spanLengthRcp)) + 0.5;\n float subpixH = subpixG * fxaaQualitySubpix;\n float pixelOffsetGood = goodSpan ? pixelOffset : 0.0;\n float pixelOffsetSubpix = max(pixelOffsetGood, subpixH);\n if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;\n if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;\n return vec4(decodeHDR(texture2D(texture, posM, 0.0)).xyz, rgbyM.y);\n}\nvoid main()\n{\n vec4 color = FxaaPixelShader(\n v_Texcoord,\n texture,\n vec2(1.0) / viewport.zw,\n subpixel,\n edgeThreshold,\n edgeThresholdMin\n );\n gl_FragColor = vec4(color.rgb, 1.0);\n}\n@end");var hi={NORMAL:"normal",POSITION:"position",TEXCOORD_0:"texcoord0",TEXCOORD_1:"texcoord1",WEIGHTS_0:"weight",JOINTS_0:"joint",COLOR:"color"},fi={5120:We.Int8Array,5121:We.Uint8Array,5122:We.Int16Array,5123:We.Uint16Array,5125:We.Uint32Array,5126:We.Float32Array},di={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},mi=Pe.extend({rootNode:null,rootPath:null,textureRootPath:null,bufferRootPath:null,shader:"clay.standard",useStandardMaterial:!1,includeCamera:!0,includeAnimation:!0,includeMesh:!0,includeTexture:!0,crossOrigin:"",textureFlipY:!1,shaderLibrary:null},function(){this.shaderLibrary||(this.shaderLibrary=kn.createLibrary())},{load:function(t){var e=this,r=t.endsWith(".glb");null==this.rootPath&&(this.rootPath=t.slice(0,t.lastIndexOf("/"))),Yn.get({url:t,onprogress:function(t,r,n){e.trigger("progress",t,r,n)},onerror:function(t){e.trigger("error",t)},responseType:r?"arraybuffer":"text",onload:function(t){r?e.parseBinary(t):e.parse(JSON.parse(t))}})},parseBinary:function(t){var e=new Uint32Array(t,0,4);if(1179937895!==e[0])return void this.trigger("error","Invalid glTF binary format: Invalid header");if(e[0]<2)return void this.trigger("error","Only glTF2.0 is supported.");for(var r,n=new DataView(t,12),i=[],a=0;a=r.COLOR_ATTACHMENT0&&a<=r.COLOR_ATTACHMENT0+8&&i.push(a);n.drawBuffersEXT(i)}}this.trigger("beforerender",this,t);var o=this.clearDepth?r.DEPTH_BUFFER_BIT:0;if(r.depthMask(!0),this.clearColor){o|=r.COLOR_BUFFER_BIT,r.colorMask(!0,!0,!0,!0);var s=this.clearColor;Array.isArray(s)&&r.clearColor(s[0],s[1],s[2],s[3])}r.clear(o),this.blendWithPrevious?(r.enable(r.BLEND),this.material.transparent=!0):(r.disable(r.BLEND),this.material.transparent=!1),this.renderQuad(t),this.trigger("afterrender",this,t),e&&this.unbind(t,e)},renderQuad:function(t){Si.material=this.material,t.renderPass([Si],wi)},dispose:function(t){}});K.import(ci);var Ci=Xn.extend(function(){var t=new K({vertex:K.source("clay.skybox.vertex"),fragment:K.source("clay.skybox.fragment")}),e=new vr({shader:t,depthMask:!1});return{scene:null,geometry:new Mn,material:e,environmentMap:null,culling:!1}},function(){var t=this.scene;t&&this.attachScene(t),this.environmentMap&&this.setEnvironmentMap(this.environmentMap)},{attachScene:function(t){this.scene&&this.detachScene(),t.skybox=this,this.scene=t,t.on("beforerender",this._beforeRenderScene,this)},detachScene:function(){this.scene&&(this.scene.off("beforerender",this._beforeRenderScene),this.scene.skybox=null),this.scene=null},dispose:function(t){this.detachScene(),this.geometry.dispose(t)},setEnvironmentMap:function(t){this.material.set("environmentMap",t)},getEnvironmentMap:function(){return this.material.get("environmentMap")},_beforeRenderScene:function(t,e,r){this.renderSkybox(t,r)},renderSkybox:function(t,e){this.position.copy(e.getWorldPosition()),this.update(),t.gl.disable(t.gl.BLEND),this.material.get("lod")>0?this.material.define("fragment","LOD"):this.material.undefine("fragment","LOD"),t.renderPass([this],e)}}),Ni=["px","nx","py","ny","pz","nz"],Ri=Pe.extend(function(){var t={position:new Xe,far:1e3,near:.1,texture:null,shadowMapPass:null},e=t._cameras={px:new jn({fov:90}),nx:new jn({fov:90}),py:new jn({fov:90}),ny:new jn({fov:90}),pz:new jn({fov:90}),nz:new jn({fov:90})};return e.px.lookAt(Xe.POSITIVE_X,Xe.NEGATIVE_Y),e.nx.lookAt(Xe.NEGATIVE_X,Xe.NEGATIVE_Y),e.py.lookAt(Xe.POSITIVE_Y,Xe.POSITIVE_Z),e.ny.lookAt(Xe.NEGATIVE_Y,Xe.NEGATIVE_Z),e.pz.lookAt(Xe.POSITIVE_Z,Xe.NEGATIVE_Y),e.nz.lookAt(Xe.NEGATIVE_Z,Xe.NEGATIVE_Y),t._frameBuffer=new bi,t},{getCamera:function(t){return this._cameras[t]},render:function(t,e,r){var n=t.gl;r||e.update();for(var i=this.texture.width,a=2*Math.atan(i/(i-.5))/Math.PI*180,o=0;o<6;o++){var s=Ni[o],u=this._cameras[s];if(Xe.copy(u.position,this.position),u.far=this.far,u.near=this.near,u.fov=a,this.shadowMapPass){u.update();var l=e.getBoundingBox();l.applyTransform(u.viewMatrix),e.viewBoundingBoxLastFrame.copy(l),this.shadowMapPass.render(t,e,u,!0)}this._frameBuffer.attach(this.texture,n.COLOR_ATTACHMENT0,n.TEXTURE_CUBE_MAP_POSITIVE_X+o),this._frameBuffer.bind(t),t.render(e,u,!0),this._frameBuffer.unbind(t)}},dispose:function(t){this._frameBuffer.dispose(t)}});K.import(li);var Li=Xn.extend(function(){var t=new K(K.source("clay.basic.vertex"),K.source("clay.basic.fragment")),e=new vr({shader:t,depthMask:!1});return e.enableTexture("diffuseMap"),{scene:null,geometry:new Cn({widthSegments:30,heightSegments:30}),material:e,environmentMap:null,culling:!1}},function(){var t=this.scene;t&&this.attachScene(t),this.environmentMap&&this.setEnvironmentMap(this.environmentMap)},{attachScene:function(t){this.scene&&this.detachScene(),t.skydome=this,this.scene=t,t.on("beforerender",this._beforeRenderScene,this)},detachScene:function(){this.scene&&(this.scene.off("beforerender",this._beforeRenderScene),this.scene.skydome=null),this.scene=null},_beforeRenderScene:function(t,e,r){this.position.copy(r.getWorldPosition()),this.update(),t.renderPass([this],r)},setEnvironmentMap:function(t){this.material.set("diffuseMap",t)},getEnvironmentMap:function(){return this.material.get("diffuseMap")},dispose:function(t){this.detachScene(),this.geometry.dispose(t)}}),Pi=ft("DXT1"),Di=ft("DXT3"),Ii=ft("DXT5"),Oi={parse:function(t,e){var r=new Int32Array(t,0,31);if(542327876!==r[0])return null;if(4&!r(20))return null;var n,i,a=r(21),o=r[4],s=r[3],u=512&r[28],l=131072&r[2];switch(a){case Pi:n=8,i=lr.COMPRESSED_RGB_S3TC_DXT1_EXT;break;case Di:n=16,i=lr.COMPRESSED_RGBA_S3TC_DXT3_EXT;break;case Ii:n=16,i=lr.COMPRESSED_RGBA_S3TC_DXT5_EXT;break;default:return null}var c=r[1]+4,h=u?6:1,f=1;l&&(f=Math.max(1,r[7]));for(var d=[],m=0;m=i)){a+=2;for(var o="";a20)return console.warn("Given image is not a height map"),t}var f,d,m,p;u%(4*n)==0?(f=o.data[u],m=o.data[u+4]):u%(4*n)==4*(n-1)?(f=o.data[u-4],m=o.data[u]):(f=o.data[u-4],m=o.data[u+4]),u<4*n?(d=o.data[u],p=o.data[u+4*n]):u>n*(i-1)*4?(d=o.data[u-4*n],p=o.data[u]):(d=o.data[u-4*n],p=o.data[u+4*n]),s.data[u]=f-m+127,s.data[u+1]=d-p+127,s.data[u+2]=255,s.data[u+3]=255}return a.putImageData(s,0,0),r},isHeightImage:function(t,e,r){if(!t||!t.width||!t.height)return!1;var n=document.createElement("canvas"),i=n.getContext("2d"),a=e||32;r=r||20,n.width=n.height=a,i.drawImage(t,0,0,a,a);for(var o=i.getImageData(0,0,a,a),s=0;sr)return!1}return!0},_fetchTexture:function(t,e,r){Yn.get({url:t,responseType:"arraybuffer",onload:e,onerror:r})},createChessboard:function(t,e,r,n){t=t||512,e=e||64,r=r||"black",n=n||"white";var i=Math.ceil(t/e),a=document.createElement("canvas");a.width=t,a.height=t;var o=a.getContext("2d");o.fillStyle=n,o.fillRect(0,0,t,t),o.fillStyle=r;for(var s=0;s 0.0) {\n prefilteredColor += decodeHDR(textureCube(environmentMap, L)).rgb * NoL;\n totalWeight += NoL;\n }\n }\n gl_FragColor = encodeHDR(vec4(prefilteredColor / totalWeight, 1.0));\n}\n"})});h.set("normalDistribution",n),r.encodeRGBM&&h.define("fragment","RGBM_ENCODE"),r.decodeRGBM&&h.define("fragment","RGBM_DECODE");var f,d=new vn;if(e instanceof Pn){var m=new On({width:a,height:o,type:s===lr.FLOAT?lr.HALF_FLOAT:s});Hi.panoramaToCubeMap(t,e,m,{encodeRGBM:r.decodeRGBM}),e=m}f=new Ci({scene:d,material:h}),f.material.set("environmentMap",e);var p=new Ri({texture:u});r.encodeRGBM&&(s=u.type=lr.UNSIGNED_BYTE);for(var _=new Pn({width:a,height:o,type:s}),g=new bi({depthBuffer:!1}),v=We[s===lr.UNSIGNED_BYTE?"Uint8Array":"Float32Array"],y=0;y 0.0) {\n float G = G_Smith(roughness, NoV, NoL);\n float G_Vis = G * VoH / (NoH * NoV);\n float Fc = pow(1.0 - VoH, 5.0);\n A += (1.0 - Fc) * G_Vis;\n B += Fc * G_Vis;\n }\n }\n gl_FragColor = vec4(vec2(A, B) / fSampleNumber, 0.0, 1.0);\n}\n"}),i=new Pn({width:512,height:256,type:lr.HALF_FLOAT,minFilter:lr.NEAREST,magFilter:lr.NEAREST,useMipmap:!1});return n.setUniform("normalDistribution",e),n.setUniform("viewportSize",[512,256]),n.attachOutput(i),n.render(t,r),r.dispose(t),i},Gi.generateNormalDistribution=function(t,e){for(var t=t||256,e=e||1024,r=new Pn({width:t,height:e,type:lr.FLOAT,minFilter:lr.NEAREST,magFilter:lr.NEAREST,useMipmap:!1}),n=new Float32Array(e*t*4),i=0;i>>16)>>>0;o=((1431655765&o)<<1|(2863311530&o)>>>1)>>>0,o=((858993459&o)<<2|(3435973836&o)>>>2)>>>0,o=((252645135&o)<<4|(4042322160&o)>>>4)>>>0,o=(((16711935&o)<<8|(4278255360&o)>>>8)>>>0)/4294967296;for(var s=0;s= shadowCascadeClipsNear[_idx_] &&\n depth <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n directionalLightShadowMaps[0], directionalLightMatrices[_idx_], position,\n directionalLightShadowMapSizes[0],\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n shadowContribs[0] = shadowContrib;\n }\n }}\n for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#else\nvoid computeShadowOfDirectionalLights(vec3 position, inout float shadowContribs[DIRECTIONAL_LIGHT_COUNT]){\n float shadowContrib;\n for(int _idx_ = 0; _idx_ < DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\n shadowContrib = computeShadowContrib(\n directionalLightShadowMaps[_idx_], directionalLightMatrices[_idx_], position,\n directionalLightShadowMapSizes[_idx_]\n );\n shadowContribs[_idx_] = shadowContrib;\n }}\n for(int _idx_ = DIRECTIONAL_LIGHT_SHADOWMAP_COUNT; _idx_ < DIRECTIONAL_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#endif\n#endif\n#if defined(POINT_LIGHT_SHADOWMAP_COUNT)\nvoid computeShadowOfPointLights(vec3 position, inout float shadowContribs[POINT_LIGHT_COUNT] ){\n vec3 lightPosition;\n vec3 direction;\n for(int _idx_ = 0; _idx_ < POINT_LIGHT_SHADOWMAP_COUNT; _idx_++) {{\n lightPosition = pointLightPosition[_idx_];\n direction = position - lightPosition;\n shadowContribs[_idx_] = computeShadowContribOmni(pointLightShadowMaps[_idx_], direction, pointLightRange[_idx_]);\n }}\n for(int _idx_ = POINT_LIGHT_SHADOWMAP_COUNT; _idx_ < POINT_LIGHT_COUNT; _idx_++) {{\n shadowContribs[_idx_] = 1.0;\n }}\n}\n#endif\n#endif\n@end");var Zi=Pe.extend(function(){return{softShadow:Zi.PCF,shadowBlur:1,lightFrustumBias:"auto",kernelPCF:new Float32Array([1,0,1,1,-1,1,0,1,-1,0,-1,-1,1,-1,0,-1]),precision:"mediump",_lastRenderNotCastShadow:!1,_frameBuffer:new bi,_textures:{},_shadowMapNumber:{POINT_LIGHT:0,DIRECTIONAL_LIGHT:0,SPOT_LIGHT:0},_depthMaterials:{},_distanceMaterials:{},_opaqueCasters:[],_receivers:[],_lightsCastShadow:[],_lightCameras:{},_lightMaterials:{},_texturePool:new Xi}},function(){this._gaussianPassH=new Mi({fragment:K.source("clay.compositor.gaussian_blur")}),this._gaussianPassV=new Mi({fragment:K.source("clay.compositor.gaussian_blur")}),this._gaussianPassH.setUniform("blurSize",this.shadowBlur),this._gaussianPassH.setUniform("blurDir",0),this._gaussianPassV.setUniform("blurSize",this.shadowBlur),this._gaussianPassV.setUniform("blurDir",1),this._outputDepthPass=new Mi({fragment:K.source("clay.sm.debug_depth")})},{render:function(t,e,r,n){r||(r=e.getMainCamera()),this.trigger("beforerender",this,t,e,r),this._renderShadowPass(t,e,r,n),this.trigger("afterrender",this,t,e,r)},renderDebug:function(t,e){t.saveClear();var r=t.viewport,n=0,i=e||r.width/4,a=i;this.softShadow===Zi.VSM?this._outputDepthPass.material.define("fragment","USE_VSM"):this._outputDepthPass.material.undefine("fragment","USE_VSM");for(var o in this._textures){var s=this._textures[o];t.setViewport(n,0,i*s.width/s.height,a),this._outputDepthPass.setUniform("depthMap",s),this._outputDepthPass.render(t),n+=i*s.width/s.height}t.setViewport(r),t.restoreClear()},_updateCasterAndReceiver:function(t,e){if(e.castShadow&&this._opaqueCasters.push(e),e.receiveShadow?(this._receivers.push(e),e.material.set("shadowEnabled",1),e.material.set("pcfKernel",this.kernelPCF)):e.material.set("shadowEnabled",0),!e.material.shader&&e.material.updateShader&&e.material.updateShader(t),this.softShadow===Zi.VSM)e.material.define("fragment","USE_VSM"),e.material.undefine("fragment","PCF_KERNEL_SIZE");else{e.material.undefine("fragment","USE_VSM");var r=this.kernelPCF;r&&r.length?e.material.define("fragment","PCF_KERNEL_SIZE",r.length/2):e.material.undefine("fragment","PCF_KERNEL_SIZE")}},_update:function(t,e){for(var r=0;r4){console.warn("Support at most 4 cascade");continue}p.shadowCascade>1&&(s=p.shadowCascade),this.renderDirectionalLightShadow(t,e,r,p,this._opaqueCasters,f,h,c)}else p instanceof gi?this.renderSpotLightShadow(t,e,p,this._opaqueCasters,l,u):p instanceof _i&&this.renderPointLightShadow(t,e,p,this._opaqueCasters,d);this._shadowMapNumber[p.type]++}for(var _ in this._shadowMapNumber)for(var g=this._shadowMapNumber[_],v=_+"_SHADOWMAP_COUNT",m=0;m0?x.define("fragment",v,g):x.isDefined("fragment",v)&&x.undefine("fragment",v))}for(var m=0;m0){var E=c.map(i);if(T.directionalLightShadowMaps={value:c,type:"tv"},T.directionalLightMatrices={value:h,type:"m4v"},T.directionalLightShadowMapSizes={value:E,type:"1fv"},s){var b=f.slice(),A=f.slice();b.pop(),A.shift(),b.reverse(),A.reverse(),h.reverse(),T.shadowCascadeClipsNear={value:b,type:"1fv"},T.shadowCascadeClipsFar={value:A,type:"1fv"}}}if(u.length>0){var S=u.map(i),T=e.shadowUniforms;T.spotLightShadowMaps={value:u,type:"tv"},T.spotLightMatrices={value:l,type:"m4v"},T.spotLightShadowMapSizes={value:S,type:"1fv"}}d.length>0&&(T.pointLightShadowMaps={value:d,type:"tv"})}},renderDirectionalLightShadow:function(){var t=new hn,e=new ar,r=new tr,n=new ar,i=new ar,a=new ar,o=new ar;return function(s,u,l,c,h,f,d,m){var p=this._getDepthMaterial(c),_={getMaterial:function(t){return t.shadowDepthMaterial||p},sortCompare:zr.opaqueSortCompare};if(!u.viewBoundingBoxLastFrame.isFinite()){var g=u.getBoundingBox();u.viewBoundingBoxLastFrame.copy(g).applyTransform(l.viewMatrix)}var v=Math.min(-u.viewBoundingBoxLastFrame.min.z,l.far),y=Math.max(-u.viewBoundingBoxLastFrame.max.z,l.near),x=this._getDirectionalLightCamera(c,u,l),T=a.array;o.copy(x.projectionMatrix),Yi.invert(i.array,x.worldTransform.array),Yi.multiply(i.array,i.array,l.worldTransform.array),Yi.multiply(T,o.array,i.array);for(var E=[],b=l instanceof jn,A=(l.near+l.far)/(l.near-l.far),S=2*l.near*l.far/(l.near-l.far),w=0;w<=c.shadowCascade;w++){var M=y*Math.pow(v/y,w/c.shadowCascade),C=y+(v-y)*w/c.shadowCascade,N=M*c.cascadeSplitLogFactor+C*(1-c.cascadeSplitLogFactor);E.push(N),f.push(-(-N*A+S)/-N)}var R=this._getTexture(c,c.shadowCascade);m.push(R);var L=s.viewport,P=s.gl;this._frameBuffer.attach(R),this._frameBuffer.bind(s),P.clear(P.COLOR_BUFFER_BIT|P.DEPTH_BUFFER_BIT);for(var w=0;w=0&&x[v]>1e-4&&(Ji.transformMat4(b,y,_[T[v]]),Ji.scaleAndAdd(E,E,b,x[v]));A.set(g,E)}}for(var g=0;g 0.0;\n#endif\n#ifdef SKINNING\n @import clay.chunk.skin_matrix\n skinnedPosition = (skinMatrixWS * vec4(position, 1.0)).xyz;\n #ifdef FIRST_PASS\n skinnedNormal = (skinMatrixWS * vec4(normal, 0.0)).xyz;\n if (hasTangent) {\n skinnedTangent = (skinMatrixWS * vec4(tangent.xyz, 0.0)).xyz;\n }\n #endif\n#endif\n gl_Position = worldViewProjection * vec4(skinnedPosition, 1.0);\n v_Texcoord = texcoord * uvRepeat + uvOffset;\n#ifdef FIRST_PASS\n v_Normal = normalize((worldInverseTranspose * vec4(skinnedNormal, 0.0)).xyz);\n if (hasTangent) {\n v_Tangent = normalize((worldInverseTranspose * vec4(skinnedTangent, 0.0)).xyz);\n v_Bitangent = normalize(cross(v_Normal, v_Tangent) * tangent.w);\n }\n v_WorldPosition = (world * vec4(skinnedPosition, 1.0)).xyz;\n#endif\n}\n@end\n@export clay.deferred.gbuffer1.fragment\nuniform mat4 viewInverse : VIEWINVERSE;\nuniform float glossiness;\nvarying vec2 v_Texcoord;\nvarying vec3 v_Normal;\nvarying vec3 v_WorldPosition;\nuniform sampler2D normalMap;\nvarying vec3 v_Tangent;\nvarying vec3 v_Bitangent;\nuniform sampler2D roughGlossMap;\nuniform bool useRoughGlossMap;\nuniform bool useRoughness;\nuniform bool doubleSided;\nuniform int roughGlossChannel: 0;\nfloat indexingTexel(in vec4 texel, in int idx) {\n if (idx == 3) return texel.a;\n else if (idx == 1) return texel.g;\n else if (idx == 2) return texel.b;\n else return texel.r;\n}\nvoid main()\n{\n vec3 N = v_Normal;\n if (doubleSided) {\n vec3 eyePos = viewInverse[3].xyz;\n vec3 V = eyePos - v_WorldPosition;\n if (dot(N, V) < 0.0) {\n N = -N;\n }\n }\n if (dot(v_Tangent, v_Tangent) > 0.0) {\n vec3 normalTexel = texture2D(normalMap, v_Texcoord).xyz;\n if (dot(normalTexel, normalTexel) > 0.0) { N = normalTexel * 2.0 - 1.0;\n mat3 tbn = mat3(v_Tangent, v_Bitangent, v_Normal);\n N = normalize(tbn * N);\n }\n }\n gl_FragColor.rgb = (N + 1.0) * 0.5;\n float g = glossiness;\n if (useRoughGlossMap) {\n float g2 = indexingTexel(texture2D(roughGlossMap, v_Texcoord), roughGlossChannel);\n if (useRoughness) {\n g2 = 1.0 - g2;\n }\n g = clamp(g2 + (g - 0.5) * 2.0, 0.0, 1.0);\n }\n gl_FragColor.a = g + 0.005;\n}\n@end\n@export clay.deferred.gbuffer2.fragment\nuniform sampler2D diffuseMap;\nuniform sampler2D metalnessMap;\nuniform vec3 color;\nuniform float metalness;\nuniform bool useMetalnessMap;\nuniform bool linear;\nvarying vec2 v_Texcoord;\n@import clay.util.srgb\nvoid main ()\n{\n float m = metalness;\n if (useMetalnessMap) {\n vec4 metalnessTexel = texture2D(metalnessMap, v_Texcoord);\n m = clamp(metalnessTexel.r + (m * 2.0 - 1.0), 0.0, 1.0);\n }\n vec4 texel = texture2D(diffuseMap, v_Texcoord);\n if (linear) {\n texel = sRGBToLinear(texel);\n }\n gl_FragColor.rgb = texel.rgb * color;\n gl_FragColor.a = m + 0.005;\n}\n@end\n@export clay.deferred.gbuffer.debug\n@import clay.deferred.chunk.light_head\nuniform int debug: 0;\nvoid main ()\n{\n @import clay.deferred.chunk.gbuffer_read\n if (debug == 0) {\n gl_FragColor = vec4(N, 1.0);\n }\n else if (debug == 1) {\n gl_FragColor = vec4(vec3(z), 1.0);\n }\n else if (debug == 2) {\n gl_FragColor = vec4(position, 1.0);\n }\n else if (debug == 3) {\n gl_FragColor = vec4(vec3(glossiness), 1.0);\n }\n else if (debug == 4) {\n gl_FragColor = vec4(vec3(metalness), 1.0);\n }\n else {\n gl_FragColor = vec4(albedo, 1.0);\n }\n}\n@end"), +K.import("@export clay.deferred.chunk.light_head\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture2;\nuniform sampler2D gBufferTexture3;\nuniform vec2 windowSize: WINDOW_SIZE;\nuniform vec4 viewport: VIEWPORT;\nuniform mat4 viewProjectionInv;\n#ifdef DEPTH_ENCODED\n@import clay.util.decode_float\n#endif\n@end\n@export clay.deferred.chunk.gbuffer_read\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec2 uv2 = (gl_FragCoord.xy - viewport.xy) / viewport.zw;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n vec4 texel3 = texture2D(gBufferTexture3, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n float glossiness = texel1.a;\n float metalness = texel3.a;\n vec3 N = texel1.rgb * 2.0 - 1.0;\n float z = texture2D(gBufferTexture2, uv).r * 2.0 - 1.0;\n vec2 xy = uv2 * 2.0 - 1.0;\n vec4 projectedPos = vec4(xy, z, 1.0);\n vec4 p4 = viewProjectionInv * projectedPos;\n vec3 position = p4.xyz / p4.w;\n vec3 albedo = texel3.rgb;\n vec3 diffuseColor = albedo * (1.0 - metalness);\n vec3 specularColor = mix(vec3(0.04), albedo, metalness);\n@end\n@export clay.deferred.chunk.light_equation\nfloat D_Phong(in float g, in float ndh) {\n float a = pow(8192.0, g);\n return (a + 2.0) / 8.0 * pow(ndh, a);\n}\nfloat D_GGX(in float g, in float ndh) {\n float r = 1.0 - g;\n float a = r * r;\n float tmp = ndh * ndh * (a - 1.0) + 1.0;\n return a / (3.1415926 * tmp * tmp);\n}\nvec3 F_Schlick(in float ndv, vec3 spec) {\n return spec + (1.0 - spec) * pow(1.0 - ndv, 5.0);\n}\nvec3 lightEquation(\n in vec3 lightColor, in vec3 diffuseColor, in vec3 specularColor,\n in float ndl, in float ndh, in float ndv, in float g\n)\n{\n return ndl * lightColor\n * (diffuseColor + D_Phong(g, ndh) * F_Schlick(ndv, specularColor));\n}\n@end");var na=Pe.extend(function(){return{enableTargetTexture1:!0,enableTargetTexture2:!0,enableTargetTexture3:!0,renderTransparent:!1,_renderList:[],_gBufferTex1:new Pn({minFilter:lr.NEAREST,magFilter:lr.NEAREST,type:lr.HALF_FLOAT}),_gBufferTex2:new Pn({minFilter:lr.NEAREST,magFilter:lr.NEAREST,format:lr.DEPTH_STENCIL,type:lr.UNSIGNED_INT_24_8_WEBGL}),_gBufferTex3:new Pn({minFilter:lr.NEAREST,magFilter:lr.NEAREST}),_defaultNormalMap:new Pn({image:Tt("#000")}),_defaultRoughnessMap:new Pn({image:Tt("#fff")}),_defaultMetalnessMap:new Pn({image:Tt("#fff")}),_defaultDiffuseMap:new Pn({image:Tt("#fff")}),_frameBuffer:new bi,_gBufferMaterial1:new vr({shader:new K(K.source("clay.deferred.gbuffer.vertex"),K.source("clay.deferred.gbuffer1.fragment")),vertexDefines:{FIRST_PASS:null},fragmentDefines:{FIRST_PASS:null}}),_gBufferMaterial2:new vr({shader:new K(K.source("clay.deferred.gbuffer.vertex"),K.source("clay.deferred.gbuffer2.fragment"))}),_debugPass:new Mi({fragment:K.source("clay.deferred.gbuffer.debug")})}},{resize:function(t,e){this._gBufferTex1.width===t&&this._gBufferTex1.height===e||(this._gBufferTex1.width=t,this._gBufferTex1.height=e,this._gBufferTex2.width=t,this._gBufferTex2.height=e,this._gBufferTex3.width=t,this._gBufferTex3.height=e)},setViewport:function(t,e,r,n,i){var a;a="object"==typeof t?t:{x:t,y:e,width:r,height:n,devicePixelRatio:i||1},this._frameBuffer.viewport=a},getViewport:function(){return this._frameBuffer.viewport?this._frameBuffer.viewport:{x:0,y:0,width:this._gBufferTex1.width,height:this._gBufferTex1.height,devicePixelRatio:1}},update:function(t,e,r){for(var n=t.gl,i=this._frameBuffer,a=i.viewport,o=e.opaqueList,s=e.transparentList,u=0,l=this._renderList,c=0;c= shadowCascadeClipsNear[_idx_] &&\n z <= shadowCascadeClipsFar[_idx_]\n ) {\n shadowContrib = computeShadowContrib(\n lightShadowMap, lightMatrices[_idx_], position, lightShadowMapSize,\n vec2(1.0 / float(SHADOW_CASCADE), 1.0),\n vec2(float(_idx_) / float(SHADOW_CASCADE), 0.0)\n );\n }\n }}\n gl_FragColor.rgb *= shadowContrib;\n#endif\n gl_FragColor.a = 1.0;\n}\n@end\n"),K.import("@export clay.deferred.ambient_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec2 windowSize: WINDOW_SIZE;\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo;\n gl_FragColor.a = 1.0;\n}\n@end"),K.import("@export clay.deferred.ambient_sh_light\nuniform sampler2D gBufferTexture1;\nuniform sampler2D gBufferTexture3;\nuniform vec3 lightColor;\nuniform vec3 lightCoefficients[9];\nuniform vec2 windowSize: WINDOW_SIZE;\nvec3 calcAmbientSHLight(vec3 N) {\n return lightCoefficients[0]\n + lightCoefficients[1] * N.x\n + lightCoefficients[2] * N.y\n + lightCoefficients[3] * N.z\n + lightCoefficients[4] * N.x * N.z\n + lightCoefficients[5] * N.z * N.y\n + lightCoefficients[6] * N.y * N.x\n + lightCoefficients[7] * (3.0 * N.z * N.z - 1.0)\n + lightCoefficients[8] * (N.x * N.x - N.y * N.y);\n}\nvoid main()\n{\n vec2 uv = gl_FragCoord.xy / windowSize;\n vec4 texel1 = texture2D(gBufferTexture1, uv);\n if (dot(texel1.rgb, vec3(1.0)) == 0.0) {\n discard;\n }\n vec3 N = texel1.rgb * 2.0 - 1.0;\n vec3 albedo = texture2D(gBufferTexture3, uv).rgb;\n gl_FragColor.rgb = lightColor * albedo * calcAmbientSHLight(N);\n gl_FragColor.a = 1.0;\n}\n@end"),K.import("@export clay.deferred.ambient_cubemap_light\n@import clay.deferred.chunk.light_head\nuniform vec3 lightColor;\nuniform samplerCube lightCubemap;\nuniform sampler2D brdfLookup;\nuniform vec3 eyePosition;\n@import clay.util.rgbm\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 V = normalize(eyePosition - position);\n vec3 L = reflect(-V, N);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float rough = clamp(1.0 - glossiness, 0.0, 1.0);\n float bias = rough * 5.0;\n vec2 brdfParam = texture2D(brdfLookup, vec2(rough, ndv)).xy;\n vec3 envWeight = specularColor * brdfParam.x + brdfParam.y;\n vec3 envTexel = RGBMDecode(textureCubeLodEXT(lightCubemap, L, bias), 51.5);\n gl_FragColor.rgb = lightColor * envTexel * envWeight;\n gl_FragColor.a = 1.0;\n}\n@end"),K.import("@export clay.deferred.point_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 eyePosition;\n#ifdef SHADOWMAP_ENABLED\nuniform samplerCube lightShadowMap;\nuniform float lightShadowMapSize;\n#endif\nvarying vec3 v_Position;\n@import clay.plugin.shadow_map_common\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n#ifdef SHADOWMAP_ENABLED\n float shadowContrib = computeShadowContribOmni(\n lightShadowMap, -L * dist, lightRange\n );\n gl_FragColor.rgb *= clamp(shadowContrib, 0.0, 1.0);\n#endif\n gl_FragColor.a = 1.0;\n}\n@end"),K.import("@export clay.deferred.sphere_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform float lightRadius;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n float dist = length(L);\n vec3 R = reflect(V, N);\n float tmp = dot(L, R);\n vec3 cToR = tmp * R - L;\n float d = length(cToR);\n L = L + cToR * clamp(lightRadius / d, 0.0, 1.0);\n L = normalize(L);\n vec3 H = normalize(L + V);\n float ndl = clamp(dot(N, L), 0.0, 1.0);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n float attenuation = lightAttenuation(dist, lightRange);\n gl_FragColor.rgb = lightColor * ndl * attenuation;\n glossiness = clamp(glossiness - lightRadius / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = attenuation * lightEquation(\n lightColor, diffuseColor, specularColor, ndl, ndh, ndv, glossiness\n );\n gl_FragColor.a = 1.0;\n}\n@end"),K.import("@export clay.deferred.tube_light\n@import clay.deferred.chunk.light_head\n@import clay.util.calculate_attenuation\n@import clay.deferred.chunk.light_equation\nuniform vec3 lightPosition;\nuniform vec3 lightColor;\nuniform float lightRange;\nuniform vec3 lightExtend;\nuniform vec3 eyePosition;\nvarying vec3 v_Position;\nvoid main()\n{\n @import clay.deferred.chunk.gbuffer_read\n vec3 L = lightPosition - position;\n vec3 V = normalize(eyePosition - position);\n vec3 R = reflect(V, N);\n vec3 L0 = lightPosition - lightExtend - position;\n vec3 L1 = lightPosition + lightExtend - position;\n vec3 LD = L1 - L0;\n float len0 = length(L0);\n float len1 = length(L1);\n float irra = 2.0 * clamp(dot(N, L0) / (2.0 * len0) + dot(N, L1) / (2.0 * len1), 0.0, 1.0);\n float LDDotR = dot(R, LD);\n float t = (LDDotR * dot(R, L0) - dot(L0, LD)) / (dot(LD, LD) - LDDotR * LDDotR);\n t = clamp(t, 0.0, 1.0);\n L = L0 + t * LD;\n float dist = length(L);\n L /= dist;\n vec3 H = normalize(L + V);\n float ndh = clamp(dot(N, H), 0.0, 1.0);\n float ndv = clamp(dot(N, V), 0.0, 1.0);\n glossiness = clamp(glossiness - 0.0 / 2.0 / dist, 0.0, 1.0);\n gl_FragColor.rgb = lightColor * irra * lightAttenuation(dist, lightRange)\n * (diffuseColor + D_Phong(glossiness, ndh) * F_Schlick(ndv, specularColor));\n gl_FragColor.a = 1.0;\n}\n@end"),K.import(kr);var ia=Pe.extend(function(){var t=K.source("clay.compositor.vertex"),e=K.source("clay.deferred.light_volume.vertex"),r=new K(t,K.source("clay.deferred.directional_light")),n=function(t){t.blendEquation(t.FUNC_ADD),t.blendFunc(t.ONE,t.ONE)},i=function(t){return new vr({shader:t,blend:n,transparent:!0,depthMask:!1})},a=function(t){return new K(e,K.source("clay.deferred."+t))},o=new ea({capSegments:10}),s=new ar;s.rotateX(Math.PI/2).translate(new Xe(0,-1,0)),o.applyTransform(s);var u=new ra({capSegments:10});return s.identity().rotateZ(Math.PI/2),u.applyTransform(s),{shadowMapPass:null,autoResize:!0,_createLightPassMat:i,_gBuffer:new na,_lightAccumFrameBuffer:new bi({depthBuffer:!1}),_lightAccumTex:new Pn({type:lr.HALF_FLOAT,minFilter:lr.NEAREST,magFilter:lr.NEAREST}),_fullQuadPass:new Mi({blendWithPrevious:!0}),_directionalLightMat:i(r),_ambientMat:i(new K(t,K.source("clay.deferred.ambient_light"))),_ambientSHMat:i(new K(t,K.source("clay.deferred.ambient_sh_light"))),_ambientCubemapMat:i(new K(t,K.source("clay.deferred.ambient_cubemap_light"))),_spotLightShader:a("spot_light"),_pointLightShader:a("point_light"),_sphereLightShader:a("sphere_light"),_tubeLightShader:a("tube_light"),_lightSphereGeo:new Cn({widthSegments:10,heightSegements:10}),_lightConeGeo:o,_lightCylinderGeo:u,_outputPass:new Mi({fragment:K.source("clay.compositor.output")})}},{render:function(t,e,r,n){n=n||{},n.renderToTarget=n.renderToTarget||!1,n.notUpdateShadow=n.notUpdateShadow||!1,n.notUpdateScene=n.notUpdateScene||!1,n.notUpdateScene||e.update(!1,!0),r.update(!0);var i=t.getDevicePixelRatio();!this.autoResize||t.getWidth()*i===this._lightAccumTex.width&&t.getHeight()*i===this._lightAccumTex.height||this.resize(t.getWidth()*i,t.getHeight()*i),this._gBuffer.update(t,e,r),this._accumulateLightBuffer(t,e,r,!n.notUpdateShadow),n.renderToTarget||(this._outputPass.setUniform("texture",this._lightAccumTex),this._outputPass.render(t))},getTargetTexture:function(){return this._lightAccumTex},getTargetFrameBuffer:function(){return this._lightAccumFrameBuffer},getGBuffer:function(){return this._gBuffer},setViewport:function(t,e,r,n,i){this._gBuffer.setViewport(t,e,r,n,i),this._lightAccumFrameBuffer.viewport=this._gBuffer.getViewport()},resize:function(t,e){this._lightAccumTex.width=t,this._lightAccumTex.height=e,this._gBuffer.resize(t,e)},_accumulateLightBuffer:function(t,e,r,n){for(var i=t.gl,a=this._lightAccumTex,o=this._lightAccumFrameBuffer,s=r.getWorldPosition().array,u=0;u=0){var l="touchend"!=u?i.targetTouches[0]:i.changedTouches[0];"touchstart"===u?u="mousedown":"touchend"===u?u="mouseup":"touchmove"===u&&(u="mousemove"),a=l.clientX-s.left,o=l.clientY-s.top}else a=i.clientX-s.left,o=i.clientY-s.top;var c,h=t.pick(a,o);if("DOMMouseScroll"!==u&&"mousewheel"!==u||(c=i.wheelDelta?i.wheelDelta/120:-(i.detail||0)/3),h){if(h.target.silent)return;if("mousemove"===u){var f=h.target!==r;f&&r&&Pt(r,Lt("mouseout",{target:r},a,o)),Pt(h.target,Lt("mousemove",h,a,o)),f&&Pt(h.target,Lt("mouseover",h,a,o))}else Pt(h.target,Lt(u,h,a,o,c));r=h.target}else r&&(Pt(r,Lt("mouseout",{target:r},a,o)),r=null)}})},this)},Mt.prototype._updateGraphicOptions=function(t,e,r){for(var n,i=!!t.tonemapping,a=!!t.linear,o=0;o0,l=e.color;e.depth=0,u&&va.set(l,0,0,0,0);for(var c=!0,h=1/n,f=0;f-g&&m-g&&p-g&&_0){var _=f[0],b=(_[0]+1)*u,A=(1-_[1])*l;e.fillStyle=p,"rectangle"===T?e.fillRect(b-E,A-E,x,x):"circle"===T&&(e.beginPath(),e.arc(b,A,E,0,2*Math.PI),e.fill())}}}e.restore()},dispose:function(){this._triangles.clear(),this._lines.clear(),this._points.clear(),this._primitives=[],this.ctx=null,this.canvas=null}}),Ea=Pe.extend(function(){return{name:"",inputLinks:{},outputLinks:{},_prevOutputTextures:{},_outputTextures:{},_outputReferences:{},_rendering:!1,_rendered:!1,_compositor:null}},{updateParameter:function(t,e){var r=this.outputs[t],n=r.parameters,i=r._parametersCopy;if(i||(i=r._parametersCopy={}),n)for(var a in n)"width"!==a&&"height"!==a&&(i[a]=n[a]);var o,s;return o=n.width instanceof Function?n.width.call(this,e):n.width,s=n.height instanceof Function?n.height.call(this,e):n.height,i.width===o&&i.height===s||this._outputTextures[t]&&this._outputTextures[t].dispose(e.gl),i.width=o,i.height=s,i},setParameter:function(t,e){},getParameter:function(t){},setParameters:function(t){for(var e in t)this.setParameter(e,t[e])},render:function(){},getOutput:function(t,e){if(null==e)return e=t,this._outputTextures[e];var r=this.outputs[e];if(r)return this._rendered?r.outputLastFrame?this._prevOutputTextures[e]:this._outputTextures[e]:this._rendering?(this._prevOutputTextures[e]||(this._prevOutputTextures[e]=this._compositor.allocateTexture(r.parameters||{})),this._prevOutputTextures[e]):(this.render(t),this._outputTextures[e])},removeReference:function(t){if(0===--this._outputReferences[t]){this.outputs[t].keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}},link:function(t,e,r){this.inputLinks[t]={node:e,pin:r},e.outputLinks[r]||(e.outputLinks[r]=[]),e.outputLinks[r].push({node:this,pin:t}),this.pass.material.enableTexture(t)},clear:function(){this.inputLinks={},this.outputLinks={}},updateReference:function(t){if(!this._rendering){this._rendering=!0;for(var e in this.inputLinks){var r=this.inputLinks[e];r.node.updateReference(r.pin)}this._rendering=!1}t&&this._outputReferences[t]++},beforeFrame:function(){this._rendered=!1;for(var t in this.outputLinks)this._outputReferences[t]=0},afterFrame:function(){for(var t in this.outputLinks)if(this._outputReferences[t]>0){var e=this.outputs[t];e.keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}}}),ba=Pe.extend(function(){return{nodes:[]}},{dirty:function(){this._dirty=!0},addNode:function(t){this.nodes.indexOf(t)>=0||(this.nodes.push(t),this._dirty=!0)},removeNode:function(t){"string"==typeof t&&(t=this.getNodeByName(t));var e=this.nodes.indexOf(t);e>=0&&(this.nodes.splice(e,1),this._dirty=!0)},getNodeByName:function(t){for(var e=0;e=e.COLOR_ATTACHMENT0&&u<=e.COLOR_ATTACHMENT0+8&&c.push(u);l.drawBuffersEXT(c)}t.saveClear(),t.clearBit=He.DEPTH_BUFFER_BIT|He.COLOR_BUFFER_BIT,r=t.render(this.scene,this.camera,!this.autoUpdateScene,this.preZ),t.restoreClear(),n.unbind(t)}else r=t.render(this.scene,this.camera,!this.autoUpdateScene,this.preZ);this.trigger("afterrender",r),this._rendering=!1,this._rendered=!0}}),wa=Ea.extend(function(){return{texture:null,outputs:{color:{}}}},function(){},{getOutput:function(t,e){return this.texture},beforeFrame:function(){},afterFrame:function(){}}),Ma=Ea.extend(function(){return{name:"",inputs:{},outputs:null,shader:"",inputLinks:{},outputLinks:{},pass:null,_prevOutputTextures:{},_outputTextures:{},_outputReferences:{},_rendering:!1,_rendered:!1,_compositor:null}},function(){var t=new Mi({fragment:this.shader});this.pass=t},{render:function(t,e){this.trigger("beforerender",t),this._rendering=!0;var r=t.gl;for(var n in this.inputLinks){var i=this.inputLinks[n],a=i.node.getOutput(t,i.pin);this.pass.setUniform(n,a)}if(this.outputs){this.pass.outputs={};var o={};for(var s in this.outputs){var u=this.updateParameter(s,t);isNaN(u.width)&&this.updateParameter(s,t);var l=this.outputs[s],c=this._compositor.allocateTexture(u);this._outputTextures[s]=c;var h=l.attachment||r.COLOR_ATTACHMENT0;"string"==typeof h&&(h=r[h]),o[h]=c}this._compositor.getFrameBuffer().bind(t);for(var h in o)this._compositor.getFrameBuffer().attach(o[h],h);this.pass.render(t),this._compositor.getFrameBuffer().updateMipmap(t.gl)}else this.pass.outputs=null,this._compositor.getFrameBuffer().unbind(t),this.pass.render(t,e);for(var n in this.inputLinks){var i=this.inputLinks[n];i.node.removeReference(i.pin)}this._rendering=!1,this._rendered=!0,this.trigger("afterrender",t)},updateParameter:function(t,e){var r=this.outputs[t],n=r.parameters,i=r._parametersCopy;if(i||(i=r._parametersCopy={}),n)for(var a in n)"width"!==a&&"height"!==a&&(i[a]=n[a]);var o,s;return o=n.width instanceof Function?n.width.call(this,e):n.width,s=n.height instanceof Function?n.height.call(this,e):n.height,i.width===o&&i.height===s||this._outputTextures[t]&&this._outputTextures[t].dispose(e),i.width=o,i.height=s,i},setParameter:function(t,e){this.pass.setUniform(t,e)},getParameter:function(t){return this.pass.getUniform(t)},setParameters:function(t){for(var e in t)this.setParameter(e,t[e])},define:function(t,e){this.pass.material.define("fragment",t,e)},undefine:function(t){this.pass.material.undefine("fragment",t)},removeReference:function(t){if(0===--this._outputReferences[t]){this.outputs[t].keepLastFrame?(this._prevOutputTextures[t]&&this._compositor.releaseTexture(this._prevOutputTextures[t]),this._prevOutputTextures[t]=this._outputTextures[t]):this._compositor.releaseTexture(this._outputTextures[t])}},clear:function(){Ea.prototype.clear.call(this),this.pass.material.disableTexturesAll()}}),Ca=/^#source\((.*?)\)/,Na=$r.extend({range:100,radius:5},{type:"SPHERE_LIGHT",uniformTemplates:{sphereLightPosition:{type:"3f",value:function(t){return t.getWorldPosition().array}},sphereLightRange:{type:"1f",value:function(t){return t.range}},sphereLightRadius:{type:"1f",value:function(t){return t.radius}},sphereLightColor:{type:"3f",value:function(t){var e=t.color,r=t.intensity;return[e[0]*r,e[1]*r,e[2]*r]}}}}),Ra=$r.extend({range:100,length:10},{type:"TUBE_LIGHT",uniformTemplates:{tubeLightPosition:{type:"3f",value:function(t){return t.getWorldPosition().array}},tubeLightExtend:{type:"3f",value:function(){var t=new Xe;return function(e){return t.copy(e.worldTransform.x).normalize().scale(e.length/2).array}}()},tubeLightRange:{type:"1f",value:function(t){return t.range}},tubeLightColor:{type:"3f",value:function(t){var e=t.color,r=t.intensity;return[e[0]*r,e[1]*r,e[2]*r]}}}}),La=Pe.extend({rootPath:"",textureRootPath:"",shaderRootPath:"",scene:null,camera:null},{load:function(t){var e=this;this.rootPath||(this.rootPath=t.slice(0,t.lastIndexOf("/"))),Yn.get({url:t,onprogress:function(t,r,n){e.trigger("progress",t,r,n)},onerror:function(t){e.trigger("error",t)},responseType:"text",onload:function(t){qt(JSON.parse(t),{textureRootPath:this.textureRootPath||this.rootPath,camera:this.camera,scene:this.scene})}})}}),Pa=pe.mat2,Da=function(){this.array=Pa.create(),this._dirty=!0};Da.prototype={constructor:Da,setArray:function(t){for(var e=0;e0&&Qa.scaleAndAdd(t.array,t.array,this.force.array,n/r)}});K.import("@export clay.particle.vertex\nuniform mat4 worldView : WORLDVIEW;\nuniform mat4 projection : PROJECTION;\nattribute vec3 position : POSITION;\nattribute vec3 normal : NORMAL;\n#ifdef UV_ANIMATION\nattribute vec2 texcoord0 : TEXCOORD_0;\nattribute vec2 texcoord1 : TEXCOORD_1;\nvarying vec2 v_Uv0;\nvarying vec2 v_Uv1;\n#endif\nvarying float v_Age;\nvoid main() {\n v_Age = normal.x;\n float rotation = normal.y;\n vec4 worldViewPosition = worldView * vec4(position, 1.0);\n gl_Position = projection * worldViewPosition;\n float w = gl_Position.w;\n gl_PointSize = normal.z * projection[0].x / w;\n #ifdef UV_ANIMATION\n v_Uv0 = texcoord0;\n v_Uv1 = texcoord1;\n #endif\n}\n@end\n@export clay.particle.fragment\nuniform sampler2D sprite;\nuniform sampler2D gradient;\nuniform vec3 color : [1.0, 1.0, 1.0];\nuniform float alpha : 1.0;\nvarying float v_Age;\n#ifdef UV_ANIMATION\nvarying vec2 v_Uv0;\nvarying vec2 v_Uv1;\n#endif\nvoid main() {\n vec4 color = vec4(color, alpha);\n #ifdef SPRITE_ENABLED\n #ifdef UV_ANIMATION\n color *= texture2D(sprite, mix(v_Uv0, v_Uv1, gl_PointCoord));\n #else\n color *= texture2D(sprite, gl_PointCoord);\n #endif\n #endif\n #ifdef GRADIENT_ENABLED\n color *= texture2D(gradient, vec2(v_Age, 0.5));\n #endif\n gl_FragColor = color;\n}\n@end");var to=new K(K.source("clay.particle.vertex"),K.source("clay.particle.fragment")),eo=zn.extend({loop:!0,oneshot:!1,duration:1,spriteAnimationTileX:1,spriteAnimationTileY:1,spriteAnimationRepeat:0,mode:zn.POINTS,ignorePicking:!0,_elapsedTime:0,_emitting:!0},function(){this.geometry=new An({dynamic:!0}),this.material||(this.material=new vr({shader:to,transparent:!0,depthMask:!1}),this.material.enableTexture("sprite")),this._particles=[],this._fields=[],this._emitters=[]},{culling:!1,frustumCulling:!1,castShadow:!1,receiveShadow:!1,addEmitter:function(t){this._emitters.push(t)},removeEmitter:function(t){this._emitters.splice(this._emitters.indexOf(t),1)},addField:function(t){this._fields.push(t)},removeField:function(t){this._fields.splice(this._fields.indexOf(t),1)},reset:function(){for(var t=0;t=i.life?(i.emitter.kill(i),e[r]=e[n-1],e.pop(),n--):r++}for(var r=0;r0)for(var a=0;a1,o=t.attributes.position.value,s=t.attributes.normal.value,u=t.attributes.texcoord0.value,l=t.attributes.texcoord1.value,c=this._particles.length;o&&o.length===3*c||(o=t.attributes.position.value=new Float32Array(3*c),s=t.attributes.normal.value=new Float32Array(3*c),a&&(u=t.attributes.texcoord0.value=new Float32Array(2*c),l=t.attributes.texcoord1.value=new Float32Array(2*c)));for(var h=1/e,f=0;fthis.duration&&!this.loop},dispose:function(t){for(var e=0;e1&&n&&n.length>1){var a=re(n)/re(i);!isFinite(a)&&(a=1),e.pinchScale=a;var o=ne(n);return e.pinchX=o[0],e.pinchY=o[1],{type:"pinch",target:t[0].target,event:e}}}}},oo=[[0,0],[0,1],[1,1],[1,0]],so=[0,1,2,2,3,0],uo=Xn.extend({camera:null,plane:null,maxGrid:0,frustumCulling:!1},function(){var t=this.geometry=new An({dynamic:!0});t.attributes.position.init(6),t.attributes.normal.init(6),t.attributes.texcoord0.init(6),t.indices=new Uint16Array(6),this.plane=new nn},{updateGeometry:function(){var t=this._unProjectGrid();if(t){for(var e=this.geometry.attributes.position,r=this.geometry.attributes.normal,n=this.geometry.attributes.texcoord0,i=this.geometry.indices,a=0;a<6;a++){var o=so[a];e.set(a,t[o].array),r.set(a,this.plane.normal.array),n.set(a,oo[o]),i[a]=a}this.geometry.dirty()}},_unProjectGrid:function(){for(var t=new nn,e=[0,1,0,2,1,3,2,3,4,5,4,6,5,7,6,7,0,4,1,5,2,6,3,7],r=new Xe,n=new Xe,i=[],a=[],o=0;o<4;o++)a[o]=new Xe(0,0);var s=new dn;return function(){t.copy(this.plane),t.applyTransform(this.camera.viewMatrix);for(var o=this.camera.frustum.vertices,u=0,l=0;l<12;l++){r.array=o[e[2*l]],n.array=o[e[2*l+1]];var c=t.intersectLine(r,n,i[u]);c&&(i[u]||(i[u]=c),u++)}if(0!==u){for(var l=0;l0},update:function(t){if(t=t||16,this._rotating){var e=("cw"===this.autoRotateDirection?1:-1)*this.autoRotateSpeed/180*Math.PI;this._phi-=e*t/1e3,this._needsUpdate=!0}else this._rotateVelocity.len()>0&&(this._needsUpdate=!0);(Math.abs(this._zoomSpeed)>.01||this._panVelocity.len()>0)&&(this._needsUpdate=!0),this._needsUpdate&&(this._updateDistance(Math.min(t,50)),this._updatePan(Math.min(t,50)),this._updateRotate(Math.min(t,50)),this._updateTransform(),this.target.update(),this.trigger("update"),this._needsUpdate=!1)},_updateRotate:function(t){var e=this._rotateVelocity;this._phi=e.y*t/20+this._phi,this._theta=e.x*t/20+this._theta,this.setAlpha(this.getAlpha()),this.setBeta(this.getBeta()),this._vectorDamping(e,this.damping)},_updateDistance:function(t){this._setDistance(this._distance+this._zoomSpeed*t/20),this._zoomSpeed*=this.damping},_setDistance:function(t){this._distance=Math.max(Math.min(t,this.maxDistance),this.minDistance)},_updatePan:function(t){var e=this._panVelocity,r=this._distance,n=this.target,i=n.worldTransform.y,a=n.worldTransform.x;this._center.scaleAndAdd(a,-e.x*r/200).scaleAndAdd(i,-e.y*r/200),this._vectorDamping(e,0)},_updateTransform:function(){var t=this.target,e=new Xe,r=this._theta+Math.PI/2,n=this._phi+Math.PI/2,i=Math.sin(r);e.x=i*Math.cos(n),e.y=-Math.cos(r),e.z=i*Math.sin(n),t.position.copy(this._center).scaleAndAdd(e,this._distance),t.rotation.identity().rotateY(-this._phi).rotateX(-this._theta)},_startCountingStill:function(){clearTimeout(this._stillTimeout);var t=this.autoRotateAfterStill,e=this;!isNaN(t)&&t>0&&(this._stillTimeout=setTimeout(function(){e._rotating=!0},1e3*t))},_vectorDamping:function(t,e){var r=t.len();r*=e,r<1e-4&&(r=0),t.normalize().scale(r)},decomposeTransform:function(){if(this.target){this.target.updateWorldTransform();var t=this.target.worldTransform.z,e=Math.asin(t.y),r=Math.atan2(t.x,t.z);this._theta=e,this._phi=-r,this.setBeta(this.getBeta()),this.setAlpha(this.getAlpha()),this._setDistance(this.target.position.dist(this._center))}},_mouseDownHandler:function(t){if(!this._isAnimating()){var e=t.clientX,r=t.clientY;if(t.targetTouches){var n=t.targetTouches[0];e=n.clientX,r=n.clientY,this._mode="rotate",this._processGesture(t,"start")}var i=this.domElement;i.addEventListener("touchmove",this._mouseMoveHandler),i.addEventListener("touchend",this._mouseUpHandler),i.addEventListener("mousemove",this._mouseMoveHandler),i.addEventListener("mouseup",this._mouseUpHandler),0===t.button?this._mode="rotate":1===t.button&&(this._mode="pan"),this._rotateVelocity.set(0,0),this._rotating=!1,this.autoRotate&&this._startCountingStill(),this._mouseX=e,this._mouseY=r}},_mouseMoveHandler:function(t){if(!this._isAnimating()){var e,r=t.clientX,n=t.clientY;if(t.targetTouches){var i=t.targetTouches[0];r=i.clientX,n=i.clientY,e=this._processGesture(t,"change")}var a=ie(this.panSensitivity),o=ie(this.rotateSensitivity);e||("rotate"===this._mode?(this._rotateVelocity.y=(r-this._mouseX)/this.domElement.clientHeight*2*o[0],this._rotateVelocity.x=(n-this._mouseY)/this.domElement.clientWidth*2*o[1]):"pan"===this._mode&&(this._panVelocity.x=(r-this._mouseX)/this.domElement.clientWidth*a[0]*400,this._panVelocity.y=(-n+this._mouseY)/this.domElement.clientHeight*a[1]*400)),this._mouseX=r,this._mouseY=n,t.preventDefault()}},_mouseWheelHandler:function(t){if(!this._isAnimating()){var e=t.wheelDelta||-t.detail;0!==e&&this._zoomHandler(t,e>0?-1:1)}},_pinchHandler:function(t){this._isAnimating()||this._zoomHandler(t,t.pinchScale>1?-.4:.4)},_zoomHandler:function(t,e){var r=Math.max(Math.min(this._distance-this.minDistance,this.maxDistance-this._distance));this._zoomSpeed=e*Math.max(r/40*this.zoomSensitivity,.2),this._rotating=!1,this.autoRotate&&"rotate"===this._mode&&this._startCountingStill(),t.preventDefault()},_mouseUpHandler:function(t){var e=this.domElement;e.removeEventListener("touchmove",this._mouseMoveHandler),e.removeEventListener("touchend",this._mouseUpHandler),e.removeEventListener("mousemove",this._mouseMoveHandler),e.removeEventListener("mouseup",this._mouseUpHandler),this._processGesture(t,"end")},_addAnimator:function(t){var e=this._animators;return e.push(t),t.done(function(){var r=e.indexOf(t);r>=0&&e.splice(r,1)}),t},_processGesture:function(t,e){var r=this._gestureMgr;"start"===e&&r.clear();var n=r.recognize(t,null,this.domElement);if("end"===e&&r.clear(),n){var i=n.type;t.gestureEvent=i,this._pinchHandler(n.event)}return n}});Object.defineProperty(lo.prototype,"autoRotate",{get:function(){return this._autoRotate},set:function(t){this._autoRotate=t,this._rotating=t}}),Object.defineProperty(lo.prototype,"target",{get:function(){return this._target},set:function(t){t&&t.target&&this.setCenter(t.target.toArray()),this._target=t,this.decomposeTransform()}});var co=An.extend({dynamic:!1}),ho=pe.mat4,fo=pe.vec3,mo={merge:function(t,e){if(t.length){var r=t[0],n=r.geometry,i=r.material,a=new An({dynamic:!1});a.boundingBox=new tr;for(var o=n.getEnabledAttributes(),s=0;s=65535?new Uint32Array(3*f):new Uint16Array(3*f);for(var _=0,g=0,v=n.isUseIndices(),y=0;y0;){for(var _=[],g=[],v=[],y=0,f=0;f=0&&-1===g[S]&&(y65535?new Uint32Array(3*R.triangles.length):new Uint16Array(3*R.triangles.length);var G=0;O=0;for(var f=0;f=0?L[S]:-1}O++}D.indices[G++]=C[b]}D.updateBoundingBox(),w.add(I)}for(var j=t.children(),f=0;f0&&(r.indices=oe(t.indices,e),n.push(r.indices.buffer)),r.attributes={};for(var i in t.attributes)if(t.attributes.hasOwnProperty(i)){var a=t.attributes[i];a&&a.value&&a.value.length>0&&(a=r.attributes[i]=ae(a,e),n.push(a.value.buffer))}return{data:r,buffers:n}},toGeometry:function(t){if(!t)return null;if(t.data&&t.buffers)return _o.toGeometry(t.data);if(!t.metadata||t.metadata.generator!==po.generator)throw new Error("[util.transferable.toGeometry] the object is not generated by util.transferable.");var e={dynamic:t.dynamic,indices:t.indices};if(t.boundingBox){var r=(new Xe).setArray(t.boundingBox.min),n=(new Xe).setArray(t.boundingBox.max);e.boundingBox=new tr(r,n)}var i={};for(var a in t.attributes)if(t.attributes.hasOwnProperty(a)){var o=t.attributes[a];i[a]=new An.Attribute(o.name,o.type,o.size,o.semantic),i[a].value=o.value}return e.attributes=i,new An(e)}};K.import("@export clay.vr.disorter.output.vertex\nattribute vec2 texcoord: TEXCOORD_0;\nattribute vec3 position: POSITION;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n v_Texcoord = texcoord;\n gl_Position = vec4(position.xy, 0.5, 1.0);\n}\n@end\n@export clay.vr.disorter.output.fragment\nuniform sampler2D texture;\nvarying vec2 v_Texcoord;\nvoid main()\n{\n gl_FragColor = texture2D(texture, v_Texcoord);\n}\n@end");var go=Pe.extend(function(){return{clearColor:[0,0,0,1],_mesh:new Xn({geometry:new An({dynamic:!0}),culling:!1,material:new vr({depthTest:!1,shader:new K({vertex:K.source("clay.vr.disorter.output.vertex"),fragment:K.source("clay.vr.disorter.output.fragment")})})}),_fakeCamera:new jn}},{render:function(t,e){var r=this.clearColor,n=t.gl;n.clearColor(r[0],r[1],r[2],r[3]),n.clear(n.COLOR_BUFFER_BIT),n.disable(n.BLEND),this._mesh.material.set("texture",e),t.saveViewport(),t.setViewport(0,0,t.getWidth(),t.getHeight()),t.renderPass([this._mesh],this._fakeCamera),t.restoreViewport()},updateFromVRDisplay:function(t){t.deviceInfo_?this._updateMesh(20,20,t.deviceInfo_):console.warn("Cant get vrDisplay.deviceInfo_, seems code changed")},_updateMesh:function(t,e,r){var n=this._mesh.geometry.attributes.position,i=this._mesh.geometry.attributes.texcoord0;n.init(2*t*e),i.init(2*t*e);for(var a=r.getLeftEyeVisibleTanAngles(),o=r.getLeftEyeNoLensTanAngles(),s=r.getLeftEyeVisibleScreenRect(o),u=0,l=[],c=[],h=0;h<2;h++){for(var f=0;f